Thanks to visit codestin.com
Credit goes to github.com

Skip to content

A modern, high-performance logging utility for Python with multiple output formats and colorful console output.

License

Notifications You must be signed in to change notification settings

DogukanUrker/Tamga

Folders and files

NameName
Last commit message
Last commit date

Latest commit

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

Tamga PyPI Downloads

A modern, high-performance logging utility for Python with multiple output formats and colorful console output.

Installation

πŸ€– AI Integration: For AI/LLM integration, see LLMs.txt or access documentation directly via Context7

tamΒ·ga /ˈtΓ¦mΙ‘Ι™/ Β· noun An ancient Turkic symbol or seal used for marking ownership, identity, or lineage.

Terminal

✨ Features

  • 🎨 Beautiful Console Output - Colorful, formatted logs using Tailwind CSS colors
  • ⚑ High Performance - Buffered writing system (10x faster than traditional logging)
  • πŸ“Š Multiple Outputs - Console, file, JSON, SQLite, MongoDB
  • πŸ”„ Automatic Rotation - File size management with backup support
  • 🧡 Thread-Safe - Safe for multi-threaded applications
  • πŸ”” Notifications - Multi-service notifications via Apprise (Discord, Slack, Email, SMS, and more)
  • πŸ” Structured Logging - Key-value data support with all log methods

πŸš€ Quick Start

See examples/simple_usage.py for a full script.

from tamga import Tamga

# Create logger with default settings
logger = Tamga()

# Log messages
logger.info("Application started")
logger.warning("Memory usage at 85%")
logger.error("Failed to connect to API")
logger.success("User registered successfully")
logger.debug("Cache initialized with 1000 entries")

πŸ§‘β€πŸ’» Examples

See examples/ for ready-to-run scripts:

  • simple_usage.py β€” basic logging
  • fastapi_webapp.py β€” FastAPI integration
  • advanced_config.py β€” production config
  • high_performance.py β€” high-speed big data logging demo

πŸ“¦ Installation

pip install tamga                    # Basic installation
pip install tamga[mongo]             # With MongoDB support
pip install tamga[notifications]     # With notification support
pip install tamga[all]               # All features

🎯 Usage Examples

Basic Configuration

logger = Tamga(
    # Display settings
    colored_output=True,     # Colored output
    show_time=True,          # Include timestamp
    show_timezone=False,     # Include timezone

    # Output destinations
    file_output=True,        # Log to file
    file_path="app.log",     # Log file path
    buffer_size=50,          # Buffer size for performance
)

Structured Logging

# Log with key-value data using any log method
logger.info("User action",
    user_id="123",
    action="login",
    ip_address="192.168.1.1",
    success=True
)

# Works with all log levels
logger.error("Database connection failed",
    host="localhost",
    port=5432,
    timeout=30,
    retry_count=3
)

logger.success("Payment processed",
    amount=99.99,
    currency="USD",
    method="credit_card",
    transaction_id="tx_123"
)

Production Setup

logger = Tamga(
    # File rotation
    file_output=True,
    max_file_size_mb=50,     # 50MB max file size
    enable_backup=True,      # Create backups

    # Performance
    buffer_size=200,         # Larger buffer for production
    console_output=False,    # Disable console for speed

    # External services
    mongo_output=True,
    mongo_uri="mongodb://...",

    # Multi-service notifications
    notify_services=[
        "discord://webhook_id/webhook_token",
        "slack://tokenA/tokenB/tokenC/#alerts",
        "mailto://user:[email protected]:587/[email protected]",
        "twilio://SID:Token@+1234567890/+0987654321",
    ],
    notify_levels=["CRITICAL", "ERROR", "NOTIFY"],
)

πŸ“‹ Log Levels

Level Color Method Use Case
INFO Sky logger.info() General information
WARNING Amber logger.warning() Warning messages
ERROR Rose logger.error() Error messages
SUCCESS Emerald logger.success() Success messages
DEBUG Indigo logger.debug() Debug information
CRITICAL Red logger.critical() Critical issues
DATABASE Green logger.database() Database operations
NOTIFY Purple logger.notify() Send notifications
METRIC Cyan logger.metric() Performance metrics
TRACE Gray logger.trace() Detailed trace info
CUSTOM Any logger.custom() Custom levels

πŸ”§ Advanced Features

Notifications

# Configure notification services (supports 80+ services via Apprise)
logger = Tamga(
    notify_services=[
        "discord://webhook_id/webhook_token",
        "slack://tokenA/tokenB/tokenC/#channel",
    ],
    notify_levels=["CRITICAL", "ERROR", "NOTIFY"],
    notify_title="{appname}: {level} Alert",
    notify_format="markdown",  # text, markdown, or html
)

# Send notification
logger.notify("Payment received from user #123")

# Critical logs also trigger notifications
logger.critical("Database connection lost")

Custom Log Levels

logger.custom("Deploy completed", "DEPLOY", "purple")
logger.custom("Payment received", "PAYMENT", "green")

Buffer Control

# Force write all buffered logs
logger.flush()

File Rotation

When log files reach max_file_size_mb, Tamga automatically:

  • Creates timestamped backups (if enabled)
  • Clears the original file
  • Continues logging seamlessly

πŸ“Š Performance

Tamga uses a buffered writing system that delivers significantly faster performance compared to traditional logging. The buffering mechanism provides optimal throughput for high-volume logging scenarios while maintaining thread safety.

🀝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

πŸ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

πŸ”— Links


Made with ❀️ by Doğukan Ürker

Contributors 3

  •  
  •  
  •  

Languages