Skip to main content

Utility for django-statusboard to notify status changes

Project description

statusboard-notify

Build Pypi codecov

Utility for django-statusboard that notifies users about service status changes. The notification are sent via email or published in a Telegram channel.

This app periodically notifies about service status changes - except for changes from "Operational" to "Performance issues" (and viceversa).

screenshot of a Telegram channel

Note the notification script attempts to send the message only once for each backend.

Installation

Install the package:

pip install django-statusboard-notify[with_telegram]

If you don't need Telegram notifications, you can install the package without the with_telegram extra.

Configure the application

Add the following applications to your Django projects:

# settings.py
INSTALLED_APPS += [
    'statusboard',
    'statusboard-notify',
]

Email notification

In order to enable the email notifications, you have to set the sender:

# settings.py
STATUSBOARD_NOTIFY_EMAIL_SENDER = "statusboard@localhost.localdomain

You can edit the subject:

# settings.py
STATUSBOARD_NOTIFY_EMAIL_SUBJECT = "Mysubject"

You can add a list of recipients that will receive the notifications about all the services:

# settings.py
STATUSBOARD_NOTIFY_EMAIL_RECIPIENTS = [
    "admin@localhost.localdomain",
    "anotheradmin@localhost.localdomain",
]

From the admin page you can associate an existing user to one or more services:

screenshot of the admin page

The email is sent in two formats: plain text and html. The email is created using the template statusboard_notify/templates/statusboard_notify/email.html and then is converted using pypandoc to create the plain text version.

It's possibile to customize the footer of the email: create the file templates/statusboard_notify/email.html that extends the original template:

{% extends "statusboard_notify/email.html" %}
{% block footer %}
    <footer class="footer">
        For more informations please visit <a href="https://localhost.localdomain/status">the statuspage</a>
    </footer>
{% endblock %}

Telegram notification

In order to enable the Telegram notifications, you have to:

  1. Create a bot with BotFather.
  2. Create a channel.
  3. Make your bot an admin of your channel.
  4. Go to https://web.telegram.org and open the channel: the URL is something like https://web.telegram.org/#/im?p=c1234567890_1231231231231231231. The channel id is the concatenation of -100 and the numbers between c and _ (in the example, 1234567890, then the chat id is -1001234567890).

Then add the following variables to your settings.py.

# settings.py
STATUSBOARD_NOTIFY_TELEGRAM_TOKEN = "TELEGRAM-TOKEN-FROM-BOTFATHER"
STATUSBOARD_NOTIFY_TELEGRAM_CHAT_ID = -1001234567890

Configure the notification script

The notifications are fired by command send_notifications, that reads the notification queue from the DB and sends the services status changes to the recipients (the notifications are then removed).

You can activate the command using crontab, systemd, celery, etc. Below, an example with crontab:

# Check every 10 minutes for service status changes
*/10 * * * * /path/to/django/project/manage.py send_notifications

Contact and copyright information

Copyright (C) 2021 Emanuele Di Giacomo emanuele@digiacomo.cc

django-statusboard-notify is licensed under GPLv2+.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-statusboard-notify-0.7.0.tar.gz (15.7 kB view details)

Uploaded Source

Built Distribution

django_statusboard_notify-0.7.0-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file django-statusboard-notify-0.7.0.tar.gz.

File metadata

File hashes

Hashes for django-statusboard-notify-0.7.0.tar.gz
Algorithm Hash digest
SHA256 4bdb152baa51c00a5c46e84a972091317e235f90f1f59aea54d2cdfafe4ffc34
MD5 b57fb720e79d26e67c34165c008fd839
BLAKE2b-256 2bb01e9d88365c68681ac87138b79d355fa92b5a3becea12606d7ef20ae12732

See more details on using hashes here.

File details

Details for the file django_statusboard_notify-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_statusboard_notify-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 73953b62a79c6c056c15dcdc6f6129c8081564eeaf5aa265b29aa5ffd0e3b451
MD5 9d797237413a3998171e442c348c04a1
BLAKE2b-256 27ccd557ef63d5acc477b757c254c2a2278e4cc61a5c701277878bcdde1c2683

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page