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.
34 lines
1.2 KiB
Go
34 lines
1.2 KiB
Go
// mautrix-discord - A Matrix-Discord puppeting bridge.
|
|
// Copyright (C) 2026 Tulir Asokan
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Affero General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package discordid
|
|
|
|
import "github.com/bwmarrin/discordgo"
|
|
|
|
type PortalMetadata struct {
|
|
// The ID of the Discord guild that the channel corresponding to this portal
|
|
// belongs to.
|
|
//
|
|
// For private channels (DMs and group DMs), this will be the zero value
|
|
// (an empty string).
|
|
GuildID string `json:"guild_id"`
|
|
}
|
|
|
|
type UserLoginMetadata struct {
|
|
Token string `json:"token"`
|
|
HeartbeatSession discordgo.HeartbeatSession `json:"heartbeat_session"`
|
|
}
|