| @@ -59,6 +59,7 @@ import * as ep___admin_unsilenceUser from './endpoints/admin/unsilence-user.js'; | ||||
| import * as ep___admin_unsuspendUser from './endpoints/admin/unsuspend-user.js'; | ||||
| import * as ep___admin_updateMeta from './endpoints/admin/update-meta.js'; | ||||
| import * as ep___admin_vacuum from './endpoints/admin/vacuum.js'; | ||||
| import * as ep___admin_deleteAccount from './endpoints/admin/delete-account.js'; | ||||
| import * as ep___announcements from './endpoints/announcements.js'; | ||||
| import * as ep___antennas_create from './endpoints/antennas/create.js'; | ||||
| import * as ep___antennas_delete from './endpoints/antennas/delete.js'; | ||||
| @@ -370,6 +371,7 @@ const eps = [ | ||||
| 	['admin/unsuspend-user', ep___admin_unsuspendUser], | ||||
| 	['admin/update-meta', ep___admin_updateMeta], | ||||
| 	['admin/vacuum', ep___admin_vacuum], | ||||
| 	['admin/delete-account', ep___admin_deleteAccount], | ||||
| 	['announcements', ep___announcements], | ||||
| 	['antennas/create', ep___antennas_create], | ||||
| 	['antennas/delete', ep___antennas_delete], | ||||
|   | ||||
| @@ -0,0 +1,31 @@ | ||||
| import { Users } from '@/models/index.js'; | ||||
| import { deleteAccount } from '@/services/delete-account.js'; | ||||
| import define from '../../define.js'; | ||||
|  | ||||
| export const meta = { | ||||
| 	tags: ['admin'], | ||||
|  | ||||
| 	requireCredential: true, | ||||
| 	requireAdmin: true, | ||||
|  | ||||
| 	res: { | ||||
| 	}, | ||||
| } as const; | ||||
|  | ||||
| export const paramDef = { | ||||
| 	type: 'object', | ||||
| 	properties: { | ||||
| 		userId: { type: 'string', format: 'misskey:id' }, | ||||
| 	}, | ||||
| 	required: ['userId'], | ||||
| } as const; | ||||
|  | ||||
| // eslint-disable-next-line import/no-default-export | ||||
| export default define(meta, paramDef, async (ps) => { | ||||
| 	const user = await Users.findOneByOrFail({ id: ps.userId }); | ||||
| 	if (user.isDeleted) { | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	await deleteAccount(user); | ||||
| }); | ||||
| @@ -1,9 +1,7 @@ | ||||
| import bcrypt from 'bcryptjs'; | ||||
| import define from '../../define.js'; | ||||
| import { UserProfiles, Users } from '@/models/index.js'; | ||||
| import { doPostSuspend } from '@/services/suspend-user.js'; | ||||
| import { publishUserEvent } from '@/services/stream.js'; | ||||
| import { createDeleteAccountJob } from '@/queue/index.js'; | ||||
| import { deleteAccount } from '@/services/delete-account.js'; | ||||
| import define from '../../define.js'; | ||||
|  | ||||
| export const meta = { | ||||
| 	requireCredential: true, | ||||
| @@ -34,17 +32,5 @@ export default define(meta, paramDef, async (ps, user) => { | ||||
| 		throw new Error('incorrect password'); | ||||
| 	} | ||||
|  | ||||
| 	// 物理削除する前にDelete activityを送信する | ||||
| 	await doPostSuspend(user).catch(e => {}); | ||||
|  | ||||
| 	createDeleteAccountJob(user, { | ||||
| 		soft: false, | ||||
| 	}); | ||||
|  | ||||
| 	await Users.update(user.id, { | ||||
| 		isDeleted: true, | ||||
| 	}); | ||||
|  | ||||
| 	// Terminate streaming | ||||
| 	publishUserEvent(user.id, 'terminate', {}); | ||||
| 	await deleteAccount(user); | ||||
| }); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 syuilo
					syuilo