
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
70 lines
2.4 KiB
Python
70 lines
2.4 KiB
Python
# 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
|
|
|
|
import logging
|
|
import urlparse
|
|
|
|
|
|
from quantumclient.common import utils
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
API_NAME = 'network'
|
|
API_VERSIONS = {
|
|
'1.0': 'quantumclient.Client',
|
|
'1.1': 'quantumclient.ClientV11',
|
|
'2.0': 'quantumclient.v2_0.client.Client',
|
|
}
|
|
|
|
|
|
def make_client(instance):
|
|
"""Returns an identity service client.
|
|
"""
|
|
quantum_client = utils.get_client_class(
|
|
API_NAME,
|
|
instance._api_version[API_NAME],
|
|
API_VERSIONS,
|
|
)
|
|
instance.initialize()
|
|
url = instance._url
|
|
url = url.rstrip("/")
|
|
client_full_name = (quantum_client.__module__ + "." +
|
|
quantum_client.__name__)
|
|
LOG.debug("we are using client: %s", client_full_name)
|
|
v1x = (client_full_name == API_VERSIONS['1.1'] or
|
|
client_full_name == API_VERSIONS['1.0'])
|
|
if v1x:
|
|
magic_tuple = urlparse.urlsplit(url)
|
|
scheme, netloc, path, query, frag = magic_tuple
|
|
host = magic_tuple.hostname
|
|
port = magic_tuple.port
|
|
use_ssl = scheme.lower().startswith('https')
|
|
client = quantum_client(host=host, port=port, use_ssl=use_ssl)
|
|
client.auth_token = instance._token
|
|
client.logger = LOG
|
|
return client
|
|
else:
|
|
client = quantum_client(username=instance._username,
|
|
tenant_name=instance._tenant_name,
|
|
password=instance._password,
|
|
region_name=instance._region_name,
|
|
auth_url=instance._auth_url,
|
|
endpoint_url=url,
|
|
token=instance._token,
|
|
auth_strategy=instance._auth_strategy)
|
|
return client
|