blob: 1076fcaf32a3f62b0e05b51137867841540adfef [file] [log] [blame]
Sean Dague556add52013-07-19 14:28:44 -04001# 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
Matthew Treinish21905512015-07-13 10:33:35 -040013from oslo_serialization import jsonutils as json
Masayuki Igawabfa07602015-01-20 18:47:17 +090014from tempest_lib import exceptions as lib_exc
chris fattarsi8ed39ac2012-04-30 14:11:27 -070015
Ken'ichi Ohmichi0e836652015-01-08 04:38:56 +000016from tempest.common import service_client
Matthew Treinish684d8992014-01-30 16:27:40 +000017
chris fattarsi8ed39ac2012-04-30 14:11:27 -070018
Ken'ichi Ohmichia6287072015-07-02 02:43:15 +000019class IdentityClient(service_client.ServiceClient):
Ralf Haferkampd5525e32015-06-19 17:17:47 +020020 api_version = "v2.0"
chris fattarsi8ed39ac2012-04-30 14:11:27 -070021
Filip HubĂ­k81354052015-03-09 19:04:23 +010022 def get_api_description(self):
23 """Retrieves info about the v2.0 Identity API"""
24 url = ''
25 resp, body = self.get(url)
26 self.expected_success([200, 203], resp.status)
27 return service_client.ResponseBody(resp, self._parse_resp(body))
28
chris fattarsi8ed39ac2012-04-30 14:11:27 -070029 def has_admin_extensions(self):
30 """
31 Returns True if the KSADM Admin Extensions are supported
32 False otherwise
33 """
34 if hasattr(self, '_has_admin_extensions'):
35 return self._has_admin_extensions
David Kranze9d2f422014-07-02 13:57:41 -040036 # Try something that requires admin
37 try:
38 self.list_roles()
39 self._has_admin_extensions = True
40 except Exception:
41 self._has_admin_extensions = False
chris fattarsi8ed39ac2012-04-30 14:11:27 -070042 return self._has_admin_extensions
43
44 def create_role(self, name):
Sean Daguef237ccb2013-01-04 15:19:14 -050045 """Create a role."""
chris fattarsi8ed39ac2012-04-30 14:11:27 -070046 post_body = {
47 'name': name,
48 }
49 post_body = json.dumps({'role': post_body})
vponomaryov67b58fe2014-02-06 19:05:41 +020050 resp, body = self.post('OS-KSADM/roles', post_body)
David Kranze9d2f422014-07-02 13:57:41 -040051 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +000052 return service_client.ResponseBody(resp, self._parse_resp(body))
chris fattarsi8ed39ac2012-04-30 14:11:27 -070053
Gong Zhangcb6b8862014-02-20 15:14:05 +080054 def get_role(self, role_id):
55 """Get a role by its id."""
56 resp, body = self.get('OS-KSADM/roles/%s' % role_id)
David Kranze9d2f422014-07-02 13:57:41 -040057 self.expected_success(200, resp.status)
Gong Zhangcb6b8862014-02-20 15:14:05 +080058 body = json.loads(body)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +000059 return service_client.ResponseBody(resp, body['role'])
Gong Zhangcb6b8862014-02-20 15:14:05 +080060
chris fattarsi9ba7b0e2012-05-07 13:55:51 -070061 def create_tenant(self, name, **kwargs):
62 """
63 Create a tenant
64 name (required): New tenant name
65 description: Description of new tenant (default is none)
66 enabled <true|false>: Initial tenant status (default is true)
67 """
68 post_body = {
69 'name': name,
70 'description': kwargs.get('description', ''),
Gordon Chungad873602013-02-18 19:26:27 -050071 'enabled': kwargs.get('enabled', True),
chris fattarsi9ba7b0e2012-05-07 13:55:51 -070072 }
73 post_body = json.dumps({'tenant': post_body})
vponomaryov67b58fe2014-02-06 19:05:41 +020074 resp, body = self.post('tenants', post_body)
David Kranze9d2f422014-07-02 13:57:41 -040075 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +000076 return service_client.ResponseBody(resp, self._parse_resp(body))
chris fattarsi9ba7b0e2012-05-07 13:55:51 -070077
chris fattarsi8ed39ac2012-04-30 14:11:27 -070078 def delete_role(self, role_id):
Sean Daguef237ccb2013-01-04 15:19:14 -050079 """Delete a role."""
David Kranze9d2f422014-07-02 13:57:41 -040080 resp, body = self.delete('OS-KSADM/roles/%s' % str(role_id))
81 self.expected_success(204, resp.status)
82 return resp, body
chris fattarsi8ed39ac2012-04-30 14:11:27 -070083
rajalakshmi-ganesan8ba945e2012-08-01 15:43:19 +053084 def list_user_roles(self, tenant_id, user_id):
Sean Daguef237ccb2013-01-04 15:19:14 -050085 """Returns a list of roles assigned to a user for a tenant."""
rajalakshmi-ganesan8ba945e2012-08-01 15:43:19 +053086 url = '/tenants/%s/users/%s/roles' % (tenant_id, user_id)
87 resp, body = self.get(url)
David Kranze9d2f422014-07-02 13:57:41 -040088 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +000089 return service_client.ResponseBodyList(resp, self._parse_resp(body))
Rohit Karajgi69e80a02012-05-15 03:54:04 -070090
rajalakshmi-ganesan8ba945e2012-08-01 15:43:19 +053091 def assign_user_role(self, tenant_id, user_id, role_id):
Sean Daguef237ccb2013-01-04 15:19:14 -050092 """Add roles to a user on a tenant."""
Zhongyue Luoe0884a32012-09-25 17:24:17 +080093 resp, body = self.put('/tenants/%s/users/%s/roles/OS-KSADM/%s' %
vponomaryov67b58fe2014-02-06 19:05:41 +020094 (tenant_id, user_id, role_id), "")
David Kranze9d2f422014-07-02 13:57:41 -040095 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +000096 return service_client.ResponseBody(resp, self._parse_resp(body))
Rohit Karajgi69e80a02012-05-15 03:54:04 -070097
rajalakshmi-ganesan8ba945e2012-08-01 15:43:19 +053098 def remove_user_role(self, tenant_id, user_id, role_id):
Sean Daguef237ccb2013-01-04 15:19:14 -050099 """Removes a role assignment for a user on a tenant."""
David Kranze9d2f422014-07-02 13:57:41 -0400100 resp, body = self.delete('/tenants/%s/users/%s/roles/OS-KSADM/%s' %
101 (tenant_id, user_id, role_id))
102 self.expected_success(204, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000103 return service_client.ResponseBody(resp, body)
Rohit Karajgi69e80a02012-05-15 03:54:04 -0700104
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700105 def delete_tenant(self, tenant_id):
Sean Daguef237ccb2013-01-04 15:19:14 -0500106 """Delete a tenant."""
David Kranze9d2f422014-07-02 13:57:41 -0400107 resp, body = self.delete('tenants/%s' % str(tenant_id))
108 self.expected_success(204, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000109 return service_client.ResponseBody(resp, body)
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700110
111 def get_tenant(self, tenant_id):
Sean Daguef237ccb2013-01-04 15:19:14 -0500112 """Get tenant details."""
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700113 resp, body = self.get('tenants/%s' % str(tenant_id))
David Kranze9d2f422014-07-02 13:57:41 -0400114 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000115 return service_client.ResponseBody(resp, self._parse_resp(body))
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700116
chris fattarsi8ed39ac2012-04-30 14:11:27 -0700117 def list_roles(self):
Sean Daguef237ccb2013-01-04 15:19:14 -0500118 """Returns roles."""
chris fattarsi8ed39ac2012-04-30 14:11:27 -0700119 resp, body = self.get('OS-KSADM/roles')
David Kranze9d2f422014-07-02 13:57:41 -0400120 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000121 return service_client.ResponseBodyList(resp, self._parse_resp(body))
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700122
123 def list_tenants(self):
Sean Daguef237ccb2013-01-04 15:19:14 -0500124 """Returns tenants."""
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700125 resp, body = self.get('tenants')
David Kranze9d2f422014-07-02 13:57:41 -0400126 self.expected_success(200, resp.status)
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700127 body = json.loads(body)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000128 return service_client.ResponseBodyList(resp, body['tenants'])
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700129
Dan Smithd6ff6b72012-08-23 10:29:41 -0700130 def get_tenant_by_name(self, tenant_name):
David Kranzb7afa922014-12-30 10:56:26 -0500131 tenants = self.list_tenants()
Dan Smithd6ff6b72012-08-23 10:29:41 -0700132 for tenant in tenants:
133 if tenant['name'] == tenant_name:
134 return tenant
Masayuki Igawabfa07602015-01-20 18:47:17 +0900135 raise lib_exc.NotFound('No such tenant')
Dan Smithd6ff6b72012-08-23 10:29:41 -0700136
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700137 def update_tenant(self, tenant_id, **kwargs):
Sean Daguef237ccb2013-01-04 15:19:14 -0500138 """Updates a tenant."""
David Kranzb7afa922014-12-30 10:56:26 -0500139 body = self.get_tenant(tenant_id)
chris fattarsi9ba7b0e2012-05-07 13:55:51 -0700140 name = kwargs.get('name', body['name'])
141 desc = kwargs.get('description', body['description'])
142 en = kwargs.get('enabled', body['enabled'])
143 post_body = {
144 'id': tenant_id,
145 'name': name,
146 'description': desc,
147 'enabled': en,
148 }
149 post_body = json.dumps({'tenant': post_body})
vponomaryov67b58fe2014-02-06 19:05:41 +0200150 resp, body = self.post('tenants/%s' % tenant_id, post_body)
David Kranze9d2f422014-07-02 13:57:41 -0400151 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000152 return service_client.ResponseBody(resp, self._parse_resp(body))
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700153
huangtianhuafc8db4f2013-10-08 12:05:58 +0800154 def create_user(self, name, password, tenant_id, email, **kwargs):
Sean Daguef237ccb2013-01-04 15:19:14 -0500155 """Create a user."""
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700156 post_body = {
157 'name': name,
158 'password': password,
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700159 'email': email
160 }
Brant Knudsona4cfe0c2014-03-15 09:36:45 -0500161 if tenant_id is not None:
162 post_body['tenantId'] = tenant_id
huangtianhuafc8db4f2013-10-08 12:05:58 +0800163 if kwargs.get('enabled') is not None:
164 post_body['enabled'] = kwargs.get('enabled')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700165 post_body = json.dumps({'user': post_body})
vponomaryov67b58fe2014-02-06 19:05:41 +0200166 resp, body = self.post('users', post_body)
David Kranze9d2f422014-07-02 13:57:41 -0400167 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000168 return service_client.ResponseBody(resp, self._parse_resp(body))
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700169
Chang Bo Guob36b2f12013-09-13 04:52:00 -0700170 def update_user(self, user_id, **kwargs):
171 """Updates a user."""
172 put_body = json.dumps({'user': kwargs})
vponomaryov67b58fe2014-02-06 19:05:41 +0200173 resp, body = self.put('users/%s' % user_id, put_body)
David Kranze9d2f422014-07-02 13:57:41 -0400174 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000175 return service_client.ResponseBody(resp, self._parse_resp(body))
Chang Bo Guob36b2f12013-09-13 04:52:00 -0700176
rajalakshmi-ganesan7312bb52013-01-29 20:03:42 +0530177 def get_user(self, user_id):
178 """GET a user."""
179 resp, body = self.get("users/%s" % user_id)
David Kranze9d2f422014-07-02 13:57:41 -0400180 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000181 return service_client.ResponseBody(resp, self._parse_resp(body))
rajalakshmi-ganesan7312bb52013-01-29 20:03:42 +0530182
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700183 def delete_user(self, user_id):
Sean Daguef237ccb2013-01-04 15:19:14 -0500184 """Delete a user."""
David Kranze9d2f422014-07-02 13:57:41 -0400185 resp, body = self.delete("users/%s" % user_id)
186 self.expected_success(204, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000187 return service_client.ResponseBody(resp, body)
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700188
189 def get_users(self):
Sean Daguef237ccb2013-01-04 15:19:14 -0500190 """Get the list of users."""
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700191 resp, body = self.get("users")
David Kranze9d2f422014-07-02 13:57:41 -0400192 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000193 return service_client.ResponseBodyList(resp, self._parse_resp(body))
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700194
195 def enable_disable_user(self, user_id, enabled):
Sean Daguef237ccb2013-01-04 15:19:14 -0500196 """Enables or disables a user."""
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700197 put_body = {
Sean Dague14c68182013-04-14 15:34:30 -0400198 'enabled': enabled
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700199 }
200 put_body = json.dumps({'user': put_body})
vponomaryov67b58fe2014-02-06 19:05:41 +0200201 resp, body = self.put('users/%s/enabled' % user_id, put_body)
David Kranze9d2f422014-07-02 13:57:41 -0400202 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000203 return service_client.ResponseBody(resp, self._parse_resp(body))
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700204
Zhi Kun Liu30caeae2014-02-26 15:30:24 +0800205 def get_token(self, token_id):
206 """Get token details."""
207 resp, body = self.get("tokens/%s" % token_id)
David Kranze9d2f422014-07-02 13:57:41 -0400208 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000209 return service_client.ResponseBody(resp, self._parse_resp(body))
Zhi Kun Liu30caeae2014-02-26 15:30:24 +0800210
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700211 def delete_token(self, token_id):
Sean Daguef237ccb2013-01-04 15:19:14 -0500212 """Delete a token."""
David Kranze9d2f422014-07-02 13:57:41 -0400213 resp, body = self.delete("tokens/%s" % token_id)
214 self.expected_success(204, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000215 return service_client.ResponseBody(resp, body)
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700216
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530217 def list_users_for_tenant(self, tenant_id):
Sean Daguef237ccb2013-01-04 15:19:14 -0500218 """List users for a Tenant."""
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530219 resp, body = self.get('/tenants/%s/users' % tenant_id)
David Kranze9d2f422014-07-02 13:57:41 -0400220 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000221 return service_client.ResponseBodyList(resp, self._parse_resp(body))
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530222
Dan Smithd6ff6b72012-08-23 10:29:41 -0700223 def get_user_by_username(self, tenant_id, username):
David Kranzb7afa922014-12-30 10:56:26 -0500224 users = self.list_users_for_tenant(tenant_id)
Dan Smithd6ff6b72012-08-23 10:29:41 -0700225 for user in users:
226 if user['name'] == username:
227 return user
Masayuki Igawabfa07602015-01-20 18:47:17 +0900228 raise lib_exc.NotFound('No such user')
Dan Smithd6ff6b72012-08-23 10:29:41 -0700229
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530230 def create_service(self, name, type, **kwargs):
Sean Daguef237ccb2013-01-04 15:19:14 -0500231 """Create a service."""
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530232 post_body = {
Zhongyue Luoa1343de2013-01-04 16:21:35 +0800233 'name': name,
234 'type': type,
235 'description': kwargs.get('description')
236 }
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530237 post_body = json.dumps({'OS-KSADM:service': post_body})
vponomaryov67b58fe2014-02-06 19:05:41 +0200238 resp, body = self.post('/OS-KSADM/services', post_body)
David Kranze9d2f422014-07-02 13:57:41 -0400239 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000240 return service_client.ResponseBody(resp, self._parse_resp(body))
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530241
242 def get_service(self, service_id):
Sean Daguef237ccb2013-01-04 15:19:14 -0500243 """Get Service."""
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530244 url = '/OS-KSADM/services/%s' % service_id
245 resp, body = self.get(url)
David Kranze9d2f422014-07-02 13:57:41 -0400246 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000247 return service_client.ResponseBody(resp, self._parse_resp(body))
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530248
umamohanb51ad002013-01-24 18:13:15 +0000249 def list_services(self):
250 """List Service - Returns Services."""
Tushar Kalraa76929c2014-03-31 12:23:07 -0700251 resp, body = self.get('/OS-KSADM/services')
David Kranze9d2f422014-07-02 13:57:41 -0400252 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000253 return service_client.ResponseBodyList(resp, self._parse_resp(body))
umamohanb51ad002013-01-24 18:13:15 +0000254
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530255 def delete_service(self, service_id):
Sean Daguef237ccb2013-01-04 15:19:14 -0500256 """Delete Service."""
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530257 url = '/OS-KSADM/services/%s' % service_id
David Kranze9d2f422014-07-02 13:57:41 -0400258 resp, body = self.delete(url)
259 self.expected_success(204, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000260 return service_client.ResponseBody(resp, body)
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530261
Abhijeet.Jainff5c3542014-05-06 16:07:30 +0530262 def update_user_password(self, user_id, new_pass):
263 """Update User Password."""
264 put_body = {
265 'password': new_pass,
266 'id': user_id
267 }
268 put_body = json.dumps({'user': put_body})
269 resp, body = self.put('users/%s/OS-KSADM/password' % user_id, put_body)
David Kranze9d2f422014-07-02 13:57:41 -0400270 self.expected_success(200, resp.status)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000271 return service_client.ResponseBody(resp, self._parse_resp(body))
Abhijeet.Jainff5c3542014-05-06 16:07:30 +0530272
Abhijeet.Jain3f49b842014-05-20 12:06:20 +0530273 def list_extensions(self):
274 """List all the extensions."""
275 resp, body = self.get('/extensions')
David Kranze9d2f422014-07-02 13:57:41 -0400276 self.expected_success(200, resp.status)
Abhijeet.Jain3f49b842014-05-20 12:06:20 +0530277 body = json.loads(body)
Ken'ichi Ohmichia6ac2422015-01-13 01:09:39 +0000278 return service_client.ResponseBodyList(resp,
279 body['extensions']['values'])
Andrea Frittoli32d74992015-03-06 17:01:07 +0000280
281 def create_user_ec2_credentials(self, user_id, tenant_id):
282 post_body = json.dumps({'tenant_id': tenant_id})
283 resp, body = self.post('/users/%s/credentials/OS-EC2' % user_id,
284 post_body)
285 self.expected_success(200, resp.status)
286 return service_client.ResponseBody(resp, self._parse_resp(body))
287
288 def list_user_ec2_credentials(self, user_id):
289 resp, body = self.get('/users/%s/credentials/OS-EC2' % user_id)
290 self.expected_success(200, resp.status)
291 return service_client.ResponseBodyList(resp, self._parse_resp(body))