A Python client for the telegram-logger service
Project description
🚀 telegram-logger-client: Your Log's New Best Friend
Welcome to the telegram-logger-client - where your logs go to become stars!
🛠 Prerequisites
Before you dive in, make sure you've got your backstage pass ready:
-
You'll need to set up and run the telegram-logger service. It's like the bouncer at the club - without it, your logs aren't getting in.
-
Head over to https://github.com/psyb0t/telegram-logger for the VIP instructions on setting up the telegram-logger service.
-
Once you've got that service up and running, come back here and let's make some noise!
🎭 Installation (No Secret Handshake Required)
Install this badass as a module and executable:
pip install telegram-logger-client
Go with pipx
to just use it as an executable:
pipx install telegram-logger-client
🕹️ Usage (AKA How to Make Some Noise)
🐍 As a Python Module
Summon the TelegramLoggerClient in your Python code:
from telegram_logger_client import TelegramLoggerClient
# Create your logger
logger = TelegramLoggerClient("https://your-logger-url.com", "your-secret-token")
# Send a log (it's like tweeting, but geekier)
logger.send_log(
caller="CoffeeBot",
level="warning",
message="Coffee levels critically low!",
error="Caffeine deficiency detected",
request_id="coffee-run-42",
trace_id="from-bed-to-coffee-machine",
span_id="mug-to-mouth",
data={"coffee_type": "Espresso", "sugar": False, "milk": "Oat"}
)
🔌 Attaching to Existing logging.loggers
Want to supercharge your existing logger with Telegram powers? We've got you covered! Use the attach_to_logger
function to add Telegram logging to any logger instance:
import logging
from telegram_logger_client import attach_to_logger
# Basic configuration for console output
logging.basicConfig(level=logging.DEBUG)
# Create your logger
logger = logging.getLogger("your_logger_name")
# Set up Telegram logging
attach_to_logger(logger)
# Use the logger as usual
logger.info("This will be sent to Telegram Logger and output to stdout")
The attach_to_logger
function is like a magic wand that adds Telegram logging capabilities to your existing logger. It takes care of all the behind-the-scenes work, so you can focus on what really matters - logging your heart out!
Parameters for attach_to_logger
:
logger
: Your existing logger instance (required)base_url
: The URL where your Telegram Logger service lives (optional if set in environment)x_id
: Your secret Telegram Logger handshake (optional if set in environment)level
: Set a specific logging level for Telegram logging (optional)show_originating_file
: Show the origin of the log (optional)
Don't forget to set your TELEGRAM_LOGGER_BASE_URL
and TELEGRAM_LOGGER_X_ID
environment variables, or pass them directly to attach_to_logger
. Now go forth and log like a boss! 🚀📝
🖥️ Command Line Magic
First, set up your secret lair:
export TELEGRAM_LOGGER_BASE_URL=https://your-logger-url.com
export TELEGRAM_LOGGER_X_ID=your-secret-token
Now, shout into the void (or just send a log):
telegram-logger-client \
--caller "WeatherBot" \
--level "info" \
--message "It's raining cats and dogs!" \
--error "Umbrella malfunction" \
--request-id "weather-101" \
--trace-id "cloud-to-ground" \
--span-id "drop-to-splash" \
--data '{"temperature": "chilly", "wind": "breezy"}'
Want to see every little detail? Add the --debug
flag:
telegram-logger-client \
--debug \
--caller "WeatherBot" \
--level "info" \
--message "It's raining cats and dogs!"
🎭 Logging Levels (Choose Your Adventure)
The client itself has two modes:
- Normal Mode (default): "Just the highlights" mode
- Debug Mode: "I can hear a pin drop" mode
Your logs, on the other hand, can be as dramatic as you want:
- "debug": "console.log" level
- "info": "Just FYI" level
- "warning": "Hmm, that's interesting" level
- "error": "Houston, we have a problem" level
🧙♂️ API Reference (The Boring but Important Bit)
🔮 TelegramLoggerClient
__init__(base_url: str, x_id: str)
Create your logger. Feed it URLs and tokens.
send_log(...)
Send your log on a grand adventure. Pack its bags with:
caller
: Who's making all this noise?level
: How important is this, really?message
: What's the scoop?error
: What went boom?request_id
: A unique ID for this particular escapadetrace_id
: For retracing your stepsspan_id
: A slice of time in the grand timelinedata
: Any extra bits and bobs
Returns a requests.Response
object (a postcard from your log's journey).
🗝️ Environment Variables (Your Logger's Secret Code)
TELEGRAM_LOGGER_BASE_URL
: Where your logs call homeTELEGRAM_LOGGER_X_ID
: Your logger's super-secret identity
🎲 Command Line Arguments (For When You're Feeling Bossy)
--debug
: Unleash the full power of logging (optional)--base-url
: A new home for your logs--x-id
: A new secret identity--caller
: Who's calling?--level
: On a scale of "meh" to "THE WORLD IS ENDING!"--message
: Your log's 15 minutes of fame--error
: What's gone sideways?--request-id
: This log's personal serial number--trace-id
: Breadcrumbs in the digital forest--span-id
: A moment in time--data
: Everything else but the kitchen sink
Remember: Command line arguments are the divas of the coding world - they always steal the show from environment variables.
📜 License (The Fine Print)
This project is unleashed under the WTFPL License – Do What The F**k You Want To Public License. Your imagination is the only limit, push it to the boundaries!
Now go forth and log like there's no tomorrow! May your errors be few and your insights be plentiful. Happy logging! 📝🚀
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file telegram_logger_client-0.2.2.tar.gz
.
File metadata
- Download URL: telegram_logger_client-0.2.2.tar.gz
- Upload date:
- Size: 328.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 28640c6962ee526d55081c879a95c608617cd497dd236d8de71448b54c8abc6a |
|
MD5 | c2b57946874db982871744ba73ac3499 |
|
BLAKE2b-256 | b4260e09877268df03a9432850b1f78cd91f6b7e53115a867c8776a1e126ec13 |
File details
Details for the file telegram_logger_client-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: telegram_logger_client-0.2.2-py3-none-any.whl
- Upload date:
- Size: 8.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b7f5033d02ff479e333864356a07c88f962c69306099e21ff3aee202be08af5c |
|
MD5 | 69099c66da19c10bc2884fb6fdc091c9 |
|
BLAKE2b-256 | 56dffdda23816cda4895cf0753088edd00f881d76f0f705337af7d6fb731c75d |