* feat(member-group): Team (#2616) * feat: member-group schema define * feat(fe): create group * feat: add group edit modal * feat(fe): add avatar group component * feat: edit group fix: permission select menu style * feat: bio-mode support for select-member component * fix: avatar group key unique * feat: group manage * feat: divide member into group and clbs * feat: finish team permission * chore: adjust * fix: get clbs * perf: groups code * pref: member group for team (#2706) * chore: fe adjust fix: remove the member from groups when removing from team feat: change the groups avatar when updating the team's avatar * chore: DefaultGroupName as a constant string '' * fix: create default group when create team for root * feat: comment * feat: 4811 init * pref: member group for team (#2732) * chore: default group name * feat: get default group when get by tmbid * feat(fe): adjust * member ui * fix: delete group (#2736) * perf: init4811 * pref: member group (#2818) * fix: update clb per then refetch clb list * fix: calculate group permission * feat(fe): group tag * refactor(fe): team and group manage * feat: manage group member * feat: add group transfer owner modal * feat: group manage member * chore: adjust the file structure * pref: member group * chore: adjust fe style * fix: ts error * chore: fe adjust * chore: fe adjust * chore: adjust * chore: adjust the code * perf: i18n and schema name * pref: member-group (#2862) * feat: group list ordered by updateTime * fix: transfer ownership of group when deleting member * fix: i18n fix * feat: can not set member as admin/owner when user is not active * fix: GroupInfoModal hover input do not change color * fix(fe): searchinput do not scroll * perf: team group ui * doc * remove enum --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
65 lines
1.9 KiB
TypeScript
65 lines
1.9 KiB
TypeScript
import type { NextApiRequest, NextApiResponse } from 'next';
|
|
import { jsonRes } from '@fastgpt/service/common/response';
|
|
import { connectToDatabase } from '@/service/mongo';
|
|
import { authCert } from '@fastgpt/service/support/permission/auth/common';
|
|
import { MongoAppVersion } from '@fastgpt/service/core/app/version/schema';
|
|
import { FastGPTProUrl } from '@fastgpt/service/common/system/constants';
|
|
import { POST } from '@fastgpt/service/common/api/plusRequest';
|
|
import { MongoTeam } from '@fastgpt/service/support/user/team/teamSchema';
|
|
import { MongoMemberGroupModel } from '@fastgpt/service/support/permission/memberGroup/memberGroupSchema';
|
|
import { delay } from '@fastgpt/global/common/system/utils';
|
|
import { DefaultGroupName } from '@fastgpt/global/support/user/team/group/constant';
|
|
|
|
/*
|
|
1. 给每个 team 创建一个默认的 group
|
|
*/
|
|
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
try {
|
|
await connectToDatabase();
|
|
await authCert({ req, authRoot: true });
|
|
|
|
const teamList = await MongoTeam.find({}, '_id');
|
|
console.log('Total team', teamList.length);
|
|
let success = 0;
|
|
|
|
async function createGroup(teamId: string) {
|
|
try {
|
|
await MongoMemberGroupModel.updateOne(
|
|
{
|
|
teamId,
|
|
name: DefaultGroupName
|
|
},
|
|
{
|
|
$set: {
|
|
teamId: teamId,
|
|
name: DefaultGroupName
|
|
}
|
|
},
|
|
{
|
|
upsert: true
|
|
}
|
|
);
|
|
} catch (error) {
|
|
console.log(error);
|
|
await delay(500);
|
|
return createGroup(teamId);
|
|
}
|
|
}
|
|
for await (const team of teamList) {
|
|
await createGroup(team._id);
|
|
console.log(++success);
|
|
}
|
|
|
|
jsonRes(res, {
|
|
message: 'success'
|
|
});
|
|
} catch (error) {
|
|
console.log(error);
|
|
|
|
jsonRes(res, {
|
|
code: 500,
|
|
error
|
|
});
|
|
}
|
|
}
|