Skip to content

πŸ“¬ CLI app, gRPC/HTTP server and a tiny library to send notifications via the Telegram

License

Notifications You must be signed in to change notification settings

kukymbr/tgnotifier

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

image with a gopher on a telegram plane

tgnotifier

License Release GoDoc GoReport

The tgnotifier is a tool to send a notification messages via the Telegram API.

Okay, but why?

The main feature of the tgnotifier is in the configuration, you could define bots and chats once and just send the messages, just like this:

tgnotifier send --text="😎 my cool message"

or like this:

tgnotifier send --text="πŸ¦– my the most coolest message" --bot="cool_messages_bot" --chat="chat_for_cool_messages"

One of the cases when you may want to use tgnotifier is an alerting from the CI/CD or some other services via the single entrypoint without exposing the bot credentials in every service or configuration. The gRPC and HTTP servers are also presented in the tgnotifier to have it running as a service.

Installation

To install the latest release of the tgnotifier, download the binary for your OS and put it somewhere inside the PATH.

Installation on Ubuntu/macOS example:

wget https://github.com/kukymbr/tgnotifier/releases/download/v1.0.1/tgnotifier_v1.0.1_ubuntu-latest
chmod a+x tgnotifier_v1.0.1_ubuntu-latest 
mv tgnotifier_v1.0.1_ubuntu-latest /usr/local/bin/tgnotifier
tgnotifier --version
Compile from sources

To install tgnotifier from the source, use the go install command:

go install github.com/kukymbr/tgnotifier/cmd/tgnotifier@v1.0.1
Custom build without some components

There is a possibility to compile a custom build of the tgnotifier. Golang 1.24 and above is required.

Available since v0.7.1.

# Clone the repository:
git clone https://github.com/kukymbr/tgnotifier.git && cd tgnotifier

# Checkout tag you want to compile:
git checkout v1.0.1

# To build the tgnotifier with all components:
make build

# To build the tgnotifier without the gRPC server:
make build_without_gprc

# To build the tgnotifier without the HTTP server:
make build_without_http

# To build the tgnotifier without the gRPC and HTTP server both:
make build_without_servers
Docker configuration

Docker image: ghcr.io/kukymbr/tgnotifier:1.0.1.

Docker usage examples

Sending message without a configuration file:

docker run --env TGNOTIFIER_DEFAULT_BOT=bot12345:bot_token --env TGNOTIFIER_DEFAULT_CHAT=-12345 --rm ghcr.io/kukymbr/tgnotifier:1.0.1 send --text="what's up?"

Sending message with a configuration file:

docker run --volume /path/to/.tgnotifier.yml:/tgnotifier/.tgnotifier.yml --rm ghcr.io/kukymbr/tgnotifier:1.0.1 send --text="what's up?"

Starting a gRPC server:

docker run --volume /path/to/.tgnotifier.yml:/tgnotifier/.tgnotifier.yml --rm ghcr.io/kukymbr/tgnotifier:1.0.1 grpc

Using as a docker compose service:

services:
  tgnotifier:
    image: ghcr.io/kukymbr/tgnotifier:1.0.1
    volumes:
      - /path/to/.tgnotifier.yml:/tgnotifier/.tgnotifier.yml
    ports:
      - "127.0.0.1:8080:8080"
    command: ["grpc"]

See the docker directory for a full docker compose usage example.

Configuration

The tgnotifier could have a configuration file to use multiple bots and chats. See the .tgnotifier.example.yml for an available values.

Use one of these ways to define a tgnotifier configuration:

  • Create a file named .tgnotifier.yml in the user's home or config dir, or near the tgnotifier executable file, tgnotifier will use it if no explicit config file passed as argument:
    nano "$HOME/.config/.tgnotifier.yml" # Define a config values...
    tgnotifer --text="🀠" 
  • Or create an YAML of JSON file in any location you want and give its path to the tgnotifier:
    tgnotifier --config="/path/to/config.yml" --text="πŸŽ‰"
  • Or create a configuration file and set its path to the TGNOTIFIER_CONFIG_PATH environment variable:
    export TGNOTIFIER_CONFIG_PATH=/path/to/config.yml 
    tgnotifier --text="⭐"
  • Or use a minimal configuration mode (just single bot and chat) using the environment variables:
    export TGNOTIFIER_DEFAULT_BOT="bot12345:bot-token"
    export TGNOTIFIER_DEFAULT_CHAT="-12345"
    
    tgnotifer --text="πŸ”₯" 

Configuration values

Put variables below to your configuration file to make tgnnotifier run in your way. Examples are provided in YAML format, but JSON files are supported too.

Defining the bots, who can send messages via the tgnotifier:

bots:
  first_bot: "12345:FIRST_BOT_TOKEN"
  second_bot: "bot54321:SECOND_BOT_TOKEN"

Defining the chat IDs, where tgnotifier can send messages to:

