Commit f4926a74 authored by Denis Bilenko's avatar Denis Bilenko

pywsgi.WSGIServer: remove log_message function; add environ argument

parent 37f7c039
...@@ -212,7 +212,9 @@ class WSGIHandler(BaseHTTPServer.BaseHTTPRequestHandler): ...@@ -212,7 +212,9 @@ class WSGIHandler(BaseHTTPServer.BaseHTTPRequestHandler):
return safe_write return safe_write
def log_request(self, *args): def log_request(self, *args):
self.server.log_message(self.format_request(*args)) log = self.server.log
if log is not None:
log.write(self.format_request(*args) + '\n')
def format_request(self, length='-'): def format_request(self, length='-'):
return '%s - - [%s] "%s" %s %s %.6f' % ( return '%s - - [%s] "%s" %s %s %.6f' % (
...@@ -321,26 +323,36 @@ class WSGIServer(StreamServer): ...@@ -321,26 +323,36 @@ class WSGIServer(StreamServer):
'SERVER_SOFTWARE': 'gevent/%d.%d Python/%d.%d' % (gevent.version_info[:2] + sys.version_info[:2]), 'SERVER_SOFTWARE': 'gevent/%d.%d Python/%d.%d' % (gevent.version_info[:2] + sys.version_info[:2]),
'SCRIPT_NAME': '', 'SCRIPT_NAME': '',
'wsgi.version': (1, 0), 'wsgi.version': (1, 0),
'wsgi.errors': sys.stderr,
'wsgi.multithread': False, 'wsgi.multithread': False,
'wsgi.multiprocess': False, 'wsgi.multiprocess': False,
'wsgi.run_once': False} 'wsgi.run_once': False}
def __init__(self, listener, application=None, backlog=None, spawn='default', log=sys.stderr, handler_class=None, **ssl_args): def __init__(self, listener, application=None, backlog=None, spawn='default', log=None, handler_class=None,
environ=None, **ssl_args):
StreamServer.__init__(self, listener, backlog=backlog, spawn=spawn, **ssl_args) StreamServer.__init__(self, listener, backlog=backlog, spawn=spawn, **ssl_args)
if application is not None:
self.application = application
if handler_class is not None: if handler_class is not None:
self.handler_class = handler_class self.handler_class = handler_class
if log is None:
self.log = sys.stderr
else:
self.log = log
self.set_environ(environ)
def set_environ(self, environ=None):
if environ is not None:
self.environ = environ
environ_update = getattr(self, 'environ', None)
self.environ = self.base_env.copy() self.environ = self.base_env.copy()
if self.ssl_enabled: if self.ssl_enabled:
self.environ['wsgi.url_scheme'] = 'https' self.environ['wsgi.url_scheme'] = 'https'
else: else:
self.environ['wsgi.url_scheme'] = 'http' self.environ['wsgi.url_scheme'] = 'http'
if application is not None: if environ_update is not None:
self.application = application self.environ.update(environ_update)
self.log = log if self.environ.get('wsgi.errors') is None:
self.environ['wsgi.errors'] = sys.stderr
def log_message(self, message):
self.log.write(message + '\n')
def get_environ(self): def get_environ(self):
return self.environ.copy() return self.environ.copy()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment