2019-06-10 15:32:45 +02:00
|
|
|
import logging
|
2019-05-06 15:23:21 +02:00
|
|
|
from abc import abstractmethod
|
2019-05-09 16:56:16 +02:00
|
|
|
from json import loads, dumps
|
2019-05-02 14:54:55 +02:00
|
|
|
|
2019-09-05 16:10:46 +02:00
|
|
|
from pipe_io_server import PipeIOServer
|
2019-05-02 14:54:55 +02:00
|
|
|
|
|
|
|
LOG = logging.getLogger(__name__)
|
2019-05-09 16:56:16 +02:00
|
|
|
DEFAULT_PERMISSIONS = 0o600
|
2019-05-02 14:54:55 +02:00
|
|
|
|
|
|
|
|
2019-07-24 15:17:16 +02:00
|
|
|
class PipeIOHandlerBase:
|
2019-07-12 23:25:16 +02:00
|
|
|
keys = ['']
|
|
|
|
|
|
|
|
def __init__(self, in_pipe_path, out_pipe_path, permissions=DEFAULT_PERMISSIONS):
|
2019-07-30 15:17:29 +02:00
|
|
|
self.connector = None
|
2019-09-05 15:52:34 +02:00
|
|
|
self.in_pipe = in_pipe_path
|
|
|
|
self.out_pipe = out_pipe_path
|
2019-09-04 18:07:36 +02:00
|
|
|
self.pipe_io = PipeIOServer(
|
2019-05-04 21:10:05 +02:00
|
|
|
in_pipe_path,
|
|
|
|
out_pipe_path,
|
|
|
|
permissions
|
|
|
|
)
|
2019-09-04 18:07:36 +02:00
|
|
|
self.pipe_io.handle_message = self._server_handle_message
|
2019-05-06 15:23:21 +02:00
|
|
|
self.pipe_io.start()
|
|
|
|
|
2019-09-04 18:07:36 +02:00
|
|
|
def _server_handle_message(self, message):
|
|
|
|
try:
|
|
|
|
self.handle_pipe_event(message)
|
|
|
|
except: # pylint: disable=bare-except
|
2019-09-05 15:52:34 +02:00
|
|
|
LOG.exception('Failed to handle message %s from pipe %s!', message, self.in_pipe)
|
2019-09-04 18:07:36 +02:00
|
|
|
|
2019-05-06 15:23:21 +02:00
|
|
|
@abstractmethod
|
2019-05-09 15:14:47 +02:00
|
|
|
def handle_pipe_event(self, message_bytes):
|
2019-05-06 15:23:21 +02:00
|
|
|
raise NotImplementedError()
|
2019-05-02 14:54:55 +02:00
|
|
|
|
|
|
|
def cleanup(self):
|
2019-05-06 15:23:21 +02:00
|
|
|
self.pipe_io.stop()
|
|
|
|
|
|
|
|
|
2019-07-24 15:17:16 +02:00
|
|
|
class PipeIOHandler(PipeIOHandlerBase):
|
2019-07-12 23:25:16 +02:00
|
|
|
def handle_event(self, message, _):
|
2019-05-09 15:12:42 +02:00
|
|
|
json_bytes = dumps(message).encode()
|
|
|
|
self.pipe_io.send_message(json_bytes)
|
2019-05-04 21:13:58 +02:00
|
|
|
|
2019-05-09 15:14:47 +02:00
|
|
|
def handle_pipe_event(self, message_bytes):
|
|
|
|
json = loads(message_bytes)
|
2019-07-30 15:17:29 +02:00
|
|
|
self.connector.send_message(json)
|