Creating a connection
We can create and accept a connection from the Connected Organisations page under the environment section.
On the add a connection button, you have two options:
Create a connection
Accept an invitation
Creating a connection
Only instances with an Enterprise license can create a connection with another server. Once the user clicks on Create a connection, they’re taken to the Connection Inner page:
Here they can enter/decide:
Organisation name
This would also be the connection name
Choose default destination team
This would be the default team where any channels shared would land.
Channels they want to share
Initially, the user can only share their own channels, and not see other channels that are shared, but later on, they will see two tabs:
For channels shared by the external server
Their own channels shared.
Channel Sharing
The user can decide to share their channels by clicking on the Add channels button.
A modal opens up allowing them to choose Public channels cross team.
The user can select multiple channels.
Once the channels are selected and added, they appear in the list.
The user can decide to remove them, or add new channels.
This would use a pretty similar UI as the channels listing page in the system console.
We will not have the filters here that exist in that channels listing page.
A server cannot reshare a channel that's shared with them (so this would only show channels belonging to your server)
However, a channel originating on your server can be shared to multiple secure connections
Share code
Once done, the user can click on Save to create a connection. They get a share popup to share the code needed to accept the connection.
Accepting a connection
Only instances with an Enterprise license can accept a connection with another server. On the other end, once the user receives the invitation code, they can go to the same page and click on Accept a connection in the Add connection dropdown.
Here the user can enter the encrypted invitation code and the organisation name.
Connection Inner Page
This inner page is similar to the one above. Except, it has two tabs which shows channels shared by the external org, and the your own channels shared.
Changing the destination team
The user can change the destination team to decide where the channels land.
Unless the destination team is overridden at a per channel level, the default team would also change for the channel.
The user can decide to change the destination team of a channel before he accepts the connection by pressing the edit button.
If they press the edit button, a modal like this appears. allowing them to change the team (only for that channel).
Connection list page
Here we display the connections that the user has created/accepted.
Status of the connection.
Channels shared
Options to See the invitation code, edit, and delete the connection.
The option to see the invitation code will only be there if the connection is pending.
Once the connection is made, the share code option will disappear, as we only allow users to share the code 1 to 1.
DMs with External Connection
If you are sharing a channel with a user, you can also communicate with them via DM.
Shared channels in sidebar
This is how the shared channels would appear, with the shared icon, and hovering over it displays the tooltip.
Any user in the channel that belongs to the external org would also have that icon beside is username/fullname.
Browse shared channels
Shared channels would also be visible in the browse channels modal with an icon.
Channel Members
Members from other orgs can also be seen in the channel member list (with an icon on the right), but you won’t be able to manage them.
Removing a connection
When a connection/channel is removed, we will remove all shared users from the channel list, and also remove the link icon from the LHS, header, and anywhere it appears.