mirror of
https://github.com/onyx-and-iris/obsws-ruby.git
synced 2025-01-18 13:30:48 +00:00
pause main thread until authentication successful
lowercase debug strings raise OBSWSError if no matching response received.
This commit is contained in:
parent
c3f39ea095
commit
9ac5b6f36f
@ -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,15 +48,16 @@ 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
|
||||||
|
Thread.new do
|
||||||
@driver.start
|
@driver.start
|
||||||
|
|
||||||
loop do
|
loop do
|
||||||
@ -68,6 +66,7 @@ module OBSWS
|
|||||||
break
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def auth_token(salt:, challenge:)
|
def auth_token(salt:, challenge:)
|
||||||
Digest::SHA256.base64digest(
|
Digest::SHA256.base64digest(
|
||||||
@ -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])
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user