Browse Source

(*)增加获取用户角色资源

master
zmh 2 years ago
parent
commit
96d7b153f5
  1. 201
      api/app/lib/controllers/userRole/index.js
  2. 8
      api/app/lib/models/role_resource.js
  3. 11
      api/app/lib/routes/userRole/index.js

201
api/app/lib/controllers/userRole/index.js

@ -3,97 +3,146 @@ const moment = require('moment')
const fs = require('fs'); const fs = require('fs');
async function get(ctx) { async function get(ctx) {
try { try {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
let userRoleList = await models.UserRole.findAndCountAll({ let userRoleList = await models.UserRole.findAndCountAll({
order: [['id', 'desc']] order: [['id', 'desc']]
}); });
ctx.status = 200 ctx.status = 200
ctx.body = userRoleList; ctx.body = userRoleList;
} catch (error) { } catch (error) {
ctx.fs.logger.error(`path:${ctx.path},error:${error}`) ctx.fs.logger.error(`path:${ctx.path},error:${error}`)
ctx.status = 400; ctx.status = 400;
ctx.body = { name: 'FindError', message: '查询用户信息失败' } ctx.body = { name: 'FindError', message: '查询用户信息失败' }
} }
} }
async function add(ctx) { async function add(ctx) {
try { try {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
const { userId, roleId } = ctx.request.body const { userId, roleId } = ctx.request.body
await models.UserRole.destroy({ await models.UserRole.destroy({
where: { roleId: roleId } where: { roleId: roleId }
}) })
let storageData = userId.map(e => { let storageData = userId.map(e => {
return { return {
roleId: roleId, roleId: roleId,
userId: e userId: e
} }
}) })
await models.UserRole.bulkCreate(storageData); await models.UserRole.bulkCreate(storageData);
ctx.status = 204; ctx.status = 204;
} catch (error) { } catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400; ctx.status = 400;
ctx.body = { ctx.body = {
message: typeof error == 'string' ? error : undefined message: typeof error == 'string' ? error : undefined
} }
} }
} }
async function edit(ctx) { async function edit(ctx) {
try { try {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
// const { pepUserId, provinces, cities, businessLines } = ctx.request.body // const { pepUserId, provinces, cities, businessLines } = ctx.request.body
const { id, name } = ctx.request.body const { id, name } = ctx.request.body
const role = await models.Role.findOne({ const role = await models.Role.findOne({
where: { id } where: { id }
}) })
if (!role) { if (!role) {
throw '当前角色不存在' throw '当前角色不存在'
} }
let storageData = { name } let storageData = { name }
await models.Role.update(storageData, { await models.Role.update(storageData, {
where: { id } where: { id }
}) })
ctx.status = 204; ctx.status = 204;
} catch (error) { } catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400; ctx.status = 400;
ctx.body = { ctx.body = {
message: typeof error == 'string' ? error : undefined message: typeof error == 'string' ? error : undefined
} }
} }
} }
async function del(ctx) { async function del(ctx) {
try { try {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
const { id } = ctx.request.body const { id } = ctx.request.body
await models.SalesDistribution.update({ await models.SalesDistribution.update({
delete: false delete: false
}, },
{ {
where: { id } where: { id }
}) })
ctx.status = 204; ctx.status = 204;
} catch (error) { } catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400; ctx.status = 400;
ctx.body = { ctx.body = {
message: typeof error == 'string' ? error : undefined message: typeof error == 'string' ? error : undefined
} }
} }
} }
async function getUserResources(ctx) {
try {
const { adminHr } = ctx.fs.api.userInfo;
const { models } = ctx.fs.dc;
const { userId } = ctx.params;
let codes = [];
//人资管理员-所有权限
if (adminHr.some(admin => admin.id == userId)) {
const resource = await models.Resource.findAll({
attributes: ['code'],
order: [['id', 'asc']]
})
codes = resource.map(r => r.code);
} else {
const userResources = await models.RoleResource.findAll({
attributes: ['id', 'resId'],
include: [{
required: true,
model: models.Role,
attributes: [],
include: [{
model: models.UserRole,
attributes: [],
where: { userId: userId }
}],
}, {
required: true,
model: models.Resource,
attributes: ['id', 'name', 'code'],
}],
order: [['id', 'asc']]
});
let rslt = [];
userResources && userResources.map(ur => {
if (!rslt.some(r => r.id === ur.resId)) {
rslt.push(ur.resource);
codes.push(ur.resource.code);
}
})
}
ctx.status = 200;
ctx.body = codes;
} catch (error) {
ctx.fs.logger.error(`path:${ctx.path},error:${error}`)
ctx.status = 400;
ctx.body = { name: 'FindError', message: '获取用户角色资源失败' }
}
}
module.exports = { module.exports = {
get, get,
add, add,
edit, edit,
del, del,
getUserResources
} }

8
api/app/lib/models/role_resource.js

@ -39,5 +39,13 @@ module.exports = dc => {
indexes: [] indexes: []
}); });
dc.models.RoleResource = RoleResource; dc.models.RoleResource = RoleResource;
const Role = dc.models.Role;
RoleResource.belongsTo(Role, { foreignKey: 'roleId', targetKey: 'id' });
Role.hasMany(RoleResource, { foreignKey: 'roleId', sourceKey: 'id' });
const Resource = dc.models.Resource;
RoleResource.belongsTo(Resource, { foreignKey: 'resId', targetKey: 'id' });
Resource.hasMany(RoleResource, { foreignKey: 'resId', sourceKey: 'id' });
return RoleResource; return RoleResource;
}; };

11
api/app/lib/routes/userRole/index.js

@ -4,11 +4,14 @@ const userRole = require('../../controllers/userRole');
module.exports = function (app, router, opts) { module.exports = function (app, router, opts) {
app.fs.api.logAttr['GET/roleUser/list'] = { content: '角色用户列表', visible: true }; app.fs.api.logAttr['GET/roleUser/list'] = { content: '角色用户列表', visible: true };
router.get('/roleUser/list', userRole.get); router.get('/roleUser/list', userRole.get);
app.fs.api.logAttr['POST/roleUser/add'] = { content: '角色添加用户成功', visible: true }; app.fs.api.logAttr['POST/roleUser/add'] = { content: '角色添加用户成功', visible: true };
router.post('/roleUser/add', userRole.add); router.post('/roleUser/add', userRole.add);
app.fs.api.logAttr['GET/user/:userId/role/resources'] = { content: '获取用户角色资源', visible: true };
router.get('/user/:userId/role/resources', userRole.getUserResources);
}; };
Loading…
Cancel
Save