mirror of
https://github.com/onyx-and-iris/obsws-ruby.git
synced 2026-04-09 09:53:29 +00:00
Compare commits
22 Commits
implement-
...
dev
| Author | SHA1 | Date | |
|---|---|---|---|
| 3c892623fa | |||
|
|
92b36ecce4 | ||
| 1dc8bf10f7 | |||
|
|
426a7d6628 | ||
| e1146913f9 | |||
|
|
78ca03e610 | ||
| 03174b9e40 | |||
|
|
63dd131d61 | ||
| 6ffae8e6c7 | |||
|
|
2878c31819 | ||
| 2e774ef185 | |||
|
|
3e661b23a3 | ||
| fac83a0dde | |||
| 4c4746fe8a | |||
| 3a0f298045 | |||
| a4b70b6a98 | |||
| 7c20063866 | |||
| 7cf05fbe08 | |||
| 587e861bbe | |||
| 3f255d6b45 | |||
| 9bd2b53b3d | |||
| 61c9a7b365 |
@@ -1,7 +1,7 @@
|
|||||||
PATH
|
PATH
|
||||||
remote: .
|
remote: .
|
||||||
specs:
|
specs:
|
||||||
obsws (0.5.8)
|
obsws (0.6.2)
|
||||||
waitutil (~> 0.2.1)
|
waitutil (~> 0.2.1)
|
||||||
websocket-driver (~> 0.7.5)
|
websocket-driver (~> 0.7.5)
|
||||||
|
|
||||||
@@ -19,9 +19,9 @@ GEM
|
|||||||
racc
|
racc
|
||||||
racc (1.7.1)
|
racc (1.7.1)
|
||||||
rainbow (3.1.1)
|
rainbow (3.1.1)
|
||||||
rake (11.3.0)
|
rake (13.0.6)
|
||||||
regexp_parser (2.8.1)
|
regexp_parser (2.8.1)
|
||||||
rexml (3.2.5)
|
rexml (3.4.2)
|
||||||
rubocop (1.52.1)
|
rubocop (1.52.1)
|
||||||
json (~> 2.3)
|
json (~> 2.3)
|
||||||
parallel (~> 1.10)
|
parallel (~> 1.10)
|
||||||
@@ -58,11 +58,12 @@ GEM
|
|||||||
|
|
||||||
PLATFORMS
|
PLATFORMS
|
||||||
x64-mingw-ucrt
|
x64-mingw-ucrt
|
||||||
|
x86_64-linux
|
||||||
|
|
||||||
DEPENDENCIES
|
DEPENDENCIES
|
||||||
minitest (~> 5.16, >= 5.16.3)
|
minitest (~> 5.16, >= 5.16.3)
|
||||||
obsws!
|
obsws!
|
||||||
rake (~> 11.2, >= 11.2.2)
|
rake (~> 13.0, >= 11.2.2)
|
||||||
standard (~> 1.30)
|
standard (~> 1.30)
|
||||||
|
|
||||||
BUNDLED WITH
|
BUNDLED WITH
|
||||||
|
|||||||
13
README.md
13
README.md
@@ -67,7 +67,9 @@ For a full list of requests refer to [Requests](https://github.com/obsproject/ob
|
|||||||
|
|
||||||
### Events
|
### Events
|
||||||
|
|
||||||
Register blocks with the Event client using the `on` method. The event data will be passed to the block.
|
Register blocks with the Event client using the `on` method. Event tokens should match the event name but snake cased.
|
||||||
|
|
||||||
|
The event data will be passed to the block.
|
||||||
|
|
||||||
example:
|
example:
|
||||||
|
|
||||||
@@ -76,10 +78,10 @@ class Observer
|
|||||||
def initialize
|
def initialize
|
||||||
@e_client = OBSWS::Events::Client.new(host: "localhost", port: 4455, password: "strongpassword")
|
@e_client = OBSWS::Events::Client.new(host: "localhost", port: 4455, password: "strongpassword")
|
||||||
# register blocks on event types.
|
# register blocks on event types.
|
||||||
@e_client.on(:current_program_scene_changed) do |data|
|
@e_client.on :current_program_scene_changed do |data|
|
||||||
...
|
...
|
||||||
end
|
end
|
||||||
@e_client.on(:input_mute_state_changed) do |data|
|
@e_client.on :input_mute_state_changed do |data|
|
||||||
...
|
...
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -95,11 +97,12 @@ For both request responses and event data you may inspect the available attribut
|
|||||||
example:
|
example:
|
||||||
|
|
||||||
```ruby
|
```ruby
|
||||||
resp = cl.get_version
|
resp = @r_client.get_version
|
||||||
p resp.attrs
|
p resp.attrs
|
||||||
|
|
||||||
def on_scene_created(data):
|
@e_client.on :input_mute_state_changed do |data|
|
||||||
p data.attrs
|
p data.attrs
|
||||||
|
end
|
||||||
```
|
```
|
||||||
|
|
||||||
### Errors
|
### Errors
|
||||||
|
|||||||
@@ -6,16 +6,16 @@ class Main
|
|||||||
@r_client = OBSWS::Requests::Client.new(**kwargs)
|
@r_client = OBSWS::Requests::Client.new(**kwargs)
|
||||||
@e_client = OBSWS::Events::Client.new(**kwargs)
|
@e_client = OBSWS::Events::Client.new(**kwargs)
|
||||||
|
|
||||||
@e_client.on(:current_program_scene_changed) do |data|
|
@e_client.on :current_program_scene_changed do |data|
|
||||||
puts "Switched to scene #{data.scene_name}"
|
puts "Switched to scene #{data.scene_name}"
|
||||||
end
|
end
|
||||||
@e_client.on(:scene_created) do |data|
|
@e_client.on :scene_created do |data|
|
||||||
puts "scene #{data.scene_name} has been created"
|
puts "scene #{data.scene_name} has been created"
|
||||||
end
|
end
|
||||||
@e_client.on(:input_mute_state_changed) do |data|
|
@e_client.on :input_mute_state_changed do |data|
|
||||||
puts "#{data.input_name} mute toggled"
|
puts "#{data.input_name} mute toggled"
|
||||||
end
|
end
|
||||||
@e_client.on(:exit_started) do
|
@e_client.on :exit_started do
|
||||||
puts "OBS closing!"
|
puts "OBS closing!"
|
||||||
@r_client.close
|
@r_client.close
|
||||||
@e_client.close
|
@e_client.close
|
||||||
|
|||||||
@@ -14,12 +14,12 @@ class Main
|
|||||||
subs = OBSWS::Events::SUBS::LOW_VOLUME | OBSWS::Events::SUBS::INPUTVOLUMEMETERS
|
subs = OBSWS::Events::SUBS::LOW_VOLUME | OBSWS::Events::SUBS::INPUTVOLUMEMETERS
|
||||||
@e_client = OBSWS::Events::Client.new(subs:, **kwargs)
|
@e_client = OBSWS::Events::Client.new(subs:, **kwargs)
|
||||||
|
|
||||||
@e_client.on(:input_mute_state_changed) do |data|
|
@e_client.on :input_mute_state_changed do |data|
|
||||||
if data.input_name == DEVICE
|
if data.input_name == DEVICE
|
||||||
puts "#{DEVICE} mute toggled"
|
puts "#{DEVICE} mute toggled"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@e_client.on(:input_volume_meters) do |data|
|
@e_client.on :input_volume_meters do |data|
|
||||||
fget = ->(x) { (x > 0) ? (20 * Math.log(x, 10)).round(1) : -200.0 }
|
fget = ->(x) { (x > 0) ? (20 * Math.log(x, 10)).round(1) : -200.0 }
|
||||||
|
|
||||||
data.inputs.each do |d|
|
data.inputs.each do |d|
|
||||||
|
|||||||
@@ -18,10 +18,13 @@ require_relative "obsws/event"
|
|||||||
require_relative "obsws/version"
|
require_relative "obsws/version"
|
||||||
|
|
||||||
module OBSWS
|
module OBSWS
|
||||||
|
# Base OBSWS error class
|
||||||
class OBSWSError < StandardError; end
|
class OBSWSError < StandardError; end
|
||||||
|
|
||||||
|
# Raised when a connection fails or times out
|
||||||
class OBSWSConnectionError < OBSWSError; end
|
class OBSWSConnectionError < OBSWSError; end
|
||||||
|
|
||||||
|
# Raised when a request returns an error code
|
||||||
class OBSWSRequestError < OBSWSError
|
class OBSWSRequestError < OBSWSError
|
||||||
attr_reader :req_name, :code
|
attr_reader :req_name, :code
|
||||||
|
|
||||||
|
|||||||
@@ -28,8 +28,8 @@ module OBSWS
|
|||||||
ALL = LOW_VOLUME | HIGH_VOLUME
|
ALL = LOW_VOLUME | HIGH_VOLUME
|
||||||
end
|
end
|
||||||
|
|
||||||
module EventDirector
|
module Director
|
||||||
include Util::String
|
using Util::CoreExtensions
|
||||||
|
|
||||||
def observers
|
def observers
|
||||||
@observers ||= {}
|
@observers ||= {}
|
||||||
@@ -40,23 +40,23 @@ module OBSWS
|
|||||||
end
|
end
|
||||||
|
|
||||||
def register(cbs)
|
def register(cbs)
|
||||||
cbs = [cbs] unless cbs.respond_to? :each
|
cbs = Array(cbs) unless cbs.respond_to? :each
|
||||||
cbs.each { |cb| on(cb.name[3..].to_sym, cb) }
|
cbs.each { |cb| on(cb.name[3..].to_sym, cb) }
|
||||||
end
|
end
|
||||||
|
|
||||||
def deregister(cbs)
|
def deregister(cbs)
|
||||||
cbs = [cbs] unless cbs.respond_to? :each
|
cbs = Array(cbs) unless cbs.respond_to? :each
|
||||||
cbs.each { |cb| observers[cb.name[3..].to_sym]&.reject! { |o| cbs.include? o } }
|
cbs.each { |cb| observers[cb.name[3..].to_sym]&.reject! { |o| cbs.include? o } }
|
||||||
end
|
end
|
||||||
|
|
||||||
def fire(event, data)
|
def fire(event, data)
|
||||||
observers[snakecase(event).to_sym]&.each { |block| data.empty? ? block.call : block.call(data) }
|
observers[event.snakecase.to_sym]&.each { |block| data.empty? ? block.call : block.call(data) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class Client
|
class Client
|
||||||
include Logging
|
include Logging
|
||||||
include EventDirector
|
include Events::Director
|
||||||
include Mixin::TearDown
|
include Mixin::TearDown
|
||||||
include Mixin::OPCodes
|
include Mixin::OPCodes
|
||||||
|
|
||||||
|
|||||||
@@ -1,16 +1,17 @@
|
|||||||
module OBSWS
|
module OBSWS
|
||||||
module Mixin
|
module Mixin
|
||||||
module Meta
|
module Meta
|
||||||
include Util::String
|
using Util::CoreExtensions
|
||||||
|
|
||||||
def make_field_methods(*params)
|
def make_field_methods(*params)
|
||||||
params.each do |param|
|
params.each do |param|
|
||||||
define_singleton_method(snakecase(param.to_s)) { @resp[param] }
|
define_singleton_method(param.to_s.snakecase) { @resp[param] }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class MetaObject
|
class MetaObject
|
||||||
|
using Util::CoreExtensions
|
||||||
include Mixin::Meta
|
include Mixin::Meta
|
||||||
|
|
||||||
def initialize(resp, fields)
|
def initialize(resp, fields)
|
||||||
@@ -21,14 +22,14 @@ module OBSWS
|
|||||||
|
|
||||||
def empty? = @fields.empty?
|
def empty? = @fields.empty?
|
||||||
|
|
||||||
def attrs = @fields.map { |f| snakecase(f.to_s) }
|
def attrs = @fields.map { |f| f.to_s.snakecase }
|
||||||
end
|
end
|
||||||
|
|
||||||
class Response < MetaObject; end
|
|
||||||
# Represents a request response object
|
# Represents a request response object
|
||||||
|
class Response < MetaObject; end
|
||||||
|
|
||||||
class Data < MetaObject; end
|
|
||||||
# Represents an event data object
|
# Represents an event data object
|
||||||
|
class Data < MetaObject; end
|
||||||
|
|
||||||
module TearDown
|
module TearDown
|
||||||
def stop_driver
|
def stop_driver
|
||||||
|
|||||||
@@ -1,16 +1,17 @@
|
|||||||
module OBSWS
|
module OBSWS
|
||||||
module Util
|
module Util
|
||||||
module String
|
module CoreExtensions
|
||||||
def camelcase(s)
|
refine String do
|
||||||
s.split("_").map(&:capitalize).join
|
def camelcase
|
||||||
|
split("_").map(&:capitalize).join
|
||||||
end
|
end
|
||||||
|
|
||||||
def snakecase(s)
|
def snakecase
|
||||||
s
|
gsub(/([A-Z]+)([A-Z][a-z])/, '\1_\2')
|
||||||
.gsub(/([A-Z]+)([A-Z][a-z])/, '\1_\2')
|
|
||||||
.gsub(/([a-z\d])([A-Z])/, '\1_\2')
|
.gsub(/([a-z\d])([A-Z])/, '\1_\2')
|
||||||
.downcase
|
.downcase
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ module OBSWS
|
|||||||
end
|
end
|
||||||
|
|
||||||
def patch
|
def patch
|
||||||
0
|
2
|
||||||
end
|
end
|
||||||
|
|
||||||
def to_a
|
def to_a
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ Gem::Specification.new do |spec|
|
|||||||
spec.add_runtime_dependency "waitutil", "~> 0.2.1"
|
spec.add_runtime_dependency "waitutil", "~> 0.2.1"
|
||||||
spec.add_development_dependency "standard", "~> 1.30"
|
spec.add_development_dependency "standard", "~> 1.30"
|
||||||
spec.add_development_dependency "minitest", "~> 5.16", ">= 5.16.3"
|
spec.add_development_dependency "minitest", "~> 5.16", ">= 5.16.3"
|
||||||
spec.add_development_dependency "rake", "~> 11.2", ">= 11.2.2"
|
spec.add_development_dependency "rake", ">= 11.2.2", "~> 13.0"
|
||||||
spec.required_ruby_version = ">= 3.0"
|
spec.required_ruby_version = ">= 3.0"
|
||||||
spec.metadata = {
|
spec.metadata = {
|
||||||
"source_code_uri" => "https://github.com/onyx-and-iris/obsws-ruby"
|
"source_code_uri" => "https://github.com/onyx-and-iris/obsws-ruby"
|
||||||
|
|||||||
Reference in New Issue
Block a user