mirror of
https://github.com/Palakis/obs-websocket.git
synced 2024-08-30 18:12:16 +00:00
Docs: Update enums and varios other stuff
This commit is contained in:
parent
f0d68f3eec
commit
9a1b6dcd3a
@ -101,123 +101,123 @@ These are the enumeration definitions for various codes used by obs-websocket.
|
|||||||
|
|
||||||
#### RequestStatus Enum
|
#### RequestStatus Enum
|
||||||
```cpp
|
```cpp
|
||||||
enum RequestStatus: uint16_t {
|
enum RequestStatus {
|
||||||
Unknown = 0,
|
Unknown = 0,
|
||||||
|
|
||||||
// For internal use to signify a successful parameter check
|
// For internal use to signify a successful parameter check
|
||||||
NoError = 10,
|
NoError = 10,
|
||||||
|
|
||||||
Success = 100,
|
Success = 100,
|
||||||
|
|
||||||
// The request is denied because the client is not authenticated
|
// The `requestType` field is missing from the request data
|
||||||
AuthenticationMissing = 200,
|
MissingRequestType = 203,
|
||||||
// Connection has already been authenticated (for modules utilizing a request to provide authentication)
|
// The request type is invalid (does not exist)
|
||||||
AlreadyAuthenticated = 201,
|
UnknownRequestType = 204,
|
||||||
// Authentication request was denied (for modules utilizing a request to provide authentication)
|
// Generic error code (comment is expected to be provided)
|
||||||
AuthenticationDenied = 202,
|
GenericError = 205,
|
||||||
// The `requestType` field is missing from the request data
|
|
||||||
RequestTypeMissing = 203,
|
|
||||||
// The request type is invalid (does not exist)
|
|
||||||
InvalidRequestType = 204,
|
|
||||||
// Generic error code (comment is expected to be provided)
|
|
||||||
GenericError = 205,
|
|
||||||
|
|
||||||
// A required request parameter is missing
|
// A required request parameter is missing
|
||||||
MissingRequestParameter = 300,
|
MissingRequestParameter = 300,
|
||||||
|
// The request does not have a valid requestData object.
|
||||||
|
MissingRequestData = 301,
|
||||||
|
|
||||||
// Generic invalid request parameter message
|
// Generic invalid request parameter message
|
||||||
InvalidRequestParameter = 400,
|
InvalidRequestParameter = 400,
|
||||||
// A request parameter has the wrong data type
|
// A request parameter has the wrong data type
|
||||||
InvalidRequestParameterDataType = 401,
|
InvalidRequestParameterDataType = 401,
|
||||||
// A request parameter (float or int) is out of valid range
|
// A request parameter (float or int) is out of valid range
|
||||||
RequestParameterOutOfRange = 402,
|
RequestParameterOutOfRange = 402,
|
||||||
// A request parameter (string or array) is empty and cannot be
|
// A request parameter (string or array) is empty and cannot be
|
||||||
RequestParameterEmpty = 403,
|
RequestParameterEmpty = 403,
|
||||||
|
|
||||||
// An output is running and cannot be in order to perform the request (generic)
|
// An output is running and cannot be in order to perform the request (generic)
|
||||||
OutputRunning = 500,
|
OutputRunning = 500,
|
||||||
// An output is not running and should be
|
// An output is not running and should be
|
||||||
OutputNotRunning = 501,
|
OutputNotRunning = 501,
|
||||||
// Stream is running and cannot be
|
// Stream is running and cannot be
|
||||||
StreamRunning = 502,
|
StreamRunning = 502,
|
||||||
// Stream is not running and should be
|
// Stream is not running and should be
|
||||||
StreamNotRunning = 503,
|
StreamNotRunning = 503,
|
||||||
// Record is running and cannot be
|
// Record is running and cannot be
|
||||||
RecordRunning = 504,
|
RecordRunning = 504,
|
||||||
// Record is not running and should be
|
// Record is not running and should be
|
||||||
RecordNotRunning = 505,
|
RecordNotRunning = 505,
|
||||||
// Record is paused and cannot be
|
// Record is paused and cannot be
|
||||||
RecordPaused = 506,
|
RecordPaused = 506,
|
||||||
// Replay buffer is running and cannot be
|
// Replay buffer is running and cannot be
|
||||||
ReplayBufferRunning = 507,
|
ReplayBufferRunning = 507,
|
||||||
// Replay buffer is not running and should be
|
// Replay buffer is not running and should be
|
||||||
ReplayBufferNotRunning = 508,
|
ReplayBufferNotRunning = 508,
|
||||||
// Replay buffer is disabled and cannot be
|
// Replay buffer is disabled and cannot be
|
||||||
ReplayBufferDisabled = 509,
|
ReplayBufferDisabled = 509,
|
||||||
// Studio mode is active and cannot be
|
// Studio mode is active and cannot be
|
||||||
StudioModeActive = 510,
|
StudioModeActive = 510,
|
||||||
// Studio mode is not active and should be
|
// Studio mode is not active and should be
|
||||||
StudioModeNotActive = 511,
|
StudioModeNotActive = 511,
|
||||||
|
// Virtualcam is running and cannot be
|
||||||
|
VirtualcamRunning = 512,
|
||||||
|
// Virtualcam is not running and should be
|
||||||
|
VirtualcamNotRunning = 513,
|
||||||
|
|
||||||
// The specified source (obs_source_t) was of the invalid type (Eg. input instead of scene)
|
// The specified source (obs_source_t) was of the invalid type (Eg. input instead of scene)
|
||||||
InvalidSourceType = 600,
|
InvalidSourceType = 600,
|
||||||
// The specified source (obs_source_t) was not found (generic for input, filter, transition, scene)
|
// The specified source (obs_source_t) was not found (generic for input, filter, transition, scene)
|
||||||
SourceNotFound = 601,
|
SourceNotFound = 601,
|
||||||
// The specified source (obs_source_t) already exists. Applicable to inputs, filters, transitions, scenes
|
// The specified source (obs_source_t) already exists. Applicable to inputs, filters, transitions, scenes
|
||||||
SourceAlreadyExists = 602,
|
SourceAlreadyExists = 602,
|
||||||
// The specified input (obs_source_t-OBS_SOURCE_TYPE_FILTER) was not found
|
// The specified input (obs_source_t-OBS_SOURCE_TYPE_FILTER) was not found
|
||||||
InputNotFound = 603,
|
InputNotFound = 603,
|
||||||
// The specified input (obs_source_t-OBS_SOURCE_TYPE_INPUT) had the wrong kind
|
// The specified input (obs_source_t-OBS_SOURCE_TYPE_INPUT) had the wrong kind
|
||||||
InvalidInputKind = 604,
|
InvalidInputKind = 604,
|
||||||
// The specified filter (obs_source_t-OBS_SOURCE_TYPE_FILTER) was not found
|
// The specified filter (obs_source_t-OBS_SOURCE_TYPE_FILTER) was not found
|
||||||
FilterNotFound = 605,
|
FilterNotFound = 605,
|
||||||
// The specified transition (obs_source_t-OBS_SOURCE_TYPE_TRANSITION) was not found
|
// The specified transition (obs_source_t-OBS_SOURCE_TYPE_TRANSITION) was not found
|
||||||
TransitionNotFound = 606,
|
TransitionNotFound = 606,
|
||||||
// The specified transition (obs_source_t-OBS_SOURCE_TYPE_TRANSITION) does not support setting its position (transition is of fixed type)
|
// The specified transition (obs_source_t-OBS_SOURCE_TYPE_TRANSITION) does not support setting its position (transition is of fixed type)
|
||||||
TransitionDurationFixed = 607,
|
TransitionDurationFixed = 607,
|
||||||
// The specified scene (obs_source_t-OBS_SOURCE_TYPE_SCENE), (obs_scene_t) was not found
|
// The specified scene (obs_source_t-OBS_SOURCE_TYPE_SCENE), (obs_scene_t) was not found
|
||||||
SceneNotFound = 608,
|
SceneNotFound = 608,
|
||||||
// The specified scene item (obs_sceneitem_t) was not found
|
// The specified scene item (obs_sceneitem_t) was not found
|
||||||
SceneItemNotFound = 609,
|
SceneItemNotFound = 609,
|
||||||
// The specified scene collection was not found
|
// The specified scene collection was not found
|
||||||
SceneCollectionNotFound = 610,
|
SceneCollectionNotFound = 610,
|
||||||
// The specified profile was not found
|
// The specified profile was not found
|
||||||
ProfileNotFound = 611,
|
ProfileNotFound = 611,
|
||||||
// The specified output (obs_output_t) was not found
|
// The specified output (obs_output_t) was not found
|
||||||
OutputNotFound = 612,
|
OutputNotFound = 612,
|
||||||
// The specified encoder (obs_encoder_t) was not found
|
// The specified encoder (obs_encoder_t) was not found
|
||||||
EncoderNotFound = 613,
|
EncoderNotFound = 613,
|
||||||
// The specified service (obs_service_t) was not found
|
// The specified service (obs_service_t) was not found
|
||||||
ServiceNotFound = 614,
|
ServiceNotFound = 614,
|
||||||
// The specified hotkey was not found
|
// The specified hotkey was not found
|
||||||
HotkeyNotFound = 615,
|
HotkeyNotFound = 615,
|
||||||
// The specified directory was not found
|
// The specified directory was not found
|
||||||
DirectoryNotFound = 616,
|
DirectoryNotFound = 616,
|
||||||
// The specified config item (obs_config_t) was not found. Could be section or parameter name.
|
// The specified config item (obs_config_t) was not found. Could be section or parameter name
|
||||||
ConfigParameterNotFound = 617,
|
ConfigParameterNotFound = 617,
|
||||||
// The specified property (obs_properties_t) was not found
|
// The specified property (obs_properties_t) was not found
|
||||||
PropertyNotFound = 618
|
PropertyNotFound = 618,
|
||||||
|
|
||||||
// Processing the request failed unexpectedly
|
// Processing the request failed unexpectedly
|
||||||
RequestProcessingFailed = 700,
|
RequestProcessingFailed = 700,
|
||||||
// Starting the Output failed
|
// Starting the Output failed
|
||||||
OutputStartFailed = 701,
|
OutputStartFailed = 701,
|
||||||
// Duplicating the scene item failed
|
// Duplicating the scene item failed
|
||||||
SceneItemDuplicationFailed = 702,
|
SceneItemDuplicationFailed = 702,
|
||||||
// Rendering the screenshot failed
|
// Rendering the screenshot failed
|
||||||
ScreenshotRenderFailed = 703,
|
ScreenshotRenderFailed = 703,
|
||||||
// Encoding the screenshot failed
|
// Encoding the screenshot failed
|
||||||
ScreenshotEncodeFailed = 704,
|
ScreenshotEncodeFailed = 704,
|
||||||
// Saving the screenshot failed
|
// Saving the screenshot failed
|
||||||
ScreenshotSaveFailed = 705,
|
ScreenshotSaveFailed = 705,
|
||||||
// Creating the directory failed
|
// Creating the directory failed
|
||||||
DirectoryCreationFailed = 706,
|
DirectoryCreationFailed = 706,
|
||||||
};
|
};
|
||||||
```
|
```
|
||||||
|
|
||||||
#### WebSocketCloseCode Enum
|
#### WebSocketCloseCode Enum
|
||||||
```cpp
|
```cpp
|
||||||
enum WebSocketCloseCode: uint16_t {
|
enum WebSocketCloseCode {
|
||||||
// Internal only
|
// Internal only
|
||||||
DontClose = 0,
|
DontClose = 0,
|
||||||
// Reserved
|
// Reserved
|
||||||
@ -234,8 +234,8 @@ enum WebSocketCloseCode: uint16_t {
|
|||||||
AuthenticationFailed = 4005,
|
AuthenticationFailed = 4005,
|
||||||
// There was an invalid parameter the client's `Identify` message
|
// There was an invalid parameter the client's `Identify` message
|
||||||
InvalidIdentifyParameter = 4006,
|
InvalidIdentifyParameter = 4006,
|
||||||
// A `Request` or `RequestBatch` was missing its `requestId`
|
// A `Request` or `RequestBatch` was missing its `requestId` or `requestType`
|
||||||
RequestMissingRequestId = 4007,
|
RequestMissingRequiredField = 4007,
|
||||||
// The websocket session has been invalidated by the obs-websocket server.
|
// The websocket session has been invalidated by the obs-websocket server.
|
||||||
SessionInvalidated = 4008,
|
SessionInvalidated = 4008,
|
||||||
// The server detected the usage of an old version of the obs-websocket protocol.
|
// The server detected the usage of an old version of the obs-websocket protocol.
|
||||||
@ -247,14 +247,34 @@ enum WebSocketCloseCode: uint16_t {
|
|||||||
|
|
||||||
#### EventSubscriptions Enum
|
#### EventSubscriptions Enum
|
||||||
```cpp
|
```cpp
|
||||||
enum EventSubscriptions: uint64_t {
|
enum EventSubscriptions {
|
||||||
|
// Set subscriptions to 0 to disable all events
|
||||||
None = 0,
|
None = 0,
|
||||||
|
// Receive events in the `General` category
|
||||||
General = (1 << 0),
|
General = (1 << 0),
|
||||||
}
|
// Receive events in the `Config` category
|
||||||
|
Config = (1 << 1),
|
||||||
|
// Receive events in the `Scenes` category
|
||||||
|
Scenes = (1 << 2),
|
||||||
|
// Receive events in the `Inputs` category
|
||||||
|
Inputs = (1 << 3),
|
||||||
|
// Receive events in the `Transitions` category
|
||||||
|
Transitions = (1 << 4),
|
||||||
|
// Receive events in the `Filters` category
|
||||||
|
Filters = (1 << 5),
|
||||||
|
// Receive events in the `Outputs` category
|
||||||
|
Outputs = (1 << 6),
|
||||||
|
// Receive events in the `Scene Items` category
|
||||||
|
SceneItems = (1 << 7),
|
||||||
|
// Receive events in the `MediaInputs` category
|
||||||
|
MediaInputs = (1 << 8),
|
||||||
|
// Receive all event categories (default subscription setting)
|
||||||
|
All = (General | Config | Scenes | Inputs | Transitions | Filters | Outputs | SceneItems | MediaInputs),
|
||||||
|
};
|
||||||
```
|
```
|
||||||
Subscriptions are a bitmask system.
|
Subscriptions are a bitmask system.
|
||||||
|
|
||||||
In many languages, to generate a bitmask for `General` and `(not defined yet)`, you would do: `subscriptions = ((1 << 0) | (1 << 2))`
|
In many languages, to generate a bitmask that subscribes to `General` and `Scenes`, you would do: `subscriptions = ((1 << 0) | (1 << 2))`
|
||||||
|
|
||||||
|
|
||||||
## Message Types
|
## Message Types
|
||||||
@ -279,7 +299,6 @@ The following message types are the base message types which may be sent to and
|
|||||||
{
|
{
|
||||||
"obsWebsocketVersion": string,
|
"obsWebsocketVersion": string,
|
||||||
"rpcVersion": number,
|
"rpcVersion": number,
|
||||||
"availableEvents": array<string>,
|
|
||||||
"availableRequests": array<string>,
|
"availableRequests": array<string>,
|
||||||
"authentication": object(optional)
|
"authentication": object(optional)
|
||||||
}
|
}
|
||||||
@ -294,7 +313,6 @@ Authentication is required
|
|||||||
"websocketVersion": "5.0.0",
|
"websocketVersion": "5.0.0",
|
||||||
"rpcVersion": 1,
|
"rpcVersion": 1,
|
||||||
"availableRequests": ["GetVersion"],
|
"availableRequests": ["GetVersion"],
|
||||||
"availableEvents": ["Exiting"],
|
|
||||||
"authentication": {
|
"authentication": {
|
||||||
"challenge": "+IxH4CnCiqpX1rM9scsNynZzbOe4KhDeYcTNS3PDaeY=",
|
"challenge": "+IxH4CnCiqpX1rM9scsNynZzbOe4KhDeYcTNS3PDaeY=",
|
||||||
"salt": "lM1GncleQOaCu9lT1yeUZhFYnqhsLLP1G5lAGo3ixaI="
|
"salt": "lM1GncleQOaCu9lT1yeUZhFYnqhsLLP1G5lAGo3ixaI="
|
||||||
@ -308,8 +326,7 @@ Authentication is not required
|
|||||||
"messageType": "Hello",
|
"messageType": "Hello",
|
||||||
"websocketVersion": "5.0.0",
|
"websocketVersion": "5.0.0",
|
||||||
"rpcVersion": 1,
|
"rpcVersion": 1,
|
||||||
"availableRequests": ["GetVersion"],
|
"availableRequests": ["GetVersion"]
|
||||||
"availableEvents": ["Exiting"]
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -327,7 +344,7 @@ Authentication is not required
|
|||||||
"authentication": string(optional),
|
"authentication": string(optional),
|
||||||
"ignoreInvalidMessages": bool(optional) = false,
|
"ignoreInvalidMessages": bool(optional) = false,
|
||||||
"ignoreNonFatalRequestChecks": bool(optional) = false,
|
"ignoreNonFatalRequestChecks": bool(optional) = false,
|
||||||
"eventSubscriptions": number(optional) = (all not high volume)
|
"eventSubscriptions": number(optional) = (EventSubscriptions::All)
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
- `rpcVersion` is the version number that the client would like the obs-websocket server to use.
|
- `rpcVersion` is the version number that the client would like the obs-websocket server to use.
|
||||||
@ -341,7 +358,7 @@ Authentication is not required
|
|||||||
"messageType": "Identify",
|
"messageType": "Identify",
|
||||||
"rpcVersion": 1,
|
"rpcVersion": 1,
|
||||||
"authentication": "Dj6cLS+jrNA0HpCArRg0Z/Fc+YHdt2FQfAvgD1mip6Y=",
|
"authentication": "Dj6cLS+jrNA0HpCArRg0Z/Fc+YHdt2FQfAvgD1mip6Y=",
|
||||||
"eventSubscriptions": 3
|
"eventSubscriptions": 33
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -380,7 +397,7 @@ Authentication is not required
|
|||||||
{
|
{
|
||||||
"ignoreInvalidMessages": bool(optional) = false,
|
"ignoreInvalidMessages": bool(optional) = false,
|
||||||
"ignoreNonFatalRequestChecks": bool(optional) = false,
|
"ignoreNonFatalRequestChecks": bool(optional) = false,
|
||||||
"eventSubscriptions": number(optional) = (all not high volume)
|
"eventSubscriptions": number(optional) = (EventSubscriptions::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.
|
- Only the listed parameters may be changed after initial identification. To change a parameter not listed, you must reconnect to the obs-websocket server.
|
||||||
|
Loading…
Reference in New Issue
Block a user