Skip to main content

A non-invasive `logging` configurator and facilitator.

Project description

hanaro (하나로) is a non-invasive logging configurator and facilitator for Python.

This README is only a high-level introduction to hanaro. For more detailed documentation, please view the official docs at https://hanaro.readthedocs.io.

Installation

hanaro can be installed from pypi through the usual means:

pip install hanaro

Usage

Let's try a "learn by example" approach. The following two snippets are the contents of a configuration file that contains a "logging" configuration section, and a Python code file that initializes Python's standard logging system using that configuration. This is by no means an exhaustive example, it only intends to touch on the major offerings of hanaro.

NOTE: Configuration handling is performed using appsettings2 which supports json, toml, yaml, xml, command-line args, and environment variables to provide a unified configuration solution. This example, however, uses json because of json's wider familiarity. For the sake of demonstration assume this content is in a file named appsettings.json.

{
    "logging": {
        "level": "INFO",
        "format": "[%(asctime)s] %(message)s level=%(levelname)s source=%(name)s %(meta)s",
        "datefmt": "%Y-%m-%dT%H:%M:%S",
        "handlers": [
            {
                "type": "console",
                "level": "DEBUG"
            },
            {
                "type": "file",
                "level": "DEBUG",
                "path": "logs/",
                "name": "debug.log",
                "max_size": "4KiB",
                "max_count": 10,
                "format": "[%(asctime)s] level=%(levelname)s %(message)s source=\"%(name)s\" func=\"%(funcName)s\" %(meta)s"
            },
            {
                "type": "custom",
                "canonical": "myapp.mymodule.myhandler",
                "level": "WARNING",
                "format": "msg=\"%(message)s\" level=\"%(levelname)s\" source=\"%(name)s\" func=\"%(funcName)s\" %(meta)s"
            }
        ],
        "filters": {
            "asyncio": {
                "level": "WARNING"
            },
            "mysql.*": {
                "level": "WARNING"
            },
            "urllib3.*": {
                "level": "WARNING"
            },
            "websockets.*": {
                "level": "WARNING"
            }
        }
    },
}

This code sample is a minimum-viable solution. The custom handler above is omitted, but for the sake of demonstration know that canonical is the fully-qualified type name of a logging.Handler subclass and hanaro will create an instance of that class and configure as it does all other handlers.

from appsettings2 import getConfiguration
from hanaro import configureLogging
import logging

configureLogging(getConfiguration())

logger = logging.getLogger(__name__)

logger.info('Hello, World!')

When executed the program outputs the following:

[2025-12-31T12:34:56] Hello, World! level=INFO source=__main__ 

Notables..

Things not obvious given the example above:

  • All configuration options are optional, you can reduce the config to specifying only those things you wish to customize.
  • It is not necessary to load a configuration at all, a call to configureLogging() will still apply reasonable defaults such as adding a console handler, applying a line format, applying a default date format (ISO 8601), etc.
  • If no handlers are configured, a default handler for "console" is configured.

hanaro only has a single direct dependency: appsettings2.

Contact

You can reach me on Discord or open an Issue on Github.

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

hanaro-0.1.4.tar.gz (6.3 kB view details)

Uploaded Source

Built Distribution

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

hanaro-0.1.4-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file hanaro-0.1.4.tar.gz.

File metadata

  • Download URL: hanaro-0.1.4.tar.gz
  • Upload date:
  • Size: 6.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3+

File hashes

Hashes for hanaro-0.1.4.tar.gz
Algorithm Hash digest
SHA256 585cfa252ed3ce13acda06dfdf7ffc47ded76451ed5c07e9b8a303c3d2fe233c
MD5 a19bec581989795532cd9e4f0b12cf16
BLAKE2b-256 694891f6c2a2885c73fad00b87c383322c0d6c94b3e245223dc6cd5832696179

See more details on using hashes here.

File details

Details for the file hanaro-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: hanaro-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3+

File hashes

Hashes for hanaro-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 519c67577076cf8faf2c1e0e8a17f855f628448a4273798d1d4c0ddb037b1c06
MD5 5e2116e84e2d63d6fe0f72108391ee7d
BLAKE2b-256 8ceeddee78e50ccf9ac416bec1593da5a9b2ea95ceda420c0a05a5d0c4243f2e

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