omq 0.17.4 → 0.17.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 6c00d04d926fae9c6feb6526a611ff3f2ebc05812c7387ac0f97206c7a0b15bb
4
- data.tar.gz: 6af6b6ce8996c5f5082aac1f3b44339de359876aa17e01cfe2255b4681a053c6
3
+ metadata.gz: e3fe39e645fce312f16bc3a8601d73615ef0e7794057a3c521e7e971f252f1a0
4
+ data.tar.gz: 04d34473387abf066d2606f95008fa8c2be90f0952df0e85aea618063849fcf3
5
5
  SHA512:
6
- metadata.gz: 0db98892b62b35fc06e7a9fca89868ff1dec3bddc5ab4b5d4039bf29290702ed6db122c609c2311789159520638f9339744fdf20df39086b350f183c502075a9
7
- data.tar.gz: 85eae7b6058ead5d02cdddd41bec7dced3882b44267f1a566bc5964eab11eca6d56de23898f9912f985f86685f32690b2edfc555eee0784ac8f74da470c2cd71
6
+ metadata.gz: 76424e29263a30029e8b7d86a81e748afd490f43c26d0e8bb2d11047768cdbc8e07f3f1fe6fe3d77601e4037900af055cdb1825f2a1c3975f6d4c98cb552764f
7
+ data.tar.gz: '08af12564e152a4529ed2f2b0730bca14c1cb23285eac8d90a60e5681f258905762571ea43814ad5a8f717b40204e97b86273c39b5c08ee4729a563eaacf2f57'
data/CHANGELOG.md CHANGED
@@ -1,5 +1,16 @@
1
1
  # Changelog
2
2
 
3
+ ## 0.17.5 — 2026-04-10
4
+
5
+ ### Fixed
6
+
7
+ - **Handshake timeout.** `ConnectionLifecycle#handshake!` now wraps
8
+ the ZMTP greeting/handshake exchange with a timeout (reconnect
9
+ interval, floor 0.5s). Prevents a hang when a non-ZMQ service
10
+ accepts the TCP connection but never sends a ZMTP greeting (e.g.
11
+ macOS AirPlay Receiver on port 5000). On timeout the connection
12
+ tears down with `reconnect: true`, so the retry loop picks up.
13
+
3
14
  ## 0.17.4 — 2026-04-10
4
15
 
5
16
  ### Fixed
@@ -82,11 +82,11 @@ module OMQ
82
82
  mechanism: @engine.options.mechanism&.dup,
83
83
  max_message_size: @engine.options.max_message_size,
84
84
  )
85
- conn.handshake!
85
+ Async::Task.current.with_timeout(handshake_timeout) { conn.handshake! }
86
86
  Heartbeat.start(@barrier, conn, @engine.options, @engine.tasks)
87
87
  ready!(conn)
88
88
  @conn
89
- rescue Protocol::ZMTP::Error, *CONNECTION_LOST => error
89
+ rescue Protocol::ZMTP::Error, *CONNECTION_LOST, Async::TimeoutError => error
90
90
  @engine.emit_monitor_event(:handshake_failed, endpoint: @endpoint, detail: { error: error })
91
91
  conn&.close
92
92
  # Full tear-down with reconnect: without this, spawn_connection's
@@ -189,6 +189,18 @@ module OMQ
189
189
  end
190
190
 
191
191
 
192
+ # Handshake timeout: same logic as TCP.connect_timeout — derived
193
+ # from reconnect_interval (floor 0.5s). Prevents a hang when the
194
+ # peer accepts the TCP connection but never sends a ZMTP greeting
195
+ # (e.g. a non-ZMQ service on the same port).
196
+ #
197
+ def handshake_timeout
198
+ ri = @engine.options.reconnect_interval
199
+ ri = ri.end if ri.is_a?(Range)
200
+ [ri, 0.5].max
201
+ end
202
+
203
+
192
204
  def transition!(new_state)
193
205
  allowed = TRANSITIONS[@state]
194
206
  unless allowed&.include?(new_state)
data/lib/omq/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module OMQ
4
- VERSION = "0.17.4"
4
+ VERSION = "0.17.5"
5
5
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: omq
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.17.4
4
+ version: 0.17.5
5
5
  platform: ruby
6
6
  authors:
7
7
  - Patrik Wenger