blob: 9f58678cafbdb4294bf05d442c820bab7d93561d [file] [log] [blame]
Steve Baker450aa7f2014-08-25 10:37:27 +12001# Licensed under the Apache License, Version 2.0 (the "License"); you may
2# not use this file except in compliance with the License. You may obtain
3# a copy of the License at
4#
5# http://www.apache.org/licenses/LICENSE-2.0
6#
7# Unless required by applicable law or agreed to in writing, software
8# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
9# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
10# License for the specific language governing permissions and limitations
11# under the License.
12
Angus Salkeld70c2f282014-11-21 08:51:41 +100013import os
14
Rabi Mishrae9dffe52016-02-05 14:36:58 +053015from ceilometerclient import client as ceilometer_client
16from cinderclient import client as cinder_client
Peter Razumovsky2810bb52016-03-03 15:36:12 +030017from heat.common.i18n import _
Rabi Mishrae9dffe52016-02-05 14:36:58 +053018from heatclient import client as heat_client
Ethan Lynn07fac1f2016-05-10 23:09:51 +080019from keystoneauth1 import exceptions as kc_exceptions
20from keystoneauth1.identity.generic import password
21from keystoneauth1 import session
Rabi Mishrae9dffe52016-02-05 14:36:58 +053022from neutronclient.v2_0 import client as neutron_client
23from novaclient import client as nova_client
24from swiftclient import client as swift_client
Steve Baker450aa7f2014-08-25 10:37:27 +120025
Steve Baker450aa7f2014-08-25 10:37:27 +120026
Rabi Mishra65493fb2016-01-29 22:23:21 +053027class KeystoneWrapperClient(object):
28 """Wrapper object for keystone client
29
Rabi Mishrae9dffe52016-02-05 14:36:58 +053030 This wraps keystone client, so we can encpasulate certain
Rabi Mishra65493fb2016-01-29 22:23:21 +053031 added properties like auth_token, project_id etc.
32 """
33 def __init__(self, auth_plugin, verify=True):
34 self.auth_plugin = auth_plugin
35 self.session = session.Session(
36 auth=auth_plugin,
37 verify=verify)
38
39 @property
40 def auth_token(self):
41 return self.auth_plugin.get_token(self.session)
42
43 @property
44 def auth_ref(self):
45 return self.auth_plugin.get_access(self.session)
46
47 @property
48 def project_id(self):
49 return self.auth_plugin.get_project_id(self.session)
50
51 def get_endpoint_url(self, service_type, region=None):
52 kwargs = {
53 'service_type': service_type,
Ethan Lynn07fac1f2016-05-10 23:09:51 +080054 'region_name': region}
Rabi Mishra65493fb2016-01-29 22:23:21 +053055 return self.auth_ref.service_catalog.url_for(**kwargs)
56
57
Steve Baker450aa7f2014-08-25 10:37:27 +120058class ClientManager(object):
Peter Razumovskyf0ac9582015-09-24 16:49:03 +030059 """Provides access to the official python clients for calling various APIs.
60
Steve Baker450aa7f2014-08-25 10:37:27 +120061 Manager that provides access to the official python clients for
62 calling various OpenStack APIs.
63 """
64
Rabi Mishraa30ac122015-09-29 11:47:52 +053065 CINDERCLIENT_VERSION = '2'
Steve Baker450aa7f2014-08-25 10:37:27 +120066 HEATCLIENT_VERSION = '1'
huangtianhua15ad5322016-06-02 14:39:13 +080067 NOVA_API_VERSION = '2.1'
Angus Salkeld406bbd52015-05-13 14:24:04 +100068 CEILOMETER_VERSION = '2'
Steve Baker450aa7f2014-08-25 10:37:27 +120069
70 def __init__(self, conf):
71 self.conf = conf
Peter Razumovsky2810bb52016-03-03 15:36:12 +030072 if self.conf.auth_url.find('/v'):
Peter Razumovsky2810bb52016-03-03 15:36:12 +030073 self.auth_version = self.conf.auth_url.split('/v')[1]
74 else:
75 raise ValueError(_('Incorrectly specified auth_url config: no '
76 'version found.'))
tyagi39aa11a2016-03-07 04:47:00 -080077 self.insecure = self.conf.disable_ssl_certificate_validation
78 self.ca_file = self.conf.ca_file
Rabi Mishra17f41de2016-05-03 11:19:41 +053079
Steve Baker450aa7f2014-08-25 10:37:27 +120080 self.identity_client = self._get_identity_client()
81 self.orchestration_client = self._get_orchestration_client()
82 self.compute_client = self._get_compute_client()
83 self.network_client = self._get_network_client()
84 self.volume_client = self._get_volume_client()
Angus Salkeld4408da32015-02-03 18:53:30 +100085 self.object_client = self._get_object_client()
Angus Salkeld406bbd52015-05-13 14:24:04 +100086 self.metering_client = self._get_metering_client()
Steve Baker450aa7f2014-08-25 10:37:27 +120087
88 def _get_orchestration_client(self):
Angus Salkeld70c2f282014-11-21 08:51:41 +100089 endpoint = os.environ.get('HEAT_URL')
90 if os.environ.get('OS_NO_CLIENT_AUTH') == 'True':
91 token = None
92 else:
Rabi Mishra65493fb2016-01-29 22:23:21 +053093 token = self.identity_client.auth_token
Steve Baker450aa7f2014-08-25 10:37:27 +120094 try:
Angus Salkeld70c2f282014-11-21 08:51:41 +100095 if endpoint is None:
Rabi Mishra65493fb2016-01-29 22:23:21 +053096 endpoint = self.identity_client.get_endpoint_url(
97 'orchestration', self.conf.region)
Rabi Mishrae9dffe52016-02-05 14:36:58 +053098 except kc_exceptions.EndpointNotFound:
Steve Baker450aa7f2014-08-25 10:37:27 +120099 return None
100 else:
Rabi Mishrae9dffe52016-02-05 14:36:58 +0530101 return heat_client.Client(
Steve Baker450aa7f2014-08-25 10:37:27 +1200102 self.HEATCLIENT_VERSION,
103 endpoint,
104 token=token,
105 username=self.conf.username,
106 password=self.conf.password)
107
108 def _get_identity_client(self):
Rabi Mishra1d538742016-03-21 21:09:20 +0530109 user_domain_name = self.conf.user_domain_name
110 project_domain_name = self.conf.project_domain_name
Rabi Mishra65493fb2016-01-29 22:23:21 +0530111 kwargs = {
112 'username': self.conf.username,
113 'password': self.conf.password,
114 'tenant_name': self.conf.tenant_name,
115 'auth_url': self.conf.auth_url
116 }
117 # keystone v2 can't ignore domain details
118 if self.auth_version == '3':
119 kwargs.update({
Rabi Mishra1d538742016-03-21 21:09:20 +0530120 'user_domain_name': user_domain_name,
121 'project_domain_name': project_domain_name})
Rabi Mishra65493fb2016-01-29 22:23:21 +0530122 auth = password.Password(**kwargs)
tyagi39aa11a2016-03-07 04:47:00 -0800123 if self.insecure:
124 verify_cert = False
125 else:
126 verify_cert = self.ca_file or True
127
128 return KeystoneWrapperClient(auth, verify_cert)
Steve Baker450aa7f2014-08-25 10:37:27 +1200129
130 def _get_compute_client(self):
131
Steve Baker450aa7f2014-08-25 10:37:27 +1200132 region = self.conf.region
Steve Baker450aa7f2014-08-25 10:37:27 +1200133 # Create our default Nova client to use in testing
Rabi Mishrae9dffe52016-02-05 14:36:58 +0530134 return nova_client.Client(
huangtianhua15ad5322016-06-02 14:39:13 +0800135 self.NOVA_API_VERSION,
Rabi Mishra17f41de2016-05-03 11:19:41 +0530136 session=self.identity_client.session,
Steve Baker450aa7f2014-08-25 10:37:27 +1200137 service_type='compute',
138 endpoint_type='publicURL',
139 region_name=region,
140 no_cache=True,
tyagi39aa11a2016-03-07 04:47:00 -0800141 insecure=self.insecure,
142 cacert=self.ca_file,
Steve Baker450aa7f2014-08-25 10:37:27 +1200143 http_log_debug=True)
144
145 def _get_network_client(self):
Steve Baker450aa7f2014-08-25 10:37:27 +1200146
Rabi Mishrae9dffe52016-02-05 14:36:58 +0530147 return neutron_client.Client(
Rabi Mishra17f41de2016-05-03 11:19:41 +0530148 session=self.identity_client.session,
Steve Baker450aa7f2014-08-25 10:37:27 +1200149 endpoint_type='publicURL',
tyagi39aa11a2016-03-07 04:47:00 -0800150 insecure=self.insecure,
151 ca_cert=self.ca_file)
Steve Baker450aa7f2014-08-25 10:37:27 +1200152
153 def _get_volume_client(self):
Steve Baker450aa7f2014-08-25 10:37:27 +1200154 region = self.conf.region
155 endpoint_type = 'publicURL'
Rabi Mishrae9dffe52016-02-05 14:36:58 +0530156 return cinder_client.Client(
Steve Baker450aa7f2014-08-25 10:37:27 +1200157 self.CINDERCLIENT_VERSION,
Rabi Mishra17f41de2016-05-03 11:19:41 +0530158 session=self.identity_client.session,
Steve Baker450aa7f2014-08-25 10:37:27 +1200159 region_name=region,
160 endpoint_type=endpoint_type,
tyagi39aa11a2016-03-07 04:47:00 -0800161 insecure=self.insecure,
162 cacert=self.ca_file,
Steve Baker450aa7f2014-08-25 10:37:27 +1200163 http_log_debug=True)
Angus Salkeld4408da32015-02-03 18:53:30 +1000164
165 def _get_object_client(self):
Rabi Mishra17f41de2016-05-03 11:19:41 +0530166 # swiftclient does not support keystone sessions yet
Angus Salkeld4408da32015-02-03 18:53:30 +1000167 args = {
Rabi Mishra65493fb2016-01-29 22:23:21 +0530168 'auth_version': self.auth_version,
Angus Salkeld4408da32015-02-03 18:53:30 +1000169 'tenant_name': self.conf.tenant_name,
170 'user': self.conf.username,
171 'key': self.conf.password,
172 'authurl': self.conf.auth_url,
173 'os_options': {'endpoint_type': 'publicURL'},
tyagi39aa11a2016-03-07 04:47:00 -0800174 'insecure': self.insecure,
175 'cacert': self.ca_file,
Angus Salkeld4408da32015-02-03 18:53:30 +1000176 }
Rabi Mishrae9dffe52016-02-05 14:36:58 +0530177 return swift_client.Connection(**args)
Angus Salkeld406bbd52015-05-13 14:24:04 +1000178
179 def _get_metering_client(self):
Steve Baker5e4d5f42015-05-26 13:28:28 +1200180 try:
Rabi Mishra65493fb2016-01-29 22:23:21 +0530181 endpoint = self.identity_client.get_endpoint_url('metering',
182 self.conf.region)
Rabi Mishrae9dffe52016-02-05 14:36:58 +0530183 except kc_exceptions.EndpointNotFound:
Steve Baker5e4d5f42015-05-26 13:28:28 +1200184 return None
185 else:
186 args = {
Rabi Mishra17f41de2016-05-03 11:19:41 +0530187 'session': self.identity_client.session,
tyagi39aa11a2016-03-07 04:47:00 -0800188 'insecure': self.insecure,
189 'cacert': self.ca_file,
Steve Baker5e4d5f42015-05-26 13:28:28 +1200190 'region_name': self.conf.region,
191 'endpoint_type': 'publicURL',
192 'service_type': 'metering',
193 }
Rabi Mishrae9dffe52016-02-05 14:36:58 +0530194 return ceilometer_client.Client(self.CEILOMETER_VERSION,
195 endpoint, **args)