mirror of
https://github.com/YMFE/yapi.git
synced 2025-01-18 13:04:46 +08:00
475 lines
16 KiB
JavaScript
Executable File
475 lines
16 KiB
JavaScript
Executable File
const groupModel = require('../models/group.js');
|
||
const yapi = require('../yapi.js');
|
||
const baseController = require('./base.js');
|
||
const projectModel = require('../models/project.js');
|
||
const userModel = require('../models/user.js');
|
||
const interfaceModel = require('../models/interface.js');
|
||
const interfaceColModel = require('../models/interfaceCol.js');
|
||
const interfaceCaseModel = require('../models/interfaceCase.js');
|
||
|
||
class groupController extends baseController {
|
||
constructor(ctx) {
|
||
super(ctx);
|
||
}
|
||
/**
|
||
* 添加项目分组
|
||
* @interface /group/get
|
||
* @method GET
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @param {String} id 项目分组ID
|
||
* @returns {Object}
|
||
* @example
|
||
*/
|
||
async get(ctx) {
|
||
try {
|
||
let params = ctx.request.query;
|
||
if (!params.id) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组id不能为空');
|
||
}
|
||
let groupInst = yapi.getInst(groupModel);
|
||
let result = await groupInst.getGroupById(params.id);
|
||
result = result.toObject();
|
||
result.role = await this.getProjectRole(params.id, 'group');
|
||
if(result.type === 'private'){
|
||
result.group_name = '个人空间';
|
||
}
|
||
ctx.body = yapi.commons.resReturn(result);
|
||
} catch (e) {
|
||
ctx.body = yapi.commons.resReturn(null, 400, e.message)
|
||
}
|
||
|
||
}
|
||
|
||
/**
|
||
* 添加项目分组
|
||
* @interface /group/add
|
||
* @method POST
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @param {String} group_name 项目分组名称,不能为空
|
||
* @param {String} [group_desc] 项目分组描述
|
||
* @param {String} owner_uid 组长uid
|
||
* @returns {Object}
|
||
* @example ./api/group/add.json
|
||
*/
|
||
async add(ctx) {
|
||
let params = ctx.request.body;
|
||
|
||
params = yapi.commons.handleParams(params, {
|
||
group_name: 'string',
|
||
group_desc: 'string',
|
||
owner_uid: 'number'
|
||
});
|
||
|
||
if (this.getRole() !== 'admin') {
|
||
return ctx.body = yapi.commons.resReturn(null, 401, '没有权限');
|
||
}
|
||
|
||
if (!params.group_name) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '项目分组名不能为空');
|
||
}
|
||
|
||
// if (!params.owner_uid) {
|
||
// return ctx.body = yapi.commons.resReturn(null, 400, '项目分组必须添加一个组长');
|
||
// }
|
||
|
||
let groupUserdata = null;
|
||
if (params.owner_uid) {
|
||
groupUserdata = await this.getUserdata(params.owner_uid, 'owner');
|
||
if (groupUserdata === null) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '组长uid不存在')
|
||
}
|
||
}
|
||
|
||
let groupInst = yapi.getInst(groupModel);
|
||
|
||
let checkRepeat = await groupInst.checkRepeat(params.group_name);
|
||
|
||
if (checkRepeat > 0) {
|
||
return ctx.body = yapi.commons.resReturn(null, 401, '项目分组名已存在');
|
||
}
|
||
|
||
let data = {
|
||
group_name: params.group_name,
|
||
group_desc: params.group_desc,
|
||
uid: this.getUid(),
|
||
add_time: yapi.commons.time(),
|
||
up_time: yapi.commons.time(),
|
||
members: groupUserdata ? [groupUserdata] : []
|
||
};
|
||
|
||
try {
|
||
let result = await groupInst.save(data);
|
||
|
||
result = yapi.commons.fieldSelect(result, ['_id', 'group_name', 'group_desc', 'uid', 'members']);
|
||
let username = this.getUsername();
|
||
yapi.commons.saveLog({
|
||
content: `用户 "${username}" 新增了分组 "${params.group_name}"`,
|
||
type: 'group',
|
||
uid: this.getUid(),
|
||
username: username,
|
||
typeid: result._id
|
||
});
|
||
ctx.body = yapi.commons.resReturn(result);
|
||
} catch (e) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, e.message);
|
||
}
|
||
|
||
}
|
||
|
||
async getUserdata(uid, role) {
|
||
role = role || 'dev';
|
||
let userInst = yapi.getInst(userModel);
|
||
let userData = await userInst.findById(uid);
|
||
if (!userData) {
|
||
return null;
|
||
}
|
||
return {
|
||
_role: userData.role,
|
||
role: role,
|
||
uid: userData._id,
|
||
username: userData.username,
|
||
email: userData.email
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 添加项目分组成员
|
||
* @interface /group/add_member
|
||
* @method POST
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @param {String} id 项目分组id
|
||
* @param {String} member_uid 项目分组成员uid
|
||
* @param {String} role 成员角色,owner or dev or guest
|
||
* @returns {Object}
|
||
* @example
|
||
*/
|
||
|
||
|
||
|
||
async addMember(ctx) {
|
||
|
||
let params = ctx.request.body;
|
||
let groupInst = yapi.getInst(groupModel);
|
||
if (!params.member_uid) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组成员uid不能为空');
|
||
}
|
||
if (!params.id) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组id不能为空');
|
||
}
|
||
|
||
params.role = ['owner', 'dev', 'guest'].find(v => v === params.role) || 'dev';
|
||
|
||
var check = await groupInst.checkMemberRepeat(params.id, params.member_uid);
|
||
if (check > 0) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '成员已存在');
|
||
}
|
||
let groupUserdata = await this.getUserdata(params.member_uid, params.role);
|
||
if (groupUserdata === null) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '组长uid不存在')
|
||
}
|
||
if (groupUserdata._role === 'admin') {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '不能邀请管理员')
|
||
}
|
||
delete groupUserdata._role;
|
||
try {
|
||
let result = await groupInst.addMember(params.id, groupUserdata);
|
||
let username = this.getUsername();
|
||
let rolename = {
|
||
owner: "组长",
|
||
dev: "开发者",
|
||
guest: "访客"
|
||
};
|
||
yapi.commons.saveLog({
|
||
content: `用户 "${username}" 新增了分组成员 "${groupUserdata.username}" 为 "${rolename[params.role]}"`,
|
||
type: 'group',
|
||
uid: this.getUid(),
|
||
username: username,
|
||
typeid: params.id
|
||
});
|
||
ctx.body = yapi.commons.resReturn(result);
|
||
} catch (e) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, e.message);
|
||
}
|
||
}
|
||
|
||
|
||
/**
|
||
* 修改项目分组成员角色
|
||
* @interface /group/change_member_role
|
||
* @method POST
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @param {String} id 项目分组id
|
||
* @param {String} member_uid 项目分组成员uid
|
||
* @param {String} role 权限 ['owner'|'dev']
|
||
* @returns {Object}
|
||
* @example
|
||
*/
|
||
async changeMemberRole(ctx) {
|
||
let params = ctx.request.body;
|
||
let groupInst = yapi.getInst(groupModel);
|
||
if (!params.member_uid) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组成员uid不能为空');
|
||
}
|
||
if (!params.id) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组id不能为空');
|
||
}
|
||
var check = await groupInst.checkMemberRepeat(params.id, params.member_uid);
|
||
if (check === 0) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组成员不存在');
|
||
}
|
||
if (await this.checkAuth(params.id, 'group', 'danger') !== true) {
|
||
return ctx.body = yapi.commons.resReturn(null, 405, '没有权限');
|
||
}
|
||
|
||
params.role = ['owner', 'dev', 'guest'].find(v => v === params.role) || 'dev';
|
||
|
||
try {
|
||
let result = await groupInst.changeMemberRole(params.id, params.member_uid, params.role);
|
||
let username = this.getUsername();
|
||
let rolename = {
|
||
owner: "组长",
|
||
dev: "开发者",
|
||
guest: "访客"
|
||
};
|
||
let groupUserdata = await this.getUserdata(params.member_uid, params.role);
|
||
yapi.commons.saveLog({
|
||
content: `用户 "${username}" 更改了分组成员 "${groupUserdata.username}" 的权限为 "${rolename[params.role]}"`,
|
||
type: 'group',
|
||
uid: this.getUid(),
|
||
username: username,
|
||
typeid: params.id
|
||
});
|
||
ctx.body = yapi.commons.resReturn(result);
|
||
} catch (e) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, e.message);
|
||
}
|
||
}
|
||
/**
|
||
* 获取所有项目成员
|
||
* @interface /group/get_member_list
|
||
* @method GET
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @param {String} id 项目分组id
|
||
* @returns {Object}
|
||
* @example
|
||
*/
|
||
|
||
async getMemberList(ctx) {
|
||
let params = ctx.request.query;
|
||
if (!params.id) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '项目id不能为空');
|
||
}
|
||
|
||
try {
|
||
let groupInst = yapi.getInst(groupModel);
|
||
let group = await groupInst.get(params.id);
|
||
ctx.body = yapi.commons.resReturn(group.members);
|
||
} catch (e) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, e.message);
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 删除项目成员
|
||
* @interface /group/del_member
|
||
* @method POST
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @param {String} id 项目分组id
|
||
* @param {String} member_uid 项目分组成员uid
|
||
* @returns {Object}
|
||
* @example
|
||
*/
|
||
|
||
async delMember(ctx) {
|
||
let params = ctx.request.body;
|
||
let groupInst = yapi.getInst(groupModel);
|
||
if (!params.member_uid) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组成员uid不能为空');
|
||
}
|
||
if (!params.id) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组id不能为空');
|
||
}
|
||
var check = await groupInst.checkMemberRepeat(params.id, params.member_uid);
|
||
if (check === 0) {
|
||
return ctx.body = yapi.commons.resReturn(null, 400, '分组成员不存在');
|
||
}
|
||
if (await this.checkAuth(params.id, 'group', 'danger') !== true) {
|
||
return ctx.body = yapi.commons.resReturn(null, 405, '没有权限');
|
||
}
|
||
|
||
try {
|
||
let result = await groupInst.delMember(params.id, params.member_uid);
|
||
let username = this.getUsername();
|
||
let rolename = {
|
||
owner: "组长",
|
||
dev: "开发者",
|
||
guest: "访客"
|
||
};
|
||
let groupUserdata = await this.getUserdata(params.member_uid, params.role);
|
||
yapi.commons.saveLog({
|
||
content: `用户 "${username}" 删除了分组成员 "${groupUserdata.username}"`,
|
||
type: 'group',
|
||
uid: this.getUid(),
|
||
username: username,
|
||
typeid: params.id
|
||
});
|
||
ctx.body = yapi.commons.resReturn(result);
|
||
} catch (e) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, e.message);
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 获取项目分组列表
|
||
* @interface /group/list
|
||
* @method get
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @returns {Object}
|
||
* @example ./api/group/list.json
|
||
*/
|
||
async list(ctx) {
|
||
try {
|
||
var groupInst = yapi.getInst(groupModel);
|
||
let projectInst = yapi.getInst(projectModel);
|
||
let userInst = yapi.getInst(userModel);
|
||
let result = await groupInst.list();
|
||
let privateGroup = await groupInst.getByPrivateUid(this.getUid())
|
||
let newResult = [];
|
||
|
||
if(!privateGroup){
|
||
privateGroup = await groupInst.save({
|
||
uid: this.getUid(),
|
||
group_name: 'User-' + this.getUid(),
|
||
add_time: yapi.commons.time(),
|
||
up_time: yapi.commons.time(),
|
||
type: 'private'
|
||
})
|
||
}
|
||
|
||
|
||
if(result && result.length > 0){
|
||
for(let i=0; i< result.length; i++){
|
||
result[i] = result[i].toObject();
|
||
result[i].role = await this.getProjectRole(result[i]._id, 'group');
|
||
if(result[i].role !== 'member'){
|
||
newResult.unshift(result[i]);
|
||
}else{
|
||
let publicCount = await projectInst.countWithPublic(result[i].id);
|
||
if(publicCount > 0){
|
||
newResult.push(result[i]);
|
||
}
|
||
|
||
}
|
||
}
|
||
}
|
||
if(privateGroup){
|
||
privateGroup = privateGroup.toObject();
|
||
privateGroup.group_name = '个人空间';
|
||
privateGroup.role = 'owner';
|
||
newResult.unshift(privateGroup);
|
||
}
|
||
|
||
ctx.body = yapi.commons.resReturn(newResult);
|
||
} catch (e) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, e.message);
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 删除项目分组
|
||
* @interface /group/del
|
||
* @method post
|
||
* @param {String} id 项目分组id
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @returns {Object}
|
||
* @example ./api/group/del.json
|
||
*/
|
||
async del(ctx) {
|
||
if (this.getRole() !== 'admin') {
|
||
return ctx.body = yapi.commons.resReturn(null, 401, '没有权限');
|
||
}
|
||
|
||
try {
|
||
let groupInst = yapi.getInst(groupModel);
|
||
let projectInst = yapi.getInst(projectModel);
|
||
let interfaceInst = yapi.getInst(interfaceModel);
|
||
let interfaceColInst = yapi.getInst(interfaceColModel);
|
||
let interfaceCaseInst = yapi.getInst(interfaceCaseModel);
|
||
let id = ctx.request.body.id;
|
||
|
||
if (!id) {
|
||
return ctx.body = yapi.commons.resReturn(null, 402, 'id不能为空');
|
||
}
|
||
let projectList = await projectInst.list(id, true);
|
||
projectList.forEach(async (p) => {
|
||
await interfaceInst.delByProjectId(p._id)
|
||
await interfaceCaseInst.delByProjectId(p._id)
|
||
await interfaceColInst.delByProjectId(p._id)
|
||
})
|
||
await projectInst.delByGroupid(id);
|
||
let result = await groupInst.del(id);
|
||
ctx.body = yapi.commons.resReturn(result);
|
||
} catch (err) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, err.message);
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 更新项目分组
|
||
* @interface /group/up
|
||
* @method post
|
||
* @param {String} id 项目分组id
|
||
* @param {String} group_name 项目分组名称
|
||
* @param {String} group_desc 项目分组描述
|
||
* @category group
|
||
* @foldnumber 10
|
||
* @returns {Object}
|
||
* @example ./api/group/up.json
|
||
*/
|
||
async up(ctx) {
|
||
|
||
let groupInst = yapi.getInst(groupModel);
|
||
let id = ctx.request.body.id;
|
||
let data = {};
|
||
|
||
if (await this.checkAuth(id, 'group', 'danger') !== true) {
|
||
return ctx.body = yapi.commons.resReturn(null, 405, '没有权限');
|
||
}
|
||
try {
|
||
ctx.request.body = yapi.commons.handleParams(ctx.request.body, {
|
||
id: 'number',
|
||
group_name: 'string',
|
||
group_desc: 'string'
|
||
});
|
||
|
||
ctx.request.body.group_name && (data.group_name = ctx.request.body.group_name);
|
||
ctx.request.body.group_desc && (data.group_desc = ctx.request.body.group_desc);
|
||
if (Object.keys(data).length === 0) {
|
||
ctx.body = yapi.commons.resReturn(null, 404, '分组名和分组描述不能为空');
|
||
}
|
||
let result = await groupInst.up(id, data);
|
||
let username = this.getUsername();
|
||
yapi.commons.saveLog({
|
||
content: `用户 "${username}" 更新了 "${data.group_name}" 分组`,
|
||
type: 'group',
|
||
uid: this.getUid(),
|
||
username: username,
|
||
typeid: id
|
||
});
|
||
ctx.body = yapi.commons.resReturn(result);
|
||
} catch (err) {
|
||
ctx.body = yapi.commons.resReturn(null, 402, err.message);
|
||
}
|
||
}
|
||
}
|
||
|
||
module.exports = groupController;
|