From 01f96826e189f203b5059b75589a7e882d24be36 Mon Sep 17 00:00:00 2001 From: Boris Zbarsky Date: Tue, 14 Feb 2023 12:45:33 -0500 Subject: [PATCH] Manual changes to remove emberAfSendImmediateDefaultResponse. --- .../include/static-supported-modes-manager.h | 3 +- .../src/static-supported-modes-manager.cpp | 11 +- .../include/static-supported-modes-manager.h | 3 +- .../linux/static-supported-modes-manager.cpp | 11 +- .../account-login-server.cpp | 20 +-- .../audio-output-server.cpp | 15 +- .../barrier-control-server.cpp | 17 +- .../channel-server/channel-server.cpp | 30 ++-- .../color-control-server.cpp | 130 +++++++------- .../color-control-server.h | 9 +- .../diagnostic-logs-server.cpp | 4 +- .../door-lock-server/door-lock-server.cpp | 118 ++++++------ .../door-lock-server/door-lock-server.h | 22 ++- .../group-key-mgmt-server.cpp | 24 +-- .../clusters/groups-server/groups-server.cpp | 63 ++++--- .../identify-server/identify-server.cpp | 7 +- .../clusters/level-control/level-control.cpp | 169 ++++++++++-------- .../media-input-server/media-input-server.cpp | 37 ++-- .../mode-select-server/mode-select-server.cpp | 17 +- .../supported-modes-manager.h | 6 +- .../clusters/on-off-server/on-off-server.cpp | 46 ++--- .../clusters/on-off-server/on-off-server.h | 8 +- src/app/clusters/scenes/scenes.cpp | 8 +- .../thermostat-server/thermostat-server.cpp | 2 +- .../window-covering-server.cpp | 51 +++--- .../window-covering-server.h | 3 +- src/app/util/af.h | 13 -- src/app/util/util.cpp | 5 - 28 files changed, 430 insertions(+), 422 deletions(-) diff --git a/examples/all-clusters-app/all-clusters-common/include/static-supported-modes-manager.h b/examples/all-clusters-app/all-clusters-common/include/static-supported-modes-manager.h index 8c9515738fa7da..a8ef29863e9f0f 100644 --- a/examples/all-clusters-app/all-clusters-common/include/static-supported-modes-manager.h +++ b/examples/all-clusters-app/all-clusters-common/include/static-supported-modes-manager.h @@ -56,7 +56,8 @@ class StaticSupportedModesManager : public chip::app::Clusters::ModeSelect::Supp SupportedModesManager::ModeOptionsProvider getModeOptionsProvider(EndpointId endpointId) const override; - EmberAfStatus getModeOptionByMode(EndpointId endpointId, uint8_t mode, const ModeOptionStructType ** dataPtr) const override; + Protocols::InteractionModel::Status getModeOptionByMode(EndpointId endpointId, uint8_t mode, + const ModeOptionStructType ** dataPtr) const override; ~StaticSupportedModesManager(){}; diff --git a/examples/all-clusters-app/all-clusters-common/src/static-supported-modes-manager.cpp b/examples/all-clusters-app/all-clusters-common/src/static-supported-modes-manager.cpp index 3bc8d9a60fdf71..416915582d48ee 100644 --- a/examples/all-clusters-app/all-clusters-common/src/static-supported-modes-manager.cpp +++ b/examples/all-clusters-app/all-clusters-common/src/static-supported-modes-manager.cpp @@ -4,6 +4,7 @@ using namespace std; using namespace chip; using namespace chip::app::Clusters; using namespace chip::app::Clusters::ModeSelect; +using chip::Protocols::InteractionModel::Status; using ModeOptionStructType = Structs::ModeOptionStruct::Type; using SemanticTag = Structs::SemanticTagStruct::Type; @@ -51,13 +52,13 @@ SupportedModesManager::ModeOptionsProvider StaticSupportedModesManager::getModeO return ModeOptionsProvider(nullptr, nullptr); } -EmberAfStatus StaticSupportedModesManager::getModeOptionByMode(unsigned short endpointId, unsigned char mode, - const ModeOptionStructType ** dataPtr) const +Status StaticSupportedModesManager::getModeOptionByMode(unsigned short endpointId, unsigned char mode, + const ModeOptionStructType ** dataPtr) const { auto modeOptionsProvider = this->getModeOptionsProvider(endpointId); if (modeOptionsProvider.begin() == nullptr) { - return EMBER_ZCL_STATUS_UNSUPPORTED_CLUSTER; + return Status::UnsupportedCluster; } auto * begin = this->getModeOptionsProvider(endpointId).begin(); auto * end = this->getModeOptionsProvider(endpointId).end(); @@ -68,11 +69,11 @@ EmberAfStatus StaticSupportedModesManager::getModeOptionByMode(unsigned short en if (modeOption.mode == mode) { *dataPtr = &modeOption; - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } } emberAfPrintln(EMBER_AF_PRINT_DEBUG, "Cannot find the mode %u", mode); - return EMBER_ZCL_STATUS_INVALID_COMMAND; + return Status::InvalidCommand; } const ModeSelect::SupportedModesManager * ModeSelect::getSupportedModesManager() diff --git a/examples/placeholder/linux/include/static-supported-modes-manager.h b/examples/placeholder/linux/include/static-supported-modes-manager.h index 8c9515738fa7da..a8ef29863e9f0f 100644 --- a/examples/placeholder/linux/include/static-supported-modes-manager.h +++ b/examples/placeholder/linux/include/static-supported-modes-manager.h @@ -56,7 +56,8 @@ class StaticSupportedModesManager : public chip::app::Clusters::ModeSelect::Supp SupportedModesManager::ModeOptionsProvider getModeOptionsProvider(EndpointId endpointId) const override; - EmberAfStatus getModeOptionByMode(EndpointId endpointId, uint8_t mode, const ModeOptionStructType ** dataPtr) const override; + Protocols::InteractionModel::Status getModeOptionByMode(EndpointId endpointId, uint8_t mode, + const ModeOptionStructType ** dataPtr) const override; ~StaticSupportedModesManager(){}; diff --git a/examples/placeholder/linux/static-supported-modes-manager.cpp b/examples/placeholder/linux/static-supported-modes-manager.cpp index 3bc8d9a60fdf71..416915582d48ee 100644 --- a/examples/placeholder/linux/static-supported-modes-manager.cpp +++ b/examples/placeholder/linux/static-supported-modes-manager.cpp @@ -4,6 +4,7 @@ using namespace std; using namespace chip; using namespace chip::app::Clusters; using namespace chip::app::Clusters::ModeSelect; +using chip::Protocols::InteractionModel::Status; using ModeOptionStructType = Structs::ModeOptionStruct::Type; using SemanticTag = Structs::SemanticTagStruct::Type; @@ -51,13 +52,13 @@ SupportedModesManager::ModeOptionsProvider StaticSupportedModesManager::getModeO return ModeOptionsProvider(nullptr, nullptr); } -EmberAfStatus StaticSupportedModesManager::getModeOptionByMode(unsigned short endpointId, unsigned char mode, - const ModeOptionStructType ** dataPtr) const +Status StaticSupportedModesManager::getModeOptionByMode(unsigned short endpointId, unsigned char mode, + const ModeOptionStructType ** dataPtr) const { auto modeOptionsProvider = this->getModeOptionsProvider(endpointId); if (modeOptionsProvider.begin() == nullptr) { - return EMBER_ZCL_STATUS_UNSUPPORTED_CLUSTER; + return Status::UnsupportedCluster; } auto * begin = this->getModeOptionsProvider(endpointId).begin(); auto * end = this->getModeOptionsProvider(endpointId).end(); @@ -68,11 +69,11 @@ EmberAfStatus StaticSupportedModesManager::getModeOptionByMode(unsigned short en if (modeOption.mode == mode) { *dataPtr = &modeOption; - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } } emberAfPrintln(EMBER_AF_PRINT_DEBUG, "Cannot find the mode %u", mode); - return EMBER_ZCL_STATUS_INVALID_COMMAND; + return Status::InvalidCommand; } const ModeSelect::SupportedModesManager * ModeSelect::getSupportedModesManager() diff --git a/src/app/clusters/account-login-server/account-login-server.cpp b/src/app/clusters/account-login-server/account-login-server.cpp index 6bdef96d44fcd9..39e05d54e41909 100644 --- a/src/app/clusters/account-login-server/account-login-server.cpp +++ b/src/app/clusters/account-login-server/account-login-server.cpp @@ -137,7 +137,7 @@ bool emberAfAccountLoginClusterLoginCallback(app::CommandHandler * command, cons { CHIP_ERROR err = CHIP_NO_ERROR; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; auto & tempAccountIdentifier = commandData.tempAccountIdentifier; auto & setupPin = commandData.setupPIN; @@ -146,42 +146,42 @@ bool emberAfAccountLoginClusterLoginCallback(app::CommandHandler * command, cons if (!delegate->HandleLogin(tempAccountIdentifier, setupPin)) { - status = EMBER_ZCL_STATUS_UNSUPPORTED_ACCESS; + status = Status::UnsupportedAccess; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfAccountLoginClusterLoginCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + command->AddStatus(commandPath, status); return true; } bool emberAfAccountLoginClusterLogoutCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::Logout::DecodableType & commandData) { - CHIP_ERROR err = CHIP_NO_ERROR; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + CHIP_ERROR err = CHIP_NO_ERROR; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; Delegate * delegate = GetDelegate(endpoint); VerifyOrExit(isDelegateNull(delegate, endpoint) != true, err = CHIP_ERROR_INCORRECT_STATE); if (!delegate->HandleLogout()) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfAccountLoginClusterLogoutCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } diff --git a/src/app/clusters/audio-output-server/audio-output-server.cpp b/src/app/clusters/audio-output-server/audio-output-server.cpp index df73f6189cf7c9..c28c3811a4c997 100644 --- a/src/app/clusters/audio-output-server/audio-output-server.cpp +++ b/src/app/clusters/audio-output-server/audio-output-server.cpp @@ -35,6 +35,7 @@ using namespace chip; using namespace chip::app::Clusters::AudioOutput; +using chip::Protocols::InteractionModel::Status; static constexpr size_t kAudioOutputDelegateTableSize = EMBER_AF_AUDIO_OUTPUT_CLUSTER_SERVER_ENDPOINT_COUNT + CHIP_DEVICE_CONFIG_DYNAMIC_ENDPOINT_COUNT; @@ -212,27 +213,27 @@ bool emberAfAudioOutputClusterRenameOutputCallback(app::CommandHandler * command bool emberAfAudioOutputClusterSelectOutputCallback(app::CommandHandler * command, const app::ConcreteCommandPath & commandPath, const Commands::SelectOutput::DecodableType & commandData) { - CHIP_ERROR err = CHIP_NO_ERROR; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; - auto & index = commandData.index; + CHIP_ERROR err = CHIP_NO_ERROR; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; + auto & index = commandData.index; Delegate * delegate = GetDelegate(endpoint); VerifyOrExit(isDelegateNull(delegate, endpoint) != true, err = CHIP_ERROR_INCORRECT_STATE); if (!delegate->HandleSelectOutput(index)) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfAudioOutputClusterSelectOutputCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + command->AddStatus(commandPath, status); return true; } diff --git a/src/app/clusters/barrier-control-server/barrier-control-server.cpp b/src/app/clusters/barrier-control-server/barrier-control-server.cpp index e310d7ba541061..94f286bed4cbc4 100644 --- a/src/app/clusters/barrier-control-server/barrier-control-server.cpp +++ b/src/app/clusters/barrier-control-server/barrier-control-server.cpp @@ -32,6 +32,7 @@ using namespace chip; using namespace chip::app::Clusters; using namespace chip::app::Clusters::BarrierControl; +using chip::Protocols::InteractionModel::Status; typedef struct { @@ -258,9 +259,9 @@ void emberAfBarrierControlClusterServerTickCallback(EndpointId endpoint) // ----------------------------------------------------------------------------- // Handling commands -static void sendDefaultResponse(EmberAfStatus status) +static void sendDefaultResponse(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, Status status) { - if (emberAfSendImmediateDefaultResponse(status) != EMBER_SUCCESS) + if (commandObj->AddStatus(commandPath, status) != CHIP_NO_ERROR) { emberAfBarrierControlClusterPrintln("Failed to send default response"); } @@ -272,21 +273,21 @@ bool emberAfBarrierControlClusterBarrierControlGoToPercentCallback( { auto & percentOpen = commandData.percentOpen; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; emberAfBarrierControlClusterPrintln("RX: GoToPercentCallback p=%d", percentOpen); if (isRemoteLockoutOn(endpoint)) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } else if (percentOpen > 100 // "100" means "100%", so greater than that is invalid || (!emAfPluginBarrierControlServerIsPartialBarrierSupported(endpoint) && percentOpen != EMBER_ZCL_BARRIER_CONTROL_BARRIER_POSITION_CLOSED && percentOpen != EMBER_ZCL_BARRIER_CONTROL_BARRIER_POSITION_OPEN)) { - status = EMBER_ZCL_STATUS_CONSTRAINT_ERROR; + status = Status::ConstraintError; } else { @@ -307,7 +308,7 @@ bool emberAfBarrierControlClusterBarrierControlGoToPercentCallback( } } - sendDefaultResponse(status); + sendDefaultResponse(commandObj, commandPath, status); return true; } @@ -319,7 +320,7 @@ bool emberAfBarrierControlClusterBarrierControlStopCallback(app::CommandHandler EndpointId endpoint = commandPath.mEndpointId; emberAfDeactivateServerTick(endpoint, BarrierControl::Id); setMovingState(endpoint, EMBER_ZCL_BARRIER_CONTROL_MOVING_STATE_STOPPED); - sendDefaultResponse(EMBER_ZCL_STATUS_SUCCESS); + sendDefaultResponse(commandObj, commandPath, Status::Success); return true; } diff --git a/src/app/clusters/channel-server/channel-server.cpp b/src/app/clusters/channel-server/channel-server.cpp index 55bffb1fb27a9a..909daad853dd56 100644 --- a/src/app/clusters/channel-server/channel-server.cpp +++ b/src/app/clusters/channel-server/channel-server.cpp @@ -233,55 +233,55 @@ bool emberAfChannelClusterChangeChannelCallback(app::CommandHandler * command, c bool emberAfChannelClusterChangeChannelByNumberCallback(app::CommandHandler * command, const app::ConcreteCommandPath & commandPath, const Commands::ChangeChannelByNumber::DecodableType & commandData) { - CHIP_ERROR err = CHIP_NO_ERROR; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; - auto & majorNumber = commandData.majorNumber; - auto & minorNumber = commandData.minorNumber; + CHIP_ERROR err = CHIP_NO_ERROR; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; + auto & majorNumber = commandData.majorNumber; + auto & minorNumber = commandData.minorNumber; Delegate * delegate = GetDelegate(endpoint); VerifyOrExit(isDelegateNull(delegate, endpoint) != true, err = CHIP_ERROR_INCORRECT_STATE); if (!delegate->HandleChangeChannelByNumber(majorNumber, minorNumber)) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfChannelClusterChangeChannelByNumberCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + command->AddStatus(commandPath, status); return true; } bool emberAfChannelClusterSkipChannelCallback(app::CommandHandler * command, const app::ConcreteCommandPath & commandPath, const Commands::SkipChannel::DecodableType & commandData) { - CHIP_ERROR err = CHIP_NO_ERROR; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; - auto & count = commandData.count; + CHIP_ERROR err = CHIP_NO_ERROR; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; + auto & count = commandData.count; Delegate * delegate = GetDelegate(endpoint); VerifyOrExit(isDelegateNull(delegate, endpoint) != true, err = CHIP_ERROR_INCORRECT_STATE); if (!delegate->HandleSkipChannel(count)) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfChannelClusterSkipChannelCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + command->AddStatus(commandPath, status); return true; } diff --git a/src/app/clusters/color-control-server/color-control-server.cpp b/src/app/clusters/color-control-server/color-control-server.cpp index beb2f3dc693b95..2e3c485db6c82d 100644 --- a/src/app/clusters/color-control-server/color-control-server.cpp +++ b/src/app/clusters/color-control-server/color-control-server.cpp @@ -53,25 +53,27 @@ bool ColorControlServer::HasFeature(chip::EndpointId endpoint, ColorControlFeatu return success ? ((featureMap & to_underlying(feature)) != 0) : false; } -EmberAfStatus ColorControlServer::stopAllColorTransitions(EndpointId endpoint) +Status ColorControlServer::stopAllColorTransitions(EndpointId endpoint) { EmberEventControl * event = getEventControl(endpoint); - VerifyOrReturnError(event != nullptr, EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrReturnError(event != nullptr, Status::UnsupportedEndpoint); emberEventControlSetInactive(event); - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } -bool ColorControlServer::stopMoveStepCommand(EndpointId endpoint, uint8_t optionsMask, uint8_t optionsOverride) +bool ColorControlServer::stopMoveStepCommand(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, + uint8_t optionsMask, uint8_t optionsOverride) { - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; if (shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { status = stopAllColorTransitions(endpoint); } - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -756,13 +758,13 @@ bool ColorControlServer::moveHueCommand(app::CommandHandler * commandObj, const uint8_t currentHue = 0; uint16_t currentEnhancedHue = 0; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); Color16uTransitionState * colorSaturationTransitionState = getSaturationTransitionState(endpoint); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorSaturationTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorSaturationTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -850,7 +852,7 @@ bool ColorControlServer::moveHueCommand(app::CommandHandler * commandObj, const emberEventControlSetDelayMS(configureHSVEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -874,15 +876,15 @@ bool ColorControlServer::moveToHueCommand(app::CommandHandler * commandObj, cons { EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; - uint16_t currentHue = 0; + Status status = Status::Success; + uint16_t currentHue = 0; uint8_t direction; ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); Color16uTransitionState * colorSaturationTransitionState = getSaturationTransitionState(endpoint); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorSaturationTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorSaturationTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -998,7 +1000,7 @@ bool ColorControlServer::moveToHueCommand(app::CommandHandler * commandObj, cons emberEventControlSetDelayMS(configureHSVEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1023,16 +1025,16 @@ bool ColorControlServer::moveToHueAndSaturationCommand(app::CommandHandler * com { EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; - uint16_t currentHue = 0; - uint16_t halfWay = isEnhanced ? HALF_MAX_UINT16T : HALF_MAX_UINT8T; + Status status = Status::Success; + uint16_t currentHue = 0; + uint16_t halfWay = isEnhanced ? HALF_MAX_UINT16T : HALF_MAX_UINT8T; bool moveUp; Color16uTransitionState * colorSaturationTransitionState = getSaturationTransitionState(endpoint); ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); - VerifyOrExit(colorSaturationTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorSaturationTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (isEnhanced) { @@ -1126,7 +1128,7 @@ bool ColorControlServer::moveToHueAndSaturationCommand(app::CommandHandler * com emberEventControlSetDelayMS(configureHSVEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1150,13 +1152,13 @@ bool ColorControlServer::stepHueCommand(app::CommandHandler * commandObj, const { EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); Color16uTransitionState * colorSaturationTransitionState = getSaturationTransitionState(endpoint); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorSaturationTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorSaturationTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1237,7 +1239,7 @@ bool ColorControlServer::stepHueCommand(app::CommandHandler * commandObj, const emberEventControlSetDelayMS(configureHSVEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1249,13 +1251,13 @@ bool ColorControlServer::moveSaturationCommand(app::CommandHandler * commandObj, auto & optionsMask = commandData.optionsMask; auto & optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); Color16uTransitionState * colorSaturationTransitionState = getSaturationTransitionState(endpoint); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorSaturationTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorSaturationTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1307,7 +1309,7 @@ bool ColorControlServer::moveSaturationCommand(app::CommandHandler * commandObj, emberEventControlSetDelayMS(configureHSVEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1329,13 +1331,13 @@ bool ColorControlServer::moveToSaturationCommand(app::CommandHandler * commandOb uint8_t optionsMask = commandData.optionsMask; uint8_t optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); Color16uTransitionState * colorSaturationTransitionState = getSaturationTransitionState(endpoint); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorSaturationTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorSaturationTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1382,7 +1384,7 @@ bool ColorControlServer::moveToSaturationCommand(app::CommandHandler * commandOb emberEventControlSetDelayMS(configureHSVEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1395,14 +1397,14 @@ bool ColorControlServer::stepSaturationCommand(app::CommandHandler * commandObj, uint8_t optionsMask = commandData.optionsMask; uint8_t optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; uint8_t currentSaturation = 0; ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); Color16uTransitionState * colorSaturationTransitionState = getSaturationTransitionState(endpoint); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorSaturationTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorSaturationTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1457,7 +1459,7 @@ bool ColorControlServer::stepSaturationCommand(app::CommandHandler * commandObj, emberEventControlSetDelayMS(configureHSVEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1472,12 +1474,12 @@ bool ColorControlServer::colorLoopCommand(app::CommandHandler * commandObj, cons uint8_t optionsMask = commandData.optionsMask; uint8_t optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; uint8_t isColorLoopActive = 0; uint8_t deactiveColorLoop = 0; ColorHueTransitionState * colorHueTransitionState = getColorHueTransitionState(endpoint); - VerifyOrExit(colorHueTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorHueTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1574,7 +1576,7 @@ bool ColorControlServer::colorLoopCommand(app::CommandHandler * commandObj, cons } exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1717,13 +1719,13 @@ bool ColorControlServer::moveToColorCommand(app::CommandHandler * commandObj, co uint8_t optionsMask = commandData.optionsMask; uint8_t optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; Color16uTransitionState * colorXTransitionState = getXTransitionState(endpoint); Color16uTransitionState * colorYTransitionState = getYTransitionState(endpoint); - VerifyOrExit(colorXTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorYTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorXTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorYTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1767,7 +1769,7 @@ bool ColorControlServer::moveToColorCommand(app::CommandHandler * commandObj, co emberEventControlSetDelayMS(configureXYEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1779,13 +1781,13 @@ bool ColorControlServer::moveColorCommand(app::CommandHandler * commandObj, cons uint8_t optionsMask = commandData.optionsMask; uint8_t optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; Color16uTransitionState * colorXTransitionState = getXTransitionState(endpoint); Color16uTransitionState * colorYTransitionState = getYTransitionState(endpoint); - VerifyOrExit(colorXTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorYTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorXTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorYTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1860,7 +1862,7 @@ bool ColorControlServer::moveColorCommand(app::CommandHandler * commandObj, cons emberEventControlSetDelayMS(configureXYEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -1878,13 +1880,13 @@ bool ColorControlServer::stepColorCommand(app::CommandHandler * commandObj, cons uint16_t colorX = 0; uint16_t colorY = 0; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; Color16uTransitionState * colorXTransitionState = getXTransitionState(endpoint); Color16uTransitionState * colorYTransitionState = getYTransitionState(endpoint); - VerifyOrExit(colorXTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(colorYTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorXTransitionState != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(colorYTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -1934,7 +1936,7 @@ bool ColorControlServer::stepColorCommand(app::CommandHandler * commandObj, cons emberEventControlSetDelayMS(configureXYEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -2002,12 +2004,12 @@ ColorControlServer::Color16uTransitionState * ColorControlServer::getTempTransit * @param colorTemperature * @param transitionTime */ -EmberAfStatus ColorControlServer::moveToColorTemp(EndpointId aEndpoint, uint16_t colorTemperature, uint16_t transitionTime) +Status ColorControlServer::moveToColorTemp(EndpointId aEndpoint, uint16_t colorTemperature, uint16_t transitionTime) { EndpointId endpoint = aEndpoint; Color16uTransitionState * colorTempTransitionState = getTempTransitionState(endpoint); - VerifyOrReturnError(colorTempTransitionState != nullptr, EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrReturnError(colorTempTransitionState != nullptr, Status::UnsupportedEndpoint); uint16_t temperatureMin = MIN_TEMPERATURE_VALUE; Attributes::ColorTempPhysicalMinMireds::Get(endpoint, &temperatureMin); @@ -2049,7 +2051,7 @@ EmberAfStatus ColorControlServer::moveToColorTemp(EndpointId aEndpoint, uint16_t // kick off the state machine emberEventControlSetDelayMS(configureTempEventControl(endpoint), UPDATE_TIME_MS); - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } /** @@ -2192,13 +2194,13 @@ bool ColorControlServer::moveColorTempCommand(app::CommandHandler * commandObj, uint8_t optionsMask = commandData.optionsMask; uint8_t optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; uint16_t tempPhysicalMin = MIN_TEMPERATURE_VALUE; uint16_t tempPhysicalMax = MAX_TEMPERATURE_VALUE; uint16_t transitionTime; Color16uTransitionState * colorTempTransitionState = getTempTransitionState(endpoint); - VerifyOrExit(colorTempTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorTempTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -2276,7 +2278,7 @@ bool ColorControlServer::moveColorTempCommand(app::CommandHandler * commandObj, emberEventControlSetDelayMS(configureTempEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -2295,9 +2297,9 @@ bool ColorControlServer::moveToColorTempCommand(app::CommandHandler * commandObj return true; } - EmberAfStatus error = moveToColorTemp(endpoint, colorTemperature, transitionTime); + Status error = moveToColorTemp(endpoint, colorTemperature, transitionTime); - emberAfSendImmediateDefaultResponse(error); + commandObj->AddStatus(commandPath, error); return true; } @@ -2312,12 +2314,12 @@ bool ColorControlServer::stepColorTempCommand(app::CommandHandler * commandObj, uint8_t optionsMask = commandData.optionsMask; uint8_t optionsOverride = commandData.optionsOverride; EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; uint16_t tempPhysicalMin = MIN_TEMPERATURE_VALUE; uint16_t tempPhysicalMax = MAX_TEMPERATURE_VALUE; Color16uTransitionState * colorTempTransitionState = getTempTransitionState(endpoint); - VerifyOrExit(colorTempTransitionState != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); + VerifyOrExit(colorTempTransitionState != nullptr, status = Status::UnsupportedEndpoint); if (!shouldExecuteIfOff(endpoint, optionsMask, optionsOverride)) { @@ -2395,7 +2397,7 @@ bool ColorControlServer::stepColorTempCommand(app::CommandHandler * commandObj, emberEventControlSetDelayMS(configureTempEventControl(endpoint), UPDATE_TIME_MS); exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -2639,7 +2641,7 @@ void emberAfPluginLevelControlCoupledColorTempChangeCallback(EndpointId endpoint bool emberAfColorControlClusterStopMoveStepCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::StopMoveStep::DecodableType & commandData) { - return ColorControlServer::Instance().stopMoveStepCommand(commandPath.mEndpointId, commandData.optionsMask, + return ColorControlServer::Instance().stopMoveStepCommand(commandObj, commandPath, commandData.optionsMask, commandData.optionsOverride); } diff --git a/src/app/clusters/color-control-server/color-control-server.h b/src/app/clusters/color-control-server/color-control-server.h index 05c6554f43fd58..cae5d9829df301 100644 --- a/src/app/clusters/color-control-server/color-control-server.h +++ b/src/app/clusters/color-control-server/color-control-server.h @@ -22,6 +22,7 @@ #include #include #include +#include /********************************************************** * Defines and Macros @@ -130,8 +131,9 @@ class ColorControlServer static ColorControlServer & Instance(); bool HasFeature(chip::EndpointId endpoint, ColorControlFeature feature); - EmberAfStatus stopAllColorTransitions(chip::EndpointId endpoint); - bool stopMoveStepCommand(chip::EndpointId, uint8_t optionsMask, uint8_t optionsOverride); + chip::Protocols::InteractionModel::Status stopAllColorTransitions(chip::EndpointId endpoint); + bool stopMoveStepCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath, + uint8_t optionsMask, uint8_t optionsOverride); #ifdef EMBER_AF_PLUGIN_COLOR_CONTROL_SERVER_HSV bool moveHueCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath, @@ -220,7 +222,8 @@ class ColorControlServer #ifdef EMBER_AF_PLUGIN_COLOR_CONTROL_SERVER_TEMP Color16uTransitionState * getTempTransitionState(chip::EndpointId endpoint); - EmberAfStatus moveToColorTemp(chip::EndpointId aEndpoint, uint16_t colorTemperature, uint16_t transitionTime); + chip::Protocols::InteractionModel::Status moveToColorTemp(chip::EndpointId aEndpoint, uint16_t colorTemperature, + uint16_t transitionTime); uint16_t getTemperatureCoupleToLevelMin(chip::EndpointId endpoint); EmberEventControl * configureTempEventControl(chip::EndpointId); #endif // EMBER_AF_PLUGIN_COLOR_CONTROL_SERVER_TEMP diff --git a/src/app/clusters/diagnostic-logs-server/diagnostic-logs-server.cpp b/src/app/clusters/diagnostic-logs-server/diagnostic-logs-server.cpp index 9464d9c355235a..b19e4733954eb1 100644 --- a/src/app/clusters/diagnostic-logs-server/diagnostic-logs-server.cpp +++ b/src/app/clusters/diagnostic-logs-server/diagnostic-logs-server.cpp @@ -111,9 +111,7 @@ bool emberAfDiagnosticLogsClusterRetrieveLogsRequestCallback( chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath, const chip::app::Clusters::DiagnosticLogs::Commands::RetrieveLogsRequest::DecodableType & commandData) { - // TODO: Shouldn't the default "no-op" impl return some sort of error? - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, chip::Protocols::InteractionModel::Status::UnsupportedCommand); return true; } diff --git a/src/app/clusters/door-lock-server/door-lock-server.cpp b/src/app/clusters/door-lock-server/door-lock-server.cpp index 229ba23e6fed06..197f105d13897a 100644 --- a/src/app/clusters/door-lock-server/door-lock-server.cpp +++ b/src/app/clusters/door-lock-server/door-lock-server.cpp @@ -559,12 +559,12 @@ void DoorLockServer::clearUserCommandHandler(chip::app::CommandHandler * command if (0xFFFE != userIndex) { auto status = clearUser(commandPath.mEndpointId, fabricIdx, sourceNodeId, userIndex, true); - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { ChipLogError(Zcl, "[ClearUser] App reported failure when resetting the user [userIndex=%d,status=0x%x]", userIndex, - status); + to_underlying(status)); } - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return; } @@ -572,9 +572,10 @@ void DoorLockServer::clearUserCommandHandler(chip::app::CommandHandler * command for (uint16_t i = 1; i <= maxNumberOfUsers; ++i) { auto status = clearUser(commandPath.mEndpointId, fabricIdx, sourceNodeId, i, false); - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { - ChipLogError(Zcl, "[ClearUser] App reported failure when resetting the user [userIndex=%d,status=0x%x]", i, status); + ChipLogError(Zcl, "[ClearUser] App reported failure when resetting the user [userIndex=%d,status=0x%x]", i, + to_underlying(status)); commandObj->AddStatus(commandPath, Status::Failure); return; @@ -865,7 +866,7 @@ void DoorLockServer::clearCredentialCommandHandler( if (credential.IsNull()) { emberAfDoorLockClusterPrintln("[ClearCredential] Clearing all credentials [endpointId=%d]", commandPath.mEndpointId); - emberAfSendImmediateDefaultResponse(clearCredentials(commandPath.mEndpointId, modifier, sourceNodeId)); + commandObj->AddStatus(commandPath, clearCredentials(commandPath.mEndpointId, modifier, sourceNodeId)); return; } @@ -874,12 +875,12 @@ void DoorLockServer::clearCredentialCommandHandler( auto credentialIndex = credential.Value().credentialIndex; if (0xFFFE == credentialIndex) { - emberAfSendImmediateDefaultResponse(clearCredentials(commandPath.mEndpointId, modifier, sourceNodeId, credentialType)); + commandObj->AddStatus(commandPath, clearCredentials(commandPath.mEndpointId, modifier, sourceNodeId, credentialType)); return; } - emberAfSendImmediateDefaultResponse( - clearCredential(commandPath.mEndpointId, modifier, sourceNodeId, credentialType, credentialIndex, false)); + commandObj->AddStatus(commandPath, + clearCredential(commandPath.mEndpointId, modifier, sourceNodeId, credentialType, credentialIndex, false)); } void DoorLockServer::setWeekDayScheduleCommandHandler(chip::app::CommandHandler * commandObj, @@ -1884,20 +1885,20 @@ EmberAfStatus DoorLockServer::modifyUser(chip::EndpointId endpointId, chip::Fabr return EMBER_ZCL_STATUS_SUCCESS; } -EmberAfStatus DoorLockServer::clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, chip::NodeId sourceNodeId, - uint16_t userIndex, bool sendUserChangeEvent) +Status DoorLockServer::clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, chip::NodeId sourceNodeId, + uint16_t userIndex, bool sendUserChangeEvent) { EmberAfPluginDoorLockUserInfo user; if (!emberAfPluginDoorLockGetUser(endpointId, userIndex, user)) { - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } return clearUser(endpointId, modifierFabricId, sourceNodeId, userIndex, user, sendUserChangeEvent); } -EmberAfStatus DoorLockServer::clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, chip::NodeId sourceNodeId, - uint16_t userIndex, const EmberAfPluginDoorLockUserInfo & user, bool sendUserChangeEvent) +Status DoorLockServer::clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, chip::NodeId sourceNodeId, + uint16_t userIndex, const EmberAfPluginDoorLockUserInfo & user, bool sendUserChangeEvent) { // appclusters, 5.2.4.37: all the credentials associated with user should be cleared when clearing the user for (const auto & credential : user.credentials) @@ -1914,7 +1915,7 @@ EmberAfStatus DoorLockServer::clearUser(chip::EndpointId endpointId, chip::Fabri "[ClearUser] Unable to remove credentials associated with user - internal error " "[endpointId=%d,userIndex=%d,credentialIndex=%d,credentialType=%u]", endpointId, userIndex, credential.CredentialIndex, credential.CredentialType); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } } @@ -1924,6 +1925,8 @@ EmberAfStatus DoorLockServer::clearUser(chip::EndpointId endpointId, chip::Fabri { ChipLogError(Zcl, "[ClearUser] Unable to delete schedules - internal error [endpointId=%d,userIndex=%d]", endpointId, userIndex); + // TODO: Figure out whether this should still clear the user even though + // schedule clearing failed? } // Remove the user entry @@ -1931,7 +1934,7 @@ EmberAfStatus DoorLockServer::clearUser(chip::EndpointId endpointId, chip::Fabri UserStatusEnum::kAvailable, UserTypeEnum::kUnrestrictedUser, CredentialRuleEnum::kSingle, nullptr, 0)) { - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } if (sendUserChangeEvent) @@ -1939,7 +1942,7 @@ EmberAfStatus DoorLockServer::clearUser(chip::EndpointId endpointId, chip::Fabri sendRemoteLockUserChange(endpointId, LockDataTypeEnum::kUserIndex, DataOperationTypeEnum::kClear, sourceNodeId, modifierFabricId, userIndex, userIndex); } - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } bool DoorLockServer::clearFabricFromUsers(chip::EndpointId endpointId, chip::FabricIndex fabricIndex) @@ -2649,15 +2652,15 @@ void DoorLockServer::sendHolidayScheduleResponse(chip::app::CommandHandler * com commandObj->AddResponse(commandPath, response); } -EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId, - CredentialTypeEnum credentialType, uint16_t credentialIndex, bool sendUserChangeEvent) +Status DoorLockServer::clearCredential(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId, + CredentialTypeEnum credentialType, uint16_t credentialIndex, bool sendUserChangeEvent) { if (CredentialTypeEnum::kProgrammingPIN == credentialType) { emberAfDoorLockClusterPrintln("[clearCredential] Cannot clear programming PIN credentials " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier); - return EMBER_ZCL_STATUS_INVALID_COMMAND; + return Status::InvalidCommand; } if (!credentialIndexValid(endpointId, credentialType, credentialIndex)) @@ -2665,7 +2668,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: emberAfDoorLockClusterPrintln("[clearCredential] Cannot clear credential - index out of bounds " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier); - return EMBER_ZCL_STATUS_INVALID_COMMAND; + return Status::InvalidCommand; } // 1. Fetch the credential from storage, so we know what we're deleting @@ -2676,7 +2679,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[clearCredential] Unable to clear credential - couldn't read credential from database " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } if (DlCredentialStatus::kAvailable == credential.status) @@ -2684,7 +2687,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: emberAfDoorLockClusterPrintln("[clearCredential] Ignored attempt to clear unoccupied credential slot " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier); - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } if (credentialType != credential.credentialType) @@ -2693,7 +2696,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d,actualCredentialType=%u]", endpointId, to_underlying(credentialType), credentialIndex, modifier, to_underlying(credential.credentialType)); - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } // 2. Get the associated user and if it is the only attached credential -- delete the user. This operation will @@ -2705,7 +2708,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[clearCredential] Unable to clear related credential user - couldn't find index of related user " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } EmberAfPluginDoorLockUserInfo relatedUser; if (!emberAfPluginDoorLockGetUser(endpointId, relatedUserIndex, relatedUser)) @@ -2715,7 +2718,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d,userIndex=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } if (1 == relatedUser.credentials.size()) { @@ -2723,19 +2726,20 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d,userIndex=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex); auto clearStatus = clearUser(endpointId, modifier, sourceNodeId, relatedUserIndex, relatedUser, true); - if (EMBER_ZCL_STATUS_SUCCESS != clearStatus) + if (Status::Success != clearStatus) { ChipLogError(Zcl, "[clearCredential] Unable to clear related credential user - internal error " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d,userIndex=%d,status=%d]", - endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex, clearStatus); + endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex, + to_underlying(clearStatus)); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } emberAfDoorLockClusterPrintln("[clearCredential] Successfully clear credential and related user " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d,userIndex=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex); - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } // 3. If the user wasn't deleted, delete the credential and adjust the list of credentials for related user in the storage @@ -2746,7 +2750,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[clearCredential] Unable to clear credential - couldn't write new credential to database " "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d]", endpointId, to_underlying(credentialType), credentialIndex, modifier); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } uint8_t maxCredentialsPerUser; @@ -2756,7 +2760,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[clearCredential] Unable to get the number of available credentials per user: internal error " "[endpointId=%d,credentialType=%d,credentialIndex=%d]", endpointId, to_underlying(credentialType), credentialIndex); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } // Should never happen, only possible if the implementation of application is incorrect @@ -2768,7 +2772,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex, static_cast(relatedUser.credentials.size())); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } chip::Platform::ScopedMemoryBuffer newCredentials; @@ -2779,7 +2783,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: "[endpointId=%d,credentialType=%u,credentialIndex=%d,modifier=%d,userIndex=%d,credentialsCount=%u]", endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex, static_cast(relatedUser.credentials.size())); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } size_t newCredentialsCount = 0; @@ -2802,7 +2806,7 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: ",credentialIndex=%d,modifier=%d,userIndex=%d,newCredentialsCount=%u]", endpointId, to_underlying(credentialType), credentialIndex, modifier, relatedUserIndex, static_cast(newCredentialsCount)); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } emberAfDoorLockClusterPrintln( @@ -2817,18 +2821,18 @@ EmberAfStatus DoorLockServer::clearCredential(chip::EndpointId endpointId, chip: sourceNodeId, modifier, relatedUserIndex, credentialIndex); } - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } -EmberAfStatus DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId) +Status DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId) { if (SupportsPIN(endpointId)) { auto status = clearCredentials(endpointId, modifier, sourceNodeId, CredentialTypeEnum::kPin); - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { ChipLogError(Zcl, "[clearCredentials] Unable to clear all PIN credentials [endpointId=%d,status=%d]", endpointId, - status); + to_underlying(status)); return status; } @@ -2838,10 +2842,10 @@ EmberAfStatus DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip if (SupportsRFID(endpointId)) { auto status = clearCredentials(endpointId, modifier, sourceNodeId, CredentialTypeEnum::kRfid); - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { ChipLogError(Zcl, "[clearCredentials] Unable to clear all RFID credentials [endpointId=%d,status=%d]", endpointId, - status); + to_underlying(status)); return status; } emberAfDoorLockClusterPrintln("[clearCredentials] All RFID credentials were cleared [endpointId=%d]", endpointId); @@ -2850,18 +2854,18 @@ EmberAfStatus DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip if (SupportsFingers(endpointId)) { auto status = clearCredentials(endpointId, modifier, sourceNodeId, CredentialTypeEnum::kFingerprint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { ChipLogError(Zcl, "[clearCredentials] Unable to clear all Fingerprint credentials [endpointId=%d,status=%d]", - endpointId, status); + endpointId, to_underlying(status)); return status; } status = clearCredentials(endpointId, modifier, sourceNodeId, CredentialTypeEnum::kFingerVein); - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { ChipLogError(Zcl, "[clearCredentials] Unable to clear all Finger Vein credentials [endpointId=%d,status=%d]", - endpointId, status); + endpointId, to_underlying(status)); return status; } @@ -2871,20 +2875,20 @@ EmberAfStatus DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip if (SupportsFace(endpointId)) { auto status = clearCredentials(endpointId, modifier, sourceNodeId, CredentialTypeEnum::kFace); - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { ChipLogError(Zcl, "[clearCredentials] Unable to clear all face credentials [endpointId=%d,status=%d]", endpointId, - status); + to_underlying(status)); return status; } emberAfDoorLockClusterPrintln("[clearCredentials] All face credentials were cleared [endpointId=%d]", endpointId); } - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } -EmberAfStatus DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId, - CredentialTypeEnum credentialType) +Status DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId, + CredentialTypeEnum credentialType) { uint16_t maxNumberOfCredentials = 0; if (!getMaxNumberOfCredentials(endpointId, credentialType, maxNumberOfCredentials)) @@ -2893,21 +2897,21 @@ EmberAfStatus DoorLockServer::clearCredentials(chip::EndpointId endpointId, chip "[clearCredentials] Unable to get max number of credentials to clear - can't get max number of credentials " "[endpointId=%d,credentialType=%u]", endpointId, to_underlying(credentialType)); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; bool clearedCredential = false; for (uint16_t i = 1; i < maxNumberOfCredentials; ++i) { - EmberAfStatus clearStatus = clearCredential(endpointId, modifier, sourceNodeId, credentialType, i, false); - if (EMBER_ZCL_STATUS_SUCCESS != clearStatus) + Status clearStatus = clearCredential(endpointId, modifier, sourceNodeId, credentialType, i, false); + if (Status::Success != clearStatus) { ChipLogError(Zcl, "[clearCredentials] Unable to clear the credential - internal error " "[endpointId=%d,credentialType=%u,credentialIndex=%d,status=%d]", - endpointId, to_underlying(credentialType), i, status); - if (status == EMBER_ZCL_STATUS_SUCCESS) + endpointId, to_underlying(credentialType), i, to_underlying(status)); + if (status == Status::Success) { status = clearStatus; } @@ -3371,7 +3375,7 @@ bool DoorLockServer::HandleRemoteLockOperation(chip::app::CommandHandler * comma } // Send command response - emberAfSendImmediateDefaultResponse(success ? EMBER_ZCL_STATUS_SUCCESS : EMBER_ZCL_STATUS_FAILURE); + commandObj->AddStatus(commandPath, success ? Status::Success : Status::Failure); // Most of the time we want to send the lock operation event but sometimes (when the lockout is active) we don't want it. if (!sendEvent) diff --git a/src/app/clusters/door-lock-server/door-lock-server.h b/src/app/clusters/door-lock-server/door-lock-server.h index 3f8fab53e8cd62..d56ef343ff43f7 100644 --- a/src/app/clusters/door-lock-server/door-lock-server.h +++ b/src/app/clusters/door-lock-server/door-lock-server.h @@ -30,6 +30,7 @@ #include #include #include +#include #ifndef DOOR_LOCK_SERVER_ENDPOINT #define DOOR_LOCK_SERVER_ENDPOINT 1 @@ -219,10 +220,11 @@ class DoorLockServer uint16_t userIndex, const Nullable & userName, const Nullable & userUniqueId, const Nullable & userStatus, const Nullable & userType, const Nullable & credentialRule); - EmberAfStatus clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, chip::NodeId sourceNodeId, - uint16_t userIndex, bool sendUserChangeEvent); - EmberAfStatus clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, chip::NodeId sourceNodeId, - uint16_t userIndex, const EmberAfPluginDoorLockUserInfo & user, bool sendUserChangeEvent); + chip::Protocols::InteractionModel::Status clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, + chip::NodeId sourceNodeId, uint16_t userIndex, bool sendUserChangeEvent); + chip::Protocols::InteractionModel::Status clearUser(chip::EndpointId endpointId, chip::FabricIndex modifierFabricId, + chip::NodeId sourceNodeId, uint16_t userIndex, + const EmberAfPluginDoorLockUserInfo & user, bool sendUserChangeEvent); bool clearFabricFromUsers(chip::EndpointId endpointId, chip::FabricIndex fabricIndex); @@ -252,11 +254,13 @@ class DoorLockServer const EmberAfPluginDoorLockCredentialInfo & existingCredential, const chip::ByteSpan & credentialData, uint16_t userIndex, const Nullable & userStatus, Nullable userType); - EmberAfStatus clearCredential(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId, - CredentialTypeEnum credentialType, uint16_t credentialIndex, bool sendUserChangeEvent); - EmberAfStatus clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId); - EmberAfStatus clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, chip::NodeId sourceNodeId, - CredentialTypeEnum credentialType); + chip::Protocols::InteractionModel::Status clearCredential(chip::EndpointId endpointId, chip::FabricIndex modifier, + chip::NodeId sourceNodeId, CredentialTypeEnum credentialType, + uint16_t credentialIndex, bool sendUserChangeEvent); + chip::Protocols::InteractionModel::Status clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, + chip::NodeId sourceNodeId); + chip::Protocols::InteractionModel::Status clearCredentials(chip::EndpointId endpointId, chip::FabricIndex modifier, + chip::NodeId sourceNodeId, CredentialTypeEnum credentialType); bool clearFabricFromCredentials(chip::EndpointId endpointId, CredentialTypeEnum credentialType, chip::FabricIndex fabricToRemove); diff --git a/src/app/clusters/group-key-mgmt-server/group-key-mgmt-server.cpp b/src/app/clusters/group-key-mgmt-server/group-key-mgmt-server.cpp index 36b17457cc12c6..d3ff29f0e326b9 100644 --- a/src/app/clusters/group-key-mgmt-server/group-key-mgmt-server.cpp +++ b/src/app/clusters/group-key-mgmt-server/group-key-mgmt-server.cpp @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include @@ -374,11 +375,10 @@ bool emberAfGroupKeyManagementClusterKeySetWriteCallback( } // Send response - EmberStatus status = - emberAfSendImmediateDefaultResponse(CHIP_NO_ERROR == err ? EMBER_ZCL_STATUS_SUCCESS : EMBER_ZCL_STATUS_FAILURE); - if (EMBER_SUCCESS != status) + err = commandObj->AddStatus(commandPath, StatusIB(err).mStatus); + if (CHIP_NO_ERROR != err) { - ChipLogDetail(Zcl, "GroupKeyManagementCluster: KeySetWrite failed: 0x%x", status); + ChipLogDetail(Zcl, "GroupKeyManagementCluster: KeySetWrite failed: %" CHIP_ERROR_FORMAT, err.Format()); } return true; } @@ -451,9 +451,9 @@ bool emberAfGroupKeyManagementClusterKeySetRemoveCallback( const chip::app::Clusters::GroupKeyManagement::Commands::KeySetRemove::DecodableType & commandData) { - auto fabric = commandObj->GetAccessingFabricIndex(); - auto * provider = GetGroupDataProvider(); - EmberAfStatus status = EMBER_ZCL_STATUS_FAILURE; + auto fabric = commandObj->GetAccessingFabricIndex(); + auto * provider = GetGroupDataProvider(); + Status status = Status::Failure; if (nullptr != provider) { @@ -461,19 +461,19 @@ bool emberAfGroupKeyManagementClusterKeySetRemoveCallback( CHIP_ERROR err = provider->RemoveKeySet(fabric, commandData.groupKeySetID); if (CHIP_ERROR_KEY_NOT_FOUND == err) { - status = EMBER_ZCL_STATUS_NOT_FOUND; + status = Status::NotFound; } else if (CHIP_NO_ERROR == err) { - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; } } // Send response - EmberStatus send_status = emberAfSendImmediateDefaultResponse(status); - if (EMBER_SUCCESS != send_status) + CHIP_ERROR send_err = commandObj->AddStatus(commandPath, status); + if (CHIP_NO_ERROR != send_err) { - ChipLogDetail(Zcl, "GroupKeyManagementCluster: KeySetRemove failed: 0x%x", send_status); + ChipLogDetail(Zcl, "GroupKeyManagementCluster: KeySetRemove failed: %" CHIP_ERROR_FORMAT, send_err.Format()); } return true; } diff --git a/src/app/clusters/groups-server/groups-server.cpp b/src/app/clusters/groups-server/groups-server.cpp index 39ba191b37b710..8e27d9783615f4 100644 --- a/src/app/clusters/groups-server/groups-server.cpp +++ b/src/app/clusters/groups-server/groups-server.cpp @@ -35,6 +35,7 @@ using namespace chip; using namespace app::Clusters; using namespace app::Clusters::Groups; using namespace chip::Credentials; +using Protocols::InteractionModel::Status; /** * @brief Checks if group-endpoint association exist for the given fabric @@ -71,13 +72,13 @@ static bool KeyExists(FabricIndex fabricIndex, GroupId groupId) return found; } -static EmberAfStatus GroupAdd(FabricIndex fabricIndex, EndpointId endpointId, GroupId groupId, const CharSpan & groupName) +static Status GroupAdd(FabricIndex fabricIndex, EndpointId endpointId, GroupId groupId, const CharSpan & groupName) { - VerifyOrReturnError(IsFabricGroupId(groupId), EMBER_ZCL_STATUS_CONSTRAINT_ERROR); + VerifyOrReturnError(IsFabricGroupId(groupId), Status::ConstraintError); GroupDataProvider * provider = GetGroupDataProvider(); - VerifyOrReturnError(nullptr != provider, EMBER_ZCL_STATUS_NOT_FOUND); - VerifyOrReturnError(KeyExists(fabricIndex, groupId), EMBER_ZCL_STATUS_UNSUPPORTED_ACCESS); + VerifyOrReturnError(nullptr != provider, Status::NotFound); + VerifyOrReturnError(KeyExists(fabricIndex, groupId), Status::UnsupportedAccess); // Add a new entry to the GroupTable CHIP_ERROR err = provider->SetGroupInfo(fabricIndex, GroupDataProvider::GroupInfo(groupId, groupName)); @@ -87,12 +88,12 @@ static EmberAfStatus GroupAdd(FabricIndex fabricIndex, EndpointId endpointId, Gr } if (CHIP_NO_ERROR == err) { - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } ChipLogDetail(Zcl, "ERR: Failed to add mapping (end:%d, group:0x%x), err:%" CHIP_ERROR_FORMAT, endpointId, groupId, err.Format()); - return EMBER_ZCL_STATUS_RESOURCE_EXHAUSTED; + return Status::ResourceExhausted; } static EmberAfStatus GroupRemove(FabricIndex fabricIndex, EndpointId endpointId, GroupId groupId) @@ -141,7 +142,7 @@ bool emberAfGroupsClusterAddGroupCallback(app::CommandHandler * commandObj, cons Groups::Commands::AddGroupResponse::Type response; response.groupID = commandData.groupID; - response.status = GroupAdd(fabricIndex, commandPath.mEndpointId, commandData.groupID, commandData.groupName); + response.status = to_underlying(GroupAdd(fabricIndex, commandPath.mEndpointId, commandData.groupID, commandData.groupName)); commandObj->AddResponse(commandPath, response); return true; } @@ -252,28 +253,28 @@ struct GroupMembershipResponse bool emberAfGroupsClusterGetGroupMembershipCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::GetGroupMembership::DecodableType & commandData) { - auto fabricIndex = commandObj->GetAccessingFabricIndex(); - auto * provider = GetGroupDataProvider(); - EmberAfStatus status = EMBER_ZCL_STATUS_FAILURE; + auto fabricIndex = commandObj->GetAccessingFabricIndex(); + auto * provider = GetGroupDataProvider(); + Status status = Status::Failure; - VerifyOrExit(nullptr != provider, status = EMBER_ZCL_STATUS_FAILURE); + VerifyOrExit(nullptr != provider, status = Status::Failure); { GroupDataProvider::EndpointIterator * iter = nullptr; iter = provider->IterateEndpoints(fabricIndex); - VerifyOrExit(nullptr != iter, status = EMBER_ZCL_STATUS_FAILURE); + VerifyOrExit(nullptr != iter, status = Status::Failure); commandObj->AddResponse(commandPath, GroupMembershipResponse(commandData, commandPath.mEndpointId, iter)); iter->Release(); - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; } exit: - if (EMBER_ZCL_STATUS_SUCCESS != status) + if (Status::Success != status) { - ChipLogDetail(Zcl, "GroupsCluster: GetGroupMembership failed: failed: 0x%x", status); - emberAfSendImmediateDefaultResponse(status); + ChipLogDetail(Zcl, "GroupsCluster: GetGroupMembership failed: failed: 0x%x", to_underlying(status)); + commandObj->AddStatus(commandPath, status); } return true; } @@ -298,18 +299,18 @@ bool emberAfGroupsClusterRemoveGroupCallback(app::CommandHandler * commandObj, c bool emberAfGroupsClusterRemoveAllGroupsCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::RemoveAllGroups::DecodableType & commandData) { - auto fabricIndex = commandObj->GetAccessingFabricIndex(); - auto * provider = GetGroupDataProvider(); - EmberAfStatus status = EMBER_ZCL_STATUS_FAILURE; + auto fabricIndex = commandObj->GetAccessingFabricIndex(); + auto * provider = GetGroupDataProvider(); + Status status = Status::Failure; - VerifyOrExit(nullptr != provider, status = EMBER_ZCL_STATUS_FAILURE); + VerifyOrExit(nullptr != provider, status = Status::Failure); #ifdef EMBER_AF_PLUGIN_SCENES { GroupDataProvider::EndpointIterator * iter = provider->IterateEndpoints(fabricIndex); GroupDataProvider::GroupEndpoint mapping; - VerifyOrExit(nullptr != iter, status = EMBER_ZCL_STATUS_FAILURE); + VerifyOrExit(nullptr != iter, status = Status::Failure); while (iter->Next(mapping)) { if (commandPath.mEndpointId == mapping.endpoint_id) @@ -323,13 +324,13 @@ bool emberAfGroupsClusterRemoveAllGroupsCallback(app::CommandHandler * commandOb #endif provider->RemoveEndpoint(fabricIndex, commandPath.mEndpointId); - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; exit: - emberAfSendImmediateDefaultResponse(status); - if (EMBER_ZCL_STATUS_SUCCESS != status) + commandObj->AddStatus(commandPath, status); + if (Status::Success != status) { - ChipLogDetail(Zcl, "GroupsCluster: RemoveAllGroups failed: 0x%x", status); + ChipLogDetail(Zcl, "GroupsCluster: RemoveAllGroups failed: 0x%x", to_underlying(status)); } return true; } @@ -343,23 +344,21 @@ bool emberAfGroupsClusterAddGroupIfIdentifyingCallback(app::CommandHandler * com auto groupName = commandData.groupName; auto endpointId = commandPath.mEndpointId; - EmberAfStatus status; - EmberStatus sendStatus = EMBER_SUCCESS; - + Status status; if (!emberAfIsDeviceIdentifying(endpointId)) { // If not identifying, ignore add group -> success; not a failure. - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; } else { status = GroupAdd(fabricIndex, endpointId, groupId, groupName); } - sendStatus = emberAfSendImmediateDefaultResponse(status); - if (EMBER_SUCCESS != sendStatus) + CHIP_ERROR sendErr = commandObj->AddStatus(commandPath, status); + if (CHIP_NO_ERROR != sendErr) { - ChipLogDetail(Zcl, "Groups: failed to send %s: 0x%x", "default_response", sendStatus); + ChipLogDetail(Zcl, "Groups: failed to send %s: %" CHIP_ERROR_FORMAT, "status_response", sendErr.Format()); } return true; } diff --git a/src/app/clusters/identify-server/identify-server.cpp b/src/app/clusters/identify-server/identify-server.cpp index 4a0db21a76e901..15da36a48077fa 100644 --- a/src/app/clusters/identify-server/identify-server.cpp +++ b/src/app/clusters/identify-server/identify-server.cpp @@ -28,6 +28,7 @@ #include #include +#include #include #include #include @@ -204,9 +205,9 @@ bool emberAfIdentifyClusterIdentifyCallback(CommandHandler * commandObj, const a auto & identifyTime = commandData.identifyTime; // cmd Identify - return EMBER_SUCCESS == - emberAfSendImmediateDefaultResponse( - Clusters::Identify::Attributes::IdentifyTime::Set(commandPath.mEndpointId, identifyTime)); + commandObj->AddStatus(commandPath, + ToInteractionModelStatus(Attributes::IdentifyTime::Set(commandPath.mEndpointId, identifyTime))); + return true; } bool emberAfIdentifyClusterTriggerEffectCallback(CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, diff --git a/src/app/clusters/level-control/level-control.cpp b/src/app/clusters/level-control/level-control.cpp index d569bb1a66efb0..14f472307be272 100644 --- a/src/app/clusters/level-control/level-control.cpp +++ b/src/app/clusters/level-control/level-control.cpp @@ -25,6 +25,7 @@ #include #include #include +#include #include #include @@ -50,6 +51,7 @@ using namespace chip; using namespace chip::app::Clusters; using namespace chip::app::Clusters::LevelControl; +using chip::Protocols::InteractionModel::Status; #ifndef IGNORE_LEVEL_CONTROL_CLUSTER_START_UP_CURRENT_LEVEL static bool areStartUpLevelControlServerAttributesNonVolatile(EndpointId endpoint); @@ -99,18 +101,19 @@ static EmberAfLevelControlState stateTable[kLevelControlStateTableSize]; static EmberAfLevelControlState * getState(EndpointId endpoint); -static EmberAfStatus moveToLevelHandler(EndpointId endpoint, CommandId commandId, uint8_t level, - app::DataModel::Nullable transitionTimeDs, - chip::Optional> optionsMask, - chip::Optional> optionsOverride, uint16_t storedLevel); -static void moveHandler(EndpointId endpoint, CommandId commandId, uint8_t moveMode, app::DataModel::Nullable rate, - chip::Optional> optionsMask, +static Status moveToLevelHandler(EndpointId endpoint, CommandId commandId, uint8_t level, + app::DataModel::Nullable transitionTimeDs, + chip::Optional> optionsMask, + chip::Optional> optionsOverride, uint16_t storedLevel); +static void moveHandler(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, uint8_t moveMode, + app::DataModel::Nullable rate, chip::Optional> optionsMask, chip::Optional> optionsOverride); -static void stepHandler(EndpointId endpoint, CommandId commandId, uint8_t stepMode, uint8_t stepSize, - app::DataModel::Nullable transitionTimeDs, +static void stepHandler(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, uint8_t stepMode, + uint8_t stepSize, app::DataModel::Nullable transitionTimeDs, chip::Optional> optionsMask, chip::Optional> optionsOverride); -static void stopHandler(EndpointId endpoint, CommandId commandId, chip::Optional> optionsMask, +static void stopHandler(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, + chip::Optional> optionsMask, chip::Optional> optionsOverride); static void setOnOffValue(EndpointId endpoint, bool onOff); @@ -459,12 +462,12 @@ bool emberAfLevelControlClusterMoveToLevelCallback(app::CommandHandler * command optionsMask.Raw(), optionsOverride.Raw()); } - EmberAfStatus status = moveToLevelHandler(commandPath.mEndpointId, Commands::MoveToLevel::Id, level, transitionTime, - Optional>(optionsMask), - Optional>(optionsOverride), - INVALID_STORED_LEVEL); // Don't revert to the stored level + Status status = moveToLevelHandler(commandPath.mEndpointId, Commands::MoveToLevel::Id, level, transitionTime, + Optional>(optionsMask), + Optional>(optionsOverride), + INVALID_STORED_LEVEL); // Don't revert to the stored level - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -489,12 +492,12 @@ bool emberAfLevelControlClusterMoveToLevelWithOnOffCallback(app::CommandHandler transitionTime.Value(), optionsMask.Raw(), optionsOverride.Raw()); } - EmberAfStatus status = moveToLevelHandler(commandPath.mEndpointId, Commands::MoveToLevelWithOnOff::Id, level, transitionTime, - Optional>(optionsMask), - Optional>(optionsOverride), - INVALID_STORED_LEVEL); // Don't revert to the stored level + Status status = moveToLevelHandler(commandPath.mEndpointId, Commands::MoveToLevelWithOnOff::Id, level, transitionTime, + Optional>(optionsMask), + Optional>(optionsOverride), + INVALID_STORED_LEVEL); // Don't revert to the stored level - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -518,7 +521,7 @@ bool emberAfLevelControlClusterMoveCallback(app::CommandHandler * commandObj, co optionsOverride.Raw()); } - moveHandler(commandPath.mEndpointId, Commands::Move::Id, moveMode, rate, Optional>(optionsMask), + moveHandler(commandObj, commandPath, moveMode, rate, Optional>(optionsMask), Optional>(optionsOverride)); return true; } @@ -542,8 +545,8 @@ bool emberAfLevelControlClusterMoveWithOnOffCallback(app::CommandHandler * comma optionsMask.Raw(), optionsOverride.Raw()); } - moveHandler(commandPath.mEndpointId, Commands::MoveWithOnOff::Id, moveMode, rate, - Optional>(optionsMask), Optional>(optionsOverride)); + moveHandler(commandObj, commandPath, moveMode, rate, Optional>(optionsMask), + Optional>(optionsOverride)); return true; } @@ -567,8 +570,8 @@ bool emberAfLevelControlClusterStepCallback(app::CommandHandler * commandObj, co transitionTime.Value(), optionsMask.Raw(), optionsOverride.Raw()); } - stepHandler(commandPath.mEndpointId, Commands::Step::Id, stepMode, stepSize, transitionTime, - Optional>(optionsMask), Optional>(optionsOverride)); + stepHandler(commandObj, commandPath, stepMode, stepSize, transitionTime, Optional>(optionsMask), + Optional>(optionsOverride)); return true; } @@ -592,8 +595,8 @@ bool emberAfLevelControlClusterStepWithOnOffCallback(app::CommandHandler * comma transitionTime.Value(), optionsMask.Raw(), optionsOverride.Raw()); } - stepHandler(commandPath.mEndpointId, Commands::StepWithOnOff::Id, stepMode, stepSize, transitionTime, - Optional>(optionsMask), Optional>(optionsOverride)); + stepHandler(commandObj, commandPath, stepMode, stepSize, transitionTime, Optional>(optionsMask), + Optional>(optionsOverride)); return true; } @@ -604,7 +607,7 @@ bool emberAfLevelControlClusterStopCallback(app::CommandHandler * commandObj, co auto & optionsOverride = commandData.optionsOverride; emberAfLevelControlClusterPrintln("%s STOP", "RX level-control:"); - stopHandler(commandPath.mEndpointId, Commands::Stop::Id, Optional>(optionsMask), + stopHandler(commandObj, commandPath, Optional>(optionsMask), Optional>(optionsOverride)); return true; } @@ -615,50 +618,49 @@ bool emberAfLevelControlClusterStopWithOnOffCallback(app::CommandHandler * comma auto & optionsMask = commandData.optionsMask; auto & optionsOverride = commandData.optionsOverride; emberAfLevelControlClusterPrintln("%s STOP_WITH_ON_OFF", "RX level-control:"); - stopHandler(commandPath.mEndpointId, Commands::StopWithOnOff::Id, Optional>(optionsMask), + stopHandler(commandObj, commandPath, Optional>(optionsMask), Optional>(optionsOverride)); return true; } -static EmberAfStatus moveToLevelHandler(EndpointId endpoint, CommandId commandId, uint8_t level, - app::DataModel::Nullable transitionTimeDs, - chip::Optional> optionsMask, - chip::Optional> optionsOverride, uint16_t storedLevel) +static Status moveToLevelHandler(EndpointId endpoint, CommandId commandId, uint8_t level, + app::DataModel::Nullable transitionTimeDs, + chip::Optional> optionsMask, + chip::Optional> optionsOverride, uint16_t storedLevel) { EmberAfLevelControlState * state = getState(endpoint); - EmberAfStatus status; app::DataModel::Nullable currentLevel; uint8_t actualStepSize; if (state == nullptr) { - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } if (level > EMBER_AF_PLUGIN_LEVEL_CONTROL_MAXIMUM_LEVEL) { - return EMBER_ZCL_STATUS_INVALID_COMMAND; + return Status::InvalidCommand; } if (!shouldExecuteIfOff(endpoint, commandId, optionsMask, optionsOverride)) { - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } // Cancel any currently active command before fiddling with the state. deactivate(endpoint); - status = Attributes::CurrentLevel::Get(endpoint, currentLevel); + EmberAfStatus status = Attributes::CurrentLevel::Get(endpoint, currentLevel); if (status != EMBER_ZCL_STATUS_SUCCESS) { emberAfLevelControlClusterPrintln("ERR: reading current level %x", status); - return status; + return app::ToInteractionModelStatus(status); } if (currentLevel.IsNull()) { emberAfLevelControlClusterPrintln("ERR: Current Level is null"); - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } state->commandId = commandId; @@ -690,7 +692,7 @@ static EmberAfStatus moveToLevelHandler(EndpointId endpoint, CommandId commandId } if (currentLevel.Value() == state->moveToLevel) { - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } state->increasing = true; actualStepSize = static_cast(state->moveToLevel - currentLevel.Value()); @@ -717,7 +719,7 @@ static EmberAfStatus moveToLevelHandler(EndpointId endpoint, CommandId commandId if (status != EMBER_ZCL_STATUS_SUCCESS) { emberAfLevelControlClusterPrintln("ERR: reading on/off transition time %x", status); - return status; + return app::ToInteractionModelStatus(status); } // Transition time comes in (or is stored, in the case of On/Off Transition @@ -759,7 +761,6 @@ static EmberAfStatus moveToLevelHandler(EndpointId endpoint, CommandId commandId // The setup was successful, so mark the new state as active and return. schedule(endpoint, computeCallbackWaitTimeMs(state->callbackSchedule, state->eventDurationMs)); - status = EMBER_ZCL_STATUS_SUCCESS; #ifdef EMBER_AF_PLUGIN_ON_OFF // Check that the received MoveToLevelWithOnOff produces a On action and that the onoff support the lighting featuremap @@ -770,44 +771,47 @@ static EmberAfStatus moveToLevelHandler(EndpointId endpoint, CommandId commandId } #endif // EMBER_AF_PLUGIN_ON_OFF - return status; + return Status::Success; } -static void moveHandler(EndpointId endpoint, CommandId commandId, uint8_t moveMode, app::DataModel::Nullable rate, - chip::Optional> optionsMask, +static void moveHandler(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, uint8_t moveMode, + app::DataModel::Nullable rate, chip::Optional> optionsMask, chip::Optional> optionsOverride) { + EndpointId endpoint = commandPath.mEndpointId; + CommandId commandId = commandPath.mCommandId; + EmberAfLevelControlState * state = getState(endpoint); - EmberAfStatus status; + Status status; app::DataModel::Nullable currentLevel; uint8_t difference; if (state == nullptr) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; goto send_default_response; } if (!shouldExecuteIfOff(endpoint, commandId, optionsMask, optionsOverride)) { - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; goto send_default_response; } // Cancel any currently active command before fiddling with the state. deactivate(endpoint); - status = Attributes::CurrentLevel::Get(endpoint, currentLevel); - if (status != EMBER_ZCL_STATUS_SUCCESS) + status = app::ToInteractionModelStatus(Attributes::CurrentLevel::Get(endpoint, currentLevel)); + if (status != Status::Success) { - emberAfLevelControlClusterPrintln("ERR: reading current level %x", status); + emberAfLevelControlClusterPrintln("ERR: reading current level %x", to_underlying(status)); goto send_default_response; } if (currentLevel.IsNull()) { emberAfLevelControlClusterPrintln("ERR: Current Level is null"); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; goto send_default_response; } @@ -829,7 +833,7 @@ static void moveHandler(EndpointId endpoint, CommandId commandId, uint8_t moveMo difference = static_cast(currentLevel.Value() - state->minLevel); break; default: - status = EMBER_ZCL_STATUS_INVALID_COMMAND; + status = Status::InvalidCommand; goto send_default_response; } @@ -845,7 +849,7 @@ static void moveHandler(EndpointId endpoint, CommandId commandId, uint8_t moveMo } if (currentLevel.Value() == state->moveToLevel) { - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; goto send_default_response; } } @@ -856,10 +860,10 @@ static void moveHandler(EndpointId endpoint, CommandId commandId, uint8_t moveMo if (rate.IsNull()) { app::DataModel::Nullable defaultMoveRate; - status = Attributes::DefaultMoveRate::Get(endpoint, defaultMoveRate); - if (status != EMBER_ZCL_STATUS_SUCCESS || defaultMoveRate.IsNull()) + status = app::ToInteractionModelStatus(Attributes::DefaultMoveRate::Get(endpoint, defaultMoveRate)); + if (status != Status::Success || defaultMoveRate.IsNull()) { - emberAfLevelControlClusterPrintln("ERR: reading default move rate %x", status); + emberAfLevelControlClusterPrintln("ERR: reading default move rate %x", to_underlying(status)); state->eventDurationMs = FASTEST_TRANSITION_TIME_MS; } else @@ -867,7 +871,7 @@ static void moveHandler(EndpointId endpoint, CommandId commandId, uint8_t moveMo // nonsensical case, means "don't move", so we're done if (defaultMoveRate.Value() == 0) { - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; goto send_default_response; } state->eventDurationMs = MILLISECOND_TICKS_PER_SECOND / defaultMoveRate.Value(); @@ -894,48 +898,51 @@ static void moveHandler(EndpointId endpoint, CommandId commandId, uint8_t moveMo // The setup was successful, so mark the new state as active and return. schedule(endpoint, computeCallbackWaitTimeMs(state->callbackSchedule, state->eventDurationMs)); - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; send_default_response: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); } -static void stepHandler(EndpointId endpoint, CommandId commandId, uint8_t stepMode, uint8_t stepSize, - app::DataModel::Nullable transitionTimeDs, +static void stepHandler(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, uint8_t stepMode, + uint8_t stepSize, app::DataModel::Nullable transitionTimeDs, chip::Optional> optionsMask, chip::Optional> optionsOverride) { + EndpointId endpoint = commandPath.mEndpointId; + CommandId commandId = commandPath.mCommandId; + EmberAfLevelControlState * state = getState(endpoint); - EmberAfStatus status; + Status status; app::DataModel::Nullable currentLevel; uint8_t actualStepSize = stepSize; if (state == nullptr) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; goto send_default_response; } if (!shouldExecuteIfOff(endpoint, commandId, optionsMask, optionsOverride)) { - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; goto send_default_response; } // Cancel any currently active command before fiddling with the state. deactivate(endpoint); - status = Attributes::CurrentLevel::Get(endpoint, currentLevel); - if (status != EMBER_ZCL_STATUS_SUCCESS) + status = app::ToInteractionModelStatus(Attributes::CurrentLevel::Get(endpoint, currentLevel)); + if (status != Status::Success) { - emberAfLevelControlClusterPrintln("ERR: reading current level %x", status); + emberAfLevelControlClusterPrintln("ERR: reading current level %x", to_underlying(status)); goto send_default_response; } if (currentLevel.IsNull()) { emberAfLevelControlClusterPrintln("ERR: Current Level is null"); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; goto send_default_response; } @@ -971,7 +978,7 @@ static void stepHandler(EndpointId endpoint, CommandId commandId, uint8_t stepMo } break; default: - status = EMBER_ZCL_STATUS_INVALID_COMMAND; + status = Status::InvalidCommand; goto send_default_response; } @@ -987,7 +994,7 @@ static void stepHandler(EndpointId endpoint, CommandId commandId, uint8_t stepMo } if (currentLevel.Value() == state->moveToLevel) { - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; goto send_default_response; } } @@ -1031,37 +1038,41 @@ static void stepHandler(EndpointId endpoint, CommandId commandId, uint8_t stepMo // The setup was successful, so mark the new state as active and return. schedule(endpoint, computeCallbackWaitTimeMs(state->callbackSchedule, state->eventDurationMs)); - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; send_default_response: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); } -static void stopHandler(EndpointId endpoint, CommandId commandId, chip::Optional> optionsMask, +static void stopHandler(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, + chip::Optional> optionsMask, chip::Optional> optionsOverride) { + EndpointId endpoint = commandPath.mEndpointId; + CommandId commandId = commandPath.mCommandId; + EmberAfLevelControlState * state = getState(endpoint); - EmberAfStatus status; + Status status; if (state == nullptr) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; goto send_default_response; } if (!shouldExecuteIfOff(endpoint, commandId, optionsMask, optionsOverride)) { - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; goto send_default_response; } // Cancel any currently active command. deactivate(endpoint); writeRemainingTime(endpoint, 0); - status = EMBER_ZCL_STATUS_SUCCESS; + status = Status::Success; send_default_response: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); } // Follows 07-5123-04 (ZigBee Cluster Library doc), section 3.10.2.1.1. diff --git a/src/app/clusters/media-input-server/media-input-server.cpp b/src/app/clusters/media-input-server/media-input-server.cpp index cff8580c9bf186..6910d710ce3f38 100644 --- a/src/app/clusters/media-input-server/media-input-server.cpp +++ b/src/app/clusters/media-input-server/media-input-server.cpp @@ -35,6 +35,7 @@ using namespace chip; using namespace chip::app::Clusters; using namespace chip::app::Clusters::MediaInput; +using Protocols::InteractionModel::Status; static constexpr size_t kMediaInputDelegateTableSize = EMBER_AF_MEDIA_INPUT_CLUSTER_SERVER_ENDPOINT_COUNT + CHIP_DEVICE_CONFIG_DYNAMIC_ENDPOINT_COUNT; @@ -170,9 +171,9 @@ CHIP_ERROR MediaInputAttrAccess::ReadCurrentInputAttribute(app::AttributeValueEn bool emberAfMediaInputClusterSelectInputCallback(app::CommandHandler * command, const app::ConcreteCommandPath & commandPath, const Commands::SelectInput::DecodableType & commandData) { - CHIP_ERROR err = CHIP_NO_ERROR; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + CHIP_ERROR err = CHIP_NO_ERROR; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; auto & input = commandData.index; @@ -181,68 +182,68 @@ bool emberAfMediaInputClusterSelectInputCallback(app::CommandHandler * command, if (!delegate->HandleSelectInput(input)) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfMediaInputClusterSelectInputCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + command->AddStatus(commandPath, status); return true; } bool emberAfMediaInputClusterShowInputStatusCallback(app::CommandHandler * command, const app::ConcreteCommandPath & commandPath, const Commands::ShowInputStatus::DecodableType & commandData) { - CHIP_ERROR err = CHIP_NO_ERROR; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + CHIP_ERROR err = CHIP_NO_ERROR; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; Delegate * delegate = GetDelegate(endpoint); VerifyOrExit(isDelegateNull(delegate, endpoint) != true, err = CHIP_ERROR_INCORRECT_STATE); if (!delegate->HandleShowInputStatus()) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfMediaInputClusterShowInputStatusCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + command->AddStatus(commandPath, status); return true; } bool emberAfMediaInputClusterHideInputStatusCallback(app::CommandHandler * command, const app::ConcreteCommandPath & commandPath, const Commands::HideInputStatus::DecodableType & commandData) { - CHIP_ERROR err = CHIP_NO_ERROR; - EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + CHIP_ERROR err = CHIP_NO_ERROR; + EndpointId endpoint = commandPath.mEndpointId; + Status status = Status::Success; Delegate * delegate = GetDelegate(endpoint); VerifyOrExit(isDelegateNull(delegate, endpoint) != true, err = CHIP_ERROR_INCORRECT_STATE); if (!delegate->HandleHideInputStatus()) { - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } exit: if (err != CHIP_NO_ERROR) { ChipLogError(Zcl, "emberAfMediaInputClusterHideInputStatusCallback error: %s", err.AsString()); - status = EMBER_ZCL_STATUS_FAILURE; + status = Status::Failure; } - emberAfSendImmediateDefaultResponse(status); + command->AddStatus(commandPath, status); return true; } diff --git a/src/app/clusters/mode-select-server/mode-select-server.cpp b/src/app/clusters/mode-select-server/mode-select-server.cpp index f9dcac708052b3..bd925130aab116 100644 --- a/src/app/clusters/mode-select-server/mode-select-server.cpp +++ b/src/app/clusters/mode-select-server/mode-select-server.cpp @@ -100,13 +100,13 @@ bool emberAfModeSelectClusterChangeToModeCallback(CommandHandler * commandHandle uint8_t newMode = commandData.newMode; // Check that the newMode matches one of the supported options const ModeSelect::Structs::ModeOptionStruct::Type * modeOptionPtr; - EmberAfStatus checkSupportedModeStatus = + Status checkSupportedModeStatus = ModeSelect::getSupportedModesManager()->getModeOptionByMode(endpointId, newMode, &modeOptionPtr); - if (EMBER_ZCL_STATUS_SUCCESS != checkSupportedModeStatus) + if (Status::Success != checkSupportedModeStatus) { emberAfPrintln(EMBER_AF_PRINT_DEBUG, "ModeSelect: Failed to find the option with mode %u", newMode); - emberAfSendImmediateDefaultResponse(checkSupportedModeStatus); - return false; + commandHandler->AddStatus(commandPath, checkSupportedModeStatus); + return true; } ModeSelect::Attributes::CurrentMode::Set(endpointId, newMode); @@ -263,12 +263,5 @@ static InteractionModel::Status verifyModeValue(const EndpointId endpointId, con return InteractionModel::Status::Success; } const ModeSelect::Structs::ModeOptionStruct::Type * modeOptionPtr; - EmberAfStatus checkSupportedModeStatus = - ModeSelect::getSupportedModesManager()->getModeOptionByMode(endpointId, newMode, &modeOptionPtr); - if (EMBER_ZCL_STATUS_SUCCESS != checkSupportedModeStatus) - { - const InteractionModel::Status returnStatus = ToInteractionModelStatus(checkSupportedModeStatus); - return returnStatus; - } - return InteractionModel::Status::Success; + return ModeSelect::getSupportedModesManager()->getModeOptionByMode(endpointId, newMode, &modeOptionPtr); } diff --git a/src/app/clusters/mode-select-server/supported-modes-manager.h b/src/app/clusters/mode-select-server/supported-modes-manager.h index 6818d445b298f7..497a604497200a 100644 --- a/src/app/clusters/mode-select-server/supported-modes-manager.h +++ b/src/app/clusters/mode-select-server/supported-modes-manager.h @@ -23,6 +23,7 @@ #include #include #include +#include namespace chip { namespace app { @@ -73,10 +74,11 @@ class SupportedModesManager * @param endpointId The endpoint for which to search the ModeOptionStruct. * @param mode The mode for which to search the ModeOptionStruct. * @param dataPtr The pointer to receive the ModeOptionStruct, if one is found. - * @return EMBER_ZCL_STATUS_SUCCESS if successfully found the option. Otherwise, returns appropriate status code (found in + * @return Status::Success if successfully found the option. Otherwise, returns appropriate status code (found in * ) */ - virtual EmberAfStatus getModeOptionByMode(EndpointId endpointId, uint8_t mode, const ModeOptionStructType ** dataPtr) const = 0; + virtual Protocols::InteractionModel::Status getModeOptionByMode(EndpointId endpointId, uint8_t mode, + const ModeOptionStructType ** dataPtr) const = 0; virtual ~SupportedModesManager() {} }; diff --git a/src/app/clusters/on-off-server/on-off-server.cpp b/src/app/clusters/on-off-server/on-off-server.cpp index a4074f8926c57e..6ea1b556db2e01 100644 --- a/src/app/clusters/on-off-server/on-off-server.cpp +++ b/src/app/clusters/on-off-server/on-off-server.cpp @@ -22,6 +22,7 @@ #include #include #include +#include #include #ifdef EMBER_AF_PLUGIN_SCENES @@ -325,27 +326,27 @@ EmberAfStatus OnOffServer::getOnOffValueForStartUp(chip::EndpointId endpoint, bo return status; } -bool OnOffServer::offCommand(const app::ConcreteCommandPath & commandPath) +bool OnOffServer::offCommand(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath) { EmberAfStatus status = setOnOffValue(commandPath.mEndpointId, Commands::Off::Id, false); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, app::ToInteractionModelStatus(status)); return true; } -bool OnOffServer::onCommand(const app::ConcreteCommandPath & commandPath) +bool OnOffServer::onCommand(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath) { EmberAfStatus status = setOnOffValue(commandPath.mEndpointId, Commands::On::Id, false); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, app::ToInteractionModelStatus(status)); return true; } -bool OnOffServer::toggleCommand(const app::ConcreteCommandPath & commandPath) +bool OnOffServer::toggleCommand(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath) { EmberAfStatus status = setOnOffValue(commandPath.mEndpointId, Commands::Toggle::Id, false); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, app::ToInteractionModelStatus(status)); return true; } @@ -355,7 +356,7 @@ bool OnOffServer::offWithEffectCommand(app::CommandHandler * commandObj, const a OnOffEffectIdentifier effectId = commandData.effectIdentifier; uint8_t effectVariant = commandData.effectVariant; chip::EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; if (SupportsLightingApplications(endpoint)) { @@ -398,21 +399,20 @@ bool OnOffServer::offWithEffectCommand(app::CommandHandler * commandObj, const a } } - status = setOnOffValue(endpoint, Commands::Off::Id, false); + status = app::ToInteractionModelStatus(setOnOffValue(endpoint, Commands::Off::Id, false)); } else { - status = EMBER_ZCL_STATUS_UNSUPPORTED_COMMAND; + status = Status::UnsupportedCommand; } - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } bool OnOffServer::OnWithRecallGlobalSceneCommand(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath) { chip::EndpointId endpoint = commandPath.mEndpointId; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; if (!SupportsLightingApplications(endpoint)) { @@ -429,7 +429,7 @@ bool OnOffServer::OnWithRecallGlobalSceneCommand(app::CommandHandler * commandOb if (globalSceneControl) { - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, Status::Success); return true; } @@ -446,7 +446,7 @@ bool OnOffServer::OnWithRecallGlobalSceneCommand(app::CommandHandler * commandOb OnOff::Attributes::GlobalSceneControl::Set(endpoint, true); setOnOffValue(endpoint, Commands::On::Id, false); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, Status::Success); return true; } @@ -470,28 +470,28 @@ uint32_t OnOffServer::calculateNextWaitTimeMS() return (uint32_t) waitTime.count(); } -bool OnOffServer::OnWithTimedOffCommand(const app::ConcreteCommandPath & commandPath, +bool OnOffServer::OnWithTimedOffCommand(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::OnWithTimedOff::DecodableType & commandData) { BitFlags onOffControl = commandData.onOffControl; uint16_t onTime = commandData.onTime; uint16_t offWaitTime = commandData.offWaitTime; - EmberAfStatus status = EMBER_ZCL_STATUS_SUCCESS; + Status status = Status::Success; chip::EndpointId endpoint = commandPath.mEndpointId; bool isOn = false; uint16_t currentOffWaitTime = MAX_TIME_VALUE; uint16_t currentOnTime = 0; EmberEventControl * event = configureEventControl(endpoint); - VerifyOrExit(event != nullptr, status = EMBER_ZCL_STATUS_UNSUPPORTED_ENDPOINT); - VerifyOrExit(SupportsLightingApplications(endpoint), status = EMBER_ZCL_STATUS_UNSUPPORTED_COMMAND); + VerifyOrExit(event != nullptr, status = Status::UnsupportedEndpoint); + VerifyOrExit(SupportsLightingApplications(endpoint), status = Status::UnsupportedCommand); OnOff::Attributes::OnOff::Get(endpoint, &isOn); // OnOff is off and the commands is only accepted if on if (onOffControl.Has(OnOffControl::kAcceptOnlyWhenOn) && !isOn) { - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, Status::Success); return true; } @@ -526,7 +526,7 @@ bool OnOffServer::OnWithTimedOffCommand(const app::ConcreteCommandPath & command } exit: - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -705,19 +705,19 @@ OnOffEffect::~OnOffEffect() bool emberAfOnOffClusterOffCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::Off::DecodableType & commandData) { - return OnOffServer::Instance().offCommand(commandPath); + return OnOffServer::Instance().offCommand(commandObj, commandPath); } bool emberAfOnOffClusterOnCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::On::DecodableType & commandData) { - return OnOffServer::Instance().onCommand(commandPath); + return OnOffServer::Instance().onCommand(commandObj, commandPath); } bool emberAfOnOffClusterToggleCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::Toggle::DecodableType & commandData) { - return OnOffServer::Instance().toggleCommand(commandPath); + return OnOffServer::Instance().toggleCommand(commandObj, commandPath); } bool emberAfOnOffClusterOffWithEffectCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, @@ -736,7 +736,7 @@ bool emberAfOnOffClusterOnWithRecallGlobalSceneCallback(app::CommandHandler * co bool emberAfOnOffClusterOnWithTimedOffCallback(app::CommandHandler * commandObj, const app::ConcreteCommandPath & commandPath, const Commands::OnWithTimedOff::DecodableType & commandData) { - return OnOffServer::Instance().OnWithTimedOffCommand(commandPath, commandData); + return OnOffServer::Instance().OnWithTimedOffCommand(commandObj, commandPath, commandData); } void emberAfOnOffClusterServerInitCallback(chip::EndpointId endpoint) diff --git a/src/app/clusters/on-off-server/on-off-server.h b/src/app/clusters/on-off-server/on-off-server.h index 71c793691e741b..2bf8b091a8cc95 100644 --- a/src/app/clusters/on-off-server/on-off-server.h +++ b/src/app/clusters/on-off-server/on-off-server.h @@ -48,14 +48,14 @@ class OnOffServer static OnOffServer & Instance(); - bool offCommand(const chip::app::ConcreteCommandPath & commandPath); - bool onCommand(const chip::app::ConcreteCommandPath & commandPath); - bool toggleCommand(const chip::app::ConcreteCommandPath & commandPath); + bool offCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath); + bool onCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath); + bool toggleCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath); void initOnOffServer(chip::EndpointId endpoint); bool offWithEffectCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath, const chip::app::Clusters::OnOff::Commands::OffWithEffect::DecodableType & commandData); bool OnWithRecallGlobalSceneCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath); - bool OnWithTimedOffCommand(const chip::app::ConcreteCommandPath & commandPath, + bool OnWithTimedOffCommand(chip::app::CommandHandler * commandObj, const chip::app::ConcreteCommandPath & commandPath, const chip::app::Clusters::OnOff::Commands::OnWithTimedOff::DecodableType & commandData); void updateOnOffTimeCommand(chip::EndpointId endpoint); EmberAfStatus getOnOffValue(chip::EndpointId endpoint, bool * currentOnOffValue); diff --git a/src/app/clusters/scenes/scenes.cpp b/src/app/clusters/scenes/scenes.cpp index a02095d21764a1..8cddbf754192a7 100644 --- a/src/app/clusters/scenes/scenes.cpp +++ b/src/app/clusters/scenes/scenes.cpp @@ -25,6 +25,7 @@ #include #include #include +#include #ifdef EMBER_AF_PLUGIN_GROUPS_SERVER #include @@ -408,7 +409,6 @@ bool emberAfScenesClusterRecallSceneCallback(app::CommandHandler * commandObj, c // value of TransitionTime. EmberAfStatus status; - EmberStatus sendStatus = EMBER_SUCCESS; emberAfScenesClusterPrintln("RX: RecallScene 0x%2x, 0x%x", groupId, sceneId); status = emberAfScenesClusterRecallSavedSceneCallback(fabricIndex, emberAfCurrentEndpoint(), groupId, sceneId); #ifdef EMBER_AF_PLUGIN_ZLL_SCENES_SERVER @@ -417,10 +417,10 @@ bool emberAfScenesClusterRecallSceneCallback(app::CommandHandler * commandObj, c emberAfPluginZllScenesServerRecallSceneZllExtensions(emberAfCurrentEndpoint()); } #endif - sendStatus = emberAfSendImmediateDefaultResponse(status); - if (EMBER_SUCCESS != sendStatus) + CHIP_ERROR sendErr = commandObj->AddStatus(commandPath, app::ToInteractionModelStatus(status)); + if (CHIP_NO_ERROR != sendErr) { - emberAfScenesClusterPrintln("Scenes: failed to send %s: 0x%x", "default_response", sendStatus); + emberAfScenesClusterPrintln("Scenes: failed to send %s: %" CHIP_ERROR_FORMAT, "status_response", sendErr.Format()); } return true; } diff --git a/src/app/clusters/thermostat-server/thermostat-server.cpp b/src/app/clusters/thermostat-server/thermostat-server.cpp index 6e87527dbc6fab..47e7a0fd5b3cda 100644 --- a/src/app/clusters/thermostat-server/thermostat-server.cpp +++ b/src/app/clusters/thermostat-server/thermostat-server.cpp @@ -751,7 +751,7 @@ bool emberAfThermostatClusterSetpointRaiseLowerCallback(app::CommandHandler * co break; } - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, app::ToInteractionModelStatus(status)); return true; } diff --git a/src/app/clusters/window-covering-server/window-covering-server.cpp b/src/app/clusters/window-covering-server/window-covering-server.cpp index 883f3d0c101f17..edb6f3940878ff 100644 --- a/src/app/clusters/window-covering-server/window-covering-server.cpp +++ b/src/app/clusters/window-covering-server/window-covering-server.cpp @@ -26,6 +26,7 @@ #include #include #include +#include #include #include @@ -568,7 +569,7 @@ void PostAttributeChange(chip::EndpointId endpoint, chip::AttributeId attributeI } } -EmberAfStatus GetMotionLockStatus(chip::EndpointId endpoint) +Status GetMotionLockStatus(chip::EndpointId endpoint) { BitMask mode = ModeGet(endpoint); BitMask configStatus = ConfigStatusGet(endpoint); @@ -579,17 +580,17 @@ EmberAfStatus GetMotionLockStatus(chip::EndpointId endpoint) if (mode.Has(Mode::kMaintenanceMode)) { // Mainterance Mode - return EMBER_ZCL_STATUS_BUSY; + return Status::Busy; } if (mode.Has(Mode::kCalibrationMode)) { // Calibration Mode - return EMBER_ZCL_STATUS_FAILURE; + return Status::Failure; } } - return EMBER_ZCL_STATUS_SUCCESS; + return Status::Success; } void SetDefaultDelegate(EndpointId endpoint, Delegate * delegate) @@ -626,11 +627,11 @@ bool emberAfWindowCoveringClusterUpOrOpenCallback(app::CommandHandler * commandO emberAfWindowCoveringClusterPrint("UpOrOpen command received"); - EmberAfStatus status = GetMotionLockStatus(endpoint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + Status status = GetMotionLockStatus(endpoint); + if (Status::Success != status) { emberAfWindowCoveringClusterPrint("Err device locked"); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -676,11 +677,11 @@ bool emberAfWindowCoveringClusterDownOrCloseCallback(app::CommandHandler * comma emberAfWindowCoveringClusterPrint("DownOrClose command received"); - EmberAfStatus status = GetMotionLockStatus(endpoint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + Status status = GetMotionLockStatus(endpoint); + if (Status::Success != status) { emberAfWindowCoveringClusterPrint("Err device locked"); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -726,11 +727,11 @@ bool emberAfWindowCoveringClusterStopMotionCallback(app::CommandHandler * comman emberAfWindowCoveringClusterPrint("StopMotion command received"); - EmberAfStatus status = GetMotionLockStatus(endpoint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + Status status = GetMotionLockStatus(endpoint); + if (Status::Success != status) { emberAfWindowCoveringClusterPrint("Err device locked"); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -772,11 +773,11 @@ bool emberAfWindowCoveringClusterGoToLiftValueCallback(app::CommandHandler * com emberAfWindowCoveringClusterPrint("GoToLiftValue %u command received", liftValue); - EmberAfStatus status = GetMotionLockStatus(endpoint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + Status status = GetMotionLockStatus(endpoint); + if (Status::Success != status) { emberAfWindowCoveringClusterPrint("Err device locked"); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -814,11 +815,11 @@ bool emberAfWindowCoveringClusterGoToLiftPercentageCallback(app::CommandHandler emberAfWindowCoveringClusterPrint("GoToLiftPercentage %u command received", percent100ths); - EmberAfStatus status = GetMotionLockStatus(endpoint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + Status status = GetMotionLockStatus(endpoint); + if (Status::Success != status) { emberAfWindowCoveringClusterPrint("Err device locked"); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -864,11 +865,11 @@ bool emberAfWindowCoveringClusterGoToTiltValueCallback(app::CommandHandler * com emberAfWindowCoveringClusterPrint("GoToTiltValue %u command received", tiltValue); - EmberAfStatus status = GetMotionLockStatus(endpoint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + Status status = GetMotionLockStatus(endpoint); + if (Status::Success != status) { emberAfWindowCoveringClusterPrint("Err device locked"); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } @@ -906,11 +907,11 @@ bool emberAfWindowCoveringClusterGoToTiltPercentageCallback(app::CommandHandler emberAfWindowCoveringClusterPrint("GoToTiltPercentage %u command received", percent100ths); - EmberAfStatus status = GetMotionLockStatus(endpoint); - if (EMBER_ZCL_STATUS_SUCCESS != status) + Status status = GetMotionLockStatus(endpoint); + if (Status::Success != status) { emberAfWindowCoveringClusterPrint("Err device locked"); - emberAfSendImmediateDefaultResponse(status); + commandObj->AddStatus(commandPath, status); return true; } diff --git a/src/app/clusters/window-covering-server/window-covering-server.h b/src/app/clusters/window-covering-server/window-covering-server.h index 874417ab1d1214..b1d21d8bb750bf 100644 --- a/src/app/clusters/window-covering-server/window-covering-server.h +++ b/src/app/clusters/window-covering-server/window-covering-server.h @@ -21,6 +21,7 @@ #include #include #include +#include #include @@ -115,7 +116,7 @@ uint16_t TiltToPercent100ths(chip::EndpointId endpoint, uint16_t tilt); uint16_t Percent100thsToTilt(chip::EndpointId endpoint, uint16_t percent100ths); void TiltPositionSet(chip::EndpointId endpoint, NPercent100ths position); -EmberAfStatus GetMotionLockStatus(chip::EndpointId endpoint); +Protocols::InteractionModel::Status GetMotionLockStatus(chip::EndpointId endpoint); /** * @brief PostAttributeChange is called when an Attribute is modified. diff --git a/src/app/util/af.h b/src/app/util/af.h index 1192b60c77325a..9632d68f6d0ee8 100644 --- a/src/app/util/af.h +++ b/src/app/util/af.h @@ -520,19 +520,6 @@ EmberStatus emberEventControlSetDelayMS(EmberEventControl * control, uint32_t de */ EmberStatus emberAfSendDefaultResponse(const EmberAfClusterCommand * cmd, EmberAfStatus status); -/** - * @brief Sends a default response to a cluster command using the - * current command. - * - * This function is used to prepare and send a default response to a cluster - * command. - * - * @param status Status code for the default response command. - * @return An ::EmberStatus value that indicates the success or failure of - * sending the response. - */ -EmberStatus emberAfSendImmediateDefaultResponse(EmberAfStatus status); - /** * @brief Access to client API APS frame. */ diff --git a/src/app/util/util.cpp b/src/app/util/util.cpp index dee7c35902c548..f61d492ff4a089 100644 --- a/src/app/util/util.cpp +++ b/src/app/util/util.cpp @@ -334,11 +334,6 @@ void emAfApplyDisableDefaultResponse(uint8_t * frame_control) } } -EmberStatus emberAfSendImmediateDefaultResponse(EmberAfStatus status) -{ - return emberAfSendDefaultResponse(emberAfCurrentCommand(), status); -} - EmberStatus emberAfSendDefaultResponse(const EmberAfClusterCommand * cmd, EmberAfStatus status) { // Default Response commands are only sent in response to unicast commands.