diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2018-08-14 01:05:58 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2018-08-14 01:05:58 +0900 |
| commit | 9021bb5694bbe31cbff09d25d5d610fef0cfdda9 (patch) | |
| tree | 5ac13ce2d4ec309dc7e925929404485e21a85c8b /src/server/api/endpoints/admin | |
| parent | Merge pull request #2189 from syuilo/patch-1 (diff) | |
| download | sharkey-9021bb5694bbe31cbff09d25d5d610fef0cfdda9.tar.gz sharkey-9021bb5694bbe31cbff09d25d5d610fef0cfdda9.tar.bz2 sharkey-9021bb5694bbe31cbff09d25d5d610fef0cfdda9.zip | |
wip
Diffstat (limited to 'src/server/api/endpoints/admin')
| -rw-r--r-- | src/server/api/endpoints/admin/suspend-user.ts | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/src/server/api/endpoints/admin/suspend-user.ts b/src/server/api/endpoints/admin/suspend-user.ts new file mode 100644 index 0000000000..8698120cdb --- /dev/null +++ b/src/server/api/endpoints/admin/suspend-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: 'Suspend a user.' + }, + + requireCredential: true, + requireAdmin: true, + + params: { + userId: $.type(ID).note({ + desc: { + ja: '対象のユーザーID', + en: 'The user ID which you want to suspend' + } + }), + } +}; + +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: { + isSuspended: true + } + }); + + res(); +}); |