mirror of
https://github.com/coder/coder.git
synced 2025-07-12 00:14:10 +00:00
docs: enable Microsoft Teams Notifications (#14781)
This commit is contained in:
160
docs/admin/notifications/teams.md
Normal file
160
docs/admin/notifications/teams.md
Normal file
@ -0,0 +1,160 @@
|
|||||||
|
# Microsoft Teams Notifications
|
||||||
|
|
||||||
|
[Microsoft Teams](https://www.microsoft.com/en-us/microsoft-teams) is a widely
|
||||||
|
used collaboration platform, and with Coder's integration, you can enable
|
||||||
|
automated notifications directly within Teams using workflows and
|
||||||
|
[Adaptive Cards](https://adaptivecards.io/)
|
||||||
|
|
||||||
|
Administrators can configure Coder to send notifications via an incoming webhook
|
||||||
|
endpoint. These notifications appear as messages in Teams chats, either with the
|
||||||
|
Flow Bot or a specified user/service account.
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
Before setting up Microsoft Teams notifications, ensure that you have the
|
||||||
|
following:
|
||||||
|
|
||||||
|
- Administrator access to the Teams platform
|
||||||
|
- Coder platform with notifications enabled
|
||||||
|
|
||||||
|
## Build Teams Workflow
|
||||||
|
|
||||||
|
The process of setting up a Teams workflow consists of three key steps:
|
||||||
|
|
||||||
|
1. Configure the Webhook Trigger.
|
||||||
|
|
||||||
|
Begin by configuring the trigger: **"When a Teams webhook request is
|
||||||
|
received"**.
|
||||||
|
|
||||||
|
Ensure the trigger access level is set to **"Anyone"**.
|
||||||
|
|
||||||
|
2. Setup the JSON Parsing Action.
|
||||||
|
|
||||||
|
Next, add the **"Parse JSON"** action, linking the content to the **"Body"**
|
||||||
|
of the received webhook request. Use the following schema to parse the
|
||||||
|
notification payload:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"_version": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"payload": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"_version": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"user_email": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"actions": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"label": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"url": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": ["label", "url"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"title": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"body": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
This action parses the notification's title, body, and the recipient's email
|
||||||
|
address.
|
||||||
|
|
||||||
|
3. Configure the Adaptive Card Action.
|
||||||
|
|
||||||
|
Finally, set up the **"Post Adaptive Card in a chat or channel"** action
|
||||||
|
with the following recommended settings:
|
||||||
|
|
||||||
|
**Post as**: Flow Bot
|
||||||
|
|
||||||
|
**Post in**: Chat with Flow Bot
|
||||||
|
|
||||||
|
**Recipient**: `user_email`
|
||||||
|
|
||||||
|
Use the following _Adaptive Card_ template:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"$schema": "https://adaptivecards.io/schemas/adaptive-card.json",
|
||||||
|
"type": "AdaptiveCard",
|
||||||
|
"version": "1.0",
|
||||||
|
"body": [
|
||||||
|
{
|
||||||
|
"type": "Image",
|
||||||
|
"url": "https://coder.com/coder-logo-horizontal.png",
|
||||||
|
"height": "40px",
|
||||||
|
"altText": "Coder",
|
||||||
|
"horizontalAlignment": "center"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "TextBlock",
|
||||||
|
"text": "**@{replace(body('Parse_JSON')?['title'], '"', '\"')}**"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "TextBlock",
|
||||||
|
"text": "@{replace(body('Parse_JSON')?['body'], '"', '\"')}",
|
||||||
|
"wrap": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "ActionSet",
|
||||||
|
"actions": [@{replace(replace(join(body('Parse_JSON')?['payload']?['actions'], ','), '{', '{"type": "Action.OpenUrl",'), '"label"', '"title"')}]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
_Notice_: The Coder `actions` format differs from the `ActionSet` schema, so
|
||||||
|
its properties need to be modified: include `Action.OpenUrl` type, rename
|
||||||
|
`label` to `title`. Unfortunately, there is no straightforward solution for
|
||||||
|
`for-each` pattern.
|
||||||
|
|
||||||
|
Feel free to customize the payload to modify the logo, notification title,
|
||||||
|
or body content to suit your needs.
|
||||||
|
|
||||||
|
## Enable Webhook Integration
|
||||||
|
|
||||||
|
To enable webhook integration in Coder, ensure the "notifications" experiment is
|
||||||
|
activated by running the following command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
export CODER_EXPERIMENTS=notifications
|
||||||
|
```
|
||||||
|
|
||||||
|
Then, define the POST webhook endpoint created by your Teams workflow:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
export CODER_NOTIFICATIONS_WEBHOOK_ENDPOINT=https://prod-16.eastus.logic.azure.com:443/workflows/f8fbe3e8211e4b638...`
|
||||||
|
```
|
||||||
|
|
||||||
|
Finally, go to the **Notification Settings** in Coder and switch the notifier to
|
||||||
|
**Webhook**.
|
||||||
|
|
||||||
|
## Limitations
|
||||||
|
|
||||||
|
1. **Public Webhook Trigger**: The Teams webhook trigger must be open to the
|
||||||
|
public (**"Anyone"** can send the payload). It's recommended to keep the
|
||||||
|
endpoint secret and apply additional authorization layers to protect against
|
||||||
|
unauthorized access.
|
||||||
|
|
||||||
|
2. **Markdown Support in Adaptive Cards**: Note that Adaptive Cards support a
|
||||||
|
[limited set of Markdown tags](https://learn.microsoft.com/en-us/microsoftteams/platform/task-modules-and-cards/cards/cards-format?tabs=adaptive-md%2Cdesktop%2Cconnector-html).
|
@ -516,7 +516,14 @@
|
|||||||
"title": "Notifications",
|
"title": "Notifications",
|
||||||
"description": "Learn how to configure notifications",
|
"description": "Learn how to configure notifications",
|
||||||
"path": "./admin/notifications.md",
|
"path": "./admin/notifications.md",
|
||||||
"icon_path": "./images/icons/info.svg"
|
"icon_path": "./images/icons/info.svg",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"title": "Microsoft Teams Notifications",
|
||||||
|
"description": "Learn how to setup Microsoft Teams notifications",
|
||||||
|
"path": "./admin/notifications/teams.md"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
Reference in New Issue
Block a user