refactor: make connector use queues #4

Merged
pufereq merged 12 commits from refactor/make-connector-use-queues into develop 2025-11-30 17:35:33 +00:00
2 changed files with 150 additions and 146 deletions
Showing only changes of commit 54d2ba0083 - Show all commits

View File

@@ -7,7 +7,7 @@ import socket
import time import time
from typing import Callable from typing import Callable
from judas_protocol import Message from judas_protocol import Category, ControlAction, Message
class Connector: class Connector:
@@ -54,6 +54,8 @@ class Connector:
self.inbound_buffer: bytes = b"" self.inbound_buffer: bytes = b""
self.outbound_buffer: bytes = b"" self.outbound_buffer: bytes = b""
self.pending_acks: dict[str, tuple[Message, float]] = {}
self.running: bool = True self.running: bool = True
self.on_message: Callable[[Message], None] = on_message self.on_message: Callable[[Message], None] = on_message
@@ -169,7 +171,27 @@ class Connector:
) )
try: try:
message = Message.from_bytes(message_bytes) message = Message.from_bytes(message_bytes)
self.on_message(message) # handle incoming ACKs
if (
message.category == Category.CONTROL
and message.action == ControlAction.ACK
):
if (
message.payload.get("target_id")
in self.pending_acks
):
target_id = message.payload["target_id"]
self.logger.debug(
f"[.] Received ACK for message ID {target_id}"
)
del self.pending_acks[target_id]
else:
self.on_message(message)
if message.ack_required:
ack_message = Message.ack(message.id)
self.send(ack_message)
self._send_outbound()
except Exception as e: except Exception as e:
self.logger.error(f"[!] Failed to parse message: {e}") self.logger.error(f"[!] Failed to parse message: {e}")