mirror of
https://github.com/42wim/matterbridge.git
synced 2025-02-18 22:40:47 +01:00
Created MS Teams setup (markdown)
parent
1339031c97
commit
f47f441cf6
280
MS-Teams-setup.md
Normal file
280
MS-Teams-setup.md
Normal file
@ -0,0 +1,280 @@
|
||||
<!-- TOC -->
|
||||
|
||||
- [MSteams - mattermost - matterbridge integration](#MSteams---mattermost---matterbridge-integration)
|
||||
- [Go to Microsoft Azure portal](#go-to-microsoft-azure-portal)
|
||||
- [Go to App registrations](#go-to-app-registrations)
|
||||
- [Create a new App registration](#create-a-new-app-registration)
|
||||
- [Set Permissions](#set-permissions)
|
||||
- [Click on View API Permissions (at the bottom)](#click-on-view-api-permissions-at-the-bottom)
|
||||
- [Actually set permissions](#actually-set-permissions)
|
||||
- [Wait and let an admin consent them](#wait-and-let-an-admin-consent-them)
|
||||
- [Consent](#consent)
|
||||
- [Accept permissions](#accept-permissions)
|
||||
- [Wait again](#wait-again)
|
||||
- [Reload](#reload)
|
||||
- [Set redirect URI](#set-redirect-uri)
|
||||
- [Set application as public client](#set-application-as-public-client)
|
||||
- [Get necessary ID's for matterbridge](#get-necessary-ids-for-matterbridge)
|
||||
- [ClientID and TenantID](#clientid-and-tenantid)
|
||||
- [TeamID](#teamid)
|
||||
- [ChannelID](#channelid)
|
||||
- [Matterbridge configuration](#matterbridge-configuration)
|
||||
- [Configure teams in matterbridge](#configure-teams-in-matterbridge)
|
||||
- [Configure mattermost in matterbridge](#configure-mattermost-in-matterbridge)
|
||||
- [Configure bridging channels](#configure-bridging-channels)
|
||||
- [Once again the complete configuration](#once-again-the-complete-configuration)
|
||||
- [Starting matterbridge](#starting-matterbridge)
|
||||
|
||||
<!-- /TOC -->
|
||||
|
||||
# MSteams - mattermost - matterbridge integration
|
||||
|
||||
This is a complete walkthrough about how to setup an example mattermost <=> microsoft teams integration using matterbridge.
|
||||
|
||||
Please read everything very careful!
|
||||
|
||||
# Go to Microsoft Azure portal
|
||||
|
||||
- https://portal.azure.com/#blade/Microsoft_AAD_IAM/ActiveDirectoryMenuBlade/Overview
|
||||
|
||||
# Go to App registrations
|
||||
|
||||
- https://portal.azure.com/#blade/Microsoft_AAD_IAM/ActiveDirectoryMenuBlade/RegisteredApps
|
||||
|
||||
data:image/s3,"s3://crabby-images/219f9/219f9f21a088d3de88ddc9a792d91b12eec9e4cb" alt="image"
|
||||
|
||||
# Create a new App registration
|
||||
|
||||
Click on `New Registration` (top)
|
||||
|
||||
data:image/s3,"s3://crabby-images/6c983/6c9834984621116e4c36dc8b5a66f4d84a9691eb" alt="image"
|
||||
|
||||
# Set Permissions
|
||||
|
||||
## Click on View API Permissions (at the bottom)
|
||||
|
||||
data:image/s3,"s3://crabby-images/c6041/c6041131b0007bf51857efc82efaeba4bd2ff56d" alt="image"
|
||||
|
||||
## Actually set permissions
|
||||
|
||||
- Choose `graph API`
|
||||
- Choose `delegated permissions`
|
||||
- Add `Group.Read.All` and `Group.ReadWrite.All`
|
||||
|
||||
data:image/s3,"s3://crabby-images/d8ba1/d8ba1da3169b9bb53b4a3662ca577321c57c84ff" alt="image"
|
||||
|
||||
## Wait and let an admin consent them
|
||||
|
||||
This can take a while according to the message
|
||||
|
||||
data:image/s3,"s3://crabby-images/ec494/ec494ef42b5e3a68fe9fbddf5c33fa4bf7bda8bf" alt="image"
|
||||
|
||||
## Consent
|
||||
|
||||
You can now click on the Grant admin consent for `yourorganization`
|
||||
|
||||
data:image/s3,"s3://crabby-images/617ad/617ad984f098c90f687efcd6f1259e6ab90e5ae0" alt="image"
|
||||
|
||||
## Accept permissions
|
||||
|
||||
You'll get a popup with the permissions you just added. Agree
|
||||
|
||||
data:image/s3,"s3://crabby-images/a34f4/a34f4550431124cf07c4bb431f55adcb0396fade" alt="image"
|
||||
|
||||
## Wait again
|
||||
|
||||
This will take a few minutes again :)
|
||||
|
||||
data:image/s3,"s3://crabby-images/9ea7b/9ea7bcadc8116db95026803965cd6357fc9f5d02" alt="image"
|
||||
|
||||
## Reload
|
||||
|
||||
Afterwards you'll see green checkboxes for the permissions
|
||||
|
||||
data:image/s3,"s3://crabby-images/2cbd3/2cbd3af3c5bb5fe3b0dd67b3947822df526c3189" alt="image"
|
||||
|
||||
# Set redirect URI
|
||||
|
||||
This needs to be set otherwise the delegation doesn't work. Click on "Add a redirect URI"
|
||||
|
||||
data:image/s3,"s3://crabby-images/b7c64/b7c646897262b46b3cc4a020572aec5519a9665c" alt="image"
|
||||
|
||||
Just fill in something like http://localhost:12345/matterbridge
|
||||
|
||||
data:image/s3,"s3://crabby-images/be88c/be88c68bdcb4d9a88054fe321d533a5bdd67d9ee" alt="image"
|
||||
|
||||
# Set application as public client
|
||||
|
||||
Scroll down a bit
|
||||
|
||||
Set `Treat application as a public client.` to Yes
|
||||
|
||||
data:image/s3,"s3://crabby-images/c2839/c28390a86329ae5ea8ebedd545bf19561508194c" alt="image"
|
||||
|
||||
Don't forget to click Save on top of the page
|
||||
|
||||
|
||||
# Get necessary ID's for matterbridge
|
||||
|
||||
## ClientID and TenantID
|
||||
|
||||
Click on overview, left upper link.
|
||||
|
||||
You'll see 2 ID's, these are needed for the matterbridge configuration.
|
||||
|
||||
- Tenant ID
|
||||
- Client ID
|
||||
|
||||
data:image/s3,"s3://crabby-images/39ae6/39ae6fa7a2db2479b5ebc454797e68ea78eddc05" alt="image"
|
||||
|
||||
## TeamID
|
||||
|
||||
Go to your teams website <https://teams.microsoft.com> should work.
|
||||
|
||||
Find your team, click on the 3 dots and select `get link to team`
|
||||
|
||||
data:image/s3,"s3://crabby-images/c8fd7/c8fd70034183b5d332083da59847c6747e621caf" alt="image"
|
||||
|
||||
This will get you a popup, click copy.
|
||||
|
||||
data:image/s3,"s3://crabby-images/e29c1/e29c1568e3badfeca23d146f3de71217e46e500b" alt="image"
|
||||
|
||||
If you paste it you'll get something like
|
||||
|
||||
https://teams.microsoft.com/l/team/19%3axxxxxxxxxxxxxxxxxc%40thread.skype/conversations?groupId=**xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx**&tenantId=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
|
||||
|
||||
The groupID is the TeamID you need to configure matterbridge.
|
||||
|
||||
## ChannelID
|
||||
|
||||
Next you have to decide which channel you want to bridge with for example mattermost.
|
||||
|
||||
In our setup we have the team `matterbridge` with 2 channels `General` (a default channel for every team) and `newchannel` one I created.
|
||||
|
||||
You'll find the channel ID in the URL in the `threadId=`**19:82abcxxxxxxxxx@thread.skype**
|
||||
|
||||
data:image/s3,"s3://crabby-images/9d803/9d803a24f5011c98d1fd8cb3f4069d5f631448a6" alt="image"
|
||||
|
||||
Note this ID **19:82abcxxxxxxxxx@thread.skype**, we will need it when configuring the bridging.
|
||||
|
||||
|
||||
# Matterbridge configuration
|
||||
|
||||
Create an empty `matterbridge.toml` file
|
||||
|
||||
## Configure teams in matterbridge
|
||||
|
||||
You should know have all the three ID's to configure matterbridge:
|
||||
|
||||
```toml
|
||||
[msteams.teams]
|
||||
TenantID="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
|
||||
ClientID="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
|
||||
TeamID="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
|
||||
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
|
||||
```
|
||||
|
||||
add this to the `matterbridge.toml` file
|
||||
|
||||
## Configure mattermost in matterbridge
|
||||
|
||||
See als the [wiki](https://github.com/42wim/matterbridge/wiki/Section-Mattermost-(basic)-https)
|
||||
|
||||
Configure this for your setup and add this to the `matterbridge.toml` file
|
||||
|
||||
|
||||
```toml
|
||||
[mattermost.mymattermost]
|
||||
#The mattermost hostname. (do not prefix it with http or https)
|
||||
Server="yourmattermostserver.domain:443"
|
||||
|
||||
#the team name as can be seen in the mattermost webinterface URL
|
||||
#in lowercase, without spaces
|
||||
Team="yourteam"
|
||||
|
||||
#login/pass of your bot.
|
||||
#Use a dedicated user for this and not your own!
|
||||
Login="yourlogin"
|
||||
Password="yourpass"
|
||||
|
||||
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
|
||||
PrefixMessagesWithNick=true
|
||||
```
|
||||
|
||||
## Configure bridging channels
|
||||
|
||||
If you want to bridge the `testing` channel in mattermost with the `general` channel in msteams the configuration will look like this:
|
||||
|
||||
```toml
|
||||
[[gateway.inout]]
|
||||
account = "mattermost.mymattermost"
|
||||
channel = "testing"
|
||||
|
||||
[[gateway.inout]]
|
||||
account="msteams.teams"
|
||||
channel="19:82caxxxxxxxxxxxxxxxxxxxxxxxx@thread.skype"
|
||||
```
|
||||
|
||||
The strange channel **19:82caxxxxxxxxxxxxxxxxxxxxxxxx@thread.skype** can be found in this documentation at the **ChannelID** header above.
|
||||
|
||||
## Once again the complete configuration
|
||||
|
||||
Your `matterbridge.toml` file should contain:
|
||||
|
||||
```toml
|
||||
[msteams.teams]
|
||||
TenantID="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
|
||||
ClientID="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
|
||||
TeamID="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
|
||||
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
|
||||
|
||||
[mattermost.mymattermost]
|
||||
Server="yourmattermostserver.domain:443"
|
||||
Team="yourteam"
|
||||
Login="yourlogin"
|
||||
Password="yourpass"
|
||||
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
|
||||
PrefixMessagesWithNick=true
|
||||
|
||||
[[gateway.inout]]
|
||||
account = "mattermost.mymattermost"
|
||||
channel = "testing"
|
||||
|
||||
[[gateway.inout]]
|
||||
account="msteams.teams"
|
||||
channel="19:82caxxxxxxxxxxxxxxxxxxxxxxxx@thread.skype"
|
||||
```
|
||||
|
||||
|
||||
## Starting matterbridge
|
||||
|
||||
Now you can start matterbridge by running `matterbridge -conf matterbridge.toml`
|
||||
|
||||
The first time you start matterbridge it'll ask you to authenticate the app on behalf of you. You can do this from your own account or use a specific bot account for it.
|
||||
|
||||
Matterbridge can only read/send to the channels the account is in
|
||||
|
||||
```bash
|
||||
[0003] INFO router: Starting bridge: msteams.teams
|
||||
To sign in, use a web browser to open the page https://microsoft.com/devicelogin and enter the code C8EGY6384 to authenticate.
|
||||
```
|
||||
|
||||
Go to the URL as specified and enter the code.
|
||||
|
||||
data:image/s3,"s3://crabby-images/769ca/769ca0ab3f808dcbf3db6118a4f137568fca5cb0" alt="image"
|
||||
|
||||
You'll now get a popup to consent, this is everything that matterbridge has access to. For now it'll only use read all groups and read and write all groups to read and send messages.
|
||||
|
||||
data:image/s3,"s3://crabby-images/7ae88/7ae880ef78c766b0c55be49ed23d42bfb8939cc4" alt="image"
|
||||
|
||||
Afterwards you should see this window
|
||||
|
||||
data:image/s3,"s3://crabby-images/95848/958481b2340886f58d07f007b2eedfcffe073037" alt="image"
|
||||
|
||||
And matterbridge will continue to start-up
|
||||
|
||||
Matterbridge by default will write a sessionfile containing tokens to the directory where matterbridge is running. It'll be a file called `msteams_session.json`. This files contains the necessary credentials so that matterbridge can restart/renew without asking the device login again.
|
||||
|
||||
Be sure to keep this file secure!
|
||||
|
||||
You can choose another path/filename, by adding `SessionFile="yourfilename"` to the `[msteams.teams]` configuration.
|
Loading…
x
Reference in New Issue
Block a user