Skip to main content

Add your description here

Project description

OneLogger 🚀

A Simple and Efficient Logging Library

OneLogger is a lightweight logging library built to help you dynamically configure and manage log settings with ease using oneenv. It leverages Python's built-in logging module and (for Python versions up to 3.12) enhances performance with picologging. Perfect for development, testing, and production environments!

Features ✨

  • Dynamic Configuration: Easily manage logging settings using environment variables via oneenv.
  • High Performance Logging:
    • For Python versions ≤ 3.12, OneLogger uses picologging to deliver blazing-fast logging 🚀.
    • For Python 3.13 and later, it seamlessly falls back to the standard logging module.
  • Flexible Output Options: Configure logs to output to the console, files (with rotation), or both.
  • Custom Formatting: Supports both plain text and JSON log formats.
  • Asynchronous Logging: Optionally enable asynchronous logging for better performance under high load.
  • Easy Integration: A simple API with a singleton pattern for effortless logger retrieval.

Supported Environments 🖥️

  • Python ≥ 3.11
    • Python < 3.13: Utilizes picologging for enhanced performance.
    • Python ≥ 3.13: Uses the standard logging module for full compatibility.

Installation 🛠️

For Users 👥

pip install onelogger

For Developers 🛠️

  1. Clone the Repository

    git clone <repository-url>
    cd onelogger
    
  2. Create and Activate a Virtual Environment

    python -m venv .venv
    # Windows (PowerShell)
    .\.venv\Scripts\Activate.ps1
    # macOS/Linux
    source .venv/bin/activate
    
  3. Install Development Dependencies

    pip install -e ".[dev]"
    

Usage 🚀

OneLogger integrates effortlessly into your projects. For example:

from onelogger import Logger

# Retrieve a configured logger instance
logger = Logger.get_logger("example_logger")

# Log messages at various levels
logger.info("This is an informational message.")
logger.error("This is an error message.")

try:
    result = 1 / 0
except Exception as e:
    logger.exception("An exception occurred during division!")

You can try out the example provided in the examples folder:

python examples/example_logger.py

Configuration 📦

OneLogger uses oneenv to manage environment variables with ease. The library automatically generates a .env.example template file with detailed descriptions for all available settings. This makes it simple to:

  • View all available configuration options with descriptions
  • Understand the purpose and valid values for each setting
  • Create your own .env file by copying and modifying the template

Here's an example of the auto-generated template:

# Auto-generated by OneEnv

# Specifies the logging level used by OneLogger.
# Valid options are DEBUG, INFO, WARNING, ERROR, and CRITICAL.
# Required
LOG_LEVEL=DEBUG

# Specifies the destination for log output.
# Options: 'console' for standard output, 'file' for file logging, or 'both'.
# Required
LOG_OUTPUT=both

# Specifies the log file path when LOG_OUTPUT is set to 'file' or 'both'.
LOG_FILE_PATH=example.log

# ... (other settings with descriptions)

To configure OneLogger, simply:

  1. Copy .env.example to .env
  2. Modify the values in .env according to your needs
  3. OneLogger will automatically load these settings when initialized

Contributing 🤝

Contributions are welcome! Please follow best practices and add tests as necessary.

License 📄

This project is licensed under the MIT License.

Color Support 🎨

OneLogger supports ANSI color codes in log messages:

  • Console output shows colored messages (when supported)
  • File output can strip color codes (configurable via LOG_STRIP_COLORS)

Windows Users

Color support is automatically enabled on Windows 10 and later. For earlier versions, you might need to use Windows Terminal or another terminal that supports ANSI colors.

Environment Variables

  • LOG_STRIP_COLORS: Set to "true" to remove color codes from file output (default: "false")
  • NO_COLOR: Set to any value to disable colors completely

Enjoy fast and configurable logging with OneLogger! 🎉

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

onelogger-0.1.1.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

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

onelogger-0.1.1-py3-none-any.whl (12.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: onelogger-0.1.1.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for onelogger-0.1.1.tar.gz
Algorithm Hash digest
SHA256 63db45859640cfdb4c98c38fbcd51d10ab4ff866d7bf7755a1787aedfdf8c2be
MD5 d9697d87ef611e8599d3ff59a8d39c5a
BLAKE2b-256 1df78d180d885f9f1d414556fa78a96dc3ebde9077665ead5481d22cf76123bb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: onelogger-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 12.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for onelogger-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c63a9b8963cb066bb38c0644e735a0051ada864cda0045b723c56a1ba6fdb382
MD5 826fcc9177a4f64a040ac1eada4c9828
BLAKE2b-256 182bb0c3f14780e3b2435b70b9e5f46a2a2d5047eb29c400b391c6323cf52aeb

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