X-Git-Url: https://osm.etsi.org/gitweb/?p=osm%2FUI.git;a=blobdiff_plain;f=skyquake%2Fframework%2Fcore%2Fmodules%2Fapi%2FuserManagementAPI.js;h=fdce725b03b3d738e4428e6be84b220e17b42471;hp=c6260dfea58557872e6556d1f6021d6c7bda42cc;hb=refs%2Fheads%2Fprojects;hpb=7667a1e05e21dc336503f058cac111fac91f06c6 diff --git a/skyquake/framework/core/modules/api/userManagementAPI.js b/skyquake/framework/core/modules/api/userManagementAPI.js index c6260dfea..fdce725b0 100644 --- a/skyquake/framework/core/modules/api/userManagementAPI.js +++ b/skyquake/framework/core/modules/api/userManagementAPI.js @@ -32,8 +32,7 @@ UserManagement.get = function(req) { var api_server = req.query['api_server']; return new Promise(function(resolve, reject) { - Promise.all([ - rp({ + var userConfig = rp({ uri: utils.confdPort(api_server) + '/api/operational/user-config/user', method: 'GET', headers: _.extend({}, constants.HTTP_HEADERS.accept.data, { @@ -42,15 +41,53 @@ UserManagement.get = function(req) { forever: constants.FOREVER_ON, rejectUnauthorized: false, resolveWithFullResponse: true + }); + var userOp = rp({ + uri: utils.confdPort(api_server) + '/api/operational/user-state/user', + method: 'GET', + headers: _.extend({}, constants.HTTP_HEADERS.accept.data, { + 'Authorization': req.session && req.session.authorization + }), + forever: constants.FOREVER_ON, + rejectUnauthorized: false, + resolveWithFullResponse: true }) + Promise.all([ + userConfig, + userOp ]).then(function(result) { var response = {}; response['data'] = {}; + var resultData = []; if (result[0].body) { - response['data']['user'] = JSON.parse(result[0].body)['rw-user:user']; + resultData.push(JSON.parse(result[0].body)['rw-user:user'].sort()); + } + if (result[1].body) { + resultData.push(JSON.parse(result[1].body)['rw-user:user'].sort()); } response.statusCode = constants.HTTP_RESPONSE_CODES.SUCCESS.OK - + response['data']['user'] = resultData[0].map(function(d,i) { + var mergedData = _.merge(d, resultData[1][i]); + mergedData.projects = { + ids: [], + data: {} + }; + var projects = mergedData.projects; + mergedData.role && mergedData.role.map(function(r) { + if ((r.role != "rw-project:user-self" )&& (r.role != "rw-rbac-platform:user-self")) { + var projectId = r.keys.split(';')[0]; + if (projectId == "") { + projectId = "platform" + } + if (!projects.data[projectId]) { + projects.ids.push(projectId); + projects.data[projectId] = []; + } + projects.data[projectId].push(r.role); + } + }) + return mergedData; + }) resolve(response); }).catch(function(error) { var response = {}; @@ -70,21 +107,27 @@ UserManagement.getProfile = function(req) { var api_server = req.query['api_server']; return new Promise(function(resolve, reject) { var response = {}; - var userId = req.session.userdata.username - response['data'] = { - userId: userId, - projectId: req.session.projectId - }; - UserManagement.getUserInfo(req, userId).then(function(result) { - response.statusCode = constants.HTTP_RESPONSE_CODES.SUCCESS.OK; - response.data.data =result.data - resolve(response); - }, function(error) { - console.log('Error retrieving getUserInfo'); + try { + var userId = req.session.userdata.username + response['data'] = { + userId: userId, + projectId: req.session.projectId + }; + UserManagement.getUserInfo(req, userId).then(function(result) { + response.statusCode = constants.HTTP_RESPONSE_CODES.SUCCESS.OK; + response.data.data = result.data + resolve(response); + }, function(error) { + console.log('Error retrieving getUserInfo'); + response.statusCode = constants.HTTP_RESPONSE_CODES.ERROR.INTERNAL_SERVER_ERROR; + reject(response); + }) + } catch (e) { + response.data.data = e; response.statusCode = constants.HTTP_RESPONSE_CODES.ERROR.INTERNAL_SERVER_ERROR; reject(response); - }) - + reject() + } }); }; UserManagement.getUserInfo = function(req, userId, domain) { @@ -107,6 +150,8 @@ UserManagement.getUserInfo = function(req, userId, domain) { } }, + //id/key values for each project + projectId:[], project: { /** * [projectId] : { @@ -123,6 +168,7 @@ UserManagement.getUserInfo = function(req, userId, domain) { var userProjects = []; projects && projects.map(function(p, i) { var users = p['project-config'] && p['project-config'].user; + userData.projectId.push(p.name); users && users.map(function(u) { if(u['user-name'] == id) { userData.project[p.name] = { @@ -132,6 +178,9 @@ UserManagement.getUserInfo = function(req, userId, domain) { u.role && u.role.map(function(r) { userData.project[p.name].role[r.role] = true }); + u["rw-project-mano:mano-role"] && u["rw-project-mano:mano-role"] .map(function(r) { + userData.project[p.name].role[r.role] = true + }); } }) }); @@ -199,7 +248,7 @@ UserManagement.update = function(req) { var api_server = req.query['api_server']; var bodyData = req.body; data = { - "user":[bodyData] + "rw-user:user": bodyData } var updateTasks = []; if(bodyData.hasOwnProperty('old-password')) { @@ -225,7 +274,7 @@ UserManagement.update = function(req) { updateTasks.push(changePW); }; var updateUser = rp({ - uri: utils.confdPort(api_server) + '/api/config/user-config', + uri: utils.confdPort(api_server) + '/api/config/user-config/user/' + bodyData['user-name'] + ',' + bodyData['user-domain'], method: 'PUT', headers: _.extend({}, constants.HTTP_HEADERS.accept.data, { 'Authorization': req.session && req.session.authorization