nRF5 SDK for Thread and Zigbee v3.2.0
Macros
Door Lock

Macros

#define ZB_HA_DEVICE_VER_DOOR_LOCK   0
 
#define ZB_HA_DECLARE_DOOR_LOCK_CLUSTER_LIST(cluster_list_name,door_lock_attr_list,basic_attr_list,identify_attr_list,groups_attr_list,scenes_attr_list)
 Declare cluster list for Door Lock device. More...
 
#define ZB_HA_DECLARE_DOOR_LOCK_EP(ep_name, ep_id, cluster_list)
 Declare endpointy for Door Lock device. More...
 
#define ZB_HA_DECLARE_DOOR_LOCK_CTX(device_ctx, ep_name)   ZBOSS_DECLARE_DEVICE_CTX_1_EP(device_ctx, ep_name)
 Declares Door Lock device context. More...
 

Detailed Description

Door Lock device has 5 clusters (see spec 7.4.11):

Door Lock device sample

Example
Declaring clusters
/******************* Declare attributes ************************/
/* Basic cluster attributes data */
zb_uint8_t g_attr_zcl_version = ZB_ZCL_VERSION;
ZB_ZCL_DECLARE_BASIC_ATTRIB_LIST(basic_attr_list, &g_attr_zcl_version, &g_attr_power_source);
/* Identify cluster attributes data */
zb_uint16_t g_attr_identify_time = 0;
ZB_ZCL_DECLARE_IDENTIFY_ATTRIB_LIST(identify_attr_list, &g_attr_identify_time);
/* Door Lock cluster attributes data */
ZB_ZCL_DECLARE_DOOR_LOCK_CLUSTER_ATTRIB_LIST(door_lock_attr_list,
&g_lock_state,
&g_lock_type,
&g_actuator_enabled);
/* Groups cluster attributes data */
zb_uint8_t g_attr_name_support = 0;
ZB_ZCL_DECLARE_GROUPS_ATTRIB_LIST(groups_attr_list, &g_attr_name_support);
/********************* Declare device **************************/
door_lock_attr_list,
basic_attr_list,
identify_attr_list,
groups_attr_list);
ZB_HA_DECLARE_DOOR_LOCK_EP(door_lock_ep, HA_DOOR_LOCK_ENDPOINT, door_lock_cluster);
ZB_HA_DECLARE_DOOR_LOCK_CTX(door_lock_ctx, door_lock_ep);
Registering device list
ZB_AF_REGISTER_DEVICE_CTX(&door_lock_ctx);
ZB_AF_SET_ENDPOINT_HANDLER(HA_DOOR_LOCK_ENDPOINT, zcl_specific_cluster_cmd_handler);
Example of command handler
zb_uint8_t zcl_specific_cluster_cmd_handler(zb_uint8_t param)
{
zb_buf_t *zcl_cmd_buf = (zb_buf_t *)ZB_BUF_FROM_REF(param);
zb_bool_t cmd_processed = ZB_FALSE;
zb_zcl_attr_t* attr_desc;
switch( cmd_info -> cluster_id )
{
if( cmd_info->is_common_command )
{
TRACE_MSG(TRACE_ZCL2, "Skip general command %hd", (FMT__H, cmd_info->cmd_id));
}
else
{
attr_desc = zb_zcl_get_attr_desc_a(ZB_ZCL_PARSED_HDR_SHORT_DATA(cmd_info).dst_endpoint,
switch( cmd_info->cmd_id )
{
TRACE_MSG(TRACE_ZCL3, "Got cluster command 0x%04x", (FMT__D, cmd_info->cmd_id));
TRACE_MSG(TRACE_ZCL1, "Cmd: ZB_ZCL_CMD_DOOR_LOCK_LOCK_DOOR", (FMT__0));
/* Process cluster command */
cmd_processed = ZB_TRUE;
/* For user: --- Command for door lock put here --- */
/* For user: --- Check and change attribute value --- */
/** [Send Door Lock response] */
ZB_ZCL_PARSED_HDR_SHORT_DATA(cmd_info).src_addr,
ZB_ZCL_PARSED_HDR_SHORT_DATA(cmd_info).src_endpoint,
ZB_ZCL_PARSED_HDR_SHORT_DATA(cmd_info).dst_endpoint,
cmd_info->profile_id,
cmd_info->seq_number,
status);
/** [Send Door Lock response] */
break;
TRACE_MSG(TRACE_ZCL1, "Cmd: ZB_ZCL_CMD_DOOR_LOCK_UNLOCK_DOOR", (FMT__0));
/* Process cluster command */
cmd_processed = ZB_TRUE;
/* For user: --- Command for door unlock put here --- */
/* For user: --- Check and change attribute value --- */
/** [Send Door Unlock response] */
ZB_ZCL_PARSED_HDR_SHORT_DATA(cmd_info).src_addr,
ZB_ZCL_PARSED_HDR_SHORT_DATA(cmd_info).src_endpoint,
ZB_ZCL_PARSED_HDR_SHORT_DATA(cmd_info).dst_endpoint,
cmd_info->profile_id,
cmd_info->seq_number,
status);
/** [Send Door Unlock response] */
break;
default:
TRACE_MSG(TRACE_ZCL2, "Cluster command %hd, skip it", (FMT__H, cmd_info->cmd_id));
break;
}
}
break;
default:
TRACE_MSG(TRACE_ZCL1, "SRV role, cluster 0x%d is not supported", (FMT__D, cmd_info->cluster_id));
break;
}
}

