Skip to content

Latest commit

 

History

History
356 lines (310 loc) · 16 KB

README.md

File metadata and controls

356 lines (310 loc) · 16 KB

Telegram Grafana Report Bot

The repository contains the source code of the Bot that sends users Grafana graphics upon request in channels or private messages in Telegram.
The bot can interact with any number of handles from any number of Grafans.
All of them are added through the JSON configuration.

The repository also contains an example deployment for Docker-Compose.
Including two test graphics.

Disclaimer:

⚠️Using some or all of the elements of this code, You assume responsibility for any consequences!

⚠️The licenses for the technologies on which the code depends are subject to change by their authors.

Contents:

Dependencies:

Pre-deployment steps:

Deployment:

Interacting with the Bot:



Required:

The application code is written in python and obviously depends on it.
Python version 3.10 [Python Software Foundation License / (with) Zero-Clause BSD license]:

Required Packages:

aiohttp [Apache License version 2.0]:
Used to perform asynchronous requests.

pyTelegramBotAPI [GPL-2.0 license]:
Used to interact with the telegram api

Installing the Required Packages:

pip install aiohttp
pip install pyTelegramBotAPI

Pre-deployment steps

Telegram Bot registration:

To start the bot registration process, you must have a Telegram account.

  • Log in to Telegram in any way convenient for you and write to the @BotFather bot.
  • Write to the bot:
    /start
    
  • Next write him:
    /newbot
    
  • After that, write what your bot will be called. This name will be displayed as its name in the profile.
    Then you will need to write the unique bot ID, according to the instructions.
    As a result, you will receive a unique token for your bot. It will be needed for program configuration file.
    More details about its use can be found in paragraphs «Deploy-with-Docker-Compose»
    and «Run on Bare-Metal or Virtual Machine».

Telegram channel settings:

Create a channel in Telegram in any way convenient for you.

  • Add your bot to the channel and make him an administrator in it.
    Remove all unnecessary rights from him: the ability to write messages to the channel is enough.
  • Open Telegram Web-version
    Find your chanel and copy channel id in web url after #- symbols.
    As exemple #-0000000000.
    It will be needed for program configuration file.
  • More details about its use can be found in paragraphs «Deploy with Docker-Compose»
    and «Run on Bare-Metal or Virtual Machine».

Crate Grafana Technical User:

The creation process will be described for version 11.2.2. In other versions the interface may change.
But it most likely will not change in the future.

  • Open your Grafana web interface.
  • On the left side of the page, select Administration.
  • Select Users and access.
  • Next select Service accounts.
  • In the upper right part of the page, click "Add service account".
  • Enter a descriptive name under which you will be able to easily find this service account in the list of others.
    And select Viewer rights for him.
  • On the right side, in the token table, click "Add service account token".
  • Click "Generate token"
    Be sure to copy the token immediately after this.
    It will only be shown once.
    It will be needed for program configuration file.
    More details about its use can be found in paragraphs «Deploy with Docker-Compose»
    and «Run on Bare-Metal or Virtual Machine».

Add new handlers to Config file:

Since the complete filling of the configuration file depends on how you will deploy the application,
let's first look at how to add handlers for the Bot.
Config file location:
./📂Telegram_Grafana_Report_Bot
   └── 📄config.json
Example of handler in config.json file:

