This repository has been archived by the owner on Mar 17, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 763
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
7df85ce
commit 5842cd6
Showing
10 changed files
with
165 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,126 @@ | ||
# Federation | ||
|
||
## Introduction | ||
|
||
Rocket.Chat Federation allows servers to communicate with each other, with no limits on the number of connected servers. | ||
|
||
We use industry standards, like DNS records, keeping the process as seamless as possible, seeking the most hassle-free communication between servers. | ||
|
||
When enabling federation on your server, your server becames part of the Rocket.Chat Federated Network, which allows it to find and exchange messages and files with other Federation enabled Rocket.Chat servers. | ||
|
||
## Features | ||
|
||
- **Current** | ||
- Inviting users from remote servers; | ||
- Direct chats between servers; | ||
- Public, private and broadcast rooms with remote users from any number of servers; | ||
- Read receipts, notifications and alerts are distributed to remote servers; | ||
- Mute/Unmute remote users; | ||
- File sharing among servers; | ||
- **Confirmed next features** | ||
- Encrypted rooms; | ||
- Whitelist servers to communicate with; | ||
- Better federation setup process, with helpers to validate the configuration; | ||
|
||
## Configuration | ||
|
||
When you open Federation's config screen, you will see this: | ||
|
||
data:image/s3,"s3://crabby-images/13fd1/13fd1a543f8863eaee30f28a825e0ffd151815e3" alt="Initial Federation Screen" | ||
|
||
Below, a brief explanation of each configuration option: | ||
|
||
### Enabled | ||
|
||
This determines whether or not Federation is enabled on this server. | ||
|
||
### Status | ||
|
||
This is the current Federation status, which can be one of the following: | ||
|
||
- **Could not enable, settings are not fully set :** Make sure all the options are correctly filled and saved; | ||
- **Booting... :** federation is initializing; | ||
- _[HUB Only]_ **Registering with Hub... :** federation is trying to register with the Hub; | ||
- _[HUB Only]_ **Disabled, could not register with Hub :** federation could not register with the Hub; | ||
- **Disabled :** federation is disabled | ||
- **Running :** federation is running and ready to communicate with other servers; | ||
|
||
### Domain | ||
|
||
Fill this option with your domain name, usually where the Rocket.Chat server is hosted. | ||
|
||
### Public Key | ||
|
||
All Federation communications are double encrypted, which means messages cannot be delivered by mistake to a wrong peer. This is your public key, which is specially generated for Rocket.Chat and by Rocket.Chat, which will be shared with peers you are communicating with. | ||
|
||
The encryption process encrypts the message using the Server A private key, and the Server B public key. | ||
|
||
When a server receives the message, it uses the Server B private key and the Server A public key to decrypt it. | ||
|
||
So, let's say the message ended up on Server C: this server won't have Server B's private key to decrypt it, so the message can't be read at all. | ||
|
||
### Hub URL | ||
|
||
This usually remains as is. This is the Hub URL, where your server will register and confirm domain ownership if you are not using DNS discovery method. | ||
|
||
### Discovery Method | ||
|
||
How are you going to be found in the Rocket.Chat Federated Network? You can choose through DNS or, as a fallback, the Rocket.Chat Hub. | ||
|
||
**Important:** We recommend using the DNS method. The Hub is a tool to allow users to easily adopt, try and validate the feature or as a different way to be part of the Rocket.Chat Federated Network until DNS record changes are made. Also, the Hub requires external communication and access to a specific e-mail address owned by your domain, as explained below, which introduces extra configuration steps in some protected internal networks. | ||
|
||
## Adding Federation to your server | ||
|
||
You have two ways of adding your server to the Rocket.Chat Federated Network: | ||
|
||
### Recommended: Configuring your DNS | ||
|
||
To add your server to the Federated Network using the DNS, fill all the needed configuration fields (making sure you are picking **true** on the _Enabled_ field), pick the `DNS` _Discovery Method_ option, save and follow the guide below. | ||
|
||
Let's suppose we have a domain named `mydomain.com`, and my Rocket.Chat server is hosted at `chat.mydomain.com`, port `80`. | ||
|
||
You'll have to add two DNS records: | ||
|
||
#### SRV Record | ||
|
||
- Service: `_rocketchat` | ||
- Protocol: `_tcp` | ||
- Name: `mydomain.com` | ||
- Weight: `1` | ||
- Priority: `1` | ||
- TTL: `1 hour` | ||
- Target: `chat.mydomain.com` | ||
- Port: `80` | ||
|
||
In Amazon Route 53 it would look something like this: | ||
data:image/s3,"s3://crabby-images/e75dc/e75dc66ca448c63d5fec316fe1044a6adc041ed6" alt="image" | ||
|
||
#### TXT Record | ||
|
||
- Host: `rocketchat-public-key.mydomain.com` | ||
- Value: `<my public key, as shown on the configuration screen>` | ||
|
||
When both of those entries are added to the DNS records, you should be able to be found by other peers after the propagation. | ||
|
||
NOTE: Some DNS providers won't allow the full public key string to be entered so, after saving, we recommend making sure the string is complete, starting as `-----BEGIN PUBLIC KEY-----` and ending as `-----END PUBLIC KEY-----`. If that is not the case, follow your provider's instructions. For example, AWS's Route 53 needs the string to be split in two pieces, like this: | ||
|
||
``` | ||
"-----BEGIN PUBLIC KEY-----...." | ||
"...-----END PUBLIC KEY-----" | ||
``` | ||
|
||
### Alternative: registering on Hub | ||
|
||
To add your server to the Federated Network using the Hub, fill all the needed configuration fields (making sure you are picking **true** on the _Enabled_ field), pick the `Hub` _Discovery Method_ option, save and follow the guide below. | ||
|
||
#### Confirm domain ownership | ||
|
||
When you click `Save` on the federation config screen, you will begin the registration process. This process takes a few seconds and if you are not yet registered to the Hub, you should receive an email at `webmaster@mydomain.com`, where `mydomain.com` is the domain address you configured on the `Domain` field. | ||
|
||
Make sure the data is correct and confirm the changes. | ||
|
||
After that step, you should be able to be found on the Rocket.Chat Federated Network. | ||
|
||
## Using Rocket.Chat Federation | ||
|
||
Click [here](../../user-guides/talking-to-users-from-another-server/) to learn how to use Rocket.Chat federation. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
32 changes: 32 additions & 0 deletions
32
user-guides/talking-to-users-from-another-server/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
# Talking to users from another server | ||
|
||
Once you have [added your server to the Federated Network](../../administrator-guides/federation) you can talk to users from server who have done the same. | ||
|
||
## Using Rocket.Chat Federation | ||
|
||
After enabling federation, you should be able to start chatting with other servers. | ||
|
||
## Inviting users from a different server | ||
|
||
To do so, you should go to the `Directory` section, `Users` tab, and pick `Every Workspace` from the dropdown menu. | ||
|
||
data:image/s3,"s3://crabby-images/817de/817de654e94ef9180041451c39dfb69f0dccdf7a" alt="Directory Search Users" | ||
|
||
Then, you should be able to look for users on remote servers, called peers. You can search using a combination of a username and a domain or an e-mail address, like: | ||
|
||
- Username: `myfriendsusername@anotherdomain.com` | ||
- E-mail address: `joseph@remotedomain.com` | ||
|
||
If the remote server is within Rocket.Chat Federated Network, you will be able to see the users: | ||
|
||
data:image/s3,"s3://crabby-images/3eb72/3eb72f0353f5f47be0d8f957b68d39eb5851ccdc" alt="Directory Search Result" | ||
|
||
## Inviting remote users and chatting | ||
|
||
If you click on one of those listed users, you will invite them to your server without login access. Also, you and everyone else on your server will be able to chat with that new remote user. | ||
|
||
data:image/s3,"s3://crabby-images/d9bb3/d9bb366e3b224a41fae905c93e5280046e8eab48" alt="Chat" | ||
|
||
From now on, you can invite that user to any other room, public or private. Those channels are going to be replicated to the remote server, without the messages history. | ||
|
||
As a reminder, if you invite a remote user to a public channel, this channel will be created as private on the remote server, so you can be sure only invited users will be able to see that channel content. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+36.7 KB
user-guides/talking-to-users-from-another-server/directory-result.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.