summary refs log tree commit diff
path: root/src/routes/users/@me/index.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/routes/users/@me/index.ts')
-rw-r--r--src/routes/users/@me/index.ts18
1 files changed, 16 insertions, 2 deletions
diff --git a/src/routes/users/@me/index.ts b/src/routes/users/@me/index.ts

index e4d9588f..d139203d 100644 --- a/src/routes/users/@me/index.ts +++ b/src/routes/users/@me/index.ts
@@ -1,12 +1,13 @@ import { Router, Request, Response } from "express"; -import { UserModel } from "@fosscord/server-util"; +import { UserModel, toObject } from "@fosscord/server-util"; import { HTTPError } from "lambert-server"; import { getPublicUser } from "../../../util/User"; +import { UserModifySchema } from "../../../schema/User" +import { check } from "../../../util/instanceOf"; const router: Router = Router(); router.get("/", async (req: Request, res: Response) => { - // TODO: user projection const user = await UserModel.findOne({ id: req.user_id }).exec(); if (!user) throw new HTTPError("User not found", 404); @@ -15,4 +16,17 @@ router.get("/", async (req: Request, res: Response) => { res.json(publicUser); }); +router.patch("/", check(UserModifySchema), async (req: Request, res: Response) => { + const body = req.body as UserModifySchema; + + const user = await UserModel.findOne({ id: req.user_id }).exec(); + if (!user) throw new HTTPError("User not found", 404); + + var newuser = await UserModel.findOneAndUpdate({ id: req.user_id }, { + ...body + }).exec(); + + res.json(newuser); +}); + export default router;