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

49 lines
1.1 KiB
TypeScript
Raw Normal View History

2019-02-20 17:30:21 +01: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 17:30:21 +01:00
export const meta = {
2020-02-15 13:33:32 +01:00
requireCredential: true as const,
2019-02-20 17:30:21 +01:00
secure: true,
params: {
password: {
validator: $.str
},
}
};
export default define(meta, async (ps, user) => {
2021-02-13 07:33:38 +01:00
const profile = await UserProfiles.findOneOrFail(user.id);
const userDetailed = await Users.findOneOrFail(user.id);
if (userDetailed.isDeleted) {
return;
}
2019-04-10 08:04:27 +02:00
2019-02-20 17:30:21 +01:00
// Compare password
const same = await bcrypt.compare(ps.password, profile.password!);
2019-02-20 17:30:21 +01:00
if (!same) {
throw new Error('incorrect password');
2019-02-20 17:30:21 +01:00
}
// 物理削除する前にDelete activityを送信する
await doPostSuspend(user).catch(e => {});
createDeleteAccountJob(user, {
soft: false
});
await Users.update(user.id, {
isDeleted: true,
});
// Terminate streaming
publishUserEvent(user.id, 'terminate', {});
});