start on d->m removing reactions

This commit is contained in:
Cadence Ember 2023-09-25 17:36:27 +13:00
parent 8d3ac665c9
commit 4f807159ba
3 changed files with 56 additions and 1 deletions

View file

@ -0,0 +1,36 @@
// @ts-check
const Ty = require("../../types")
const assert = require("assert").strict
const passthrough = require("../../passthrough")
const {discord, sync, db, select} = passthrough
/** @type {import("../../matrix/api")} */
const api = sync.require("../../matrix/api")
/** @type {import("./register-user")} */
const registerUser = sync.require("./register-user")
/** @type {import("../actions/create-room")} */
const createRoom = sync.require("../actions/create-room")
/** @type {import("../../matrix/file")} */
const file = sync.require("../../matrix/file")
/**
* @param {import("discord-api-types/v10").GatewayMessageReactionRemoveDispatchData} data
*/
async function removeReaction(data) {
const roomID = select("channel_room", "room_id", "WHERE channel_id = ?").pluck().get(data.channel_id)
if (!roomID) return
const eventIDForMessage = select("event_message", "event_id", "WHERE message_id = ? AND part = 0").pluck().get(data.message_id)
if (!eventIDForMessage) return
const mxid = select("sim", "mxid", "WHERE discord_id = ?").pluck().get(data.user_id)
if (!mxid) return
/** @type {Ty.Pagination<Ty.Event.Outer<Ty.Event.M_Reaction>>} */
const relations = await api.getRelations(roomID, eventIDForMessage, "m.annotation")
const eventIDForReaction = relations.chunk.find(e => e.sender === mxid && e.content["m.relates_to"].key === data.emoji) // TODO: get the key from the emoji
if (!eventIDForReaction) return
await api.redactEvent(roomID, eventIDForReaction, mxid)
}
module.exports.removeReaction = removeReaction

View file

@ -1,7 +1,7 @@
// @ts-check // @ts-check
const Ty = require("../types") const Ty = require("../types")
const assert = require("assert") const assert = require("assert").strict
const passthrough = require("../passthrough") const passthrough = require("../passthrough")
const { discord, sync, db } = passthrough const { discord, sync, db } = passthrough
@ -109,6 +109,18 @@ function getJoinedMembers(roomID) {
return mreq.mreq("GET", `/client/v3/rooms/${roomID}/joined_members`) return mreq.mreq("GET", `/client/v3/rooms/${roomID}/joined_members`)
} }
/**
* @param {string} roomID
* @param {string} eventID
* @param {string?} [relType]
* @returns {Promise<Ty.Pagination<Ty.Event.Outer<any>>>}
*/
function getRelations(roomID, eventID, relType) {
let path = `/client/v1/rooms/${roomID}/relations/${eventID}`
if (relType) path += `/${relType}`
return mreq.mreq("GET", path)
}
/** /**
* @param {string} roomID * @param {string} roomID
* @param {string} type * @param {string} type
@ -207,6 +219,7 @@ module.exports.getEvent = getEvent
module.exports.getAllState = getAllState module.exports.getAllState = getAllState
module.exports.getStateEvent = getStateEvent module.exports.getStateEvent = getStateEvent
module.exports.getJoinedMembers = getJoinedMembers module.exports.getJoinedMembers = getJoinedMembers
module.exports.getRelations = getRelations
module.exports.sendState = sendState module.exports.sendState = sendState
module.exports.sendEvent = sendEvent module.exports.sendEvent = sendEvent
module.exports.redactEvent = redactEvent module.exports.redactEvent = redactEvent

6
types.d.ts vendored
View file

@ -215,3 +215,9 @@ export namespace R {
event_id: string event_id: string
} }
} }
export type Pagination<T> {
chunk: T[]
next_batch?: string
prev_match?: string
}