Door Lock Server#
API and Callbacks for the Door Lock Cluster Server Component.
Silicon Labs implementation of the Door Lock server cluster. This is an incomplete component implementation. It does all of the mandatory and optional behavior in the Door Lock cluster needed to pass the Door Lock cluster tests. It does not store user and schedule tables in persistent memory, check user pin activation against user status or user schedule, or offer callbacks and component options to the application for further customization of functionality.
Modules#
sl_zigbee_af_plugin_door_lock_server_log_entry_t
sl_zigbee_af_plugin_door_lock_server_user_t
sl_zigbee_af_plugin_door_lock_server_weekday_schedule_entry_t
sl_zigbee_af_plugin_door_lock_server_yearday_schedule_entry_t
sl_zigbee_af_plugin_door_lock_server_holiday_schedule_entry_t
sl_zigbee_af_plugin_door_lock_server_disposable_schedule_entry_t
API#
Add a log entry. Returns true if the entry was added. Note that the eventId parameter should be of type sl_zigbee_af_door_lock_operation_event_code_t or sl_zigbee_af_door_lock_programming_event_code_t.
Get a log entry associated with the entry ID. If the entry ID does not exist, the most recent entry is returned and the entryId parameter is updated. The entryId is a 1-based index into an array of log entries in order to match GetLogRecord ZCL command. This will return true if the entry was successfully returned.
Unlock the door with a pin.
Unlock the door with RFID.
Macros#
At boot, the NumberOfRFIDUsersSupported attribute will be written to this value.
This value should reflect the value of the MaxRFIDCodeLength attribute.
At boot, the NumberOfYearDaySchedulesSupportedPerUser attribute will be written to this value.
At boot, the NumberOfHolidaySchedulesSupported attribute will be written to this value.
This value should reflect the value of the NumberOfLogRecordsSupported attribute.
API Documentation#
sl_zigbee_af_door_lock_server_add_log_entry#
bool sl_zigbee_af_door_lock_server_add_log_entry (sl_zigbee_af_door_lock_event_type_t eventType, sl_zigbee_af_door_lock_event_source_t source, uint8_t eventId, uint16_t userId, uint8_t pinLength, uint8_t * pin)
Add a log entry. Returns true if the entry was added. Note that the eventId parameter should be of type sl_zigbee_af_door_lock_operation_event_code_t or sl_zigbee_af_door_lock_programming_event_code_t.
| Type | Direction | Argument Name | Description |
|---|---|---|---|
| sl_zigbee_af_door_lock_event_type_t | [in] | eventType | event type |
| sl_zigbee_af_door_lock_event_source_t | [in] | source | event source |
| uint8_t | [in] | eventId | event ID |
| uint16_t | [in] | userId | user ID |
| uint8_t | [in] | pinLength | pin length |
| uint8_t * | [in] | pin | pin |
Returns
bool True if the log entry was added.
sl_zigbee_af_door_lock_server_get_log_entry#
bool sl_zigbee_af_door_lock_server_get_log_entry (uint16_t * entryId, sl_zigbee_af_plugin_door_lock_server_log_entry_t * entry)
Get a log entry associated with the entry ID. If the entry ID does not exist, the most recent entry is returned and the entryId parameter is updated. The entryId is a 1-based index into an array of log entries in order to match GetLogRecord ZCL command. This will return true if the entry was successfully returned.
| Type | Direction | Argument Name | Description |
|---|---|---|---|
| uint16_t * | [inout] | entryId | pointer to the entry ID |
| sl_zigbee_af_plugin_door_lock_server_log_entry_t * | [out] | entry | pointer to log entry struct |
Returns
bool True if the command was successfully handled.
sl_zigbee_af_door_lock_server_apply_pin#
sl_zigbee_af_status_t sl_zigbee_af_door_lock_server_apply_pin (uint8_t * pin, uint8_t pinLength)
Unlock the door with a pin.
| Type | Direction | Argument Name | Description |
|---|---|---|---|
| uint8_t * | [in] | pin | pin to attempt |
| uint8_t | [in] | pinLength | pin length |
Returns
An sl_status_t value that indicates the success or failure of the API call. See sl_zigbee_af_write_server_attribute.
sl_zigbee_af_door_lock_server_apply_rfid#
sl_zigbee_af_status_t sl_zigbee_af_door_lock_server_apply_rfid (uint8_t * rfid, uint8_t rfidLength)
Unlock the door with RFID.
| Type | Direction | Argument Name | Description |
|---|---|---|---|
| uint8_t * | [in] | rfid | RFID to attempt |
| uint8_t | [in] | rfidLength | RFID length |
Returns
An sl_status_t value that indicates the success or failure of the API call. See sl_zigbee_af_write_server_attribute.