Green Power Server#
Callbacks for Green Power Server Component.
Callbacks#
Green power server commissioning timeout callback.
Green power server pairing complete callback.
Sink table access notification callback.
Green power server commissioning callback.
Green power server security failure callback.
Green power server update involved TC callback.
Green power server notification forward callback.
Green power commissioning notification callback.
Sink commissioning enter call status notification callback.
Update alias information callback.
Green power server pairing complete callback.
Green power server update sink list callback.
Callbacks Documentation#
sl_zigbee_af_green_power_server_commissioning_timeout_cb#
void sl_zigbee_af_green_power_server_commissioning_timeout_cb (uint8_t commissioningTimeoutType, uint8_t numberOfEndpoints, uint8_t * endpoint)
Green power server commissioning timeout callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | commissioningTimeoutType | one of the types COMMISSIONING_TIMEOUT_TYPE_COMMISSIONING_WINDOW_TIMEOUT, COMMISSIONING_TIMEOUT_TYPE_GENERIC_SWITCH or COMMISSIONING_TIMEOUT_TYPE_MULTI_SENSOR Ver.: always | 
| uint8_t | N/A | numberOfEndpoints | Number of sink endpoints participated in the commissioning Ver.: always | 
| uint8_t * | N/A | endpoint | list of sink endpoints Ver.: always | 
This function is called by the Green Power Server upon expiration of any of the commissioning timers, which can be server commissioning window, generic switch commissioning, or multi-sensor commissioning timer expiration.
sl_zigbee_af_green_power_server_pairing_complete_cb#
void sl_zigbee_af_green_power_server_pairing_complete_cb (uint8_t numberOfEndpoints, uint8_t * endpoint)
Green power server pairing complete callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | numberOfEndpoints | number of sink endpoints participated in the pairing Ver.: always | 
| uint8_t * | N/A | endpoint | list of sink endpoints Ver.: always | 
This function is called by the Green Power Server upon the completion of the pairing to indicate the closure of the pairing session.
sl_zigbee_af_green_power_server_sink_table_access_notification_cb#
bool sl_zigbee_af_green_power_server_sink_table_access_notification_cb (void * data, sl_zigbee_af_gp_server_sink_table_access_type_t accessType)
Sink table access notification callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void * | N/A | data | void pointer to the data Ver.: always | 
| sl_zigbee_af_gp_server_sink_table_access_type_t | N/A | accessType | accessType Ver.: always | 
This function is called by the green power server plugin to notify the application about Green Power Device addition or removal by the green power server to the Sink Table. If returned false, the sink table remains un-accessed.
Returns
- true if the access is granted. 
sl_zigbee_af_green_power_server_gpd_commissioning_cb#
bool sl_zigbee_af_green_power_server_gpd_commissioning_cb (sl_zigbee_gp_application_info_t * appInfo, bool * matchFound)
Green power server commissioning callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_gp_application_info_t * | N/A | appInfo | Application information of the commissioning GPD. Ver.: always | 
| bool * | N/A | matchFound | Output flag to notify matching functionality. Ver.: always | 
This function is called by the green power server plugin to notify the application of a Green Power Device that has requested commissioning with this sink. Returns false if callback is not handled, true if callback is handled. When the callback is handled, it must set the matchFound argument appropriately to indicate if the matching functionality is found on the sink or not.
Returns
- true if application handled it Ver.: always 
sl_zigbee_af_green_power_server_gpd_security_failure_cb#
void sl_zigbee_af_green_power_server_gpd_security_failure_cb (sl_zigbee_gp_address_t * gpdAddr)
Green power server security failure callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_gp_address_t * | N/A | gpdAddr | Ver.: always | 
This function is called by the green power server plugin to notify the application of a Green Power Security Processing failed for an incoming notification.
sl_zigbee_af_green_power_server_update_involve_t_c_cb#
bool sl_zigbee_af_green_power_server_update_involve_t_c_cb (sl_status_t status)
Green power server update involved TC callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_status_t | N/A | status | Ver.: always | 
This function is called by the Green Power Server to proceed with updating the InvolveTC bit of the security level attribute.
Returns
- true if application handled it and plugin will not process it Ver.: always 
sl_zigbee_af_green_power_cluster_gp_notification_forward_cb#
bool sl_zigbee_af_green_power_cluster_gp_notification_forward_cb (uint16_t options, sl_zigbee_gp_address_t * addr, uint32_t gpdSecurityFrameCounter, uint8_t gpdCommandId, uint8_t * gpdCommandPayload, uint16_t gppShortAddress, uint8_t gppDistance)
Green power server notification forward callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint16_t | N/A | options | from the incoming Gp Notification Command Ver.: always | 
| sl_zigbee_gp_address_t * | N/A | addr | GPD address Ver.: always | 
| uint32_t | N/A | gpdSecurityFrameCounter | Ver.: always | 
| uint8_t | N/A | gpdCommandId | Ver.: always | 
| uint8_t * | N/A | gpdCommandPayload | first byte is length of the payload Ver.: always | 
| uint16_t | N/A | gppShortAddress | Ver.: always | 
| uint8_t | N/A | gppDistance | Ver.: always | 
This function is called by the green power server plugin to notify the application of a Green Power Gp Notification of an incoming gpd command. Return true to handle in application.
Returns
- true if application handled it and plugin will not process it anymore. else return false to process the notification by the plugin Ver.: always 
sl_zigbee_af_green_power_server_gpd_commissioning_notification_cb#
bool sl_zigbee_af_green_power_server_gpd_commissioning_notification_cb (uint8_t commandId, uint16_t commNotificationOptions, sl_zigbee_gp_address_t * gpdAddr, uint32_t gpdSecurityFrameCounter, uint8_t gpdCommandId, uint8_t * gpdCommandPayload, uint16_t gppShortAddress, int8_t rssi, uint8_t linkQuality, uint8_t gppDistance, uint32_t commissioningNotificationMic)
Green power commissioning notification callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | commandId | Ver.: always | 
| uint16_t | N/A | commNotificationOptions | Ver.: always | 
| sl_zigbee_gp_address_t * | N/A | gpdAddr | Ver.: always | 
| uint32_t | N/A | gpdSecurityFrameCounter | Ver.: always | 
| uint8_t | N/A | gpdCommandId | Ver.: always | 
| uint8_t * | N/A | gpdCommandPayload | Ver.: always | 
| uint16_t | N/A | gppShortAddress | Ver.: always | 
| int8_t | N/A | rssi | Ver.: always | 
| uint8_t | N/A | linkQuality | Ver.: always | 
| uint8_t | N/A | gppDistance | Ver.: always | 
| uint32_t | N/A | commissioningNotificationMic | Ver.: always | 
This function is called by the green power server plugin to notify the application about gp commissioning notification received by the sink. If the this function returns false indicating application does not handle the notification, the plugin will handle. If this returns true, the plugin will skip processing of the commissioning notification.
Returns
- true if application handles it and plugin will not process it anymore. else return false to process the notification by the plugin Ver.: always 
sl_zigbee_af_green_power_cluster_commissioning_message_status_notification_cb#
void sl_zigbee_af_green_power_cluster_commissioning_message_status_notification_cb (sl_zigbee_af_green_power_server_commissioning_state_t * commissioningState, sl_zigbee_aps_frame_t * apsFrame, sl_zigbee_outgoing_message_type_t messageType, uint16_t destination, sl_status_t status)
Sink commissioning enter call status notification callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_af_green_power_server_commissioning_state_t * | N/A | commissioningState | Sink commissioning state Ver.: always | 
| sl_zigbee_aps_frame_t * | N/A | apsFrame | aps frame header Ver.: always | 
| sl_zigbee_outgoing_message_type_t | N/A | messageType | unicast or broadcast Ver.: always | 
| uint16_t | N/A | destination | destination node Ver.: always | 
| sl_status_t | N/A | status | status of the network submission Ver.: always | 
This function is called by the green power server plugin from the sink commissioning enter command to notify the application of the status of the proxy commissioning enter message submission to network layer.
sl_zigbee_af_green_power_server_update_alias_cb#
bool sl_zigbee_af_green_power_server_update_alias_cb (sl_zigbee_gp_address_t * gpdAddr, uint16_t * alias)
Update alias information callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_gp_address_t * | N/A | gpdAddr | GPD address Ver.: always | 
| uint16_t * | N/A | alias | Ver.: always | 
This function is called by the green power server plugin during commissioning to update alias information from user.
Returns
- true if the alias is updated by the caller. 
sl_zigbee_af_green_power_server_pairing_status_cb#
void sl_zigbee_af_green_power_server_pairing_status_cb (sl_zigbee_sink_pairing_status_t status, sl_zigbee_commissioning_gpd_t * commissioningGpd)
Green power server pairing complete callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_sink_pairing_status_t | N/A | status | status of the pairing Ver.: always | 
| sl_zigbee_commissioning_gpd_t * | N/A | commissioningGpd | context of the GPD that is currently commissioning Ver.: always | 
This function is called by the Green Power Server plugin during the pairing process to indicate the status. This may be called multiple times for a single pairing session. This provides the status as well as the current GPD context. This callback can be monitored to get information in case a GPD commissioning that has started ended up in success or failure. This callback does not give any information about a commissioning GPDF that gets filtered out ealier in the commissioning processing.
sl_zigbee_af_green_power_server_pre_sink_pairing_cb#
void sl_zigbee_af_green_power_server_pre_sink_pairing_cb (sl_zigbee_commissioning_gpd_t * commissioningGpd)
Green power server update sink list callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_commissioning_gpd_t * | N/A | commissioningGpd | context of the GPD that is currently commissioning Ver.: always | 
This callback is called by the green power server at a final stagee during pairing process. At this point the commissioning sink is ready to be saved or updated into the sink table and GpPairing announcement. This callback is helpful to supply or update the associated parameters to the sink entry. For example, a sink application can update a group list groupcast comminication.