| {{> header}} |
| |
| // Prevent multiple inclusion |
| #pragma once |
| |
| #include <app-common/zap-generated/af-structs.h> |
| #include <app-common/zap-generated/cluster-objects.h> |
| #include <app/util/af-types.h> |
| #include <app/util/basic-types.h> |
| |
| #include <app/CommandHandler.h> |
| #include <app/CommandSender.h> |
| #include <app/ConcreteAttributePath.h> |
| #include <app/ConcreteCommandPath.h> |
| #include <lib/support/Span.h> |
| #include <protocols/interaction_model/Constants.h> |
| |
| /** @brief Cluster Init |
| * |
| * This function is called when a specific cluster is initialized. It gives the |
| * application an opportunity to take care of cluster initialization procedures. |
| * It is called exactly once for each endpoint where cluster is present. |
| * |
| * @param endpoint Ver.: always |
| * @param clusterId Ver.: always |
| */ |
| void emberAfClusterInitCallback(chip::EndpointId endpoint, chip::ClusterId clusterId); |
| |
| // Cluster Init Functions |
| |
| {{#zcl_clusters}} |
| |
| /** @brief {{label}} Cluster Init |
| * |
| * Cluster Init |
| * |
| * @param endpoint Endpoint that is being initialized |
| */ |
| void emberAf{{asUpperCamelCase label}}ClusterInitCallback(chip::EndpointId endpoint); |
| |
| {{/zcl_clusters}} |
| |
| // Cluster Server/Client Init Functions |
| |
| {{#zcl_clusters}} |
| |
| // |
| // {{label}} Cluster |
| // |
| |
| /** @brief {{label}} Cluster Server Init |
| * |
| * Server Init |
| * |
| * @param endpoint Endpoint that is being initialized |
| */ |
| void emberAf{{asUpperCamelCase label}}ClusterServerInitCallback(chip::EndpointId endpoint); |
| |
| /** @brief {{label}} Cluster Client Init |
| * |
| * Client Init |
| * |
| * @param endpoint Endpoint that is being initialized |
| */ |
| void emberAf{{asUpperCamelCase label}}ClusterClientInitCallback(chip::EndpointId endpoint); |
| |
| /** @brief {{label}} Cluster Server Attribute Changed |
| * |
| * Server Attribute Changed |
| * |
| * @param attributePath Concrete attribute path that changed |
| */ |
| void Matter{{asUpperCamelCase label}}ClusterServerAttributeChangedCallback(const chip::app::ConcreteAttributePath & attributePath); |
| |
| /** @brief {{label}} Cluster Server Message Sent |
| * |
| * Server Message Sent |
| * |
| * @param destination The destination to which the message was sent |
| * @param apsFrame The APS frame for the message |
| * @param msgLen The length of the message |
| * @param message The message that was sent |
| * @param status The status of the sent message |
| */ |
| void emberAf{{asUpperCamelCase label}}ClusterServerMessageSentCallback(const chip::MessageSendDestination & destination, EmberApsFrame * apsFrame, uint16_t msgLen, uint8_t * message, EmberStatus status); |
| |
| /** @brief {{label}} Cluster Client Message Sent |
| * |
| * Client Message Sent |
| * |
| * @param destination The destination to which the message was sent |
| * @param apsFrame The APS frame for the message |
| * @param msgLen The length of the message |
| * @param message The message that was sent |
| * @param status The status of the sent message |
| */ |
| void emberAf{{asUpperCamelCase label}}ClusterClientMessageSentCallback(const chip::MessageSendDestination & destination, EmberApsFrame * apsFrame, uint16_t msgLen, uint8_t * message, EmberStatus status); |
| |
| /** @brief {{label}} Cluster Server Pre Attribute Changed |
| * |
| * Server Pre Attribute Changed |
| * |
| * @param attributePath Concrete attribute path to be changed |
| * @param attributeType Attribute type |
| * @param size Attribute size |
| * @param value Attribute value |
| */ |
| chip::Protocols::InteractionModel::Status Matter{{asUpperCamelCase label}}ClusterServerPreAttributeChangedCallback(const chip::app::ConcreteAttributePath & attributePath, EmberAfAttributeType attributeType, uint16_t size, uint8_t * value); |
| |
| /** @brief {{label}} Cluster Client Pre Attribute Changed |
| * |
| * Client Pre Attribute Changed |
| * |
| * @param attributePath Concrete attribute path to be changed |
| * @param attributeType Attribute type |
| * @param size Attribute size |
| * @param value Attribute value |
| */ |
| chip::Protocols::InteractionModel::Status Matter{{asUpperCamelCase label}}ClusterClientPreAttributeChangedCallback(const chip::app::ConcreteAttributePath & attributePath, EmberAfAttributeType attributeType, uint16_t size, uint8_t * value); |
| |
| /** @brief {{label}} Cluster Server Tick |
| * |
| * Server Tick |
| * |
| * @param endpoint Endpoint that is being served |
| */ |
| void emberAf{{asUpperCamelCase label}}ClusterServerTickCallback(chip::EndpointId endpoint); |
| |
| /** @brief {{label}} Cluster Client Tick |
| * |
| * Client Tick |
| * |
| * @param endpoint Endpoint that is being served |
| */ |
| void emberAf{{asUpperCamelCase label}}ClusterClientTickCallback(chip::EndpointId endpoint); |
| |
| {{/zcl_clusters}} |
| |
| // Cluster Commands Callback |
| |
| {{#zcl_clusters}} |
| {{#zcl_commands}} |
| /** |
| * @brief {{parent.name}} Cluster {{name}} Command callback (from {{source}}) |
| */ |
| {{#if (isServer source)}} |
| bool emberAf{{asUpperCamelCase parent.label}}Cluster{{asUpperCamelCase name}}Callback(chip::EndpointId endpoint, |
| chip::app::CommandSender * commandObj |
| {{#zcl_command_arguments}}, {{#if isArray}}{{asUnderlyingZclType type}}{{else}}{{#if_is_struct type}}{{zapTypeToDecodableClusterObjectType type ns=parent.parent.label}}{{else}}{{asUnderlyingZclType type}}{{/if_is_struct}}{{/if}} {{asSymbol label}}{{/zcl_command_arguments}}); |
| {{else}} |
| bool emberAf{{asUpperCamelCase parent.label}}Cluster{{asUpperCamelCase name}}Callback(chip::app::CommandHandler * commandObj, |
| const chip::app::ConcreteCommandPath & commandPath, |
| const chip::app::Clusters::{{asUpperCamelCase parent.label}}::Commands::{{asUpperCamelCase name}}::DecodableType & commandData); |
| {{/if}} |
| {{/zcl_commands}} |
| {{/zcl_clusters}} |
| |
| /** @brief Add To Current App Tasks |
| * |
| * This function is only useful to sleepy end devices. This function will note |
| * the passed item as part of a set of tasks the application has outstanding |
| * (e.g. message sent requiring APS acknwoledgement). This will affect how the |
| * application behaves with regard to sleeping and polling. Until the |
| * outstanding task is completed, the device may poll more frequently and sleep |
| * less often. |
| */ |
| void emberAfAddToCurrentAppTasksCallback(EmberAfApplicationTask tasks); |
| |
| /** @brief Remove From Current App Tasks |
| * |
| * This function is only useful to sleepy end devices. This function will |
| * remove the passed item from the set of tasks the application has outstanding |
| * (e.g. message sent requiring APS acknwoledgement). This will affect how the |
| * application behaves with regard to sleeping and polling. Removing the item |
| * from the list of outstanding tasks may allow the device to sleep longer and |
| * poll less frequently. If there are other outstanding tasks the system may |
| * still have to stay away and poll more often. |
| */ |
| void emberAfRemoveFromCurrentAppTasksCallback(EmberAfApplicationTask tasks); |
| |
| /** @brief Allow Network Write Attribute |
| * |
| * This function is called by the application framework before it writes an |
| * attribute in response to a write attribute request from an external device. |
| * The value passed into this callback is the value to which the attribute is to |
| * be set by the framework. |
| Example: In mirroring simple metering data |
| * on an Energy Services Interface (ESI) (formerly called Energy Service Portal |
| * (ESP) in SE 1.0).), a mirrored simple meter needs to write read-only |
| * attributes on its mirror. The-meter-mirror sample application, located in |
| * app/framework/sample-apps, uses this callback to allow the mirrored device to |
| * write simple metering attributes on the mirror regardless of the fact that |
| * most simple metering attributes are defined as read-only by the ZigBee |
| * specification. |
| Note: The ZCL specification does not (as of this |
| * writing) specify any permission-level security for writing writeable |
| * attributes. As far as the ZCL specification is concerned, if an attribute is |
| * writeable, any device that has a link key for the device should be able to |
| * write that attribute. Furthermore if an attribute is read only, it should not |
| * be written over the air. Thus, if you implement permissions for writing |
| * attributes as a feature, you MAY be operating outside the specification. This |
| * is unlikely to be a problem for writing read-only attributes, but it may be a |
| * problem for attributes that are writeable according to the specification but |
| * restricted by the application implementing this callback. |
| */ |
| EmberAfAttributeWritePermission emberAfAllowNetworkWriteAttributeCallback(chip::EndpointId endpoint, chip::ClusterId clusterId, |
| chip::AttributeId attributeId, |
| uint8_t * value, uint8_t type); |
| |
| /** @brief Attribute Read Access |
| * |
| * This function is called whenever the Application Framework needs to check |
| * access permission for an attribute read. |
| */ |
| bool emberAfAttributeReadAccessCallback(chip::EndpointId endpoint, chip::ClusterId clusterId, chip::AttributeId attributeId); |
| |
| /** @brief Attribute Write Access |
| * |
| * This function is called whenever the Application Framework needs to check |
| * access permission for an attribute write. |
| */ |
| bool emberAfAttributeWriteAccessCallback(chip::EndpointId endpoint, chip::ClusterId clusterId, chip::AttributeId attributeId); |
| |
| /** @brief Default Response |
| * |
| * This function is called by the application framework when a Default Response |
| * command is received from an external device. The application should return |
| * true if the message was processed or false if it was not. |
| * |
| * @param clusterId The cluster identifier of this response. |
| * @param commandId The command identifier to which this is a response. |
| * @param status Specifies either SUCCESS or the nature of the error that was |
| * detected in the received command. |
| */ |
| bool emberAfDefaultResponseCallback(chip::ClusterId clusterId, chip::CommandId commandId, EmberAfStatus status); |
| |
| /** @brief Pre Message Send |
| * |
| * This function is called by the framework when it is about to pass a message |
| * to the stack primitives for sending. This message may or may not be ZCL, |
| * ZDO, or some other protocol. This is called prior to |
| any ZigBee |
| * fragmentation that may be done. If the function returns true it is assumed |
| * the callback has consumed and processed the message. The callback must also |
| * set the EmberStatus status code to be passed back to the caller. The |
| * framework will do no further processing on the message. |
| If the |
| * function returns false then it is assumed that the callback has not processed |
| * the mesasge and the framework will continue to process accordingly. |
| * |
| * @param messageStruct The structure containing the parameters of the APS |
| * message to be sent. |
| * @param status A pointer to the status code value that will be returned to the |
| * caller. |
| */ |
| bool emberAfPreMessageSendCallback(EmberAfMessageStruct * messageStruct, EmberStatus * status); |
| |
| /** @brief Message Sent |
| * |
| * This function is called by the application framework from the message sent |
| * handler, when it is informed by the stack regarding the message sent status. |
| * All of the values passed to the emberMessageSentHandler are passed on to this |
| * callback. This provides an opportunity for the application to verify that its |
| * message has been sent successfully and take the appropriate action. This |
| * callback should return a bool value of true or false. A value of true |
| * indicates that the message sent notification has been handled and should not |
| * be handled by the application framework. |
| */ |
| bool emberAfMessageSentCallback(const chip::MessageSendDestination & destination, EmberApsFrame * apsFrame, |
| uint16_t msgLen, uint8_t * message, EmberStatus status); |
| |
| /** @brief External Attribute Read |
| * |
| * Like emberAfExternalAttributeWriteCallback above, this function is called |
| * when the framework needs to read an attribute that is not stored within the |
| * Application Framework's data structures. |
| All of the important |
| * information about the attribute itself is passed as a pointer to an |
| * EmberAfAttributeMetadata struct, which is stored within the application and |
| * used to manage the attribute. A complete description of the |
| * EmberAfAttributeMetadata struct is provided in |
| * app/framework/include/af-types.h |
| This function assumes that the |
| * application is able to read the attribute, write it into the passed buffer, |
| * and return immediately. Any attributes that require a state machine for |
| * reading and writing are not really candidates for externalization at the |
| * present time. The Application Framework does not currently include a state |
| * machine for reading or writing attributes that must take place across a |
| * series of application ticks. Attributes that cannot be read in a timely |
| * manner should be stored within the Application Framework and updated |
| * occasionally by the application code from within the |
| * emberAfMainTickCallback. |
| If the application was successfully able to |
| * read the attribute and write it into the passed buffer, it should return a |
| * value of EMBER_ZCL_STATUS_SUCCESS. Ensure that the size of the externally |
| * managed attribute value is smaller than what the buffer can hold. In the case |
| * of a buffer overflow throw an appropriate error such as |
| * EMBER_ZCL_STATUS_INSUFFICIENT_SPACE. Any other return value indicates the |
| * application was not able to read the attribute. |
| */ |
| EmberAfStatus emberAfExternalAttributeReadCallback(chip::EndpointId endpoint, chip::ClusterId clusterId, |
| const EmberAfAttributeMetadata * attributeMetadata, |
| uint8_t * buffer, uint16_t maxReadLength); |
| |
| /** @brief External Attribute Write |
| * |
| * This function is called whenever the Application Framework needs to write an |
| * attribute which is not stored within the data structures of the Application |
| * Framework itself. One of the new features in Version 2 is the ability to |
| * store attributes outside the Framework. This is particularly useful for |
| * attributes that do not need to be stored because they can be read off the |
| * hardware when they are needed, or are stored in some central location used by |
| * many modules within the system. In this case, you can indicate that the |
| * attribute is stored externally. When the framework needs to write an external |
| * attribute, it makes a call to this callback. |
| This callback is very |
| * useful for host micros which need to store attributes in persistent memory. |
| * Because each host micro (used with an Ember NCP) has its own type of |
| * persistent memory storage, the Application Framework does not include the |
| * ability to mark attributes as stored in flash the way that it does for Ember |
| * SoCs like the EM35x. On a host micro, any attributes that need to be stored |
| * in persistent memory should be marked as external and accessed through the |
| * external read and write callbacks. Any host code associated with the |
| * persistent storage should be implemented within this callback. |
| All of |
| * the important information about the attribute itself is passed as a pointer |
| * to an EmberAfAttributeMetadata struct, which is stored within the application |
| * and used to manage the attribute. A complete description of the |
| * EmberAfAttributeMetadata struct is provided in |
| * app/framework/include/af-types.h. |
| This function assumes that the |
| * application is able to write the attribute and return immediately. Any |
| * attributes that require a state machine for reading and writing are not |
| * candidates for externalization at the present time. The Application Framework |
| * does not currently include a state machine for reading or writing attributes |
| * that must take place across a series of application ticks. Attributes that |
| * cannot be written immediately should be stored within the Application |
| * Framework and updated occasionally by the application code from within the |
| * emberAfMainTickCallback. |
| If the application was successfully able to |
| * write the attribute, it returns a value of EMBER_ZCL_STATUS_SUCCESS. Any |
| * other return value indicates the application was not able to write the |
| * attribute. |
| */ |
| EmberAfStatus emberAfExternalAttributeWriteCallback(chip::EndpointId endpoint, chip::ClusterId clusterId, |
| const EmberAfAttributeMetadata * attributeMetadata, |
| uint8_t * buffer); |
| |
| /** @brief Get Current Time |
| * |
| * This callback is called when device attempts to get current time from the |
| * hardware. If this device has means to retrieve exact time, then this method |
| * should implement it. If the callback can't provide the exact time it should |
| * return 0 to indicate failure. Default action is to return 0, which indicates |
| * that device does not have access to real time. |
| * |
| */ |
| uint32_t emberAfGetCurrentTimeCallback(); |
| |
| /** @brief Get Endpoint Info |
| * |
| * This function is a callback to an application implemented endpoint that |
| * operates outside the normal application framework. When the framework wishes |
| * to perform operations with that endpoint it uses this callback to retrieve |
| * the endpoint's information. If the endpoint exists and the application can |
| * provide data then true shall be returned. Otherwise the callback must return |
| * false. |
| * |
| * @param endpoint The endpoint to retrieve data for. Ver.: always |
| * @param returnNetworkIndex The index corresponding to the ZigBee network the |
| * endpoint belongs to. If not using a multi-network device, 0 must be |
| * returned. Otherwise on a multi-network device the stack will switch to this |
| * network before sending the message. Ver.: always |
| * @param returnEndpointInfo A pointer to a data struct that will be written |
| * with information about the endpoint. Ver.: always |
| */ |
| bool emberAfGetEndpointInfoCallback(chip::EndpointId endpoint, uint8_t * returnNetworkIndex, EmberAfEndpointInfoStruct * returnEndpointInfo); |
| |
| /** @brief Registration Abort |
| * |
| * This callback is called when the device should abort the registration |
| * process. |
| * |
| */ |
| void emberAfRegistrationAbortCallback(); |
| |
| /** @brief Interpan Send Message |
| * |
| * This function will send a raw MAC message with interpan frame format using |
| * the passed parameters. |
| * |
| * @param header Interpan header info Ver.: always |
| * @param messageLength The length of the message received or to send Ver.: |
| * always |
| * @param message The message data received or to send. Ver.: always |
| */ |
| EmberStatus emberAfInterpanSendMessageCallback(EmberAfInterpanHeader * header, uint16_t messageLength, uint8_t * message); |
| |
| /** @brief Start Move |
| * |
| * This function is called to initiate the process for a device to move (rejoin) |
| * to a new parent. |
| * |
| */ |
| bool emberAfStartMoveCallback(); |
| |
| /** @brief Pre Attribute Change |
| * |
| * This function is called by the application framework before it changes an |
| * attribute value. The value passed into this callback is the value to which |
| * the attribute is to be set by the framework. The application should return |
| * chip::Protocols::InteractionModel::Status::Success to permit the change or |
| * any other code to reject it. |
| */ |
| chip::Protocols::InteractionModel::Status MatterPreAttributeChangeCallback(const chip::app::ConcreteAttributePath & attributePath, |
| uint8_t type, uint16_t size, uint8_t * value); |
| |
| /** @brief Post Attribute Change |
| * |
| * This function is called by the application framework after it changes an |
| * attribute value. The value passed into this callback is the value to which |
| * the attribute was set by the framework. |
| */ |
| void MatterPostAttributeChangeCallback(const chip::app::ConcreteAttributePath & attributePath, |
| uint8_t type, uint16_t size, uint8_t * value); |