chats:
  main_chat: "-12345"
  secondary_chat: "@my_test_channel"

To use a program without a bot or a chat argument, define a default_bot and default_chat values in the config file:

default_bot: "first_bot"
default_chat: "main_chat"

Defining the schedule when messages are sent without a sound notification:

silence_schedule:
  - from: 22:00
    to: 9:00

Defining substrings to replace in the message texts:

replaces:
  "@test": "[Test](tg://user?id=123456789)"
  "FYI": "for your information"
  "{{ failed }}": "Pipeline job has failed" 
Some other configuration options
# Telegram API client configuration.
client:
  # Telegram API requests timeout.
  timeout: 30s

# Failed requests (500 responses, timeouts, protocol errors) retrier options.
retrier:
  # Type of the retrier.
  # Available:
  #  - noop: just single attempt, no retries;
  #  - linear: fixed retry delay, `attempts` and `delay` fields are used;
  #  - progressive: increasing retry delay, `attempts`, `delay` and `multiplier` fields are used.
  type: progressive
  # Maximum count of attempts.
  attempts: 3
  # Delay between an attempts, or initial delay in case of a progressive retrier.
  delay: 500ms
  # Delay multiplier for a progressive retrier.
  multiplier: 2

To run tgnotifier without a config file at all, define the env vars with default bot credentials and chat ID:

export TGNOTIFIER_DEFAULT_BOT="bot12345:bot-token"
export TGNOTIFIER_DEFAULT_CHAT="-12345"
Where can I get a bot identifier and chat ID?
  1. See the Telegram Bot API tutorial to find out how to obtain a bot token.
  2. Getting the chat ID is little more tricky, you need to add bot to a required chat, send there a message and request the getUpdates Telegram API endpoint:
    • use curl or browser to request this data, see this doc for an example;
    • or use tgnotifierui GUI, see its doc for more info: docs/gui.md.

CLI tool usage

Usage:
  tgnotifier send [flags]

Flags:
      --bot string                      Bot name to send message from (defined in config); if not set, the default_bot directive or the bot from the TGNOTIFIER_DEFAULT_BOT env var will be used
      --chat string                     Chat name to send message to (defined in config); if not set, the default_chat directive or the chat ID from the TGNOTIFIER_DEFAULT_CHAT env var will be used
      --config string                   Path to a config file
      --debug                           Enable the debug mode
      --disable-notification            Disable message sound notification
  -h, --help                            help for send
      --parse-mode message parse mode   Parse mode (MarkdownV2|HTML)
      --protect-content                 Protect message content from copying and forwarding
      --text string                     Message text
  -v, --version                         version for send

Command execution examples

Send a "Hello, World!" message from the default bot to the default chat, defined by the environment variables:

export TGNOTIFIER_DEFAULT_BOT="bot12345:bot-token"
export TGNOTIFIER_DEFAULT_CHAT="-12345"

tgnotifier --text="Hello, World!"

Send a "Hello, World!" message from the default bot to the default chat, defined in the config file:

tgnotifier --text="Hello, World!"

Send a "Hello, World!" message from the first_bot to the main_chat, mentioning the JohnDoe user:

tgnotifier --bot=first_bot --chat=main_chat --text="Hello, World and @JohnDoe!"

Send a "Hello, World!" message from the second_bot to the main_chat with no sound notification:

tgnotifier --bot=second_bot --chat=main_chat --text="Hello, World!" --disable-notification=true

Send a "Hello, World!" message from the another_bot to the another_chat using the non-default config file:

tgnotifier --config="/path/to/another_config.yaml" --bot=another_bot --chat=another_chat --text="Hello, World!" 

gRPC server

The tgnotifier could be started as an gRPC server. To run the server, use the tgnotifier grpc command:

Usage:
  tgnotifier grpc [flags]

Flags:
      --config string   Path to a config file
      --debug           Enable the debug mode
  -h, --help            help for grpc
  -v, --version         version for grpc

See the tgnotifier.proto for an API contract.

HTTP server

The tgnotifier could be started as an HTTP server too. To run the server, use the tgnotifier http command:

Usage:
  tgnotifier http [flags]

Flags:
      --config string   Path to a config file
      --debug           Enable the debug mode
  -h, --help            help for grpc
  -v, --version         version for grpc

See the openapi.yaml for an API contract.

GUI

If you want to test or visualize tgnotifier possibilities or to send couple messages via the UI, run the tgnotifierui app.

See the GUI readme for more info.

tgkit library

Yes, there also a library to communicate with a Telegram API. See its doc for more info: docs/tgkit.md.

TODO

  • Predefined messages with templates and i18n.
  • tgkit: generate models from Telegram's swagger file.
  • HTTP server.
  • Optional user's config file in the home dir.
  • gRPC server.
  • Docker configuration.
  • Replace map in config.
  • Define default bot & chat in config file.
  • Silence schedule in config.

License

MIT licensed.