Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Client ¶
type Client struct { // The backing websocket connection to the OBS websocket server. Conn *websocket.Conn // The time we're willing to wait to receive a response from the server. ResponseTimeout time.Duration // Events broadcast by the server when actions happen within OBS. IncomingEvents chan events.Event // Raw JSON message responses from the websocket server. IncomingResponses chan json.RawMessage Log Logger }
Client represents a requests client to the OBS websocket server. Its intention is to provide a means of communication between the top-level client and the category-level clients, so while its fields are exported, they should be of no interest to consumers of this library.
func (*Client) Disconnect ¶
Disconnect sends a message to the OBS websocket server to close the client's open connection. You don't really have to do this as any connections should close when your program terminates or interrupts. But here's a function anyways.
func (*Client) SendRequest ¶
SendRequest abstracts the logic every subclient uses to send a request and receive the corresponding response.
To get the response for a sent request, we can just read the next response from our channel. This works fine in a single-threaded context, and the message IDs of both the sent request and response should match.
In a concurrent context, this isn't necessarily true, but since gorilla/websocket doesn't handle concurrency anyways, who cares? We could technically add a mutex in between sending our request and reading from the channel, but ehh...
Interestingly, it does seem thread-safe if I use a totally different connection, in that connection A won't get a response from OBS for a request from connection B. So, message IDs must be unique per client? More interestingly, events appear to be broadcast to every client, maybe because they have no associated message ID?
type Logger ¶ added in v0.7.1
type Logger interface {
Printf(string, ...interface{})
}
Logger is a interface compatible with both the stdlib's logger and some third-party loggers.
type Params ¶
type Params interface { GetRequestType() string SetRequestType(string) GetMessageID() string SetMessageID(string) // The name of the actual request, i.e. "Abc" for "AbcParams". Used to // set the RequestType, so it's essentially an alias for GetRequestType. GetSelfName() string }
Params describes the behavior for any params-like object. Used to abstract the functionality of any request that embeds ParamsBasic within their fields.
type ParamsBasic ¶
type ParamsBasic struct { RequestType string `json:"request-type,omitempty"` MessageID string `json:"message-id,omitempty"` }
ParamsBasic represents common parameters for any request.
func (*ParamsBasic) GetMessageID ¶
func (o *ParamsBasic) GetMessageID() string
GetMessageID does what it says.
func (*ParamsBasic) GetRequestType ¶
func (o *ParamsBasic) GetRequestType() string
GetRequestType does what it says.
func (*ParamsBasic) SetMessageID ¶
func (o *ParamsBasic) SetMessageID(x string)
SetMessageID does what it says.
func (*ParamsBasic) SetRequestType ¶
func (o *ParamsBasic) SetRequestType(x string)
SetRequestType does what it says.
type Response ¶
Response describes the behavior for any response-like object. Used to abstract the functionality of any request's response that embeds ResponseBasic within their fields.
type ResponseBasic ¶
type ResponseBasic struct { MessageID string `json:"message-id,omitempty"` Status string `json:"status,omitempty"` Error string `json:"error,omitempty"` }
ResponseBasic represents common fields on any returned response.
func (*ResponseBasic) GetError ¶
func (o *ResponseBasic) GetError() string
GetError does what it says.
func (*ResponseBasic) GetMessageID ¶
func (o *ResponseBasic) GetMessageID() string
GetMessageID does what it says.
func (*ResponseBasic) GetStatus ¶
func (o *ResponseBasic) GetStatus() string
GetStatus does what it says.