2012-05-18 09:02:29 +08:00
|
|
|
# Copyright 2012 OpenStack LLC.
|
|
|
|
# All Rights Reserved
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
# not use this file except in compliance with the License. You may obtain
|
|
|
|
# a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
# License for the specific language governing permissions and limitations
|
|
|
|
# under the License.
|
|
|
|
#
|
|
|
|
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
|
|
|
|
"""
|
|
|
|
Command-line interface to the Quantum APIs
|
|
|
|
"""
|
|
|
|
import argparse
|
|
|
|
import gettext
|
|
|
|
import itertools
|
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from cliff.app import App
|
|
|
|
from cliff.commandmanager import CommandManager
|
|
|
|
|
|
|
|
from quantumclient.common import clientmanager
|
|
|
|
from quantumclient.common import exceptions as exc
|
|
|
|
from quantumclient.common import utils
|
|
|
|
|
|
|
|
|
|
|
|
gettext.install('quantum', unicode=1)
|
|
|
|
VERSION = '2.0'
|
|
|
|
|
|
|
|
|
|
|
|
def env(*vars, **kwargs):
|
|
|
|
"""Search for the first defined of possibly many env vars
|
|
|
|
|
|
|
|
Returns the first environment variable defined in vars, or
|
|
|
|
returns the default defined in kwargs.
|
|
|
|
|
|
|
|
"""
|
|
|
|
for v in vars:
|
|
|
|
value = os.environ.get(v, None)
|
|
|
|
if value:
|
|
|
|
return value
|
|
|
|
return kwargs.get('default', '')
|
|
|
|
|
|
|
|
COMMAND_V1 = {
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-list': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.network.ListNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-show': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.network.ShowNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-create': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.network.CreateNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-delete': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.network.DeleteNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-update': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.network.UpdateNetwork'),
|
|
|
|
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-list': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.port.ListPort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-show': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.port.ShowPort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-create': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.port.CreatePort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-delete': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.port.DeletePort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-update': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.port.UpdatePort'),
|
|
|
|
|
2012-07-05 15:01:39 +08:00
|
|
|
'iface-plugin': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.interface.PlugInterface'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'iface-unplug': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.interface.UnPlugInterface'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'iface-show': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v1_1.interface.ShowInterface'), }
|
|
|
|
COMMAND_V2 = {
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-list': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.network.ListNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-show': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.network.ShowNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-create': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.network.CreateNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-delete': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.network.DeleteNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'net-update': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.network.UpdateNetwork'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'subnet-list': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.subnet.ListSubnet'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'subnet-show': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.subnet.ShowSubnet'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'subnet-create': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.subnet.CreateSubnet'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'subnet-delete': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.subnet.DeleteSubnet'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'subnet-update': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.subnet.UpdateSubnet'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-list': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.port.ListPort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-show': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.port.ShowPort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-create': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.port.CreatePort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-delete': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.port.DeletePort'),
|
2012-07-05 15:01:39 +08:00
|
|
|
'port-update': utils.import_class(
|
2012-05-18 09:02:29 +08:00
|
|
|
'quantumclient.quantum.v2_0.port.UpdatePort'), }
|
|
|
|
|
|
|
|
COMMANDS = {'1.0': COMMAND_V1,
|
|
|
|
'1.1': COMMAND_V1,
|
|
|
|
'2.0': COMMAND_V2, }
|
|
|
|
|
|
|
|
|
|
|
|
class HelpAction(argparse.Action):
|
|
|
|
"""Provide a custom action so the -h and --help options
|
|
|
|
to the main app will print a list of the commands.
|
|
|
|
|
|
|
|
The commands are determined by checking the CommandManager
|
|
|
|
instance, passed in as the "default" value for the action.
|
|
|
|
"""
|
|
|
|
def __call__(self, parser, namespace, values, option_string=None):
|
|
|
|
app = self.default
|
|
|
|
parser.print_help(app.stdout)
|
|
|
|
app.stdout.write('\nCommands for API v%s:\n' % app.api_version)
|
|
|
|
command_manager = app.command_manager
|
|
|
|
for name, ep in sorted(command_manager):
|
|
|
|
factory = ep.load()
|
|
|
|
cmd = factory(self, None)
|
|
|
|
one_liner = cmd.get_description().split('\n')[0]
|
|
|
|
app.stdout.write(' %-13s %s\n' % (name, one_liner))
|
|
|
|
sys.exit(0)
|
|
|
|
|
|
|
|
|
|
|
|
class QuantumShell(App):
|
|
|
|
|
|
|
|
CONSOLE_MESSAGE_FORMAT = '%(levelname)s: %(name)s %(message)s'
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
def __init__(self, apiversion):
|
|
|
|
super(QuantumShell, self).__init__(
|
|
|
|
description=__doc__.strip(),
|
|
|
|
version=VERSION,
|
|
|
|
command_manager=CommandManager('quantum.cli'), )
|
|
|
|
for k, v in COMMANDS[apiversion].items():
|
|
|
|
self.command_manager.add_command(k, v)
|
|
|
|
|
|
|
|
# This is instantiated in initialize_app() only when using
|
|
|
|
# password flow auth
|
|
|
|
self.auth_client = None
|
|
|
|
self.api_version = apiversion
|
|
|
|
|
|
|
|
def build_option_parser(self, description, version):
|
|
|
|
"""Return an argparse option parser for this application.
|
|
|
|
|
|
|
|
Subclasses may override this method to extend
|
|
|
|
the parser with more global options.
|
|
|
|
|
|
|
|
:param description: full description of the application
|
|
|
|
:paramtype description: str
|
|
|
|
:param version: version number for the application
|
|
|
|
:paramtype version: str
|
|
|
|
"""
|
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description=description,
|
|
|
|
add_help=False, )
|
|
|
|
parser.add_argument(
|
|
|
|
'--version',
|
|
|
|
action='version',
|
|
|
|
version='%(prog)s {0}'.format(version), )
|
|
|
|
parser.add_argument(
|
|
|
|
'-v', '--verbose',
|
|
|
|
action='count',
|
|
|
|
dest='verbose_level',
|
|
|
|
default=self.DEFAULT_VERBOSE_LEVEL,
|
|
|
|
help='Increase verbosity of output. Can be repeated.', )
|
|
|
|
parser.add_argument(
|
|
|
|
'-q', '--quiet',
|
|
|
|
action='store_const',
|
|
|
|
dest='verbose_level',
|
|
|
|
const=0,
|
|
|
|
help='suppress output except warnings and errors', )
|
|
|
|
parser.add_argument(
|
|
|
|
'-H', '--Help',
|
|
|
|
action=HelpAction,
|
|
|
|
nargs=0,
|
|
|
|
default=self, # tricky
|
|
|
|
help="show this help message and exit", )
|
|
|
|
parser.add_argument(
|
|
|
|
'--debug',
|
|
|
|
default=False,
|
|
|
|
action='store_true',
|
|
|
|
help='show tracebacks on errors', )
|
|
|
|
# Global arguments
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_auth_strategy', metavar='<auth_strategy>',
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
default=env('OS_AUTH_STRATEGY', default='keystone'),
|
|
|
|
help='Authentication strategy (Env: OS_AUTH_STRATEGY'
|
|
|
|
', default keystone). For now, any other value will'
|
|
|
|
' disable the authentication')
|
|
|
|
|
2012-05-18 09:02:29 +08:00
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_auth_url', metavar='<auth_url>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=env('OS_AUTH_URL'),
|
|
|
|
help='Authentication URL (Env: OS_AUTH_URL)')
|
|
|
|
|
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_tenant_name', metavar='<auth_tenant_name>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=env('OS_TENANT_NAME'),
|
|
|
|
help='Authentication tenant name (Env: OS_TENANT_NAME)')
|
|
|
|
|
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_username', metavar='<auth_username>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=utils.env('OS_USERNAME'),
|
|
|
|
help='Authentication username (Env: OS_USERNAME)')
|
|
|
|
|
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_password', metavar='<auth_password>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=utils.env('OS_PASSWORD'),
|
|
|
|
help='Authentication password (Env: OS_PASSWORD)')
|
|
|
|
|
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_region_name', metavar='<auth_region_name>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=env('OS_REGION_NAME'),
|
|
|
|
help='Authentication region name (Env: OS_REGION_NAME)')
|
|
|
|
|
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_quantum_api_version',
|
|
|
|
metavar='<quantum_api_version>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=env('OS_QUANTUM_API_VERSION', default='2.0'),
|
|
|
|
help='QAUNTUM API version, default=2.0 '
|
|
|
|
'(Env: OS_QUANTUM_API_VERSION)')
|
|
|
|
|
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_token', metavar='<token>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=env('OS_TOKEN'),
|
|
|
|
help='Defaults to env[OS_TOKEN]')
|
|
|
|
|
|
|
|
parser.add_argument(
|
2012-07-05 15:01:39 +08:00
|
|
|
'--os_url', metavar='<url>',
|
2012-05-18 09:02:29 +08:00
|
|
|
default=env('OS_URL'),
|
|
|
|
help='Defaults to env[OS_URL]')
|
|
|
|
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def run(self, argv):
|
|
|
|
"""Equivalent to the main program for the application.
|
|
|
|
|
|
|
|
:param argv: input arguments and options
|
|
|
|
:paramtype argv: list of str
|
|
|
|
"""
|
|
|
|
try:
|
|
|
|
self.options, remainder = self.parser.parse_known_args(argv)
|
|
|
|
self.configure_logging()
|
|
|
|
self.interactive_mode = not remainder
|
|
|
|
self.initialize_app(remainder)
|
|
|
|
except Exception as err:
|
|
|
|
if self.options.debug:
|
|
|
|
self.log.exception(err)
|
|
|
|
raise
|
|
|
|
else:
|
|
|
|
self.log.error(err)
|
|
|
|
return 1
|
|
|
|
result = 1
|
|
|
|
if self.interactive_mode:
|
|
|
|
_argv = [sys.argv[0]]
|
|
|
|
sys.argv = _argv
|
|
|
|
result = self.interact()
|
|
|
|
else:
|
|
|
|
result = self.run_subcommand(remainder)
|
|
|
|
return result
|
|
|
|
|
|
|
|
def authenticate_user(self):
|
|
|
|
"""Make sure the user has provided all of the authentication
|
|
|
|
info we need.
|
|
|
|
"""
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
if self.options.os_auth_strategy == 'keystone':
|
|
|
|
if self.options.os_token or self.options.os_url:
|
|
|
|
# Token flow auth takes priority
|
|
|
|
if not self.options.os_token:
|
|
|
|
raise exc.CommandError(
|
|
|
|
"You must provide a token via"
|
2012-07-05 15:01:39 +08:00
|
|
|
" either --os_token or env[OS_TOKEN]")
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
|
|
|
|
if not self.options.os_url:
|
|
|
|
raise exc.CommandError(
|
|
|
|
"You must provide a service URL via"
|
2012-07-05 15:01:39 +08:00
|
|
|
" either --os_url or env[OS_URL]")
|
2012-05-18 09:02:29 +08:00
|
|
|
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
else:
|
|
|
|
# Validate password flow auth
|
|
|
|
if not self.options.os_username:
|
|
|
|
raise exc.CommandError(
|
|
|
|
"You must provide a username via"
|
2012-07-05 15:01:39 +08:00
|
|
|
" either --os_username or env[OS_USERNAME]")
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
|
|
|
|
if not self.options.os_password:
|
|
|
|
raise exc.CommandError(
|
|
|
|
"You must provide a password via"
|
2012-07-05 15:01:39 +08:00
|
|
|
" either --os_password or env[OS_PASSWORD]")
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
|
|
|
|
if not (self.options.os_tenant_name):
|
|
|
|
raise exc.CommandError(
|
|
|
|
"You must provide a tenant_name via"
|
2012-07-05 15:01:39 +08:00
|
|
|
" either --os_tenant_name or via env[OS_TENANT_NAME]")
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
|
|
|
|
if not self.options.os_auth_url:
|
|
|
|
raise exc.CommandError(
|
|
|
|
"You must provide an auth url via"
|
2012-07-05 15:01:39 +08:00
|
|
|
" either --os_auth_url or via env[OS_AUTH_URL]")
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
else: # not keystone
|
2012-05-18 09:02:29 +08:00
|
|
|
if not self.options.os_url:
|
|
|
|
raise exc.CommandError(
|
|
|
|
"You must provide a service URL via"
|
2012-07-05 15:01:39 +08:00
|
|
|
" either --os_url or env[OS_URL]")
|
2012-05-18 09:02:29 +08:00
|
|
|
|
|
|
|
self.client_manager = clientmanager.ClientManager(
|
|
|
|
token=self.options.os_token,
|
|
|
|
url=self.options.os_url,
|
|
|
|
auth_url=self.options.os_auth_url,
|
|
|
|
tenant_name=self.options.os_tenant_name,
|
|
|
|
username=self.options.os_username,
|
|
|
|
password=self.options.os_password,
|
|
|
|
region_name=self.options.os_region_name,
|
add --fixed-ip argument to create port
add --fixed-ip argument to create port and add list and dict type for unknow option
now we can use known option feature:
quantumv2 create_port --fixed-ip subnet_id=<id>,ip_address=<ip>
--fixed-ip subnet_id=<id>, ip_address=<ip2> network_id
or unknown option feature:
one ip:
quantumv2 create_port network_id --fixed_ips type=dict list=true subnet_id=<id>,ip_address=<ip>
two ips:
quantumv2 create_port network_id --fixed_ips type=dict subnet_id=<id>,ip_address=<ip> subnet_id=<id>,ip_address=<ip2>
to create port
Please download: https://review.openstack.org/#/c/8794/4 and
set core_plugin = quantum.db.db_base_plugin_v2.QuantumDbPluginV2 on quantum server side
Patch 2: support cliff 1.0
Patch 3: support specify auth strategy, for now, any other auth strategy than keystone will disable auth,
format port output
Patch 4: format None as '' when outputing, deal with list of dict, add QUANTUMCLIENT_DEBUG env to enable http req/resp print,
which is helpful for testing nova integration
Patch 5: fix interactive mode, and initialize_app problem
Change-Id: I693848c75055d1947862d55f4b538c1dfb1e86db
2012-06-24 16:11:11 +08:00
|
|
|
api_version=self.api_version,
|
|
|
|
auth_strategy=self.options.os_auth_strategy, )
|
2012-05-18 09:02:29 +08:00
|
|
|
return
|
|
|
|
|
|
|
|
def initialize_app(self, argv):
|
|
|
|
"""Global app init bits:
|
|
|
|
|
|
|
|
* set up API versions
|
|
|
|
* validate authentication info
|
|
|
|
"""
|
|
|
|
|
|
|
|
super(QuantumShell, self).initialize_app(argv)
|
|
|
|
|
|
|
|
self.api_version = {
|
|
|
|
'network': self.options.os_quantum_api_version, }
|
|
|
|
|
|
|
|
# If the user is not asking for help, make sure they
|
|
|
|
# have given us auth.
|
|
|
|
cmd_name = None
|
|
|
|
if argv:
|
|
|
|
cmd_info = self.command_manager.find_command(argv)
|
|
|
|
cmd_factory, cmd_name, sub_argv = cmd_info
|
|
|
|
if self.interactive_mode or cmd_name != 'help':
|
|
|
|
self.authenticate_user()
|
|
|
|
|
|
|
|
def clean_up(self, cmd, result, err):
|
|
|
|
self.log.debug('clean_up %s', cmd.__class__.__name__)
|
|
|
|
if err:
|
|
|
|
self.log.debug('got an error: %s', err)
|
|
|
|
|
|
|
|
|
|
|
|
def itertools_compressdef(data, selectors):
|
|
|
|
# patch 2.6 compress('ABCDEF', [1,0,1,0,1,1]) --> A C E F
|
|
|
|
return (d for d, s in itertools.izip(data, selectors) if s)
|
|
|
|
|
|
|
|
|
|
|
|
def main(argv=sys.argv[1:]):
|
|
|
|
apiVersion = None
|
|
|
|
versionFlag = False
|
|
|
|
for argitem in argv:
|
2012-07-05 15:01:39 +08:00
|
|
|
if argitem.startswith('--os_quantum_api_version='):
|
2012-05-18 09:02:29 +08:00
|
|
|
apiVersion = argitem.split('=', 2)[1]
|
|
|
|
break
|
2012-07-05 15:01:39 +08:00
|
|
|
elif '--os_quantum_api_version' == argitem:
|
2012-05-18 09:02:29 +08:00
|
|
|
versionFlag = True
|
|
|
|
elif versionFlag:
|
|
|
|
apiVersion = argitem
|
|
|
|
break
|
|
|
|
if apiVersion and apiVersion not in COMMANDS.keys():
|
|
|
|
print ("Invalid API version or API version '%s' is not supported" %
|
|
|
|
apiVersion)
|
|
|
|
sys.exit(1)
|
|
|
|
if not apiVersion:
|
|
|
|
apiVersion = env('OS_QUANTUM_API_VERSION', default='2.0')
|
|
|
|
try:
|
|
|
|
if not getattr(itertools, 'compress', None):
|
|
|
|
setattr(itertools, 'compress', itertools_compressdef)
|
|
|
|
return QuantumShell(apiVersion).run(argv)
|
|
|
|
except exc.QuantumClientException:
|
|
|
|
return 1
|
|
|
|
except Exception as e:
|
|
|
|
print e
|
|
|
|
return 1
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
sys.exit(main(sys.argv[1:]))
|