forked from cadence/out-of-your-element
		
	be able to sync space properties
This commit is contained in:
		
							parent
							
								
									6cd509d274
								
							
						
					
					
						commit
						892bf4496d
					
				
					 1 changed files with 17 additions and 6 deletions
				
			
		|  | @ -4,13 +4,15 @@ const assert = require("assert") | ||||||
| const DiscordTypes = require("discord-api-types/v10") | const DiscordTypes = require("discord-api-types/v10") | ||||||
| 
 | 
 | ||||||
| const passthrough = require("../../passthrough") | const passthrough = require("../../passthrough") | ||||||
| const { sync, db } = passthrough | const { discord, sync, db } = passthrough | ||||||
| /** @type {import("../../matrix/api")} */ | /** @type {import("../../matrix/api")} */ | ||||||
| const api = sync.require("../../matrix/api") | const api = sync.require("../../matrix/api") | ||||||
| /** @type {import("../../matrix/file")} */ | /** @type {import("../../matrix/file")} */ | ||||||
| const file = sync.require("../../matrix/file") | const file = sync.require("../../matrix/file") | ||||||
| /** @type {import("./create-room")} */ | /** @type {import("./create-room")} */ | ||||||
| const createRoom = sync.require("./create-room") | const createRoom = sync.require("./create-room") | ||||||
|  | /** @type {import("../../matrix/kstate")} */ | ||||||
|  | const ks = sync.require("../../matrix/kstate") | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * @param {import("discord-api-types/v10").RESTGetAPIGuildResult} guild |  * @param {import("discord-api-types/v10").RESTGetAPIGuildResult} guild | ||||||
|  | @ -58,7 +60,7 @@ async function guildToKState(guild) { | ||||||
| 		"m.room.name/": {name: guild.name}, | 		"m.room.name/": {name: guild.name}, | ||||||
| 		"m.room.avatar/": avatarEventContent, | 		"m.room.avatar/": avatarEventContent, | ||||||
| 		"m.room.guest_access/": {guest_access: "can_join"}, // guests can join space if other conditions are met
 | 		"m.room.guest_access/": {guest_access: "can_join"}, // guests can join space if other conditions are met
 | ||||||
| 		"m.room.history_visibility": {history_visibility: "invited"} // any events sent after user was invited are visible
 | 		"m.room.history_visibility/": {history_visibility: "invited"} // any events sent after user was invited are visible
 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return guildKState | 	return guildKState | ||||||
|  | @ -69,17 +71,26 @@ async function syncSpace(guildID) { | ||||||
| 	const guild = discord.guilds.get(guildID) | 	const guild = discord.guilds.get(guildID) | ||||||
| 	assert.ok(guild) | 	assert.ok(guild) | ||||||
| 
 | 
 | ||||||
| 	/** @type {{room_id: string, thread_parent: string?}} */ | 	/** @type {string?} */ | ||||||
| 	const existing = db.prepare("SELECT space_id from guild_space WHERE guild_id = ?").get(guildID) | 	const spaceID = db.prepare("SELECT space_id from guild_space WHERE guild_id = ?").pluck().get(guildID) | ||||||
| 
 | 
 | ||||||
| 	const guildKState = await guildToKState(guild) | 	const guildKState = await guildToKState(guild) | ||||||
| 
 | 
 | ||||||
| 	if (!existing) { | 	if (!spaceID) { | ||||||
| 		const spaceID = await createSpace(guild, guildKState) | 		const spaceID = await createSpace(guild, guildKState) | ||||||
|  | 		return spaceID // Naturally, the newly created space is already up to date, so we can always skip syncing here.
 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	console.log(`[space sync] to matrix: ${guild.name}`) | ||||||
|  | 
 | ||||||
|  | 	// sync channel state to room
 | ||||||
|  | 	const spaceKState = await createRoom.roomToKState(spaceID) | ||||||
|  | 	const spaceDiff = ks.diffKState(spaceKState, guildKState) | ||||||
|  | 	await createRoom.applyKStateDiffToRoom(spaceID, spaceDiff) | ||||||
|  | 
 | ||||||
| 	return spaceID | 	return spaceID | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| module.exports.createSpace = createSpace | module.exports.createSpace = createSpace | ||||||
|  | module.exports.syncSpace = syncSpace | ||||||
|  | module.exports.guildToKState = guildToKState | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue