Skip to main content

Rate-limited Telegram notifications with priority queue

Project description

tg-notify

Rate-limited Telegram notifications with priority queue.

Install

pip install tg-notify

Quick Start

export TELEGRAM_BOT_TOKEN="your-bot-token"
export TELEGRAM_CHAT_ID="-1001234567890"
from tg_notify import send_telegram_message

send_telegram_message("Hello from tg-notify!")

Shortcuts

from tg_notify import send_error, send_success, send_warning, send_info, send_stats, send_alert

send_error("DB connection failed", {"host": "db.example.com"})
send_success("Deploy complete", {"version": "1.2.3"})
send_warning("Disk usage high", {"usage": "89%"})
send_info("New user registered", {"email": "user@example.com"})
send_stats("Daily Report", {"users": 1500, "revenue": "$3200"})
send_alert("Server down!", {"server": "prod-1"})

TelegramSender

from tg_notify import TelegramSender

sender = TelegramSender(bot_token="your-token", chat_id=-123456)
sender.send_message("Hello!")
sender.send_photo("chart.png", caption="Daily stats")
sender.send_document("report.pdf")

Priority Queue

Messages are queued with 4 priority levels and rate-limited to 20 msg/sec:

Priority Use case
CRITICAL (1) Security alerts, system down
HIGH (2) Errors, important warnings
NORMAL (3) Info, success messages
LOW (4) Stats, debug

Auto-cleanup drops low-priority messages when queue fills up.

from tg_notify import telegram_queue

# Flush before exit (CLI scripts)
telegram_queue.flush(timeout=5)

License

MIT

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

tg_notify-0.1.1.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tg_notify-0.1.1-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file tg_notify-0.1.1.tar.gz.

File metadata

  • Download URL: tg_notify-0.1.1.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.18

File hashes

Hashes for tg_notify-0.1.1.tar.gz
Algorithm Hash digest
SHA256 5d05889bd7310379af3472e90c21fe136db479e6a453a53e51d24e788c429f77
MD5 9dcffaac005928973838af3e46e4437d
BLAKE2b-256 dc897d7d4d81f90e76d6cd2562c0f8c834b4ed2990a803a00f3c2524bf50c916

See more details on using hashes here.

File details

Details for the file tg_notify-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: tg_notify-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 12.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.18

File hashes

Hashes for tg_notify-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cec926dbf4bc860e7685193e43116a3d23f993814f6526aaf73169fc68d77fa3
MD5 1040807c900a8950c8422fa9ddd78025
BLAKE2b-256 1094496c351c11ec593e568b5e22e811ac7e588e454fb2c87b1f094bd61c860f

See more details on using hashes here.

Supported by

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