/prom2teams

prom2teams is an HTTP server built with Python that receives alert notifications from a previously configured Prometheus Alertmanager instance and forwards it to Microsoft Teams using defined connectors

Primary LanguagePythonApache License 2.0Apache-2.0

Logo

Build Status Docker Build Status Docker Automated build

prom2teams

Alert example

prom2teams is a Web server built with Python that receives alert notifications from a previously configured Prometheus Alertmanager instance and forwards it to Microsoft Teams using defined connectors.

Getting Started

Prerequisites

The application has been tested with Prometheus 2.2.1, Python 3.5.0 and pip 9.0.1.

Newer versions of Prometheus/Python/pip should work but could also present issues.

Installing

prom2teams is present on PyPI, so could be installed using pip3:

$ pip3 install prom2teams

Note: Works since v1.1.1

Usage

Important: Config path must be provided with at least one Microsoft Teams Connector. Check the options to know how you can supply it.

# To start the server (config file path , group alerts by, log file path, log level and Jinja2 template path are optional arguments):
$ prom2teams [--configpath <config file path>] [--groupalertsby ("name"|"description"|"instance"|"severity"|"summary")] [--logfilepath <log file path>] [--loglevel (DEBUG|INFO|WARNING|ERROR|CRITICAL)] [--templatepath <Jinja2 template file path>]

# To show the help message:
$ prom2teams --help

Other options to start the service are:

export APP_CONFIG_FILE=<config file path>
$ prom2teams

Note: Grouping alerts works since v2.2.1

Docker image

Every new Prom2teams release, a new Docker image is built in our Dockerhub. We strongly recommend you to use the images with the version tag, though it will be possible to use them without it.

There are two things you need to bear in mind when creating a Prom2teams container:

  • The connector URL must be passed as the environment variable PROM2TEAMS_CONNECTOR
  • In case you want to group alerts, you need to pass the field as the environment variable PROM2TEAMS_GROUP_ALERTS_BY
  • You need to map container's Prom2teams port to one on your host.

So a sample Docker run command would be:

$ docker run -it -d -e PROM2TEAMS_GROUP_ALERTS_BY=FIELD_YOU_WANT_TO_GROUP_BY -e PROM2TEAMS_CONNECTOR="CONNECTOR_URL" -p 8089:8089 idealista/prom2teams:VERSION

Provide custom config file

If you prefer to use your own config file, you just need to provide it as a Docker volume to the container and map it to /opt/prom2teams/config.ini. Sample:

$ docker run -it -d -v pathToTheLocalConfigFile:/opt/prom2teams/config.ini -p 8089:8089 idealista/prom2teams:VERSION

Production

For production environments you should prefer using a WSGI server. uWSGI dependency is installed for an easy usage. Some considerations must be taken to use it:

The binary prom2teams_uwsgi launches the app using the uwsgi server. Due to some incompatibilities with wheel you must install prom2teams using sudo pip install --no-binary :all: prom2teams (pypa/wheel#92)

$ prom2teams_uwsgi <path to uwsgi ini config>

And uwsgi would look like:

[uwsgi]
master = true
processes = 5
#socket = 0.0.0.0:8001
#protocol = http
socket = /tmp/prom2teams.sock
chmod-socket = 777
vacuum = true
env = APP_ENVIRONMENT=pro
env = APP_CONFIG_FILE=/etc/default/prom2teams.ini

Consider not provide chdir property neither module property.

Also you can set the module file, by doing a symbolic link: sudo mkdir -p /usr/local/etc/prom2teams/ && sudo ln -sf /usr/local/lib/python3.5/dist-packages/usr/local/etc/prom2teams/wsgi.py /usr/local/etc/prom2teams/wsgi.py (check your dist-packages folder)

Another approach is to provide yourself the module file module example and the bin uwsgi call uwsgi example

Note: default log level is DEBUG. Messages are redirected to stdout. To enable file log, set the env APP_ENVIRONMENT=(pro|pre)

Config file

The config file is an INI file and should have the structure described below:

[Microsoft Teams]
# At least one connector is required here
Connector: <webhook url>
AnotherConnector: <webhook url>   
...

[HTTP Server]
Host: <host ip> # default: localhost
Port: <host port> # default: 8089

[Log]
Level: <loglevel (DEBUG|INFO|WARNING|ERROR|CRITICAL)> # default: DEBUG
Path: <log file path>  # default: /var/log/prom2teams/prom2teams.log

[Template]
Path: <Jinja2 template path> # default: app resources template

[Group Alerts]
Field: <Field to group alerts by> # alerts won't be grouped by default

Note: Grouping alerts works since v2.2.0

Configuring Prometheus

The webhook receiver in Prometheus allows configuring a prom2teams server.

The url is formed by the host and port defined in the previous step.

Note: In order to keep compatibility with previous versions, v2.0 keep attending the default connector ("Connector") in the endpoint 0.0.0.0:8089. This will be removed in future versions.

// The prom2teams endpoint to send HTTP POST requests to.
url: 0.0.0.0:8089/v2/<Connector1>

Templating

prom2teams provides a default template built with Jinja2 to render messages in Microsoft Teams. This template could be overrided using the 'templatepath' argument ('--templatepath ') during the application start.

Some fields are considered mandatory when received from Alert Manager. If such a field is not included a default value of 'unknown' is assigned.

Other optional fields are skipped and not included in the Teams message.

Swagger UI

Accessing to <Host>:<Port> (e.g. localhost:8089) in a web browser shows the API v1 documentation.

Swagger UI

Accessing to <Host>:<Port>/v2 (e.g. localhost:8089/v2) in a web browser shows the API v2 documentation.

Swagger UI

Testing

To run the test suite you should type the following:

// After cloning prom2teams :)
$ python3 -m unittest discover tests

Built With

Python 3.6.2 pip 9.0.1

Versioning

For the versions available, see the tags on this repository.

Additionaly you can see what change in each version in the CHANGELOG.md file.

Authors

See also the list of contributors who participated in this project.

License

Apache 2.0 License

This project is licensed under the Apache 2.0 license - see the LICENSE file for details.

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.