71 KiB
Main Table of Contents
obs-websocket 5.0.0 Protocol
General Intro
obs-websocket provides a feature-rich RPC communication protocol, giving access to much of OBS's feature set. This document contains everything you should know in order to make a connection and use obs-websocket's functionality to the fullest.
Design Goals
- Abstraction of identification, events, requests, and batch requests into dedicated message types
- Conformity of request naming using similar terms like
Get
,Set
,Get[x]List
,Start[x]
,Toggle[x]
- Conformity of OBS data field names like
sourceName
,sourceKind
,sourceType
,sceneName
,sceneItemName
- Error code response system - integer corrosponds to type of error, with optional comment
- Possible support for multiple message encoding options: JSON and MessagePack
- PubSub system - Allow clients to specify which events they do or don't want to receive from OBS
- RPC versioning - Client and server negotiate the latest version of the obs-websocket protocol to communicate with.
Connecting to obs-websocket
Here's info on how to connect to obs-websocket
Connection steps
These steps should be followed precisely. Failure to connect to the server as instructed will likely result in your client being treated in an undefined way.
-
Initial HTTP request made to the obs-websocket server.
- The
Sec-WebSocket-Protocol
header can be used to tell obs-websocket which kind of message encoding to use. By default, obs-websocket uses JSON over text. Available subprotocols:obswebsocket.json
- JSON over text framesobswebsocket.msgpack
- MsgPack over binary frames
- The
-
Once the connection is upgraded, the websocket server will immediately send an OpCode 0
Hello
message to the client. -
The client listens for the
Hello
and responds with an OpCode 1Identify
containing all appropriate session parameters.- If there is an
authentication
field in themessageData
object, the server requires authentication, and the steps in Creating an authentication string should be followed. - If there is no
authentication
field, the resultingIdentify
object sent to the server does not require anauthentication
string. - The client determines if the server's
rpcVersion
is supported, and if not it provides its closest supported version inIdentify
.
- If there is an
-
The server receives and processes the
Identify
sent by the client.- If authentication is required and the
Identify
message data does not contain anauthentication
string, or the string is not correct, the connection is closed withWebSocketCloseCode::AuthenticationFailed
- If the client has requested an
rpcVersion
which the server cannot use, the connection is closed withWebSocketCloseCode::UnsupportedRpcVersion
. This system allows both the server and client to have seamless backwards compatability. - If any other parameters are malformed (invalid type, etc), the connection is closed with an appropriate close code.
- If authentication is required and the
-
Once identification is processed on the server, the server responds to the client with an OpCode 2
Identified
. -
The client will begin receiving events from obs-websocket and may now make requests to obs-websocket.
-
At any time after a client has been identified, it may send an OpCode 3
Reidentify
message to update certain allowed session parameters. The server will respond in the same way it does during initial identification.
Connection Notes
- If a binary frame is received when using the
obswebsocket.json
(default) subprotocol, or a text frame is received while using theobswebsocket.msgpack
subprotocol, the connection is closed withWebSocketCloseCode::MessageDecodeError
. - The obs-websocket server listens for any messages containing a
request-type
field in the first level JSON from unidentified clients. If a message matches, the connection is closed withWebSocketCloseCode::UnsupportedRpcVersion
and a warning is logged. - If a message with a
messageType
is not recognized to the obs-websocket server, the connection is closed withWebSocketCloseCode::UnknownOpCode
. - At no point may the client send any message other than a single
Identify
before it has received anIdentified
. Doing so will result in the connection being closed withWebSocketCloseCode::NotIdentified
.
Creating an authentication string
obs-websocket uses SHA256 to transmit authentication credentials. The server starts by sending an object in the authentication
field of its Hello
message data. The client processes the authentication challenge and responds via the authentication
string in the Identify
message data.
For this guide, we'll be using supersecretpassword
as the password.
The authentication
object in Hello
looks like this (example):
{
"challenge": "+IxH4CnCiqpX1rM9scsNynZzbOe4KhDeYcTNS3PDaeY=",
"salt": "lM1GncleQOaCu9lT1yeUZhFYnqhsLLP1G5lAGo3ixaI="
}
To generate the authentication string, follow these steps:
- Concatenate the websocket password with the
salt
provided by the server (password + salt
) - Generate an SHA256 binary hash of the result and base64 encode it, known as a base64 secret.
- Concatenate the base64 secret with the
challenge
sent by the server (base64_secret + challenge
) - Generate a binary SHA256 hash of that result and base64 encode it. You now have your
authentication
string.
For real-world examples of the authentication
string creation, refer to the obs-websocket client libraries listed on the README.
Message Types (OpCodes)
The following message types are the low-level message types which may be sent to and from obs-websocket.
Messages sent from the obs-websocket server or client may contain these first-level fields, known as the base object:
{
"op": number,
"d": object
}
op
is aWebSocketOpCode
OpCode.d
is an object of the data fields associated with the operation.
Hello (OpCode 0)
- Sent from: obs-websocket
- Sent to: Freshly connected websocket client
- Description: First message sent from the server immediately on client connection. Contains authentication information if auth is required. Also contains RPC version for version negotiation.
Data Keys:
{
"obsWebSocketVersion": string,
"rpcVersion": number,
"authentication": object(optional)
}
rpcVersion
is a version number which gets incremented on each breaking change to the obs-websocket protocol. Its usage in this context is to provide the current rpc version that the server would like to use.
Example Messages: Authentication is required
{
"op": 0,
"d": {
"obsWebSocketVersion": "5.0.0",
"rpcVersion": 1,
"authentication": {
"challenge": "+IxH4CnCiqpX1rM9scsNynZzbOe4KhDeYcTNS3PDaeY=",
"salt": "lM1GncleQOaCu9lT1yeUZhFYnqhsLLP1G5lAGo3ixaI="
}
}
}
Authentication is not required
{
"op": 0,
"d": {
"obsWebSocketVersion": "5.0.0",
"rpcVersion": 1
}
}
Identify (OpCode 1)
- Sent from: Freshly connected websocket client
- Sent to: obs-websocket
- Description: Response to
Hello
message, should contain authentication string if authentication is required, along with PubSub subscriptions and other session parameters.
Data Keys:
{
"rpcVersion": number,
"authentication": string(optional),
"ignoreInvalidMessages": bool(optional) = false,
"eventSubscriptions": number(optional) = (EventSubscription::All)
}
rpcVersion
is the version number that the client would like the obs-websocket server to use.- When
ignoreInvalidMessages
is true, the socket will not be closed forWebSocketCloseCode
:MessageDecodeError
,UnknownOpCode
, orMissingDataKey
. Instead, the message will be logged and ignored. eventSubscriptions
is a bitmask ofEventSubscriptions
items to subscribe to events and event categories at will. By default, all event categories are subscribed, except for events marked as high volume. High volume events must be explicitly subscribed to.
Example Message:
{
"op": 1,
"d": {
"rpcVersion": 1,
"authentication": "Dj6cLS+jrNA0HpCArRg0Z/Fc+YHdt2FQfAvgD1mip6Y=",
"eventSubscriptions": 33
}
}
Identified (OpCode 2)
- Sent from: obs-websocket
- Sent to: Freshly identified client
- Description: The identify request was received and validated, and the connection is now ready for normal operation.
Data Keys:
{
"negotiatedRpcVersion": number
}
- If rpc version negotiation succeeds, the server determines the RPC version to be used and gives it to the client as
negotiatedRpcVersion
Example Message:
{
"op": 2,
"d": {
"negotiatedRpcVersion": 1
}
}
Reidentify (OpCode 3)
- Sent from: Identified client
- Sent to: obs-websocket
- Description: Sent at any time after initial identification to update the provided session parameters.
Data Keys:
{
"ignoreInvalidMessages": bool(optional) = false,
"eventSubscriptions": number(optional) = (EventSubscription::All)
}
- Only the listed parameters may be changed after initial identification. To change a parameter not listed, you must reconnect to the obs-websocket server.
Event (OpCode 5)
- Sent from: obs-websocket
- Sent to: All subscribed and identified clients
- Description: An event coming from OBS has occured. Eg scene switched, source muted.
Data Keys:
{
"eventType": string,
"eventIntent": number,
"eventData": object(optional)
}
eventIntent
is the original intent required to be subscribed to in order to receive the event.
Example Message:
{
"op": 5,
"d": {
"eventType": "StudioModeStateChanged",
"eventIntent": 1,
"eventData": {
"studioModeEnabled": true
}
}
}
Request (OpCode 6)
- Sent from: Identified client
- Sent to: obs-websocket
- Description: Client is making a request to obs-websocket. Eg get current scene, create source.
Data Keys:
{
"requestType": string,
"requestId": string,
"requestData": object(optional),
}
Example Message:
{
"op": 6,
"d": {
"requestType": "SetCurrentScene",
"requestId": "f819dcf0-89cc-11eb-8f0e-382c4ac93b9c",
"requestData": {
"sceneName": "Scene 12"
}
}
}
RequestResponse (OpCode 7)
- Sent from: obs-websocket
- Sent to: Identified client which made the request
- Description: obs-websocket is responding to a request coming from a client.
Data Keys:
{
"requestType": string,
"requestId": string,
"requestStatus": object,
"responseData": object(optional)
}
- The
requestType
andrequestId
are simply mirrors of what was sent by the client.
requestStatus
object:
{
"result": bool,
"code": number,
"comment": string(optional)
}
result
istrue
if the request resulted inRequestStatus::Success
. False if otherwise.code
is aRequestStatus
code.comment
may be provided by the server on errors to offer further details on why a request failed.
Example Messages: Successful Response
{
"op": 7,
"d": {
"requestType": "SetCurrentScene",
"requestId": "f819dcf0-89cc-11eb-8f0e-382c4ac93b9c",
"requestStatus": {
"result": true,
"code": 100
}
}
}
Failure Response
{
"op": 7,
"d": {
"requestType": "SetCurrentScene",
"requestId": "f819dcf0-89cc-11eb-8f0e-382c4ac93b9c",
"requestStatus": {
"result": false,
"code": 608,
"comment": "Parameter: sceneName"
}
}
}
RequestBatch (OpCode 8)
- Sent from: Identified client
- Sent to: obs-websocket
- Description: Client is making a batch of requests for obs-websocket. Requests are processed serially (in order) by the server.
Data Keys:
{
"requestId": string,
"haltOnFailure": bool(optional) = false,
"executionType": number(optional) = RequestBatchExecutionType::SerialRealtime
"requests": array<object>
}
- When
haltOnFailure
istrue
, the processing of requests will be halted on first failure. Returns only the processed requests inRequestBatchResponse
. - Requests in the
requests
array follow the same structure as theRequest
payload data format, howeverrequestId
is an optional field.
RequestBatchResponse (OpCode 9)
- Sent from: obs-websocket
- Sent to: Identified client which made the request
- Description: obs-websocket is responding to a request batch coming from the client.
Data Keys:
{
"requestId": string,
"results": array<object>
}
Enums
These are enumeration declarations, which are referenced throughout obs-websocket's protocol.
Enumerations Table of Contents
- WebSocketOpCode
- WebSocketCloseCode
- WebSocketCloseCode::DontClose
- WebSocketCloseCode::UnknownReason
- WebSocketCloseCode::MessageDecodeError
- WebSocketCloseCode::MissingDataField
- WebSocketCloseCode::InvalidDataFieldType
- WebSocketCloseCode::InvalidDataFieldValue
- WebSocketCloseCode::UnknownOpCode
- WebSocketCloseCode::NotIdentified
- WebSocketCloseCode::AlreadyIdentified
- WebSocketCloseCode::AuthenticationFailed
- WebSocketCloseCode::UnsupportedRpcVersion
- WebSocketCloseCode::SessionInvalidated
- WebSocketCloseCode::UnsupportedFeature
- RequestBatchExecutionType
- RequestStatus
- RequestStatus::Unknown
- RequestStatus::NoError
- RequestStatus::Success
- RequestStatus::MissingRequestType
- RequestStatus::UnknownRequestType
- RequestStatus::GenericError
- RequestStatus::UnsupportedRequestBatchExecutionType
- RequestStatus::MissingRequestField
- RequestStatus::MissingRequestData
- RequestStatus::InvalidRequestField
- RequestStatus::InvalidRequestFieldType
- RequestStatus::RequestFieldOutOfRange
- RequestStatus::RequestFieldEmpty
- RequestStatus::TooManyRequestFields
- RequestStatus::OutputRunning
- RequestStatus::OutputNotRunning
- RequestStatus::OutputPaused
- RequestStatus::OutputNotPaused
- RequestStatus::OutputDisabled
- RequestStatus::StudioModeActive
- RequestStatus::StudioModeNotActive
- RequestStatus::ResourceNotFound
- RequestStatus::ResourceAlreadyExists
- RequestStatus::InvalidResourceType
- RequestStatus::NotEnoughResources
- RequestStatus::InvalidResourceState
- RequestStatus::InvalidInputKind
- RequestStatus::ResourceCreationFailed
- RequestStatus::ResourceActionFailed
- RequestStatus::RequestProcessingFailed
- RequestStatus::CannotAct
- EventSubscription
- EventSubscription::None
- EventSubscription::General
- EventSubscription::Config
- EventSubscription::Scenes
- EventSubscription::Inputs
- EventSubscription::Transitions
- EventSubscription::Filters
- EventSubscription::Outputs
- EventSubscription::SceneItems
- EventSubscription::MediaInputs
- EventSubscription::ExternalPlugins
- EventSubscription::All
- EventSubscription::InputVolumeMeters
- EventSubscription::InputActiveStateChanged
- EventSubscription::InputShowStateChanged
- EventSubscription::SceneItemTransformChanged
WebSocketOpCode
WebSocketOpCode::Hello
The initial message sent by obs-websocket to newly connected clients.
- Identifier Value:
0
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::Identify
The message sent by a newly connected client to obs-websocket in response to a Hello
.
- Identifier Value:
1
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::Identified
The response sent by obs-websocket to a client after it has successfully identified with obs-websocket.
- Identifier Value:
2
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::Reidentify
The message sent by an already-identified client to update identification parameters.
- Identifier Value:
3
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::Event
The message sent by obs-websocket containing an event payload.
- Identifier Value:
5
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::Request
The message sent by a client to obs-websocket to perform a request.
- Identifier Value:
6
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::RequestResponse
The message sent by obs-websocket in response to a particular request from a client.
- Identifier Value:
7
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::RequestBatch
The message sent by a client to obs-websocket to perform a batch of requests.
- Identifier Value:
8
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketOpCode::RequestBatchResponse
The message sent by obs-websocket in response to a particular batch of requests from a client.
- Identifier Value:
9
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode
WebSocketCloseCode::DontClose
For internal use only to tell the request handler not to perform any close action.
- Identifier Value:
0
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::UnknownReason
Unknown reason, should never be used.
- Identifier Value:
4000
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::MessageDecodeError
The server was unable to decode the incoming websocket message.
- Identifier Value:
4002
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::MissingDataField
A data field is required but missing from the payload.
- Identifier Value:
4003
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::InvalidDataFieldType
A data field's value type is invalid.
- Identifier Value:
4004
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::InvalidDataFieldValue
A data field's value is invalid.
- Identifier Value:
4005
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::UnknownOpCode
The specified op
was invalid or missing.
- Identifier Value:
4006
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::NotIdentified
The client sent a websocket message without first sending Identify
message.
- Identifier Value:
4007
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::AlreadyIdentified
The client sent an Identify
message while already identified.
Note: Once a client has identified, only Reidentify
may be used to change session parameters.
- Identifier Value:
4008
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::AuthenticationFailed
The authentication attempt (via Identify
) failed.
- Identifier Value:
4009
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::UnsupportedRpcVersion
The server detected the usage of an old version of the obs-websocket RPC protocol.
- Identifier Value:
4010
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::SessionInvalidated
The websocket session has been invalidated by the obs-websocket server.
Note: This is the code used by the Kick
button in the UI Session List. If you receive this code, you must not automatically reconnect.
- Identifier Value:
4011
- Latest Supported RPC Version:
1
- Added in v5.0.0
WebSocketCloseCode::UnsupportedFeature
A requested feature is not supported due to hardware/software limitations.
- Identifier Value:
4012
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestBatchExecutionType
RequestBatchExecutionType::None
Not a request batch.
- Identifier Value:
-1
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestBatchExecutionType::SerialRealtime
A request batch which processes all requests serially, as fast as possible.
Note: To introduce artificial delay, use the Sleep
request and the sleepMillis
request field.
- Identifier Value:
0
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestBatchExecutionType::SerialFrame
A request batch type which processes all requests serially, in sync with the graphics thread. Designed to provide high accuracy for animations.
Note: To introduce artificial delay, use the Sleep
request and the sleepFrames
request field.
- Identifier Value:
1
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestBatchExecutionType::Parallel
A request batch type which processes all requests using all available threads in the thread pool.
Note: This is mainly experimental, and only really shows its colors during requests which require lots of
active processing, like GetSourceScreenshot
.
- Identifier Value:
2
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus
RequestStatus::Unknown
Unknown status, should never be used.
- Identifier Value:
0
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::NoError
For internal use to signify a successful field check.
- Identifier Value:
10
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::Success
The request has succeeded.
- Identifier Value:
100
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::MissingRequestType
The requestType
field is missing from the request data.
- Identifier Value:
203
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::UnknownRequestType
The request type is invalid or does not exist.
- Identifier Value:
204
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::GenericError
Generic error code.
Note: A comment is required to be provided by obs-websocket.
- Identifier Value:
205
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::UnsupportedRequestBatchExecutionType
The request batch execution type is not supported.
- Identifier Value:
206
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::MissingRequestField
A required request field is missing.
- Identifier Value:
300
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::MissingRequestData
The request does not have a valid requestData object.
- Identifier Value:
301
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::InvalidRequestField
Generic invalid request field message.
Note: A comment is required to be provided by obs-websocket.
- Identifier Value:
400
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::InvalidRequestFieldType
A request field has the wrong data type.
- Identifier Value:
401
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::RequestFieldOutOfRange
A request field (number) is outside of the allowed range.
- Identifier Value:
402
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::RequestFieldEmpty
A request field (string or array) is empty and cannot be.
- Identifier Value:
403
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::TooManyRequestFields
There are too many request fields (eg. a request takes two optionals, where only one is allowed at a time).
- Identifier Value:
404
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::OutputRunning
An output is running and cannot be in order to perform the request.
- Identifier Value:
500
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::OutputNotRunning
An output is not running and should be.
- Identifier Value:
501
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::OutputPaused
An output is paused and should not be.
- Identifier Value:
502
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::OutputNotPaused
An output is not paused and should be.
- Identifier Value:
503
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::OutputDisabled
An output is disabled and should not be.
- Identifier Value:
504
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::StudioModeActive
Studio mode is active and cannot be.
- Identifier Value:
505
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::StudioModeNotActive
Studio mode is not active and should be.
- Identifier Value:
506
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::ResourceNotFound
The resource was not found.
Note: Resources are any kind of object in obs-websocket, like inputs, profiles, outputs, etc.
- Identifier Value:
600
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::ResourceAlreadyExists
The resource already exists.
- Identifier Value:
601
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::InvalidResourceType
The type of resource found is invalid.
- Identifier Value:
602
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::NotEnoughResources
There are not enough instances of the resource in order to perform the request.
- Identifier Value:
603
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::InvalidResourceState
The state of the resource is invalid. For example, if the resource is blocked from being accessed.
- Identifier Value:
604
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::InvalidInputKind
The specified input (obs_source_t-OBS_SOURCE_TYPE_INPUT) had the wrong kind.
- Identifier Value:
605
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::ResourceCreationFailed
Creating the resource failed.
- Identifier Value:
700
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::ResourceActionFailed
Performing an action on the resource failed.
- Identifier Value:
701
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::RequestProcessingFailed
Processing the request failed unexpectedly.
Note: A comment is required to be provided by obs-websocket.
- Identifier Value:
702
- Latest Supported RPC Version:
1
- Added in v5.0.0
RequestStatus::CannotAct
The combination of request fields cannot be used to perform an action.
- Identifier Value:
703
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription
EventSubscription::None
Subcription value used to disable all events.
- Identifier Value:
0
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::General
Subscription value to receive events in the General
category.
- Identifier Value:
(1 << 0)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::Config
Subscription value to receive events in the Config
category.
- Identifier Value:
(1 << 1)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::Scenes
Subscription value to receive events in the Scenes
category.
- Identifier Value:
(1 << 2)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::Inputs
Subscription value to receive events in the Inputs
category.
- Identifier Value:
(1 << 3)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::Transitions
Subscription value to receive events in the Transitions
category.
- Identifier Value:
(1 << 4)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::Filters
Subscription value to receive events in the Filters
category.
- Identifier Value:
(1 << 5)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::Outputs
Subscription value to receive events in the Outputs
category.
- Identifier Value:
(1 << 6)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::SceneItems
Subscription value to receive events in the SceneItems
category.
- Identifier Value:
(1 << 7)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::MediaInputs
Subscription value to receive events in the MediaInputs
category.
- Identifier Value:
(1 << 8)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::ExternalPlugins
Subscription value to receive the ExternalPluginEvent
event.
- Identifier Value:
(1 << 9)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::All
Helper to receive all non-high-volume events.
- Identifier Value:
(General | Config | Scenes | Inputs | Transitions | Filters | Outputs | SceneItems | MediaInputs | ExternalPlugins)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::InputVolumeMeters
Subscription value to receive the InputVolumeMeters
high-volume event.
- Identifier Value:
(1 << 16)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::InputActiveStateChanged
Subscription value to receive the InputActiveStateChanged
high-volume event.
- Identifier Value:
(1 << 17)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::InputShowStateChanged
Subscription value to receive the InputShowStateChanged
high-volume event.
- Identifier Value:
(1 << 18)
- Latest Supported RPC Version:
1
- Added in v5.0.0
EventSubscription::SceneItemTransformChanged
Subscription value to receive the SceneItemTransformChanged
high-volume event.
- Identifier Value:
(1 << 19)
- Latest Supported RPC Version:
1
- Added in v5.0.0
Events
Events Table of Contents
General
ExitStarted
OBS has begun the shutdown process.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
StudioModeStateChanged
Studio mode has been enabled or disabled.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
studioModeEnabled | Boolean | True == Enabled, False == Disabled |
VendorEvent
An event has been emitted from a vendor.
A vendor is a unique name registered by a third-party plugin or script, which allows for custom requests and events to be added to obs-websocket. If a plugin or script implements vendor requests or events, documentation is expected to be provided with them.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
vendorName | String | Name of the vendor emitting the event |
eventType | String | Vendor-provided event typedef |
eventData | Object | Vendor-provided event data. {} if event does not provide any data |
Config
CurrentSceneCollectionChanging
The current scene collection has begun changing.
Note: We recommend using this event to trigger a pause of all polling requests, as performing any requests during a scene collection change is considered undefined behavior and can cause crashes!
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
sceneCollectionName | String | Name of the current scene collection |
CurrentSceneCollectionChanged
The current scene collection has changed.
Note: If polling has been paused during CurrentSceneCollectionChanging
, this is the que to restart polling.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
sceneCollectionName | String | Name of the new scene collection |
SceneCollectionListChanged
The scene collection list has changed.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
sceneCollections | Array | Updated list of scene collections |
CurrentProfileChanging
The current profile has begun changing.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
profileName | String | Name of the current profile |
CurrentProfileChanged
The current profile has changed.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
profileName | String | Name of the new profile |
ProfileListChanged
The profile list has changed.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Data Fields:
Name | Type | Description |
---|---|---|
profiles | Array | Updated list of profiles |
Requests
Requests Table of Contents
- General
- Config
- Sources
- Inputs
- GetInputList
- GetInputKindList
- CreateInput
- RemoveInput
- SetInputName
- GetInputDefaultSettings
- GetInputSettings
- SetInputSettings
- GetInputMute
- SetInputMute
- ToggleInputMute
- GetInputVolume
- SetInputVolume
- GetInputAudioSyncOffset
- SetInputAudioSyncOffset
- GetInputAudioMonitorType
- SetInputAudioMonitorType
- GetInputPropertiesListPropertyItems
- PressInputPropertiesButton
General
GetVersion
Gets data about the current plugin and RPC version.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
obsVersion | String | Current OBS Studio version |
obsWebSocketVersion | String | Current obs-websocket version |
rpcVersion | Number | Current latest obs-websocket RPC version |
availableRequests | Array | Array of available RPC requests for the currently negotiated RPC version |
GetStats
Gets statistics about OBS, obs-websocket, and the current session.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
cpuUsage | Number | Current CPU usage in percent |
memoryUsage | Number | Amount of memory in MB currently being used by OBS |
availableDiskSpace | Number | Available disk space on the device being used for recording storage |
activeFps | Number | Current FPS being rendered |
averageFrameRenderTime | Number | Average time in milliseconds that OBS is taking to render a frame |
renderSkippedFrames | Number | Number of frames skipped by OBS in the render thread |
renderTotalFrames | Number | Total number of frames outputted by the render thread |
outputSkippedFrames | Number | Number of frames skipped by OBS in the output thread |
outputTotalFrames | Number | Total number of frames outputted by the output thread |
webSocketSessionIncomingMessages | Number | Total number of messages received by obs-websocket from the client |
webSocketSessionOutgoingMessages | Number | Total number of messages sent by obs-websocket to the client |
BroadcastCustomEvent
Broadcasts a CustomEvent
to all WebSocket clients. Receivers are clients which are identified and subscribed.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
eventData | Object | Data payload to emit to all receivers | None | N/A |
CallVendorRequest
Call a request registered to a vendor.
A vendor is a unique name registered by a third-party plugin or script, which allows for custom requests and events to be added to obs-websocket. If a plugin or script implements vendor requests or events, documentation is expected to be provided with them.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
vendorName | String | Name of the vendor to use | None | N/A |
requestType | String | The request type to call | None | N/A |
?requestData | Object | Object containing appropriate request data | None | {} |
Response Fields:
Name | Type | Description |
---|---|---|
responseData | Object | Object containing appropriate response data. {} if request does not provide any response data |
GetHotkeyList
Gets an array of all hotkey names in OBS
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
hotkeys | Array | Array of hotkey names |
TriggerHotkeyByName
Triggers a hotkey using its name. See GetHotkeyList
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
hotkeyName | String | Name of the hotkey to trigger | None | N/A |
TriggerHotkeyByKeySequence
Triggers a hotkey using a sequence of keys.
- Complexity Rating:
4/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
?keyId | String | The OBS key ID to use. See https://github.com/obsproject/obs-studio/blob/master/libobs/obs-hotkeys.h | None | Not pressed |
?keyModifiers | Object | Object containing key modifiers to apply | None | Ignored |
?keyModifiers.shift | Boolean | Press Shift | None | Not pressed |
?keyModifiers.control | Boolean | Press CTRL | None | Not pressed |
?keyModifiers.alt | Boolean | Press ALT | None | Not pressed |
?keyModifiers.command | Boolean | Press CMD (Mac) | None | Not pressed |
GetStudioModeEnabled
Gets whether studio is enabled.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
studioModeEnabled | Boolean | Whether studio mode is enabled |
SetStudioModeEnabled
Enables or disables studio mode
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
studioModeEnabled | Boolean | True == Enabled, False == Disabled | None | N/A |
Sleep
Sleeps for a time duration or number of frames. Only available in request batches with types SERIAL_REALTIME
or SERIAL_FRAME
.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sleepMillis | Number | Number of milliseconds to sleep for (if SERIAL_REALTIME mode) |
>= 0, <= 50000 | N/A |
sleepFrames | Number | Number of frames to sleep for (if SERIAL_FRAME mode) |
>= 0, <= 10000 | N/A |
Config
GetPersistentData
Gets the value of a "slot" from the selected persistent data realm.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
realm | String | The data realm to select. OBS_WEBSOCKET_DATA_REALM_GLOBAL or OBS_WEBSOCKET_DATA_REALM_PROFILE |
None | N/A |
slotName | String | The name of the slot to retrieve data from | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
slotValue | String | Value associated with the slot. null if not set |
SetPersistentData
Sets the value of a "slot" from the selected persistent data realm.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
realm | String | The data realm to select. OBS_WEBSOCKET_DATA_REALM_GLOBAL or OBS_WEBSOCKET_DATA_REALM_PROFILE |
None | N/A |
slotName | String | The name of the slot to retrieve data from | None | N/A |
slotValue | Any | The value to apply to the slot | None | N/A |
GetSceneCollectionList
Gets an array of all scene collections
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
currentSceneCollectionName | String | The name of the current scene collection |
sceneCollections | Array | Array of all available scene collections |
SetCurrentSceneCollection
Switches to a scene collection.
Note: This will block until the collection has finished changing.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneCollectionName | String | Name of the scene collection to switch to | None | N/A |
CreateSceneCollection
Creates a new scene collection, switching to it in the process.
Note: This will block until the collection has finished changing.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneCollectionName | String | Name for the new scene collection | None | N/A |
GetProfileList
Gets an array of all profiles
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
currentProfileName | String | The name of the current profile |
profiles | Array | Array of all available profiles |
SetCurrentProfile
Switches to a profile.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
profileName | String | Name of the profile to switch to | None | N/A |
CreateProfile
Creates a new profile, switching to it in the process
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
profileName | String | Name for the new profile | None | N/A |
RemoveProfile
Removes a profile. If the current profile is chosen, it will change to a different profile first.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
profileName | String | Name of the profile to remove | None | N/A |
GetProfileParameter
Gets a parameter from the current profile's configuration.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
parameterCategory | String | Category of the parameter to get | None | N/A |
parameterName | String | Name of the parameter to get | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
parameterValue | String | Value associated with the parameter. null if not set and no default |
defaultParameterValue | String | Default value associated with the parameter. null if no default |
SetProfileParameter
Sets the value of a parameter in the current profile's configuration.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
parameterCategory | String | Category of the parameter to set | None | N/A |
parameterName | String | Name of the parameter to set | None | N/A |
parameterValue | String | Value of the parameter to set. Use null to delete |
None | N/A |
GetVideoSettings
Gets the current video settings.
Note: To get the true FPS value, divide the FPS numerator by the FPS denominator. Example: 60000/1001
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
fpsNumerator | Number | Numerator of the fractional FPS value |
fpsDenominator | Number | Denominator of the fractional FPS value |
baseWidth | Number | Width of the base (canvas) resolution in pixels |
baseHeight | Number | Height of the base (canvas) resolution in pixels |
outputWidth | Number | Width of the output resolution in pixels |
outputHeight | Number | Height of the output resolution in pixels |
SetVideoSettings
Sets the current video settings.
Note: Fields must be specified in pairs. For example, you cannot set only baseWidth
without needing to specify baseHeight
.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
?fpsNumerator | Number | Numerator of the fractional FPS value | >= 1 | Not changed |
?fpsDenominator | Number | Denominator of the fractional FPS value | >= 1 | Not changed |
?baseWidth | Number | Width of the base (canvas) resolution in pixels | >= 1, <= 4096 | Not changed |
?baseHeight | Number | Height of the base (canvas) resolution in pixels | >= 1, <= 4096 | Not changed |
?outputWidth | Number | Width of the output resolution in pixels | >= 1, <= 4096 | Not changed |
?outputHeight | Number | Height of the output resolution in pixels | >= 1, <= 4096 | Not changed |
GetStreamServiceSettings
Gets the current stream service settings (stream destination).
- Complexity Rating:
4/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
streamServiceType | String | Stream service type, like rtmp_custom or rtmp_common |
streamServiceSettings | Object | Stream service settings |
SetStreamServiceSettings
Sets the current stream service settings (stream destination).
Note: Simple RTMP settings can be set with type rtmp_custom
and the settings fields server
and key
.
- Complexity Rating:
4/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
streamServiceType | String | Type of stream service to apply. Example: rtmp_common or rtmp_custom |
None | N/A |
streamServiceSettings | Object | Settings to apply to the service | None | N/A |
Sources
GetSceneList
Gets an array of all scenes in OBS.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
scenes | Array | Array of scenes in OBS |
currentProgramSceneName | String | Current program scene |
currentPreviewSceneName | String | Current preview scene. null if not in studio mode |
GetCurrentProgramScene
Gets the current program scene.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
currentProgramSceneName | String | Current program scene |
SetCurrentProgramScene
Sets the current program scene.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneName | String | Scene to set as the current program scene | None | N/A |
GetCurrentPreviewScene
Gets the current preview scene.
Only available when studio mode is enabled.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Response Fields:
Name | Type | Description |
---|---|---|
currentPreviewSceneName | String | Current preview scene |
SetCurrentPreviewScene
Sets the current preview scene.
Only available when studio mode is enabled.
- Complexity Rating:
1/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneName | String | Scene to set as the current preview scene | None | N/A |
CreateScene
Creates a new scene in OBS.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneName | String | Name for the new scene | None | N/A |
RemoveScene
Removes a scene from OBS.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneName | String | Name of the scene to remove | None | N/A |
SetSceneName
Sets the name of a scene (rename).
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneName | String | Name of the scene to be renamed | None | N/A |
newSceneName | String | New name for the scene | None | N/A |
GetSourceActive
Gets the active and show state of a source.
Compatible with inputs and scenes.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sourceName | String | Name of the source to get the active state of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
videoActive | Boolean | Whether the source is showing in Program |
videoShowing | Boolean | Whether the source is showing in the UI (Preview, Projector, Properties) |
GetSourceScreenshot
Gets a Base64-encoded screenshot of a source.
The imageWidth
and imageHeight
parameters are treated as "scale to inner", meaning the smallest ratio will be used and the aspect ratio of the original resolution is kept.
If imageWidth
and imageHeight
are not specified, the compressed image will use the full resolution of the source.
Compatible with inputs and scenes.
- Complexity Rating:
4/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sourceName | String | Name of the source to take a screenshot of | None | N/A |
imageFormat | String | Image compression format to use. Use GetVersion to get compatible image formats |
None | N/A |
?imageWidth | Number | Width to scale the screenshot to | >= 8, <= 4096 | Source value is used |
?imageHeight | Number | Height to scale the screenshot to | >= 8, <= 4096 | Source value is used |
?imageCompressionQuality | Number | Compression quality to use. 0 for high compression, 100 for uncompressed. -1 to use "default" (whatever that means, idk) | >= -1, <= 100 | -1 |
Response Fields:
Name | Type | Description |
---|---|---|
imageData | String | Base64-encoded screenshot |
SaveSourceScreenshot
Saves a screenshot of a source to the filesystem.
The imageWidth
and imageHeight
parameters are treated as "scale to inner", meaning the smallest ratio will be used and the aspect ratio of the original resolution is kept.
If imageWidth
and imageHeight
are not specified, the compressed image will use the full resolution of the source.
Compatible with inputs and scenes.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sourceName | String | Name of the source to take a screenshot of | None | N/A |
imageFormat | String | Image compression format to use. Use GetVersion to get compatible image formats |
None | N/A |
imageFilePath | String | Path to save the screenshot file to. Eg. C:\Users\user\Desktop\screenshot.png |
None | N/A |
?imageWidth | Number | Width to scale the screenshot to | >= 8, <= 4096 | Source value is used |
?imageHeight | Number | Height to scale the screenshot to | >= 8, <= 4096 | Source value is used |
?imageCompressionQuality | Number | Compression quality to use. 0 for high compression, 100 for uncompressed. -1 to use "default" (whatever that means, idk) | >= -1, <= 100 | -1 |
Response Fields:
Name | Type | Description |
---|---|---|
imageData | String | Base64-encoded screenshot |
Inputs
GetInputList
Gets an array of all inputs in OBS.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
?inputKind | String | Restrict the array to only inputs of the specified kind | None | All kinds included |
Response Fields:
Name | Type | Description |
---|---|---|
inputs | Array | Array of inputs |
GetInputKindList
Gets an array of all available input kinds in OBS.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
?unversioned | Boolean | True == Return all kinds as unversioned, False == Return with version suffixes (if available) | None | false |
Response Fields:
Name | Type | Description |
---|---|---|
inputKinds | Array | Array of input kinds |
CreateInput
Creates a new input, adding it as a scene item to the specified scene.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
sceneName | String | Name of the scene to add the input to as a scene item | None | N/A |
inputName | String | Name of the new input to created | None | N/A |
inputKind | String | The kind of input to be created | None | N/A |
?inputSettings | Object | Settings object to initialize the input with | None | Default settings used |
?sceneItemEnabled | Boolean | Whether to set the created scene item to enabled or disabled | None | True |
Response Fields:
Name | Type | Description |
---|---|---|
sceneItemId | Number | ID of the newly created scene item |
RemoveInput
Removes an existing input.
Note: Will immediately remove all associated scene items.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to remove | None | N/A |
SetInputName
Sets the name of an input (rename).
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Current input name | None | N/A |
newInputName | String | New name for the input | None | N/A |
GetInputDefaultSettings
Gets the default settings for an input kind.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputKind | String | Input kind to get the default settings for | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
defaultInputSettings | Object | Object of default settings for the input kind |
GetInputSettings
Gets the settings of an input.
Note: Does not include defaults. To create the entire settings object, overlay inputSettings
over the defaultInputSettings
provided by GetInputDefaultSettings
.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to get the settings of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
inputSettings | Object | Object of settings for the input |
inputKind | String | The kind of the input |
SetInputSettings
Sets the settings of an input.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to set the settings of | None | N/A |
inputSettings | Object | Object of settings to apply | None | N/A |
GetInputMute
Gets the audio mute state of an input.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of input to get the mute state of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
inputMuted | Boolean | Whether the input is muted |
SetInputMute
Sets the audio mute state of an input.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to set the mute state of | None | N/A |
inputMuted | Boolean | Whether to mute the input or not | None | N/A |
ToggleInputMute
Toggles the audio mute state of an input.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to toggle the mute state of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
inputMuted | Boolean | Whether the input has been muted or unmuted |
GetInputVolume
Gets the current volume setting of an input.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to get the volume of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
inputVolumeMul | Number | Volume setting in mul |
inputVolumeDb | Number | Volume setting in dB |
SetInputVolume
Sets the volume setting of an input.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to set the volume of | None | N/A |
?inputVolumeMul | Number | Volume setting in mul | >= 0, <= 20 | inputVolumeDb should be specified |
?inputVolumeDb | Number | Volume setting in dB | >= -100, <= -26 | inputVolumeMul should be specified |
GetInputAudioSyncOffset
Gets the audio sync offset of an input.
Note: The audio sync offset can be negative too!
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to get the audio sync offset of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
inputAudioSyncOffset | Number | Audio sync offset in milliseconds |
SetInputAudioSyncOffset
Sets the audio sync offset of an input.
- Complexity Rating:
3/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to set the audio sync offset of | None | N/A |
inputAudioSyncOffset | Number | New audio sync offset in milliseconds | >= -950, <= 20000 | N/A |
GetInputAudioMonitorType
Gets the audio monitor type of an input.
The available audio monitor types are:
-
OBS_MONITORING_TYPE_NONE
-
OBS_MONITORING_TYPE_MONITOR_ONLY
-
OBS_MONITORING_TYPE_MONITOR_AND_OUTPUT
-
Complexity Rating:
2/5
-
Latest Supported RPC Version:
1
-
Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to get the audio monitor type of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
monitorType | String | Audio monitor type |
SetInputAudioMonitorType
Sets the audio monitor type of an input.
- Complexity Rating:
2/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input to set the audio monitor type of | None | N/A |
monitorType | String | Audio monitor type | None | N/A |
GetInputPropertiesListPropertyItems
Gets the items of a list property from an input's properties.
Note: Use this in cases where an input provides a dynamic, selectable list of items. For example, display capture, where it provides a list of available displays.
- Complexity Rating:
4/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input | None | N/A |
propertyName | String | Name of the list property to get the items of | None | N/A |
Response Fields:
Name | Type | Description |
---|---|---|
propertyItems | Array | Array of items in the list property |
PressInputPropertiesButton
Presses a button in the properties of an input.
Note: Use this in cases where there is a button in the properties of an input that cannot be accessed in any other way. For example, browser sources, where there is a refresh button.
- Complexity Rating:
4/5
- Latest Supported RPC Version:
1
- Added in v5.0.0
Request Fields:
Name | Type | Description | Value Restrictions | ?Default Behavior |
---|---|---|---|---|
inputName | String | Name of the input | None | N/A |
propertyName | String | Name of the button property to press | None | N/A |