diff options
author | AlTech98 <altech123159@gmail.com> | 2021-09-13 19:09:01 +0200 |
---|---|---|
committer | AlTech98 <altech123159@gmail.com> | 2021-09-13 19:09:01 +0200 |
commit | b15a93d120e5998eccedba99086c1e539ba5983f (patch) | |
tree | 23dd994c10692a4ace670bca2e203e9373246c55 | |
parent | Merge pull request #355 from AlTech98/attachments (diff) | |
download | server-b15a93d120e5998eccedba99086c1e539ba5983f.tar.xz |
Emit USER_UPDATE, fix #214
-rw-r--r-- | api/src/routes/users/@me/index.ts | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/api/src/routes/users/@me/index.ts b/api/src/routes/users/@me/index.ts index 68723374..a8c0edc4 100644 --- a/api/src/routes/users/@me/index.ts +++ b/api/src/routes/users/@me/index.ts @@ -1,6 +1,6 @@ import { Router, Request, Response } from "express"; -import { User, PrivateUserProjection } from "@fosscord/util"; -import { check, route } from "@fosscord/api"; +import { User, PrivateUserProjection, emitEvent, UserUpdateEvent } from "@fosscord/util"; +import { route } from "@fosscord/api"; import { handleFile } from "@fosscord/api"; const router: Router = Router(); @@ -33,8 +33,16 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: if (body.avatar) body.avatar = await handleFile(`/avatars/${req.user_id}`, body.avatar as string); if (body.banner) body.banner = await handleFile(`/banners/${req.user_id}`, body.banner as string); - const user = await new User({ ...body, id: req.user_id }).save(); - // TODO: dispatch user update event + await new User({ ...body, id: req.user_id }).save(); + + //Need to reload user from db due to https://github.com/typeorm/typeorm/issues/3490 + const user = await User.findOneOrFail({ where: { id: req.user_id }, select: PrivateUserProjection }); + + await emitEvent({ + event: "USER_UPDATE", + user_id: req.user_id, + data: user + } as UserUpdateEvent); res.json(user); }); |