{ "enums": [ { "enumType": "EventSubscription", "enumIdentifiers": [ { "description": "Subcription value used to disable all events.", "enumIdentifier": "None", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 0 }, { "description": "Subscription value to receive events in the `General` category.", "enumIdentifier": "General", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 0)" }, { "description": "Subscription value to receive events in the `Config` category.", "enumIdentifier": "Config", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 1)" }, { "description": "Subscription value to receive events in the `Scenes` category.", "enumIdentifier": "Scenes", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 2)" }, { "description": "Subscription value to receive events in the `Inputs` category.", "enumIdentifier": "Inputs", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 3)" }, { "description": "Subscription value to receive events in the `Transitions` category.", "enumIdentifier": "Transitions", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 4)" }, { "description": "Subscription value to receive events in the `Filters` category.", "enumIdentifier": "Filters", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 5)" }, { "description": "Subscription value to receive events in the `Outputs` category.", "enumIdentifier": "Outputs", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 6)" }, { "description": "Subscription value to receive events in the `SceneItems` category.", "enumIdentifier": "SceneItems", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 7)" }, { "description": "Subscription value to receive events in the `MediaInputs` category.", "enumIdentifier": "MediaInputs", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 8)" }, { "description": "Subscription value to receive the `VendorEvent` event.", "enumIdentifier": "Vendors", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 9)" }, { "description": "Helper to receive all non-high-volume events.", "enumIdentifier": "All", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(General | Config | Scenes | Inputs | Transitions | Filters | Outputs | SceneItems | MediaInputs | Vendors)" }, { "description": "Subscription value to receive the `InputVolumeMeters` high-volume event.", "enumIdentifier": "InputVolumeMeters", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 16)" }, { "description": "Subscription value to receive the `InputActiveStateChanged` high-volume event.", "enumIdentifier": "InputActiveStateChanged", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 17)" }, { "description": "Subscription value to receive the `InputShowStateChanged` high-volume event.", "enumIdentifier": "InputShowStateChanged", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 18)" }, { "description": "Subscription value to receive the `SceneItemTransformChanged` high-volume event.", "enumIdentifier": "SceneItemTransformChanged", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "(1 << 19)" } ] }, { "enumType": "RequestBatchExecutionType", "enumIdentifiers": [ { "description": "Not a request batch.", "enumIdentifier": "None", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": "-1" }, { "description": "A request batch which processes all requests serially, as fast as possible.\n\nNote: To introduce artificial delay, use the `Sleep` request and the `sleepMillis` request field.", "enumIdentifier": "SerialRealtime", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 0 }, { "description": "A request batch type which processes all requests serially, in sync with the graphics thread. Designed to provide high accuracy for animations.\n\nNote: To introduce artificial delay, use the `Sleep` request and the `sleepFrames` request field.", "enumIdentifier": "SerialFrame", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 1 }, { "description": "A request batch type which processes all requests using all available threads in the thread pool.\n\nNote: This is mainly experimental, and only really shows its colors during requests which require lots of\nactive processing, like `GetSourceScreenshot`.", "enumIdentifier": "Parallel", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 2 } ] }, { "enumType": "RequestStatus", "enumIdentifiers": [ { "description": "Unknown status, should never be used.", "enumIdentifier": "Unknown", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 0 }, { "description": "For internal use to signify a successful field check.", "enumIdentifier": "NoError", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 10 }, { "description": "The request has succeeded.", "enumIdentifier": "Success", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 100 }, { "description": "The `requestType` field is missing from the request data.", "enumIdentifier": "MissingRequestType", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 203 }, { "description": "The request type is invalid or does not exist.", "enumIdentifier": "UnknownRequestType", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 204 }, { "description": "Generic error code.\n\nNote: A comment is required to be provided by obs-websocket.", "enumIdentifier": "GenericError", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 205 }, { "description": "The request batch execution type is not supported.", "enumIdentifier": "UnsupportedRequestBatchExecutionType", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 206 }, { "description": "A required request field is missing.", "enumIdentifier": "MissingRequestField", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 300 }, { "description": "The request does not have a valid requestData object.", "enumIdentifier": "MissingRequestData", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 301 }, { "description": "Generic invalid request field message.\n\nNote: A comment is required to be provided by obs-websocket.", "enumIdentifier": "InvalidRequestField", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 400 }, { "description": "A request field has the wrong data type.", "enumIdentifier": "InvalidRequestFieldType", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 401 }, { "description": "A request field (number) is outside of the allowed range.", "enumIdentifier": "RequestFieldOutOfRange", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 402 }, { "description": "A request field (string or array) is empty and cannot be.", "enumIdentifier": "RequestFieldEmpty", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 403 }, { "description": "There are too many request fields (eg. a request takes two optionals, where only one is allowed at a time).", "enumIdentifier": "TooManyRequestFields", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 404 }, { "description": "An output is running and cannot be in order to perform the request.", "enumIdentifier": "OutputRunning", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 500 }, { "description": "An output is not running and should be.", "enumIdentifier": "OutputNotRunning", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 501 }, { "description": "An output is paused and should not be.", "enumIdentifier": "OutputPaused", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 502 }, { "description": "An output is not paused and should be.", "enumIdentifier": "OutputNotPaused", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 503 }, { "description": "An output is disabled and should not be.", "enumIdentifier": "OutputDisabled", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 504 }, { "description": "Studio mode is active and cannot be.", "enumIdentifier": "StudioModeActive", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 505 }, { "description": "Studio mode is not active and should be.", "enumIdentifier": "StudioModeNotActive", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 506 }, { "description": "The resource was not found.\n\nNote: Resources are any kind of object in obs-websocket, like inputs, profiles, outputs, etc.", "enumIdentifier": "ResourceNotFound", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 600 }, { "description": "The resource already exists.", "enumIdentifier": "ResourceAlreadyExists", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 601 }, { "description": "The type of resource found is invalid.", "enumIdentifier": "InvalidResourceType", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 602 }, { "description": "There are not enough instances of the resource in order to perform the request.", "enumIdentifier": "NotEnoughResources", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 603 }, { "description": "The state of the resource is invalid. For example, if the resource is blocked from being accessed.", "enumIdentifier": "InvalidResourceState", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 604 }, { "description": "The specified input (obs_source_t-OBS_SOURCE_TYPE_INPUT) had the wrong kind.", "enumIdentifier": "InvalidInputKind", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 605 }, { "description": "Creating the resource failed.", "enumIdentifier": "ResourceCreationFailed", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 700 }, { "description": "Performing an action on the resource failed.", "enumIdentifier": "ResourceActionFailed", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 701 }, { "description": "Processing the request failed unexpectedly.\n\nNote: A comment is required to be provided by obs-websocket.", "enumIdentifier": "RequestProcessingFailed", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 702 }, { "description": "The combination of request fields cannot be used to perform an action.", "enumIdentifier": "CannotAct", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 703 } ] }, { "enumType": "WebSocketCloseCode", "enumIdentifiers": [ { "description": "For internal use only to tell the request handler not to perform any close action.", "enumIdentifier": "DontClose", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 0 }, { "description": "Unknown reason, should never be used.", "enumIdentifier": "UnknownReason", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4000 }, { "description": "The server was unable to decode the incoming websocket message.", "enumIdentifier": "MessageDecodeError", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4002 }, { "description": "A data field is required but missing from the payload.", "enumIdentifier": "MissingDataField", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4003 }, { "description": "A data field's value type is invalid.", "enumIdentifier": "InvalidDataFieldType", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4004 }, { "description": "A data field's value is invalid.", "enumIdentifier": "InvalidDataFieldValue", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4005 }, { "description": "The specified `op` was invalid or missing.", "enumIdentifier": "UnknownOpCode", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4006 }, { "description": "The client sent a websocket message without first sending `Identify` message.", "enumIdentifier": "NotIdentified", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4007 }, { "description": "The client sent an `Identify` message while already identified.\n\nNote: Once a client has identified, only `Reidentify` may be used to change session parameters.", "enumIdentifier": "AlreadyIdentified", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4008 }, { "description": "The authentication attempt (via `Identify`) failed.", "enumIdentifier": "AuthenticationFailed", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4009 }, { "description": "The server detected the usage of an old version of the obs-websocket RPC protocol.", "enumIdentifier": "UnsupportedRpcVersion", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4010 }, { "description": "The websocket session has been invalidated by the obs-websocket server.\n\nNote: This is the code used by the `Kick` button in the UI Session List. If you receive this code, you must not automatically reconnect.", "enumIdentifier": "SessionInvalidated", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4011 }, { "description": "A requested feature is not supported due to hardware/software limitations.", "enumIdentifier": "UnsupportedFeature", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 4012 } ] }, { "enumType": "WebSocketOpCode", "enumIdentifiers": [ { "description": "The initial message sent by obs-websocket to newly connected clients.", "enumIdentifier": "Hello", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 0 }, { "description": "The message sent by a newly connected client to obs-websocket in response to a `Hello`.", "enumIdentifier": "Identify", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 1 }, { "description": "The response sent by obs-websocket to a client after it has successfully identified with obs-websocket.", "enumIdentifier": "Identified", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 2 }, { "description": "The message sent by an already-identified client to update identification parameters.", "enumIdentifier": "Reidentify", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 3 }, { "description": "The message sent by obs-websocket containing an event payload.", "enumIdentifier": "Event", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 5 }, { "description": "The message sent by a client to obs-websocket to perform a request.", "enumIdentifier": "Request", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 6 }, { "description": "The message sent by obs-websocket in response to a particular request from a client.", "enumIdentifier": "RequestResponse", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 7 }, { "description": "The message sent by a client to obs-websocket to perform a batch of requests.", "enumIdentifier": "RequestBatch", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 8 }, { "description": "The message sent by obs-websocket in response to a particular batch of requests from a client.", "enumIdentifier": "RequestBatchResponse", "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "enumValue": 9 } ] } ], "requests": [ { "description": "Gets the value of a \"slot\" from the selected persistent data realm.", "requestType": "GetPersistentData", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "realm", "valueType": "String", "valueDescription": "The data realm to select. `OBS_WEBSOCKET_DATA_REALM_GLOBAL` or `OBS_WEBSOCKET_DATA_REALM_PROFILE`", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "slotName", "valueType": "String", "valueDescription": "The name of the slot to retrieve data from", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "slotValue", "valueType": "Any", "valueDescription": "Value associated with the slot. `null` if not set" } ] }, { "description": "Sets the value of a \"slot\" from the selected persistent data realm.", "requestType": "SetPersistentData", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "realm", "valueType": "String", "valueDescription": "The data realm to select. `OBS_WEBSOCKET_DATA_REALM_GLOBAL` or `OBS_WEBSOCKET_DATA_REALM_PROFILE`", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "slotName", "valueType": "String", "valueDescription": "The name of the slot to retrieve data from", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "slotValue", "valueType": "Any", "valueDescription": "The value to apply to the slot", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets an array of all scene collections", "requestType": "GetSceneCollectionList", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [], "responseFields": [ { "valueName": "currentSceneCollectionName", "valueType": "String", "valueDescription": "The name of the current scene collection" }, { "valueName": "sceneCollections", "valueType": "Array", "valueDescription": "Array of all available scene collections" } ] }, { "description": "Switches to a scene collection.\n\nNote: This will block until the collection has finished changing.", "requestType": "SetCurrentSceneCollection", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "sceneCollectionName", "valueType": "String", "valueDescription": "Name of the scene collection to switch to", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Creates a new scene collection, switching to it in the process.\n\nNote: This will block until the collection has finished changing.", "requestType": "CreateSceneCollection", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "sceneCollectionName", "valueType": "String", "valueDescription": "Name for the new scene collection", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets an array of all profiles", "requestType": "GetProfileList", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [], "responseFields": [ { "valueName": "currentProfileName", "valueType": "String", "valueDescription": "The name of the current profile" }, { "valueName": "profiles", "valueType": "Array", "valueDescription": "Array of all available profiles" } ] }, { "description": "Switches to a profile.", "requestType": "SetCurrentProfile", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "profileName", "valueType": "String", "valueDescription": "Name of the profile to switch to", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Creates a new profile, switching to it in the process", "requestType": "CreateProfile", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "profileName", "valueType": "String", "valueDescription": "Name for the new profile", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Removes a profile. If the current profile is chosen, it will change to a different profile first.", "requestType": "RemoveProfile", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "profileName", "valueType": "String", "valueDescription": "Name of the profile to remove", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets a parameter from the current profile's configuration.", "requestType": "GetProfileParameter", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "parameterCategory", "valueType": "String", "valueDescription": "Category of the parameter to get", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "parameterName", "valueType": "String", "valueDescription": "Name of the parameter to get", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "parameterValue", "valueType": "String", "valueDescription": "Value associated with the parameter. `null` if not set and no default" }, { "valueName": "defaultParameterValue", "valueType": "String", "valueDescription": "Default value associated with the parameter. `null` if no default" } ] }, { "description": "Sets the value of a parameter in the current profile's configuration.", "requestType": "SetProfileParameter", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "parameterCategory", "valueType": "String", "valueDescription": "Category of the parameter to set", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "parameterName", "valueType": "String", "valueDescription": "Name of the parameter to set", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "parameterValue", "valueType": "String", "valueDescription": "Value of the parameter to set. Use `null` to delete", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the current video settings.\n\nNote: To get the true FPS value, divide the FPS numerator by the FPS denominator. Example: `60000/1001`", "requestType": "GetVideoSettings", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [], "responseFields": [ { "valueName": "fpsNumerator", "valueType": "Number", "valueDescription": "Numerator of the fractional FPS value" }, { "valueName": "fpsDenominator", "valueType": "Number", "valueDescription": "Denominator of the fractional FPS value" }, { "valueName": "baseWidth", "valueType": "Number", "valueDescription": "Width of the base (canvas) resolution in pixels" }, { "valueName": "baseHeight", "valueType": "Number", "valueDescription": "Height of the base (canvas) resolution in pixels" }, { "valueName": "outputWidth", "valueType": "Number", "valueDescription": "Width of the output resolution in pixels" }, { "valueName": "outputHeight", "valueType": "Number", "valueDescription": "Height of the output resolution in pixels" } ] }, { "description": "Sets the current video settings.\n\nNote: Fields must be specified in pairs. For example, you cannot set only `baseWidth` without needing to specify `baseHeight`.", "requestType": "SetVideoSettings", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "fpsNumerator", "valueType": "Number", "valueDescription": "Numerator of the fractional FPS value", "valueRestrictions": ">= 1", "valueOptional": true, "valueOptionalBehavior": "Not changed" }, { "valueName": "fpsDenominator", "valueType": "Number", "valueDescription": "Denominator of the fractional FPS value", "valueRestrictions": ">= 1", "valueOptional": true, "valueOptionalBehavior": "Not changed" }, { "valueName": "baseWidth", "valueType": "Number", "valueDescription": "Width of the base (canvas) resolution in pixels", "valueRestrictions": ">= 1, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Not changed" }, { "valueName": "baseHeight", "valueType": "Number", "valueDescription": "Height of the base (canvas) resolution in pixels", "valueRestrictions": ">= 1, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Not changed" }, { "valueName": "outputWidth", "valueType": "Number", "valueDescription": "Width of the output resolution in pixels", "valueRestrictions": ">= 1, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Not changed" }, { "valueName": "outputHeight", "valueType": "Number", "valueDescription": "Height of the output resolution in pixels", "valueRestrictions": ">= 1, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Not changed" } ], "responseFields": [] }, { "description": "Gets the current stream service settings (stream destination).", "requestType": "GetStreamServiceSettings", "complexity": 4, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [], "responseFields": [ { "valueName": "streamServiceType", "valueType": "String", "valueDescription": "Stream service type, like `rtmp_custom` or `rtmp_common`" }, { "valueName": "streamServiceSettings", "valueType": "Object", "valueDescription": "Stream service settings" } ] }, { "description": "Sets the current stream service settings (stream destination).\n\nNote: Simple RTMP settings can be set with type `rtmp_custom` and the settings fields `server` and `key`.", "requestType": "SetStreamServiceSettings", "complexity": 4, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "requestFields": [ { "valueName": "streamServiceType", "valueType": "String", "valueDescription": "Type of stream service to apply. Example: `rtmp_common` or `rtmp_custom`", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "streamServiceSettings", "valueType": "Object", "valueDescription": "Settings to apply to the service", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets data about the current plugin and RPC version.", "requestType": "GetVersion", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [], "responseFields": [ { "valueName": "obsVersion", "valueType": "String", "valueDescription": "Current OBS Studio version" }, { "valueName": "obsWebSocketVersion", "valueType": "String", "valueDescription": "Current obs-websocket version" }, { "valueName": "rpcVersion", "valueType": "Number", "valueDescription": "Current latest obs-websocket RPC version" }, { "valueName": "availableRequests", "valueType": "Array", "valueDescription": "Array of available RPC requests for the currently negotiated RPC version" }, { "valueName": "supportedImageFormats", "valueType": "Array", "valueDescription": "Image formats available in `GetSourceScreenshot` and `SaveSourceScreenshot` requests." } ] }, { "description": "Gets statistics about OBS, obs-websocket, and the current session.", "requestType": "GetStats", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [], "responseFields": [ { "valueName": "cpuUsage", "valueType": "Number", "valueDescription": "Current CPU usage in percent" }, { "valueName": "memoryUsage", "valueType": "Number", "valueDescription": "Amount of memory in MB currently being used by OBS" }, { "valueName": "availableDiskSpace", "valueType": "Number", "valueDescription": "Available disk space on the device being used for recording storage" }, { "valueName": "activeFps", "valueType": "Number", "valueDescription": "Current FPS being rendered" }, { "valueName": "averageFrameRenderTime", "valueType": "Number", "valueDescription": "Average time in milliseconds that OBS is taking to render a frame" }, { "valueName": "renderSkippedFrames", "valueType": "Number", "valueDescription": "Number of frames skipped by OBS in the render thread" }, { "valueName": "renderTotalFrames", "valueType": "Number", "valueDescription": "Total number of frames outputted by the render thread" }, { "valueName": "outputSkippedFrames", "valueType": "Number", "valueDescription": "Number of frames skipped by OBS in the output thread" }, { "valueName": "outputTotalFrames", "valueType": "Number", "valueDescription": "Total number of frames outputted by the output thread" }, { "valueName": "webSocketSessionIncomingMessages", "valueType": "Number", "valueDescription": "Total number of messages received by obs-websocket from the client" }, { "valueName": "webSocketSessionOutgoingMessages", "valueType": "Number", "valueDescription": "Total number of messages sent by obs-websocket to the client" } ] }, { "description": "Broadcasts a `CustomEvent` to all WebSocket clients. Receivers are clients which are identified and subscribed.", "requestType": "BroadcastCustomEvent", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [ { "valueName": "eventData", "valueType": "Object", "valueDescription": "Data payload to emit to all receivers", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Call a request registered to a vendor.\n\nA 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.\nIf a plugin or script implements vendor requests or events, documentation is expected to be provided with them.", "requestType": "CallVendorRequest", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [ { "valueName": "vendorName", "valueType": "String", "valueDescription": "Name of the vendor to use", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "requestType", "valueType": "String", "valueDescription": "The request type to call", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "requestData", "valueType": "Object", "valueDescription": "Object containing appropriate request data", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "{}" } ], "responseFields": [ { "valueName": "responseData", "valueType": "Object", "valueDescription": "Object containing appropriate response data. {} if request does not provide any response data" } ] }, { "description": "Gets an array of all hotkey names in OBS", "requestType": "GetHotkeyList", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [], "responseFields": [ { "valueName": "hotkeys", "valueType": "Array", "valueDescription": "Array of hotkey names" } ] }, { "description": "Triggers a hotkey using its name. See `GetHotkeyList`", "requestType": "TriggerHotkeyByName", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [ { "valueName": "hotkeyName", "valueType": "String", "valueDescription": "Name of the hotkey to trigger", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Triggers a hotkey using a sequence of keys.", "requestType": "TriggerHotkeyByKeySequence", "complexity": 4, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [ { "valueName": "keyId", "valueType": "String", "valueDescription": "The OBS key ID to use. See https://github.com/obsproject/obs-studio/blob/master/libobs/obs-hotkeys.h", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "Not pressed" }, { "valueName": "keyModifiers", "valueType": "Object", "valueDescription": "Object containing key modifiers to apply", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "Ignored" }, { "valueName": "keyModifiers.shift", "valueType": "Boolean", "valueDescription": "Press Shift", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "Not pressed" }, { "valueName": "keyModifiers.control", "valueType": "Boolean", "valueDescription": "Press CTRL", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "Not pressed" }, { "valueName": "keyModifiers.alt", "valueType": "Boolean", "valueDescription": "Press ALT", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "Not pressed" }, { "valueName": "keyModifiers.command", "valueType": "Boolean", "valueDescription": "Press CMD (Mac)", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "Not pressed" } ], "responseFields": [] }, { "description": "Gets whether studio is enabled.", "requestType": "GetStudioModeEnabled", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [], "responseFields": [ { "valueName": "studioModeEnabled", "valueType": "Boolean", "valueDescription": "Whether studio mode is enabled" } ] }, { "description": "Enables or disables studio mode", "requestType": "SetStudioModeEnabled", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [ { "valueName": "studioModeEnabled", "valueType": "Boolean", "valueDescription": "True == Enabled, False == Disabled", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Sleeps for a time duration or number of frames. Only available in request batches with types `SERIAL_REALTIME` or `SERIAL_FRAME`.", "requestType": "Sleep", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "requestFields": [ { "valueName": "sleepMillis", "valueType": "Number", "valueDescription": "Number of milliseconds to sleep for (if `SERIAL_REALTIME` mode)", "valueRestrictions": ">= 0, <= 50000", "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sleepFrames", "valueType": "Number", "valueDescription": "Number of frames to sleep for (if `SERIAL_FRAME` mode)", "valueRestrictions": ">= 0, <= 10000", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets an array of all inputs in OBS.", "requestType": "GetInputList", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputKind", "valueType": "String", "valueDescription": "Restrict the array to only inputs of the specified kind", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "All kinds included" } ], "responseFields": [ { "valueName": "inputs", "valueType": "Array", "valueDescription": "Array of inputs" } ] }, { "description": "Gets an array of all available input kinds in OBS.", "requestType": "GetInputKindList", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "unversioned", "valueType": "Boolean", "valueDescription": "True == Return all kinds as unversioned, False == Return with version suffixes (if available)", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "false" } ], "responseFields": [ { "valueName": "inputKinds", "valueType": "Array", "valueDescription": "Array of input kinds" } ] }, { "description": "Creates a new input, adding it as a scene item to the specified scene.", "requestType": "CreateInput", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene to add the input to as a scene item", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the new input to created", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "inputKind", "valueType": "String", "valueDescription": "The kind of input to be created", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "inputSettings", "valueType": "Object", "valueDescription": "Settings object to initialize the input with", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "Default settings used" }, { "valueName": "sceneItemEnabled", "valueType": "Boolean", "valueDescription": "Whether to set the created scene item to enabled or disabled", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "True" } ], "responseFields": [ { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "ID of the newly created scene item" } ] }, { "description": "Removes an existing input.\n\nNote: Will immediately remove all associated scene items.", "requestType": "RemoveInput", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to remove", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Sets the name of an input (rename).", "requestType": "SetInputName", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Current input name", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "newInputName", "valueType": "String", "valueDescription": "New name for the input", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the default settings for an input kind.", "requestType": "GetInputDefaultSettings", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputKind", "valueType": "String", "valueDescription": "Input kind to get the default settings for", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "defaultInputSettings", "valueType": "Object", "valueDescription": "Object of default settings for the input kind" } ] }, { "description": "Gets the settings of an input.\n\nNote: Does not include defaults. To create the entire settings object, overlay `inputSettings` over the `defaultInputSettings` provided by `GetInputDefaultSettings`.", "requestType": "GetInputSettings", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to get the settings of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "inputSettings", "valueType": "Object", "valueDescription": "Object of settings for the input" }, { "valueName": "inputKind", "valueType": "String", "valueDescription": "The kind of the input" } ] }, { "description": "Sets the settings of an input.", "requestType": "SetInputSettings", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to set the settings of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "inputSettings", "valueType": "Object", "valueDescription": "Object of settings to apply", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "overlay", "valueType": "Boolean", "valueDescription": "True == apply the settings on top of existing ones, False == reset the input to its defaults, then apply settings.", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "true" } ], "responseFields": [] }, { "description": "Gets the audio mute state of an input.", "requestType": "GetInputMute", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of input to get the mute state of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "inputMuted", "valueType": "Boolean", "valueDescription": "Whether the input is muted" } ] }, { "description": "Sets the audio mute state of an input.", "requestType": "SetInputMute", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to set the mute state of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "inputMuted", "valueType": "Boolean", "valueDescription": "Whether to mute the input or not", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Toggles the audio mute state of an input.", "requestType": "ToggleInputMute", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to toggle the mute state of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "inputMuted", "valueType": "Boolean", "valueDescription": "Whether the input has been muted or unmuted" } ] }, { "description": "Gets the current volume setting of an input.", "requestType": "GetInputVolume", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to get the volume of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "inputVolumeMul", "valueType": "Number", "valueDescription": "Volume setting in mul" }, { "valueName": "inputVolumeDb", "valueType": "Number", "valueDescription": "Volume setting in dB" } ] }, { "description": "Sets the volume setting of an input.", "requestType": "SetInputVolume", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to set the volume of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "inputVolumeMul", "valueType": "Number", "valueDescription": "Volume setting in mul", "valueRestrictions": ">= 0, <= 20", "valueOptional": true, "valueOptionalBehavior": "`inputVolumeDb` should be specified" }, { "valueName": "inputVolumeDb", "valueType": "Number", "valueDescription": "Volume setting in dB", "valueRestrictions": ">= -100, <= -26", "valueOptional": true, "valueOptionalBehavior": "`inputVolumeMul` should be specified" } ], "responseFields": [] }, { "description": "Gets the audio sync offset of an input.\n\nNote: The audio sync offset can be negative too!", "requestType": "GetInputAudioSyncOffset", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to get the audio sync offset of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "inputAudioSyncOffset", "valueType": "Number", "valueDescription": "Audio sync offset in milliseconds" } ] }, { "description": "Sets the audio sync offset of an input.", "requestType": "SetInputAudioSyncOffset", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to set the audio sync offset of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "inputAudioSyncOffset", "valueType": "Number", "valueDescription": "New audio sync offset in milliseconds", "valueRestrictions": ">= -950, <= 20000", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the audio monitor type of an input.\n\nThe available audio monitor types are:\n- `OBS_MONITORING_TYPE_NONE`\n- `OBS_MONITORING_TYPE_MONITOR_ONLY`\n- `OBS_MONITORING_TYPE_MONITOR_AND_OUTPUT`", "requestType": "GetInputAudioMonitorType", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to get the audio monitor type of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "monitorType", "valueType": "String", "valueDescription": "Audio monitor type" } ] }, { "description": "Sets the audio monitor type of an input.", "requestType": "SetInputAudioMonitorType", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input to set the audio monitor type of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "monitorType", "valueType": "String", "valueDescription": "Audio monitor type", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the items of a list property from an input's properties.\n\nNote: 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.", "requestType": "GetInputPropertiesListPropertyItems", "complexity": 4, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "propertyName", "valueType": "String", "valueDescription": "Name of the list property to get the items of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "propertyItems", "valueType": "Array", "valueDescription": "Array of items in the list property" } ] }, { "description": "Presses a button in the properties of an input.\n\nNote: 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.", "requestType": "PressInputPropertiesButton", "complexity": 4, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "inputs", "requestFields": [ { "valueName": "inputName", "valueType": "String", "valueDescription": "Name of the input", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "propertyName", "valueType": "String", "valueDescription": "Name of the button property to press", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets a list of all scene items in a scene.\n\nScenes only", "requestType": "GetSceneItemList", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene to get the items of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "sceneItems", "valueType": "Array", "valueDescription": "Array of scene items in the scene" } ] }, { "description": "Basically GetSceneItemList, but for groups.\n\nUsing groups at all in OBS is discouraged, as they are very broken under the hood.\n\nGroups only", "requestType": "GetGroupItemList", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the group to get the items of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "sceneItems", "valueType": "Array", "valueDescription": "Array of scene items in the group" } ] }, { "description": "Searches a scene for a source, and returns its id.\n\nScenes and Groups", "requestType": "GetSceneItemId", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene or group to search in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sourceName", "valueType": "String", "valueDescription": "Name of the source to find", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item" } ] }, { "description": "Creates a new scene item using a source.\n\nScenes only", "requestType": "CreateSceneItem", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene to create the new item in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sourceName", "valueType": "String", "valueDescription": "Name of the source to add to the scene", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemEnabled", "valueType": "Boolean", "valueDescription": "Enable state to apply to the scene item on creation", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "True" } ], "responseFields": [ { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item" } ] }, { "description": "Removes a scene item from a scene.\n\nScenes only", "requestType": "RemoveSceneItem", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Duplicates a scene item, copying all transform and crop info.\n\nScenes only", "requestType": "DuplicateSceneItem", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "destinationSceneName", "valueType": "String", "valueDescription": "Name of the scene to create the duplicated item in", "valueRestrictions": null, "valueOptional": true, "valueOptionalBehavior": "`sceneName` is assumed" } ], "responseFields": [ { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the duplicated scene item" } ] }, { "description": "Gets the transform and crop info of a scene item.\n\nScenes and Groups", "requestType": "GetSceneItemTransform", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "sceneItemTransform", "valueType": "Object", "valueDescription": "Object containing scene item transform info" } ] }, { "description": "Sets the transform and crop info of a scene item.", "requestType": "SetSceneItemTransform", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemTransform", "valueType": "Object", "valueDescription": "Object containing scene item transform info to update", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the enable state of a scene item.\n\nScenes and Groups", "requestType": "GetSceneItemEnabled", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "sceneItemEnabled", "valueType": "Boolean", "valueDescription": "Whether the scene item is enabled. `true` for enabled, `false` for disabled" } ] }, { "description": "Sets the enable state of a scene item.\n\nScenes and Groups", "requestType": "SetSceneItemEnabled", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemEnabled", "valueType": "Boolean", "valueDescription": "New enable state of the scene item", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the lock state of a scene item.\n\nScenes and Groups", "requestType": "GetSceneItemLocked", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "sceneItemLocked", "valueType": "Boolean", "valueDescription": "Whether the scene item is locked. `true` for locked, `false` for unlocked" } ] }, { "description": "Sets the lock state of a scene item.\n\nScenes and Group", "requestType": "SetSceneItemLocked", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemLocked", "valueType": "Boolean", "valueDescription": "New lock state of the scene item", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the index position of a scene item in a scene.\n\nAn index of 0 is at the bottom of the source list in the UI.\n\nScenes and Groups", "requestType": "GetSceneItemIndex", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "sceneItemIndex", "valueType": "Number", "valueDescription": "Index position of the scene item" } ] }, { "description": "Sets the index position of a scene item in a scene.\n\nScenes and Groups", "requestType": "SetSceneItemIndex", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scene items", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene the item is in", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemId", "valueType": "Number", "valueDescription": "Numeric ID of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "sceneItemIndex", "valueType": "Number", "valueDescription": "New index position of the scene item", "valueRestrictions": ">= 0", "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets an array of all scenes in OBS.", "requestType": "GetSceneList", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [], "responseFields": [ { "valueName": "currentProgramSceneName", "valueType": "String", "valueDescription": "Current program scene" }, { "valueName": "currentPreviewSceneName", "valueType": "String", "valueDescription": "Current preview scene. `null` if not in studio mode" }, { "valueName": "scenes", "valueType": "Array", "valueDescription": "Array of scenes in OBS" } ] }, { "description": "Gets the current program scene.", "requestType": "GetCurrentProgramScene", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [], "responseFields": [ { "valueName": "currentProgramSceneName", "valueType": "String", "valueDescription": "Current program scene" } ] }, { "description": "Sets the current program scene.", "requestType": "SetCurrentProgramScene", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Scene to set as the current program scene", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the current preview scene.\n\nOnly available when studio mode is enabled.", "requestType": "GetCurrentPreviewScene", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [], "responseFields": [ { "valueName": "currentPreviewSceneName", "valueType": "String", "valueDescription": "Current preview scene" } ] }, { "description": "Sets the current preview scene.\n\nOnly available when studio mode is enabled.", "requestType": "SetCurrentPreviewScene", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Scene to set as the current preview scene", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Creates a new scene in OBS.", "requestType": "CreateScene", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name for the new scene", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Removes a scene from OBS.", "requestType": "RemoveScene", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene to remove", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Sets the name of a scene (rename).", "requestType": "SetSceneName", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "scenes", "requestFields": [ { "valueName": "sceneName", "valueType": "String", "valueDescription": "Name of the scene to be renamed", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "newSceneName", "valueType": "String", "valueDescription": "New name for the scene", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [] }, { "description": "Gets the active and show state of a source.\n\n**Compatible with inputs and scenes.**", "requestType": "GetSourceActive", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "sources", "requestFields": [ { "valueName": "sourceName", "valueType": "String", "valueDescription": "Name of the source to get the active state of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null } ], "responseFields": [ { "valueName": "videoActive", "valueType": "Boolean", "valueDescription": "Whether the source is showing in Program" }, { "valueName": "videoShowing", "valueType": "Boolean", "valueDescription": "Whether the source is showing in the UI (Preview, Projector, Properties)" } ] }, { "description": "Gets a Base64-encoded screenshot of a source.\n\nThe `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.\nIf `imageWidth` and `imageHeight` are not specified, the compressed image will use the full resolution of the source.\n\n**Compatible with inputs and scenes.**", "requestType": "GetSourceScreenshot", "complexity": 4, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "sources", "requestFields": [ { "valueName": "sourceName", "valueType": "String", "valueDescription": "Name of the source to take a screenshot of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "imageFormat", "valueType": "String", "valueDescription": "Image compression format to use. Use `GetVersion` to get compatible image formats", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "imageWidth", "valueType": "Number", "valueDescription": "Width to scale the screenshot to", "valueRestrictions": ">= 8, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Source value is used" }, { "valueName": "imageHeight", "valueType": "Number", "valueDescription": "Height to scale the screenshot to", "valueRestrictions": ">= 8, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Source value is used" }, { "valueName": "imageCompressionQuality", "valueType": "Number", "valueDescription": "Compression quality to use. 0 for high compression, 100 for uncompressed. -1 to use \"default\" (whatever that means, idk)", "valueRestrictions": ">= -1, <= 100", "valueOptional": true, "valueOptionalBehavior": "-1" } ], "responseFields": [ { "valueName": "imageData", "valueType": "String", "valueDescription": "Base64-encoded screenshot" } ] }, { "description": "Saves a screenshot of a source to the filesystem.\n\nThe `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.\nIf `imageWidth` and `imageHeight` are not specified, the compressed image will use the full resolution of the source.\n\n**Compatible with inputs and scenes.**", "requestType": "SaveSourceScreenshot", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "sources", "requestFields": [ { "valueName": "sourceName", "valueType": "String", "valueDescription": "Name of the source to take a screenshot of", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "imageFormat", "valueType": "String", "valueDescription": "Image compression format to use. Use `GetVersion` to get compatible image formats", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "imageFilePath", "valueType": "String", "valueDescription": "Path to save the screenshot file to. Eg. `C:\\Users\\user\\Desktop\\screenshot.png`", "valueRestrictions": null, "valueOptional": false, "valueOptionalBehavior": null }, { "valueName": "imageWidth", "valueType": "Number", "valueDescription": "Width to scale the screenshot to", "valueRestrictions": ">= 8, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Source value is used" }, { "valueName": "imageHeight", "valueType": "Number", "valueDescription": "Height to scale the screenshot to", "valueRestrictions": ">= 8, <= 4096", "valueOptional": true, "valueOptionalBehavior": "Source value is used" }, { "valueName": "imageCompressionQuality", "valueType": "Number", "valueDescription": "Compression quality to use. 0 for high compression, 100 for uncompressed. -1 to use \"default\" (whatever that means, idk)", "valueRestrictions": ">= -1, <= 100", "valueOptional": true, "valueOptionalBehavior": "-1" } ], "responseFields": [ { "valueName": "imageData", "valueType": "String", "valueDescription": "Base64-encoded screenshot" } ] }, { "description": "Gets the status of the stream output.", "requestType": "GetStreamStatus", "complexity": 2, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "stream", "requestFields": [], "responseFields": [ { "valueName": "outputActive", "valueType": "Boolean", "valueDescription": "Whether the output is active" }, { "valueName": "outputReconnecting", "valueType": "Boolean", "valueDescription": "Whether the output is currently reconnecting" }, { "valueName": "outputTimecode", "valueType": "String", "valueDescription": "Current formatted timecode string for the output" }, { "valueName": "outputDuration", "valueType": "Number", "valueDescription": "Current duration in milliseconds for the output" }, { "valueName": "outputBytes", "valueType": "Number", "valueDescription": "Number of bytes sent by the output" }, { "valueName": "outputSkippedFrames", "valueType": "Number", "valueDescription": "Number of frames skipped by the output's process" }, { "valueName": "outputTotalFrames", "valueType": "Number", "valueDescription": "Total number of frames delivered by the output's process" } ] }, { "description": "Toggles the status of the stream output.", "requestType": "ToggleStream", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "stream", "requestFields": [], "responseFields": [ { "valueName": "outputActive", "valueType": "Boolean", "valueDescription": "New state of the stream output" } ] }, { "description": "Starts the stream output.", "requestType": "StartStream", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "stream", "requestFields": [], "responseFields": [] }, { "description": "Stops the stream output.", "requestType": "StopStream", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "stream", "requestFields": [], "responseFields": [] } ], "events": [ { "description": "The current scene collection has begun changing.\n\nNote: We recommend using this event to trigger a pause of all polling requests, as performing any requests during a\nscene collection change is considered undefined behavior and can cause crashes!", "eventType": "CurrentSceneCollectionChanging", "eventSubscription": "Config", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "dataFields": [ { "valueName": "sceneCollectionName", "valueType": "String", "valueDescription": "Name of the current scene collection" } ] }, { "description": "The current scene collection has changed.\n\nNote: If polling has been paused during `CurrentSceneCollectionChanging`, this is the que to restart polling.", "eventType": "CurrentSceneCollectionChanged", "eventSubscription": "Config", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "dataFields": [ { "valueName": "sceneCollectionName", "valueType": "String", "valueDescription": "Name of the new scene collection" } ] }, { "description": "The scene collection list has changed.", "eventType": "SceneCollectionListChanged", "eventSubscription": "Config", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "dataFields": [ { "valueName": "sceneCollections", "valueType": "Array", "valueDescription": "Updated list of scene collections" } ] }, { "description": "The current profile has begun changing.", "eventType": "CurrentProfileChanging", "eventSubscription": "Config", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "dataFields": [ { "valueName": "profileName", "valueType": "String", "valueDescription": "Name of the current profile" } ] }, { "description": "The current profile has changed.", "eventType": "CurrentProfileChanged", "eventSubscription": "Config", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "dataFields": [ { "valueName": "profileName", "valueType": "String", "valueDescription": "Name of the new profile" } ] }, { "description": "The profile list has changed.", "eventType": "ProfileListChanged", "eventSubscription": "Config", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "config", "dataFields": [ { "valueName": "profiles", "valueType": "Array", "valueDescription": "Updated list of profiles" } ] }, { "description": "OBS has begun the shutdown process.", "eventType": "ExitStarted", "eventSubscription": "General", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "dataFields": [] }, { "description": "Studio mode has been enabled or disabled.", "eventType": "StudioModeStateChanged", "eventSubscription": "General", "complexity": 1, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "dataFields": [ { "valueName": "studioModeEnabled", "valueType": "Boolean", "valueDescription": "True == Enabled, False == Disabled" } ] }, { "description": "An event has been emitted from a vendor.\n\nA 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.\nIf a plugin or script implements vendor requests or events, documentation is expected to be provided with them.", "eventType": "VendorEvent", "eventSubscription": "Vendors", "complexity": 3, "rpcVersion": "1", "deprecated": false, "initialVersion": "5.0.0", "category": "general", "dataFields": [ { "valueName": "vendorName", "valueType": "String", "valueDescription": "Name of the vendor emitting the event" }, { "valueName": "eventType", "valueType": "String", "valueDescription": "Vendor-provided event typedef" }, { "valueName": "eventData", "valueType": "Object", "valueDescription": "Vendor-provided event data. {} if event does not provide any data" } ] } ] }