Skip to content

Commit

Permalink
Address followup issues for preset/atomic-write implementation. (proj…
Browse files Browse the repository at this point in the history
…ect-chip#35175)

* Puts some file-local functions in an anonymous namespace.
* Fixes the "is this attribute supported?" check to correctly check for global
  attributes that are not in Ember metadata.
* Moves the comment explaining why it's OK to skip the spec-required ACL check
  to the place where that check is being skipped.
* Removes a non-spec-compliant "error if the timeout is 0" bit.

Fixes project-chip#35168
  • Loading branch information
bzbarsky-apple authored and PeterC1965 committed Aug 28, 2024
1 parent 265d5b3 commit c21ee45
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 11 deletions.
13 changes: 13 additions & 0 deletions src/app/GlobalAttributes.h
Original file line number Diff line number Diff line change
Expand Up @@ -40,5 +40,18 @@ constexpr AttributeId GlobalAttributesNotInMetadata[] = {

static_assert(ArrayIsSorted(GlobalAttributesNotInMetadata), "Array of global attribute ids must be sorted");

inline bool IsSupportedGlobalAttributeNotInMetadata(AttributeId attributeId)
{
for (auto & attr : GlobalAttributesNotInMetadata)
{
if (attr == attributeId)
{
return true;
}
}

return false;
}

} // namespace app
} // namespace chip
31 changes: 20 additions & 11 deletions src/app/clusters/thermostat-server/thermostat-server-atomic.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@

#include "thermostat-server.h"

#include <app/GlobalAttributes.h>
#include <platform/internal/CHIPDeviceLayerInternal.h>

using namespace chip;
Expand Down Expand Up @@ -47,6 +48,8 @@ void TimerExpiredCallback(System::Layer * systemLayer, void * callbackContext)
gThermostatAttrAccess.ResetAtomicWrite(endpoint);
}

namespace {

/**
* @brief Schedules a timer for the given timeout in milliseconds.
*
Expand Down Expand Up @@ -185,15 +188,25 @@ Status BuildAttributeStatuses(const EndpointId endpoint, const DataModel::Decoda
const EmberAfAttributeMetadata * metadata =
emberAfLocateAttributeMetadata(endpoint, Thermostat::Id, attributeStatus.attributeID);

if (metadata == nullptr)
if (metadata != nullptr)
{
// This is definitely an attribute we know about.
continue;
}

if (IsSupportedGlobalAttributeNotInMetadata(attributeStatus.attributeID))
{
// This is not a valid attribute on the Thermostat cluster on the supplied endpoint
return Status::InvalidCommand;
continue;
}

// This is not a valid attribute on the Thermostat cluster on the supplied endpoint
return Status::InvalidCommand;
}
return Status::Success;
}

} // anonymous namespace

bool ThermostatAttrAccess::InAtomicWrite(EndpointId endpoint, Optional<AttributeId> attributeId)
{

Expand Down Expand Up @@ -422,6 +435,10 @@ void ThermostatAttrAccess::BeginAtomicWrite(CommandHandler * commandObj, const C
status = Status::Success;
for (size_t i = 0; i < attributeStatuses.AllocatedSize(); ++i)
{
// If we've gotten this far, then the client has manage permission to call AtomicRequest,
// which is also the privilege necessary to write to the atomic attributes, so no need to do
// the "If the client does not have sufficient privilege to write to the attribute" check
// from the spec.
auto & attributeStatus = attributeStatuses[i];
auto statusCode = Status::Success;
switch (attributeStatus.attributeID)
Expand All @@ -442,11 +459,6 @@ void ThermostatAttrAccess::BeginAtomicWrite(CommandHandler * commandObj, const C
}

auto timeout = std::min(System::Clock::Milliseconds16(commandData.timeout.Value()), maximumTimeout);
if (timeout.count() == 0)
{
commandObj->AddStatus(commandPath, Status::InvalidInState);
return;
}

if (status == Status::Success)
{
Expand Down Expand Up @@ -605,9 +617,6 @@ bool emberAfThermostatClusterAtomicRequestCallback(CommandHandler * commandObj,
{
auto & requestType = commandData.requestType;

// If we've gotten this far, then the client has manage permission to call AtomicRequest, which is also the
// privilege necessary to write to the atomic attributes, so no need to check

switch (requestType)
{
case Globals::AtomicRequestTypeEnum::kBeginWrite:
Expand Down

0 comments on commit c21ee45

Please sign in to comment.