API endpoint for message info
This commit is contained in:
@@ -419,6 +419,14 @@ async function setPresence(data, mxid) {
|
|||||||
await mreq.mreq("PUT", path(`/client/v3/presence/${mxid}/status`, mxid), data)
|
await mreq.mreq("PUT", path(`/client/v3/presence/${mxid}/status`, mxid), data)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {string} mxid
|
||||||
|
* @returns {Promise<{displayname?: string, avatar_url?: string}>}
|
||||||
|
*/
|
||||||
|
function getProfile(mxid) {
|
||||||
|
return mreq.mreq("GET", `/client/v3/profile/${mxid}`)
|
||||||
|
}
|
||||||
|
|
||||||
module.exports.path = path
|
module.exports.path = path
|
||||||
module.exports.register = register
|
module.exports.register = register
|
||||||
module.exports.createRoom = createRoom
|
module.exports.createRoom = createRoom
|
||||||
@@ -452,3 +460,4 @@ module.exports.getAlias = getAlias
|
|||||||
module.exports.getAccountData = getAccountData
|
module.exports.getAccountData = getAccountData
|
||||||
module.exports.setAccountData = setAccountData
|
module.exports.setAccountData = setAccountData
|
||||||
module.exports.setPresence = setPresence
|
module.exports.setPresence = setPresence
|
||||||
|
module.exports.getProfile = getProfile
|
||||||
|
60
src/web/routes/info.js
Normal file
60
src/web/routes/info.js
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
// @ts-check
|
||||||
|
|
||||||
|
const {z} = require("zod")
|
||||||
|
const {defineEventHandler, getValidatedQuery, H3Event} = require("h3")
|
||||||
|
const {as, from, sync, select} = require("../../passthrough")
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {H3Event} event
|
||||||
|
* @returns {import("../../matrix/api")}
|
||||||
|
*/
|
||||||
|
function getAPI(event) {
|
||||||
|
/* c8 ignore next */
|
||||||
|
return event.context.api || sync.require("../../matrix/api")
|
||||||
|
}
|
||||||
|
|
||||||
|
const schema = {
|
||||||
|
message: z.object({
|
||||||
|
message_id: z.string().regex(/^[0-9]+$/)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
as.router.get("/api/message", defineEventHandler(async event => {
|
||||||
|
const api = getAPI(event)
|
||||||
|
|
||||||
|
const {message_id} = await getValidatedQuery(event, schema.message.parse)
|
||||||
|
const metadatas = from("event_message").join("message_channel", "message_id").join("channel_room", "channel_id").where({message_id})
|
||||||
|
.select("event_id", "event_type", "event_subtype", "part", "reaction_part", "room_id", "source").and("ORDER BY part ASC, reaction_part DESC").all()
|
||||||
|
|
||||||
|
if (metadatas.length === 0) {
|
||||||
|
return new Response("Message not found", {status: 404, statusText: "Not Found"})
|
||||||
|
}
|
||||||
|
|
||||||
|
const events = await Promise.all(metadatas.map(metadata =>
|
||||||
|
api.getEvent(metadata.room_id, metadata.event_id).then(raw => ({
|
||||||
|
metadata: Object.assign({sender: raw.sender}, metadata),
|
||||||
|
raw
|
||||||
|
}))
|
||||||
|
))
|
||||||
|
|
||||||
|
const primary = events.find(e => e.metadata.part === 0) || events[0]
|
||||||
|
const mxid = primary.metadata.sender
|
||||||
|
const source = primary.metadata.source === 0 ? "matrix" : "discord"
|
||||||
|
|
||||||
|
let matrix_author = undefined
|
||||||
|
if (source === "matrix") {
|
||||||
|
matrix_author = select("member_cache", ["displayname", "avatar_url", "mxid"], {room_id: primary.metadata.room_id, mxid}).get()
|
||||||
|
if (!matrix_author) {
|
||||||
|
try {
|
||||||
|
matrix_author = await api.getProfile(mxid)
|
||||||
|
} catch (e) {
|
||||||
|
matrix_author = {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!matrix_author.displayname) matrix_author.displayname = mxid
|
||||||
|
if (!matrix_author.avatar_url) matrix_author.avatar_url = null
|
||||||
|
matrix_author["mxid"] = mxid
|
||||||
|
}
|
||||||
|
|
||||||
|
return {source, matrix_author, events}
|
||||||
|
}))
|
19
src/web/routes/info.test.js
Normal file
19
src/web/routes/info.test.js
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
// @ts-check
|
||||||
|
|
||||||
|
const assert = require("assert/strict")
|
||||||
|
const tryToCatch = require("try-to-catch")
|
||||||
|
const {router, test} = require("../../../test/web")
|
||||||
|
|
||||||
|
test("web info: 404 when message does not exist", async t => {
|
||||||
|
const res = await router.test("get", "/api/message?message_id=1", {
|
||||||
|
api: {
|
||||||
|
async getEvent(roomID, eventID) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.fail("test not written")
|
||||||
|
})
|
||||||
|
|
||||||
|
test("web info: returns data when message exists", async t => {
|
||||||
|
t.fail("test not written")
|
||||||
|
})
|
@@ -29,6 +29,7 @@ sync.require("./routes/download-matrix")
|
|||||||
sync.require("./routes/download-discord")
|
sync.require("./routes/download-discord")
|
||||||
sync.require("./routes/guild-settings")
|
sync.require("./routes/guild-settings")
|
||||||
sync.require("./routes/guild")
|
sync.require("./routes/guild")
|
||||||
|
sync.require("./routes/info")
|
||||||
sync.require("./routes/link")
|
sync.require("./routes/link")
|
||||||
sync.require("./routes/log-in-with-matrix")
|
sync.require("./routes/log-in-with-matrix")
|
||||||
sync.require("./routes/oauth")
|
sync.require("./routes/oauth")
|
||||||
|
@@ -133,6 +133,7 @@ file._actuallyUploadDiscordFileToMxc = function(url, res) { throw new Error(`Not
|
|||||||
require("../src/web/routes/download-matrix.test")
|
require("../src/web/routes/download-matrix.test")
|
||||||
require("../src/web/routes/guild.test")
|
require("../src/web/routes/guild.test")
|
||||||
require("../src/web/routes/guild-settings.test")
|
require("../src/web/routes/guild-settings.test")
|
||||||
|
require("../src/web/routes/info.test")
|
||||||
require("../src/web/routes/link.test")
|
require("../src/web/routes/link.test")
|
||||||
require("../src/web/routes/log-in-with-matrix.test")
|
require("../src/web/routes/log-in-with-matrix.test")
|
||||||
require("../src/discord/utils.test")
|
require("../src/discord/utils.test")
|
||||||
|
Reference in New Issue
Block a user