Product
Introducing License Enforcement in Socket
Ensure open-source compliance with Socket’s License Enforcement Beta. Set up your License Policy and secure your software!
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 ^^^^^^^^^^^^^^^^^^^^^
Python's Logging Cookbook <http://docs.python.org/3/howto/logging-cookbook.html>
__.here <http://httpd.apache.org/docs/current/mod/mod_log_config.html#logformat>
__.WSGI <http://en.wikipedia.org/wiki/Web_Server_Gateway_Interface>
__
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 ^^^^^^^^^^^^^^^^^^
listing of wsgi-request-logger <https://pypi.python.org/pypi/wsgi-request-logger>
__hosted on Github <https://github.com/pklaus/wsgi-request-logger>
__.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/>
__FAQs
Apache-like combined logging for WSGI Web Applications
We found that wsgi-request-logger demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Product
Ensure open-source compliance with Socket’s License Enforcement Beta. Set up your License Policy and secure your software!
Product
We're launching a new set of license analysis and compliance features for analyzing, managing, and complying with licenses across a range of supported languages and ecosystems.
Product
We're excited to introduce Socket Optimize, a powerful CLI command to secure open source dependencies with tested, optimized package overrides.