| /* |
| * |
| * Copyright (c) 2019 Google LLC. |
| * All rights reserved. |
| * |
| * 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. |
| */ |
| |
| #pragma once |
| |
| #include <app/clusters/door-lock-server/door-lock-server.h> |
| |
| #include <stdbool.h> |
| #include <stdint.h> |
| |
| #include "AppEvent.h" |
| |
| #include "FreeRTOS.h" |
| #include "timers.h" // provides FreeRTOS timer support |
| |
| #include <lib/core/CHIPError.h> |
| |
| struct WeekDaysScheduleInfo |
| { |
| DlScheduleStatus status; |
| EmberAfPluginDoorLockWeekDaySchedule schedule; |
| }; |
| |
| struct YearDayScheduleInfo |
| { |
| DlScheduleStatus status; |
| EmberAfPluginDoorLockYearDaySchedule schedule; |
| }; |
| |
| struct HolidayScheduleInfo |
| { |
| DlScheduleStatus status; |
| EmberAfPluginDoorLockHolidaySchedule schedule; |
| }; |
| |
| namespace P6DoorLock { |
| namespace ResourceRanges { |
| // Used to size arrays |
| static constexpr uint16_t kMaxUsers = 10; |
| static constexpr uint8_t kMaxCredentialsPerUser = 10; |
| static constexpr uint8_t kMaxWeekdaySchedulesPerUser = 10; |
| static constexpr uint8_t kMaxYeardaySchedulesPerUser = 10; |
| static constexpr uint8_t kMaxHolidaySchedules = 10; |
| static constexpr uint8_t kMaxCredentialSize = 20; |
| static constexpr uint8_t kNumCredentialTypes = 6; |
| |
| static constexpr uint8_t kMaxCredentials = kMaxUsers * kMaxCredentialsPerUser; |
| } // namespace ResourceRanges |
| |
| namespace LockInitParams { |
| |
| struct LockParam |
| { |
| // Read from zap attributes |
| uint16_t numberOfUsers = 0; |
| uint8_t numberOfCredentialsPerUser = 0; |
| uint8_t numberOfWeekdaySchedulesPerUser = 0; |
| uint8_t numberOfYeardaySchedulesPerUser = 0; |
| uint8_t numberOfHolidaySchedules = 0; |
| }; |
| |
| class ParamBuilder |
| { |
| public: |
| ParamBuilder & SetNumberOfUsers(uint16_t numberOfUsers) |
| { |
| lockParam_.numberOfUsers = numberOfUsers; |
| return *this; |
| } |
| ParamBuilder & SetNumberOfCredentialsPerUser(uint8_t numberOfCredentialsPerUser) |
| { |
| lockParam_.numberOfCredentialsPerUser = numberOfCredentialsPerUser; |
| return *this; |
| } |
| ParamBuilder & SetNumberOfWeekdaySchedulesPerUser(uint8_t numberOfWeekdaySchedulesPerUser) |
| { |
| lockParam_.numberOfWeekdaySchedulesPerUser = numberOfWeekdaySchedulesPerUser; |
| return *this; |
| } |
| ParamBuilder & SetNumberOfYeardaySchedulesPerUser(uint8_t numberOfYeardaySchedulesPerUser) |
| { |
| lockParam_.numberOfYeardaySchedulesPerUser = numberOfYeardaySchedulesPerUser; |
| return *this; |
| } |
| ParamBuilder & SetNumberOfHolidaySchedules(uint8_t numberOfHolidaySchedules) |
| { |
| lockParam_.numberOfHolidaySchedules = numberOfHolidaySchedules; |
| return *this; |
| } |
| LockParam GetLockParam() { return lockParam_; } |
| |
| private: |
| LockParam lockParam_; |
| }; |
| |
| } // namespace LockInitParams |
| } // namespace P6DoorLock |
| |
| using namespace ::chip; |
| using namespace P6DoorLock::ResourceRanges; |
| |
| class LockManager |
| { |
| public: |
| enum Action_t |
| { |
| LOCK_ACTION = 0, |
| UNLOCK_ACTION, |
| |
| INVALID_ACTION |
| } Action; |
| |
| enum State_t |
| { |
| kState_LockInitiated = 0, |
| kState_LockCompleted, |
| kState_UnlockInitiated, |
| kState_UnlockCompleted, |
| } State; |
| |
| CHIP_ERROR Init(chip::app::DataModel::Nullable<chip::app::Clusters::DoorLock::DlLockState> state, |
| P6DoorLock::LockInitParams::LockParam lockParam); |
| bool NextState(); |
| bool IsActionInProgress(); |
| bool InitiateAction(int32_t aActor, Action_t aAction); |
| |
| typedef void (*Callback_fn_initiated)(Action_t, int32_t aActor); |
| typedef void (*Callback_fn_completed)(Action_t); |
| void SetCallbacks(Callback_fn_initiated aActionInitiated_CB, Callback_fn_completed aActionCompleted_CB); |
| |
| bool Lock(chip::EndpointId endpointId, const Optional<chip::ByteSpan> & pin, OperationErrorEnum & err); |
| bool Unlock(chip::EndpointId endpointId, const Optional<chip::ByteSpan> & pin, OperationErrorEnum & err); |
| |
| bool GetUser(chip::EndpointId endpointId, uint16_t userIndex, EmberAfPluginDoorLockUserInfo & user); |
| bool SetUser(chip::EndpointId endpointId, uint16_t userIndex, chip::FabricIndex creator, chip::FabricIndex modifier, |
| const chip::CharSpan & userName, uint32_t uniqueId, UserStatusEnum userStatus, UserTypeEnum usertype, |
| CredentialRuleEnum credentialRule, const CredentialStruct * credentials, size_t totalCredentials); |
| |
| bool GetCredential(chip::EndpointId endpointId, uint16_t credentialIndex, CredentialTypeEnum credentialType, |
| EmberAfPluginDoorLockCredentialInfo & credential); |
| |
| bool SetCredential(chip::EndpointId endpointId, uint16_t credentialIndex, chip::FabricIndex creator, chip::FabricIndex modifier, |
| DlCredentialStatus credentialStatus, CredentialTypeEnum credentialType, |
| const chip::ByteSpan & credentialData); |
| |
| DlStatus GetWeekdaySchedule(chip::EndpointId endpointId, uint8_t weekdayIndex, uint16_t userIndex, |
| EmberAfPluginDoorLockWeekDaySchedule & schedule); |
| |
| DlStatus SetWeekdaySchedule(chip::EndpointId endpointId, uint8_t weekdayIndex, uint16_t userIndex, DlScheduleStatus status, |
| DaysMaskMap daysMask, uint8_t startHour, uint8_t startMinute, uint8_t endHour, uint8_t endMinute); |
| |
| DlStatus GetYeardaySchedule(chip::EndpointId endpointId, uint8_t yearDayIndex, uint16_t userIndex, |
| EmberAfPluginDoorLockYearDaySchedule & schedule); |
| |
| DlStatus SetYeardaySchedule(chip::EndpointId endpointId, uint8_t yearDayIndex, uint16_t userIndex, DlScheduleStatus status, |
| uint32_t localStartTime, uint32_t localEndTime); |
| |
| DlStatus GetHolidaySchedule(chip::EndpointId endpointId, uint8_t holidayIndex, EmberAfPluginDoorLockHolidaySchedule & schedule); |
| |
| DlStatus SetHolidaySchedule(chip::EndpointId endpointId, uint8_t holidayIndex, DlScheduleStatus status, uint32_t localStartTime, |
| uint32_t localEndTime, OperatingModeEnum operatingMode); |
| |
| bool IsValidUserIndex(uint16_t userIndex); |
| bool IsValidCredentialType(CredentialTypeEnum type); |
| bool IsValidCredentialIndex(uint16_t credentialIndex, CredentialTypeEnum type); |
| bool IsValidWeekdayScheduleIndex(uint8_t scheduleIndex); |
| bool IsValidYeardayScheduleIndex(uint8_t scheduleIndex); |
| bool IsValidHolidayScheduleIndex(uint8_t scheduleIndex); |
| |
| bool setLockState(chip::EndpointId endpointId, DlLockState lockState, const Optional<chip::ByteSpan> & pin, |
| OperationErrorEnum & err); |
| const char * lockStateToString(DlLockState lockState) const; |
| |
| bool ReadConfigValues(); |
| |
| private: |
| friend LockManager & LockMgr(); |
| chip::EndpointId mEndpointId; |
| State_t mState; |
| |
| Callback_fn_initiated mActionInitiated_CB; |
| Callback_fn_completed mActionCompleted_CB; |
| |
| void CancelTimer(void); |
| void StartTimer(uint32_t aTimeoutMs); |
| |
| static void TimerEventHandler(TimerHandle_t xTimer); |
| static void AutoLockTimerEventHandler(AppEvent * aEvent); |
| static void ActuatorMovementTimerEventHandler(AppEvent * aEvent); |
| |
| EmberAfPluginDoorLockUserInfo mLockUsers[kMaxUsers]; |
| EmberAfPluginDoorLockCredentialInfo mLockCredentials[kNumCredentialTypes][kMaxCredentials]; |
| WeekDaysScheduleInfo mWeekdaySchedule[kMaxUsers][kMaxWeekdaySchedulesPerUser]; |
| YearDayScheduleInfo mYeardaySchedule[kMaxUsers][kMaxYeardaySchedulesPerUser]; |
| HolidayScheduleInfo mHolidaySchedule[kMaxHolidaySchedules]; |
| |
| char mUserNames[ArraySize(mLockUsers)][DOOR_LOCK_MAX_USER_NAME_SIZE]; |
| uint8_t mCredentialData[kNumCredentialTypes][kMaxCredentials][kMaxCredentialSize]; |
| CredentialStruct mCredentials[kMaxUsers][kMaxCredentials]; |
| |
| static LockManager sLock; |
| P6DoorLock::LockInitParams::LockParam LockParams; |
| }; |
| |
| inline LockManager & LockMgr() |
| { |
| return LockManager::sLock; |
| } |