mirror of
https://github.com/morpheus65535/bazarr
synced 2024-12-28 10:38:26 +00:00
34 lines
950 B
Python
34 lines
950 B
Python
from gevent.pywsgi import WSGIServer
|
|
|
|
from .handler import WebSocketHandler
|
|
from .logging import create_logger
|
|
|
|
|
|
class WebSocketServer(WSGIServer):
|
|
handler_class = WebSocketHandler
|
|
debug_log_format = (
|
|
'-' * 80 + '\n' +
|
|
'%(levelname)s in %(module)s [%(pathname)s:%(lineno)d]:\n' +
|
|
'%(message)s\n' +
|
|
'-' * 80
|
|
)
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
self.debug = kwargs.pop('debug', False)
|
|
self.pre_start_hook = kwargs.pop('pre_start_hook', None)
|
|
self._logger = None
|
|
self.clients = {}
|
|
|
|
super(WebSocketServer, self).__init__(*args, **kwargs)
|
|
|
|
def handle(self, socket, address):
|
|
handler = self.handler_class(socket, address, self)
|
|
handler.handle()
|
|
|
|
@property
|
|
def logger(self):
|
|
if not self._logger:
|
|
self._logger = create_logger(
|
|
__name__, self.debug, self.debug_log_format)
|
|
|
|
return self._logger
|