bootstrap-vz/bootstrapvz/base/remote/server.py

58 lines
1.2 KiB
Python
Raw Normal View History

def main():
opts = getopts()
log_forwarder = setup_logging()
serve(opts, log_forwarder)
def setup_logging():
import logging
from log import LogForwarder
log_forwarder = LogForwarder()
root = logging.getLogger()
root.addHandler(log_forwarder)
root.setLevel(logging.NOTSET)
return log_forwarder
def serve(opts, log_forwarder):
class Server(object):
2014-11-24 17:26:13 +01:00
def __init__(self):
self.stop_serving = False
def run(self, *args, **kwargs):
from bootstrapvz.base.main import run
return run(*args, **kwargs)
def set_log_server(self, server):
return log_forwarder.set_server(server)
def ping(self):
return 'pong'
2014-11-24 17:26:13 +01:00
def stop(self):
self.stop_serving = True
import Pyro4
2014-11-24 17:26:13 +01:00
Pyro4.config.COMMTIMEOUT = 0.5
daemon = Pyro4.Daemon('localhost', port=int(opts['--listen']), unixsocket=None)
2014-11-24 17:26:13 +01:00
server = Server()
daemon.register(server, 'server')
2014-11-24 17:26:13 +01:00
daemon.requestLoop(loopCondition=lambda: not server.stop_serving)
def getopts():
from docopt import docopt
usage = """bootstrap-vz-server
Usage: bootstrap-vz-server [options]
Options:
--listen <port> Serve on specified port [default: 46675]
-h, --help show this help
"""
return docopt(usage)