Matrix-Discord bridge with modern features.
Find a file
Guzio 86cfbd21a9 I broke Git
of course I did
2026-03-02 15:27:54 +00:00
.vscode changing spaces to tabs 2023-08-21 21:04:41 +12:00
docs Improve threads UX 2026-03-02 15:17:08 +00:00
scripts Add script to estimate total channel file size 2026-02-27 18:35:48 +13:00
src Improve threads UX 2026-03-02 15:17:08 +00:00
test Improve threads UX 2026-03-02 15:17:08 +00:00
.c8rc.json Rearrange code (self-review) 2024-03-04 17:02:38 +13:00
.gitignore Update .gitignore 2026-02-19 13:03:16 +00:00
addbot.js Future-proof permissions 2025-12-05 17:13:56 +13:00
addbot.sh Remove token from config file 2024-09-13 23:47:11 +12:00
COPYING license nicense 2023-10-02 23:12:03 +13:00
jsconfig.json Fix typecheck 2026-02-11 11:31:27 +13:00
package-lock.json Allow for custom additions to webroot 2026-02-17 12:54:50 +13:00
package.json Allow for custom additions to webroot 2026-02-17 12:54:50 +13:00
readme.md Document encryption as unsupported 2026-03-01 22:05:46 +13:00
start.js Wait for Discord connection before listening m->d 2026-01-21 14:53:52 +13:00

Out Of Your Element

Modern Matrix-to-Discord appservice bridge, created by @cadence:cadence.moe

Releases Discuss on Matrix

Why a new bridge?

  • Modern: Supports new Discord features like replies, threads and stickers, and new Matrix features like edits, spaces and space membership.
  • Efficient: Special attention has been given to memory usage, database indexes, disk footprint, runtime algorithms, and queries to the homeserver. Efficiency details.
  • Reliable: Any errors on either side are notified on Matrix and can be retried. Messages sent during bridge downtime will still be bridged after it comes back up.
  • Tested: A test suite and code coverage make sure all the logic and special cases work.
  • Simple development: No build step (it's JavaScript, not TypeScript), minimal/lightweight dependencies, and abstraction only where necessary so that less background knowledge is required. No need to learn about Intents or library functions.
  • No locking algorithm: Other bridges use a locking algorithm which is a source of frequent bugs. This bridge avoids the need for one.
  • Latest API: Being on the latest Discord API version lets it access all features, without the risk of deprecated API versions being removed.

What works?

Most features you'd expect in both directions: messages, edits, deletions, formatting (including spoilers), reactions, custom emojis, custom emoji reactions, mentions, channel mentions, replies, threads, stickers (all formats: PNG, APNG, GIF, Lottie), attachments, spoiler attachments (compatible with most clients), embeds, URL previews, presence, discord.com hyperlinks, and more.

Metadata is also synced: people's names, avatars, usernames; channel names, icons, topics; spaces containing rooms; custom emoji lists. Syncing Matrix rooms, room icons, and topics is optional: you can keep them different from the Discord ones if you prefer.

I've also added some interesting features that I haven't seen in any other bridge:

  • Members using the PluralKit bot each get their own persistent accounts
  • Replies from PluralKit members are restyled into native Matrix replies
  • Simulated user accounts are named @the_persons_username rather than @112233445566778899
  • Matrix custom emojis from private rooms are still visible on Discord as a sprite sheet
  • To save space, larger files from Discord are linked instead of reuploaded to Matrix (links don't expire)

For more information about features, see the user guide.

Caveats

  • This bridge is not designed for puppetting.
  • Direct Messaging is not supported until I figure out a good way of doing it.
  • Encrypted messages are not supported. Decryption is often unreliable on Matrix, and your messages end up in plaintext on Discord anyway, so there's not much advantage.

Get started!

Read the installation instructions →