summary refs log tree commit diff
path: root/src/routes/users/@me/disable.ts
diff options
context:
space:
mode:
authorxnacly <matteogropp@protonmail.com>2021-08-10 20:55:47 +0200
committerxnacly <matteogropp@protonmail.com>2021-08-10 20:55:47 +0200
commitd5a9e2c3787d0ef2a2bf76968a20f8e56290efaf (patch)
treea33e018dc20f80ca0d12b7d92a3d3e0f957a4ab0 /src/routes/users/@me/disable.ts
parent:bug: fix bans (diff)
downloadserver-d5a9e2c3787d0ef2a2bf76968a20f8e56290efaf.tar.xz
added disable route & check if user is disabled
Diffstat (limited to '')
-rw-r--r--src/routes/users/@me/disable.ts16
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;