X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=osm_nbi%2Fauthconn_keystone.py;h=e9173063669c44a830b4d5f2b8459fb8c7e7c8d2;hb=refs%2Fchanges%2F77%2F7477%2F5;hp=54442c8c9d617f699def4ecf91dea056254cb3da;hpb=5c01e193a17fcf730406e39fe7d019e1dee5c64d;p=osm%2FNBI.git diff --git a/osm_nbi/authconn_keystone.py b/osm_nbi/authconn_keystone.py index 54442c8..e917306 100644 --- a/osm_nbi/authconn_keystone.py +++ b/osm_nbi/authconn_keystone.py @@ -247,10 +247,11 @@ class AuthconnKeystone(Authconn): self.logger.exception("Error during user deletion using keystone") raise AuthconnOperationException("Error during user deletion using Keystone") - def get_user_list(self): + def get_user_list(self, filter_q={}): """ Get user list. + :param filter_q: dictionary to filter user list. :return: returns a list of users. """ try: @@ -260,6 +261,14 @@ class AuthconnKeystone(Authconn): "_id": user.id } for user in users if user.name != self.admin_username] + allowed_fields = ["_id", "username"] + for key in filter_q.keys(): + if key not in allowed_fields: + continue + + users = [user for user in users + if filter_q[key] == user[key]] + for user in users: projects = self.keystone.projects.list(user=user["_id"]) projects = [{