Socket
Socket
Sign inDemoInstall

wsgi-request-logger

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

wsgi-request-logger

Apache-like combined logging for WSGI Web Applications


Maintainers
1

Request Logging for WSGI Web Applications

This is a middleware which you can use to log requests to your WSGI based site. It's even imitating Apache's combined log format to allow you to use any of the many tools for Apache log file analysis.

By making use of Python's standard library logging facilities, you can easily set it up to log to STDOUT, time rotated log files, email, syslog, etc.

Installation ^^^^^^^^^^^^

Simply install this Python module via

::

pip install wsgi-request-logger

Usage ^^^^^

To add this middleware to your WSGI application and log to the file access.log, do:

::

from requestlogger import WSGILogger, ApacheFormatter
from logging.handlers import TimedRotatingFileHandler

def application(environ, start_response):
    response_body = 'The request method was %s' % environ['REQUEST_METHOD']
    response_body = response_body.encode('utf-8')
    response_headers = [('Content-Type', 'text/plain'),
                        ('Content-Length', str(len(response_body)))]
    start_response('200 OK', response_headers)
    return [response_body]

handlers = [ TimedRotatingFileHandler('access.log', 'd', 7) , ]
loggingapp = WSGILogger(application, handlers, ApacheFormatter())

if __name__ == '__main__':
    from wsgiref.simple_server import make_server
    http = make_server('', 8080, loggingapp)
    http.serve_forever()

The Authors ^^^^^^^^^^^

This WSGI middleware was originally developed under the name wsgilog <https://pypi.python.org/pypi/wsgilog/>__ by L. C. Rees. It was forked by Philipp Klaus in 2013 to build a WSGI middleware for request logging rather than exception handling and logging.

License ^^^^^^^

This software, wsgi-request-logger, is published under a 3-clause BSD license.

Developers' Resources ^^^^^^^^^^^^^^^^^^^^^

  • To read about your options for the logging handler, you may want to read Python's Logging Cookbook <http://docs.python.org/3/howto/logging-cookbook.html>__.
  • Documentation on Apache's log format can be found here <http://httpd.apache.org/docs/current/mod/mod_log_config.html#logformat>__.
  • The WSGI <http://en.wikipedia.org/wiki/Web_Server_Gateway_Interface>__
    • Web Server Gateway Interface - is defined in PEP 333 <http://www.python.org/dev/peps/pep-0333/>__ with an update for Python 3 in PEP 3333 <http://www.python.org/dev/peps/pep-3333/>__.

General References ^^^^^^^^^^^^^^^^^^

  • PyPI's listing of wsgi-request-logger <https://pypi.python.org/pypi/wsgi-request-logger>__
  • The source code for this Python module is hosted on Github <https://github.com/pklaus/wsgi-request-logger>__.
  • A blog post with more background information and usage examples: wsgi-request-logger – Logging HTTP Requests With Any WSGI Web Application like Flask, Bottle or Django <https://blog.philippklaus.de/2013/06/wsgi-request-logger-logging-http-requests-with-any-wsgi-web-application-like-flask-bottle-or-django/>__

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc