From 9ac5b6f36fe713a1a8960205b430a24b21af9370 Mon Sep 17 00:00:00 2001 From: norm Date: Sun, 23 Oct 2022 04:39:22 +0100 Subject: [PATCH] pause main thread until authentication successful lowercase debug strings raise OBSWSError if no matching response received. --- lib/obsws/base.rb | 28 +++++++++++++++------------- lib/obsws/req.rb | 4 ++++ obsws_rb.gemspec => obsws.gemspec | 0 3 files changed, 19 insertions(+), 13 deletions(-) rename obsws_rb.gemspec => obsws.gemspec (100%) diff --git a/lib/obsws/base.rb b/lib/obsws/base.rb index 3a703cb..1efe89f 100644 --- a/lib/obsws/base.rb +++ b/lib/obsws/base.rb @@ -37,11 +37,8 @@ module OBSWS @socket = TCPSocket.new(host, port) @driver = WebSocket::Driver.client(Socket.new("ws://#{host}:#{port}", @socket)) - @ready = false - @closed = false @driver.on :open do |msg| LOGGER.debug("driver socket open") - @ready = true end @driver.on :close do |msg| LOGGER.debug("driver socket closed") @@ -51,21 +48,23 @@ module OBSWS LOGGER.debug("received [#{msg}] passing to handler") msg_handler(JSON.parse(msg.data, symbolize_names: true)) end - Thread.new { start_driver } + start_driver WaitUtil.wait_for_condition( - "driver socket ready", + "waiting authentication successful", delay_sec: 0.01, - timeout_sec: 0.5 - ) { @ready } + timeout_sec: 3 + ) { @authenticated } end def start_driver - @driver.start + Thread.new do + @driver.start - loop do - @driver.parse(@socket.readpartial(4096)) - rescue EOFError - break + loop do + @driver.parse(@socket.readpartial(4096)) + rescue EOFError + break + end end end @@ -85,6 +84,7 @@ module OBSWS eventSubscriptions: @subs } } + LOGGER.debug("initiating authentication") @driver.text(JSON.generate(payload)) end @@ -92,9 +92,11 @@ module OBSWS op_code = data[:op] case op_code when Mixin::OPCodes::HELLO + LOGGER.debug("hello received, passing to auth") authenticate(data[:d][:authentication]) when Mixin::OPCodes::IDENTIFIED - LOGGER.debug("Authentication successful") + LOGGER.debug("authentication successful") + @authenticated = true when Mixin::OPCodes::EVENT, Mixin::OPCodes::REQUESTRESPONSE changed notify_observers(op_code, data[:d]) diff --git a/lib/obsws/req.rb b/lib/obsws/req.rb index 6d0a0cd..4ad1c4c 100644 --- a/lib/obsws/req.rb +++ b/lib/obsws/req.rb @@ -51,6 +51,10 @@ module OBSWS raise OBSWSError.new(error.join("\n")) end @response[:responseData] + rescue WaitUtil::TimeoutError + msg = "no response with matching id received" + LOGGER.error(msg) + raise OBSWSError.new(msg) end def get_version diff --git a/obsws_rb.gemspec b/obsws.gemspec similarity index 100% rename from obsws_rb.gemspec rename to obsws.gemspec