| /* |
| * |
| * <COPYRIGHT> |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| /** |
| * @file |
| * Defines the chip Device Layer TimeSyncManager object. |
| * |
| */ |
| |
| #ifndef TIME_SYNC_MANAGER_H |
| #define TIME_SYNC_MANAGER_H |
| |
| namespace chip { |
| namespace Profiles { |
| namespace StatusReporting { |
| class StatusReport; |
| } |
| } |
| } |
| |
| namespace chip { |
| namespace DeviceLayer { |
| |
| class PlatformManagerImpl; |
| namespace Internal { |
| extern CHIP_ERROR InitServiceDirectoryManager(void); |
| template<class> class GenericPlatformManagerImpl; |
| template<class> class GenericPlatformManagerImpl_FreeRTOS; |
| } |
| |
| /** |
| * Manages time synchronization for chip Devices. |
| */ |
| class TimeSyncManager final |
| { |
| public: |
| |
| // ===== Members that define the public interface of the TimeSyncManager |
| |
| enum TimeSyncMode |
| { |
| kTimeSyncMode_NotSupported = 0, |
| kTimeSyncMode_Disabled = 1, |
| kTimeSyncMode_Service = 2, |
| |
| kTimeSyncMode_Max, |
| }; |
| |
| TimeSyncMode GetMode(); |
| CHIP_ERROR SetMode(TimeSyncMode newMode); |
| |
| uint32_t GetSyncInterval(); |
| void SetSyncInterval(uint32_t intervalSec); |
| |
| bool IsTimeSynchronized(); |
| |
| private: |
| |
| // ===== Members for internal use by the following friends. |
| |
| friend class PlatformManagerImpl; |
| template<class> friend class Internal::GenericPlatformManagerImpl; |
| template<class> friend class Internal::GenericPlatformManagerImpl_FreeRTOS; |
| friend CHIP_ERROR Internal::InitServiceDirectoryManager(); |
| friend TimeSyncManager & TimeSyncMgr(void); |
| |
| static TimeSyncManager sInstance; |
| |
| CHIP_ERROR Init(); |
| void OnPlatformEvent(const ChipDeviceEvent * event); |
| #if CHIP_DEVICE_CONFIG_ENABLE_SERVICE_DIRECTORY_TIME_SYNC |
| static void MarkServiceDirRequestStart(); |
| static void ProcessServiceDirTimeData(uint64_t timeQueryReceiptMsec, uint32_t timeProcessMsec); |
| #endif |
| |
| // ===== Private members for use by this class only. |
| |
| uint64_t mLastSyncTimeMS; // in monotonic time |
| #if CHIP_DEVICE_CONFIG_ENABLE_SERVICE_DIRECTORY_TIME_SYNC |
| uint64_t mServiceDirTimeSyncStartUS; |
| #endif |
| #if CHIP_DEVICE_CONFIG_ENABLE_CHIP_TIME_SERVICE_TIME_SYNC |
| ::chip::Binding * mTimeSyncBinding; |
| #endif |
| uint32_t mSyncIntervalSec; |
| TimeSyncMode mMode; |
| |
| void DriveTimeSync(); |
| void CancelTimeSync(); |
| void ApplySynchronizedTime(uint64_t syncedRealTimeUS); |
| void TimeSyncFailed(CHIP_ERROR reason, chip::Profiles::StatusReporting::StatusReport * statusReport); |
| |
| #if CHIP_DEVICE_CONFIG_ENABLE_CHIP_TIME_SERVICE_TIME_SYNC |
| static void TimeServiceSync_HandleBindingEvent(void * appState, ::chip::Binding::EventType event, |
| const ::chip::Binding::InEventParam & inParam, ::chip::Binding::OutEventParam & outParam); |
| static void TimeServiceSync_HandleSyncComplete(void * context, CHIP_ERROR result, int64_t syncedRealTimeUS); |
| #endif |
| |
| static void DriveTimeSync(::chip::System::Layer * layer, void * appState, ::chip::System::Error err); |
| |
| protected: |
| |
| // Construction/destruction limited to subclasses. |
| TimeSyncManager() = default; |
| ~TimeSyncManager() = default; |
| |
| // No copy, move or assignment. |
| TimeSyncManager(const TimeSyncManager &) = delete; |
| TimeSyncManager(const TimeSyncManager &&) = delete; |
| TimeSyncManager & operator=(const TimeSyncManager &) = delete; |
| }; |
| |
| inline TimeSyncManager::TimeSyncMode TimeSyncManager::GetMode() |
| { |
| return mMode; |
| } |
| |
| inline uint32_t TimeSyncManager::GetSyncInterval() |
| { |
| return mSyncIntervalSec; |
| } |
| |
| /** |
| * Returns a reference to the TimeSyncManager singleton object. |
| */ |
| inline TimeSyncManager & TimeSyncMgr(void) |
| { |
| return TimeSyncManager::sInstance; |
| } |
| |
| } // namespace DeviceLayer |
| } // namespace chip |
| |
| #endif // TIME_SYNC_MANAGER_H |