-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Multi-domain support #8885
Comments
This will be inherently supported when portable identities (initially MSC1228 and now its successor MSC2787) is implemented. Portable identities will allow users to show up to any old homeserver with their MXID and UPK, and that homeserver will then send messages on their behalf. In this world where MXIDs will map to user keys, I imagine aliases will be much easier to implement. |
It's good to know this is in progress. Another use case that require this multi-domain feature, a slightly different than the Alias approach. Not sure if the "portable identities" can achieve this as well: Say i am hosting a matrix instance for myself, using myName.com, and I have one (or few) MXID for my own uses, work or personal. It works great so right now I want to bring my friend onboard. It's definitely possible to ask them to register through matrix.org or other homeservers, but I would like to offer them opportunity to use my homeserver. However it looks weird if I give them @their_name:myname.com ID (use my server's domain). So I would like to add an additional domain name (eg. whatNet.com) so I can assign different domain to my friend on one single instances. I believe XMPP can do it, one instances that hosts multiple domains. Of course, i can run two different instances, for two different domain, but then it back to William's issue,
|
@SharkIng I believe your use-case is the intended use-case for this feature, aliases were just an additional bonus. Portable identities do not actually completely solve this issue inherently (AFAIK) as it is currently written, because it sounds like creating an MXID would still require operating a homeserver on that domain. But I added a suggestion that would enable this behavior at matrix-org/matrix-spec-proposals#2787 (comment) |
Is this the best issue to follow for this? This would be awesome to have. I'm in the same boat running things in docker with the exception that I want to run two, but would love to do it with a minimum of fuss. Thank you for all of your hard work on this! |
I've been using Synapse for several years now via docker and I wanted to add my two cents. Recently, I too found myself wanting to expand usage into completely different projects. This feature is a must to be able to do so. Otherwise as others have stated, the added complexity of maintaining multiple instances (even with tools like Ansible and the like) make this a no go currently. Also, big thanks to all the folks who work on this project. I moved away from Whatsapp (Facebook) a few years ago and enjoy the fact that I own my data, not some corporate entity. Cheers! |
Adding some keywords: multi-tenant multi-tenancy |
How is it going? Is the multi-tenant support there? My use case is that I want synapse to use different databases inside a same DB-server. |
I'm in the same boat - we run several projects, and their public rooms (at least) should be in their respective domains. I cannot just choose one and let other projects borrow its name. I could come up with yet another domain independent of all of them just to run Matrix, but that sounds stupid, and also is not great for PR... An alternative by running several instances requires significantly more resources and also increases maintenance costs. |
@marmarek if all you want is room aliases on a domain you can use https://github.com/tulir/mauliasproxy |
Please implement this feature! I am currently forced to run two homeserver instances on the same metal just for the sake of separating business chat (me@business.com) from family chat (me@family.com). It would be really great if I could simply host both MXIDs (me@business.com and me@family.com) on the same technical instance as it halfs the metal and effort needed! Thanks! 👍 |
thumbs up on this one |
Adding keywords: vhost virtual host hosts |
Are there any updates on this? I’d also like to share one install for more than one domain… |
As seemingly portable identities aren't happening anytime soon, could we please just solve it using a workaround as trivial as possible? We would badly need to enable by default people to register to free shared Synapse instances with their own domain or subdomain. It's way better spam protection than requiring an email address and as a bonus, could also provide for a transition path for the user if the HS dies. Even if all account data is otherwise lost, the user could get to keep their established name. |
I hacked together a solution for me with using caddy v2 as reverse proxy. My scenario:
As a result, I can log in to element.web from within an iframe (!) inside nextcloud, no matter which domain I'm using for nextcloud, without changing This is the relevant code block for reverse proxying matrix & synapse:
This approach may be adaptable to keep synapse and its singular public_baseurl but make it reachable by many domains. The MXID server part would still be same for all, based on the servername. Note: Playing with the cookie domains and CSP is not a great thing to do, but I hoped I did not create an open window for malpractice |
Description:
As a mail server can be configured to be the MTA for multiple email domains, so should Synapse be able to support being the homeserver for multiple domains.
I currently run two synapse servers on two separate domains in docker containers, but on the same host (using separate docker container stacks). This leads to excessive configuration regarding additional networking, database storage with duplicate datasets, and federation across two synapse servers sitting directly next to each other. Ideally, synapse should be aware that the server handles homeserver duties for multiple domains, and skip excessive federation or data storage for things that would otherwise be federated across the network.
Additionally, it would be nice to have the ability (like in mail servers) to have "alias" functionality for vanity user accounts or domains (e.g. a publicly published matrix ID of
@mycoolusername:myworkdomain.net
would actually just send messages to and from the@user:personaldomain.com
matrix ID).The text was updated successfully, but these errors were encountered: