mirror of
https://github.com/espressif/esp-matter.git
synced 2026-04-27 19:13:13 +00:00
1062 lines
37 KiB
C++
1062 lines
37 KiB
C++
/*
|
|
*
|
|
* Copyright (c) 2022 Project CHIP Authors
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
// THIS FILE IS GENERATED BY ZAP
|
|
|
|
#include <cinttypes>
|
|
#include <cstdint>
|
|
|
|
#include <app-common/zap-generated/af-structs.h>
|
|
#include <app-common/zap-generated/callback.h>
|
|
#include <app-common/zap-generated/cluster-objects.h>
|
|
#include <app-common/zap-generated/ids/Clusters.h>
|
|
#include <app-common/zap-generated/ids/Commands.h>
|
|
#include <app/CommandHandler.h>
|
|
#include <app/InteractionModelEngine.h>
|
|
#include <app/util/util.h>
|
|
#include <lib/core/CHIPSafeCasts.h>
|
|
#include <lib/support/TypeTraits.h>
|
|
|
|
// Currently we need some work to keep compatible with ember lib.
|
|
#include <app/util/ember-compatibility-functions.h>
|
|
|
|
namespace chip {
|
|
namespace app {
|
|
|
|
// Cluster specific command parsing
|
|
|
|
namespace Clusters {
|
|
|
|
namespace AdministratorCommissioning {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::OpenCommissioningWindow::Id: {
|
|
Commands::OpenCommissioningWindow::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfAdministratorCommissioningClusterOpenCommissioningWindowCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::OpenBasicCommissioningWindow::Id: {
|
|
Commands::OpenBasicCommissioningWindow::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfAdministratorCommissioningClusterOpenBasicCommissioningWindowCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RevokeCommissioning::Id: {
|
|
Commands::RevokeCommissioning::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfAdministratorCommissioningClusterRevokeCommissioningCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace AdministratorCommissioning
|
|
|
|
namespace ColorControl {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::MoveToHue::Id: {
|
|
Commands::MoveToHue::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveToHueCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveHue::Id: {
|
|
Commands::MoveHue::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveHueCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StepHue::Id: {
|
|
Commands::StepHue::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterStepHueCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveToSaturation::Id: {
|
|
Commands::MoveToSaturation::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveToSaturationCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveSaturation::Id: {
|
|
Commands::MoveSaturation::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveSaturationCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StepSaturation::Id: {
|
|
Commands::StepSaturation::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterStepSaturationCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveToHueAndSaturation::Id: {
|
|
Commands::MoveToHueAndSaturation::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveToHueAndSaturationCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveToColor::Id: {
|
|
Commands::MoveToColor::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveToColorCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveColor::Id: {
|
|
Commands::MoveColor::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveColorCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StepColor::Id: {
|
|
Commands::StepColor::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterStepColorCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveToColorTemperature::Id: {
|
|
Commands::MoveToColorTemperature::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveToColorTemperatureCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StopMoveStep::Id: {
|
|
Commands::StopMoveStep::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterStopMoveStepCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveColorTemperature::Id: {
|
|
Commands::MoveColorTemperature::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterMoveColorTemperatureCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StepColorTemperature::Id: {
|
|
Commands::StepColorTemperature::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfColorControlClusterStepColorTemperatureCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace ColorControl
|
|
|
|
namespace GeneralCommissioning {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::ArmFailSafe::Id: {
|
|
Commands::ArmFailSafe::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGeneralCommissioningClusterArmFailSafeCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::SetRegulatoryConfig::Id: {
|
|
Commands::SetRegulatoryConfig::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfGeneralCommissioningClusterSetRegulatoryConfigCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::CommissioningComplete::Id: {
|
|
Commands::CommissioningComplete::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfGeneralCommissioningClusterCommissioningCompleteCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace GeneralCommissioning
|
|
|
|
namespace GroupKeyManagement {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::KeySetWrite::Id: {
|
|
Commands::KeySetWrite::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupKeyManagementClusterKeySetWriteCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::KeySetRead::Id: {
|
|
Commands::KeySetRead::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupKeyManagementClusterKeySetReadCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::KeySetRemove::Id: {
|
|
Commands::KeySetRemove::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupKeyManagementClusterKeySetRemoveCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::KeySetReadAllIndices::Id: {
|
|
Commands::KeySetReadAllIndices::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfGroupKeyManagementClusterKeySetReadAllIndicesCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace GroupKeyManagement
|
|
|
|
namespace Groups {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::AddGroup::Id: {
|
|
Commands::AddGroup::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupsClusterAddGroupCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::ViewGroup::Id: {
|
|
Commands::ViewGroup::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupsClusterViewGroupCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::GetGroupMembership::Id: {
|
|
Commands::GetGroupMembership::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupsClusterGetGroupMembershipCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RemoveGroup::Id: {
|
|
Commands::RemoveGroup::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupsClusterRemoveGroupCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RemoveAllGroups::Id: {
|
|
Commands::RemoveAllGroups::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupsClusterRemoveAllGroupsCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::AddGroupIfIdentifying::Id: {
|
|
Commands::AddGroupIfIdentifying::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfGroupsClusterAddGroupIfIdentifyingCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace Groups
|
|
|
|
namespace Identify {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::Identify::Id: {
|
|
Commands::Identify::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfIdentifyClusterIdentifyCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace Identify
|
|
|
|
namespace LevelControl {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::MoveToLevel::Id: {
|
|
Commands::MoveToLevel::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterMoveToLevelCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::Move::Id: {
|
|
Commands::Move::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterMoveCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::Step::Id: {
|
|
Commands::Step::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterStepCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::Stop::Id: {
|
|
Commands::Stop::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterStopCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveToLevelWithOnOff::Id: {
|
|
Commands::MoveToLevelWithOnOff::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterMoveToLevelWithOnOffCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::MoveWithOnOff::Id: {
|
|
Commands::MoveWithOnOff::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterMoveWithOnOffCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StepWithOnOff::Id: {
|
|
Commands::StepWithOnOff::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterStepWithOnOffCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StopWithOnOff::Id: {
|
|
Commands::StopWithOnOff::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfLevelControlClusterStopWithOnOffCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace LevelControl
|
|
|
|
namespace NetworkCommissioning {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::ScanNetworks::Id: {
|
|
Commands::ScanNetworks::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfNetworkCommissioningClusterScanNetworksCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::AddOrUpdateWiFiNetwork::Id: {
|
|
Commands::AddOrUpdateWiFiNetwork::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfNetworkCommissioningClusterAddOrUpdateWiFiNetworkCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RemoveNetwork::Id: {
|
|
Commands::RemoveNetwork::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfNetworkCommissioningClusterRemoveNetworkCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::ConnectNetwork::Id: {
|
|
Commands::ConnectNetwork::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfNetworkCommissioningClusterConnectNetworkCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::ReorderNetwork::Id: {
|
|
Commands::ReorderNetwork::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfNetworkCommissioningClusterReorderNetworkCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace NetworkCommissioning
|
|
|
|
namespace OnOff {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::Off::Id: {
|
|
Commands::Off::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfOnOffClusterOffCallback(apCommandObj, aCommandPath,
|
|
commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::On::Id: {
|
|
Commands::On::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfOnOffClusterOnCallback(apCommandObj, aCommandPath,
|
|
commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::Toggle::Id: {
|
|
Commands::Toggle::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfOnOffClusterToggleCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace OnOff
|
|
|
|
namespace OperationalCredentials {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::AttestationRequest::Id: {
|
|
Commands::AttestationRequest::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfOperationalCredentialsClusterAttestationRequestCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::CertificateChainRequest::Id: {
|
|
Commands::CertificateChainRequest::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfOperationalCredentialsClusterCertificateChainRequestCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::CSRRequest::Id: {
|
|
Commands::CSRRequest::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfOperationalCredentialsClusterCSRRequestCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::AddNOC::Id: {
|
|
Commands::AddNOC::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfOperationalCredentialsClusterAddNOCCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::UpdateNOC::Id: {
|
|
Commands::UpdateNOC::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfOperationalCredentialsClusterUpdateNOCCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::UpdateFabricLabel::Id: {
|
|
Commands::UpdateFabricLabel::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfOperationalCredentialsClusterUpdateFabricLabelCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RemoveFabric::Id: {
|
|
Commands::RemoveFabric::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfOperationalCredentialsClusterRemoveFabricCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::AddTrustedRootCertificate::Id: {
|
|
Commands::AddTrustedRootCertificate::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled =
|
|
emberAfOperationalCredentialsClusterAddTrustedRootCertificateCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace OperationalCredentials
|
|
|
|
namespace Scenes {
|
|
|
|
void DispatchServerCommand(CommandHandler *apCommandObj,
|
|
const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aDataTlv) {
|
|
CHIP_ERROR TLVError = CHIP_NO_ERROR;
|
|
bool wasHandled = false;
|
|
{
|
|
switch (aCommandPath.mCommandId) {
|
|
case Commands::AddScene::Id: {
|
|
Commands::AddScene::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfScenesClusterAddSceneCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::ViewScene::Id: {
|
|
Commands::ViewScene::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfScenesClusterViewSceneCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RemoveScene::Id: {
|
|
Commands::RemoveScene::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfScenesClusterRemoveSceneCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RemoveAllScenes::Id: {
|
|
Commands::RemoveAllScenes::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfScenesClusterRemoveAllScenesCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::StoreScene::Id: {
|
|
Commands::StoreScene::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfScenesClusterStoreSceneCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::RecallScene::Id: {
|
|
Commands::RecallScene::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfScenesClusterRecallSceneCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
case Commands::GetSceneMembership::Id: {
|
|
Commands::GetSceneMembership::DecodableType commandData;
|
|
TLVError = DataModel::Decode(aDataTlv, commandData);
|
|
if (TLVError == CHIP_NO_ERROR) {
|
|
wasHandled = emberAfScenesClusterGetSceneMembershipCallback(
|
|
apCommandObj, aCommandPath, commandData);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
// Unrecognized command ID, error status will apply.
|
|
apCommandObj->AddStatus(
|
|
aCommandPath,
|
|
Protocols::InteractionModel::Status::UnsupportedCommand);
|
|
ChipLogError(Zcl,
|
|
"Unknown command " ChipLogFormatMEI
|
|
" for cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mCommandId),
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (CHIP_NO_ERROR != TLVError || !wasHandled) {
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::InvalidCommand);
|
|
ChipLogProgress(Zcl,
|
|
"Failed to dispatch command, TLVError=%" CHIP_ERROR_FORMAT,
|
|
TLVError.Format());
|
|
}
|
|
}
|
|
|
|
} // namespace Scenes
|
|
|
|
} // namespace Clusters
|
|
|
|
void DispatchSingleClusterCommand(const ConcreteCommandPath &aCommandPath,
|
|
TLV::TLVReader &aReader,
|
|
CommandHandler *apCommandObj) {
|
|
Compatibility::SetupEmberAfCommandHandler(apCommandObj, aCommandPath);
|
|
|
|
switch (aCommandPath.mClusterId) {
|
|
case Clusters::AdministratorCommissioning::Id:
|
|
Clusters::AdministratorCommissioning::DispatchServerCommand(
|
|
apCommandObj, aCommandPath, aReader);
|
|
break;
|
|
case Clusters::ColorControl::Id:
|
|
Clusters::ColorControl::DispatchServerCommand(apCommandObj, aCommandPath,
|
|
aReader);
|
|
break;
|
|
case Clusters::GeneralCommissioning::Id:
|
|
Clusters::GeneralCommissioning::DispatchServerCommand(
|
|
apCommandObj, aCommandPath, aReader);
|
|
break;
|
|
case Clusters::GroupKeyManagement::Id:
|
|
Clusters::GroupKeyManagement::DispatchServerCommand(apCommandObj,
|
|
aCommandPath, aReader);
|
|
break;
|
|
case Clusters::Groups::Id:
|
|
Clusters::Groups::DispatchServerCommand(apCommandObj, aCommandPath,
|
|
aReader);
|
|
break;
|
|
case Clusters::Identify::Id:
|
|
Clusters::Identify::DispatchServerCommand(apCommandObj, aCommandPath,
|
|
aReader);
|
|
break;
|
|
case Clusters::LevelControl::Id:
|
|
Clusters::LevelControl::DispatchServerCommand(apCommandObj, aCommandPath,
|
|
aReader);
|
|
break;
|
|
case Clusters::NetworkCommissioning::Id:
|
|
Clusters::NetworkCommissioning::DispatchServerCommand(
|
|
apCommandObj, aCommandPath, aReader);
|
|
break;
|
|
case Clusters::OnOff::Id:
|
|
Clusters::OnOff::DispatchServerCommand(apCommandObj, aCommandPath, aReader);
|
|
break;
|
|
case Clusters::OperationalCredentials::Id:
|
|
Clusters::OperationalCredentials::DispatchServerCommand(
|
|
apCommandObj, aCommandPath, aReader);
|
|
break;
|
|
case Clusters::Scenes::Id:
|
|
Clusters::Scenes::DispatchServerCommand(apCommandObj, aCommandPath,
|
|
aReader);
|
|
break;
|
|
default:
|
|
ChipLogError(Zcl, "Unknown cluster " ChipLogFormatMEI,
|
|
ChipLogValueMEI(aCommandPath.mClusterId));
|
|
apCommandObj->AddStatus(
|
|
aCommandPath, Protocols::InteractionModel::Status::UnsupportedCluster);
|
|
break;
|
|
}
|
|
|
|
Compatibility::ResetEmberAfObjects();
|
|
}
|
|
|
|
} // namespace app
|
|
} // namespace chip
|