diff options
| author | syuilo <Syuilotan@yahoo.co.jp> | 2021-10-16 17:42:17 +0900 |
|---|---|---|
| committer | syuilo <Syuilotan@yahoo.co.jp> | 2021-10-16 17:42:17 +0900 |
| commit | d184f73160765b8bcefbd934dc2448c644fc2fa7 (patch) | |
| tree | 15f365810ddb81c4748a4596f1b60e0777d9df87 /src/server/api | |
| parent | :art: (diff) | |
| download | sharkey-d184f73160765b8bcefbd934dc2448c644fc2fa7.tar.gz sharkey-d184f73160765b8bcefbd934dc2448c644fc2fa7.tar.bz2 sharkey-d184f73160765b8bcefbd934dc2448c644fc2fa7.zip | |
feat(api): add users/groups/leave
Resolve #7775
Diffstat (limited to 'src/server/api')
| -rw-r--r-- | src/server/api/endpoints/users/groups/leave.ts | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/src/server/api/endpoints/users/groups/leave.ts b/src/server/api/endpoints/users/groups/leave.ts new file mode 100644 index 0000000000..0e52f2abdf --- /dev/null +++ b/src/server/api/endpoints/users/groups/leave.ts @@ -0,0 +1,50 @@ +import $ from 'cafy'; +import { ID } from '@/misc/cafy-id'; +import define from '../../../define'; +import { ApiError } from '../../../error'; +import { UserGroups, UserGroupJoinings } from '@/models/index'; + +export const meta = { + tags: ['groups', 'users'], + + requireCredential: true as const, + + kind: 'write:user-groups', + + params: { + groupId: { + validator: $.type(ID), + }, + }, + + errors: { + noSuchGroup: { + message: 'No such group.', + code: 'NO_SUCH_GROUP', + id: '62780270-1f67-5dc0-daca-3eb510612e31' + }, + + youAreOwner: { + message: 'Your are the owner.', + code: 'YOU_ARE_OWNER', + id: 'b6d6e0c2-ef8a-9bb8-653d-79f4a3107c69' + }, + } +}; + +export default define(meta, async (ps, me) => { + // Fetch the group + const userGroup = await UserGroups.findOne({ + id: ps.groupId, + }); + + if (userGroup == null) { + throw new ApiError(meta.errors.noSuchGroup); + } + + if (me.id === userGroup.userId) { + throw new ApiError(meta.errors.youAreOwner); + } + + await UserGroupJoinings.delete({ userGroupId: userGroup.id, userId: me.id }); +}); |