Class: ModelContextProtocol::Server::StreamableHttpTransport::MessagePoller
- Inherits:
-
Object
- Object
- ModelContextProtocol::Server::StreamableHttpTransport::MessagePoller
- Defined in:
- lib/model_context_protocol/server/streamable_http_transport/message_poller.rb
Constant Summary collapse
- POLL_INTERVAL =
100ms
0.1
- BATCH_SIZE =
100
Instance Method Summary collapse
-
#initialize(redis_client, stream_registry, logger, &message_delivery_block) ⇒ MessagePoller
constructor
A new instance of MessagePoller.
- #running? ⇒ Boolean
- #start ⇒ Object
- #stop ⇒ Object
Constructor Details
#initialize(redis_client, stream_registry, logger, &message_delivery_block) ⇒ MessagePoller
Returns a new instance of MessagePoller.
9 10 11 12 13 14 15 16 |
# File 'lib/model_context_protocol/server/streamable_http_transport/message_poller.rb', line 9 def initialize(redis_client, stream_registry, logger, &) @redis = redis_client @stream_registry = stream_registry @logger = logger = @running = false @poll_thread = nil end |
Instance Method Details
#running? ⇒ Boolean
47 48 49 |
# File 'lib/model_context_protocol/server/streamable_http_transport/message_poller.rb', line 47 def running? @running && @poll_thread&.alive? end |
#start ⇒ Object
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
# File 'lib/model_context_protocol/server/streamable_http_transport/message_poller.rb', line 18 def start return if @running @running = true @poll_thread = Thread.new do poll_loop rescue => e @logger.error("Message poller thread error", error: e., backtrace: e.backtrace.first(5)) sleep 1 retry if @running end @poll_thread.name = "MCP-MessagePoller" if @poll_thread.respond_to?(:name=) @logger.debug("Message poller started") end |
#stop ⇒ Object
35 36 37 38 39 40 41 42 43 44 45 |
# File 'lib/model_context_protocol/server/streamable_http_transport/message_poller.rb', line 35 def stop @running = false if @poll_thread&.alive? @poll_thread.kill @poll_thread.join(timeout: 5) end @poll_thread = nil @logger.debug("Message poller stopped") end |