{
    "Grafana": [
        {
          "token": "${GRAFANA_TOKEN}",
          "url": "${GRAFANA_URL}",
          "handlers": {
            
            "e1": {
              "dashboard_uid": "ee0jj9k1l8zr4d",
              "kiosk_status": true,
              "time_zone": "Europe%2FMoscow",
              "panel": {
                "id": 1,
                "width": 560,
                "height": 480
              },
              "handle_description": "Example dashboard 01"
            },
            ...
            
          }
        },
      {...}
    ]
}
  • token - the value of this key is a token with which the bot can connect to Grafana.
    More details on how to get this token were written above, in paragraph «Crate Grafana Technical User».
    When to replace the default value is described in the «Deployment» paragraph.
    However, it is important to mention now that this value is unique for each Grafana you want to use.
  • url - it can be either an IP address or a DNS name, depending on your settings.
    When to replace the default value is described in the «Deployment» paragraph.
    Similar to the previous key, this value will be unique for each Grafana you want to use.
    Below is an example of an url link from where you can get this value for configuration if necessary.
  • Handlers - the value of this key is a nested dictionary that lists all handles settings.
    The embedded key is the handle itself that the user will need to call.
    In this example it is called "e1".
    Accordingly, it will be called in the chat with the bot by the command "/e1".
    You need to come up with this value yourself.
    • dashboard_uid - this is a unique identifier of the dashboard in Grafana.
      The name of the dashboard and graph, although mentioned in the URL, does not really matter and may not even be added.
      Only this parameter and the panel ID have matter.
      Below is an example of an url link where you can get this value from your graph.
    • kiosk_status - is responsible for whether to show the Grafana interface when rendering an image, or not.
      Value is a boolean constant.
    • time_zone - responsible for which time zone to generate graphs.
      You can choose any convenient standard time zone.
      Their list is in Grafana.
      To open it, click on the time settings for which to display graphs in the upper right corner.
      Click "Change time settings"
      Next click "Type to search..."
      Time zones are determined by the format Country/City.
      You need to swap "/" symbol to "%2F".
      You can also write IANA by analogy. As example Etc%2FUTC.
    • panel - the panel is the actual graph that is being drawn.
      Each dashboard can have multiple panels, each with its own number.
      The key value is a nested dictionary describing the panel.
      • id - is responsible for which graph to draw.
        Below is an example of an url link where you can get this value from your graph.
      • width - width of the generated image.
        You need to come up with this value yourself.
      • height - height of the generated image.
        You need to come up with this value yourself.
    • handle_description - a description of each will be generated in the welcome message
      and added to each picture in caption, for ease of searching through messages.
      You need to come up with this value yourself.

All the settings described above, except for the token, are responsible for the link that will return the image to us.
For simplicity, they are substituted in the example:

url:3000/render/d/dashboard_uid/dashboard_name?orgId=1&refresh=10s&from=time&to=time&viewPanel=id&width=with&height=height&tz=time_zone&kiosk_status

Please note that organization ID generation is not implemented.
Its value is hardcoded as 1.

Deployment

Deploy with Docker-Compose:

The repository contains a test example that will deploy with a sample of Grafana for an example of using the bot,
a Grafana render container, and 2 graphs.
However, you will have to customize one or more files.
Please note that the example creates a persistent Docker Volume grafana_persistent_storage.
And since you don't have a Grafana token for the technical user account to begin with,
you'll have to run the build twice, deleting the containers after the first one.

Files location:
./📂Telegram_Grafana_Report_Bot
   ├── 📁Docker
   │        ├── 📄.env
   │        └── 📄docker-compose.yml
   ├── 📁Source_code
   │        └── 📄entry_point.sh
   └── 📄config.json

First, you need to create a ".env"" file with environment variables to add to the "Docker" folder.
.env file example:

# .env
TELEGRAM_BOT_TOKEN=...
TELEGRAM_CHANNEL_ID=...,...
TELEGRAM_BOT_DM_WHITE_LIST=...,...
TELEGRAM_BOT_CHANNEL_WHITE_LIST=...,...,...

GRAFANA_TOKEN=...
GRAFANA_URL=http://example_grafana:3000
GRAFANA_RENDER_SERVER_URL=http://grafana_renderer:8081/render
GRAFANA_ADMIN_USER=...
GRAFANA_ADMIN_PASSWORD=...
  • TELEGRAM_BOT_DM_WHITE_LIST - List of names of trusted users in telegram, written separated by commas without spaces.
  • TELEGRAM_BOT_CHANNEL_WHITE_LIST - List of names of trusted users in telegram, written separated by commas without spaces.

