2021-08-19 21:55:45 +09:00
|
|
|
import define from '../../../define';
|
|
|
|
|
import { ApiError } from '../../../error';
|
|
|
|
|
import { getUser } from '../../../common/getters';
|
|
|
|
|
import { UserGroups, UserGroupJoinings } from '@/models/index';
|
2019-05-18 20:36:33 +09:00
|
|
|
|
|
|
|
|
export const meta = {
|
|
|
|
|
tags: ['groups', 'users'],
|
|
|
|
|
|
2022-01-18 22:27:10 +09:00
|
|
|
requireCredential: true,
|
2019-05-18 20:36:33 +09:00
|
|
|
|
|
|
|
|
kind: 'write:user-groups',
|
|
|
|
|
|
|
|
|
|
errors: {
|
|
|
|
|
noSuchGroup: {
|
|
|
|
|
message: 'No such group.',
|
|
|
|
|
code: 'NO_SUCH_GROUP',
|
2021-12-09 23:58:30 +09:00
|
|
|
id: '4662487c-05b1-4b78-86e5-fd46998aba74',
|
2019-05-18 20:36:33 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
|
|
noSuchUser: {
|
|
|
|
|
message: 'No such user.',
|
|
|
|
|
code: 'NO_SUCH_USER',
|
2021-12-09 23:58:30 +09:00
|
|
|
id: '0b5cc374-3681-41da-861e-8bc1146f7a55',
|
2019-05-19 20:43:33 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
|
|
isOwner: {
|
|
|
|
|
message: 'The user is the owner.',
|
|
|
|
|
code: 'IS_OWNER',
|
2021-12-09 23:58:30 +09:00
|
|
|
id: '1546eed5-4414-4dea-81c1-b0aec4f6d2af',
|
2019-05-19 20:43:33 +09:00
|
|
|
},
|
2021-12-09 23:58:30 +09:00
|
|
|
},
|
2022-01-18 22:27:10 +09:00
|
|
|
} as const;
|
2019-05-18 20:36:33 +09:00
|
|
|
|
2022-02-19 14:05:32 +09:00
|
|
|
const paramDef = {
|
|
|
|
|
type: 'object',
|
|
|
|
|
properties: {
|
|
|
|
|
groupId: { type: 'string', format: 'misskey:id' },
|
|
|
|
|
userId: { type: 'string', format: 'misskey:id' },
|
|
|
|
|
},
|
|
|
|
|
required: ['groupId', 'userId'],
|
|
|
|
|
} as const;
|
|
|
|
|
|
2022-01-03 02:12:50 +09:00
|
|
|
// eslint-disable-next-line import/no-default-export
|
2022-02-19 14:05:32 +09:00
|
|
|
export default define(meta, paramDef, async (ps, me) => {
|
2019-05-18 20:36:33 +09:00
|
|
|
// Fetch the group
|
|
|
|
|
const userGroup = await UserGroups.findOne({
|
|
|
|
|
id: ps.groupId,
|
|
|
|
|
userId: me.id,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (userGroup == null) {
|
|
|
|
|
throw new ApiError(meta.errors.noSuchGroup);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Fetch the user
|
|
|
|
|
const user = await getUser(ps.userId).catch(e => {
|
|
|
|
|
if (e.id === '15348ddd-432d-49c2-8a5a-8069753becff') throw new ApiError(meta.errors.noSuchUser);
|
|
|
|
|
throw e;
|
|
|
|
|
});
|
|
|
|
|
|
2019-05-19 20:43:33 +09:00
|
|
|
if (user.id === userGroup.userId) {
|
|
|
|
|
throw new ApiError(meta.errors.isOwner);
|
|
|
|
|
}
|
|
|
|
|
|
2019-05-18 20:36:33 +09:00
|
|
|
// Pull the user
|
2019-09-26 04:14:41 +09:00
|
|
|
await UserGroupJoinings.delete({ userGroupId: userGroup.id, userId: user.id });
|
2019-05-18 20:36:33 +09:00
|
|
|
});
|