mirror of
https://github.com/Palakis/obs-websocket.git
synced 2024-08-30 18:12:16 +00:00
requesthandler: Add GetInputAudioTracks
This commit is contained in:
parent
6d216e0412
commit
702f88cea8
@ -84,6 +84,7 @@ const std::map<std::string, RequestMethodHandler> RequestHandler::_handlerMap
|
|||||||
{"SetInputAudioSyncOffset", &RequestHandler::SetInputAudioSyncOffset},
|
{"SetInputAudioSyncOffset", &RequestHandler::SetInputAudioSyncOffset},
|
||||||
{"GetInputAudioMonitorType", &RequestHandler::GetInputAudioMonitorType},
|
{"GetInputAudioMonitorType", &RequestHandler::GetInputAudioMonitorType},
|
||||||
{"SetInputAudioMonitorType", &RequestHandler::SetInputAudioMonitorType},
|
{"SetInputAudioMonitorType", &RequestHandler::SetInputAudioMonitorType},
|
||||||
|
{"GetInputAudioTracks", &RequestHandler::GetInputAudioTracks},
|
||||||
{"GetInputPropertiesListPropertyItems", &RequestHandler::GetInputPropertiesListPropertyItems},
|
{"GetInputPropertiesListPropertyItems", &RequestHandler::GetInputPropertiesListPropertyItems},
|
||||||
{"PressInputPropertiesButton", &RequestHandler::PressInputPropertiesButton},
|
{"PressInputPropertiesButton", &RequestHandler::PressInputPropertiesButton},
|
||||||
|
|
||||||
|
@ -106,6 +106,7 @@ class RequestHandler {
|
|||||||
RequestResult SetInputAudioSyncOffset(const Request&);
|
RequestResult SetInputAudioSyncOffset(const Request&);
|
||||||
RequestResult GetInputAudioMonitorType(const Request&);
|
RequestResult GetInputAudioMonitorType(const Request&);
|
||||||
RequestResult SetInputAudioMonitorType(const Request&);
|
RequestResult SetInputAudioMonitorType(const Request&);
|
||||||
|
RequestResult GetInputAudioTracks(const Request&);
|
||||||
RequestResult GetInputPropertiesListPropertyItems(const Request&);
|
RequestResult GetInputPropertiesListPropertyItems(const Request&);
|
||||||
RequestResult PressInputPropertiesButton(const Request&);
|
RequestResult PressInputPropertiesButton(const Request&);
|
||||||
|
|
||||||
|
@ -346,6 +346,9 @@ RequestResult RequestHandler::GetInputMute(const Request& request)
|
|||||||
if (!input)
|
if (!input)
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
json responseData;
|
json responseData;
|
||||||
responseData["inputMuted"] = obs_source_muted(input);
|
responseData["inputMuted"] = obs_source_muted(input);
|
||||||
return RequestResult::Success(responseData);
|
return RequestResult::Success(responseData);
|
||||||
@ -372,6 +375,9 @@ RequestResult RequestHandler::SetInputMute(const Request& request)
|
|||||||
if (!(input && request.ValidateBoolean("inputMuted", statusCode, comment)))
|
if (!(input && request.ValidateBoolean("inputMuted", statusCode, comment)))
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
obs_source_set_muted(input, request.RequestData["inputMuted"]);
|
obs_source_set_muted(input, request.RequestData["inputMuted"]);
|
||||||
|
|
||||||
return RequestResult::Success();
|
return RequestResult::Success();
|
||||||
@ -399,6 +405,9 @@ RequestResult RequestHandler::ToggleInputMute(const Request& request)
|
|||||||
if (!input)
|
if (!input)
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
bool inputMuted = !obs_source_muted(input);
|
bool inputMuted = !obs_source_muted(input);
|
||||||
obs_source_set_muted(input, inputMuted);
|
obs_source_set_muted(input, inputMuted);
|
||||||
|
|
||||||
@ -430,6 +439,9 @@ RequestResult RequestHandler::GetInputVolume(const Request& request)
|
|||||||
if (!input)
|
if (!input)
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
float inputVolumeMul = obs_source_get_volume(input);
|
float inputVolumeMul = obs_source_get_volume(input);
|
||||||
float inputVolumeDb = obs_mul_to_db(inputVolumeMul);
|
float inputVolumeDb = obs_mul_to_db(inputVolumeMul);
|
||||||
if (inputVolumeDb == -INFINITY)
|
if (inputVolumeDb == -INFINITY)
|
||||||
@ -463,6 +475,9 @@ RequestResult RequestHandler::SetInputVolume(const Request& request)
|
|||||||
if (!input)
|
if (!input)
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
bool hasMul = request.Contains("inputVolumeMul");
|
bool hasMul = request.Contains("inputVolumeMul");
|
||||||
if (hasMul && !request.ValidateOptionalNumber("inputVolumeMul", statusCode, comment, 0, 20))
|
if (hasMul && !request.ValidateOptionalNumber("inputVolumeMul", statusCode, comment, 0, 20))
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
@ -510,6 +525,9 @@ RequestResult RequestHandler::GetInputAudioBalance(const Request& request)
|
|||||||
if (!input)
|
if (!input)
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
json responseData;
|
json responseData;
|
||||||
responseData["inputAudioBalance"] = obs_source_get_balance_value(input);
|
responseData["inputAudioBalance"] = obs_source_get_balance_value(input);
|
||||||
|
|
||||||
@ -537,6 +555,9 @@ RequestResult RequestHandler::SetInputAudioBalance(const Request& request)
|
|||||||
if (!(input && request.ValidateNumber("inputAudioBalance", statusCode, comment, 0.0, 1.0)))
|
if (!(input && request.ValidateNumber("inputAudioBalance", statusCode, comment, 0.0, 1.0)))
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
float inputAudioBalance = request.RequestData["inputAudioBalance"];
|
float inputAudioBalance = request.RequestData["inputAudioBalance"];
|
||||||
obs_source_set_balance_value(input, inputAudioBalance);
|
obs_source_set_balance_value(input, inputAudioBalance);
|
||||||
|
|
||||||
@ -567,6 +588,9 @@ RequestResult RequestHandler::GetInputAudioSyncOffset(const Request& request)
|
|||||||
if (!input)
|
if (!input)
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
json responseData;
|
json responseData;
|
||||||
// Offset is stored in nanoseconds in OBS.
|
// Offset is stored in nanoseconds in OBS.
|
||||||
responseData["inputAudioSyncOffset"] = obs_source_get_sync_offset(input) / 1000000;
|
responseData["inputAudioSyncOffset"] = obs_source_get_sync_offset(input) / 1000000;
|
||||||
@ -595,6 +619,9 @@ RequestResult RequestHandler::SetInputAudioSyncOffset(const Request& request)
|
|||||||
if (!(input && request.ValidateNumber("inputAudioSyncOffset", statusCode, comment, -950, 20000)))
|
if (!(input && request.ValidateNumber("inputAudioSyncOffset", statusCode, comment, -950, 20000)))
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
int64_t syncOffset = request.RequestData["inputAudioSyncOffset"];
|
int64_t syncOffset = request.RequestData["inputAudioSyncOffset"];
|
||||||
obs_source_set_sync_offset(input, syncOffset * 1000000);
|
obs_source_set_sync_offset(input, syncOffset * 1000000);
|
||||||
|
|
||||||
@ -628,6 +655,9 @@ RequestResult RequestHandler::GetInputAudioMonitorType(const Request& request)
|
|||||||
if (!input)
|
if (!input)
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
json responseData;
|
json responseData;
|
||||||
responseData["monitorType"] = Utils::Obs::StringHelper::GetInputMonitorType(input);
|
responseData["monitorType"] = Utils::Obs::StringHelper::GetInputMonitorType(input);
|
||||||
|
|
||||||
@ -655,6 +685,9 @@ RequestResult RequestHandler::SetInputAudioMonitorType(const Request& request)
|
|||||||
if (!(input && request.ValidateString("monitorType", statusCode, comment)))
|
if (!(input && request.ValidateString("monitorType", statusCode, comment)))
|
||||||
return RequestResult::Error(statusCode, comment);
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
if (!obs_audio_monitoring_available())
|
if (!obs_audio_monitoring_available())
|
||||||
return RequestResult::Error(RequestStatus::InvalidResourceState, "Audio monitoring is not available on this platform.");
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "Audio monitoring is not available on this platform.");
|
||||||
|
|
||||||
@ -674,6 +707,44 @@ RequestResult RequestHandler::SetInputAudioMonitorType(const Request& request)
|
|||||||
return RequestResult::Success();
|
return RequestResult::Success();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the enable state of all audio tracks of an input.
|
||||||
|
*
|
||||||
|
* @requestField inputName | String | Name of the input
|
||||||
|
*
|
||||||
|
* @responseField inputAudioTracks | Object | Object of audio tracks and associated enable states
|
||||||
|
*
|
||||||
|
* @requestType GetInputAudioTracks
|
||||||
|
* @complexity 3
|
||||||
|
* @rpcVersion -1
|
||||||
|
* @initialVersion 5.0.0
|
||||||
|
* @api requests
|
||||||
|
* @category inputs
|
||||||
|
*/
|
||||||
|
RequestResult RequestHandler::GetInputAudioTracks(const Request& request)
|
||||||
|
{
|
||||||
|
RequestStatus::RequestStatus statusCode;
|
||||||
|
std::string comment;
|
||||||
|
OBSSourceAutoRelease input = request.ValidateInput("inputName", statusCode, comment);
|
||||||
|
if (!input)
|
||||||
|
return RequestResult::Error(statusCode, comment);
|
||||||
|
|
||||||
|
if (!(obs_source_get_output_flags(input) & OBS_SOURCE_AUDIO))
|
||||||
|
return RequestResult::Error(RequestStatus::InvalidResourceState, "The specified input does not support audio.");
|
||||||
|
|
||||||
|
long long tracks = obs_source_get_audio_mixers(input);
|
||||||
|
|
||||||
|
json inputAudioTracks;
|
||||||
|
for (long long i = 0; i < MAX_AUDIO_MIXES; i++) {
|
||||||
|
inputAudioTracks[std::to_string(i + 1)] = (bool)((tracks >> i) & 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
json responseData;
|
||||||
|
responseData["inputAudioTracks"] = inputAudioTracks;
|
||||||
|
|
||||||
|
return RequestResult::Success(responseData);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the items of a list property from an input's properties.
|
* Gets the items of a list property from an input's properties.
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user