|
|
|
'use strict';
|
|
|
|
const Hex = require('crypto-js/enc-hex');
|
|
|
|
const MD5 = require('crypto-js/md5');
|
|
|
|
|
|
|
|
// async function getDepMessage (ctx, next) {
|
|
|
|
// try {
|
|
|
|
// const { fs: { api: { userInfo } } } = ctx
|
|
|
|
// const models = ctx.fs.dc.models;
|
|
|
|
|
|
|
|
// let deptWhere = {}
|
|
|
|
// if (userInfo.username !== 'SuperAdmin') {
|
|
|
|
// deptWhere.id = userInfo.departmentId
|
|
|
|
// }
|
|
|
|
// let depType1 = await models.Department.findAll({
|
|
|
|
// order: [['id', 'asc']],
|
|
|
|
// // include: [{
|
|
|
|
// // model: models.User,
|
|
|
|
// // required: false,
|
|
|
|
// // where: { delete: false },
|
|
|
|
// // attributes: { exclude: ['password'] },
|
|
|
|
// // }],
|
|
|
|
// where: deptWhere,
|
|
|
|
// })
|
|
|
|
|
|
|
|
// let depRslt = []
|
|
|
|
// const getDep = async (d) => {
|
|
|
|
// let subordinate = []
|
|
|
|
// let depRes = await models.Department.findAll({
|
|
|
|
// order: [['id', 'asc']],
|
|
|
|
// // include: [{
|
|
|
|
// // model: models.User,
|
|
|
|
// // required: false,
|
|
|
|
// // where: { delete: false },
|
|
|
|
// // attributes: { exclude: ['password'] },
|
|
|
|
// // }],
|
|
|
|
// where: {
|
|
|
|
// dependence: d.id
|
|
|
|
// },
|
|
|
|
// })
|
|
|
|
// if (depRes.length)
|
|
|
|
// for (let d of depRes) {
|
|
|
|
// let dep = d.dataValues
|
|
|
|
// dep.subordinate = await getDep(d.dataValues)
|
|
|
|
// subordinate.push(dep)
|
|
|
|
// }
|
|
|
|
// return subordinate
|
|
|
|
// }
|
|
|
|
// for (let d of depType1) {
|
|
|
|
// let dep_1 = d.dataValues
|
|
|
|
// dep_1.subordinate = await getDep(d.dataValues)
|
|
|
|
// depRslt.push(dep_1)
|
|
|
|
// }
|
|
|
|
|
|
|
|
// ctx.status = 200;
|
|
|
|
// ctx.body = depRslt
|
|
|
|
// } catch (error) {
|
|
|
|
// ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
// ctx.status = 400;
|
|
|
|
// ctx.body = {
|
|
|
|
// "message": "获取部门信息失败"
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
|
|
|
|
async function getDepMessage(ctx, next) {
|
|
|
|
let error = { name: 'FindError', message: '获取部门列表失败' };
|
|
|
|
let rslt = [];
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
let list = await models.Department.findAll({});
|
|
|
|
|
|
|
|
let deptMap = []
|
|
|
|
list.filter(l => !l.dependence).map(ld => {//一级
|
|
|
|
deptMap.push({
|
|
|
|
id: ld.id,
|
|
|
|
name: ld.name,
|
|
|
|
dependence: ld.dependence,
|
|
|
|
subordinate: []
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
list.filter(l => l.dependence).map(ld => {//二级
|
|
|
|
let parent = deptMap.find(dm => dm.id == ld.dependence);
|
|
|
|
if (parent) {
|
|
|
|
parent.subordinate.push({
|
|
|
|
id: ld.id,
|
|
|
|
name: ld.name,
|
|
|
|
dependence: ld.dependence,
|
|
|
|
subordinate: []
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
rslt = deptMap;
|
|
|
|
|
|
|
|
error = null;
|
|
|
|
} catch (err) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${err}`);
|
|
|
|
}
|
|
|
|
if (error) {
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = error;
|
|
|
|
} else {
|
|
|
|
ctx.status = 200;
|
|
|
|
ctx.body = rslt;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function createDept(ctx, next) {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
try {
|
|
|
|
let rslt = ctx.request.body;
|
|
|
|
await models.Department.create(Object.assign({}, rslt, { read: 1 }))
|
|
|
|
ctx.status = 204;
|
|
|
|
ctx.body = { message: '新建部门成功' }
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '新建部门失败' }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function updateDept(ctx, next) {
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { id } = ctx.params;
|
|
|
|
const body = ctx.request.body;
|
|
|
|
await models.Department.update(
|
|
|
|
body,
|
|
|
|
{ where: { id: id } }
|
|
|
|
)
|
|
|
|
ctx.status = 204;
|
|
|
|
ctx.body = { message: '修改部门成功' }
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '修改部门失败' }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function delDept(ctx, next) {
|
|
|
|
let errMsg = "删除部门失败";
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { id } = ctx.params;
|
|
|
|
let list = await models.Department.findAll({});
|
|
|
|
let deptIds = list.map(l => l.id);
|
|
|
|
const allUsers = await models.User.findAll({
|
|
|
|
where: {
|
|
|
|
departmentId: { $in: deptIds },
|
|
|
|
delete: false
|
|
|
|
}
|
|
|
|
})
|
|
|
|
const childrenDept = await models.Department.findAll({ where: { dependence: id } })
|
|
|
|
const childrenUser = allUsers.filter(au => au.departmentId == id);
|
|
|
|
if (childrenUser.length || childrenDept.length) {
|
|
|
|
errMsg = '请先删除部门下的用户或子部门';
|
|
|
|
throw errMsg;
|
|
|
|
}
|
|
|
|
await models.Department.destroy({ where: { id: id } });
|
|
|
|
await models.Department.destroy({ where: { dependence: id } });
|
|
|
|
ctx.status = 204;
|
|
|
|
ctx.body = { message: '删除部门成功' }
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: error }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function getUser(ctx, next) {
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { depId } = ctx.params;
|
|
|
|
let userRes = null;
|
|
|
|
if (depId !== 'null') {
|
|
|
|
userRes = await models.User.findAll({
|
|
|
|
where: {
|
|
|
|
departmentId: parseInt(depId),
|
|
|
|
delete: false
|
|
|
|
},
|
|
|
|
attributes: { exclude: ['password'] },
|
|
|
|
order: [['id', 'asc']],
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
userRes = await models.User.findAll({
|
|
|
|
where: {
|
|
|
|
delete: false
|
|
|
|
},
|
|
|
|
attributes: { exclude: ['password'] },
|
|
|
|
order: [['id', 'asc']],
|
|
|
|
include: [{
|
|
|
|
required: true,
|
|
|
|
model: models.Department,
|
|
|
|
attributes: ['id', 'name'],
|
|
|
|
}]
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx.status = 200;
|
|
|
|
ctx.body = userRes
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = {
|
|
|
|
"message": "获取用户信息失败"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function creatUser(ctx, next) {
|
|
|
|
let errMsg = "新建用户失败"
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const data = ctx.request.body;
|
|
|
|
|
|
|
|
let repeatUserNameCount = await models.User.count({
|
|
|
|
where: {
|
|
|
|
username: data.phone,
|
|
|
|
delete: false
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
if (repeatUserNameCount) {
|
|
|
|
errMsg = '已有当前用户名'
|
|
|
|
throw errMsg
|
|
|
|
}
|
|
|
|
|
|
|
|
await models.User.create({
|
|
|
|
name: data.name,
|
|
|
|
username: data.phone,
|
|
|
|
password: Hex.stringify(MD5(data.password)),
|
|
|
|
departmentId: data.departmentId,
|
|
|
|
email: data.email,
|
|
|
|
enable: data.enable,
|
|
|
|
delete: false,
|
|
|
|
phone: data.phone,
|
|
|
|
post: data.post,
|
|
|
|
structure:data.structure
|
|
|
|
})
|
|
|
|
|
|
|
|
ctx.status = 204;
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = {
|
|
|
|
"message": errMsg
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async function updateUser(ctx, next) {
|
|
|
|
let errMsg = "修改用户失败"
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const data = ctx.request.body;
|
|
|
|
const { id } = ctx.params;
|
|
|
|
|
|
|
|
let repeatUserNameCount = await models.User.count({
|
|
|
|
where: {
|
|
|
|
username: data.username
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
if (repeatUserNameCount) {
|
|
|
|
errMsg = '已有当前用户名'
|
|
|
|
throw errMsg
|
|
|
|
}
|
|
|
|
|
|
|
|
await models.User.update({
|
|
|
|
name: data.name,
|
|
|
|
username: data.phone,
|
|
|
|
departmentId: data.departmentId,
|
|
|
|
email: data.email,
|
|
|
|
enable: data.enable,
|
|
|
|
delete: false,
|
|
|
|
phone: data.phone,
|
|
|
|
post: data.post,
|
|
|
|
structure:data.structure
|
|
|
|
}, {
|
|
|
|
where: {
|
|
|
|
id: id
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
ctx.status = 204;
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = {
|
|
|
|
"message": errMsg
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function deleteUser(ctx, next) {
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { ids } = ctx.params;
|
|
|
|
const userIds = ids.split(',');
|
|
|
|
await models.User.update({
|
|
|
|
delete: true,
|
|
|
|
}, {
|
|
|
|
where: {
|
|
|
|
id: { $in: userIds },
|
|
|
|
}
|
|
|
|
});
|
|
|
|
ctx.status = 204;
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = {
|
|
|
|
"message": "删除用户失败"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function resetPwd(ctx, next) {
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { id } = ctx.params;
|
|
|
|
const data = ctx.request.body;
|
|
|
|
await models.User.update({
|
|
|
|
password: Hex.stringify(MD5(data.password)),
|
|
|
|
}, {
|
|
|
|
where: {
|
|
|
|
id: id,
|
|
|
|
}
|
|
|
|
});
|
|
|
|
ctx.status = 204;
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = {
|
|
|
|
"message": "重置用户密码失败"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 修改用户密码
|
|
|
|
* @params {userId-用户Id} ctx
|
|
|
|
* @request.body {password-用户新密码} ctx
|
|
|
|
*/
|
|
|
|
async function updateUserPassword(ctx, next) {
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { userId } = ctx.params;
|
|
|
|
const { password } = ctx.request.body;
|
|
|
|
if (!password) {
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { "message": "请输入修改密码" };
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const userRes = await models.User.findOne({
|
|
|
|
where: {
|
|
|
|
id: userId
|
|
|
|
},
|
|
|
|
attributes: ['id']
|
|
|
|
});
|
|
|
|
if (userRes) {
|
|
|
|
await models.User.update({ password: Hex.stringify(MD5(password)) }, { where: { id: userId, } });
|
|
|
|
ctx.status = 204;
|
|
|
|
} else {
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = {
|
|
|
|
"message": "用户不存在"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = {
|
|
|
|
"message": "修改用户密码失败"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
getDepMessage,
|
|
|
|
createDept,
|
|
|
|
updateDept,
|
|
|
|
delDept,
|
|
|
|
getUser,
|
|
|
|
creatUser,
|
|
|
|
updateUser,
|
|
|
|
deleteUser,
|
|
|
|
resetPwd,
|
|
|
|
updateUserPassword
|
|
|
|
}
|