Skip to main content

async telegram handler

Project description

telegram_handler

Telegram logging handler for logging library in python.

Telegram log handler sends log messages directly to either a telegram channel or chat for your choice

Motivation

Tracking program execution state remotely - directly from your telegram account

Screenshots

screenshot

Code Examples

Basic usage example:

import logging

from telegram_handler import TelegramLoggingHandler

BOT_TOKEN = '1612485124:AAFW9JXxjqY9d-XayMKh8Q4-_iyHkXSw3N8'
CHANNEL_NAME = 'example_channel_logger'


def main():
    telegram_log_handler = TelegramLoggingHandler(BOT_TOKEN, CHANNEL_NAME)
    my_logger = logging.getLogger('My-Logger')
    my_logger.setLevel(logging.INFO)
    my_logger.addHandler(logging.StreamHandler())
    my_logger.addHandler(telegram_log_handler)

    for i in range(5):
        my_logger.error(f'iterating {i}..')


if __name__ == '__main__':
    main()

Another option is to add the handler to the root logger:

import logging

from telegram_handler import TelegramLoggingHandler

BOT_TOKEN = '1612485124:AAFW9JXxjqY9d-XayMKh8Q4-_iyHkXSw3N8'
CHANNEL_NAME = 'example_channel_logger'


def main():
    telegram_log_handler = TelegramLoggingHandler(BOT_TOKEN, CHANNEL_NAME)
    logging.basicConfig(
        handlers = [
            telegram_log_handler
        ],
        level=logging.INFO,
        format='%(asctime)s | %(levelname)s | %(name)s | %(message)s'
    )
    my_logger = logging.getLogger('My-Logger')
    for i in range(5):
        my_logger.error(f'iterating {i}..')


if __name__ == '__main__':
    main()

Installation

pip install telegram-handler

Preparation

In order to use the package you should:

  • Create a bot, you can see how this is being done here.
  • Create a channel, you can see how this is being done here.

How to use?

  • Use TelegramLoggingHandler and send messages from a different thread (recommended)

Parameters:

  • bot_token - The token that returns from the BotFather when creating the bot.
    bot_token
  • channel_name - Each chat in Telegram have chat id.
    • Channel name is the chat id for public channels. So for the public channel example_channel_logger the chat id will be example_channel_logger
    • The channel_name can be any chat id, you can see how to obtain chat id here.

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

telegram-handler-1.4.tar.gz (3.5 kB view details)

Uploaded Source

Built Distribution

telegram_handler-1.4-py3-none-any.whl (3.8 kB view details)

Uploaded Python 3

File details

Details for the file telegram-handler-1.4.tar.gz.

File metadata

  • Download URL: telegram-handler-1.4.tar.gz
  • Upload date:
  • Size: 3.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/3.7.2 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.52.0 CPython/3.8.6

File hashes

Hashes for telegram-handler-1.4.tar.gz
Algorithm Hash digest
SHA256 a0f1b693128c8cca11cc40a2b5125444b82d078810ed146d9f3120be2982aba0
MD5 3a448e3bc203c65a026f02301651dda5
BLAKE2b-256 4ffe33d79167b6623a813157ccc63b8bf886fd65777f4f13ff19fb616cf94132

See more details on using hashes here.

File details

Details for the file telegram_handler-1.4-py3-none-any.whl.

File metadata

  • Download URL: telegram_handler-1.4-py3-none-any.whl
  • Upload date:
  • Size: 3.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/3.7.2 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.52.0 CPython/3.8.6

File hashes

Hashes for telegram_handler-1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 fa1772bc070a5676db29b9f78f18ad54ddf79a568efaf8dc871fd71c9400178c
MD5 d6af15bbe6ac59a0cf6c2b3f145e9568
BLAKE2b-256 6e829d88fa72cef8a8d2cda5a2be3ddb124d749d22b33bdffa6f43c0d55433a4

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