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.
The application has been tested with Prometheus 1.7.1, Python 3.5.0 and pip 9.0.1.
Newer versions of Prometheus/Python/pip should work but could also present issues.
prom2teams is present on PyPI, so could be installed using pip3:
$ pip3 install prom2teams
Note: Only works since v1.1.1
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 , log file path, log level and Jinja2 template path are optional arguments):
$ prom2teams [--configpath <config file path>] [--logfilepath <log file path>] [--loglevel (DEBUG|INFO|WARNING|ERROR|CRITICAL)] [--templatepath <Jinja2 template file path>]
# To show the help message:
$ prom2teams --help
Another options to start the service are:
export APP_CONFIG_FILE=<config file path>
$ prom2teams
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
- 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_CONNECTOR="CONNECTOR_URL" -p 8089:8089 idealista/prom2teams:VERSION
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)
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
Name: <host name> # default: localhost: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
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>
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 as described below:
Other optional fields are skipped and not included in the Teams message.
Accessing to <Host>:<Port>
(e.g. localhost:8001
) in a web browser shows the API v1 documentation.
Accessing to <Host>:<Port>/v2
(e.g. localhost:8001/v2
) in a web browser shows the API v2 documentation.
To run the test suite you should type the following:
// After cloning prom2teams :)
$ python3 -m unittest discover tests
For the versions available, see the tags on this repository.
Additionaly you can see what change in each version in the CHANGELOG.md file.
- Idealista - Work with - idealista
See also the list of contributors who participated in this project.
This project is licensed under the Apache 2.0 license - see the LICENSE file for details.
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.