pause main thread until authentication successful

lowercase debug strings

raise OBSWSError if no matching response received.
This commit is contained in:
norm 2022-10-23 04:39:22 +01:00
parent c3f39ea095
commit 9ac5b6f36f
3 changed files with 19 additions and 13 deletions

View File

@ -37,11 +37,8 @@ module OBSWS
@socket = TCPSocket.new(host, port) @socket = TCPSocket.new(host, port)
@driver = @driver =
WebSocket::Driver.client(Socket.new("ws://#{host}:#{port}", @socket)) WebSocket::Driver.client(Socket.new("ws://#{host}:#{port}", @socket))
@ready = false
@closed = false
@driver.on :open do |msg| @driver.on :open do |msg|
LOGGER.debug("driver socket open") LOGGER.debug("driver socket open")
@ready = true
end end
@driver.on :close do |msg| @driver.on :close do |msg|
LOGGER.debug("driver socket closed") LOGGER.debug("driver socket closed")
@ -51,21 +48,23 @@ module OBSWS
LOGGER.debug("received [#{msg}] passing to handler") LOGGER.debug("received [#{msg}] passing to handler")
msg_handler(JSON.parse(msg.data, symbolize_names: true)) msg_handler(JSON.parse(msg.data, symbolize_names: true))
end end
Thread.new { start_driver } start_driver
WaitUtil.wait_for_condition( WaitUtil.wait_for_condition(
"driver socket ready", "waiting authentication successful",
delay_sec: 0.01, delay_sec: 0.01,
timeout_sec: 0.5 timeout_sec: 3
) { @ready } ) { @authenticated }
end end
def start_driver def start_driver
@driver.start Thread.new do
@driver.start
loop do loop do
@driver.parse(@socket.readpartial(4096)) @driver.parse(@socket.readpartial(4096))
rescue EOFError rescue EOFError
break break
end
end end
end end
@ -85,6 +84,7 @@ module OBSWS
eventSubscriptions: @subs eventSubscriptions: @subs
} }
} }
LOGGER.debug("initiating authentication")
@driver.text(JSON.generate(payload)) @driver.text(JSON.generate(payload))
end end
@ -92,9 +92,11 @@ module OBSWS
op_code = data[:op] op_code = data[:op]
case op_code case op_code
when Mixin::OPCodes::HELLO when Mixin::OPCodes::HELLO
LOGGER.debug("hello received, passing to auth")
authenticate(data[:d][:authentication]) authenticate(data[:d][:authentication])
when Mixin::OPCodes::IDENTIFIED when Mixin::OPCodes::IDENTIFIED
LOGGER.debug("Authentication successful") LOGGER.debug("authentication successful")
@authenticated = true
when Mixin::OPCodes::EVENT, Mixin::OPCodes::REQUESTRESPONSE when Mixin::OPCodes::EVENT, Mixin::OPCodes::REQUESTRESPONSE
changed changed
notify_observers(op_code, data[:d]) notify_observers(op_code, data[:d])

View File

@ -51,6 +51,10 @@ module OBSWS
raise OBSWSError.new(error.join("\n")) raise OBSWSError.new(error.join("\n"))
end end
@response[:responseData] @response[:responseData]
rescue WaitUtil::TimeoutError
msg = "no response with matching id received"
LOGGER.error(msg)
raise OBSWSError.new(msg)
end end
def get_version def get_version