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.