In Telegram usernames start with the "@" symbol.
But you must specify the username without it.

  • TELEGRAM_BOT_TOKEN - the token we received by performing the steps in «Telegram Bot registration» paragraph.
  • TELEGRAM_CHANNEL_ID - list of channels where it is permissible to call the bot, written separated by commas without spaces.
    How to find out the channel name is described in «Telegram channel settings» paragraph.
  • GRAFANA_TOKEN - the token we received by performing the steps in «Crate Grafana Technical User» paragraph.
  • GRAFANA_URL - ip address or DNS name of yore Grafana instance.
  • GRAFANA_RENDER_SERVER_URL - ip address or DNS name of yore Grafana-Render instance.
  • GRAFANA_ADMIN_USER - name of Grafana root user.
  • GRAFANA_ADMIN_PASSWORD - Grafana root user password. Each instance of your Grafana or render servers needs its own environment variables.
    Additional instances will also need to be added in docker-compose.yaml and entry_point.sh.
    How to add new handles, including grafana instances, can be read in the «Add new handlers to Config file» paragraph.

If you do not want to use more than one Grafana, you just need to replace the data in the file with your own, according to the rules described above.
There is no point in describing the structure of these files listed at the beginning of the paragraph in more detail,
since you will literally need to make duplicates of these variables for new grafana instances, but under different names.

Example of using Docker variables in config.json file:

{
  "Telegram_Bot":
  {
    "token": "${TELEGRAM_BOT_TOKEN}",
    "dm_white_list": [
      "${TELEGRAM_BOT_DM_WHITE_LIST}"
    ],
    "channel_id": [
      "${TELEGRAM_CHANNEL_ID}"
    ],
    "channel_white_list": [
      "${TELEGRAM_BOT_CHANNEL_WHITE_LIST}"
    ],
    "block_forwarding_messages": true
  },

  "Grafana": [
    {
      "token": "${GRAFANA_TOKEN}",
      "url": "${GRAFANA_URL}",
      "handlers": {...}
    }
  ]
}

More details about the keys and values of the file can be found in the next paragraph «Run on Bare-Metal or Virtual Machine», with example values.

To run Docker-compos, open terminal and go to the Docker directory and enter the command.

docker-compose up -d

Run on Bare-Metal or Virtual Machine:

For normal launch primarily you will need to manually configure the config.json file.
Then you will need to launch the entry point to the program.

Files location:
./📂Telegram_Grafana_Report_Bot
   ├── 📁Source_code
   │        └── 📄Telegram_Grafana_Report_Bot.py
   └── 📄config.json

Example of config.json file:

{
  "Telegram_Bot":
  {
    "token": "0000000000:aAaAaAaaAaAaAaAaAaAaaaAAAaAaAaAAaaAa",
    "dm_white_list": [
      "dm_user",
      "dm_user2"
    ],
    "channel_id": [
      "0000000000",
      "0000000000"
    ],
    "channel_white_list": [
      "dm_user",
      "channel_user"
    ],
    "block_forwarding_messages": true
  },

  "Grafana": [
    
    {
      "token": "glsa_A0A0aA0aAaA0A0aA0aAaA0A0aA0aA_00ffAaaa",
      "url": "http://example_grafana:3000",
      "handlers": {...}
    }
    
  ]
}
  • Telegram_Bot:
    • token - the token we received by performing the steps in «Telegram Bot registration» paragraph.
    • dm_white_list - usernames who can write private messages to the bot.
      In Telegram usernames start with the "@" symbol.
      But you must specify the username without it.
    • channel_id - List of channels where it is permissible to call the bot. How to find out the channel name is described in «Telegram channel settings» paragraph.
    • channel_white_list - list of usernames that are allowed to call the bot in channels.
    • block_forwarding_messages - prevents forwarding bot messages if true.
  • Grafana - list of nested dictionaries describing Grafana with which the bot can interact.
    • token - the token we received by performing the steps in «Crate Grafana Technical User».
    • url - ip address or DNS name of yore Grafana instance.
    • handlers - nested dictionary describing all the handlers that the bot can work with.
      Details on how to configure them are written in Add new handlers to Config file paragraph.

Run Telegram_Grafana_Report_Bot.py with command:

python -B Telegram_Grafana_Report_Bot.py

How to call the Bot:

Go to the channel where your bot is located, or start a private message conversation with it.
Use one of the commands:

  • /star - generate welcome message with all handles description.
  • /help - will do the same.
  • /all - get all graphs images from all Grafans related to the handles you added.
  • Graph handler - es example /e1 in example Docker-compose.

♥️ Thank you for your interest in my work! ♥️