connector: first pass at bridging guilds
For each guild specified in the config, create a space and bridge all contained text channels that the user has permissions to view. * Finally add a custom config struct where we accept a list of guild IDs to bridge. This is intended to be temporary as we flesh out the proper interfaces for managing which guilds to bridge. * Defined a custom meta type for portals that holds the containing guild ID of the channel (if any). * Transferred the responsibility of building a channel's ChatInfo and ChatMemberList to the DiscordChatResync event itself.
This commit is contained in:
@@ -31,6 +31,8 @@ import (
|
||||
"maunium.net/go/mautrix/bridgev2"
|
||||
"maunium.net/go/mautrix/event"
|
||||
"maunium.net/go/mautrix/format"
|
||||
|
||||
"go.mau.fi/mautrix-discord/pkg/discordid"
|
||||
)
|
||||
|
||||
const discordEpochMillis = 1420070400000
|
||||
@@ -109,6 +111,7 @@ func (mc *MessageConverter) ToDiscord(
|
||||
}
|
||||
|
||||
portal := msg.Portal
|
||||
guildID := msg.Portal.Metadata.(*discordid.PortalMetadata).GuildID
|
||||
channelID := string(portal.ID)
|
||||
content := msg.Content
|
||||
|
||||
@@ -152,8 +155,8 @@ func (mc *MessageConverter) ToDiscord(
|
||||
Name: att.Filename,
|
||||
ID: mc.NextDiscordUploadID(),
|
||||
}},
|
||||
// TODO: Populate with guild ID. Support threads.
|
||||
}, discordgo.WithChannelReferer("", channelID))
|
||||
// TODO: Support threads.
|
||||
}, discordgo.WithChannelReferer(guildID, channelID))
|
||||
|
||||
if err != nil {
|
||||
log.Err(err).Msg("Failed to create attachment in preparation for attachment reupload")
|
||||
|
||||
Reference in New Issue
Block a user