Files
Andreas Jaeger 9908379f82 Cleanup py27 support
This repo is now testing only with Python 3, so let's make
a few cleanups:
- Remove python 2.7 stanza from setup.py
- Remove obsolete sections from setup.cfg
- Update classifiers
- This repo has no docs, remove releasenotes and docs building
  infrastructure
- Cleanup */source/conf.py to remove now obsolete content.
- Remove install_command from tox.ini, the default is fine
- Remove Babel from requirements, it's not needed for running.
- Use TOX_CONSTRAINTS_FILE, UPPER_CONSTRAINTS_FILE is obsolete
- Update to hacking 3.0, fix problems found

Change-Id: I9133baec6cb123440f34b8c4b31001cfe875919e
2020-05-09 18:06:43 +02:00

108 lines
3.0 KiB
Python

# Copyright (C) 2016 Catalyst IT Ltd
#
# 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.
from six.moves.urllib import parse
from adjutantclient.common import base
from adjutantclient import exc
class Role(base.Resource):
pass
class ManagableRole(base.Resource):
pass
class ManagedRoleManager(base.ManagerWithFind):
resource_class = ManagableRole
def list(self, **kwargs):
"""Get a list of roles that can be managed.
:rtype: list of :class:`Role`
"""
params = {}
url = '/openstack/roles?%(params)s' % {
'params': parse.urlencode(params, True)
}
return self._list(url, 'roles')
def get(self, role_id):
"""Get a role by role_id"""
# Right now the only way is to list them all, then iterate.
# Perhaps a filter or new endpoint would be useful here.
roles = self.list()
for role in roles:
if role.id == role_id:
return role
raise exc.HTTPNotFound()
class UserRoleManager(base.BaseManager):
resource_class = Role
def list(self, **kwargs):
"""List roles for a given user"""
# TODO(adriant): Look up user by name/id
url = '/openstack/users/%s/roles' % kwargs['user']
return self._list(url, 'roles')
def add(self, user, role=None, roles=None):
"""Add a role to a user"""
# TODO(adriant): resolve the roles and users into id's
# user_id = base.getid(user)
user_id = user
# role_id = role
if role:
params = {
'roles': [role]
}
elif roles:
params = {
'roles': roles
}
route = '/openstack/users/%s/roles'
url = route % (user_id)
try:
self._put(url, json=params, response_key=None)
except exc.HTTPBadRequest as e:
print(e.message)
return False
return True
def remove(self, user_id, role=None, roles=None):
"""Remove a role or roles from a user"""
if role:
params = {
'roles': [role]
}
elif roles:
params = {
'roles': roles
}
route = '/openstack/users/%s/roles'
url = route % (user_id)
try:
self._delete(url, json=params, response_key=None)
except exc.HTTPBadRequest as e:
print(e.message)
return False
return True