diff --git a/src/app/clusters/time-synchronization-server/time-synchronization-server.cpp b/src/app/clusters/time-synchronization-server/time-synchronization-server.cpp index c7c79f3d1fc499..870cd9593bd510 100644 --- a/src/app/clusters/time-synchronization-server/time-synchronization-server.cpp +++ b/src/app/clusters/time-synchronization-server/time-synchronization-server.cpp @@ -300,26 +300,18 @@ void TimeSynchronizationServer::AttemptToGetFallbackNTPTimeFromDelegate() void TimeSynchronizationServer::OnDeviceConnectedFn(Messaging::ExchangeManager & exchangeMgr, const SessionHandle & sessionHandle) { // Connected to our trusted time source, let's read the time. - app::AttributePathParams readPaths[2]; - readPaths[0] = app::AttributePathParams(kRootEndpointId, app::Clusters::TimeSynchronization::Id, - app::Clusters::TimeSynchronization::Attributes::UTCTime::Id); - readPaths[1] = app::AttributePathParams(kRootEndpointId, app::Clusters::TimeSynchronization::Id, - app::Clusters::TimeSynchronization::Attributes::Granularity::Id); - - app::InteractionModelEngine * engine = app::InteractionModelEngine::GetInstance(); - app::ReadPrepareParams readParams(sessionHandle); + AttributePathParams readPaths[2]; + readPaths[0] = AttributePathParams(kRootEndpointId, Id, Attributes::UTCTime::Id); + readPaths[1] = AttributePathParams(kRootEndpointId, Id, Attributes::Granularity::Id); + + InteractionModelEngine * engine = InteractionModelEngine::GetInstance(); + ReadPrepareParams readParams(sessionHandle); readParams.mpAttributePathParamsList = readPaths; readParams.mAttributePathParamsListSize = 2; - auto attributeCache = Platform::MakeUnique(*this); - if (attributeCache == nullptr) - { - // This is unlikely to work if we don't have memory, but let's try - OnDeviceConnectionFailureFn(); - return; - } - auto readClient = chip::Platform::MakeUnique(engine, &exchangeMgr, attributeCache->GetBufferedCallback(), - app::ReadClient::InteractionType::Read); + mTrustedNodeUtcTime.SetNull(); + mTrustedNodeGranularity = GranularityEnum::kNoTimeGranularity; + auto readClient = Platform::MakeUnique(engine, &exchangeMgr, *this, ReadClient::InteractionType::Read); if (readClient == nullptr) { // This is unlikely to work if we don't have memory, but let's try @@ -333,8 +325,7 @@ void TimeSynchronizationServer::OnDeviceConnectedFn(Messaging::ExchangeManager & OnDeviceConnectionFailureFn(); return; } - mAttributeCache = std::move(attributeCache); - mReadClient = std::move(readClient); + mReadClient = std::move(readClient); } void TimeSynchronizationServer::OnDeviceConnectionFailureFn() @@ -343,20 +334,39 @@ void TimeSynchronizationServer::OnDeviceConnectionFailureFn() AttemptToGetFallbackNTPTimeFromDelegate(); } -void TimeSynchronizationServer::OnDone(ReadClient * apReadClient) +void TimeSynchronizationServer::OnAttributeData(const ConcreteDataAttributePath & aPath, TLV::TLVReader * apData, + const StatusIB & aStatus) { - using namespace chip::app::Clusters::TimeSynchronization::Attributes; - - Granularity::TypeInfo::Type granularity = GranularityEnum::kNoTimeGranularity; - mAttributeCache->Get(kRootEndpointId, granularity); + if (aPath.mClusterId != Id || aStatus.IsFailure()) + { + return; + } + switch (aPath.mAttributeId) + { + case Attributes::UTCTime::Id: + if (DataModel::Decode(*apData, mTrustedNodeUtcTime) != CHIP_NO_ERROR) + { + mTrustedNodeUtcTime.SetNull(); + } + break; + case Attributes::Granularity::Id: + if (DataModel::Decode(*apData, mTrustedNodeGranularity) != CHIP_NO_ERROR) + { + mTrustedNodeGranularity = GranularityEnum::kNoTimeGranularity; + } + break; + default: + break; + } +} - UTCTime::TypeInfo::Type time; - CHIP_ERROR err = mAttributeCache->Get(kRootEndpointId, time); - if (err == CHIP_NO_ERROR && !time.IsNull() && granularity != GranularityEnum::kNoTimeGranularity) +void TimeSynchronizationServer::OnDone(ReadClient * apReadClient) +{ + if (!mTrustedNodeUtcTime.IsNull() && mTrustedNodeGranularity != GranularityEnum::kNoTimeGranularity) { GranularityEnum ourGranularity; // Being conservative with granularity - nothing smaller than seconds because of network delay - switch (granularity) + switch (mTrustedNodeGranularity) { case GranularityEnum::kMinutesGranularity: case GranularityEnum::kSecondsGranularity: @@ -367,7 +377,7 @@ void TimeSynchronizationServer::OnDone(ReadClient * apReadClient) break; } - err = SetUTCTime(kRootEndpointId, time.Value(), ourGranularity, TimeSourceEnum::kNodeTimeCluster); + CHIP_ERROR err = SetUTCTime(kRootEndpointId, mTrustedNodeUtcTime.Value(), ourGranularity, TimeSourceEnum::kNodeTimeCluster); if (err == CHIP_NO_ERROR) { return; @@ -377,6 +387,7 @@ void TimeSynchronizationServer::OnDone(ReadClient * apReadClient) // If we failed to set the UTC time, it doesn't hurt to try the backup - NTP system might have different permissions on the // system clock AttemptToGetFallbackNTPTimeFromDelegate(); + mReadClient = nullptr; } #endif diff --git a/src/app/clusters/time-synchronization-server/time-synchronization-server.h b/src/app/clusters/time-synchronization-server/time-synchronization-server.h index b17fd0f880e1e7..bd319cf4f1e467 100644 --- a/src/app/clusters/time-synchronization-server/time-synchronization-server.h +++ b/src/app/clusters/time-synchronization-server/time-synchronization-server.h @@ -72,7 +72,7 @@ enum class TimeSyncEventFlag : uint8_t class TimeSynchronizationServer : public FabricTable::Delegate #if TIME_SYNC_ENABLE_TSC_FEATURE , - public ClusterStateCache::Callback + public ReadClient::Callback #endif { public: @@ -117,8 +117,8 @@ class TimeSynchronizationServer : public FabricTable::Delegate void OnDeviceConnectedFn(Messaging::ExchangeManager & exchangeMgr, const SessionHandle & sessionHandle); void OnDeviceConnectionFailureFn(); - // AttributeCache::Callback functions - void OnAttributeChanged(ClusterStateCache * cache, const ConcreteAttributePath & path) override {} + // ReadClient::Callback functions + void OnAttributeData(const ConcreteDataAttributePath & aPath, TLV::TLVReader * apData, const StatusIB & aStatus) override; void OnDone(ReadClient * apReadClient) override; #endif @@ -142,10 +142,11 @@ class TimeSynchronizationServer : public FabricTable::Delegate static TimeSynchronizationServer sTimeSyncInstance; TimeSyncEventFlag mEventFlag = TimeSyncEventFlag::kNone; #if TIME_SYNC_ENABLE_TSC_FEATURE - Platform::UniquePtr mAttributeCache; - Platform::UniquePtr mReadClient; chip::Callback::Callback mOnDeviceConnectedCallback; chip::Callback::Callback mOnDeviceConnectionFailureCallback; + Attributes::UTCTime::TypeInfo::DecodableType mTrustedNodeUtcTime; + Attributes::Granularity::TypeInfo::DecodableType mTrustedNodeGranularity; + Platform::UniquePtr mReadClient; #endif chip::Callback::Callback mOnTimeSyncCompletion; chip::Callback::Callback mOnFallbackNTPCompletion;