forked from cadence/out-of-your-element
Fix /api/link-space joinRoom() for remote spaces
This commit is contained in:
parent
74172f3d3d
commit
37da02d13a
1 changed files with 17 additions and 0 deletions
|
@ -12,6 +12,20 @@ const auth = sync.require("../auth")
|
||||||
const mreq = sync.require("../../matrix/mreq")
|
const mreq = sync.require("../../matrix/mreq")
|
||||||
const {reg} = require("../../matrix/read-registration")
|
const {reg} = require("../../matrix/read-registration")
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {string} UserID
|
||||||
|
* @returns {string} the HS of the user, or "" if the user ID is malformed
|
||||||
|
*/
|
||||||
|
function getHSOfUser(user) {
|
||||||
|
domainStartIndex = user.indexOf(":");
|
||||||
|
if (domainStartIndex >= 1) {
|
||||||
|
return user.slice(domainStartIndex + 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {H3Event} event
|
* @param {H3Event} event
|
||||||
* @returns {import("../../matrix/api")}
|
* @returns {import("../../matrix/api")}
|
||||||
|
@ -75,6 +89,9 @@ as.router.post("/api/link-space", defineEventHandler(async event => {
|
||||||
const existing = select("guild_space", "guild_id", {}, "WHERE guild_id = ? OR space_id = ?").get(guildID, spaceID)
|
const existing = select("guild_space", "guild_id", {}, "WHERE guild_id = ? OR space_id = ?").get(guildID, spaceID)
|
||||||
if (existing) throw createError({status: 400, message: "Bad Request", data: `Guild ID ${guildID} or space ID ${spaceID} are already bridged and cannot be reused`})
|
if (existing) throw createError({status: 400, message: "Bad Request", data: `Guild ID ${guildID} or space ID ${spaceID} are already bridged and cannot be reused`})
|
||||||
|
|
||||||
|
const inviteSender = select("invite", "mxid", {mxid: session.data.mxid, room_id: spaceID}).pluck().get()
|
||||||
|
via = [ getHSOfUser(inviteSender) ]
|
||||||
|
|
||||||
// Check space exists and bridge is joined
|
// Check space exists and bridge is joined
|
||||||
try {
|
try {
|
||||||
await api.joinRoom(parsedBody.space_id, null, via)
|
await api.joinRoom(parsedBody.space_id, null, via)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue