A logger for python
Project description
GamuLogger
📚 Table of Contents
🔨 Installation
The package is available in the assets of the latest release on pypi.
You can install it with pip:
pip install gamuLogger
💡 Usage
- First you need to import the package:
from gamuLogger import deepDebug, debug, info, warning, error, critical, Logger, LEVELS, SENSITIVE_LEVELS
note: you can also only import the members you need instead of importing all of them.
- Then you can use the functions like this:
info('This is an info message') warning('This is a warning message') error('This is an error message')
You may note that the logging function are also available as static methods in the
Logger
class. This allow you to have them encapsulated in a class and use them in a more object oriented way:from gamuLogger import Logger Logger.info('This is an info message') Logger.warning('This is a warning message') Logger.error('This is an error message')
⚙️ Configuration
1. Basic Configuration
You can configure the logger using methods of the Logger
class. Here is an example of how you can do it:
from gamuLogger import Logger, LEVELS, SENSITIVE_LEVELS
# default target is the standard output, name is 'stdout'
Logger.setLevel("stdout", LEVELS.INFO); # this mean yhat all logs with level less than INFO will be ignored
Logger.setSensitiveLevel("stdout", SENSITIVE_LEVELS.HIDE); # If a log message contains sensitive data, it will be hidden
Logger.addSensitiveData('myPasswordSecret'); # add 'myPasswordSecret' to the list of sensitive data (if a log message contains any of them, it will be hidden according to the sensitive level)
Logger.setModule('my-module'); # set the module name for this file to 'my-module' (this will be displayed in the log message) (by default, no module name is set)
Logger.addTarget("data.log", LEVELS.DEBUG, SENSITIVE_LEVELS.HIDE) # add a new target to the logger (this will log all messages with level less than DEBUG to the file 'data.log' and hide sensitive data if any)
Please note that the logger can be used without any manual configuration. The default configuration is:
- target: terminal
- level:
INFO
- sensitive mode:
HIDE
- sensitive data:
[]
- module name:
None
Note that the module name is set only for the current file. If you want to set the module name for all files, you need to set it in each file.
📁 Examples
you can find examples in the example directory.
📜 License
This project is licensed under the MIT License - see the LICENSE file for details.
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
Built Distribution
File details
Details for the file gamulogger-3.0.1.tar.gz
.
File metadata
- Download URL: gamulogger-3.0.1.tar.gz
- Upload date:
- Size: 11.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 448935b3f92c20092359f7d9eb9037ea68be8947f8d7dd3f7081c50c18c25901 |
|
MD5 | b8730e0fadec123ab168ebd625f65e11 |
|
BLAKE2b-256 | f01563552197417bb1a85ab6b72b8dfea70bc7436836c6b9f8e43b6713012d86 |
Provenance
The following attestation bundles were made for gamulogger-3.0.1.tar.gz
:
Publisher:
OnRelease.yml
on T0ine34/gamuLogger
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
gamulogger-3.0.1.tar.gz
- Subject digest:
448935b3f92c20092359f7d9eb9037ea68be8947f8d7dd3f7081c50c18c25901
- Sigstore transparency entry: 149149797
- Sigstore integration time:
- Predicate type:
File details
Details for the file gamuLogger-3.0.1-py3-none-any.whl
.
File metadata
- Download URL: gamuLogger-3.0.1-py3-none-any.whl
- Upload date:
- Size: 12.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c60a2fd9e343a5980e6c587bb228dbbc3bd514950c957ba4432309aff8d734af |
|
MD5 | 81123870eb6c95102bc021e2838b095a |
|
BLAKE2b-256 | f13a56691006cd0a990dff68d8f5590a852974a4a9895d2e88fbdc513b01c737 |
Provenance
The following attestation bundles were made for gamuLogger-3.0.1-py3-none-any.whl
:
Publisher:
OnRelease.yml
on T0ine34/gamuLogger
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
gamulogger-3.0.1-py3-none-any.whl
- Subject digest:
c60a2fd9e343a5980e6c587bb228dbbc3bd514950c957ba4432309aff8d734af
- Sigstore transparency entry: 149149799
- Sigstore integration time:
- Predicate type: