2020-11-25 15:47:41 +01:00
# notify-by-telegram
2020-11-26 08:28:40 +01:00
Send Nagios notifications to a [Telegram Messenger ](https://telegram.org/ ) channel.
2020-11-25 17:13:16 +01:00
## Telegram bot
2020-11-26 08:28:40 +01:00
This [tutorial ](https://takersplace.de/2019/12/19/telegram-notifications-with-nagios/ ) explains how to create a Telegram bot. You'll need the `chat_id` and `auth_key` for the next section.
2020-11-25 17:13:16 +01:00
## Installation
_This guide has been written for [Debian ](https://www.debian.org/ ). Some commands might slightly change depending on your distribution._
Clone the repository:
```
2020-11-26 08:28:40 +01:00
git clone https://github.com/jouir/notify-by-telegram.git /opt/notify-by-telegram
2020-11-25 17:13:16 +01:00
```
Install dependencies using the package manager:
```
2020-11-26 14:48:46 +01:00
sudo apt install python3-jinja2 python3-requests python3-jsonschema
2020-11-25 17:13:16 +01:00
```
## Configuration
Copy and update the configuration file example:
```
2020-11-26 14:48:46 +01:00
cp -p config.example.json telegram.json
2020-11-26 08:28:40 +01:00
vim telegram.json
sudo mv telegram.json /etc/nagios4/telegram.json
2020-11-26 13:02:08 +01:00
sudo chown root:nagios /etc/nagios4/telegram.json
sudo chmod 640 /etc/nagios4/telegram.json
2020-11-25 17:13:16 +01:00
```
Ensure Nagios reads the configuration file:
```
2020-11-26 08:28:40 +01:00
echo "cfg_file=/opt/notify-by-telegram/nagios.cfg" >> /etc/nagios4/nagios.cfg
2020-11-25 17:13:16 +01:00
```
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.
2020-11-26 12:57:32 +01:00
## Message format
`notify-by-telegram` script uses the `MarkdownV2` format to generate Telegram messages.
[Jinja ](https://jinja.palletsprojects.com ) 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 ](templates ) directory.
They can be overriden in the configuration file:
```json
{
"host_template": "/etc/nagios4/host.md.j2",
"service_template": "/etc/nagios4/service.md.j2"
}
```
Both options are optional.