user = osmutils.get_user(request)
client = Client()
result = client.user_list(user.get_token())
+
result = {
'users': result['data'] if result and result['error'] is False else []
}
+
return __response_handler(request, result, 'user_list.html')
def create(request):
user = osmutils.get_user(request)
client = Client()
- user_data ={
+ user_data = {
"username": request.POST['username'],
"password": request.POST['password'],
- "projects": request.POST.getlist('projects')
+ "domain_name": request.POST['domain_name']
}
+
result = client.user_create(user.get_token(), user_data)
if result['error']:
return __response_handler(request, result['data'], url=None,
else:
return __response_handler(request, {}, url=None, status=200)
+
+@login_required
+def user_info(request, user_id=None):
+ user = osmutils.get_user(request)
+ try:
+ client = Client()
+
+ info_res = client.get_user_info(user.get_token(), user_id)
+ except Exception as e:
+ log.exception(e)
+ info_res = {'error': True, 'data': str(e)}
+ if info_res['error']:
+ return __response_handler(request, info_res['data'], url=None,
+ status=info_res['data']['status'] if 'status' in info_res['data'] else 500)
+ else:
+ return __response_handler(request, info_res['data'], url=None, status=200)
+
+
@login_required
def update(request, user_id=None):
user = osmutils.get_user(request)
try:
client = Client()
- projects_old = request.POST.get('projects_old').split(',')
- projects_new = request.POST.getlist('projects')
- default_project = request.POST.get('default_project')
- projects_new.append(default_project)
- projects_to_add = list(set(projects_new) - set(projects_old))
- projects_to_remove = list(set(projects_old) - set(projects_new))
-
- project_payload = {}
-
- for p in projects_to_remove:
- project_payload["$"+str(p)] = None
- for p in projects_to_add:
- if p not in projects_old:
- project_payload["$+"+str(p)] = str(p)
- project_payload["$" + default_project] = None
- project_payload["$+[0]"] = default_project
payload = {}
- if project_payload:
- payload["projects"] = project_payload
+
if request.POST.get('password') and request.POST.get('password') is not '':
payload["password"] = request.POST.get('password')
+ if request.POST.getlist('map_project_name') and request.POST.getlist('map_role_name'):
+ project_param_name = request.POST.getlist('map_project_name')
+ role_param_ip = request.POST.getlist('map_role_name')
+ payload["project_role_mappings"] = []
+ for i, project in enumerate(project_param_name):
+ payload["project_role_mappings"].append({
+ 'project': project,
+ 'role': role_param_ip[i],
+ })
+
update_res = client.user_update(user.get_token(), user_id, payload)
except Exception as e:
log.exception(e)
status=update_res['data']['status'] if 'status' in update_res['data'] else 500)
else:
return __response_handler(request, {}, url=None, status=200)
- #return __response_handler(request, {}, 'users:list', to_redirect=True, )
def __response_handler(request, data_res, url=None, to_redirect=None, *args, **kwargs):