summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--package-lock.json14
-rw-r--r--src/routes/channels/#channel_id/messages/#message_id/ack.ts44
-rw-r--r--src/util/Message.ts2
3 files changed, 33 insertions, 27 deletions
diff --git a/package-lock.json b/package-lock.json

index 95af52cf..dbf98809 100644 --- a/package-lock.json +++ b/package-lock.json
@@ -9,7 +9,7 @@ "version": "1.0.0", "license": "ISC", "dependencies": { - "@fosscord/server-util": "^1.3.32", + "@fosscord/server-util": "^1.3.35", "@types/jest": "^26.0.22", "@types/json-schema": "^7.0.7", "ajv": "^8.4.0", @@ -677,9 +677,9 @@ } }, "node_modules/@fosscord/server-util": { - "version": "1.3.32", - "resolved": "https://registry.npmjs.org/@fosscord/server-util/-/server-util-1.3.32.tgz", - "integrity": "sha512-wEwIvDSwCSg5t19sN88fQ/Qv873Y9jm5L35vmuNU10NhYHS+fbKawha+Lj5Ftb0+tGHM19N2qc5X8mt2Pd5kGg==", + "version": "1.3.35", + "resolved": "https://registry.npmjs.org/@fosscord/server-util/-/server-util-1.3.35.tgz", + "integrity": "sha512-uXv28XjmdmpMvkCGvXArAjpmW3x9he14ts1uupfK/dOkxd5CFdLvFOjiWyWiHSddBfp2GwHdGIRlnC0BD03UhA==", "dependencies": { "@types/jsonwebtoken": "^8.5.0", "@types/mongoose-autopopulate": "^0.10.1", @@ -11337,9 +11337,9 @@ } }, "@fosscord/server-util": { - "version": "1.3.32", - "resolved": "https://registry.npmjs.org/@fosscord/server-util/-/server-util-1.3.32.tgz", - "integrity": "sha512-wEwIvDSwCSg5t19sN88fQ/Qv873Y9jm5L35vmuNU10NhYHS+fbKawha+Lj5Ftb0+tGHM19N2qc5X8mt2Pd5kGg==", + "version": "1.3.35", + "resolved": "https://registry.npmjs.org/@fosscord/server-util/-/server-util-1.3.35.tgz", + "integrity": "sha512-uXv28XjmdmpMvkCGvXArAjpmW3x9he14ts1uupfK/dOkxd5CFdLvFOjiWyWiHSddBfp2GwHdGIRlnC0BD03UhA==", "requires": { "@types/jsonwebtoken": "^8.5.0", "@types/mongoose-autopopulate": "^0.10.1", diff --git a/src/routes/channels/#channel_id/messages/#message_id/ack.ts b/src/routes/channels/#channel_id/messages/#message_id/ack.ts
index 9782365f..f4d9e696 100644 --- a/src/routes/channels/#channel_id/messages/#message_id/ack.ts +++ b/src/routes/channels/#channel_id/messages/#message_id/ack.ts
@@ -1,29 +1,35 @@ -import { getPermission } from "@fosscord/server-util"; -import { MessageModel } from "@fosscord/server-util"; -import { Event } from "@fosscord/server-util"; -import { ChannelModel } from "@fosscord/server-util"; +import { getPermission, MessageAckEvent, ReadStateModel } from "@fosscord/server-util"; import { Request, Response, Router } from "express"; -import { HTTPError } from "lambert-server"; import { emitEvent } from "../../../../../util/Event"; +import { check } from "../../../../../util/instanceOf"; const router = Router(); -// router.pot("/", async (req: Request, res: Response) => { -// 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 42cdbb90..3e177517 100644 --- a/src/util/Message.ts +++ b/src/util/Message.ts
@@ -124,7 +124,7 @@ export async function sendMessage(opts: Partial<Message>) { 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; }