From aee1eb29490f38dcdce54984902226a9ac8ee135 Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Fri, 30 Jul 2021 17:37:16 +0200 Subject: [PATCH] :construction: message acknowledge --- package-lock.json | Bin 670953 -> 670953 bytes package.json | 2 +- .../#channel_id/messages/#message_id/ack.ts | 44 ++++++++++-------- src/util/Message.ts | 2 +- 4 files changed, 27 insertions(+), 21 deletions(-) diff --git a/package-lock.json b/package-lock.json index 95af52cfe03bdf20143b0aa82c1d29f74c4c90d9..dbf98809f74b25efedb671fb1fa07ccd37ede307 100644 GIT binary patch delta 287 zcmaF)Q{&}NjR~I_O*eiCjhXyV(qM9Btj6?%=FAGAr4eOD77q~8L5UQCB=rNr3Go;`YHa|6)C39ZYe%xZvI)B;g#W;9>FOoPH6>3?&TgS z?w&z8dCmq-E(XS-8Iu>bDNIgS$lh!l*KQlf2*gZ4%nZaV+il}mx98Ep4bu&Gv&&2u kkYr=uY#XjhSwEht*(mWvs^Jz&wS}a@TUtGMC_T=iqeH5<|;kKMRYr zK>ffn3v=U0%dA{eA7j(9+)}?#Lj%8zNRMFcv?TAu@{B}npDa_ik|YD|5_b<@LrXuS z!erA3i`){UfE3eg_vwY { -// const { channel_id, message_id } = req.params; +// TODO: check if message exists +// TODO: send read state event to all channel members -// const permission = await getPermission(req.user_id, channel?.guild_id, channel_id, { channel }); -// permission.hasThrow("MANAGE_MESSAGES"); +router.post("/", check({ $manual: Boolean, $mention_count: Number }), async (req: Request, res: Response) => { + const { channel_id, message_id } = req.params; -// await emitEvent({ -// event: "MESSAGE_ACK", -// channel_id, -// data: { -// channel_id, -// message_id -// } -// } as MessageAckEvent); + const permission = await getPermission(req.user_id, undefined, channel_id); + permission.hasThrow("VIEW_CHANNEL"); -// res.sendStatus(204); -// }); + await ReadStateModel.updateOne( + { user_id: req.user_id, channel_id, message_id }, + { user_id: req.user_id, channel_id, message_id } + ).exec(); + + await emitEvent({ + event: "MESSAGE_ACK", + user_id: req.user_id, + data: { + channel_id, + message_id, + version: 496 + } + } as MessageAckEvent); + + res.sendStatus(204); +}); export default router; diff --git a/src/util/Message.ts b/src/util/Message.ts index 42cdbb902..3e1775174 100644 --- a/src/util/Message.ts +++ b/src/util/Message.ts @@ -124,7 +124,7 @@ export async function sendMessage(opts: Partial) { await emitEvent({ event: "MESSAGE_CREATE", channel_id: opts.channel_id, data, guild_id: message.guild_id } as MessageCreateEvent); - postHandleMessage(data); // no await as it shouldnt block the message send function + postHandleMessage(data).catch((e) => {}); // no await as it shouldnt block the message send function and silently catch error return data; }