2018-04-03 12:49:14 +00:00
|
|
|
# Copyright (C) 2018 Avatao.com Innovative Learning Kft.
|
|
|
|
# All Rights Reserved. See LICENSE file for details.
|
|
|
|
|
2018-01-31 14:50:52 +00:00
|
|
|
from functools import partial
|
2018-03-25 13:43:59 +00:00
|
|
|
|
|
|
|
import zmq
|
2018-01-24 17:19:49 +00:00
|
|
|
from zmq.eventloop.zmqstream import ZMQStream
|
|
|
|
|
2018-03-25 14:36:31 +00:00
|
|
|
from tfw.config import TFWENV
|
2018-06-29 09:50:36 +00:00
|
|
|
from tfw.config.logs import logging
|
|
|
|
|
2019-05-27 12:09:13 +00:00
|
|
|
from .scope import Scope
|
|
|
|
from .serialization import serialize_tfw_msg, with_deserialize_tfw_msg
|
|
|
|
from .zmq_connector_base import ZMQConnectorBase
|
|
|
|
|
2018-06-29 09:50:36 +00:00
|
|
|
LOG = logging.getLogger(__name__)
|
2018-01-31 14:50:52 +00:00
|
|
|
|
2018-01-24 17:19:49 +00:00
|
|
|
|
2018-01-30 13:31:00 +00:00
|
|
|
class ServerDownlinkConnector(ZMQConnectorBase):
|
2018-01-29 15:07:36 +00:00
|
|
|
def __init__(self, zmq_context=None):
|
|
|
|
super(ServerDownlinkConnector, self).__init__(zmq_context)
|
2018-01-24 17:19:49 +00:00
|
|
|
self._zmq_sub_socket = self._zmq_context.socket(zmq.SUB)
|
2018-04-19 07:21:41 +00:00
|
|
|
self._zmq_sub_socket.connect(f'tcp://localhost:{TFWENV.PUBLISHER_PORT}')
|
2019-05-21 11:55:28 +00:00
|
|
|
self._zmq_sub_socket.setsockopt(zmq.RCVHWM, 0)
|
2018-01-24 17:19:49 +00:00
|
|
|
self._zmq_sub_stream = ZMQStream(self._zmq_sub_socket)
|
|
|
|
|
|
|
|
self.subscribe = partial(self._zmq_sub_socket.setsockopt_string, zmq.SUBSCRIBE)
|
|
|
|
self.unsubscribe = partial(self._zmq_sub_socket.setsockopt_string, zmq.UNSUBSCRIBE)
|
2018-06-29 09:50:36 +00:00
|
|
|
|
|
|
|
def register_callback(self, callback):
|
|
|
|
callback = with_deserialize_tfw_msg(callback)
|
|
|
|
self._zmq_sub_stream.on_recv(callback)
|
2018-01-26 14:16:34 +00:00
|
|
|
|
2019-05-20 09:06:57 +00:00
|
|
|
def close(self):
|
|
|
|
self._zmq_sub_stream.close()
|
|
|
|
|
2018-01-29 15:07:36 +00:00
|
|
|
|
2018-01-30 13:31:00 +00:00
|
|
|
class ServerUplinkConnector(ZMQConnectorBase):
|
2018-01-29 15:07:36 +00:00
|
|
|
def __init__(self, zmq_context=None):
|
|
|
|
super(ServerUplinkConnector, self).__init__(zmq_context)
|
|
|
|
self._zmq_push_socket = self._zmq_context.socket(zmq.PUSH)
|
2018-04-19 07:21:41 +00:00
|
|
|
self._zmq_push_socket.connect(f'tcp://localhost:{TFWENV.RECEIVER_PORT}')
|
2019-05-21 11:55:28 +00:00
|
|
|
self._zmq_push_socket.setsockopt(zmq.SNDHWM, 0)
|
2018-01-29 15:07:36 +00:00
|
|
|
|
2019-05-26 16:26:33 +00:00
|
|
|
def send_message(self, message, scope=Scope.ZMQ):
|
|
|
|
message['scope'] = scope.value
|
2018-04-13 14:35:30 +00:00
|
|
|
self._zmq_push_socket.send_multipart(serialize_tfw_msg(message))
|
2018-01-29 15:07:36 +00:00
|
|
|
|
2019-05-20 09:06:57 +00:00
|
|
|
def close(self):
|
|
|
|
self._zmq_push_socket.close()
|
|
|
|
|
2018-01-29 15:07:36 +00:00
|
|
|
|
|
|
|
class ServerConnector(ServerUplinkConnector, ServerDownlinkConnector):
|
2019-05-20 09:06:57 +00:00
|
|
|
def close(self):
|
|
|
|
ServerUplinkConnector.close(self)
|
|
|
|
ServerDownlinkConnector.close(self)
|