From 23242418c7e2f7dcbc4c09a696173c188b019610 Mon Sep 17 00:00:00 2001 From: fesseha-eve <88329315+fessehaeve@users.noreply.github.com> Date: Thu, 17 Aug 2023 18:59:35 +0200 Subject: [PATCH] clear dstoffset when DSTOffsetRequired is true (#28654) Co-authored-by: C Freeman --- .../time-synchronization-server.cpp | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) 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 9a1b2aa408bd59..f3a2d203c824fe 100644 --- a/src/app/clusters/time-synchronization-server/time-synchronization-server.cpp +++ b/src/app/clusters/time-synchronization-server/time-synchronization-server.cpp @@ -925,12 +925,6 @@ bool emberAfTimeSynchronizationClusterSetTimeZoneCallback( } else { - TimeState dstState = TimeSynchronizationServer::Instance().UpdateDSTOffsetState(); - TimeSynchronizationServer::Instance().ClearDSTOffset(); - if (dstState == TimeState::kActive || dstState == TimeState::kChanged) - { - emitDSTStatusEvent(commandPath.mEndpointId, false); - } response.DSTOffsetRequired = true; } } @@ -938,6 +932,17 @@ bool emberAfTimeSynchronizationClusterSetTimeZoneCallback( { response.DSTOffsetRequired = true; } + + if (response.DSTOffsetRequired) + { + TimeState dstState = TimeSynchronizationServer::Instance().UpdateDSTOffsetState(); + TimeSynchronizationServer::Instance().ClearDSTOffset(); + if (dstState == TimeState::kActive || dstState == TimeState::kChanged) + { + emitDSTStatusEvent(commandPath.mEndpointId, false); + } + } + commandObj->AddResponse(commandPath, response); return true; }