Fix issues in PR #64

This commit is contained in:
R. Richard
2019-08-26 11:10:39 +02:00
committed by therealkrispet
parent 2e5867cc49
commit 965973a32f
9 changed files with 28 additions and 15 deletions

View File

@ -3,3 +3,4 @@ from .event_handler_factory_base import EventHandlerFactoryBase
from .control_event_handler import ControlEventHandler
from .fsm_aware_event_handler import FSMAwareEventHandler
from .signed_event_handler import SignedEventHandler
from .signed_control_event_handler import SignedControlEventHandler

View File

@ -4,6 +4,5 @@ from .event_handler import EventHandler
class ControlEventHandler(EventHandler): # pylint: disable=abstract-method
def _event_callback(self, message):
if message.get('intent') != Intent.EVENT.value:
self.handle_event(message, self.connector)
def _validate_message(self, message):
return message.get('intent') != Intent.EVENT.value

View File

@ -9,7 +9,11 @@ class EventHandler:
self.connector.register_callback(self._event_callback)
def _event_callback(self, message):
self.handle_event(message, self.connector)
if self._validate_message(message):
self.handle_event(message, self.connector)
def _validate_message(self, message):
return True
def handle_event(self, message, connector):
raise NotImplementedError()

View File

@ -0,0 +1,9 @@
from .control_event_handler import ControlEventHandler
from .signed_event_handler import SignedEventHandler
class SignedControlEventHandler(ControlEventHandler, SignedEventHandler):
def _validate_message(self, message):
return (
ControlEventHandler._validate_message(self, message) and
SignedEventHandler._validate_message(self, message)
)

View File

@ -2,19 +2,19 @@ import logging
from tfw.internals.crypto import KeyManager, verify_message
from .control_event_handler import ControlEventHandler
from .event_handler import EventHandler
LOG = logging.getLogger(__name__)
# pylint: disable=abstract-method
class SignedEventHandler(ControlEventHandler):
class SignedEventHandler(EventHandler):
def __init__(self, connector):
self._auth_key = KeyManager().auth_key
super().__init__(connector)
def _event_callback(self, message):
if verify_message(self._auth_key, message):
self.handle_event(message, self.connector)
else:
def _validate_message(self, message):
is_valid = verify_message(self._auth_key, message)
if not is_valid:
LOG.error('Message does not have valid signature: %s', message)
return is_valid

View File

@ -54,7 +54,7 @@ class ZMQUplinkConnector:
def send_message(self, message, scope=Scope.ZMQ, intent=None):
message['scope'] = scope.value
if isinstance(intent, Intent):
if intent is not None:
message['intent'] = intent.value
self._zmq_push_socket.send_multipart(serialize_tfw_msg(message))