Skip to main content

A comprehensive logging utility for managing application lifecycle logs

Project description

LifecycleLogging

LifecycleLogging Logo

A comprehensive logging utility for managing application lifecycle logs, combining the power of Python's logging with rich output formatting.

Documentation GitHub

Installation

pip install lifecyclelogging

Features

  • Configurable console and file logging outputs
  • Rich formatting for enhanced readability
  • Message storage with context and storage markers
  • Verbosity controls with bypass markers
  • Case-insensitive level filtering for allowed/denied storage rules
  • JSON data attachment support
  • Type-safe implementation
  • Seamless integration with existing logging systems
  • Automatic Gunicorn logger integration

Project Goals

  • Provide a batteries-included logging helper that stays compatible with modern Python releases
  • Keep configuration ergonomic while remaining type-safe and explicit
  • Offer sensible defaults that work locally and in containerized runtimes
  • Deliver reliable automation through testing, linting, and release workflows

Basic Usage

from lifecyclelogging import Logging

# Initialize logger
logger = Logging(
    enable_console=True,  # Enable console output
    enable_file=True,     # Enable file output
    logger_name="my_app"
)

# Basic logging
logger.logged_statement("Basic message", log_level="info")

# With context marker
logger.logged_statement(
    "Message with context",
    context_marker="STARTUP",
    log_level="info"
)

# With JSON data
logger.logged_statement(
    "Message with data",
    json_data={"key": "value"},
    log_level="debug"
)

Advanced Features

Verbosity Control

logger = Logging(
    enable_verbose_output=True,
    verbosity_threshold=2
)

# Only logged if verbosity threshold allows
logger.logged_statement(
    "Detailed debug info",
    verbose=True,
    verbosity=2,
    log_level="debug"
)

Verbosity Bypass Helpers

logger.register_verbosity_bypass_marker("IMPORTANT")

# Will be logged regardless of verbosity settings
logger.logged_statement(
    "Critical info",
    context_marker="IMPORTANT",
    verbose=True,
    verbosity=5,
    log_level="debug"
)

Message Storage

# Store message under a marker
logger.logged_statement(
    "Important event",
    storage_marker="EVENTS",
    log_level="info"
)

# Access stored messages
events = logger.stored_messages["EVENTS"]

Gunicorn Integration

When running under Gunicorn, LifecycleLogging automatically detects and inherits Gunicorn's logger configuration:

# The logger will automatically use Gunicorn's handlers if available
logger = Logging(
    enable_console=True,
    enable_file=True
)

Development

# Install development dependencies
pip install -e ".[dev,test,docs]"

# Run tests
make test

# Run linting and type checks
make check

# Build documentation
make docs

License

MIT License - See LICENSE for details.


Happy Logging!

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

lifecyclelogging-202511.2.tar.gz (12.8 kB view details)

Uploaded Source

Built Distribution

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

lifecyclelogging-202511.2-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file lifecyclelogging-202511.2.tar.gz.

File metadata

  • Download URL: lifecyclelogging-202511.2.tar.gz
  • Upload date:
  • Size: 12.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.13 {"installer":{"name":"uv","version":"0.9.13"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for lifecyclelogging-202511.2.tar.gz
Algorithm Hash digest
SHA256 0b9f08244ab13adbb004e04b147fdc16e0b563755507523d0e537b328e8f362a
MD5 79036050d6b4d87f32996568e580e28f
BLAKE2b-256 939a51faaa60c880aadf638ed9095a0bacbbdf936fcb962790eafc5280b4d891

See more details on using hashes here.

File details

Details for the file lifecyclelogging-202511.2-py3-none-any.whl.

File metadata

  • Download URL: lifecyclelogging-202511.2-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.13 {"installer":{"name":"uv","version":"0.9.13"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for lifecyclelogging-202511.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d41f901037060d1ff8c459400114e7094637ede7f0b80692bc2d42932968fd97
MD5 8e339536a07be4d3bd4b6ddead3c0a3e
BLAKE2b-256 f38451d8be8f77fcff1460f82dfd4bf824e96286aad3046ca618260d485a04b4

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