Skip to main content
Version: v1.4.0

Microsoft Teams

This guide will show you how to enable Microsoft Teams notifications via the HTTP plugin.

Enabling the plugin:#

In your profile file (by default /etc/crowdsec/profiles.yaml) , uncomment the section

#notifications:# - http_default

Configuring the plugin:#

By default there would be a http config at /etc/crowdsec/notifications/http.yaml. Simply replace the whole content in this file with this example below.

Example config:

# Don't change thistype: http
name: http_default # this must match with the registered plugin in the profilelog_level: debug # Options include: trace, debug, info, warn, error, off
format: |  {    "type": "message",    "attachments": [      {        "contentType": "application/vnd.microsoft.card.adaptive",        "content": {          "$schema": "https://adaptivecards.io/schemas/adaptive-card.json",          "type": "AdaptiveCard",          "version": "1.2",          {{- range . -}}          {{- $decisions_len := len .Decisions -}}          {{- range $index, $element := .Decisions -}}          "body": [            {              "type": "TextBlock",              "text": "[Info] CrowdSec",              "wrap": true,              "size": "large",              "weight": "bolder",              "fontType": "Default"            },            {              "type": "FactSet",              "facts": [                {                  "title": "IP:",                  "value": "{{$element.Value}}"                },                {                  "title": "Duration:",                  "value": "{{$element.Duration}}"                },                {                  "title": "Reason:",                  "value": "{{$element.Scenario}}"                },                {                  "title": "Origin:",                  "value": "{{$element.Origin}}"                },                {                  "title": "Simulation:",                  "value": "{{$element.Simulated}}"                }              ]            },            {              "type": "RichTextBlock",              "inlines": [                {                  "type": "TextRun",                  "text": "\"{{ $element.Value }}\" got a ban for {{ $element.Duration }}."                }              ]            },            {              "type": "ActionSet",              "actions": [                {                  "type": "Action.OpenUrl",                  "title": "Whois",                  "url": "https://www.whois.com/whois/{{ $element.Value }}",                  "style": "positive"                },                {                  "type": "Action.OpenUrl",                  "title": "Shodan",                  "url": "https://www.shodan.io/host/{{ $element.Value }}",                  "style": "positive"                },                {                  "type": "Action.OpenUrl",                  "title": "AbuseIPDB",                  "url": "https://www.abuseipdb.com/check/{{ $element.Value }}",                  "style": "positive"                }              ]            },            {            "type": "ActionSet",            "actions": [                {                    "type": "Action.OpenUrl",                    "title": "Unban IP in CAPI",                    "url": "https://crowdsec.net/unban-my-ip/",                    "style": "positive"                }            ],            }            {{- if lt $index (sub $decisions_len 1) -}}            ,            {{- end -}}            {{- end -}}          {{- end -}}          ]        }      }    ]  }
# CrowdSec-Channelurl: https://mycompany.webhook.office.com/webhookb2/{TOKEN}
# Test netcat#url: "http://127.0.0.1:5555"
method: POST # eg either of "POST", "GET", "PUT" and other http verbs is valid value. 
headers:  Content-Type: application/json#   Authorization: token 0x64312313# skip_tls_verification:  # either true or false. Default is false# group_wait: # duration to wait collecting alerts before sending to this plugin, eg "30s"# group_threshold: # if alerts exceed this, then the plugin will be sent the message. eg "10"# max_retry: # number of tries to attempt to send message to plugins in case of error.# timeout: # duration to wait for response from plugin before considering this attempt a failure. eg "10s"

Note

  • Don't forget to replace the webhook with your own webhook
  • See microsoft docs for instructions to obtain a webhook.
  • The format is a go template, which is fed a list of Alert objects.

Final Steps:#

Let's restart crowdsec

sudo systemctl restart crowdsec

You can verify whether the plugin is properly working by triggering scenarios using tools like wapiti, nikto etc.