diff options
| author | Aya Morisawa <AyaMorisawa4869@gmail.com> | 2018-08-18 13:09:15 +0900 |
|---|---|---|
| committer | Aya Morisawa <AyaMorisawa4869@gmail.com> | 2018-08-18 13:09:15 +0900 |
| commit | 11bb1608cf339a250c66364ec993e87b5d4d1c33 (patch) | |
| tree | cbc6c61d880168f681f84c5375a40bb89e3595f3 /src/server/api/endpoints/admin | |
| parent | Merge pull request #2310 from sei0o/fix-1776 (diff) | |
| download | sharkey-11bb1608cf339a250c66364ec993e87b5d4d1c33.tar.gz sharkey-11bb1608cf339a250c66364ec993e87b5d4d1c33.tar.bz2 sharkey-11bb1608cf339a250c66364ec993e87b5d4d1c33.zip | |
Resolve #2293
Diffstat (limited to 'src/server/api/endpoints/admin')
| -rw-r--r-- | src/server/api/endpoints/admin/unverify-user.ts | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/src/server/api/endpoints/admin/unverify-user.ts b/src/server/api/endpoints/admin/unverify-user.ts new file mode 100644 index 0000000000..d75f3674bf --- /dev/null +++ b/src/server/api/endpoints/admin/unverify-user.ts @@ -0,0 +1,46 @@ +import $ from 'cafy'; +import ID from '../../../../misc/cafy-id'; +import getParams from '../../get-params'; +import User from '../../../../models/user'; + +export const meta = { + desc: { + ja: '指定したユーザーの公式アカウントを解除します。', + en: 'Mark a user as vunerified.' + }, + + requireCredential: true, + requireAdmin: true, + + params: { + userId: $.type(ID).note({ + desc: { + ja: '対象のユーザーID', + en: 'The user ID which you want to unverify' + } + }), + } +}; + +export default (params: any) => new Promise(async (res, rej) => { + const [ps, psErr] = getParams(meta, params); + if (psErr) return rej(psErr); + + const user = await User.findOne({ + _id: ps.userId + }); + + if (user == null) { + return rej('user not found'); + } + + await User.findOneAndUpdate({ + _id: user._id + }, { + $set: { + isVerified: false + } + }); + + res(); +}); |