Fix the multiple regions issue in common client

We need to supply the region_name while creating the various openstack
clients in the common client code, then the client will work well with
the multiple regions.

Closes-Bug: #1323172
Change-Id: Idb30739b84d3813dd970f735b5789c564eb0759d
This commit is contained in:
terryyao 2014-05-26 16:52:55 +08:00
parent 0756217e87
commit e91f6dffc5

View File

@ -68,11 +68,13 @@ class AbstractService(object):
return version return version
def _init_std_client(self): def _init_std_client(self):
region_name = self.base_args.get('region_name', None)
return self._patch(self.clazz(self.base_args['username'], return self._patch(self.clazz(self.base_args['username'],
self.base_args['password'], self.base_args['password'],
self.base_args['tenant_name'], self.base_args['tenant_name'],
self.base_args['auth_url'], self.base_args['auth_url'],
self.base_args['insecure'], self.base_args['insecure'],
region_name=region_name,
cacert=self.base_args['cacert'])) cacert=self.base_args['cacert']))
def new_client(self, client_extension=None, *extension_args): def new_client(self, client_extension=None, *extension_args):
@ -158,6 +160,7 @@ class NeutronService(AbstractService):
super(NeutronService, self).__init__(*kargs) super(NeutronService, self).__init__(*kargs)
def new_client(self, client_extension=None, *extension_args): def new_client(self, client_extension=None, *extension_args):
region_name = self.base_args.get('region_name', None)
return self._extend(self._patch(self.clazz( return self._extend(self._patch(self.clazz(
username=self.base_args['username'], username=self.base_args['username'],
tenant_name=self.base_args['tenant_name'], tenant_name=self.base_args['tenant_name'],
@ -165,6 +168,7 @@ class NeutronService(AbstractService):
auth_url=self.base_args['auth_url'], auth_url=self.base_args['auth_url'],
endpoint_url=self.management_url, endpoint_url=self.management_url,
insecure=self.base_args['insecure'], insecure=self.base_args['insecure'],
region_name=region_name,
token=self.keystone.auth_token, token=self.keystone.auth_token,
ca_cert=self.base_args['cacert'])), ca_cert=self.base_args['cacert'])),
client_extension, *extension_args) client_extension, *extension_args)