egirlskey/packages/backend/src/server/api/endpoints/i/delete-account.ts

50 lines
1.1 KiB
TypeScript
Raw Normal View History

2019-02-20 16:30:21 +00:00
import $ from 'cafy';
import * as bcrypt from 'bcryptjs';
import define from '../../define';
import { UserProfiles, Users } from '@/models/index';
import { doPostSuspend } from '@/services/suspend-user';
import { publishUserEvent } from '@/services/stream';
import { createDeleteAccountJob } from '@/queue';
2019-02-20 16:30:21 +00:00
export const meta = {
2020-02-15 12:33:32 +00:00
requireCredential: true as const,
2019-02-20 16:30:21 +00:00
secure: true,
params: {
password: {
2021-12-09 14:58:30 +00:00
validator: $.str,
2019-02-20 16:30:21 +00:00
},
2021-12-09 14:58:30 +00:00
},
2019-02-20 16:30:21 +00:00
};
2022-01-02 17:12:50 +00:00
// eslint-disable-next-line import/no-default-export
export default define(meta, async (ps, user) => {
2021-02-13 06:33:38 +00:00
const profile = await UserProfiles.findOneOrFail(user.id);
const userDetailed = await Users.findOneOrFail(user.id);
if (userDetailed.isDeleted) {
return;
}
2019-04-10 06:04:27 +00:00
2019-02-20 16:30:21 +00:00
// Compare password
const same = await bcrypt.compare(ps.password, profile.password!);
2019-02-20 16:30:21 +00:00
if (!same) {
throw new Error('incorrect password');
2019-02-20 16:30:21 +00:00
}
// 物理削除する前にDelete activityを送信する
await doPostSuspend(user).catch(e => {});
createDeleteAccountJob(user, {
2021-12-09 14:58:30 +00:00
soft: false,
});
await Users.update(user.id, {
isDeleted: true,
});
// Terminate streaming
publishUserEvent(user.id, 'terminate', {});
});