|
|
@ -4,6 +4,51 @@ const MD5 = require('crypto-js/md5'); |
|
|
|
const moment = require('moment'); |
|
|
|
const uuid = require('uuid'); |
|
|
|
|
|
|
|
async function getDataRange(ctx) { |
|
|
|
//null为所有权限,不加条件过滤
|
|
|
|
let userIds = null; |
|
|
|
let departmentNames = null; |
|
|
|
let userNames = null; |
|
|
|
let dataRange = null; |
|
|
|
const { adminHr, id, department, allDepartment } = ctx.fs.api.userInfo; |
|
|
|
//人资管理-所有权限
|
|
|
|
if (adminHr.filter(admin => admin.id == id).length) { |
|
|
|
dataRange = 1; |
|
|
|
} else { |
|
|
|
const models = ctx.fs.dc.models; |
|
|
|
//获取用户对应角色的最高数据范围
|
|
|
|
let roleRes = await models.Role.findAll({ |
|
|
|
include: [{ |
|
|
|
model: models.UserRole, |
|
|
|
where: { userId: id } |
|
|
|
}] |
|
|
|
}) |
|
|
|
if (roleRes.some(r => r.dataRange && r.dataRange === 1)) { |
|
|
|
dataRange = 1; |
|
|
|
} else { |
|
|
|
const departments = allDepartment.departments; |
|
|
|
dataRange = 2; |
|
|
|
userIds = []; |
|
|
|
userNames = []; |
|
|
|
if (department && departments) { |
|
|
|
let userDeps = department.map(d => d.id); |
|
|
|
departmentNames = department.map(d => d.name); |
|
|
|
let deps = departments.filter(d => userDeps.indexOf(d.id) > -1) |
|
|
|
if (deps && deps.length > 0) { |
|
|
|
deps.map(d => d.users.map(u => { |
|
|
|
if (userIds.indexOf(u.id) < 0) { |
|
|
|
userIds.push(u.id); |
|
|
|
userNames.push(u.name); |
|
|
|
} |
|
|
|
})); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
return { dataRange, userIds, departmentNames, userNames }; |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
async function login(ctx, next) { |
|
|
|
// const transaction = await ctx.fs.dc.orm.transaction();
|
|
|
|
try { |
|
|
@ -81,4 +126,5 @@ async function logout (ctx) { |
|
|
|
module.exports = { |
|
|
|
login, |
|
|
|
logout, |
|
|
|
getDataRange |
|
|
|
}; |