42 lines
1.8 KiB
JavaScript
42 lines
1.8 KiB
JavaScript
// @ts-check
|
|
|
|
const passthrough = require("../../passthrough")
|
|
const {sync, db, select, from} = passthrough
|
|
/** @type {import("../../matrix/api")} */
|
|
const api = sync.require("../../matrix/api")
|
|
|
|
/**
|
|
* @param {import("discord-api-types/v10").GatewayMessageDeleteDispatchData} data
|
|
*/
|
|
async function deleteMessage(data) {
|
|
const roomID = select("channel_room", "room_id", {channel_id: data.channel_id}).pluck().get()
|
|
if (!roomID) return
|
|
|
|
const eventsToRedact = select("event_message", "event_id", {message_id: data.id}).pluck().all()
|
|
db.prepare("DELETE FROM message_channel WHERE message_id = ?").run(data.id)
|
|
db.prepare("DELETE FROM event_message WHERE message_id = ?").run(data.id)
|
|
for (const eventID of eventsToRedact) {
|
|
// Unfortunately, we can't specify a sender to do the redaction as, unless we find out that info via the audit logs
|
|
await api.redactEvent(roomID, eventID)
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param {import("discord-api-types/v10").GatewayMessageDeleteBulkDispatchData} data
|
|
*/
|
|
async function deleteMessageBulk(data) {
|
|
const roomID = select("channel_room", "room_id", {channel_id: data.channel_id}).pluck().get()
|
|
if (!roomID) return
|
|
|
|
const sids = JSON.stringify(data.ids)
|
|
const eventsToRedact = from("event_message").pluck("event_id").and("WHERE message_id IN (SELECT value FROM json_each(?)").all(sids)
|
|
db.prepare("DELETE FROM message_channel WHERE message_id IN (SELECT value FROM json_each(?)").run(sids)
|
|
db.prepare("DELETE FROM event_message WHERE message_id IN (SELECT value FROM json_each(?)").run(sids)
|
|
for (const eventID of eventsToRedact) {
|
|
// Awaiting will make it go slower, but since this could be a long-running operation either way, we want to leave rate limit capacity for other operations
|
|
await api.redactEvent(roomID, eventID)
|
|
}
|
|
}
|
|
|
|
module.exports.deleteMessage = deleteMessage
|
|
module.exports.deleteMessageBulk = deleteMessageBulk
|