3.4 KiB
Megabridge
Megabridge, also known as bridgev2 (final naming is subject to change), is a new high-level framework for writing puppeting Matrix bridges with hopefully minimal boilerplate code.
General architecture
Megabridge is split into three components: network connectors, the central bridge module, and Matrix connectors.
-
Network connectors are responsible for connecting to the remote (non-Matrix) network and handling all the protocol-specific details.
-
The central bridge module has most of the generic bridge logic, such as keeping track of portal mappings and handling messages.
-
Matrix connectors are responsible for connecting to Matrix. Initially there will be two Matrix connectors: one for the standard setup that connects to a Matrix homeserver as an application service, and another for Beeper's local bridge system. However, in the future there could be a third connector which uses a single bot account and MSC4144 instead of an appservice with ghost users.
The central bridge module defines interfaces that it uses to interact with the connectors on both sides. Additionally, the connectors are allowed to directly call interface methods on other side.
Getting started with a new network connector
To create a new network connector, you need to implement the
NetworkConnector
, LoginProcess
, NetworkAPI
and RemoteEvent
interfaces.
NetworkConnector
is the main entry point to the remote network. It is responsible for general non-user-specific things, as well as creatingNetworkAPI
s and starting login flows.LoginProcess
is a state machine for logging into the remote network.NetworkAPI
is the remote network client for a single login. It is responsible for maintaining the connection to the remote network, receiving incoming events, sending outgoing events, and fetching information like chat/user metadata.RemoteEvent
represents a single event from the remote network, such as a message or a reaction. When the NetworkAPI receives an event, it should create aRemoteEvent
object and pass it to the bridge usingBridge.QueueRemoteEvent
.
Login
Logins are implemented by combining three types of steps:
user_input
asks the user to enter some information, such as a phone number, username, email, password, or 2FA code.cookies
either asks the user to extract cookies from their browser, or opens a webview to do it automatically (depending on whether the login is being done via bridge commands or a more advanced client).display_and_wait
displays a QR code or other data to the user and waits until the remote network accepts the login.
The general flow is:
- Login handler (bridge command or client) calls
NetworkConnector.GetLoginFlows
to get available login flows, and asks the user to pick one (or alternatively automatically picks the first one if there's only one option). - Login handler calls
NetworkConnector.CreateLogin
with the chosen flow ID and the network connector returns aLoginProcess
object that remembers the user and flow. - Login handler calls
LoginProcess.Start
to get the first step. - Login handler calls the appropriate functions (
Wait
,SubmitUserInput
orSubmitCookies
) based on the step data as many times as needed. - When the login is done, the login process creates the
UserLogin
object and returns acomplete
step.