redash
redash copied to clipboard
Microsoft Teams Webhook alert destination
What type of PR is this? (check all applicable)
- [x] New Alert Destination
Description
Create a new alert destination for Microsoft Teams Webhooks
Related Tickets & Documents
https://discuss.redash.io/t/microsoft-teams-integration/852
Mobile & Desktop Screenshots/Recordings (if there are UI changes)
data:image/s3,"s3://crabby-images/0909d/0909dbcde3a93e8a9584aad4acf8b99d1d4b94f7" alt="Screen Shot 2022-01-21 at 3 31 15 PM"
data:image/s3,"s3://crabby-images/23be4/23be47e70905d6534e59775cc2162b793242402e" alt="Screen Shot 2022-01-21 at 3 33 26 PM"
data:image/s3,"s3://crabby-images/865dc/865dc40d59f4588ebc497c9ba70dc0173f1cdf41" alt="Screen Shot 2022-01-21 at 3 33 35 PM"
Working on text formatting and icons.
Planning to use this icon.
data:image/s3,"s3://crabby-images/3c674/3c6740a80812e0a172fe86fde9571dbb2fff0d9a" alt="Screen Shot 2022-01-21 at 4 16 49 PM"
data:image/s3,"s3://crabby-images/61bca/61bca5d1f50ec8d88e6d518e6b727130bbd6c19c" alt="Screen Shot 2022-01-21 at 4 16 58 PM"
data:image/s3,"s3://crabby-images/57543/57543823dd9ef0e382f2db86a31d5f7383f7c2e6" alt="Screen Shot 2022-01-21 at 4 18 27 PM"
data:image/s3,"s3://crabby-images/2a029/2a0292f8ccae6ed3307d2244adce4f661ac36819" alt="Screen Shot 2022-01-21 at 4 22 29 PM"
MS Alert Webhook documentation here: https://docs.microsoft.com/en-us/outlook/actionable-messages/message-card-reference
@arikfr , one thing I noticed during testing is that a trigger is fired when the criteria is met and when the criteria is reset. Is that correct (I see it here now https://redash.io/help/user-guide/alerts/setting-up-an-alert#Alert-Statuses)? Is that info in the new_state argument (new_state seems the three options here: https://github.com/getredash/redash/blob/master/redash/models/init.py#L970)?
I noticed during testing is that a trigger is fired when the criteria is met and when the criteria is reset. Is that correct?
Yes.
Is that info in the new_state argument (new_state seems the three options here:
Yes. Related docs:
UNKNOWN means Redash does not have enough data to evaluate the alert criteria. You will see this status immediately after creating your Alert until the query has executed. You will also see this status if there was no data in the query result or if the most recent query result doesn’t include the Value Column you configured.
If for some reason this doesn't make it into the next release, could the patch from #5726 ship tactically (it's super tiny), and then reverted in this PR?
Any update about this work? There's an official way to implement this MS Teams in the current release (such as a plugin)?
This will be included in the next release later this summer.
Yes, alert destinations are pluggable just like query runners 👌 This one should be compatible with any installation of Redash V10.
This will be included in the next release later this summer.
Yes, alert destinations are pluggable just like query runners 👌 This one should be compatible with any installation of Redash V10.
how can I add it to my current instance so? Do we have a tutorial for that?
how can I add it to my current instance so? Do we have a tutorial for that?
We don't but working on publishing a doc with a strategy for this. There are a few different approaches. Probably the easiest is to copy the file into your local copy of the source code and then issue a COPY
command in the Dockerfile that places it into your containers.
In case anyone wants to bring this into their existing install, your Dockerfile should look something like this. (double check the base image)
FROM redash/redash:8.0.0.b32245
USER root
# upgrade to fix vulnerabilities and enable ldap
RUN apt update && apt install -y sudo linux-libc-dev
RUN pip install --upgrade pip && pip install --upgrade ldap3 Werkzeug==0.16.1
USER redash
COPY microsoft_teams_webhook.py /app/redash/destinations/microsoft_teams_webhook.py
COPY microsoft_teams_webhook.png /app/client/dist/images/destinations/microsoft_teams_webhook.png
Then set the environment variable
REDASH_ADDITIONAL_DESTINATIONS: redash.destinations.microsoft_teams_webhook
Thanks!