~ moving test server script on level up
parent
db46c75d72
commit
0c14ebec87
|
@ -0,0 +1,92 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# Copyright (c) Contributors, http://opensimulator.org/
|
||||||
|
# See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are met:
|
||||||
|
# * Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
# * Redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
# * Neither the name of the OpenSim Project nor the
|
||||||
|
# names of its contributors may be used to endorse or promote products
|
||||||
|
# derived from this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
|
||||||
|
# EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
# DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
|
||||||
|
import logging
|
||||||
|
import BaseHTTPServer
|
||||||
|
|
||||||
|
# enable debug level logging
|
||||||
|
logging.basicConfig(level = logging.DEBUG,
|
||||||
|
format='%(asctime)s %(levelname)s %(message)s')
|
||||||
|
|
||||||
|
# subclassed HTTPRequestHandler
|
||||||
|
class ConciergeHandler(BaseHTTPServer.BaseHTTPRequestHandler):
|
||||||
|
def logRequest(self):
|
||||||
|
logging.info('[ConciergeHandler] %(command)s request: %(host)s:%(port)d --- %(path)s',
|
||||||
|
dict(command = self.command,
|
||||||
|
host = self.client_address[0],
|
||||||
|
port = self.client_address[1],
|
||||||
|
path = self.path))
|
||||||
|
|
||||||
|
def logResponse(self, status):
|
||||||
|
logging.info('[ConciergeHandler] %(command)s returned %(status)d',
|
||||||
|
dict(command = self.command,
|
||||||
|
status = status))
|
||||||
|
|
||||||
|
|
||||||
|
def do_HEAD(self):
|
||||||
|
self.logRequest()
|
||||||
|
|
||||||
|
self.send_response(200)
|
||||||
|
self.send_header('Content-type', 'text/html')
|
||||||
|
self.end_headers()
|
||||||
|
|
||||||
|
self.logResponse(200)
|
||||||
|
|
||||||
|
def do_POST(self):
|
||||||
|
self.logRequest()
|
||||||
|
hdrs = {}
|
||||||
|
for hdr in self.headers.headers:
|
||||||
|
logging.debug('[ConciergeHandler] POST: header: %s', hdr.rstrip())
|
||||||
|
|
||||||
|
length = int(self.headers.getheader('Content-Length'))
|
||||||
|
content = self.rfile.read(length)
|
||||||
|
self.rfile.close()
|
||||||
|
|
||||||
|
logging.debug('[ConciergeHandler] POST: content: %s', content)
|
||||||
|
|
||||||
|
self.send_response(200)
|
||||||
|
self.send_header('Content-type', 'text/html')
|
||||||
|
self.end_headers()
|
||||||
|
|
||||||
|
self.logResponse(200)
|
||||||
|
|
||||||
|
def log_request(code, size):
|
||||||
|
pass
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
|
||||||
|
httpServer = BaseHTTPServer.HTTPServer(('', 8080), ConciergeHandler)
|
||||||
|
logging.info('[ConciergeServer] Concierge Broker Test Server starting')
|
||||||
|
|
||||||
|
try:
|
||||||
|
httpServer.serve_forever()
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
logging.info('[ConciergeServer] terminating')
|
||||||
|
|
||||||
|
httpServer.server_close()
|
Loading…
Reference in New Issue