2026-02-23 15:56:29 +00:00
|
|
|
from ... schema import RowsQueryRequest, RowsQueryResponse
|
2025-09-03 23:39:11 +01:00
|
|
|
from ... messaging import TranslatorRegistry
|
|
|
|
|
|
|
|
|
|
from . requestor import ServiceRequestor
|
|
|
|
|
|
2026-02-23 15:56:29 +00:00
|
|
|
class RowsQueryRequestor(ServiceRequestor):
|
2025-09-03 23:39:11 +01:00
|
|
|
def __init__(
|
2025-12-17 21:40:43 +00:00
|
|
|
self, backend, request_queue, response_queue, timeout,
|
2025-09-03 23:39:11 +01:00
|
|
|
consumer, subscriber,
|
|
|
|
|
):
|
|
|
|
|
|
2026-02-23 15:56:29 +00:00
|
|
|
super(RowsQueryRequestor, self).__init__(
|
2025-12-17 21:40:43 +00:00
|
|
|
backend=backend,
|
2025-09-03 23:39:11 +01:00
|
|
|
request_queue=request_queue,
|
|
|
|
|
response_queue=response_queue,
|
2026-02-23 15:56:29 +00:00
|
|
|
request_schema=RowsQueryRequest,
|
|
|
|
|
response_schema=RowsQueryResponse,
|
2025-09-03 23:39:11 +01:00
|
|
|
subscription = subscriber,
|
|
|
|
|
consumer_name = consumer,
|
|
|
|
|
timeout=timeout,
|
|
|
|
|
)
|
|
|
|
|
|
2026-02-23 15:56:29 +00:00
|
|
|
self.request_translator = TranslatorRegistry.get_request_translator("rows-query")
|
|
|
|
|
self.response_translator = TranslatorRegistry.get_response_translator("rows-query")
|
2025-09-03 23:39:11 +01:00
|
|
|
|
|
|
|
|
def to_request(self, body):
|
Pub/sub abstraction: decouple from Pulsar (#751)
Remove Pulsar-specific concepts from application code so that
the pub/sub backend is swappable via configuration.
Rename translators:
- to_pulsar/from_pulsar → decode/encode across all translator
classes, dispatch handlers, and tests (55+ files)
- from_response_with_completion → encode_with_completion
- Remove pulsar.schema.Record from translator base class
Queue naming (CLASS:TOPICSPACE:TOPIC):
- Replace topic() helper with queue() using new format:
flow:tg:name, request:tg:name, response:tg:name, state:tg:name
- Queue class implies persistence/TTL (no QoS in names)
- Update Pulsar backend map_topic() to parse new format
- Librarian queues use flow class (persistent, for chunking)
- Config push uses state class (persistent, last-value)
- Remove 15 dead topic imports from schema files
- Update init_trustgraph.py namespace: config → state
Confine Pulsar to pulsar_backend.py:
- Delete legacy PulsarClient class from pubsub.py
- Move add_args to add_pubsub_args() with standalone flag
for CLI tools (defaults to localhost)
- PulsarBackendConsumer.receive() catches _pulsar.Timeout,
raises standard TimeoutError
- Remove Pulsar imports from: async_processor, flow_processor,
log_level, all 11 client files, 4 storage writers, gateway
service, gateway config receiver
- Remove log_level/LoggerLevel from client API
- Rewrite tg-monitor-prompts to use backend abstraction
- Update tg-dump-queues to use add_pubsub_args
Also: pubsub-abstraction.md tech spec covering problem statement,
design goals, as-is requirements, candidate broker assessment,
approach, and implementation order.
2026-04-01 20:16:53 +01:00
|
|
|
return self.request_translator.decode(body)
|
2025-09-03 23:39:11 +01:00
|
|
|
|
|
|
|
|
def from_response(self, message):
|
Pub/sub abstraction: decouple from Pulsar (#751)
Remove Pulsar-specific concepts from application code so that
the pub/sub backend is swappable via configuration.
Rename translators:
- to_pulsar/from_pulsar → decode/encode across all translator
classes, dispatch handlers, and tests (55+ files)
- from_response_with_completion → encode_with_completion
- Remove pulsar.schema.Record from translator base class
Queue naming (CLASS:TOPICSPACE:TOPIC):
- Replace topic() helper with queue() using new format:
flow:tg:name, request:tg:name, response:tg:name, state:tg:name
- Queue class implies persistence/TTL (no QoS in names)
- Update Pulsar backend map_topic() to parse new format
- Librarian queues use flow class (persistent, for chunking)
- Config push uses state class (persistent, last-value)
- Remove 15 dead topic imports from schema files
- Update init_trustgraph.py namespace: config → state
Confine Pulsar to pulsar_backend.py:
- Delete legacy PulsarClient class from pubsub.py
- Move add_args to add_pubsub_args() with standalone flag
for CLI tools (defaults to localhost)
- PulsarBackendConsumer.receive() catches _pulsar.Timeout,
raises standard TimeoutError
- Remove Pulsar imports from: async_processor, flow_processor,
log_level, all 11 client files, 4 storage writers, gateway
service, gateway config receiver
- Remove log_level/LoggerLevel from client API
- Rewrite tg-monitor-prompts to use backend abstraction
- Update tg-dump-queues to use add_pubsub_args
Also: pubsub-abstraction.md tech spec covering problem statement,
design goals, as-is requirements, candidate broker assessment,
approach, and implementation order.
2026-04-01 20:16:53 +01:00
|
|
|
return self.response_translator.encode_with_completion(message)
|