diff options
author | xnacly <matteogropp@protonmail.com> | 2021-08-10 20:55:47 +0200 |
---|---|---|
committer | xnacly <matteogropp@protonmail.com> | 2021-08-10 20:55:47 +0200 |
commit | d5a9e2c3787d0ef2a2bf76968a20f8e56290efaf (patch) | |
tree | a33e018dc20f80ca0d12b7d92a3d3e0f957a4ab0 /src/routes/users/@me/disable.ts | |
parent | :bug: fix bans (diff) | |
download | server-d5a9e2c3787d0ef2a2bf76968a20f8e56290efaf.tar.xz |
added disable route & check if user is disabled
Diffstat (limited to '')
-rw-r--r-- | src/routes/users/@me/disable.ts | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/src/routes/users/@me/disable.ts b/src/routes/users/@me/disable.ts index b16ef783..0e5b734e 100644 --- a/src/routes/users/@me/disable.ts +++ b/src/routes/users/@me/disable.ts @@ -1,10 +1,20 @@ +import { UserModel } from "@fosscord/server-util"; import { Router, Response, Request } from "express"; +import bcrypt from "bcrypt"; const router = Router(); -router.post("/", (req: Request, res: Response) => { - // TODO: - res.sendStatus(204); +router.post("/", async (req: Request, res: Response) => { + const user = await UserModel.findOne({ id: req.user_id }).exec(); //User object + + let correctpass = await bcrypt.compare(req.body.password, user!.user_data.hash); //Not sure if user typed right password :/ + if (correctpass) { + await UserModel.updateOne({ id: req.user_id }, { disabled: true }).exec(); + + res.sendStatus(204); + } else { + res.status(400).json({ message: "Password does not match", code: 50018 }); + } }); export default router; |