The complete set of Door Lock device samples can be found in /snippet/ha_door_lock_sample.c.

Macro Definition Documentation

#define ZB_HA_DECLARE_DOOR_LOCK_CLUSTER_LIST (   cluster_list_name,
  door_lock_attr_list,
  basic_attr_list,
  identify_attr_list,
  groups_attr_list,
  scenes_attr_list 
)

Declare cluster list for Door Lock device.

Parameters
cluster_list_name- cluster list variable name
door_lock_attr_list- attribute list for On/off switch configuration cluster
basic_attr_list- attribute list for Basic cluster
identify_attr_list- attribute list for Identify cluster
groups_attr_list- attribute list for Groups cluster
scenes_attr_list- attribute list for Scenes cluster
#define ZB_HA_DECLARE_DOOR_LOCK_CTX (   device_ctx,
  ep_name 
)    ZBOSS_DECLARE_DEVICE_CTX_1_EP(device_ctx, ep_name)

Declares Door Lock device context.

Parameters
device_ctx- device context variable name.
ep_name- endpoint variable name.
#define ZB_HA_DECLARE_DOOR_LOCK_EP (   ep_name,
  ep_id,
  cluster_list 
)
Value:
ZB_ZCL_DECLARE_DOOR_LOCK_SIMPLE_DESC(ep_name, ep_id, \
ZB_HA_DOOR_LOCK_IN_CLUSTER_NUM, ZB_HA_DOOR_LOCK_OUT_CLUSTER_NUM); \
ZBOSS_DEVICE_DECLARE_REPORTING_CTX(reporting_info## device_ctx_name, \
ZB_HA_DOOR_LOCK_REPORT_ATTR_COUNT); \
0, \
NULL, \
ZB_ZCL_ARRAY_SIZE(cluster_list, zb_zcl_cluster_desc_t), \
cluster_list, \
(zb_af_simple_desc_1_1_t*)&simple_desc_##ep_name, \
ZB_HA_DOOR_LOCK_REPORT_ATTR_COUNT, \
reporting_info## device_ctx_name, \
0, NULL)
ZCL cluster description.
Definition: zb_zcl_common.h:143
Definition: zboss_api_af.h:287
#define ZBOSS_DEVICE_DECLARE_REPORTING_CTX(rep_ctx, rep_count)
Definition: zboss_api_af.h:579
#define ZB_AF_DECLARE_ENDPOINT_DESC(ep_name,ep_id,profile_id,reserved_length,reserved_ptr,cluster_number,cluster_list,simple_desc,rep_count,rep_ctx,lev_ctrl_count,lev_ctrl_ctx)
Initialize endpoint descriptor.
Definition: zboss_api_af.h:490
Definition: zboss_api_af.h:201

Declare endpointy for Door Lock device.

Parameters
ep_name- endpoint variable name
ep_id- endpoint ID
cluster_list- endpoint cluster list
#define ZB_HA_DEVICE_VER_DOOR_LOCK   0

Door Lock device version


Documentation feedback | Developer Zone | Subscribe | Updated