From c90de34aea451ae2986f9ba097178e1693f84619 Mon Sep 17 00:00:00 2001 From: Vivien Nicolas Date: Fri, 15 Oct 2021 18:31:11 +0200 Subject: [PATCH 1/2] Update chip-tool to use the InvokeCommand API --- examples/chip-tool/templates/commands.zapt | 96 ++++++++++++------- .../zap-templates/common/ClustersHelper.js | 6 +- 2 files changed, 66 insertions(+), 36 deletions(-) diff --git a/examples/chip-tool/templates/commands.zapt b/examples/chip-tool/templates/commands.zapt index 448edab4023120..1e4432c2c88c76 100644 --- a/examples/chip-tool/templates/commands.zapt +++ b/examples/chip-tool/templates/commands.zapt @@ -4,6 +4,7 @@ #include +#include #include #include #include @@ -26,6 +27,16 @@ static void OnDefaultFailureResponse(void * context, uint8_t status) command->SetCommandExitStatus(CHIP_ERROR_INTERNAL); } +static void OnDefaultSuccess(void * context, const chip::app::DataModel::NullObjectType & data) +{ + OnDefaultSuccessResponse(context); +}; + +static void OnDefaultFailure(void * context, EmberAfStatus status) +{ + OnDefaultFailureResponse(context, status); +}; + static void OnBooleanAttributeResponse(void * context, bool value) { ChipLogProgress(chipTool, "Boolean attribute Response: %d", value); @@ -119,19 +130,6 @@ static void OnCharStringAttributeResponse(void * context, const chip::ByteSpan v command->SetCommandExitStatus(CHIP_NO_ERROR); } -{{#chip_client_clusters}} -{{#chip_cluster_responses}} -static void On{{asUpperCamelCase parent.name}}Cluster{{asUpperCamelCase name}}(void * context{{#chip_cluster_response_arguments}}, {{asUnderlyingZclType type}} {{asSymbol label}}{{/chip_cluster_response_arguments}}) -{ - ChipLogProgress(chipTool, "{{asUpperCamelCase parent.name}}Cluster{{asUpperCamelCase name}}"); - - ModelCommand * command = static_cast(context); - command->SetCommandExitStatus(CHIP_NO_ERROR); -} - -{{/chip_cluster_responses}} -{{/chip_client_clusters}} - {{#chip_client_clusters}} {{#chip_server_cluster_attributes}} {{#if isList}} @@ -172,6 +170,31 @@ static void On{{asUpperCamelCase parent.name}}{{asUpperCamelCase name}}ListAttri {{/chip_server_cluster_attributes}} {{/chip_client_clusters}} +{{#chip_client_clusters}} +{{#chip_cluster_responses}} +static void On{{asUpperCamelCase parent.name}}{{asUpperCamelCase name}}Success(void * context, const chip::app::Clusters::{{asUpperCamelCase parent.name}}::Commands::{{asUpperCamelCase name}}::DecodableType & data) +{ + ChipLogProgress(Zcl, "Received {{asUpperCamelCase name}}:"); + {{#chip_cluster_response_arguments}} + {{~#*inline "field"}}data.{{asLowerCamelCase label}}{{/inline~}} + {{#if isArray}} + ChipLogProgress(Zcl, " {{label}}: Array printing is not implemented yet."); + {{else if (isOctetString type)}} + ChipLogProgress(Zcl, " {{label}}: %zu", {{>field}}.size()); + {{else if (isCharString type)}} + ChipLogProgress(Zcl, " {{label}}: %.*s", static_cast({{>field}}.size()), {{>field}}.data()); + {{else}} + ChipLogProgress(Zcl, " {{label}}: {{asPrintFormat type}}", {{>field}}); + {{/if}} + {{/chip_cluster_response_arguments}} + + ModelCommand * command = static_cast(context); + command->SetCommandExitStatus(CHIP_NO_ERROR); +}; + +{{/chip_cluster_responses}} +{{/chip_client_clusters}} + {{> clusters_header}} {{#chip_client_clusters}} @@ -186,40 +209,45 @@ class {{asUpperCamelCase clusterName}}{{asUpperCamelCase name}}: public ModelCom public: {{asUpperCamelCase clusterName}}{{asUpperCamelCase name}}(): ModelCommand("{{asDelimitedCommand name}}") { - {{#chip_cluster_command_arguments_with_structs_expanded}} - {{#if (isString type)}} - AddArgument("{{asUpperCamelCase label}}", &m{{asUpperCamelCase label}}); + {{#chip_cluster_command_arguments}} + {{~#*inline "field"}}mRequest.{{asLowerCamelCase label}}{{/inline~}} + {{#if isArray}} + // {{label}} Array parsing is not supported yet + {{else if isStruct}} + // {{label}} Struct parsing is not supported yet + {{else if (isString type)}} + AddArgument("{{asUpperCamelCase label}}", &{{>field}}); {{else}} - AddArgument("{{asUpperCamelCase label}}", {{asTypeMinValue type}}, {{asTypeMaxValue type}}, &m{{asUpperCamelCase label}}); + AddArgument("{{asUpperCamelCase label}}", {{asTypeMinValue type}}, {{asTypeMaxValue type}}, + {{~#if ./isEnum}}reinterpret_castfield}})> *>(&{{>field}}) + {{else ./isBitmap}}reinterpret_cast *>(&{{>field}}) + {{else}}&{{>field}} + {{/if~}} + ); {{/if}} - {{/chip_cluster_command_arguments_with_structs_expanded}} + {{/chip_cluster_command_arguments}} ModelCommand::AddArguments(); } - ~{{asUpperCamelCase clusterName}}{{asUpperCamelCase name}}() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster ({{asHex parent.code 4}}) command ({{asHex code 2}}) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster ({{asHex parent.code 8}}) command ({{asHex code 8}}) on endpoint %" PRIu8, endpointId); + + {{#chip_cluster_command_non_expanded_arguments}} + {{#if isArray}} + {{! TODO Implement complex types parsing in order to properly set the request parameters }} + {{zapTypeToEncodableClusterObjectType type ns=parent.parent.name}} {{asLowerCamelCase label}}; + mRequest.{{asLowerCamelCase label}} = chip::Span<{{zapTypeToEncodableClusterObjectType type ns=parent.parent.name}}>(&{{asLowerCamelCase label}}, 1); + {{/if}} + {{/chip_cluster_command_non_expanded_arguments}} chip::Controller::{{asUpperCamelCase parent.name}}Cluster cluster; cluster.Associate(device, endpointId); - return cluster.{{asUpperCamelCase name}}(onSuccessCallback->Cancel(), onFailureCallback->Cancel(){{#chip_cluster_command_arguments_with_structs_expanded}}, m{{asUpperCamelCase label}}{{/chip_cluster_command_arguments_with_structs_expanded}}); + return cluster.InvokeCommand(mRequest, this, {{#if hasSpecificResponse}}On{{asUpperCamelCase parent.name}}{{asUpperCamelCase response.name}}Success{{else}}OnDefaultSuccess{{/if}}, OnDefaultFailure); } private: - {{#if hasSpecificResponse}} - chip::Callback::Callback<{{asUpperCamelCase parent.name}}Cluster{{asUpperCamelCase responseName}}Callback> * onSuccessCallback = new chip::Callback::Callback<{{asUpperCamelCase parent.name}}Cluster{{asUpperCamelCase responseName}}Callback>(On{{asUpperCamelCase parent.name}}Cluster{{asUpperCamelCase responseName}}, this); - {{else}} - chip::Callback::Callback * onSuccessCallback = new chip::Callback::Callback(OnDefaultSuccessResponse, this); - {{/if}} - chip::Callback::Callback * onFailureCallback = new chip::Callback::Callback(OnDefaultFailureResponse, this); - {{#chip_cluster_command_arguments_with_structs_expanded}} - {{#if (isCharString type)}}chip::ByteSpan{{else}}{{chipType}}{{/if}} m{{asUpperCamelCase label}}; - {{/chip_cluster_command_arguments_with_structs_expanded}} + chip::app::Clusters::{{asUpperCamelCase parent.name}}::Commands::{{asUpperCamelCase name}}::Type mRequest; }; {{/chip_cluster_commands}} diff --git a/src/app/zap-templates/common/ClustersHelper.js b/src/app/zap-templates/common/ClustersHelper.js index 71926ea20e6396..72210cf1077281 100644 --- a/src/app/zap-templates/common/ClustersHelper.js +++ b/src/app/zap-templates/common/ClustersHelper.js @@ -300,12 +300,14 @@ function handleBasic(item, [ atomics, enums, bitmaps, structs ]) const enumItem = getEnum(enums, itemType); if (enumItem) { - itemType = enumItem.type; + item.isEnum = true; + itemType = enumItem.type; } const bitmap = getBitmap(bitmaps, itemType); if (bitmap) { - itemType = bitmap.type; + item.isBitmap = true; + itemType = bitmap.type; } const atomic = getAtomic(atomics, itemType); From 348b7f9eb40af3cdda18453a58ffc32a0e06553a Mon Sep 17 00:00:00 2001 From: Vivien Nicolas Date: Mon, 18 Oct 2021 16:40:28 +0200 Subject: [PATCH 2/2] Update generated chip-tool commands --- .../zap-generated/cluster/Commands.h | 4635 ++++++----------- 1 file changed, 1597 insertions(+), 3038 deletions(-) diff --git a/zzz_generated/chip-tool/zap-generated/cluster/Commands.h b/zzz_generated/chip-tool/zap-generated/cluster/Commands.h index d243b0ffc86697..be1427606d81f5 100644 --- a/zzz_generated/chip-tool/zap-generated/cluster/Commands.h +++ b/zzz_generated/chip-tool/zap-generated/cluster/Commands.h @@ -21,6 +21,7 @@ #include +#include #include #include #include @@ -43,6 +44,16 @@ static void OnDefaultFailureResponse(void * context, uint8_t status) command->SetCommandExitStatus(CHIP_ERROR_INTERNAL); } +static void OnDefaultSuccess(void * context, const chip::app::DataModel::NullObjectType & data) +{ + OnDefaultSuccessResponse(context); +}; + +static void OnDefaultFailure(void * context, EmberAfStatus status) +{ + OnDefaultFailureResponse(context, status); +}; + static void OnBooleanAttributeResponse(void * context, bool value) { ChipLogProgress(chipTool, "Boolean attribute Response: %d", value); @@ -140,1029 +151,1248 @@ static void OnCharStringAttributeResponse(void * context, const chip::ByteSpan v command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnAccountLoginClusterGetSetupPINResponse(void * context, uint8_t * setupPIN) +static void OnApplicationLauncherApplicationLauncherListListAttributeResponse(void * context, uint16_t count, uint16_t * entries) { - ChipLogProgress(chipTool, "AccountLoginClusterGetSetupPINResponse"); - - ModelCommand * command = static_cast(context); - command->SetCommandExitStatus(CHIP_NO_ERROR); -} + ChipLogProgress(chipTool, "OnApplicationLauncherApplicationLauncherListListAttributeResponse: %" PRIu16 " entries", count); -static void OnApplicationLauncherClusterLaunchAppResponse(void * context, uint8_t status, uint8_t * data) -{ - ChipLogProgress(chipTool, "ApplicationLauncherClusterLaunchAppResponse"); + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "INT16U[%" PRIu16 "]: %" PRIu16 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnContentLauncherClusterLaunchContentResponse(void * context, uint8_t * data, uint8_t contentLaunchStatus) +static void OnAudioOutputAudioOutputListListAttributeResponse(void * context, uint16_t count, _AudioOutputInfo * entries) { - ChipLogProgress(chipTool, "ContentLauncherClusterLaunchContentResponse"); - - ModelCommand * command = static_cast(context); - command->SetCommandExitStatus(CHIP_NO_ERROR); -} + ChipLogProgress(chipTool, "OnAudioOutputAudioOutputListListAttributeResponse: %" PRIu16 " entries", count); -static void OnContentLauncherClusterLaunchURLResponse(void * context, uint8_t * data, uint8_t contentLaunchStatus) -{ - ChipLogProgress(chipTool, "ContentLauncherClusterLaunchURLResponse"); + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "AudioOutputInfo[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " index: %" PRIu8 "", entries[i].index); + ChipLogProgress(chipTool, " outputType: %" PRIu8 "", entries[i].outputType); + ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterClearAllPinsResponse(void * context, uint8_t status) +static void OnContentLauncherAcceptsHeaderListListAttributeResponse(void * context, uint16_t count, chip::ByteSpan * entries) { - ChipLogProgress(chipTool, "DoorLockClusterClearAllPinsResponse"); + ChipLogProgress(chipTool, "OnContentLauncherAcceptsHeaderListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(Zcl, " : %zu", entries[i].size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterClearAllRfidsResponse(void * context, uint8_t status) +static void OnContentLauncherSupportedStreamingTypesListAttributeResponse(void * context, uint16_t count, uint8_t * entries) { - ChipLogProgress(chipTool, "DoorLockClusterClearAllRfidsResponse"); + ChipLogProgress(chipTool, "OnContentLauncherSupportedStreamingTypesListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "ContentLaunchStreamingType[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterClearHolidayScheduleResponse(void * context, uint8_t status) +static void OnDescriptorDeviceListListAttributeResponse(void * context, uint16_t count, _DeviceType * entries) { - ChipLogProgress(chipTool, "DoorLockClusterClearHolidayScheduleResponse"); + ChipLogProgress(chipTool, "OnDescriptorDeviceListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "DeviceType[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " type: %" PRIu32 "", entries[i].type); + ChipLogProgress(chipTool, " revision: %" PRIu16 "", entries[i].revision); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterClearPinResponse(void * context, uint8_t status) +static void OnDescriptorServerListListAttributeResponse(void * context, uint16_t count, chip::ClusterId * entries) { - ChipLogProgress(chipTool, "DoorLockClusterClearPinResponse"); + ChipLogProgress(chipTool, "OnDescriptorServerListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "CLUSTER_ID[%" PRIu16 "]: %" PRIu32 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterClearRfidResponse(void * context, uint8_t status) +static void OnDescriptorClientListListAttributeResponse(void * context, uint16_t count, chip::ClusterId * entries) { - ChipLogProgress(chipTool, "DoorLockClusterClearRfidResponse"); + ChipLogProgress(chipTool, "OnDescriptorClientListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "CLUSTER_ID[%" PRIu16 "]: %" PRIu32 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterClearWeekdayScheduleResponse(void * context, uint8_t status) +static void OnDescriptorPartsListListAttributeResponse(void * context, uint16_t count, chip::EndpointId * entries) { - ChipLogProgress(chipTool, "DoorLockClusterClearWeekdayScheduleResponse"); + ChipLogProgress(chipTool, "OnDescriptorPartsListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "ENDPOINT_NO[%" PRIu16 "]: %" PRIu16 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterClearYeardayScheduleResponse(void * context, uint8_t status) +static void OnFixedLabelLabelListListAttributeResponse(void * context, uint16_t count, _LabelStruct * entries) { - ChipLogProgress(chipTool, "DoorLockClusterClearYeardayScheduleResponse"); + ChipLogProgress(chipTool, "OnFixedLabelLabelListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "LabelStruct[%" PRIu16 "]:", i); + ChipLogProgress(Zcl, " label: %zu", entries[i].label.size()); + ChipLogProgress(Zcl, " value: %zu", entries[i].value.size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterGetHolidayScheduleResponse(void * context, uint8_t scheduleId, uint8_t status, uint32_t localStartTime, - uint32_t localEndTime, uint8_t operatingModeDuringHoliday) +static void OnGeneralCommissioningBasicCommissioningInfoListListAttributeResponse(void * context, uint16_t count, + _BasicCommissioningInfoType * entries) { - ChipLogProgress(chipTool, "DoorLockClusterGetHolidayScheduleResponse"); + ChipLogProgress(chipTool, "OnGeneralCommissioningBasicCommissioningInfoListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "BasicCommissioningInfoType[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " FailSafeExpiryLengthMs: %" PRIu32 "", entries[i].FailSafeExpiryLengthMs); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterGetLogRecordResponse(void * context, uint16_t logEntryId, uint32_t timestamp, uint8_t eventType, - uint8_t source, uint8_t eventIdOrAlarmCode, uint16_t userId, chip::ByteSpan pin) +static void OnGeneralDiagnosticsNetworkInterfacesListAttributeResponse(void * context, uint16_t count, + _NetworkInterfaceType * entries) { - ChipLogProgress(chipTool, "DoorLockClusterGetLogRecordResponse"); + ChipLogProgress(chipTool, "OnGeneralDiagnosticsNetworkInterfacesListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "NetworkInterfaceType[%" PRIu16 "]:", i); + ChipLogProgress(Zcl, " Name: %zu", entries[i].Name.size()); + ChipLogProgress(chipTool, " FabricConnected: %d", entries[i].FabricConnected); + ChipLogProgress(chipTool, " OffPremiseServicesReachableIPv4: %d", entries[i].OffPremiseServicesReachableIPv4); + ChipLogProgress(chipTool, " OffPremiseServicesReachableIPv6: %d", entries[i].OffPremiseServicesReachableIPv6); + ChipLogProgress(Zcl, " HardwareAddress: %zu", entries[i].HardwareAddress.size()); + ChipLogProgress(chipTool, " Type: %" PRIu8 "", entries[i].Type); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterGetPinResponse(void * context, uint16_t userId, uint8_t userStatus, uint8_t userType, - chip::ByteSpan pin) +static void OnGroupKeyManagementGroupsListAttributeResponse(void * context, uint16_t count, _GroupState * entries) { - ChipLogProgress(chipTool, "DoorLockClusterGetPinResponse"); + ChipLogProgress(chipTool, "OnGroupKeyManagementGroupsListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "GroupState[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " VendorId: %" PRIu16 "", entries[i].VendorId); + ChipLogProgress(chipTool, " VendorGroupId: %" PRIu16 "", entries[i].VendorGroupId); + ChipLogProgress(chipTool, " GroupKeySetIndex: %" PRIu16 "", entries[i].GroupKeySetIndex); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterGetRfidResponse(void * context, uint16_t userId, uint8_t userStatus, uint8_t userType, - chip::ByteSpan rfid) +static void OnGroupKeyManagementGroupKeysListAttributeResponse(void * context, uint16_t count, _GroupKey * entries) { - ChipLogProgress(chipTool, "DoorLockClusterGetRfidResponse"); + ChipLogProgress(chipTool, "OnGroupKeyManagementGroupKeysListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "GroupKey[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " VendorId: %" PRIu16 "", entries[i].VendorId); + ChipLogProgress(chipTool, " GroupKeyIndex: %" PRIu16 "", entries[i].GroupKeyIndex); + ChipLogProgress(Zcl, " GroupKeyRoot: %zu", entries[i].GroupKeyRoot.size()); + ChipLogProgress(chipTool, " GroupKeyEpochStartTime: %" PRIu64 "", entries[i].GroupKeyEpochStartTime); + ChipLogProgress(chipTool, " GroupKeySecurityPolicy: %" PRIu8 "", entries[i].GroupKeySecurityPolicy); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterGetUserTypeResponse(void * context, uint16_t userId, uint8_t userType) +static void OnMediaInputMediaInputListListAttributeResponse(void * context, uint16_t count, _MediaInputInfo * entries) { - ChipLogProgress(chipTool, "DoorLockClusterGetUserTypeResponse"); + ChipLogProgress(chipTool, "OnMediaInputMediaInputListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "MediaInputInfo[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " index: %" PRIu8 "", entries[i].index); + ChipLogProgress(chipTool, " inputType: %" PRIu8 "", entries[i].inputType); + ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); + ChipLogProgress(Zcl, " description: %zu", entries[i].description.size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterGetWeekdayScheduleResponse(void * context, uint8_t scheduleId, uint16_t userId, uint8_t status, - uint8_t daysMask, uint8_t startHour, uint8_t startMinute, uint8_t endHour, - uint8_t endMinute) +static void OnOperationalCredentialsFabricsListListAttributeResponse(void * context, uint16_t count, _FabricDescriptor * entries) { - ChipLogProgress(chipTool, "DoorLockClusterGetWeekdayScheduleResponse"); + ChipLogProgress(chipTool, "OnOperationalCredentialsFabricsListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "FabricDescriptor[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " FabricIndex: %" PRIu8 "", entries[i].FabricIndex); + ChipLogProgress(Zcl, " RootPublicKey: %zu", entries[i].RootPublicKey.size()); + ChipLogProgress(chipTool, " VendorId: %" PRIu16 "", entries[i].VendorId); + ChipLogProgress(chipTool, " FabricId: %" PRIu64 "", entries[i].FabricId); + ChipLogProgress(chipTool, " NodeId: %" PRIu64 "", entries[i].NodeId); + ChipLogProgress(Zcl, " Label: %zu", entries[i].Label.size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterGetYeardayScheduleResponse(void * context, uint8_t scheduleId, uint16_t userId, uint8_t status, - uint32_t localStartTime, uint32_t localEndTime) +static void OnPowerSourceActiveBatteryFaultsListAttributeResponse(void * context, uint16_t count, uint8_t * entries) { - ChipLogProgress(chipTool, "DoorLockClusterGetYeardayScheduleResponse"); + ChipLogProgress(chipTool, "OnPowerSourceActiveBatteryFaultsListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "ENUM8[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterLockDoorResponse(void * context, uint8_t status) +static void OnTvChannelTvChannelListListAttributeResponse(void * context, uint16_t count, _TvChannelInfo * entries) { - ChipLogProgress(chipTool, "DoorLockClusterLockDoorResponse"); + ChipLogProgress(chipTool, "OnTvChannelTvChannelListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "TvChannelInfo[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " majorNumber: %" PRIu16 "", entries[i].majorNumber); + ChipLogProgress(chipTool, " minorNumber: %" PRIu16 "", entries[i].minorNumber); + ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); + ChipLogProgress(Zcl, " callSign: %zu", entries[i].callSign.size()); + ChipLogProgress(Zcl, " affiliateCallSign: %zu", entries[i].affiliateCallSign.size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterSetHolidayScheduleResponse(void * context, uint8_t status) +static void OnTargetNavigatorTargetNavigatorListListAttributeResponse(void * context, uint16_t count, + _NavigateTargetTargetInfo * entries) { - ChipLogProgress(chipTool, "DoorLockClusterSetHolidayScheduleResponse"); + ChipLogProgress(chipTool, "OnTargetNavigatorTargetNavigatorListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "NavigateTargetTargetInfo[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " identifier: %" PRIu8 "", entries[i].identifier); + ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterSetPinResponse(void * context, uint8_t status) +static void OnTestClusterListInt8uListAttributeResponse(void * context, uint16_t count, uint8_t * entries) { - ChipLogProgress(chipTool, "DoorLockClusterSetPinResponse"); + ChipLogProgress(chipTool, "OnTestClusterListInt8uListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "INT8U[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterSetRfidResponse(void * context, uint8_t status) +static void OnTestClusterListOctetStringListAttributeResponse(void * context, uint16_t count, chip::ByteSpan * entries) { - ChipLogProgress(chipTool, "DoorLockClusterSetRfidResponse"); + ChipLogProgress(chipTool, "OnTestClusterListOctetStringListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(Zcl, " : %zu", entries[i].size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterSetUserTypeResponse(void * context, uint8_t status) +static void OnTestClusterListStructOctetStringListAttributeResponse(void * context, uint16_t count, _TestListStructOctet * entries) { - ChipLogProgress(chipTool, "DoorLockClusterSetUserTypeResponse"); + ChipLogProgress(chipTool, "OnTestClusterListStructOctetStringListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "TestListStructOctet[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " fabricIndex: %" PRIu64 "", entries[i].fabricIndex); + ChipLogProgress(Zcl, " operationalCert: %zu", entries[i].operationalCert.size()); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterSetWeekdayScheduleResponse(void * context, uint8_t status) +static void OnThreadNetworkDiagnosticsNeighborTableListListAttributeResponse(void * context, uint16_t count, + _NeighborTable * entries) { - ChipLogProgress(chipTool, "DoorLockClusterSetWeekdayScheduleResponse"); + ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsNeighborTableListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "NeighborTable[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " ExtAddress: %" PRIu64 "", entries[i].ExtAddress); + ChipLogProgress(chipTool, " Age: %" PRIu32 "", entries[i].Age); + ChipLogProgress(chipTool, " Rloc16: %" PRIu16 "", entries[i].Rloc16); + ChipLogProgress(chipTool, " LinkFrameCounter: %" PRIu32 "", entries[i].LinkFrameCounter); + ChipLogProgress(chipTool, " MleFrameCounter: %" PRIu32 "", entries[i].MleFrameCounter); + ChipLogProgress(chipTool, " LQI: %" PRIu8 "", entries[i].LQI); + ChipLogProgress(chipTool, " AverageRssi: %" PRId8 "", entries[i].AverageRssi); + ChipLogProgress(chipTool, " LastRssi: %" PRId8 "", entries[i].LastRssi); + ChipLogProgress(chipTool, " FrameErrorRate: %" PRIu8 "", entries[i].FrameErrorRate); + ChipLogProgress(chipTool, " MessageErrorRate: %" PRIu8 "", entries[i].MessageErrorRate); + ChipLogProgress(chipTool, " RxOnWhenIdle: %d", entries[i].RxOnWhenIdle); + ChipLogProgress(chipTool, " FullThreadDevice: %d", entries[i].FullThreadDevice); + ChipLogProgress(chipTool, " FullNetworkData: %d", entries[i].FullNetworkData); + ChipLogProgress(chipTool, " IsChild: %d", entries[i].IsChild); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterSetYeardayScheduleResponse(void * context, uint8_t status) +static void OnThreadNetworkDiagnosticsRouteTableListListAttributeResponse(void * context, uint16_t count, _RouteTable * entries) { - ChipLogProgress(chipTool, "DoorLockClusterSetYeardayScheduleResponse"); + ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsRouteTableListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "RouteTable[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " ExtAddress: %" PRIu64 "", entries[i].ExtAddress); + ChipLogProgress(chipTool, " Rloc16: %" PRIu16 "", entries[i].Rloc16); + ChipLogProgress(chipTool, " RouterId: %" PRIu8 "", entries[i].RouterId); + ChipLogProgress(chipTool, " NextHop: %" PRIu8 "", entries[i].NextHop); + ChipLogProgress(chipTool, " PathCost: %" PRIu8 "", entries[i].PathCost); + ChipLogProgress(chipTool, " LQIIn: %" PRIu8 "", entries[i].LQIIn); + ChipLogProgress(chipTool, " LQIOut: %" PRIu8 "", entries[i].LQIOut); + ChipLogProgress(chipTool, " Age: %" PRIu8 "", entries[i].Age); + ChipLogProgress(chipTool, " Allocated: %d", entries[i].Allocated); + ChipLogProgress(chipTool, " LinkEstablished: %d", entries[i].LinkEstablished); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterUnlockDoorResponse(void * context, uint8_t status) +static void OnThreadNetworkDiagnosticsSecurityPolicyListAttributeResponse(void * context, uint16_t count, _SecurityPolicy * entries) { - ChipLogProgress(chipTool, "DoorLockClusterUnlockDoorResponse"); + ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsSecurityPolicyListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "SecurityPolicy[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " RotationTime: %" PRIu16 "", entries[i].RotationTime); + ChipLogProgress(chipTool, " Flags: %" PRIu16 "", entries[i].Flags); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnDoorLockClusterUnlockWithTimeoutResponse(void * context, uint8_t status) +static void OnThreadNetworkDiagnosticsOperationalDatasetComponentsListAttributeResponse(void * context, uint16_t count, + _OperationalDatasetComponents * entries) { - ChipLogProgress(chipTool, "DoorLockClusterUnlockWithTimeoutResponse"); - + ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsOperationalDatasetComponentsListAttributeResponse: %" PRIu16 " entries", + count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "OperationalDatasetComponents[%" PRIu16 "]:", i); + ChipLogProgress(chipTool, " ActiveTimestampPresent: %d", entries[i].ActiveTimestampPresent); + ChipLogProgress(chipTool, " PendingTimestampPresent: %d", entries[i].PendingTimestampPresent); + ChipLogProgress(chipTool, " MasterKeyPresent: %d", entries[i].MasterKeyPresent); + ChipLogProgress(chipTool, " NetworkNamePresent: %d", entries[i].NetworkNamePresent); + ChipLogProgress(chipTool, " ExtendedPanIdPresent: %d", entries[i].ExtendedPanIdPresent); + ChipLogProgress(chipTool, " MeshLocalPrefixPresent: %d", entries[i].MeshLocalPrefixPresent); + ChipLogProgress(chipTool, " DelayPresent: %d", entries[i].DelayPresent); + ChipLogProgress(chipTool, " PanIdPresent: %d", entries[i].PanIdPresent); + ChipLogProgress(chipTool, " ChannelPresent: %d", entries[i].ChannelPresent); + ChipLogProgress(chipTool, " PskcPresent: %d", entries[i].PskcPresent); + ChipLogProgress(chipTool, " SecurityPolicyPresent: %d", entries[i].SecurityPolicyPresent); + ChipLogProgress(chipTool, " ChannelMaskPresent: %d", entries[i].ChannelMaskPresent); + } + ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnGeneralCommissioningClusterArmFailSafeResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnThreadNetworkDiagnosticsActiveNetworkFaultsListListAttributeResponse(void * context, uint16_t count, + uint8_t * entries) { - ChipLogProgress(chipTool, "GeneralCommissioningClusterArmFailSafeResponse"); + ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsActiveNetworkFaultsListListAttributeResponse: %" PRIu16 " entries", count); + + for (uint16_t i = 0; i < count; i++) + { + ChipLogProgress(chipTool, "NetworkFault[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); + } ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); } -static void OnGeneralCommissioningClusterCommissioningCompleteResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnAccountLoginGetSetupPINResponseSuccess( + void * context, const chip::app::Clusters::AccountLogin::Commands::GetSetupPINResponse::DecodableType & data) { - ChipLogProgress(chipTool, "GeneralCommissioningClusterCommissioningCompleteResponse"); + ChipLogProgress(Zcl, "Received GetSetupPINResponse:"); + ChipLogProgress(Zcl, " setupPIN: %.*s", static_cast(data.setupPIN.size()), data.setupPIN.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGeneralCommissioningClusterSetRegulatoryConfigResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnApplicationLauncherLaunchAppResponseSuccess( + void * context, const chip::app::Clusters::ApplicationLauncher::Commands::LaunchAppResponse::DecodableType & data) { - ChipLogProgress(chipTool, "GeneralCommissioningClusterSetRegulatoryConfigResponse"); + ChipLogProgress(Zcl, "Received LaunchAppResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " data: %.*s", static_cast(data.data.size()), data.data.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGroupsClusterAddGroupResponse(void * context, uint8_t status, uint16_t groupId) +static void OnContentLauncherLaunchContentResponseSuccess( + void * context, const chip::app::Clusters::ContentLauncher::Commands::LaunchContentResponse::DecodableType & data) { - ChipLogProgress(chipTool, "GroupsClusterAddGroupResponse"); + ChipLogProgress(Zcl, "Received LaunchContentResponse:"); + ChipLogProgress(Zcl, " data: %.*s", static_cast(data.data.size()), data.data.data()); + ChipLogProgress(Zcl, " contentLaunchStatus: %" PRIu8 "", data.contentLaunchStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGroupsClusterGetGroupMembershipResponse(void * context, uint8_t capacity, uint8_t groupCount, - /* TYPE WARNING: array array defaults to */ uint8_t * groupList) +static void OnContentLauncherLaunchURLResponseSuccess( + void * context, const chip::app::Clusters::ContentLauncher::Commands::LaunchURLResponse::DecodableType & data) { - ChipLogProgress(chipTool, "GroupsClusterGetGroupMembershipResponse"); + ChipLogProgress(Zcl, "Received LaunchURLResponse:"); + ChipLogProgress(Zcl, " data: %.*s", static_cast(data.data.size()), data.data.data()); + ChipLogProgress(Zcl, " contentLaunchStatus: %" PRIu8 "", data.contentLaunchStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGroupsClusterRemoveGroupResponse(void * context, uint8_t status, uint16_t groupId) +static void +OnDoorLockClearAllPinsResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::ClearAllPinsResponse::DecodableType & data) { - ChipLogProgress(chipTool, "GroupsClusterRemoveGroupResponse"); + ChipLogProgress(Zcl, "Received ClearAllPinsResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGroupsClusterViewGroupResponse(void * context, uint8_t status, uint16_t groupId, uint8_t * groupName) +static void +OnDoorLockClearAllRfidsResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::ClearAllRfidsResponse::DecodableType & data) { - ChipLogProgress(chipTool, "GroupsClusterViewGroupResponse"); + ChipLogProgress(Zcl, "Received ClearAllRfidsResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnIdentifyClusterIdentifyQueryResponse(void * context, uint16_t timeout) +static void OnDoorLockClearHolidayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::ClearHolidayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "IdentifyClusterIdentifyQueryResponse"); + ChipLogProgress(Zcl, "Received ClearHolidayScheduleResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnKeypadInputClusterSendKeyResponse(void * context, uint8_t status) +static void OnDoorLockClearPinResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::ClearPinResponse::DecodableType & data) { - ChipLogProgress(chipTool, "KeypadInputClusterSendKeyResponse"); + ChipLogProgress(Zcl, "Received ClearPinResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaFastForwardResponse(void * context, uint8_t mediaPlaybackStatus) +static void +OnDoorLockClearRfidResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::ClearRfidResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaFastForwardResponse"); + ChipLogProgress(Zcl, "Received ClearRfidResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaNextResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockClearWeekdayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::ClearWeekdayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaNextResponse"); + ChipLogProgress(Zcl, "Received ClearWeekdayScheduleResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaPauseResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockClearYeardayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::ClearYeardayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaPauseResponse"); + ChipLogProgress(Zcl, "Received ClearYeardayScheduleResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaPlayResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockGetHolidayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::GetHolidayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaPlayResponse"); + ChipLogProgress(Zcl, "Received GetHolidayScheduleResponse:"); + ChipLogProgress(Zcl, " scheduleId: %" PRIu8 "", data.scheduleId); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " localStartTime: %" PRIu32 "", data.localStartTime); + ChipLogProgress(Zcl, " localEndTime: %" PRIu32 "", data.localEndTime); + ChipLogProgress(Zcl, " operatingModeDuringHoliday: %" PRIu8 "", data.operatingModeDuringHoliday); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaPreviousResponse(void * context, uint8_t mediaPlaybackStatus) -{ - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaPreviousResponse"); +static void +OnDoorLockGetLogRecordResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::GetLogRecordResponse::DecodableType & data) +{ + ChipLogProgress(Zcl, "Received GetLogRecordResponse:"); + ChipLogProgress(Zcl, " logEntryId: %" PRIu16 "", data.logEntryId); + ChipLogProgress(Zcl, " timestamp: %" PRIu32 "", data.timestamp); + ChipLogProgress(Zcl, " eventType: %" PRIu8 "", data.eventType); + ChipLogProgress(Zcl, " source: %" PRIu8 "", data.source); + ChipLogProgress(Zcl, " eventIdOrAlarmCode: %" PRIu8 "", data.eventIdOrAlarmCode); + ChipLogProgress(Zcl, " userId: %" PRIu16 "", data.userId); + ChipLogProgress(Zcl, " pin: %zu", data.pin.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaRewindResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockGetPinResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::GetPinResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaRewindResponse"); + ChipLogProgress(Zcl, "Received GetPinResponse:"); + ChipLogProgress(Zcl, " userId: %" PRIu16 "", data.userId); + ChipLogProgress(Zcl, " userStatus: %" PRIu8 "", data.userStatus); + ChipLogProgress(Zcl, " userType: %" PRIu8 "", data.userType); + ChipLogProgress(Zcl, " pin: %zu", data.pin.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaSeekResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockGetRfidResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::GetRfidResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaSeekResponse"); + ChipLogProgress(Zcl, "Received GetRfidResponse:"); + ChipLogProgress(Zcl, " userId: %" PRIu16 "", data.userId); + ChipLogProgress(Zcl, " userStatus: %" PRIu8 "", data.userStatus); + ChipLogProgress(Zcl, " userType: %" PRIu8 "", data.userType); + ChipLogProgress(Zcl, " rfid: %zu", data.rfid.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaSkipBackwardResponse(void * context, uint8_t mediaPlaybackStatus) +static void +OnDoorLockGetUserTypeResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::GetUserTypeResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaSkipBackwardResponse"); + ChipLogProgress(Zcl, "Received GetUserTypeResponse:"); + ChipLogProgress(Zcl, " userId: %" PRIu16 "", data.userId); + ChipLogProgress(Zcl, " userType: %" PRIu8 "", data.userType); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaSkipForwardResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockGetWeekdayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::GetWeekdayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaSkipForwardResponse"); + ChipLogProgress(Zcl, "Received GetWeekdayScheduleResponse:"); + ChipLogProgress(Zcl, " scheduleId: %" PRIu8 "", data.scheduleId); + ChipLogProgress(Zcl, " userId: %" PRIu16 "", data.userId); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " daysMask: %" PRIu8 "", data.daysMask); + ChipLogProgress(Zcl, " startHour: %" PRIu8 "", data.startHour); + ChipLogProgress(Zcl, " startMinute: %" PRIu8 "", data.startMinute); + ChipLogProgress(Zcl, " endHour: %" PRIu8 "", data.endHour); + ChipLogProgress(Zcl, " endMinute: %" PRIu8 "", data.endMinute); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaStartOverResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockGetYeardayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::GetYeardayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaStartOverResponse"); + ChipLogProgress(Zcl, "Received GetYeardayScheduleResponse:"); + ChipLogProgress(Zcl, " scheduleId: %" PRIu8 "", data.scheduleId); + ChipLogProgress(Zcl, " userId: %" PRIu16 "", data.userId); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " localStartTime: %" PRIu32 "", data.localStartTime); + ChipLogProgress(Zcl, " localEndTime: %" PRIu32 "", data.localEndTime); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaPlaybackClusterMediaStopResponse(void * context, uint8_t mediaPlaybackStatus) +static void OnDoorLockLockDoorResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::LockDoorResponse::DecodableType & data) { - ChipLogProgress(chipTool, "MediaPlaybackClusterMediaStopResponse"); + ChipLogProgress(Zcl, "Received LockDoorResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnNetworkCommissioningClusterAddThreadNetworkResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnDoorLockSetHolidayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::SetHolidayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterAddThreadNetworkResponse"); + ChipLogProgress(Zcl, "Received SetHolidayScheduleResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnNetworkCommissioningClusterAddWiFiNetworkResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnDoorLockSetPinResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::SetPinResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterAddWiFiNetworkResponse"); + ChipLogProgress(Zcl, "Received SetPinResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnNetworkCommissioningClusterDisableNetworkResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnDoorLockSetRfidResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::SetRfidResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterDisableNetworkResponse"); + ChipLogProgress(Zcl, "Received SetRfidResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnNetworkCommissioningClusterEnableNetworkResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void +OnDoorLockSetUserTypeResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::SetUserTypeResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterEnableNetworkResponse"); + ChipLogProgress(Zcl, "Received SetUserTypeResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnNetworkCommissioningClusterRemoveNetworkResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnDoorLockSetWeekdayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::SetWeekdayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterRemoveNetworkResponse"); + ChipLogProgress(Zcl, "Received SetWeekdayScheduleResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void -OnNetworkCommissioningClusterScanNetworksResponse(void * context, uint8_t errorCode, uint8_t * debugText, - /* TYPE WARNING: array array defaults to */ uint8_t * wifiScanResults, - /* TYPE WARNING: array array defaults to */ uint8_t * threadScanResults) +static void OnDoorLockSetYeardayScheduleResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::SetYeardayScheduleResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterScanNetworksResponse"); + ChipLogProgress(Zcl, "Received SetYeardayScheduleResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnNetworkCommissioningClusterUpdateThreadNetworkResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void +OnDoorLockUnlockDoorResponseSuccess(void * context, + const chip::app::Clusters::DoorLock::Commands::UnlockDoorResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterUpdateThreadNetworkResponse"); + ChipLogProgress(Zcl, "Received UnlockDoorResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnNetworkCommissioningClusterUpdateWiFiNetworkResponse(void * context, uint8_t errorCode, uint8_t * debugText) +static void OnDoorLockUnlockWithTimeoutResponseSuccess( + void * context, const chip::app::Clusters::DoorLock::Commands::UnlockWithTimeoutResponse::DecodableType & data) { - ChipLogProgress(chipTool, "NetworkCommissioningClusterUpdateWiFiNetworkResponse"); + ChipLogProgress(Zcl, "Received UnlockWithTimeoutResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnOtaSoftwareUpdateProviderClusterApplyUpdateRequestResponse(void * context, uint8_t action, uint32_t delayedActionTime) +static void OnGeneralCommissioningArmFailSafeResponseSuccess( + void * context, const chip::app::Clusters::GeneralCommissioning::Commands::ArmFailSafeResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OtaSoftwareUpdateProviderClusterApplyUpdateRequestResponse"); + ChipLogProgress(Zcl, "Received ArmFailSafeResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnOtaSoftwareUpdateProviderClusterQueryImageResponse(void * context, uint8_t status, uint32_t delayedActionTime, - uint8_t * imageURI, uint32_t softwareVersion, - uint8_t * softwareVersionString, chip::ByteSpan updateToken, - bool userConsentNeeded, chip::ByteSpan metadataForRequestor) +static void OnGeneralCommissioningCommissioningCompleteResponseSuccess( + void * context, const chip::app::Clusters::GeneralCommissioning::Commands::CommissioningCompleteResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OtaSoftwareUpdateProviderClusterQueryImageResponse"); + ChipLogProgress(Zcl, "Received CommissioningCompleteResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnOperationalCredentialsClusterAttestationResponse(void * context, chip::ByteSpan AttestationElements, - chip::ByteSpan Signature) +static void OnGeneralCommissioningSetRegulatoryConfigResponseSuccess( + void * context, const chip::app::Clusters::GeneralCommissioning::Commands::SetRegulatoryConfigResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OperationalCredentialsClusterAttestationResponse"); + ChipLogProgress(Zcl, "Received SetRegulatoryConfigResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnOperationalCredentialsClusterCertificateChainResponse(void * context, chip::ByteSpan Certificate) +static void OnGroupsAddGroupResponseSuccess(void * context, + const chip::app::Clusters::Groups::Commands::AddGroupResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OperationalCredentialsClusterCertificateChainResponse"); + ChipLogProgress(Zcl, "Received AddGroupResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnOperationalCredentialsClusterNOCResponse(void * context, uint8_t StatusCode, uint8_t FabricIndex, - chip::ByteSpan DebugText) +static void OnGroupsGetGroupMembershipResponseSuccess( + void * context, const chip::app::Clusters::Groups::Commands::GetGroupMembershipResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OperationalCredentialsClusterNOCResponse"); + ChipLogProgress(Zcl, "Received GetGroupMembershipResponse:"); + ChipLogProgress(Zcl, " capacity: %" PRIu8 "", data.capacity); + ChipLogProgress(Zcl, " groupCount: %" PRIu8 "", data.groupCount); + ChipLogProgress(Zcl, " groupList: Array printing is not implemented yet."); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnOperationalCredentialsClusterOpCSRResponse(void * context, chip::ByteSpan NOCSRElements, - chip::ByteSpan AttestationSignature) +static void +OnGroupsRemoveGroupResponseSuccess(void * context, + const chip::app::Clusters::Groups::Commands::RemoveGroupResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OperationalCredentialsClusterOpCSRResponse"); + ChipLogProgress(Zcl, "Received RemoveGroupResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnScenesClusterAddSceneResponse(void * context, uint8_t status, uint16_t groupId, uint8_t sceneId) +static void OnGroupsViewGroupResponseSuccess(void * context, + const chip::app::Clusters::Groups::Commands::ViewGroupResponse::DecodableType & data) { - ChipLogProgress(chipTool, "ScenesClusterAddSceneResponse"); + ChipLogProgress(Zcl, "Received ViewGroupResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); + ChipLogProgress(Zcl, " groupName: %.*s", static_cast(data.groupName.size()), data.groupName.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnScenesClusterGetSceneMembershipResponse(void * context, uint8_t status, uint8_t capacity, uint16_t groupId, - uint8_t sceneCount, - /* TYPE WARNING: array array defaults to */ uint8_t * sceneList) +static void +OnIdentifyIdentifyQueryResponseSuccess(void * context, + const chip::app::Clusters::Identify::Commands::IdentifyQueryResponse::DecodableType & data) { - ChipLogProgress(chipTool, "ScenesClusterGetSceneMembershipResponse"); + ChipLogProgress(Zcl, "Received IdentifyQueryResponse:"); + ChipLogProgress(Zcl, " timeout: %" PRIu16 "", data.timeout); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnScenesClusterRemoveAllScenesResponse(void * context, uint8_t status, uint16_t groupId) +static void +OnKeypadInputSendKeyResponseSuccess(void * context, + const chip::app::Clusters::KeypadInput::Commands::SendKeyResponse::DecodableType & data) { - ChipLogProgress(chipTool, "ScenesClusterRemoveAllScenesResponse"); + ChipLogProgress(Zcl, "Received SendKeyResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnScenesClusterRemoveSceneResponse(void * context, uint8_t status, uint16_t groupId, uint8_t sceneId) +static void OnMediaPlaybackMediaFastForwardResponseSuccess( + void * context, const chip::app::Clusters::MediaPlayback::Commands::MediaFastForwardResponse::DecodableType & data) { - ChipLogProgress(chipTool, "ScenesClusterRemoveSceneResponse"); + ChipLogProgress(Zcl, "Received MediaFastForwardResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnScenesClusterStoreSceneResponse(void * context, uint8_t status, uint16_t groupId, uint8_t sceneId) +static void +OnMediaPlaybackMediaNextResponseSuccess(void * context, + const chip::app::Clusters::MediaPlayback::Commands::MediaNextResponse::DecodableType & data) { - ChipLogProgress(chipTool, "ScenesClusterStoreSceneResponse"); + ChipLogProgress(Zcl, "Received MediaNextResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnScenesClusterViewSceneResponse(void * context, uint8_t status, uint16_t groupId, uint8_t sceneId, - uint16_t transitionTime, uint8_t * sceneName, - /* TYPE WARNING: array array defaults to */ uint8_t * extensionFieldSets) +static void OnMediaPlaybackMediaPauseResponseSuccess( + void * context, const chip::app::Clusters::MediaPlayback::Commands::MediaPauseResponse::DecodableType & data) { - ChipLogProgress(chipTool, "ScenesClusterViewSceneResponse"); + ChipLogProgress(Zcl, "Received MediaPauseResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTvChannelClusterChangeChannelResponse(void * context, - /* TYPE WARNING: array array defaults to */ uint8_t * ChannelMatch, - uint8_t ErrorType) +static void +OnMediaPlaybackMediaPlayResponseSuccess(void * context, + const chip::app::Clusters::MediaPlayback::Commands::MediaPlayResponse::DecodableType & data) { - ChipLogProgress(chipTool, "TvChannelClusterChangeChannelResponse"); + ChipLogProgress(Zcl, "Received MediaPlayResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTargetNavigatorClusterNavigateTargetResponse(void * context, uint8_t status, uint8_t * data) +static void OnMediaPlaybackMediaPreviousResponseSuccess( + void * context, const chip::app::Clusters::MediaPlayback::Commands::MediaPreviousResponse::DecodableType & data) { - ChipLogProgress(chipTool, "TargetNavigatorClusterNavigateTargetResponse"); + ChipLogProgress(Zcl, "Received MediaPreviousResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTestClusterClusterTestAddArgumentsResponse(void * context, uint8_t returnValue) +static void OnMediaPlaybackMediaRewindResponseSuccess( + void * context, const chip::app::Clusters::MediaPlayback::Commands::MediaRewindResponse::DecodableType & data) { - ChipLogProgress(chipTool, "TestClusterClusterTestAddArgumentsResponse"); + ChipLogProgress(Zcl, "Received MediaRewindResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTestClusterClusterTestListInt8UReverseResponse(void * context, - /* TYPE WARNING: array array defaults to */ uint8_t * arg1) +static void +OnMediaPlaybackMediaSeekResponseSuccess(void * context, + const chip::app::Clusters::MediaPlayback::Commands::MediaSeekResponse::DecodableType & data) { - ChipLogProgress(chipTool, "TestClusterClusterTestListInt8UReverseResponse"); + ChipLogProgress(Zcl, "Received MediaSeekResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTestClusterClusterTestSpecificResponse(void * context, uint8_t returnValue) +static void OnMediaPlaybackMediaSkipBackwardResponseSuccess( + void * context, const chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackwardResponse::DecodableType & data) { - ChipLogProgress(chipTool, "TestClusterClusterTestSpecificResponse"); + ChipLogProgress(Zcl, "Received MediaSkipBackwardResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnApplicationLauncherApplicationLauncherListListAttributeResponse(void * context, uint16_t count, uint16_t * entries) +static void OnMediaPlaybackMediaSkipForwardResponseSuccess( + void * context, const chip::app::Clusters::MediaPlayback::Commands::MediaSkipForwardResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnApplicationLauncherApplicationLauncherListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "INT16U[%" PRIu16 "]: %" PRIu16 "", i, entries[i]); - } + ChipLogProgress(Zcl, "Received MediaSkipForwardResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnAudioOutputAudioOutputListListAttributeResponse(void * context, uint16_t count, _AudioOutputInfo * entries) +static void OnMediaPlaybackMediaStartOverResponseSuccess( + void * context, const chip::app::Clusters::MediaPlayback::Commands::MediaStartOverResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnAudioOutputAudioOutputListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "AudioOutputInfo[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " index: %" PRIu8 "", entries[i].index); - ChipLogProgress(chipTool, " outputType: %" PRIu8 "", entries[i].outputType); - ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); - } + ChipLogProgress(Zcl, "Received MediaStartOverResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnContentLauncherAcceptsHeaderListListAttributeResponse(void * context, uint16_t count, chip::ByteSpan * entries) +static void +OnMediaPlaybackMediaStopResponseSuccess(void * context, + const chip::app::Clusters::MediaPlayback::Commands::MediaStopResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnContentLauncherAcceptsHeaderListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(Zcl, " : %zu", entries[i].size()); - } + ChipLogProgress(Zcl, "Received MediaStopResponse:"); + ChipLogProgress(Zcl, " mediaPlaybackStatus: %" PRIu8 "", data.mediaPlaybackStatus); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnContentLauncherSupportedStreamingTypesListAttributeResponse(void * context, uint16_t count, uint8_t * entries) +static void OnNetworkCommissioningAddThreadNetworkResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::AddThreadNetworkResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnContentLauncherSupportedStreamingTypesListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "ContentLaunchStreamingType[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); - } + ChipLogProgress(Zcl, "Received AddThreadNetworkResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnDescriptorDeviceListListAttributeResponse(void * context, uint16_t count, _DeviceType * entries) +static void OnNetworkCommissioningAddWiFiNetworkResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::AddWiFiNetworkResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnDescriptorDeviceListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "DeviceType[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " type: %" PRIu32 "", entries[i].type); - ChipLogProgress(chipTool, " revision: %" PRIu16 "", entries[i].revision); - } + ChipLogProgress(Zcl, "Received AddWiFiNetworkResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnDescriptorServerListListAttributeResponse(void * context, uint16_t count, chip::ClusterId * entries) +static void OnNetworkCommissioningDisableNetworkResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::DisableNetworkResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnDescriptorServerListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "CLUSTER_ID[%" PRIu16 "]: %" PRIu32 "", i, entries[i]); - } + ChipLogProgress(Zcl, "Received DisableNetworkResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnDescriptorClientListListAttributeResponse(void * context, uint16_t count, chip::ClusterId * entries) +static void OnNetworkCommissioningEnableNetworkResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::EnableNetworkResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnDescriptorClientListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "CLUSTER_ID[%" PRIu16 "]: %" PRIu32 "", i, entries[i]); - } + ChipLogProgress(Zcl, "Received EnableNetworkResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnDescriptorPartsListListAttributeResponse(void * context, uint16_t count, chip::EndpointId * entries) +static void OnNetworkCommissioningRemoveNetworkResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::RemoveNetworkResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnDescriptorPartsListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "ENDPOINT_NO[%" PRIu16 "]: %" PRIu16 "", i, entries[i]); - } + ChipLogProgress(Zcl, "Received RemoveNetworkResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnFixedLabelLabelListListAttributeResponse(void * context, uint16_t count, _LabelStruct * entries) +static void OnNetworkCommissioningScanNetworksResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::ScanNetworksResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnFixedLabelLabelListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "LabelStruct[%" PRIu16 "]:", i); - ChipLogProgress(Zcl, " label: %zu", entries[i].label.size()); - ChipLogProgress(Zcl, " value: %zu", entries[i].value.size()); - } + ChipLogProgress(Zcl, "Received ScanNetworksResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); + ChipLogProgress(Zcl, " wifiScanResults: Array printing is not implemented yet."); + ChipLogProgress(Zcl, " threadScanResults: Array printing is not implemented yet."); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGeneralCommissioningBasicCommissioningInfoListListAttributeResponse(void * context, uint16_t count, - _BasicCommissioningInfoType * entries) +static void OnNetworkCommissioningUpdateThreadNetworkResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::UpdateThreadNetworkResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnGeneralCommissioningBasicCommissioningInfoListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "BasicCommissioningInfoType[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " FailSafeExpiryLengthMs: %" PRIu32 "", entries[i].FailSafeExpiryLengthMs); - } + ChipLogProgress(Zcl, "Received UpdateThreadNetworkResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGeneralDiagnosticsNetworkInterfacesListAttributeResponse(void * context, uint16_t count, - _NetworkInterfaceType * entries) +static void OnNetworkCommissioningUpdateWiFiNetworkResponseSuccess( + void * context, const chip::app::Clusters::NetworkCommissioning::Commands::UpdateWiFiNetworkResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnGeneralDiagnosticsNetworkInterfacesListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "NetworkInterfaceType[%" PRIu16 "]:", i); - ChipLogProgress(Zcl, " Name: %zu", entries[i].Name.size()); - ChipLogProgress(chipTool, " FabricConnected: %d", entries[i].FabricConnected); - ChipLogProgress(chipTool, " OffPremiseServicesReachableIPv4: %d", entries[i].OffPremiseServicesReachableIPv4); - ChipLogProgress(chipTool, " OffPremiseServicesReachableIPv6: %d", entries[i].OffPremiseServicesReachableIPv6); - ChipLogProgress(Zcl, " HardwareAddress: %zu", entries[i].HardwareAddress.size()); - ChipLogProgress(chipTool, " Type: %" PRIu8 "", entries[i].Type); - } + ChipLogProgress(Zcl, "Received UpdateWiFiNetworkResponse:"); + ChipLogProgress(Zcl, " errorCode: %" PRIu8 "", data.errorCode); + ChipLogProgress(Zcl, " debugText: %.*s", static_cast(data.debugText.size()), data.debugText.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGroupKeyManagementGroupsListAttributeResponse(void * context, uint16_t count, _GroupState * entries) +static void OnOtaSoftwareUpdateProviderApplyUpdateRequestResponseSuccess( + void * context, + const chip::app::Clusters::OtaSoftwareUpdateProvider::Commands::ApplyUpdateRequestResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnGroupKeyManagementGroupsListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "GroupState[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " VendorId: %" PRIu16 "", entries[i].VendorId); - ChipLogProgress(chipTool, " VendorGroupId: %" PRIu16 "", entries[i].VendorGroupId); - ChipLogProgress(chipTool, " GroupKeySetIndex: %" PRIu16 "", entries[i].GroupKeySetIndex); - } + ChipLogProgress(Zcl, "Received ApplyUpdateRequestResponse:"); + ChipLogProgress(Zcl, " action: %" PRIu8 "", data.action); + ChipLogProgress(Zcl, " delayedActionTime: %" PRIu32 "", data.delayedActionTime); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnGroupKeyManagementGroupKeysListAttributeResponse(void * context, uint16_t count, _GroupKey * entries) +static void OnOtaSoftwareUpdateProviderQueryImageResponseSuccess( + void * context, const chip::app::Clusters::OtaSoftwareUpdateProvider::Commands::QueryImageResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnGroupKeyManagementGroupKeysListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "GroupKey[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " VendorId: %" PRIu16 "", entries[i].VendorId); - ChipLogProgress(chipTool, " GroupKeyIndex: %" PRIu16 "", entries[i].GroupKeyIndex); - ChipLogProgress(Zcl, " GroupKeyRoot: %zu", entries[i].GroupKeyRoot.size()); - ChipLogProgress(chipTool, " GroupKeyEpochStartTime: %" PRIu64 "", entries[i].GroupKeyEpochStartTime); - ChipLogProgress(chipTool, " GroupKeySecurityPolicy: %" PRIu8 "", entries[i].GroupKeySecurityPolicy); - } + ChipLogProgress(Zcl, "Received QueryImageResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " delayedActionTime: %" PRIu32 "", data.delayedActionTime); + ChipLogProgress(Zcl, " imageURI: %.*s", static_cast(data.imageURI.size()), data.imageURI.data()); + ChipLogProgress(Zcl, " softwareVersion: %" PRIu32 "", data.softwareVersion); + ChipLogProgress(Zcl, " softwareVersionString: %.*s", static_cast(data.softwareVersionString.size()), + data.softwareVersionString.data()); + ChipLogProgress(Zcl, " updateToken: %zu", data.updateToken.size()); + ChipLogProgress(Zcl, " userConsentNeeded: %d", data.userConsentNeeded); + ChipLogProgress(Zcl, " metadataForRequestor: %zu", data.metadataForRequestor.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnMediaInputMediaInputListListAttributeResponse(void * context, uint16_t count, _MediaInputInfo * entries) +static void OnOperationalCredentialsAttestationResponseSuccess( + void * context, const chip::app::Clusters::OperationalCredentials::Commands::AttestationResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnMediaInputMediaInputListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "MediaInputInfo[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " index: %" PRIu8 "", entries[i].index); - ChipLogProgress(chipTool, " inputType: %" PRIu8 "", entries[i].inputType); - ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); - ChipLogProgress(Zcl, " description: %zu", entries[i].description.size()); - } + ChipLogProgress(Zcl, "Received AttestationResponse:"); + ChipLogProgress(Zcl, " AttestationElements: %zu", data.attestationElements.size()); + ChipLogProgress(Zcl, " Signature: %zu", data.signature.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnOperationalCredentialsFabricsListListAttributeResponse(void * context, uint16_t count, _FabricDescriptor * entries) +static void OnOperationalCredentialsCertificateChainResponseSuccess( + void * context, const chip::app::Clusters::OperationalCredentials::Commands::CertificateChainResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnOperationalCredentialsFabricsListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "FabricDescriptor[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " FabricIndex: %" PRIu8 "", entries[i].FabricIndex); - ChipLogProgress(Zcl, " RootPublicKey: %zu", entries[i].RootPublicKey.size()); - ChipLogProgress(chipTool, " VendorId: %" PRIu16 "", entries[i].VendorId); - ChipLogProgress(chipTool, " FabricId: %" PRIu64 "", entries[i].FabricId); - ChipLogProgress(chipTool, " NodeId: %" PRIu64 "", entries[i].NodeId); - ChipLogProgress(Zcl, " Label: %zu", entries[i].Label.size()); - } + ChipLogProgress(Zcl, "Received CertificateChainResponse:"); + ChipLogProgress(Zcl, " Certificate: %zu", data.certificate.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnPowerSourceActiveBatteryFaultsListAttributeResponse(void * context, uint16_t count, uint8_t * entries) +static void OnOperationalCredentialsNOCResponseSuccess( + void * context, const chip::app::Clusters::OperationalCredentials::Commands::NOCResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnPowerSourceActiveBatteryFaultsListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "ENUM8[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); - } + ChipLogProgress(Zcl, "Received NOCResponse:"); + ChipLogProgress(Zcl, " StatusCode: %" PRIu8 "", data.statusCode); + ChipLogProgress(Zcl, " FabricIndex: %" PRIu8 "", data.fabricIndex); + ChipLogProgress(Zcl, " DebugText: %zu", data.debugText.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTvChannelTvChannelListListAttributeResponse(void * context, uint16_t count, _TvChannelInfo * entries) +static void OnOperationalCredentialsOpCSRResponseSuccess( + void * context, const chip::app::Clusters::OperationalCredentials::Commands::OpCSRResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnTvChannelTvChannelListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "TvChannelInfo[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " majorNumber: %" PRIu16 "", entries[i].majorNumber); - ChipLogProgress(chipTool, " minorNumber: %" PRIu16 "", entries[i].minorNumber); - ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); - ChipLogProgress(Zcl, " callSign: %zu", entries[i].callSign.size()); - ChipLogProgress(Zcl, " affiliateCallSign: %zu", entries[i].affiliateCallSign.size()); - } + ChipLogProgress(Zcl, "Received OpCSRResponse:"); + ChipLogProgress(Zcl, " NOCSRElements: %zu", data.NOCSRElements.size()); + ChipLogProgress(Zcl, " AttestationSignature: %zu", data.attestationSignature.size()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTargetNavigatorTargetNavigatorListListAttributeResponse(void * context, uint16_t count, - _NavigateTargetTargetInfo * entries) +static void OnScenesAddSceneResponseSuccess(void * context, + const chip::app::Clusters::Scenes::Commands::AddSceneResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnTargetNavigatorTargetNavigatorListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "NavigateTargetTargetInfo[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " identifier: %" PRIu8 "", entries[i].identifier); - ChipLogProgress(Zcl, " name: %zu", entries[i].name.size()); - } + ChipLogProgress(Zcl, "Received AddSceneResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); + ChipLogProgress(Zcl, " sceneId: %" PRIu8 "", data.sceneId); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTestClusterListInt8uListAttributeResponse(void * context, uint16_t count, uint8_t * entries) +static void OnScenesGetSceneMembershipResponseSuccess( + void * context, const chip::app::Clusters::Scenes::Commands::GetSceneMembershipResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnTestClusterListInt8uListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "INT8U[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); - } + ChipLogProgress(Zcl, "Received GetSceneMembershipResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " capacity: %" PRIu8 "", data.capacity); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); + ChipLogProgress(Zcl, " sceneCount: %" PRIu8 "", data.sceneCount); + ChipLogProgress(Zcl, " sceneList: Array printing is not implemented yet."); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTestClusterListOctetStringListAttributeResponse(void * context, uint16_t count, chip::ByteSpan * entries) +static void +OnScenesRemoveAllScenesResponseSuccess(void * context, + const chip::app::Clusters::Scenes::Commands::RemoveAllScenesResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnTestClusterListOctetStringListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(Zcl, " : %zu", entries[i].size()); - } + ChipLogProgress(Zcl, "Received RemoveAllScenesResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnTestClusterListStructOctetStringListAttributeResponse(void * context, uint16_t count, _TestListStructOctet * entries) +static void +OnScenesRemoveSceneResponseSuccess(void * context, + const chip::app::Clusters::Scenes::Commands::RemoveSceneResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnTestClusterListStructOctetStringListAttributeResponse: %" PRIu16 " entries", count); + ChipLogProgress(Zcl, "Received RemoveSceneResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); + ChipLogProgress(Zcl, " sceneId: %" PRIu8 "", data.sceneId); - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "TestListStructOctet[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " fabricIndex: %" PRIu64 "", entries[i].fabricIndex); - ChipLogProgress(Zcl, " operationalCert: %zu", entries[i].operationalCert.size()); - } + ModelCommand * command = static_cast(context); + command->SetCommandExitStatus(CHIP_NO_ERROR); +}; + +static void OnScenesStoreSceneResponseSuccess(void * context, + const chip::app::Clusters::Scenes::Commands::StoreSceneResponse::DecodableType & data) +{ + ChipLogProgress(Zcl, "Received StoreSceneResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); + ChipLogProgress(Zcl, " sceneId: %" PRIu8 "", data.sceneId); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnThreadNetworkDiagnosticsNeighborTableListListAttributeResponse(void * context, uint16_t count, - _NeighborTable * entries) +static void OnScenesViewSceneResponseSuccess(void * context, + const chip::app::Clusters::Scenes::Commands::ViewSceneResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsNeighborTableListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "NeighborTable[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " ExtAddress: %" PRIu64 "", entries[i].ExtAddress); - ChipLogProgress(chipTool, " Age: %" PRIu32 "", entries[i].Age); - ChipLogProgress(chipTool, " Rloc16: %" PRIu16 "", entries[i].Rloc16); - ChipLogProgress(chipTool, " LinkFrameCounter: %" PRIu32 "", entries[i].LinkFrameCounter); - ChipLogProgress(chipTool, " MleFrameCounter: %" PRIu32 "", entries[i].MleFrameCounter); - ChipLogProgress(chipTool, " LQI: %" PRIu8 "", entries[i].LQI); - ChipLogProgress(chipTool, " AverageRssi: %" PRId8 "", entries[i].AverageRssi); - ChipLogProgress(chipTool, " LastRssi: %" PRId8 "", entries[i].LastRssi); - ChipLogProgress(chipTool, " FrameErrorRate: %" PRIu8 "", entries[i].FrameErrorRate); - ChipLogProgress(chipTool, " MessageErrorRate: %" PRIu8 "", entries[i].MessageErrorRate); - ChipLogProgress(chipTool, " RxOnWhenIdle: %d", entries[i].RxOnWhenIdle); - ChipLogProgress(chipTool, " FullThreadDevice: %d", entries[i].FullThreadDevice); - ChipLogProgress(chipTool, " FullNetworkData: %d", entries[i].FullNetworkData); - ChipLogProgress(chipTool, " IsChild: %d", entries[i].IsChild); - } + ChipLogProgress(Zcl, "Received ViewSceneResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " groupId: %" PRIu16 "", data.groupId); + ChipLogProgress(Zcl, " sceneId: %" PRIu8 "", data.sceneId); + ChipLogProgress(Zcl, " transitionTime: %" PRIu16 "", data.transitionTime); + ChipLogProgress(Zcl, " sceneName: %.*s", static_cast(data.sceneName.size()), data.sceneName.data()); + ChipLogProgress(Zcl, " extensionFieldSets: Array printing is not implemented yet."); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnThreadNetworkDiagnosticsRouteTableListListAttributeResponse(void * context, uint16_t count, _RouteTable * entries) +static void +OnTvChannelChangeChannelResponseSuccess(void * context, + const chip::app::Clusters::TvChannel::Commands::ChangeChannelResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsRouteTableListListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "RouteTable[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " ExtAddress: %" PRIu64 "", entries[i].ExtAddress); - ChipLogProgress(chipTool, " Rloc16: %" PRIu16 "", entries[i].Rloc16); - ChipLogProgress(chipTool, " RouterId: %" PRIu8 "", entries[i].RouterId); - ChipLogProgress(chipTool, " NextHop: %" PRIu8 "", entries[i].NextHop); - ChipLogProgress(chipTool, " PathCost: %" PRIu8 "", entries[i].PathCost); - ChipLogProgress(chipTool, " LQIIn: %" PRIu8 "", entries[i].LQIIn); - ChipLogProgress(chipTool, " LQIOut: %" PRIu8 "", entries[i].LQIOut); - ChipLogProgress(chipTool, " Age: %" PRIu8 "", entries[i].Age); - ChipLogProgress(chipTool, " Allocated: %d", entries[i].Allocated); - ChipLogProgress(chipTool, " LinkEstablished: %d", entries[i].LinkEstablished); - } + ChipLogProgress(Zcl, "Received ChangeChannelResponse:"); + ChipLogProgress(Zcl, " ChannelMatch: Array printing is not implemented yet."); + ChipLogProgress(Zcl, " ErrorType: %" PRIu8 "", data.errorType); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnThreadNetworkDiagnosticsSecurityPolicyListAttributeResponse(void * context, uint16_t count, _SecurityPolicy * entries) +static void OnTargetNavigatorNavigateTargetResponseSuccess( + void * context, const chip::app::Clusters::TargetNavigator::Commands::NavigateTargetResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsSecurityPolicyListAttributeResponse: %" PRIu16 " entries", count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "SecurityPolicy[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " RotationTime: %" PRIu16 "", entries[i].RotationTime); - ChipLogProgress(chipTool, " Flags: %" PRIu16 "", entries[i].Flags); - } + ChipLogProgress(Zcl, "Received NavigateTargetResponse:"); + ChipLogProgress(Zcl, " status: %" PRIu8 "", data.status); + ChipLogProgress(Zcl, " data: %.*s", static_cast(data.data.size()), data.data.data()); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnThreadNetworkDiagnosticsOperationalDatasetComponentsListAttributeResponse(void * context, uint16_t count, - _OperationalDatasetComponents * entries) +static void OnTestClusterTestAddArgumentsResponseSuccess( + void * context, const chip::app::Clusters::TestCluster::Commands::TestAddArgumentsResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsOperationalDatasetComponentsListAttributeResponse: %" PRIu16 " entries", - count); - - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "OperationalDatasetComponents[%" PRIu16 "]:", i); - ChipLogProgress(chipTool, " ActiveTimestampPresent: %d", entries[i].ActiveTimestampPresent); - ChipLogProgress(chipTool, " PendingTimestampPresent: %d", entries[i].PendingTimestampPresent); - ChipLogProgress(chipTool, " MasterKeyPresent: %d", entries[i].MasterKeyPresent); - ChipLogProgress(chipTool, " NetworkNamePresent: %d", entries[i].NetworkNamePresent); - ChipLogProgress(chipTool, " ExtendedPanIdPresent: %d", entries[i].ExtendedPanIdPresent); - ChipLogProgress(chipTool, " MeshLocalPrefixPresent: %d", entries[i].MeshLocalPrefixPresent); - ChipLogProgress(chipTool, " DelayPresent: %d", entries[i].DelayPresent); - ChipLogProgress(chipTool, " PanIdPresent: %d", entries[i].PanIdPresent); - ChipLogProgress(chipTool, " ChannelPresent: %d", entries[i].ChannelPresent); - ChipLogProgress(chipTool, " PskcPresent: %d", entries[i].PskcPresent); - ChipLogProgress(chipTool, " SecurityPolicyPresent: %d", entries[i].SecurityPolicyPresent); - ChipLogProgress(chipTool, " ChannelMaskPresent: %d", entries[i].ChannelMaskPresent); - } + ChipLogProgress(Zcl, "Received TestAddArgumentsResponse:"); + ChipLogProgress(Zcl, " returnValue: %" PRIu8 "", data.returnValue); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; -static void OnThreadNetworkDiagnosticsActiveNetworkFaultsListListAttributeResponse(void * context, uint16_t count, - uint8_t * entries) +static void OnTestClusterTestListInt8UReverseResponseSuccess( + void * context, const chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseResponse::DecodableType & data) { - ChipLogProgress(chipTool, "OnThreadNetworkDiagnosticsActiveNetworkFaultsListListAttributeResponse: %" PRIu16 " entries", count); + ChipLogProgress(Zcl, "Received TestListInt8UReverseResponse:"); + ChipLogProgress(Zcl, " arg1: Array printing is not implemented yet."); - for (uint16_t i = 0; i < count; i++) - { - ChipLogProgress(chipTool, "NetworkFault[%" PRIu16 "]: %" PRIu8 "", i, entries[i]); - } + ModelCommand * command = static_cast(context); + command->SetCommandExitStatus(CHIP_NO_ERROR); +}; + +static void OnTestClusterTestSpecificResponseSuccess( + void * context, const chip::app::Clusters::TestCluster::Commands::TestSpecificResponse::DecodableType & data) +{ + ChipLogProgress(Zcl, "Received TestSpecificResponse:"); + ChipLogProgress(Zcl, " returnValue: %" PRIu8 "", data.returnValue); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); -} +}; /*----------------------------------------------------------------------------*\ | Cluster Name | ID | @@ -1241,31 +1471,21 @@ class AccountLoginGetSetupPIN : public ModelCommand public: AccountLoginGetSetupPIN() : ModelCommand("get-setup-pin") { - AddArgument("TempAccountIdentifier", &mTempAccountIdentifier); + AddArgument("TempAccountIdentifier", &mRequest.tempAccountIdentifier); ModelCommand::AddArguments(); } - ~AccountLoginGetSetupPIN() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050E) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050E) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::AccountLoginCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetSetupPIN(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mTempAccountIdentifier); + return cluster.InvokeCommand(mRequest, this, OnAccountLoginGetSetupPINResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnAccountLoginClusterGetSetupPINResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mTempAccountIdentifier; + chip::app::Clusters::AccountLogin::Commands::GetSetupPIN::Type mRequest; }; /* @@ -1276,32 +1496,22 @@ class AccountLoginLogin : public ModelCommand public: AccountLoginLogin() : ModelCommand("login") { - AddArgument("TempAccountIdentifier", &mTempAccountIdentifier); - AddArgument("SetupPIN", &mSetupPIN); + AddArgument("TempAccountIdentifier", &mRequest.tempAccountIdentifier); + AddArgument("SetupPIN", &mRequest.setupPIN); ModelCommand::AddArguments(); } - ~AccountLoginLogin() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050E) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050E) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::AccountLoginCluster cluster; cluster.Associate(device, endpointId); - return cluster.Login(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mTempAccountIdentifier, mSetupPIN); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mTempAccountIdentifier; - chip::ByteSpan mSetupPIN; + chip::app::Clusters::AccountLogin::Commands::Login::Type mRequest; }; /* @@ -1358,31 +1568,21 @@ class AdministratorCommissioningOpenBasicCommissioningWindow : public ModelComma public: AdministratorCommissioningOpenBasicCommissioningWindow() : ModelCommand("open-basic-commissioning-window") { - AddArgument("CommissioningTimeout", 0, UINT16_MAX, &mCommissioningTimeout); + AddArgument("CommissioningTimeout", 0, UINT16_MAX, &mRequest.commissioningTimeout); ModelCommand::AddArguments(); } - ~AdministratorCommissioningOpenBasicCommissioningWindow() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003C) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003C) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::AdministratorCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.OpenBasicCommissioningWindow(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), - mCommissioningTimeout); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mCommissioningTimeout; + chip::app::Clusters::AdministratorCommissioning::Commands::OpenBasicCommissioningWindow::Type mRequest; }; /* @@ -1393,41 +1593,26 @@ class AdministratorCommissioningOpenCommissioningWindow : public ModelCommand public: AdministratorCommissioningOpenCommissioningWindow() : ModelCommand("open-commissioning-window") { - AddArgument("CommissioningTimeout", 0, UINT16_MAX, &mCommissioningTimeout); - AddArgument("PAKEVerifier", &mPAKEVerifier); - AddArgument("Discriminator", 0, UINT16_MAX, &mDiscriminator); - AddArgument("Iterations", 0, UINT32_MAX, &mIterations); - AddArgument("Salt", &mSalt); - AddArgument("PasscodeID", 0, UINT16_MAX, &mPasscodeID); + AddArgument("CommissioningTimeout", 0, UINT16_MAX, &mRequest.commissioningTimeout); + AddArgument("PAKEVerifier", &mRequest.PAKEVerifier); + AddArgument("Discriminator", 0, UINT16_MAX, &mRequest.discriminator); + AddArgument("Iterations", 0, UINT32_MAX, &mRequest.iterations); + AddArgument("Salt", &mRequest.salt); + AddArgument("PasscodeID", 0, UINT16_MAX, &mRequest.passcodeID); ModelCommand::AddArguments(); } - ~AdministratorCommissioningOpenCommissioningWindow() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003C) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003C) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::AdministratorCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.OpenCommissioningWindow(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mCommissioningTimeout, - mPAKEVerifier, mDiscriminator, mIterations, mSalt, mPasscodeID); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mCommissioningTimeout; - chip::ByteSpan mPAKEVerifier; - uint16_t mDiscriminator; - uint32_t mIterations; - chip::ByteSpan mSalt; - uint16_t mPasscodeID; + chip::app::Clusters::AdministratorCommissioning::Commands::OpenCommissioningWindow::Type mRequest; }; /* @@ -1437,26 +1622,18 @@ class AdministratorCommissioningRevokeCommissioning : public ModelCommand { public: AdministratorCommissioningRevokeCommissioning() : ModelCommand("revoke-commissioning") { ModelCommand::AddArguments(); } - ~AdministratorCommissioningRevokeCommissioning() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003C) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003C) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::AdministratorCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.RevokeCommissioning(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::AdministratorCommissioning::Commands::RevokeCommissioning::Type mRequest; }; /* @@ -1518,30 +1695,22 @@ class ApplicationBasicChangeStatus : public ModelCommand public: ApplicationBasicChangeStatus() : ModelCommand("change-status") { - AddArgument("Status", 0, UINT8_MAX, &mStatus); + AddArgument("Status", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.status)); ModelCommand::AddArguments(); } - ~ApplicationBasicChangeStatus() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050D) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050D) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::ApplicationBasicCluster cluster; cluster.Associate(device, endpointId); - return cluster.ChangeStatus(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStatus); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mStatus; + chip::app::Clusters::ApplicationBasic::Commands::ChangeStatus::Type mRequest; }; /* @@ -1837,35 +2006,23 @@ class ApplicationLauncherLaunchApp : public ModelCommand public: ApplicationLauncherLaunchApp() : ModelCommand("launch-app") { - AddArgument("Data", &mData); - AddArgument("CatalogVendorId", 0, UINT16_MAX, &mCatalogVendorId); - AddArgument("ApplicationId", &mApplicationId); + AddArgument("Data", &mRequest.data); + AddArgument("CatalogVendorId", 0, UINT16_MAX, &mRequest.catalogVendorId); + AddArgument("ApplicationId", &mRequest.applicationId); ModelCommand::AddArguments(); } - ~ApplicationLauncherLaunchApp() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050C) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050C) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::ApplicationLauncherCluster cluster; cluster.Associate(device, endpointId); - return cluster.LaunchApp(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mData, mCatalogVendorId, mApplicationId); + return cluster.InvokeCommand(mRequest, this, OnApplicationLauncherLaunchAppResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnApplicationLauncherClusterLaunchAppResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mData; - uint16_t mCatalogVendorId; - chip::ByteSpan mApplicationId; + chip::app::Clusters::ApplicationLauncher::Commands::LaunchApp::Type mRequest; }; /* @@ -2026,32 +2183,22 @@ class AudioOutputRenameOutput : public ModelCommand public: AudioOutputRenameOutput() : ModelCommand("rename-output") { - AddArgument("Index", 0, UINT8_MAX, &mIndex); - AddArgument("Name", &mName); + AddArgument("Index", 0, UINT8_MAX, &mRequest.index); + AddArgument("Name", &mRequest.name); ModelCommand::AddArguments(); } - ~AudioOutputRenameOutput() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050B) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050B) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::AudioOutputCluster cluster; cluster.Associate(device, endpointId); - return cluster.RenameOutput(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mIndex, mName); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mIndex; - chip::ByteSpan mName; + chip::app::Clusters::AudioOutput::Commands::RenameOutput::Type mRequest; }; /* @@ -2062,30 +2209,21 @@ class AudioOutputSelectOutput : public ModelCommand public: AudioOutputSelectOutput() : ModelCommand("select-output") { - AddArgument("Index", 0, UINT8_MAX, &mIndex); + AddArgument("Index", 0, UINT8_MAX, &mRequest.index); ModelCommand::AddArguments(); } - ~AudioOutputSelectOutput() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050B) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050B) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::AudioOutputCluster cluster; cluster.Associate(device, endpointId); - return cluster.SelectOutput(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mIndex); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mIndex; + chip::app::Clusters::AudioOutput::Commands::SelectOutput::Type mRequest; }; /* @@ -2214,30 +2352,21 @@ class BarrierControlBarrierControlGoToPercent : public ModelCommand public: BarrierControlBarrierControlGoToPercent() : ModelCommand("barrier-control-go-to-percent") { - AddArgument("PercentOpen", 0, UINT8_MAX, &mPercentOpen); + AddArgument("PercentOpen", 0, UINT8_MAX, &mRequest.percentOpen); ModelCommand::AddArguments(); } - ~BarrierControlBarrierControlGoToPercent() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0103) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000103) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::BarrierControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.BarrierControlGoToPercent(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mPercentOpen); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mPercentOpen; + chip::app::Clusters::BarrierControl::Commands::BarrierControlGoToPercent::Type mRequest; }; /* @@ -2247,26 +2376,18 @@ class BarrierControlBarrierControlStop : public ModelCommand { public: BarrierControlBarrierControlStop() : ModelCommand("barrier-control-stop") { ModelCommand::AddArguments(); } - ~BarrierControlBarrierControlStop() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0103) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000103) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::BarrierControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.BarrierControlStop(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::BarrierControl::Commands::BarrierControlStop::Type mRequest; }; /* @@ -2474,26 +2595,18 @@ class BasicMfgSpecificPing : public ModelCommand { public: BasicMfgSpecificPing() : ModelCommand("mfg-specific-ping") { ModelCommand::AddArguments(); } - ~BasicMfgSpecificPing() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0028) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000028) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::BasicCluster cluster; cluster.Associate(device, endpointId); - return cluster.MfgSpecificPing(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::Basic::Commands::MfgSpecificPing::Type mRequest; }; /* @@ -3566,36 +3679,24 @@ class BindingBind : public ModelCommand public: BindingBind() : ModelCommand("bind") { - AddArgument("NodeId", 0, UINT64_MAX, &mNodeId); - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("EndpointId", 0, UINT16_MAX, &mEndpointId); - AddArgument("ClusterId", 0, UINT32_MAX, &mClusterId); + AddArgument("NodeId", 0, UINT64_MAX, &mRequest.nodeId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("EndpointId", 0, UINT16_MAX, &mRequest.endpointId); + AddArgument("ClusterId", 0, UINT32_MAX, &mRequest.clusterId); ModelCommand::AddArguments(); } - ~BindingBind() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0xF000) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000F000) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::BindingCluster cluster; cluster.Associate(device, endpointId); - return cluster.Bind(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNodeId, mGroupId, mEndpointId, mClusterId); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::NodeId mNodeId; - chip::GroupId mGroupId; - chip::EndpointId mEndpointId; - chip::ClusterId mClusterId; + chip::app::Clusters::Binding::Commands::Bind::Type mRequest; }; /* @@ -3606,36 +3707,24 @@ class BindingUnbind : public ModelCommand public: BindingUnbind() : ModelCommand("unbind") { - AddArgument("NodeId", 0, UINT64_MAX, &mNodeId); - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("EndpointId", 0, UINT16_MAX, &mEndpointId); - AddArgument("ClusterId", 0, UINT32_MAX, &mClusterId); + AddArgument("NodeId", 0, UINT64_MAX, &mRequest.nodeId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("EndpointId", 0, UINT16_MAX, &mRequest.endpointId); + AddArgument("ClusterId", 0, UINT32_MAX, &mRequest.clusterId); ModelCommand::AddArguments(); } - ~BindingUnbind() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0xF000) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000F000) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::BindingCluster cluster; cluster.Associate(device, endpointId); - return cluster.Unbind(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNodeId, mGroupId, mEndpointId, mClusterId); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::NodeId mNodeId; - chip::GroupId mGroupId; - chip::EndpointId mEndpointId; - chip::ClusterId mClusterId; + chip::app::Clusters::Binding::Commands::Unbind::Type mRequest; }; /* @@ -4326,43 +4415,31 @@ class ColorControlColorLoopSet : public ModelCommand public: ColorControlColorLoopSet() : ModelCommand("color-loop-set") { - AddArgument("UpdateFlags", 0, UINT8_MAX, &mUpdateFlags); - AddArgument("Action", 0, UINT8_MAX, &mAction); - AddArgument("Direction", 0, UINT8_MAX, &mDirection); - AddArgument("Time", 0, UINT16_MAX, &mTime); - AddArgument("StartHue", 0, UINT16_MAX, &mStartHue); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("UpdateFlags", 0, UINT8_MAX, + reinterpret_cast *>( + &mRequest.updateFlags)); + AddArgument("Action", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.action)); + AddArgument("Direction", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.direction)); + AddArgument("Time", 0, UINT16_MAX, &mRequest.time); + AddArgument("StartHue", 0, UINT16_MAX, &mRequest.startHue); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlColorLoopSet() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x44) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000044) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.ColorLoopSet(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUpdateFlags, mAction, mDirection, - mTime, mStartHue, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mUpdateFlags; - uint8_t mAction; - uint8_t mDirection; - uint16_t mTime; - uint16_t mStartHue; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type mRequest; }; /* @@ -4373,37 +4450,25 @@ class ColorControlEnhancedMoveHue : public ModelCommand public: ColorControlEnhancedMoveHue() : ModelCommand("enhanced-move-hue") { - AddArgument("MoveMode", 0, UINT8_MAX, &mMoveMode); - AddArgument("Rate", 0, UINT16_MAX, &mRate); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("MoveMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.moveMode)); + AddArgument("Rate", 0, UINT16_MAX, &mRequest.rate); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlEnhancedMoveHue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x41) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000041) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.EnhancedMoveHue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMoveMode, mRate, mOptionsMask, - mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mMoveMode; - uint16_t mRate; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type mRequest; }; /* @@ -4414,39 +4479,26 @@ class ColorControlEnhancedMoveToHue : public ModelCommand public: ColorControlEnhancedMoveToHue() : ModelCommand("enhanced-move-to-hue") { - AddArgument("EnhancedHue", 0, UINT16_MAX, &mEnhancedHue); - AddArgument("Direction", 0, UINT8_MAX, &mDirection); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("EnhancedHue", 0, UINT16_MAX, &mRequest.enhancedHue); + AddArgument("Direction", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.direction)); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlEnhancedMoveToHue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x40) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000040) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.EnhancedMoveToHue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mEnhancedHue, mDirection, - mTransitionTime, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mEnhancedHue; - uint8_t mDirection; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHue::Type mRequest; }; /* @@ -4457,39 +4509,25 @@ class ColorControlEnhancedMoveToHueAndSaturation : public ModelCommand public: ColorControlEnhancedMoveToHueAndSaturation() : ModelCommand("enhanced-move-to-hue-and-saturation") { - AddArgument("EnhancedHue", 0, UINT16_MAX, &mEnhancedHue); - AddArgument("Saturation", 0, UINT8_MAX, &mSaturation); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("EnhancedHue", 0, UINT16_MAX, &mRequest.enhancedHue); + AddArgument("Saturation", 0, UINT8_MAX, &mRequest.saturation); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlEnhancedMoveToHueAndSaturation() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x43) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000043) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.EnhancedMoveToHueAndSaturation(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mEnhancedHue, - mSaturation, mTransitionTime, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mEnhancedHue; - uint8_t mSaturation; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHueAndSaturation::Type mRequest; }; /* @@ -4500,39 +4538,26 @@ class ColorControlEnhancedStepHue : public ModelCommand public: ColorControlEnhancedStepHue() : ModelCommand("enhanced-step-hue") { - AddArgument("StepMode", 0, UINT8_MAX, &mStepMode); - AddArgument("StepSize", 0, UINT16_MAX, &mStepSize); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("StepMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.stepMode)); + AddArgument("StepSize", 0, UINT16_MAX, &mRequest.stepSize); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlEnhancedStepHue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x42) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000042) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.EnhancedStepHue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStepMode, mStepSize, - mTransitionTime, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mStepMode; - uint16_t mStepSize; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type mRequest; }; /* @@ -4543,37 +4568,24 @@ class ColorControlMoveColor : public ModelCommand public: ColorControlMoveColor() : ModelCommand("move-color") { - AddArgument("RateX", INT16_MIN, INT16_MAX, &mRateX); - AddArgument("RateY", INT16_MIN, INT16_MAX, &mRateY); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); - ModelCommand::AddArguments(); - } - ~ColorControlMoveColor() - { - delete onSuccessCallback; - delete onFailureCallback; + AddArgument("RateX", INT16_MIN, INT16_MAX, &mRequest.rateX); + AddArgument("RateY", INT16_MIN, INT16_MAX, &mRequest.rateY); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); + ModelCommand::AddArguments(); } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x08) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000008) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveColor(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mRateX, mRateY, mOptionsMask, - mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - int16_t mRateX; - int16_t mRateY; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveColor::Type mRequest; }; /* @@ -4584,41 +4596,27 @@ class ColorControlMoveColorTemperature : public ModelCommand public: ColorControlMoveColorTemperature() : ModelCommand("move-color-temperature") { - AddArgument("MoveMode", 0, UINT8_MAX, &mMoveMode); - AddArgument("Rate", 0, UINT16_MAX, &mRate); - AddArgument("ColorTemperatureMinimum", 0, UINT16_MAX, &mColorTemperatureMinimum); - AddArgument("ColorTemperatureMaximum", 0, UINT16_MAX, &mColorTemperatureMaximum); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("MoveMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.moveMode)); + AddArgument("Rate", 0, UINT16_MAX, &mRequest.rate); + AddArgument("ColorTemperatureMinimum", 0, UINT16_MAX, &mRequest.colorTemperatureMinimum); + AddArgument("ColorTemperatureMaximum", 0, UINT16_MAX, &mRequest.colorTemperatureMaximum); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveColorTemperature() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x4B) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x0000004B) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveColorTemperature(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMoveMode, mRate, - mColorTemperatureMinimum, mColorTemperatureMaximum, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mMoveMode; - uint16_t mRate; - uint16_t mColorTemperatureMinimum; - uint16_t mColorTemperatureMaximum; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type mRequest; }; /* @@ -4629,37 +4627,25 @@ class ColorControlMoveHue : public ModelCommand public: ColorControlMoveHue() : ModelCommand("move-hue") { - AddArgument("MoveMode", 0, UINT8_MAX, &mMoveMode); - AddArgument("Rate", 0, UINT8_MAX, &mRate); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("MoveMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.moveMode)); + AddArgument("Rate", 0, UINT8_MAX, &mRequest.rate); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveHue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveHue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMoveMode, mRate, mOptionsMask, - mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mMoveMode; - uint8_t mRate; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveHue::Type mRequest; }; /* @@ -4670,37 +4656,25 @@ class ColorControlMoveSaturation : public ModelCommand public: ColorControlMoveSaturation() : ModelCommand("move-saturation") { - AddArgument("MoveMode", 0, UINT8_MAX, &mMoveMode); - AddArgument("Rate", 0, UINT8_MAX, &mRate); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("MoveMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.moveMode)); + AddArgument("Rate", 0, UINT8_MAX, &mRequest.rate); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveSaturation() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveSaturation(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMoveMode, mRate, mOptionsMask, - mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mMoveMode; - uint8_t mRate; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type mRequest; }; /* @@ -4711,39 +4685,25 @@ class ColorControlMoveToColor : public ModelCommand public: ColorControlMoveToColor() : ModelCommand("move-to-color") { - AddArgument("ColorX", 0, UINT16_MAX, &mColorX); - AddArgument("ColorY", 0, UINT16_MAX, &mColorY); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("ColorX", 0, UINT16_MAX, &mRequest.colorX); + AddArgument("ColorY", 0, UINT16_MAX, &mRequest.colorY); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveToColor() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x07) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000007) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveToColor(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mColorX, mColorY, mTransitionTime, - mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mColorX; - uint16_t mColorY; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveToColor::Type mRequest; }; /* @@ -4754,37 +4714,24 @@ class ColorControlMoveToColorTemperature : public ModelCommand public: ColorControlMoveToColorTemperature() : ModelCommand("move-to-color-temperature") { - AddArgument("ColorTemperature", 0, UINT16_MAX, &mColorTemperature); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("ColorTemperature", 0, UINT16_MAX, &mRequest.colorTemperature); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveToColorTemperature() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x0A) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x0000000A) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveToColorTemperature(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mColorTemperature, - mTransitionTime, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mColorTemperature; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveToColorTemperature::Type mRequest; }; /* @@ -4795,39 +4742,26 @@ class ColorControlMoveToHue : public ModelCommand public: ColorControlMoveToHue() : ModelCommand("move-to-hue") { - AddArgument("Hue", 0, UINT8_MAX, &mHue); - AddArgument("Direction", 0, UINT8_MAX, &mDirection); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("Hue", 0, UINT8_MAX, &mRequest.hue); + AddArgument("Direction", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.direction)); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveToHue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveToHue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mHue, mDirection, mTransitionTime, - mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mHue; - uint8_t mDirection; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveToHue::Type mRequest; }; /* @@ -4838,39 +4772,25 @@ class ColorControlMoveToHueAndSaturation : public ModelCommand public: ColorControlMoveToHueAndSaturation() : ModelCommand("move-to-hue-and-saturation") { - AddArgument("Hue", 0, UINT8_MAX, &mHue); - AddArgument("Saturation", 0, UINT8_MAX, &mSaturation); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("Hue", 0, UINT8_MAX, &mRequest.hue); + AddArgument("Saturation", 0, UINT8_MAX, &mRequest.saturation); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveToHueAndSaturation() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x06) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000006) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveToHueAndSaturation(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mHue, mSaturation, - mTransitionTime, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mHue; - uint8_t mSaturation; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveToHueAndSaturation::Type mRequest; }; /* @@ -4881,37 +4801,24 @@ class ColorControlMoveToSaturation : public ModelCommand public: ColorControlMoveToSaturation() : ModelCommand("move-to-saturation") { - AddArgument("Saturation", 0, UINT8_MAX, &mSaturation); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("Saturation", 0, UINT8_MAX, &mRequest.saturation); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlMoveToSaturation() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveToSaturation(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mSaturation, mTransitionTime, - mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mSaturation; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::MoveToSaturation::Type mRequest; }; /* @@ -4922,39 +4829,25 @@ class ColorControlStepColor : public ModelCommand public: ColorControlStepColor() : ModelCommand("step-color") { - AddArgument("StepX", INT16_MIN, INT16_MAX, &mStepX); - AddArgument("StepY", INT16_MIN, INT16_MAX, &mStepY); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("StepX", INT16_MIN, INT16_MAX, &mRequest.stepX); + AddArgument("StepY", INT16_MIN, INT16_MAX, &mRequest.stepY); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlStepColor() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x09) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000009) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.StepColor(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStepX, mStepY, mTransitionTime, - mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - int16_t mStepX; - int16_t mStepY; - uint16_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::StepColor::Type mRequest; }; /* @@ -4965,44 +4858,28 @@ class ColorControlStepColorTemperature : public ModelCommand public: ColorControlStepColorTemperature() : ModelCommand("step-color-temperature") { - AddArgument("StepMode", 0, UINT8_MAX, &mStepMode); - AddArgument("StepSize", 0, UINT16_MAX, &mStepSize); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("ColorTemperatureMinimum", 0, UINT16_MAX, &mColorTemperatureMinimum); - AddArgument("ColorTemperatureMaximum", 0, UINT16_MAX, &mColorTemperatureMaximum); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("StepMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.stepMode)); + AddArgument("StepSize", 0, UINT16_MAX, &mRequest.stepSize); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("ColorTemperatureMinimum", 0, UINT16_MAX, &mRequest.colorTemperatureMinimum); + AddArgument("ColorTemperatureMaximum", 0, UINT16_MAX, &mRequest.colorTemperatureMaximum); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlStepColorTemperature() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x4C) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x0000004C) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.StepColorTemperature(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStepMode, mStepSize, - mTransitionTime, mColorTemperatureMinimum, mColorTemperatureMaximum, mOptionsMask, - mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mStepMode; - uint16_t mStepSize; - uint16_t mTransitionTime; - uint16_t mColorTemperatureMinimum; - uint16_t mColorTemperatureMaximum; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type mRequest; }; /* @@ -5013,39 +4890,26 @@ class ColorControlStepHue : public ModelCommand public: ColorControlStepHue() : ModelCommand("step-hue") { - AddArgument("StepMode", 0, UINT8_MAX, &mStepMode); - AddArgument("StepSize", 0, UINT8_MAX, &mStepSize); - AddArgument("TransitionTime", 0, UINT8_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("StepMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.stepMode)); + AddArgument("StepSize", 0, UINT8_MAX, &mRequest.stepSize); + AddArgument("TransitionTime", 0, UINT8_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlStepHue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.StepHue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStepMode, mStepSize, mTransitionTime, - mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mStepMode; - uint8_t mStepSize; - uint8_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::StepHue::Type mRequest; }; /* @@ -5056,39 +4920,26 @@ class ColorControlStepSaturation : public ModelCommand public: ColorControlStepSaturation() : ModelCommand("step-saturation") { - AddArgument("StepMode", 0, UINT8_MAX, &mStepMode); - AddArgument("StepSize", 0, UINT8_MAX, &mStepSize); - AddArgument("TransitionTime", 0, UINT8_MAX, &mTransitionTime); - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("StepMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.stepMode)); + AddArgument("StepSize", 0, UINT8_MAX, &mRequest.stepSize); + AddArgument("TransitionTime", 0, UINT8_MAX, &mRequest.transitionTime); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlStepSaturation() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x05) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000005) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.StepSaturation(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStepMode, mStepSize, - mTransitionTime, mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mStepMode; - uint8_t mStepSize; - uint8_t mTransitionTime; - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::StepSaturation::Type mRequest; }; /* @@ -5099,32 +4950,22 @@ class ColorControlStopMoveStep : public ModelCommand public: ColorControlStopMoveStep() : ModelCommand("stop-move-step") { - AddArgument("OptionsMask", 0, UINT8_MAX, &mOptionsMask); - AddArgument("OptionsOverride", 0, UINT8_MAX, &mOptionsOverride); + AddArgument("OptionsMask", 0, UINT8_MAX, &mRequest.optionsMask); + AddArgument("OptionsOverride", 0, UINT8_MAX, &mRequest.optionsOverride); ModelCommand::AddArguments(); } - ~ColorControlStopMoveStep() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0300) command (0x47) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000300) command (0x00000047) on endpoint %" PRIu8, endpointId); chip::Controller::ColorControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.StopMoveStep(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mOptionsMask, mOptionsOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mOptionsMask; - uint8_t mOptionsOverride; + chip::app::Clusters::ColorControl::Commands::StopMoveStep::Type mRequest; }; /* @@ -7610,33 +7451,22 @@ class ContentLauncherLaunchContent : public ModelCommand public: ContentLauncherLaunchContent() : ModelCommand("launch-content") { - AddArgument("AutoPlay", 0, 1, &mAutoPlay); - AddArgument("Data", &mData); + AddArgument("AutoPlay", 0, 1, &mRequest.autoPlay); + AddArgument("Data", &mRequest.data); ModelCommand::AddArguments(); } - ~ContentLauncherLaunchContent() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050A) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050A) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::ContentLauncherCluster cluster; cluster.Associate(device, endpointId); - return cluster.LaunchContent(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mAutoPlay, mData); + return cluster.InvokeCommand(mRequest, this, OnContentLauncherLaunchContentResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnContentLauncherClusterLaunchContentResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - bool mAutoPlay; - chip::ByteSpan mData; + chip::app::Clusters::ContentLauncher::Commands::LaunchContent::Type mRequest; }; /* @@ -7647,33 +7477,22 @@ class ContentLauncherLaunchURL : public ModelCommand public: ContentLauncherLaunchURL() : ModelCommand("launch-url") { - AddArgument("ContentURL", &mContentURL); - AddArgument("DisplayString", &mDisplayString); + AddArgument("ContentURL", &mRequest.contentURL); + AddArgument("DisplayString", &mRequest.displayString); ModelCommand::AddArguments(); } - ~ContentLauncherLaunchURL() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050A) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050A) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::ContentLauncherCluster cluster; cluster.Associate(device, endpointId); - return cluster.LaunchURL(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mContentURL, mDisplayString); + return cluster.InvokeCommand(mRequest, this, OnContentLauncherLaunchURLResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnContentLauncherClusterLaunchURLResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mContentURL; - chip::ByteSpan mDisplayString; + chip::app::Clusters::ContentLauncher::Commands::LaunchURL::Type mRequest; }; /* @@ -7980,35 +7799,25 @@ class DiagnosticLogsRetrieveLogsRequest : public ModelCommand public: DiagnosticLogsRetrieveLogsRequest() : ModelCommand("retrieve-logs-request") { - AddArgument("Intent", 0, UINT8_MAX, &mIntent); - AddArgument("RequestedProtocol", 0, UINT8_MAX, &mRequestedProtocol); - AddArgument("TransferFileDesignator", &mTransferFileDesignator); + AddArgument("Intent", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.intent)); + AddArgument("RequestedProtocol", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.requestedProtocol)); + AddArgument("TransferFileDesignator", &mRequest.transferFileDesignator); ModelCommand::AddArguments(); } - ~DiagnosticLogsRetrieveLogsRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0032) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000032) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::DiagnosticLogsCluster cluster; cluster.Associate(device, endpointId); - return cluster.RetrieveLogsRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mIntent, mRequestedProtocol, - mTransferFileDesignator); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mIntent; - uint8_t mRequestedProtocol; - chip::ByteSpan mTransferFileDesignator; + chip::app::Clusters::DiagnosticLogs::Commands::RetrieveLogsRequest::Type mRequest; }; /*----------------------------------------------------------------------------*\ @@ -8053,26 +7862,18 @@ class DoorLockClearAllPins : public ModelCommand { public: DoorLockClearAllPins() : ModelCommand("clear-all-pins") { ModelCommand::AddArguments(); } - ~DoorLockClearAllPins() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x08) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000008) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearAllPins(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDoorLockClearAllPinsResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterClearAllPinsResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::DoorLock::Commands::ClearAllPins::Type mRequest; }; /* @@ -8082,26 +7883,18 @@ class DoorLockClearAllRfids : public ModelCommand { public: DoorLockClearAllRfids() : ModelCommand("clear-all-rfids") { ModelCommand::AddArguments(); } - ~DoorLockClearAllRfids() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x19) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000019) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearAllRfids(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDoorLockClearAllRfidsResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterClearAllRfidsResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::DoorLock::Commands::ClearAllRfids::Type mRequest; }; /* @@ -8112,31 +7905,21 @@ class DoorLockClearHolidaySchedule : public ModelCommand public: DoorLockClearHolidaySchedule() : ModelCommand("clear-holiday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); ModelCommand::AddArguments(); } - ~DoorLockClearHolidaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x13) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000013) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearHolidaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockClearHolidayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnDoorLockClusterClearHolidayScheduleResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; + chip::app::Clusters::DoorLock::Commands::ClearHolidaySchedule::Type mRequest; }; /* @@ -8147,30 +7930,21 @@ class DoorLockClearPin : public ModelCommand public: DoorLockClearPin() : ModelCommand("clear-pin") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockClearPin() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x07) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000007) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearPin(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockClearPinResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterClearPinResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::ClearPin::Type mRequest; }; /* @@ -8181,30 +7955,21 @@ class DoorLockClearRfid : public ModelCommand public: DoorLockClearRfid() : ModelCommand("clear-rfid") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockClearRfid() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x18) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000018) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearRfid(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockClearRfidResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterClearRfidResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::ClearRfid::Type mRequest; }; /* @@ -8215,33 +7980,22 @@ class DoorLockClearWeekdaySchedule : public ModelCommand public: DoorLockClearWeekdaySchedule() : ModelCommand("clear-weekday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockClearWeekdaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x0D) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x0000000D) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearWeekdaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId, mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockClearWeekdayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnDoorLockClusterClearWeekdayScheduleResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::ClearWeekdaySchedule::Type mRequest; }; /* @@ -8252,33 +8006,22 @@ class DoorLockClearYeardaySchedule : public ModelCommand public: DoorLockClearYeardaySchedule() : ModelCommand("clear-yearday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockClearYeardaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x10) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000010) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearYeardaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId, mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockClearYeardayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnDoorLockClusterClearYeardayScheduleResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::ClearYeardaySchedule::Type mRequest; }; /* @@ -8289,31 +8032,21 @@ class DoorLockGetHolidaySchedule : public ModelCommand public: DoorLockGetHolidaySchedule() : ModelCommand("get-holiday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); ModelCommand::AddArguments(); } - ~DoorLockGetHolidaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x12) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000012) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetHolidaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockGetHolidayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterGetHolidayScheduleResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; + chip::app::Clusters::DoorLock::Commands::GetHolidaySchedule::Type mRequest; }; /* @@ -8324,30 +8057,21 @@ class DoorLockGetLogRecord : public ModelCommand public: DoorLockGetLogRecord() : ModelCommand("get-log-record") { - AddArgument("LogIndex", 0, UINT16_MAX, &mLogIndex); + AddArgument("LogIndex", 0, UINT16_MAX, &mRequest.logIndex); ModelCommand::AddArguments(); } - ~DoorLockGetLogRecord() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetLogRecord(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mLogIndex); + return cluster.InvokeCommand(mRequest, this, OnDoorLockGetLogRecordResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterGetLogRecordResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mLogIndex; + chip::app::Clusters::DoorLock::Commands::GetLogRecord::Type mRequest; }; /* @@ -8358,30 +8082,21 @@ class DoorLockGetPin : public ModelCommand public: DoorLockGetPin() : ModelCommand("get-pin") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockGetPin() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x06) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000006) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetPin(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockGetPinResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterGetPinResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::GetPin::Type mRequest; }; /* @@ -8392,30 +8107,21 @@ class DoorLockGetRfid : public ModelCommand public: DoorLockGetRfid() : ModelCommand("get-rfid") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockGetRfid() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x17) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000017) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetRfid(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockGetRfidResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterGetRfidResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::GetRfid::Type mRequest; }; /* @@ -8426,30 +8132,21 @@ class DoorLockGetUserType : public ModelCommand public: DoorLockGetUserType() : ModelCommand("get-user-type") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockGetUserType() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x15) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000015) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetUserType(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockGetUserTypeResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterGetUserTypeResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::GetUserType::Type mRequest; }; /* @@ -8460,33 +8157,22 @@ class DoorLockGetWeekdaySchedule : public ModelCommand public: DoorLockGetWeekdaySchedule() : ModelCommand("get-weekday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockGetWeekdaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x0C) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x0000000C) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetWeekdaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId, mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockGetWeekdayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterGetWeekdayScheduleResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::GetWeekdaySchedule::Type mRequest; }; /* @@ -8497,33 +8183,22 @@ class DoorLockGetYeardaySchedule : public ModelCommand public: DoorLockGetYeardaySchedule() : ModelCommand("get-yearday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); - AddArgument("UserId", 0, UINT16_MAX, &mUserId); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); ModelCommand::AddArguments(); } - ~DoorLockGetYeardaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x0F) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x0000000F) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetYeardaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId, mUserId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockGetYeardayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterGetYeardayScheduleResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; - uint16_t mUserId; + chip::app::Clusters::DoorLock::Commands::GetYeardaySchedule::Type mRequest; }; /* @@ -8534,30 +8209,21 @@ class DoorLockLockDoor : public ModelCommand public: DoorLockLockDoor() : ModelCommand("lock-door") { - AddArgument("Pin", &mPin); + AddArgument("Pin", &mRequest.pin); ModelCommand::AddArguments(); } - ~DoorLockLockDoor() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.LockDoor(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mPin); + return cluster.InvokeCommand(mRequest, this, OnDoorLockLockDoorResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterLockDoorResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mPin; + chip::app::Clusters::DoorLock::Commands::LockDoor::Type mRequest; }; /* @@ -8568,38 +8234,24 @@ class DoorLockSetHolidaySchedule : public ModelCommand public: DoorLockSetHolidaySchedule() : ModelCommand("set-holiday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); - AddArgument("LocalStartTime", 0, UINT32_MAX, &mLocalStartTime); - AddArgument("LocalEndTime", 0, UINT32_MAX, &mLocalEndTime); - AddArgument("OperatingModeDuringHoliday", 0, UINT8_MAX, &mOperatingModeDuringHoliday); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); + AddArgument("LocalStartTime", 0, UINT32_MAX, &mRequest.localStartTime); + AddArgument("LocalEndTime", 0, UINT32_MAX, &mRequest.localEndTime); + AddArgument("OperatingModeDuringHoliday", 0, UINT8_MAX, &mRequest.operatingModeDuringHoliday); ModelCommand::AddArguments(); } - ~DoorLockSetHolidaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x11) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000011) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetHolidaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId, mLocalStartTime, - mLocalEndTime, mOperatingModeDuringHoliday); + return cluster.InvokeCommand(mRequest, this, OnDoorLockSetHolidayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterSetHolidayScheduleResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; - uint32_t mLocalStartTime; - uint32_t mLocalEndTime; - uint8_t mOperatingModeDuringHoliday; + chip::app::Clusters::DoorLock::Commands::SetHolidaySchedule::Type mRequest; }; /* @@ -8610,36 +8262,26 @@ class DoorLockSetPin : public ModelCommand public: DoorLockSetPin() : ModelCommand("set-pin") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); - AddArgument("UserStatus", 0, UINT8_MAX, &mUserStatus); - AddArgument("UserType", 0, UINT8_MAX, &mUserType); - AddArgument("Pin", &mPin); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); + AddArgument("UserStatus", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.userStatus)); + AddArgument("UserType", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.userType)); + AddArgument("Pin", &mRequest.pin); ModelCommand::AddArguments(); } - ~DoorLockSetPin() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x05) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000005) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetPin(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId, mUserStatus, mUserType, mPin); + return cluster.InvokeCommand(mRequest, this, OnDoorLockSetPinResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterSetPinResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; - uint8_t mUserStatus; - uint8_t mUserType; - chip::ByteSpan mPin; + chip::app::Clusters::DoorLock::Commands::SetPin::Type mRequest; }; /* @@ -8650,36 +8292,26 @@ class DoorLockSetRfid : public ModelCommand public: DoorLockSetRfid() : ModelCommand("set-rfid") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); - AddArgument("UserStatus", 0, UINT8_MAX, &mUserStatus); - AddArgument("UserType", 0, UINT8_MAX, &mUserType); - AddArgument("Id", &mId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); + AddArgument("UserStatus", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.userStatus)); + AddArgument("UserType", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.userType)); + AddArgument("Id", &mRequest.id); ModelCommand::AddArguments(); } - ~DoorLockSetRfid() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x16) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000016) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetRfid(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId, mUserStatus, mUserType, mId); + return cluster.InvokeCommand(mRequest, this, OnDoorLockSetRfidResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterSetRfidResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; - uint8_t mUserStatus; - uint8_t mUserType; - chip::ByteSpan mId; + chip::app::Clusters::DoorLock::Commands::SetRfid::Type mRequest; }; /* @@ -8690,32 +8322,23 @@ class DoorLockSetUserType : public ModelCommand public: DoorLockSetUserType() : ModelCommand("set-user-type") { - AddArgument("UserId", 0, UINT16_MAX, &mUserId); - AddArgument("UserType", 0, UINT8_MAX, &mUserType); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); + AddArgument("UserType", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.userType)); ModelCommand::AddArguments(); } - ~DoorLockSetUserType() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x14) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000014) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetUserType(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUserId, mUserType); + return cluster.InvokeCommand(mRequest, this, OnDoorLockSetUserTypeResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterSetUserTypeResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mUserId; - uint8_t mUserType; + chip::app::Clusters::DoorLock::Commands::SetUserType::Type mRequest; }; /* @@ -8726,44 +8349,29 @@ class DoorLockSetWeekdaySchedule : public ModelCommand public: DoorLockSetWeekdaySchedule() : ModelCommand("set-weekday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); - AddArgument("UserId", 0, UINT16_MAX, &mUserId); - AddArgument("DaysMask", 0, UINT8_MAX, &mDaysMask); - AddArgument("StartHour", 0, UINT8_MAX, &mStartHour); - AddArgument("StartMinute", 0, UINT8_MAX, &mStartMinute); - AddArgument("EndHour", 0, UINT8_MAX, &mEndHour); - AddArgument("EndMinute", 0, UINT8_MAX, &mEndMinute); - ModelCommand::AddArguments(); - } - ~DoorLockSetWeekdaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); + AddArgument( + "DaysMask", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.daysMask)); + AddArgument("StartHour", 0, UINT8_MAX, &mRequest.startHour); + AddArgument("StartMinute", 0, UINT8_MAX, &mRequest.startMinute); + AddArgument("EndHour", 0, UINT8_MAX, &mRequest.endHour); + AddArgument("EndMinute", 0, UINT8_MAX, &mRequest.endMinute); + ModelCommand::AddArguments(); } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x0B) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x0000000B) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetWeekdaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId, mUserId, mDaysMask, - mStartHour, mStartMinute, mEndHour, mEndMinute); + return cluster.InvokeCommand(mRequest, this, OnDoorLockSetWeekdayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterSetWeekdayScheduleResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; - uint16_t mUserId; - uint8_t mDaysMask; - uint8_t mStartHour; - uint8_t mStartMinute; - uint8_t mEndHour; - uint8_t mEndMinute; + chip::app::Clusters::DoorLock::Commands::SetWeekdaySchedule::Type mRequest; }; /* @@ -8774,38 +8382,24 @@ class DoorLockSetYeardaySchedule : public ModelCommand public: DoorLockSetYeardaySchedule() : ModelCommand("set-yearday-schedule") { - AddArgument("ScheduleId", 0, UINT8_MAX, &mScheduleId); - AddArgument("UserId", 0, UINT16_MAX, &mUserId); - AddArgument("LocalStartTime", 0, UINT32_MAX, &mLocalStartTime); - AddArgument("LocalEndTime", 0, UINT32_MAX, &mLocalEndTime); + AddArgument("ScheduleId", 0, UINT8_MAX, &mRequest.scheduleId); + AddArgument("UserId", 0, UINT16_MAX, &mRequest.userId); + AddArgument("LocalStartTime", 0, UINT32_MAX, &mRequest.localStartTime); + AddArgument("LocalEndTime", 0, UINT32_MAX, &mRequest.localEndTime); ModelCommand::AddArguments(); } - ~DoorLockSetYeardaySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x0E) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x0000000E) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetYeardaySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mScheduleId, mUserId, - mLocalStartTime, mLocalEndTime); + return cluster.InvokeCommand(mRequest, this, OnDoorLockSetYeardayScheduleResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterSetYeardayScheduleResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mScheduleId; - uint16_t mUserId; - uint32_t mLocalStartTime; - uint32_t mLocalEndTime; + chip::app::Clusters::DoorLock::Commands::SetYeardaySchedule::Type mRequest; }; /* @@ -8816,30 +8410,21 @@ class DoorLockUnlockDoor : public ModelCommand public: DoorLockUnlockDoor() : ModelCommand("unlock-door") { - AddArgument("Pin", &mPin); + AddArgument("Pin", &mRequest.pin); ModelCommand::AddArguments(); } - ~DoorLockUnlockDoor() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.UnlockDoor(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mPin); + return cluster.InvokeCommand(mRequest, this, OnDoorLockUnlockDoorResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterUnlockDoorResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mPin; + chip::app::Clusters::DoorLock::Commands::UnlockDoor::Type mRequest; }; /* @@ -8850,33 +8435,22 @@ class DoorLockUnlockWithTimeout : public ModelCommand public: DoorLockUnlockWithTimeout() : ModelCommand("unlock-with-timeout") { - AddArgument("TimeoutInSeconds", 0, UINT16_MAX, &mTimeoutInSeconds); - AddArgument("Pin", &mPin); + AddArgument("TimeoutInSeconds", 0, UINT16_MAX, &mRequest.timeoutInSeconds); + AddArgument("Pin", &mRequest.pin); ModelCommand::AddArguments(); } - ~DoorLockUnlockWithTimeout() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0101) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000101) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::DoorLockCluster cluster; cluster.Associate(device, endpointId); - return cluster.UnlockWithTimeout(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mTimeoutInSeconds, mPin); + return cluster.InvokeCommand(mRequest, this, OnDoorLockUnlockWithTimeoutResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDoorLockClusterUnlockWithTimeoutResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mTimeoutInSeconds; - chip::ByteSpan mPin; + chip::app::Clusters::DoorLock::Commands::UnlockWithTimeout::Type mRequest; }; /* @@ -9515,26 +9089,18 @@ class EthernetNetworkDiagnosticsResetCounts : public ModelCommand { public: EthernetNetworkDiagnosticsResetCounts() : ModelCommand("reset-counts") { ModelCommand::AddArguments(); } - ~EthernetNetworkDiagnosticsResetCounts() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0037) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000037) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::EthernetNetworkDiagnosticsCluster cluster; cluster.Associate(device, endpointId); - return cluster.ResetCounts(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::EthernetNetworkDiagnostics::Commands::ResetCounts::Type mRequest; }; /* @@ -10125,36 +9691,23 @@ class GeneralCommissioningArmFailSafe : public ModelCommand public: GeneralCommissioningArmFailSafe() : ModelCommand("arm-fail-safe") { - AddArgument("ExpiryLengthSeconds", 0, UINT16_MAX, &mExpiryLengthSeconds); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("ExpiryLengthSeconds", 0, UINT16_MAX, &mRequest.expiryLengthSeconds); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~GeneralCommissioningArmFailSafe() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0030) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000030) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::GeneralCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.ArmFailSafe(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mExpiryLengthSeconds, mBreadcrumb, - mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnGeneralCommissioningArmFailSafeResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnGeneralCommissioningClusterArmFailSafeResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mExpiryLengthSeconds; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::GeneralCommissioning::Commands::ArmFailSafe::Type mRequest; }; /* @@ -10164,27 +9717,18 @@ class GeneralCommissioningCommissioningComplete : public ModelCommand { public: GeneralCommissioningCommissioningComplete() : ModelCommand("commissioning-complete") { ModelCommand::AddArguments(); } - ~GeneralCommissioningCommissioningComplete() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0030) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000030) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::GeneralCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.CommissioningComplete(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnGeneralCommissioningCommissioningCompleteResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnGeneralCommissioningClusterCommissioningCompleteResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::GeneralCommissioning::Commands::CommissioningComplete::Type mRequest; }; /* @@ -10195,38 +9739,25 @@ class GeneralCommissioningSetRegulatoryConfig : public ModelCommand public: GeneralCommissioningSetRegulatoryConfig() : ModelCommand("set-regulatory-config") { - AddArgument("Location", 0, UINT8_MAX, &mLocation); - AddArgument("CountryCode", &mCountryCode); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("Location", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.location)); + AddArgument("CountryCode", &mRequest.countryCode); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~GeneralCommissioningSetRegulatoryConfig() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0030) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000030) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::GeneralCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetRegulatoryConfig(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mLocation, mCountryCode, - mBreadcrumb, mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnGeneralCommissioningSetRegulatoryConfigResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnGeneralCommissioningClusterSetRegulatoryConfigResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mLocation; - chip::ByteSpan mCountryCode; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::GeneralCommissioning::Commands::SetRegulatoryConfig::Type mRequest; }; /* @@ -10723,32 +10254,22 @@ class GroupsAddGroup : public ModelCommand public: GroupsAddGroup() : ModelCommand("add-group") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("GroupName", &mGroupName); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("GroupName", &mRequest.groupName); ModelCommand::AddArguments(); } - ~GroupsAddGroup() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0004) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000004) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::GroupsCluster cluster; cluster.Associate(device, endpointId); - return cluster.AddGroup(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId, mGroupName); + return cluster.InvokeCommand(mRequest, this, OnGroupsAddGroupResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnGroupsClusterAddGroupResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; - chip::ByteSpan mGroupName; + chip::app::Clusters::Groups::Commands::AddGroup::Type mRequest; }; /* @@ -10759,32 +10280,22 @@ class GroupsAddGroupIfIdentifying : public ModelCommand public: GroupsAddGroupIfIdentifying() : ModelCommand("add-group-if-identifying") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("GroupName", &mGroupName); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("GroupName", &mRequest.groupName); ModelCommand::AddArguments(); } - ~GroupsAddGroupIfIdentifying() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0004) command (0x05) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000004) command (0x00000005) on endpoint %" PRIu8, endpointId); chip::Controller::GroupsCluster cluster; cluster.Associate(device, endpointId); - return cluster.AddGroupIfIdentifying(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId, mGroupName); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; - chip::ByteSpan mGroupName; + chip::app::Clusters::Groups::Commands::AddGroupIfIdentifying::Type mRequest; }; /* @@ -10795,33 +10306,22 @@ class GroupsGetGroupMembership : public ModelCommand public: GroupsGetGroupMembership() : ModelCommand("get-group-membership") { - AddArgument("GroupCount", 0, UINT8_MAX, &mGroupCount); - AddArgument("GroupList", 0, UINT16_MAX, &mGroupList); + AddArgument("GroupCount", 0, UINT8_MAX, &mRequest.groupCount); + // groupList Array parsing is not supported yet ModelCommand::AddArguments(); } - ~GroupsGetGroupMembership() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0004) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000004) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::GroupsCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetGroupMembership(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupCount, mGroupList); + return cluster.InvokeCommand(mRequest, this, OnGroupsGetGroupMembershipResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnGroupsClusterGetGroupMembershipResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mGroupCount; - uint16_t mGroupList; + chip::app::Clusters::Groups::Commands::GetGroupMembership::Type mRequest; }; /* @@ -10831,26 +10331,18 @@ class GroupsRemoveAllGroups : public ModelCommand { public: GroupsRemoveAllGroups() : ModelCommand("remove-all-groups") { ModelCommand::AddArguments(); } - ~GroupsRemoveAllGroups() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0004) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000004) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::GroupsCluster cluster; cluster.Associate(device, endpointId); - return cluster.RemoveAllGroups(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::Groups::Commands::RemoveAllGroups::Type mRequest; }; /* @@ -10861,30 +10353,21 @@ class GroupsRemoveGroup : public ModelCommand public: GroupsRemoveGroup() : ModelCommand("remove-group") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); ModelCommand::AddArguments(); } - ~GroupsRemoveGroup() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0004) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000004) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::GroupsCluster cluster; cluster.Associate(device, endpointId); - return cluster.RemoveGroup(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId); + return cluster.InvokeCommand(mRequest, this, OnGroupsRemoveGroupResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnGroupsClusterRemoveGroupResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; + chip::app::Clusters::Groups::Commands::RemoveGroup::Type mRequest; }; /* @@ -10895,30 +10378,21 @@ class GroupsViewGroup : public ModelCommand public: GroupsViewGroup() : ModelCommand("view-group") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); ModelCommand::AddArguments(); } - ~GroupsViewGroup() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0004) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000004) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::GroupsCluster cluster; cluster.Associate(device, endpointId); - return cluster.ViewGroup(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId); + return cluster.InvokeCommand(mRequest, this, OnGroupsViewGroupResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnGroupsClusterViewGroupResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; + chip::app::Clusters::Groups::Commands::ViewGroup::Type mRequest; }; /* @@ -11011,30 +10485,21 @@ class IdentifyIdentify : public ModelCommand public: IdentifyIdentify() : ModelCommand("identify") { - AddArgument("IdentifyTime", 0, UINT16_MAX, &mIdentifyTime); + AddArgument("IdentifyTime", 0, UINT16_MAX, &mRequest.identifyTime); ModelCommand::AddArguments(); } - ~IdentifyIdentify() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0003) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000003) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::IdentifyCluster cluster; cluster.Associate(device, endpointId); - return cluster.Identify(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mIdentifyTime); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mIdentifyTime; + chip::app::Clusters::Identify::Commands::Identify::Type mRequest; }; /* @@ -11044,26 +10509,18 @@ class IdentifyIdentifyQuery : public ModelCommand { public: IdentifyIdentifyQuery() : ModelCommand("identify-query") { ModelCommand::AddArguments(); } - ~IdentifyIdentifyQuery() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0003) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000003) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::IdentifyCluster cluster; cluster.Associate(device, endpointId); - return cluster.IdentifyQuery(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnIdentifyIdentifyQueryResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnIdentifyClusterIdentifyQueryResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::Identify::Commands::IdentifyQuery::Type mRequest; }; /* @@ -11074,32 +10531,24 @@ class IdentifyTriggerEffect : public ModelCommand public: IdentifyTriggerEffect() : ModelCommand("trigger-effect") { - AddArgument("EffectIdentifier", 0, UINT8_MAX, &mEffectIdentifier); - AddArgument("EffectVariant", 0, UINT8_MAX, &mEffectVariant); + AddArgument("EffectIdentifier", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.effectIdentifier)); + AddArgument("EffectVariant", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.effectVariant)); ModelCommand::AddArguments(); } - ~IdentifyTriggerEffect() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0003) command (0x40) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000003) command (0x00000040) on endpoint %" PRIu8, endpointId); chip::Controller::IdentifyCluster cluster; cluster.Associate(device, endpointId); - return cluster.TriggerEffect(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mEffectIdentifier, mEffectVariant); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mEffectIdentifier; - uint8_t mEffectVariant; + chip::app::Clusters::Identify::Commands::TriggerEffect::Type mRequest; }; /* @@ -11255,30 +10704,22 @@ class KeypadInputSendKey : public ModelCommand public: KeypadInputSendKey() : ModelCommand("send-key") { - AddArgument("KeyCode", 0, UINT8_MAX, &mKeyCode); + AddArgument("KeyCode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.keyCode)); ModelCommand::AddArguments(); } - ~KeypadInputSendKey() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0509) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000509) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::KeypadInputCluster cluster; cluster.Associate(device, endpointId); - return cluster.SendKey(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mKeyCode); + return cluster.InvokeCommand(mRequest, this, OnKeypadInputSendKeyResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnKeypadInputClusterSendKeyResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mKeyCode; + chip::app::Clusters::KeypadInput::Commands::SendKey::Type mRequest; }; /* @@ -11354,37 +10795,25 @@ class LevelControlMove : public ModelCommand public: LevelControlMove() : ModelCommand("move") { - AddArgument("MoveMode", 0, UINT8_MAX, &mMoveMode); - AddArgument("Rate", 0, UINT8_MAX, &mRate); - AddArgument("OptionMask", 0, UINT8_MAX, &mOptionMask); - AddArgument("OptionOverride", 0, UINT8_MAX, &mOptionOverride); + AddArgument("MoveMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.moveMode)); + AddArgument("Rate", 0, UINT8_MAX, &mRequest.rate); + AddArgument("OptionMask", 0, UINT8_MAX, &mRequest.optionMask); + AddArgument("OptionOverride", 0, UINT8_MAX, &mRequest.optionOverride); ModelCommand::AddArguments(); } - ~LevelControlMove() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.Move(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMoveMode, mRate, mOptionMask, - mOptionOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mMoveMode; - uint8_t mRate; - uint8_t mOptionMask; - uint8_t mOptionOverride; + chip::app::Clusters::LevelControl::Commands::Move::Type mRequest; }; /* @@ -11395,37 +10824,24 @@ class LevelControlMoveToLevel : public ModelCommand public: LevelControlMoveToLevel() : ModelCommand("move-to-level") { - AddArgument("Level", 0, UINT8_MAX, &mLevel); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionMask", 0, UINT8_MAX, &mOptionMask); - AddArgument("OptionOverride", 0, UINT8_MAX, &mOptionOverride); + AddArgument("Level", 0, UINT8_MAX, &mRequest.level); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionMask", 0, UINT8_MAX, &mRequest.optionMask); + AddArgument("OptionOverride", 0, UINT8_MAX, &mRequest.optionOverride); ModelCommand::AddArguments(); } - ~LevelControlMoveToLevel() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveToLevel(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mLevel, mTransitionTime, mOptionMask, - mOptionOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mLevel; - uint16_t mTransitionTime; - uint8_t mOptionMask; - uint8_t mOptionOverride; + chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type mRequest; }; /* @@ -11436,32 +10852,22 @@ class LevelControlMoveToLevelWithOnOff : public ModelCommand public: LevelControlMoveToLevelWithOnOff() : ModelCommand("move-to-level-with-on-off") { - AddArgument("Level", 0, UINT8_MAX, &mLevel); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); + AddArgument("Level", 0, UINT8_MAX, &mRequest.level); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); ModelCommand::AddArguments(); } - ~LevelControlMoveToLevelWithOnOff() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveToLevelWithOnOff(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mLevel, mTransitionTime); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mLevel; - uint16_t mTransitionTime; + chip::app::Clusters::LevelControl::Commands::MoveToLevelWithOnOff::Type mRequest; }; /* @@ -11472,32 +10878,23 @@ class LevelControlMoveWithOnOff : public ModelCommand public: LevelControlMoveWithOnOff() : ModelCommand("move-with-on-off") { - AddArgument("MoveMode", 0, UINT8_MAX, &mMoveMode); - AddArgument("Rate", 0, UINT8_MAX, &mRate); + AddArgument("MoveMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.moveMode)); + AddArgument("Rate", 0, UINT8_MAX, &mRequest.rate); ModelCommand::AddArguments(); } - ~LevelControlMoveWithOnOff() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x05) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000005) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.MoveWithOnOff(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMoveMode, mRate); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mMoveMode; - uint8_t mRate; + chip::app::Clusters::LevelControl::Commands::MoveWithOnOff::Type mRequest; }; /* @@ -11508,39 +10905,26 @@ class LevelControlStep : public ModelCommand public: LevelControlStep() : ModelCommand("step") { - AddArgument("StepMode", 0, UINT8_MAX, &mStepMode); - AddArgument("StepSize", 0, UINT8_MAX, &mStepSize); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("OptionMask", 0, UINT8_MAX, &mOptionMask); - AddArgument("OptionOverride", 0, UINT8_MAX, &mOptionOverride); + AddArgument("StepMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.stepMode)); + AddArgument("StepSize", 0, UINT8_MAX, &mRequest.stepSize); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("OptionMask", 0, UINT8_MAX, &mRequest.optionMask); + AddArgument("OptionOverride", 0, UINT8_MAX, &mRequest.optionOverride); ModelCommand::AddArguments(); } - ~LevelControlStep() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.Step(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStepMode, mStepSize, mTransitionTime, - mOptionMask, mOptionOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mStepMode; - uint8_t mStepSize; - uint16_t mTransitionTime; - uint8_t mOptionMask; - uint8_t mOptionOverride; + chip::app::Clusters::LevelControl::Commands::Step::Type mRequest; }; /* @@ -11551,35 +10935,24 @@ class LevelControlStepWithOnOff : public ModelCommand public: LevelControlStepWithOnOff() : ModelCommand("step-with-on-off") { - AddArgument("StepMode", 0, UINT8_MAX, &mStepMode); - AddArgument("StepSize", 0, UINT8_MAX, &mStepSize); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); + AddArgument("StepMode", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.stepMode)); + AddArgument("StepSize", 0, UINT8_MAX, &mRequest.stepSize); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); ModelCommand::AddArguments(); } - ~LevelControlStepWithOnOff() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x06) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000006) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.StepWithOnOff(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mStepMode, mStepSize, - mTransitionTime); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mStepMode; - uint8_t mStepSize; - uint16_t mTransitionTime; + chip::app::Clusters::LevelControl::Commands::StepWithOnOff::Type mRequest; }; /* @@ -11590,32 +10963,22 @@ class LevelControlStop : public ModelCommand public: LevelControlStop() : ModelCommand("stop") { - AddArgument("OptionMask", 0, UINT8_MAX, &mOptionMask); - AddArgument("OptionOverride", 0, UINT8_MAX, &mOptionOverride); + AddArgument("OptionMask", 0, UINT8_MAX, &mRequest.optionMask); + AddArgument("OptionOverride", 0, UINT8_MAX, &mRequest.optionOverride); ModelCommand::AddArguments(); } - ~LevelControlStop() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.Stop(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mOptionMask, mOptionOverride); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mOptionMask; - uint8_t mOptionOverride; + chip::app::Clusters::LevelControl::Commands::Stop::Type mRequest; }; /* @@ -11625,26 +10988,18 @@ class LevelControlStopWithOnOff : public ModelCommand { public: LevelControlStopWithOnOff() : ModelCommand("stop-with-on-off") { ModelCommand::AddArguments(); } - ~LevelControlStopWithOnOff() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0008) command (0x07) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000008) command (0x00000007) on endpoint %" PRIu8, endpointId); chip::Controller::LevelControlCluster cluster; cluster.Associate(device, endpointId); - return cluster.StopWithOnOff(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::LevelControl::Commands::StopWithOnOff::Type mRequest; }; /* @@ -12451,26 +11806,18 @@ class LowPowerSleep : public ModelCommand { public: LowPowerSleep() : ModelCommand("sleep") { ModelCommand::AddArguments(); } - ~LowPowerSleep() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0508) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000508) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::LowPowerCluster cluster; cluster.Associate(device, endpointId); - return cluster.Sleep(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::LowPower::Commands::Sleep::Type mRequest; }; /* @@ -12529,26 +11876,18 @@ class MediaInputHideInputStatus : public ModelCommand { public: MediaInputHideInputStatus() : ModelCommand("hide-input-status") { ModelCommand::AddArguments(); } - ~MediaInputHideInputStatus() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0507) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000507) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::MediaInputCluster cluster; cluster.Associate(device, endpointId); - return cluster.HideInputStatus(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaInput::Commands::HideInputStatus::Type mRequest; }; /* @@ -12559,32 +11898,22 @@ class MediaInputRenameInput : public ModelCommand public: MediaInputRenameInput() : ModelCommand("rename-input") { - AddArgument("Index", 0, UINT8_MAX, &mIndex); - AddArgument("Name", &mName); + AddArgument("Index", 0, UINT8_MAX, &mRequest.index); + AddArgument("Name", &mRequest.name); ModelCommand::AddArguments(); } - ~MediaInputRenameInput() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0507) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000507) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::MediaInputCluster cluster; cluster.Associate(device, endpointId); - return cluster.RenameInput(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mIndex, mName); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mIndex; - chip::ByteSpan mName; + chip::app::Clusters::MediaInput::Commands::RenameInput::Type mRequest; }; /* @@ -12595,30 +11924,21 @@ class MediaInputSelectInput : public ModelCommand public: MediaInputSelectInput() : ModelCommand("select-input") { - AddArgument("Index", 0, UINT8_MAX, &mIndex); + AddArgument("Index", 0, UINT8_MAX, &mRequest.index); ModelCommand::AddArguments(); } - ~MediaInputSelectInput() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0507) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000507) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::MediaInputCluster cluster; cluster.Associate(device, endpointId); - return cluster.SelectInput(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mIndex); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mIndex; + chip::app::Clusters::MediaInput::Commands::SelectInput::Type mRequest; }; /* @@ -12628,26 +11948,18 @@ class MediaInputShowInputStatus : public ModelCommand { public: MediaInputShowInputStatus() : ModelCommand("show-input-status") { ModelCommand::AddArguments(); } - ~MediaInputShowInputStatus() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0507) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000507) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::MediaInputCluster cluster; cluster.Associate(device, endpointId); - return cluster.ShowInputStatus(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaInput::Commands::ShowInputStatus::Type mRequest; }; /* @@ -12788,27 +12100,18 @@ class MediaPlaybackMediaFastForward : public ModelCommand { public: MediaPlaybackMediaFastForward() : ModelCommand("media-fast-forward") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaFastForward() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x07) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000007) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaFastForward(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaFastForwardResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnMediaPlaybackClusterMediaFastForwardResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaPlayback::Commands::MediaFastForward::Type mRequest; }; /* @@ -12818,26 +12121,18 @@ class MediaPlaybackMediaNext : public ModelCommand { public: MediaPlaybackMediaNext() : ModelCommand("media-next") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaNext() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x05) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000005) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaNext(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaNextResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnMediaPlaybackClusterMediaNextResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaPlayback::Commands::MediaNext::Type mRequest; }; /* @@ -12847,27 +12142,18 @@ class MediaPlaybackMediaPause : public ModelCommand { public: MediaPlaybackMediaPause() : ModelCommand("media-pause") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaPause() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaPause(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaPauseResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnMediaPlaybackClusterMediaPauseResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaPlayback::Commands::MediaPause::Type mRequest; }; /* @@ -12877,26 +12163,18 @@ class MediaPlaybackMediaPlay : public ModelCommand { public: MediaPlaybackMediaPlay() : ModelCommand("media-play") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaPlay() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaPlay(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaPlayResponseSuccess, OnDefaultFailure); } -private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnMediaPlaybackClusterMediaPlayResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); +private: + chip::app::Clusters::MediaPlayback::Commands::MediaPlay::Type mRequest; }; /* @@ -12906,27 +12184,18 @@ class MediaPlaybackMediaPrevious : public ModelCommand { public: MediaPlaybackMediaPrevious() : ModelCommand("media-previous") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaPrevious() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaPrevious(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaPreviousResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnMediaPlaybackClusterMediaPreviousResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaPlayback::Commands::MediaPrevious::Type mRequest; }; /* @@ -12936,27 +12205,18 @@ class MediaPlaybackMediaRewind : public ModelCommand { public: MediaPlaybackMediaRewind() : ModelCommand("media-rewind") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaRewind() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x06) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000006) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaRewind(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaRewindResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnMediaPlaybackClusterMediaRewindResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaPlayback::Commands::MediaRewind::Type mRequest; }; /* @@ -12967,30 +12227,21 @@ class MediaPlaybackMediaSeek : public ModelCommand public: MediaPlaybackMediaSeek() : ModelCommand("media-seek") { - AddArgument("Position", 0, UINT64_MAX, &mPosition); + AddArgument("Position", 0, UINT64_MAX, &mRequest.position); ModelCommand::AddArguments(); } - ~MediaPlaybackMediaSeek() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x0A) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x0000000A) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaSeek(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mPosition); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaSeekResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnMediaPlaybackClusterMediaSeekResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint64_t mPosition; + chip::app::Clusters::MediaPlayback::Commands::MediaSeek::Type mRequest; }; /* @@ -13001,31 +12252,21 @@ class MediaPlaybackMediaSkipBackward : public ModelCommand public: MediaPlaybackMediaSkipBackward() : ModelCommand("media-skip-backward") { - AddArgument("DeltaPositionMilliseconds", 0, UINT64_MAX, &mDeltaPositionMilliseconds); + AddArgument("DeltaPositionMilliseconds", 0, UINT64_MAX, &mRequest.deltaPositionMilliseconds); ModelCommand::AddArguments(); } - ~MediaPlaybackMediaSkipBackward() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x09) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000009) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaSkipBackward(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mDeltaPositionMilliseconds); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaSkipBackwardResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnMediaPlaybackClusterMediaSkipBackwardResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint64_t mDeltaPositionMilliseconds; + chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackward::Type mRequest; }; /* @@ -13036,31 +12277,21 @@ class MediaPlaybackMediaSkipForward : public ModelCommand public: MediaPlaybackMediaSkipForward() : ModelCommand("media-skip-forward") { - AddArgument("DeltaPositionMilliseconds", 0, UINT64_MAX, &mDeltaPositionMilliseconds); + AddArgument("DeltaPositionMilliseconds", 0, UINT64_MAX, &mRequest.deltaPositionMilliseconds); ModelCommand::AddArguments(); } - ~MediaPlaybackMediaSkipForward() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x08) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000008) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaSkipForward(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mDeltaPositionMilliseconds); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaSkipForwardResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnMediaPlaybackClusterMediaSkipForwardResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint64_t mDeltaPositionMilliseconds; + chip::app::Clusters::MediaPlayback::Commands::MediaSkipForward::Type mRequest; }; /* @@ -13070,27 +12301,18 @@ class MediaPlaybackMediaStartOver : public ModelCommand { public: MediaPlaybackMediaStartOver() : ModelCommand("media-start-over") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaStartOver() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaStartOver(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaStartOverResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnMediaPlaybackClusterMediaStartOverResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaPlayback::Commands::MediaStartOver::Type mRequest; }; /* @@ -13100,26 +12322,18 @@ class MediaPlaybackMediaStop : public ModelCommand { public: MediaPlaybackMediaStop() : ModelCommand("media-stop") { ModelCommand::AddArguments(); } - ~MediaPlaybackMediaStop() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0506) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000506) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::MediaPlaybackCluster cluster; cluster.Associate(device, endpointId); - return cluster.MediaStop(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnMediaPlaybackMediaStopResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnMediaPlaybackClusterMediaStopResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::MediaPlayback::Commands::MediaStop::Type mRequest; }; /* @@ -13455,36 +12669,23 @@ class NetworkCommissioningAddThreadNetwork : public ModelCommand public: NetworkCommissioningAddThreadNetwork() : ModelCommand("add-thread-network") { - AddArgument("OperationalDataset", &mOperationalDataset); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("OperationalDataset", &mRequest.operationalDataset); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningAddThreadNetwork() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x06) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x00000006) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.AddThreadNetwork(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mOperationalDataset, mBreadcrumb, - mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningAddThreadNetworkResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterAddThreadNetworkResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mOperationalDataset; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::AddThreadNetwork::Type mRequest; }; /* @@ -13495,38 +12696,24 @@ class NetworkCommissioningAddWiFiNetwork : public ModelCommand public: NetworkCommissioningAddWiFiNetwork() : ModelCommand("add-wi-fi-network") { - AddArgument("Ssid", &mSsid); - AddArgument("Credentials", &mCredentials); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("Ssid", &mRequest.ssid); + AddArgument("Credentials", &mRequest.credentials); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningAddWiFiNetwork() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.AddWiFiNetwork(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mSsid, mCredentials, mBreadcrumb, - mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningAddWiFiNetworkResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterAddWiFiNetworkResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mSsid; - chip::ByteSpan mCredentials; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::AddWiFiNetwork::Type mRequest; }; /* @@ -13537,36 +12724,23 @@ class NetworkCommissioningDisableNetwork : public ModelCommand public: NetworkCommissioningDisableNetwork() : ModelCommand("disable-network") { - AddArgument("NetworkID", &mNetworkID); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("NetworkID", &mRequest.networkID); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningDisableNetwork() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x0E) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x0000000E) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.DisableNetwork(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNetworkID, mBreadcrumb, - mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningDisableNetworkResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterDisableNetworkResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mNetworkID; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::DisableNetwork::Type mRequest; }; /* @@ -13577,35 +12751,23 @@ class NetworkCommissioningEnableNetwork : public ModelCommand public: NetworkCommissioningEnableNetwork() : ModelCommand("enable-network") { - AddArgument("NetworkID", &mNetworkID); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("NetworkID", &mRequest.networkID); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningEnableNetwork() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x0C) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x0000000C) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.EnableNetwork(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNetworkID, mBreadcrumb, mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningEnableNetworkResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterEnableNetworkResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mNetworkID; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::EnableNetwork::Type mRequest; }; /* @@ -13616,30 +12778,21 @@ class NetworkCommissioningGetLastNetworkCommissioningResult : public ModelComman public: NetworkCommissioningGetLastNetworkCommissioningResult() : ModelCommand("get-last-network-commissioning-result") { - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningGetLastNetworkCommissioningResult() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x10) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x00000010) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetLastNetworkCommissioningResult(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::GetLastNetworkCommissioningResult::Type mRequest; }; /* @@ -13650,35 +12803,23 @@ class NetworkCommissioningRemoveNetwork : public ModelCommand public: NetworkCommissioningRemoveNetwork() : ModelCommand("remove-network") { - AddArgument("NetworkID", &mNetworkID); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("NetworkID", &mRequest.networkID); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningRemoveNetwork() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x0A) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x0000000A) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.RemoveNetwork(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNetworkID, mBreadcrumb, mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningRemoveNetworkResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterRemoveNetworkResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mNetworkID; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::RemoveNetwork::Type mRequest; }; /* @@ -13689,35 +12830,23 @@ class NetworkCommissioningScanNetworks : public ModelCommand public: NetworkCommissioningScanNetworks() : ModelCommand("scan-networks") { - AddArgument("Ssid", &mSsid); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("Ssid", &mRequest.ssid); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningScanNetworks() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.ScanNetworks(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mSsid, mBreadcrumb, mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningScanNetworksResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterScanNetworksResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mSsid; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::ScanNetworks::Type mRequest; }; /* @@ -13728,36 +12857,23 @@ class NetworkCommissioningUpdateThreadNetwork : public ModelCommand public: NetworkCommissioningUpdateThreadNetwork() : ModelCommand("update-thread-network") { - AddArgument("OperationalDataset", &mOperationalDataset); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("OperationalDataset", &mRequest.operationalDataset); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningUpdateThreadNetwork() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x08) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x00000008) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.UpdateThreadNetwork(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mOperationalDataset, - mBreadcrumb, mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningUpdateThreadNetworkResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterUpdateThreadNetworkResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mOperationalDataset; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::UpdateThreadNetwork::Type mRequest; }; /* @@ -13768,38 +12884,24 @@ class NetworkCommissioningUpdateWiFiNetwork : public ModelCommand public: NetworkCommissioningUpdateWiFiNetwork() : ModelCommand("update-wi-fi-network") { - AddArgument("Ssid", &mSsid); - AddArgument("Credentials", &mCredentials); - AddArgument("Breadcrumb", 0, UINT64_MAX, &mBreadcrumb); - AddArgument("TimeoutMs", 0, UINT32_MAX, &mTimeoutMs); + AddArgument("Ssid", &mRequest.ssid); + AddArgument("Credentials", &mRequest.credentials); + AddArgument("Breadcrumb", 0, UINT64_MAX, &mRequest.breadcrumb); + AddArgument("TimeoutMs", 0, UINT32_MAX, &mRequest.timeoutMs); ModelCommand::AddArguments(); } - ~NetworkCommissioningUpdateWiFiNetwork() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0031) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000031) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::NetworkCommissioningCluster cluster; cluster.Associate(device, endpointId); - return cluster.UpdateWiFiNetwork(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mSsid, mCredentials, mBreadcrumb, - mTimeoutMs); + return cluster.InvokeCommand(mRequest, this, OnNetworkCommissioningUpdateWiFiNetworkResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnNetworkCommissioningClusterUpdateWiFiNetworkResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mSsid; - chip::ByteSpan mCredentials; - uint64_t mBreadcrumb; - uint32_t mTimeoutMs; + chip::app::Clusters::NetworkCommissioning::Commands::UpdateWiFiNetwork::Type mRequest; }; /* @@ -13890,33 +12992,23 @@ class OtaSoftwareUpdateProviderApplyUpdateRequest : public ModelCommand public: OtaSoftwareUpdateProviderApplyUpdateRequest() : ModelCommand("apply-update-request") { - AddArgument("UpdateToken", &mUpdateToken); - AddArgument("NewVersion", 0, UINT32_MAX, &mNewVersion); + AddArgument("UpdateToken", &mRequest.updateToken); + AddArgument("NewVersion", 0, UINT32_MAX, &mRequest.newVersion); ModelCommand::AddArguments(); } - ~OtaSoftwareUpdateProviderApplyUpdateRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0029) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000029) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::OtaSoftwareUpdateProviderCluster cluster; cluster.Associate(device, endpointId); - return cluster.ApplyUpdateRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUpdateToken, mNewVersion); + return cluster.InvokeCommand(mRequest, this, OnOtaSoftwareUpdateProviderApplyUpdateRequestResponseSuccess, + OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnOtaSoftwareUpdateProviderClusterApplyUpdateRequestResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mUpdateToken; - uint32_t mNewVersion; + chip::app::Clusters::OtaSoftwareUpdateProvider::Commands::ApplyUpdateRequest::Type mRequest; }; /* @@ -13927,33 +13019,22 @@ class OtaSoftwareUpdateProviderNotifyUpdateApplied : public ModelCommand public: OtaSoftwareUpdateProviderNotifyUpdateApplied() : ModelCommand("notify-update-applied") { - AddArgument("UpdateToken", &mUpdateToken); - AddArgument("SoftwareVersion", 0, UINT32_MAX, &mSoftwareVersion); + AddArgument("UpdateToken", &mRequest.updateToken); + AddArgument("SoftwareVersion", 0, UINT32_MAX, &mRequest.softwareVersion); ModelCommand::AddArguments(); } - ~OtaSoftwareUpdateProviderNotifyUpdateApplied() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0029) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000029) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::OtaSoftwareUpdateProviderCluster cluster; cluster.Associate(device, endpointId); - return cluster.NotifyUpdateApplied(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mUpdateToken, - mSoftwareVersion); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mUpdateToken; - uint32_t mSoftwareVersion; + chip::app::Clusters::OtaSoftwareUpdateProvider::Commands::NotifyUpdateApplied::Type mRequest; }; /* @@ -13964,46 +13045,30 @@ class OtaSoftwareUpdateProviderQueryImage : public ModelCommand public: OtaSoftwareUpdateProviderQueryImage() : ModelCommand("query-image") { - AddArgument("VendorId", 0, UINT16_MAX, &mVendorId); - AddArgument("ProductId", 0, UINT16_MAX, &mProductId); - AddArgument("HardwareVersion", 0, UINT16_MAX, &mHardwareVersion); - AddArgument("SoftwareVersion", 0, UINT32_MAX, &mSoftwareVersion); - AddArgument("ProtocolsSupported", 0, UINT8_MAX, &mProtocolsSupported); - AddArgument("Location", &mLocation); - AddArgument("RequestorCanConsent", 0, 1, &mRequestorCanConsent); - AddArgument("MetadataForProvider", &mMetadataForProvider); + AddArgument("VendorId", 0, UINT16_MAX, &mRequest.vendorId); + AddArgument("ProductId", 0, UINT16_MAX, &mRequest.productId); + AddArgument("HardwareVersion", 0, UINT16_MAX, &mRequest.hardwareVersion); + AddArgument("SoftwareVersion", 0, UINT32_MAX, &mRequest.softwareVersion); + AddArgument( + "ProtocolsSupported", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.protocolsSupported)); + AddArgument("Location", &mRequest.location); + AddArgument("RequestorCanConsent", 0, 1, &mRequest.requestorCanConsent); + AddArgument("MetadataForProvider", &mRequest.metadataForProvider); ModelCommand::AddArguments(); } - ~OtaSoftwareUpdateProviderQueryImage() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0029) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000029) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::OtaSoftwareUpdateProviderCluster cluster; cluster.Associate(device, endpointId); - return cluster.QueryImage(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mVendorId, mProductId, mHardwareVersion, - mSoftwareVersion, mProtocolsSupported, mLocation, mRequestorCanConsent, mMetadataForProvider); + return cluster.InvokeCommand(mRequest, this, OnOtaSoftwareUpdateProviderQueryImageResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnOtaSoftwareUpdateProviderClusterQueryImageResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mVendorId; - uint16_t mProductId; - uint16_t mHardwareVersion; - uint32_t mSoftwareVersion; - uint8_t mProtocolsSupported; - chip::ByteSpan mLocation; - bool mRequestorCanConsent; - chip::ByteSpan mMetadataForProvider; + chip::app::Clusters::OtaSoftwareUpdateProvider::Commands::QueryImage::Type mRequest; }; /* @@ -14060,37 +13125,26 @@ class OtaSoftwareUpdateRequestorAnnounceOtaProvider : public ModelCommand public: OtaSoftwareUpdateRequestorAnnounceOtaProvider() : ModelCommand("announce-ota-provider") { - AddArgument("ProviderLocation", &mProviderLocation); - AddArgument("VendorId", 0, UINT16_MAX, &mVendorId); - AddArgument("AnnouncementReason", 0, UINT8_MAX, &mAnnouncementReason); - AddArgument("MetadataForNode", &mMetadataForNode); + AddArgument("ProviderLocation", &mRequest.providerLocation); + AddArgument("VendorId", 0, UINT16_MAX, &mRequest.vendorId); + AddArgument( + "AnnouncementReason", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.announcementReason)); + AddArgument("MetadataForNode", &mRequest.metadataForNode); ModelCommand::AddArguments(); } - ~OtaSoftwareUpdateRequestorAnnounceOtaProvider() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x002A) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000002A) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::OtaSoftwareUpdateRequestorCluster cluster; cluster.Associate(device, endpointId); - return cluster.AnnounceOtaProvider(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mProviderLocation, mVendorId, - mAnnouncementReason, mMetadataForNode); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mProviderLocation; - uint16_t mVendorId; - uint8_t mAnnouncementReason; - chip::ByteSpan mMetadataForNode; + chip::app::Clusters::OtaSoftwareUpdateRequestor::Commands::AnnounceOtaProvider::Type mRequest; }; /* @@ -14450,26 +13504,18 @@ class OnOffOff : public ModelCommand { public: OnOffOff() : ModelCommand("off") { ModelCommand::AddArguments(); } - ~OnOffOff() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0006) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000006) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::OnOffCluster cluster; cluster.Associate(device, endpointId); - return cluster.Off(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::OnOff::Commands::Off::Type mRequest; }; /* @@ -14480,32 +13526,24 @@ class OnOffOffWithEffect : public ModelCommand public: OnOffOffWithEffect() : ModelCommand("off-with-effect") { - AddArgument("EffectId", 0, UINT8_MAX, &mEffectId); - AddArgument("EffectVariant", 0, UINT8_MAX, &mEffectVariant); + AddArgument("EffectId", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.effectId)); + AddArgument("EffectVariant", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.effectVariant)); ModelCommand::AddArguments(); } - ~OnOffOffWithEffect() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0006) command (0x40) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000006) command (0x00000040) on endpoint %" PRIu8, endpointId); chip::Controller::OnOffCluster cluster; cluster.Associate(device, endpointId); - return cluster.OffWithEffect(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mEffectId, mEffectVariant); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mEffectId; - uint8_t mEffectVariant; + chip::app::Clusters::OnOff::Commands::OffWithEffect::Type mRequest; }; /* @@ -14515,26 +13553,18 @@ class OnOffOn : public ModelCommand { public: OnOffOn() : ModelCommand("on") { ModelCommand::AddArguments(); } - ~OnOffOn() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0006) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000006) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::OnOffCluster cluster; cluster.Associate(device, endpointId); - return cluster.On(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::OnOff::Commands::On::Type mRequest; }; /* @@ -14544,26 +13574,18 @@ class OnOffOnWithRecallGlobalScene : public ModelCommand { public: OnOffOnWithRecallGlobalScene() : ModelCommand("on-with-recall-global-scene") { ModelCommand::AddArguments(); } - ~OnOffOnWithRecallGlobalScene() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0006) command (0x41) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000006) command (0x00000041) on endpoint %" PRIu8, endpointId); chip::Controller::OnOffCluster cluster; cluster.Associate(device, endpointId); - return cluster.OnWithRecallGlobalScene(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::OnOff::Commands::OnWithRecallGlobalScene::Type mRequest; }; /* @@ -14574,35 +13596,24 @@ class OnOffOnWithTimedOff : public ModelCommand public: OnOffOnWithTimedOff() : ModelCommand("on-with-timed-off") { - AddArgument("OnOffControl", 0, UINT8_MAX, &mOnOffControl); - AddArgument("OnTime", 0, UINT16_MAX, &mOnTime); - AddArgument("OffWaitTime", 0, UINT16_MAX, &mOffWaitTime); + AddArgument("OnOffControl", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.onOffControl)); + AddArgument("OnTime", 0, UINT16_MAX, &mRequest.onTime); + AddArgument("OffWaitTime", 0, UINT16_MAX, &mRequest.offWaitTime); ModelCommand::AddArguments(); } - ~OnOffOnWithTimedOff() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0006) command (0x42) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000006) command (0x00000042) on endpoint %" PRIu8, endpointId); chip::Controller::OnOffCluster cluster; cluster.Associate(device, endpointId); - return cluster.OnWithTimedOff(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mOnOffControl, mOnTime, - mOffWaitTime); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mOnOffControl; - uint16_t mOnTime; - uint16_t mOffWaitTime; + chip::app::Clusters::OnOff::Commands::OnWithTimedOff::Type mRequest; }; /* @@ -14612,26 +13623,18 @@ class OnOffToggle : public ModelCommand { public: OnOffToggle() : ModelCommand("toggle") { ModelCommand::AddArguments(); } - ~OnOffToggle() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0006) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000006) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::OnOffCluster cluster; cluster.Associate(device, endpointId); - return cluster.Toggle(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::OnOff::Commands::Toggle::Type mRequest; }; /* @@ -15192,40 +14195,25 @@ class OperationalCredentialsAddNOC : public ModelCommand public: OperationalCredentialsAddNOC() : ModelCommand("add-noc") { - AddArgument("NOCValue", &mNOCValue); - AddArgument("ICACValue", &mICACValue); - AddArgument("IPKValue", &mIPKValue); - AddArgument("CaseAdminNode", 0, UINT64_MAX, &mCaseAdminNode); - AddArgument("AdminVendorId", 0, UINT16_MAX, &mAdminVendorId); + AddArgument("NOCValue", &mRequest.NOCValue); + AddArgument("ICACValue", &mRequest.ICACValue); + AddArgument("IPKValue", &mRequest.IPKValue); + AddArgument("CaseAdminNode", 0, UINT64_MAX, &mRequest.caseAdminNode); + AddArgument("AdminVendorId", 0, UINT16_MAX, &mRequest.adminVendorId); ModelCommand::AddArguments(); } - ~OperationalCredentialsAddNOC() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x06) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x00000006) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.AddNOC(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNOCValue, mICACValue, mIPKValue, - mCaseAdminNode, mAdminVendorId); + return cluster.InvokeCommand(mRequest, this, OnOperationalCredentialsNOCResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnOperationalCredentialsClusterNOCResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mNOCValue; - chip::ByteSpan mICACValue; - chip::ByteSpan mIPKValue; - chip::NodeId mCaseAdminNode; - uint16_t mAdminVendorId; + chip::app::Clusters::OperationalCredentials::Commands::AddNOC::Type mRequest; }; /* @@ -15236,30 +14224,21 @@ class OperationalCredentialsAddTrustedRootCertificate : public ModelCommand public: OperationalCredentialsAddTrustedRootCertificate() : ModelCommand("add-trusted-root-certificate") { - AddArgument("RootCertificate", &mRootCertificate); + AddArgument("RootCertificate", &mRequest.rootCertificate); ModelCommand::AddArguments(); } - ~OperationalCredentialsAddTrustedRootCertificate() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x0B) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x0000000B) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.AddTrustedRootCertificate(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mRootCertificate); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mRootCertificate; + chip::app::Clusters::OperationalCredentials::Commands::AddTrustedRootCertificate::Type mRequest; }; /* @@ -15270,31 +14249,21 @@ class OperationalCredentialsAttestationRequest : public ModelCommand public: OperationalCredentialsAttestationRequest() : ModelCommand("attestation-request") { - AddArgument("AttestationNonce", &mAttestationNonce); + AddArgument("AttestationNonce", &mRequest.attestationNonce); ModelCommand::AddArguments(); } - ~OperationalCredentialsAttestationRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.AttestationRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mAttestationNonce); + return cluster.InvokeCommand(mRequest, this, OnOperationalCredentialsAttestationResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnOperationalCredentialsClusterAttestationResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mAttestationNonce; + chip::app::Clusters::OperationalCredentials::Commands::AttestationRequest::Type mRequest; }; /* @@ -15305,31 +14274,21 @@ class OperationalCredentialsCertificateChainRequest : public ModelCommand public: OperationalCredentialsCertificateChainRequest() : ModelCommand("certificate-chain-request") { - AddArgument("CertificateType", 0, UINT8_MAX, &mCertificateType); + AddArgument("CertificateType", 0, UINT8_MAX, &mRequest.certificateType); ModelCommand::AddArguments(); } - ~OperationalCredentialsCertificateChainRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.CertificateChainRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mCertificateType); + return cluster.InvokeCommand(mRequest, this, OnOperationalCredentialsCertificateChainResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnOperationalCredentialsClusterCertificateChainResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mCertificateType; + chip::app::Clusters::OperationalCredentials::Commands::CertificateChainRequest::Type mRequest; }; /* @@ -15340,31 +14299,21 @@ class OperationalCredentialsOpCSRRequest : public ModelCommand public: OperationalCredentialsOpCSRRequest() : ModelCommand("op-csrrequest") { - AddArgument("CSRNonce", &mCSRNonce); + AddArgument("CSRNonce", &mRequest.CSRNonce); ModelCommand::AddArguments(); } - ~OperationalCredentialsOpCSRRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.OpCSRRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mCSRNonce); + return cluster.InvokeCommand(mRequest, this, OnOperationalCredentialsOpCSRResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnOperationalCredentialsClusterOpCSRResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mCSRNonce; + chip::app::Clusters::OperationalCredentials::Commands::OpCSRRequest::Type mRequest; }; /* @@ -15375,31 +14324,21 @@ class OperationalCredentialsRemoveFabric : public ModelCommand public: OperationalCredentialsRemoveFabric() : ModelCommand("remove-fabric") { - AddArgument("FabricIndex", 0, UINT8_MAX, &mFabricIndex); + AddArgument("FabricIndex", 0, UINT8_MAX, &mRequest.fabricIndex); ModelCommand::AddArguments(); } - ~OperationalCredentialsRemoveFabric() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x0A) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x0000000A) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.RemoveFabric(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mFabricIndex); + return cluster.InvokeCommand(mRequest, this, OnOperationalCredentialsNOCResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnOperationalCredentialsClusterNOCResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mFabricIndex; + chip::app::Clusters::OperationalCredentials::Commands::RemoveFabric::Type mRequest; }; /* @@ -15410,31 +14349,21 @@ class OperationalCredentialsRemoveTrustedRootCertificate : public ModelCommand public: OperationalCredentialsRemoveTrustedRootCertificate() : ModelCommand("remove-trusted-root-certificate") { - AddArgument("TrustedRootIdentifier", &mTrustedRootIdentifier); + AddArgument("TrustedRootIdentifier", &mRequest.trustedRootIdentifier); ModelCommand::AddArguments(); } - ~OperationalCredentialsRemoveTrustedRootCertificate() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x0C) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x0000000C) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.RemoveTrustedRootCertificate(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), - mTrustedRootIdentifier); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mTrustedRootIdentifier; + chip::app::Clusters::OperationalCredentials::Commands::RemoveTrustedRootCertificate::Type mRequest; }; /* @@ -15445,31 +14374,21 @@ class OperationalCredentialsUpdateFabricLabel : public ModelCommand public: OperationalCredentialsUpdateFabricLabel() : ModelCommand("update-fabric-label") { - AddArgument("Label", &mLabel); + AddArgument("Label", &mRequest.label); ModelCommand::AddArguments(); } - ~OperationalCredentialsUpdateFabricLabel() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x09) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x00000009) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.UpdateFabricLabel(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mLabel); + return cluster.InvokeCommand(mRequest, this, OnOperationalCredentialsNOCResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnOperationalCredentialsClusterNOCResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mLabel; + chip::app::Clusters::OperationalCredentials::Commands::UpdateFabricLabel::Type mRequest; }; /* @@ -15480,33 +14399,22 @@ class OperationalCredentialsUpdateNOC : public ModelCommand public: OperationalCredentialsUpdateNOC() : ModelCommand("update-noc") { - AddArgument("NOCValue", &mNOCValue); - AddArgument("ICACValue", &mICACValue); + AddArgument("NOCValue", &mRequest.NOCValue); + AddArgument("ICACValue", &mRequest.ICACValue); ModelCommand::AddArguments(); } - ~OperationalCredentialsUpdateNOC() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x003E) command (0x07) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000003E) command (0x00000007) on endpoint %" PRIu8, endpointId); chip::Controller::OperationalCredentialsCluster cluster; cluster.Associate(device, endpointId); - return cluster.UpdateNOC(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNOCValue, mICACValue); + return cluster.InvokeCommand(mRequest, this, OnOperationalCredentialsNOCResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnOperationalCredentialsClusterNOCResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mNOCValue; - chip::ByteSpan mICACValue; + chip::app::Clusters::OperationalCredentials::Commands::UpdateNOC::Type mRequest; }; /* @@ -16824,43 +15732,25 @@ class ScenesAddScene : public ModelCommand public: ScenesAddScene() : ModelCommand("add-scene") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("SceneId", 0, UINT8_MAX, &mSceneId); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - AddArgument("SceneName", &mSceneName); - AddArgument("ClusterId", 0, UINT32_MAX, &mClusterId); - AddArgument("Length", 0, UINT8_MAX, &mLength); - AddArgument("Value", 0, UINT8_MAX, &mValue); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("SceneId", 0, UINT8_MAX, &mRequest.sceneId); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + AddArgument("SceneName", &mRequest.sceneName); + // extensionFieldSets Array parsing is not supported yet ModelCommand::AddArguments(); } - ~ScenesAddScene() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0005) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000005) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::ScenesCluster cluster; cluster.Associate(device, endpointId); - return cluster.AddScene(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId, mSceneId, mTransitionTime, - mSceneName, mClusterId, mLength, mValue); + return cluster.InvokeCommand(mRequest, this, OnScenesAddSceneResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnScenesClusterAddSceneResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; - uint8_t mSceneId; - uint16_t mTransitionTime; - chip::ByteSpan mSceneName; - chip::ClusterId mClusterId; - uint8_t mLength; - uint8_t mValue; + chip::app::Clusters::Scenes::Commands::AddScene::Type mRequest; }; /* @@ -16871,31 +15761,21 @@ class ScenesGetSceneMembership : public ModelCommand public: ScenesGetSceneMembership() : ModelCommand("get-scene-membership") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); ModelCommand::AddArguments(); } - ~ScenesGetSceneMembership() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0005) command (0x06) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000005) command (0x00000006) on endpoint %" PRIu8, endpointId); chip::Controller::ScenesCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetSceneMembership(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId); + return cluster.InvokeCommand(mRequest, this, OnScenesGetSceneMembershipResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnScenesClusterGetSceneMembershipResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; + chip::app::Clusters::Scenes::Commands::GetSceneMembership::Type mRequest; }; /* @@ -16906,34 +15786,23 @@ class ScenesRecallScene : public ModelCommand public: ScenesRecallScene() : ModelCommand("recall-scene") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("SceneId", 0, UINT8_MAX, &mSceneId); - AddArgument("TransitionTime", 0, UINT16_MAX, &mTransitionTime); - ModelCommand::AddArguments(); - } - ~ScenesRecallScene() - { - delete onSuccessCallback; - delete onFailureCallback; + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("SceneId", 0, UINT8_MAX, &mRequest.sceneId); + AddArgument("TransitionTime", 0, UINT16_MAX, &mRequest.transitionTime); + ModelCommand::AddArguments(); } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0005) command (0x05) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000005) command (0x00000005) on endpoint %" PRIu8, endpointId); chip::Controller::ScenesCluster cluster; cluster.Associate(device, endpointId); - return cluster.RecallScene(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId, mSceneId, mTransitionTime); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; - uint8_t mSceneId; - uint16_t mTransitionTime; + chip::app::Clusters::Scenes::Commands::RecallScene::Type mRequest; }; /* @@ -16944,30 +15813,21 @@ class ScenesRemoveAllScenes : public ModelCommand public: ScenesRemoveAllScenes() : ModelCommand("remove-all-scenes") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); ModelCommand::AddArguments(); } - ~ScenesRemoveAllScenes() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0005) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000005) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::ScenesCluster cluster; cluster.Associate(device, endpointId); - return cluster.RemoveAllScenes(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId); + return cluster.InvokeCommand(mRequest, this, OnScenesRemoveAllScenesResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnScenesClusterRemoveAllScenesResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; + chip::app::Clusters::Scenes::Commands::RemoveAllScenes::Type mRequest; }; /* @@ -16978,32 +15838,22 @@ class ScenesRemoveScene : public ModelCommand public: ScenesRemoveScene() : ModelCommand("remove-scene") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("SceneId", 0, UINT8_MAX, &mSceneId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("SceneId", 0, UINT8_MAX, &mRequest.sceneId); ModelCommand::AddArguments(); } - ~ScenesRemoveScene() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0005) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000005) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::ScenesCluster cluster; cluster.Associate(device, endpointId); - return cluster.RemoveScene(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId, mSceneId); + return cluster.InvokeCommand(mRequest, this, OnScenesRemoveSceneResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnScenesClusterRemoveSceneResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; - uint8_t mSceneId; + chip::app::Clusters::Scenes::Commands::RemoveScene::Type mRequest; }; /* @@ -17014,32 +15864,22 @@ class ScenesStoreScene : public ModelCommand public: ScenesStoreScene() : ModelCommand("store-scene") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("SceneId", 0, UINT8_MAX, &mSceneId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("SceneId", 0, UINT8_MAX, &mRequest.sceneId); ModelCommand::AddArguments(); } - ~ScenesStoreScene() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0005) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000005) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::ScenesCluster cluster; cluster.Associate(device, endpointId); - return cluster.StoreScene(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId, mSceneId); + return cluster.InvokeCommand(mRequest, this, OnScenesStoreSceneResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnScenesClusterStoreSceneResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; - uint8_t mSceneId; + chip::app::Clusters::Scenes::Commands::StoreScene::Type mRequest; }; /* @@ -17050,32 +15890,22 @@ class ScenesViewScene : public ModelCommand public: ScenesViewScene() : ModelCommand("view-scene") { - AddArgument("GroupId", 0, UINT16_MAX, &mGroupId); - AddArgument("SceneId", 0, UINT8_MAX, &mSceneId); + AddArgument("GroupId", 0, UINT16_MAX, &mRequest.groupId); + AddArgument("SceneId", 0, UINT8_MAX, &mRequest.sceneId); ModelCommand::AddArguments(); } - ~ScenesViewScene() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0005) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000005) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::ScenesCluster cluster; cluster.Associate(device, endpointId); - return cluster.ViewScene(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mGroupId, mSceneId); + return cluster.InvokeCommand(mRequest, this, OnScenesViewSceneResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnScenesClusterViewSceneResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mGroupId; - uint8_t mSceneId; + chip::app::Clusters::Scenes::Commands::ViewScene::Type mRequest; }; /* @@ -17302,26 +16132,18 @@ class SoftwareDiagnosticsResetWatermarks : public ModelCommand { public: SoftwareDiagnosticsResetWatermarks() : ModelCommand("reset-watermarks") { ModelCommand::AddArguments(); } - ~SoftwareDiagnosticsResetWatermarks() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0034) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000034) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::SoftwareDiagnosticsCluster cluster; cluster.Associate(device, endpointId); - return cluster.ResetWatermarks(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::SoftwareDiagnostics::Commands::ResetWatermarks::Type mRequest; }; /* @@ -17642,30 +16464,21 @@ class TvChannelChangeChannel : public ModelCommand public: TvChannelChangeChannel() : ModelCommand("change-channel") { - AddArgument("Match", &mMatch); + AddArgument("Match", &mRequest.match); ModelCommand::AddArguments(); } - ~TvChannelChangeChannel() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0504) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000504) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::TvChannelCluster cluster; cluster.Associate(device, endpointId); - return cluster.ChangeChannel(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMatch); + return cluster.InvokeCommand(mRequest, this, OnTvChannelChangeChannelResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnTvChannelClusterChangeChannelResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - chip::ByteSpan mMatch; + chip::app::Clusters::TvChannel::Commands::ChangeChannel::Type mRequest; }; /* @@ -17676,32 +16489,22 @@ class TvChannelChangeChannelByNumber : public ModelCommand public: TvChannelChangeChannelByNumber() : ModelCommand("change-channel-by-number") { - AddArgument("MajorNumber", 0, UINT16_MAX, &mMajorNumber); - AddArgument("MinorNumber", 0, UINT16_MAX, &mMinorNumber); + AddArgument("MajorNumber", 0, UINT16_MAX, &mRequest.majorNumber); + AddArgument("MinorNumber", 0, UINT16_MAX, &mRequest.minorNumber); ModelCommand::AddArguments(); } - ~TvChannelChangeChannelByNumber() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0504) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000504) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::TvChannelCluster cluster; cluster.Associate(device, endpointId); - return cluster.ChangeChannelByNumber(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMajorNumber, mMinorNumber); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mMajorNumber; - uint16_t mMinorNumber; + chip::app::Clusters::TvChannel::Commands::ChangeChannelByNumber::Type mRequest; }; /* @@ -17712,30 +16515,21 @@ class TvChannelSkipChannel : public ModelCommand public: TvChannelSkipChannel() : ModelCommand("skip-channel") { - AddArgument("Count", 0, UINT16_MAX, &mCount); + AddArgument("Count", 0, UINT16_MAX, &mRequest.count); ModelCommand::AddArguments(); } - ~TvChannelSkipChannel() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0504) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000504) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::TvChannelCluster cluster; cluster.Associate(device, endpointId); - return cluster.SkipChannel(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mCount); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mCount; + chip::app::Clusters::TvChannel::Commands::SkipChannel::Type mRequest; }; /* @@ -17894,33 +16688,22 @@ class TargetNavigatorNavigateTarget : public ModelCommand public: TargetNavigatorNavigateTarget() : ModelCommand("navigate-target") { - AddArgument("Target", 0, UINT8_MAX, &mTarget); - AddArgument("Data", &mData); + AddArgument("Target", 0, UINT8_MAX, &mRequest.target); + AddArgument("Data", &mRequest.data); ModelCommand::AddArguments(); } - ~TargetNavigatorNavigateTarget() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0505) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000505) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::TargetNavigatorCluster cluster; cluster.Associate(device, endpointId); - return cluster.NavigateTarget(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mTarget, mData); + return cluster.InvokeCommand(mRequest, this, OnTargetNavigatorNavigateTargetResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnTargetNavigatorClusterNavigateTargetResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mTarget; - chip::ByteSpan mData; + chip::app::Clusters::TargetNavigator::Commands::NavigateTarget::Type mRequest; }; /* @@ -18236,26 +17019,18 @@ class TestClusterTest : public ModelCommand { public: TestClusterTest() : ModelCommand("test") { ModelCommand::AddArguments(); } - ~TestClusterTest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.Test(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::TestCluster::Commands::Test::Type mRequest; }; /* @@ -18266,33 +17041,22 @@ class TestClusterTestAddArguments : public ModelCommand public: TestClusterTestAddArguments() : ModelCommand("test-add-arguments") { - AddArgument("Arg1", 0, UINT8_MAX, &mArg1); - AddArgument("Arg2", 0, UINT8_MAX, &mArg2); + AddArgument("Arg1", 0, UINT8_MAX, &mRequest.arg1); + AddArgument("Arg2", 0, UINT8_MAX, &mRequest.arg2); ModelCommand::AddArguments(); } - ~TestClusterTestAddArguments() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestAddArguments(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mArg1, mArg2); + return cluster.InvokeCommand(mRequest, this, OnTestClusterTestAddArgumentsResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnTestClusterClusterTestAddArgumentsResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mArg1; - uint8_t mArg2; + chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type mRequest; }; /* @@ -18303,30 +17067,21 @@ class TestClusterTestListInt8UArgumentRequest : public ModelCommand public: TestClusterTestListInt8UArgumentRequest() : ModelCommand("test-list-int8uargument-request") { - AddArgument("Arg1", 0, UINT8_MAX, &mArg1); + // arg1 Array parsing is not supported yet ModelCommand::AddArguments(); } - ~TestClusterTestListInt8UArgumentRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x0A) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x0000000A) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestListInt8UArgumentRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mArg1); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mArg1; + chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type mRequest; }; /* @@ -18337,31 +17092,21 @@ class TestClusterTestListInt8UReverseRequest : public ModelCommand public: TestClusterTestListInt8UReverseRequest() : ModelCommand("test-list-int8ureverse-request") { - AddArgument("Arg1", 0, UINT8_MAX, &mArg1); + // arg1 Array parsing is not supported yet ModelCommand::AddArguments(); } - ~TestClusterTestListInt8UReverseRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x0D) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x0000000D) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestListInt8UReverseRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mArg1); + return cluster.InvokeCommand(mRequest, this, OnTestClusterTestListInt8UReverseResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback( - OnTestClusterClusterTestListInt8UReverseResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mArg1; + chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseRequest::Type mRequest; }; /* @@ -18372,41 +17117,21 @@ class TestClusterTestListStructArgumentRequest : public ModelCommand public: TestClusterTestListStructArgumentRequest() : ModelCommand("test-list-struct-argument-request") { - AddArgument("A", 0, UINT8_MAX, &mA); - AddArgument("B", 0, 1, &mB); - AddArgument("C", 0, UINT8_MAX, &mC); - AddArgument("D", &mD); - AddArgument("E", &mE); - AddArgument("F", 0, UINT8_MAX, &mF); + // arg1 Array parsing is not supported yet ModelCommand::AddArguments(); } - ~TestClusterTestListStructArgumentRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x09) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x00000009) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestListStructArgumentRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mA, mB, mC, mD, mE, - mF); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mA; - bool mB; - uint8_t mC; - chip::ByteSpan mD; - chip::ByteSpan mE; - uint8_t mF; + chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type mRequest; }; /* @@ -18416,26 +17141,18 @@ class TestClusterTestNotHandled : public ModelCommand { public: TestClusterTestNotHandled() : ModelCommand("test-not-handled") { ModelCommand::AddArguments(); } - ~TestClusterTestNotHandled() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestNotHandled(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::TestCluster::Commands::TestNotHandled::Type mRequest; }; /* @@ -18445,27 +17162,18 @@ class TestClusterTestSpecific : public ModelCommand { public: TestClusterTestSpecific() : ModelCommand("test-specific") { ModelCommand::AddArguments(); } - ~TestClusterTestSpecific() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestSpecific(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnTestClusterTestSpecificResponseSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnTestClusterClusterTestSpecificResponse, - this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::TestCluster::Commands::TestSpecific::Type mRequest; }; /* @@ -18476,40 +17184,21 @@ class TestClusterTestStructArgumentRequest : public ModelCommand public: TestClusterTestStructArgumentRequest() : ModelCommand("test-struct-argument-request") { - AddArgument("A", 0, UINT8_MAX, &mA); - AddArgument("B", 0, 1, &mB); - AddArgument("C", 0, UINT8_MAX, &mC); - AddArgument("D", &mD); - AddArgument("E", &mE); - AddArgument("F", 0, UINT8_MAX, &mF); + // arg1 Struct parsing is not supported yet ModelCommand::AddArguments(); } - ~TestClusterTestStructArgumentRequest() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x07) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x00000007) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestStructArgumentRequest(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mA, mB, mC, mD, mE, mF); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mA; - bool mB; - uint8_t mC; - chip::ByteSpan mD; - chip::ByteSpan mE; - uint8_t mF; + chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type mRequest; }; /* @@ -18519,26 +17208,18 @@ class TestClusterTestUnknownCommand : public ModelCommand { public: TestClusterTestUnknownCommand() : ModelCommand("test-unknown-command") { ModelCommand::AddArguments(); } - ~TestClusterTestUnknownCommand() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x050F) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x0000050F) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::TestClusterCluster cluster; cluster.Associate(device, endpointId); - return cluster.TestUnknownCommand(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::TestCluster::Commands::TestUnknownCommand::Type mRequest; }; /* @@ -20191,26 +18872,18 @@ class ThermostatClearWeeklySchedule : public ModelCommand { public: ThermostatClearWeeklySchedule() : ModelCommand("clear-weekly-schedule") { ModelCommand::AddArguments(); } - ~ThermostatClearWeeklySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0201) command (0x03) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000201) command (0x00000003) on endpoint %" PRIu8, endpointId); chip::Controller::ThermostatCluster cluster; cluster.Associate(device, endpointId); - return cluster.ClearWeeklySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::Thermostat::Commands::ClearWeeklySchedule::Type mRequest; }; /* @@ -20220,26 +18893,18 @@ class ThermostatGetRelayStatusLog : public ModelCommand { public: ThermostatGetRelayStatusLog() : ModelCommand("get-relay-status-log") { ModelCommand::AddArguments(); } - ~ThermostatGetRelayStatusLog() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0201) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000201) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::ThermostatCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetRelayStatusLog(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::Thermostat::Commands::GetRelayStatusLog::Type mRequest; }; /* @@ -20250,32 +18915,25 @@ class ThermostatGetWeeklySchedule : public ModelCommand public: ThermostatGetWeeklySchedule() : ModelCommand("get-weekly-schedule") { - AddArgument("DaysToReturn", 0, UINT8_MAX, &mDaysToReturn); - AddArgument("ModeToReturn", 0, UINT8_MAX, &mModeToReturn); + AddArgument("DaysToReturn", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.daysToReturn)); + AddArgument( + "ModeToReturn", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.modeToReturn)); ModelCommand::AddArguments(); } - ~ThermostatGetWeeklySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0201) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000201) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::ThermostatCluster cluster; cluster.Associate(device, endpointId); - return cluster.GetWeeklySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mDaysToReturn, mModeToReturn); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mDaysToReturn; - uint8_t mModeToReturn; + chip::app::Clusters::Thermostat::Commands::GetWeeklySchedule::Type mRequest; }; /* @@ -20286,37 +18944,28 @@ class ThermostatSetWeeklySchedule : public ModelCommand public: ThermostatSetWeeklySchedule() : ModelCommand("set-weekly-schedule") { - AddArgument("NumberOfTransitionsForSequence", 0, UINT8_MAX, &mNumberOfTransitionsForSequence); - AddArgument("DayOfWeekForSequence", 0, UINT8_MAX, &mDayOfWeekForSequence); - AddArgument("ModeForSequence", 0, UINT8_MAX, &mModeForSequence); - AddArgument("Payload", 0, UINT8_MAX, &mPayload); + AddArgument("NumberOfTransitionsForSequence", 0, UINT8_MAX, &mRequest.numberOfTransitionsForSequence); + AddArgument( + "DayOfWeekForSequence", 0, UINT8_MAX, + reinterpret_cast *>(&mRequest.dayOfWeekForSequence)); + AddArgument("ModeForSequence", 0, UINT8_MAX, + reinterpret_cast *>( + &mRequest.modeForSequence)); + // payload Array parsing is not supported yet ModelCommand::AddArguments(); } - ~ThermostatSetWeeklySchedule() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0201) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000201) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::ThermostatCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetWeeklySchedule(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mNumberOfTransitionsForSequence, - mDayOfWeekForSequence, mModeForSequence, mPayload); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mNumberOfTransitionsForSequence; - uint8_t mDayOfWeekForSequence; - uint8_t mModeForSequence; - uint8_t mPayload; + chip::app::Clusters::Thermostat::Commands::SetWeeklySchedule::Type mRequest; }; /* @@ -20327,32 +18976,22 @@ class ThermostatSetpointRaiseLower : public ModelCommand public: ThermostatSetpointRaiseLower() : ModelCommand("setpoint-raise-lower") { - AddArgument("Mode", 0, UINT8_MAX, &mMode); - AddArgument("Amount", INT8_MIN, INT8_MAX, &mAmount); + AddArgument("Mode", 0, UINT8_MAX, reinterpret_cast *>(&mRequest.mode)); + AddArgument("Amount", INT8_MIN, INT8_MAX, &mRequest.amount); ModelCommand::AddArguments(); } - ~ThermostatSetpointRaiseLower() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0201) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000201) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::ThermostatCluster cluster; cluster.Associate(device, endpointId); - return cluster.SetpointRaiseLower(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mMode, mAmount); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mMode; - int8_t mAmount; + chip::app::Clusters::Thermostat::Commands::SetpointRaiseLower::Type mRequest; }; /* @@ -21605,26 +20244,18 @@ class ThreadNetworkDiagnosticsResetCounts : public ModelCommand { public: ThreadNetworkDiagnosticsResetCounts() : ModelCommand("reset-counts") { ModelCommand::AddArguments(); } - ~ThreadNetworkDiagnosticsResetCounts() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0035) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000035) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::ThreadNetworkDiagnosticsCluster cluster; cluster.Associate(device, endpointId); - return cluster.ResetCounts(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::ThreadNetworkDiagnostics::Commands::ResetCounts::Type mRequest; }; /* @@ -23916,26 +22547,18 @@ class WiFiNetworkDiagnosticsResetCounts : public ModelCommand { public: WiFiNetworkDiagnosticsResetCounts() : ModelCommand("reset-counts") { ModelCommand::AddArguments(); } - ~WiFiNetworkDiagnosticsResetCounts() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0036) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000036) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::WiFiNetworkDiagnosticsCluster cluster; cluster.Associate(device, endpointId); - return cluster.ResetCounts(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::WiFiNetworkDiagnostics::Commands::ResetCounts::Type mRequest; }; /* @@ -24455,26 +23078,18 @@ class WindowCoveringDownOrClose : public ModelCommand { public: WindowCoveringDownOrClose() : ModelCommand("down-or-close") { ModelCommand::AddArguments(); } - ~WindowCoveringDownOrClose() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0102) command (0x01) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000102) command (0x00000001) on endpoint %" PRIu8, endpointId); chip::Controller::WindowCoveringCluster cluster; cluster.Associate(device, endpointId); - return cluster.DownOrClose(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type mRequest; }; /* @@ -24485,33 +23100,22 @@ class WindowCoveringGoToLiftPercentage : public ModelCommand public: WindowCoveringGoToLiftPercentage() : ModelCommand("go-to-lift-percentage") { - AddArgument("LiftPercentageValue", 0, UINT8_MAX, &mLiftPercentageValue); - AddArgument("LiftPercent100thsValue", 0, UINT16_MAX, &mLiftPercent100thsValue); + AddArgument("LiftPercentageValue", 0, UINT8_MAX, &mRequest.liftPercentageValue); + AddArgument("LiftPercent100thsValue", 0, UINT16_MAX, &mRequest.liftPercent100thsValue); ModelCommand::AddArguments(); } - ~WindowCoveringGoToLiftPercentage() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0102) command (0x05) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000102) command (0x00000005) on endpoint %" PRIu8, endpointId); chip::Controller::WindowCoveringCluster cluster; cluster.Associate(device, endpointId); - return cluster.GoToLiftPercentage(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mLiftPercentageValue, - mLiftPercent100thsValue); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mLiftPercentageValue; - uint16_t mLiftPercent100thsValue; + chip::app::Clusters::WindowCovering::Commands::GoToLiftPercentage::Type mRequest; }; /* @@ -24522,30 +23126,21 @@ class WindowCoveringGoToLiftValue : public ModelCommand public: WindowCoveringGoToLiftValue() : ModelCommand("go-to-lift-value") { - AddArgument("LiftValue", 0, UINT16_MAX, &mLiftValue); + AddArgument("LiftValue", 0, UINT16_MAX, &mRequest.liftValue); ModelCommand::AddArguments(); } - ~WindowCoveringGoToLiftValue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0102) command (0x04) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000102) command (0x00000004) on endpoint %" PRIu8, endpointId); chip::Controller::WindowCoveringCluster cluster; cluster.Associate(device, endpointId); - return cluster.GoToLiftValue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mLiftValue); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mLiftValue; + chip::app::Clusters::WindowCovering::Commands::GoToLiftValue::Type mRequest; }; /* @@ -24556,33 +23151,22 @@ class WindowCoveringGoToTiltPercentage : public ModelCommand public: WindowCoveringGoToTiltPercentage() : ModelCommand("go-to-tilt-percentage") { - AddArgument("TiltPercentageValue", 0, UINT8_MAX, &mTiltPercentageValue); - AddArgument("TiltPercent100thsValue", 0, UINT16_MAX, &mTiltPercent100thsValue); + AddArgument("TiltPercentageValue", 0, UINT8_MAX, &mRequest.tiltPercentageValue); + AddArgument("TiltPercent100thsValue", 0, UINT16_MAX, &mRequest.tiltPercent100thsValue); ModelCommand::AddArguments(); } - ~WindowCoveringGoToTiltPercentage() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0102) command (0x08) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000102) command (0x00000008) on endpoint %" PRIu8, endpointId); chip::Controller::WindowCoveringCluster cluster; cluster.Associate(device, endpointId); - return cluster.GoToTiltPercentage(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mTiltPercentageValue, - mTiltPercent100thsValue); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint8_t mTiltPercentageValue; - uint16_t mTiltPercent100thsValue; + chip::app::Clusters::WindowCovering::Commands::GoToTiltPercentage::Type mRequest; }; /* @@ -24593,30 +23177,21 @@ class WindowCoveringGoToTiltValue : public ModelCommand public: WindowCoveringGoToTiltValue() : ModelCommand("go-to-tilt-value") { - AddArgument("TiltValue", 0, UINT16_MAX, &mTiltValue); + AddArgument("TiltValue", 0, UINT16_MAX, &mRequest.tiltValue); ModelCommand::AddArguments(); } - ~WindowCoveringGoToTiltValue() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0102) command (0x07) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000102) command (0x00000007) on endpoint %" PRIu8, endpointId); chip::Controller::WindowCoveringCluster cluster; cluster.Associate(device, endpointId); - return cluster.GoToTiltValue(onSuccessCallback->Cancel(), onFailureCallback->Cancel(), mTiltValue); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); - uint16_t mTiltValue; + chip::app::Clusters::WindowCovering::Commands::GoToTiltValue::Type mRequest; }; /* @@ -24626,26 +23201,18 @@ class WindowCoveringStopMotion : public ModelCommand { public: WindowCoveringStopMotion() : ModelCommand("stop-motion") { ModelCommand::AddArguments(); } - ~WindowCoveringStopMotion() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0102) command (0x02) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000102) command (0x00000002) on endpoint %" PRIu8, endpointId); chip::Controller::WindowCoveringCluster cluster; cluster.Associate(device, endpointId); - return cluster.StopMotion(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::WindowCovering::Commands::StopMotion::Type mRequest; }; /* @@ -24655,26 +23222,18 @@ class WindowCoveringUpOrOpen : public ModelCommand { public: WindowCoveringUpOrOpen() : ModelCommand("up-or-open") { ModelCommand::AddArguments(); } - ~WindowCoveringUpOrOpen() - { - delete onSuccessCallback; - delete onFailureCallback; - } CHIP_ERROR SendCommand(ChipDevice * device, uint8_t endpointId) override { - ChipLogProgress(chipTool, "Sending cluster (0x0102) command (0x00) on endpoint %" PRIu8, endpointId); + ChipLogProgress(chipTool, "Sending cluster (0x00000102) command (0x00000000) on endpoint %" PRIu8, endpointId); chip::Controller::WindowCoveringCluster cluster; cluster.Associate(device, endpointId); - return cluster.UpOrOpen(onSuccessCallback->Cancel(), onFailureCallback->Cancel()); + return cluster.InvokeCommand(mRequest, this, OnDefaultSuccess, OnDefaultFailure); } private: - chip::Callback::Callback * onSuccessCallback = - new chip::Callback::Callback(OnDefaultSuccessResponse, this); - chip::Callback::Callback * onFailureCallback = - new chip::Callback::Callback(OnDefaultFailureResponse, this); + chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type mRequest; }; /*