Skip to content

A decorator to aid in annotating logs for easier reading and searching

License

Notifications You must be signed in to change notification settings

github/annotated-logger

Repository files navigation

Annotated Logger

Coverage badge Ruff Checked with pyright

The annotated-logger package provides a decorator that can inject a annotatable logger object into a method or class. This logger object is a drop in replacement for logging.logger with additional functionality.

Background

Annotated Logger is actively used by GitHub's Vulnerability Management team to help to easily add context to our logs in splunk. It is more or less feature complete for our current use cases, but we will add additional features/fixes as we discover a need for them. But, we'd love feature requests, bug report and or PRs for either (see our contribution guidelines for more information if you wish to contribute).

Requirements

Annotated Logger is a Python package. It should work on any version of Python 3, but it is currently tested on 3.9 and higher.

Usage

The annotated-logger package allows you to decorate a function so that the start and end of that function is logged as well as allowing that function to request an annotated_logger object which can be used as if it was a standard python logger. Additionally, the annotated_logger object will have added annotations based on the method it requested from, any other annotations that were configured ahead of time and any annotations that were added prior to a log being made. Finally, any uncaught exceptions in a decorated method will be logged and re-raised, which allows you to when and how a method ended regardless of if it was successful or not.

from annotated_logger import AnnotatedLogger

annotated_logger = AnnotatedLogger(
    annotations={"this": "will show up in every log"},
)
annotate_logs = annotated_logger.annotate_logs

@annotate_logs()
def foo(annotated_logger, bar):
    annotated_logger.annotate(bar=bar)
    annotated_logger.info("Hi there!", extra={"mood": "happy"})

foo("this is the bar parameter")

{"created": 1708476277.102495, "levelname": "INFO", "name": "annotated_logger.fe18537a-d293-45d7-83c9-51dab3a4c436", "message": "Hi there!", "mood": "happy", "action": "__main__:foo", "this": "will show up in every log", "bar": "this is the bar parameter", "annotated": true}
{"created": 1708476277.1026022, "levelname": "INFO", "name": "annotated_logger.fe18537a-d293-45d7-83c9-51dab3a4c436", "message": "success", "action": "__main__:foo", "this": "will show up in every log", "bar": "this is the bar parameter", "run_time": "0.0", "success": true, "annotated": true}

The example directory has a few files that exercise all of the features of the annotated-logger package. The Calculator class is the most fully featured example (but not a fully featured calculator 😉). The logging_config example shows how to configure a logger via a dictConfig, like django uses. It also shows some of the interactions that can exist between a logging logger and an annotated_logger if logging is configured to use the annotated logger filter.

License

This project is licensed under the terms of the MIT open source license. Please refer to MIT for the full terms.

Maintainers

This project is primarily maintained by crimsonknave on behalf of GitHub's Vulnerability Management team as it was initially developed for our internal use.

Support

Reported bugs will be addressed, pull requests are welcome, but there is limited bandwidth for work on new features.

About

A decorator to aid in annotating logs for easier reading and searching

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages