The tgnotifier
is a tool to send a notification messages
via the Telegram API.
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.
To install the latest release of the tgnotifier
,
download the binary for your OS and put it somewhere inside the PATH.
- Ubuntu/Debian: tgnotifier_v1.0.1_ubuntu-latest
- macOS: tgnotifier_v1.0.1_macOS-latest
- Windows: tgnotifier_v1.0.1_windows-latest.exe
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.
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.
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 thetgnotifier
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="π₯"
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?
- See the Telegram Bot API tutorial to find out how to obtain a bot token.
- 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.
- use
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
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!"
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.
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.
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.
Yes, there also a library to communicate with a Telegram API. See its doc for more info: docs/tgkit.md.
- 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.