Skip to main content

Logging configuration for flask application

Project description

download version

Advanced Logging configuration for flask application based on yaml or json file. See logging.config

NOTE: If you want to use flask_logify.handlers.syslog.FlaskSysLogHandler you must init this extension with an app context.

The dump of request or response are made by builders, there are two concrete implementations:

  1. LogTextBuilder: message as plain text (configurable).

  2. LogJSONBuilder: message as json format.

You can create your own builder by extending class LogBuilder. See example usage in example/text.py.

FlaskLogging as a decorator attribute with which you can disable log messages for a specific route, passing a logging filter to it. For example you want disable log for health check endpoint. See example/text.py.

Quickstart

Install flask_logify using pip:

$ pip install Flask-Logify

Example usage

An example of log file configuration is under example folder.

Only yaml or json format are supported.

from flask import Flask
from flask_logify import FlaskLogging


app = Flask(__name__)
app.config['LOG_FILE_CONF'] = 'log.yaml'
app.config['LOG_LOGGER_NAME'] = 'flask-development'

logging = FlaskLogging()
with app.app_context():
    logging.init_app(app)

app.run()

Go to http://127.0.0.1:5000/ and see log messages like configured

Configuration

Base configuration keys:

  1. LOG_FILE_CONF: (default: None) absolute path of configuration file

  2. LOG_APP_NAME: (default: flask) the PROGRAM field of the log messages

  3. LOG_LOGGER_NAME: (default: flask-development) usually is {LOG_APP_NAME}-{FLASK_ENV}

Text and JSON builder configuration keys:

  1. LOG_REQ_HEADERS: (default: []) request headers to dump always

  2. LOG_RESP_HEADERS: (default: []) response headers to dump always

  3. LOG_SKIP_DUMP: (default: not DEBUG) if true dump of body and headers are skipped

Text builder only:

  1. LOG_RESP_FORMAT: (default: “{level} STATUS {status}nn{headers}nn{body}n”) log message format for response

  2. LOG_REQ_FORMAT: (default: “{addr} {method} {scheme} {path}nn{headers}nn{body}n”) log message format for request

License MIT

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

Flask-Logify-2.0.0.tar.gz (6.2 kB view details)

Uploaded Source

File details

Details for the file Flask-Logify-2.0.0.tar.gz.

File metadata

  • Download URL: Flask-Logify-2.0.0.tar.gz
  • Upload date:
  • Size: 6.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/39.1.0 requests-toolbelt/0.9.1 tqdm/4.29.0 CPython/3.6.5

File hashes

Hashes for Flask-Logify-2.0.0.tar.gz
Algorithm Hash digest
SHA256 31925fa6225b7225a7d627396901b783d537b82d9cfcc168dd6f92839fef0e27
MD5 adb33a38236f31b758b088759b4b0d9b
BLAKE2b-256 57cc6aad979ab6863fd998bf1a84aad5d0e3618a6c078d23ce52c12fd4b30b7c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page