Compare commits
3 commits
main
...
evil-guild
| Author | SHA1 | Date | |
|---|---|---|---|
| d3feec18cf | |||
| cd2ff3ef6b | |||
| 553c95351d |
4 changed files with 84 additions and 36 deletions
|
|
@ -357,15 +357,7 @@ async event => {
|
||||||
await api.ackEvent(event)
|
await api.ackEvent(event)
|
||||||
}))
|
}))
|
||||||
|
|
||||||
function getFromInviteRoomState(inviteRoomState, nskey, key) {
|
|
||||||
if (!Array.isArray(inviteRoomState)) return null
|
|
||||||
for (const event of inviteRoomState) {
|
|
||||||
if (event.type === nskey && event.state_key === "") {
|
|
||||||
return event.content[key]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
sync.addTemporaryListener(as, "type:m.space.child", guard("m.space.child",
|
sync.addTemporaryListener(as, "type:m.space.child", guard("m.space.child",
|
||||||
/**
|
/**
|
||||||
|
|
@ -398,24 +390,16 @@ async event => {
|
||||||
}
|
}
|
||||||
|
|
||||||
// We were invited to a room. We should join, and register the invite details for future reference in web.
|
// We were invited to a room. We should join, and register the invite details for future reference in web.
|
||||||
let attemptedApiMessage = "According to unsigned invite data."
|
try {
|
||||||
let inviteRoomState = event.unsigned?.invite_room_state
|
var inviteRoomState = await api.getInviteState(event.room_id, event)
|
||||||
if (!Array.isArray(inviteRoomState) || inviteRoomState.length === 0) {
|
} catch (e) {
|
||||||
try {
|
console.error(e)
|
||||||
inviteRoomState = await api.getInviteState(event.room_id)
|
return await api.leaveRoomWithReason(event.room_id, `I wasn't able to find out what this room is. Please report this as a bug. Check console for more details. (${e.toString()})`)
|
||||||
attemptedApiMessage = "According to SSS API."
|
|
||||||
} catch (e) {
|
|
||||||
attemptedApiMessage = "According to unsigned invite data. SSS API unavailable: " + e.toString()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
const name = getFromInviteRoomState(inviteRoomState, "m.room.name", "name")
|
if (!inviteRoomState?.name) return await api.leaveRoomWithReason(event.room_id, `Please only invite me to rooms that have a name/avatar set. Update the room details and reinvite.`)
|
||||||
const topic = getFromInviteRoomState(inviteRoomState, "m.room.topic", "topic")
|
|
||||||
const avatar = getFromInviteRoomState(inviteRoomState, "m.room.avatar", "url")
|
|
||||||
const creationType = getFromInviteRoomState(inviteRoomState, "m.room.create", "type")
|
|
||||||
if (!name) return await api.leaveRoomWithReason(event.room_id, `Please only invite me to rooms that have a name/avatar set. Update the room details and reinvite! (${attemptedApiMessage})`)
|
|
||||||
await api.joinRoom(event.room_id)
|
await api.joinRoom(event.room_id)
|
||||||
db.prepare("INSERT OR IGNORE INTO invite (mxid, room_id, type, name, topic, avatar) VALUES (?, ?, ?, ?, ?, ?)").run(event.sender, event.room_id, creationType, name, topic, avatar)
|
db.prepare("INSERT OR IGNORE INTO invite (mxid, room_id, type, name, topic, avatar) VALUES (?, ?, ?, ?, ?, ?)").run(event.sender, event.room_id, inviteRoomState.type, inviteRoomState.name, inviteRoomState.topic, inviteRoomState.avatar)
|
||||||
if (avatar) utils.getPublicUrlForMxc(avatar) // make sure it's available in the media_proxy allowed URLs
|
if (inviteRoomState.avatar) utils.getPublicUrlForMxc(inviteRoomState.avatar) // make sure it's available in the media_proxy allowed URLs
|
||||||
}
|
}
|
||||||
|
|
||||||
if (utils.eventSenderIsFromDiscord(event.state_key)) return
|
if (utils.eventSenderIsFromDiscord(event.state_key)) return
|
||||||
|
|
|
||||||
|
|
@ -158,20 +158,82 @@ function getStateEventOuter(roomID, type, key) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {string} roomID
|
* @param {string} roomID
|
||||||
* @returns {Promise<Ty.Event.InviteStrippedState[]>}
|
* @param {{unsigned?: {invite_room_state?: Ty.Event.InviteStrippedState[]}}} [event]
|
||||||
|
* @returns {Promise<{name: string?, topic: string?, avatar: string?, type: string?}>}
|
||||||
*/
|
*/
|
||||||
async function getInviteState(roomID) {
|
async function getInviteState(roomID, event) {
|
||||||
/** @type {Ty.R.SSS} */
|
function getFromInviteRoomState(strippedState, nskey, key) {
|
||||||
const root = await mreq.mreq("POST", path("/client/unstable/org.matrix.simplified_msc3575/sync", `@${reg.sender_localpart}:${reg.ooye.server_name}`, {timeout: "0"}), {
|
if (!Array.isArray(strippedState)) return null
|
||||||
room_subscriptions: {
|
for (const event of strippedState) {
|
||||||
[roomID]: {
|
if (event.type === nskey && event.state_key === "") {
|
||||||
timeline_limit: 0,
|
return event.content[key]
|
||||||
required_state: []
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
return null
|
||||||
const roomResponse = root.rooms[roomID]
|
}
|
||||||
return "stripped_state" in roomResponse ? roomResponse.stripped_state : roomResponse.invite_state
|
|
||||||
|
// Try extracting from event (if passed)
|
||||||
|
if (Array.isArray(event?.unsigned?.invite_room_state) && event.unsigned.invite_room_state.length) {
|
||||||
|
return {
|
||||||
|
name: getFromInviteRoomState(event.unsigned.invite_room_state, "m.room.name", "name"),
|
||||||
|
topic: getFromInviteRoomState(event.unsigned.invite_room_state, "m.room.topic", "topic"),
|
||||||
|
avatar: getFromInviteRoomState(event.unsigned.invite_room_state, "m.room.avatar", "url"),
|
||||||
|
type: getFromInviteRoomState(event.unsigned.invite_room_state, "m.room.create", "type")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try calling sliding sync API and extracting from stripped state
|
||||||
|
try {
|
||||||
|
/** @type {Ty.R.SSS} */
|
||||||
|
var root = await mreq.mreq("POST", path("/client/unstable/org.matrix.simplified_msc3575/sync", `@${reg.sender_localpart}:${reg.ooye.server_name}`, {timeout: "0"}), {
|
||||||
|
lists: {
|
||||||
|
a: {
|
||||||
|
ranges: [[0, 999]],
|
||||||
|
timeline_limit: 0,
|
||||||
|
required_state: [],
|
||||||
|
filters: {
|
||||||
|
is_invite: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
// Extract from sliding sync response if valid (seems to be okay on Synapse, Tuwunel and Continuwuity at time of writing)
|
||||||
|
if ("lists" in root) {
|
||||||
|
if (!root.rooms?.[roomID]) {
|
||||||
|
const e = new Error("Room data unavailable via SSS")
|
||||||
|
e["data_sss"] = root
|
||||||
|
throw e
|
||||||
|
}
|
||||||
|
|
||||||
|
const roomResponse = root.rooms[roomID]
|
||||||
|
const strippedState = "stripped_state" in roomResponse ? roomResponse.stripped_state : roomResponse.invite_state
|
||||||
|
|
||||||
|
return {
|
||||||
|
name: getFromInviteRoomState(strippedState, "m.room.name", "name"),
|
||||||
|
topic: getFromInviteRoomState(strippedState, "m.room.topic", "topic"),
|
||||||
|
avatar: getFromInviteRoomState(strippedState, "m.room.avatar", "url"),
|
||||||
|
type: getFromInviteRoomState(strippedState, "m.room.create", "type")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {}
|
||||||
|
|
||||||
|
// Invalid sliding sync response, try alternative (required for Conduit at time of writing)
|
||||||
|
const hierarchy = await getHierarchy(roomID, {limit: 1})
|
||||||
|
if (hierarchy?.rooms?.[0]?.room_id === roomID) {
|
||||||
|
const room = hierarchy?.rooms?.[0]
|
||||||
|
return {
|
||||||
|
name: room.name ?? null,
|
||||||
|
topic: room.topic ?? null,
|
||||||
|
avatar: room.avatar_url ?? null,
|
||||||
|
type: room.room_type
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const e = new Error("Room data unavailable via SSS/hierarchy")
|
||||||
|
e["data_sss"] = root
|
||||||
|
e["data_hierarchy"] = hierarchy
|
||||||
|
throw e
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -77,6 +77,7 @@ async function mreq(method, url, bodyIn, extra = {}) {
|
||||||
/** @type {any} */
|
/** @type {any} */
|
||||||
var root = JSON.parse(text)
|
var root = JSON.parse(text)
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
delete opts.headers?.["Authorization"]
|
||||||
throw new MatrixServerError(text, {baseUrl, url, ...opts})
|
throw new MatrixServerError(text, {baseUrl, url, ...opts})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
1
src/types.d.ts
vendored
1
src/types.d.ts
vendored
|
|
@ -433,6 +433,7 @@ export namespace R {
|
||||||
guest_can_join: boolean
|
guest_can_join: boolean
|
||||||
join_rule?: string
|
join_rule?: string
|
||||||
name?: string
|
name?: string
|
||||||
|
topic?: string
|
||||||
num_joined_members: number
|
num_joined_members: number
|
||||||
room_id: string
|
room_id: string
|
||||||
room_type?: string
|
room_type?: string
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue