notify-by-telegram/README.md
2020-11-26 13:01:19 +01:00

1.8 KiB

notify-by-telegram

Send Nagios notifications to a Telegram Messenger channel.

Telegram bot

This tutorial explains how to create a Telegram bot. You'll need the chat_id and auth_key for the next section.

Installation

This guide has been written for Debian. Some commands might slightly change depending on your distribution.

Clone the repository:

git clone https://github.com/jouir/notify-by-telegram.git /opt/notify-by-telegram

Install dependencies using the package manager:

sudo apt install python3-jinja2 python3-requests

Configuration

Copy and update the configuration file example:

cp -p config.json.example telegram.json
vim telegram.json
sudo mv telegram.json /etc/nagios4/telegram.json
sudo chmod 640 root:nagios /etc/nagios4/telegram.json

Ensure Nagios reads the configuration file:

echo "cfg_file=/opt/notify-by-telegram/nagios.cfg" >> /etc/nagios4/nagios.cfg

Then reload service:

systemctl reload nagios4

Logs

Errors logs can be set with the --logfile argument.

Example:

tail -f /var/log/nagios4/telegram.log

Log level can be raised using --verbose or even more with --debug arguments.

Message format

notify-by-telegram script uses the MarkdownV2 format to generate Telegram messages.

Jinja is used for templating (eg. replace {{host_name}} placeholders by the value submitted by Nagios).

Default host and service templates can be found in the templates directory.

They can be overriden in the configuration file:

{
  "host_template": "/etc/nagios4/host.md.j2",
  "service_template": "/etc/nagios4/service.md.j2"
}

Both options are optional.