blob: f3e1e1f086484f846ce7f8edd7e6282d59850baa [file] [log] [blame]
/**
*
* Copyright (c) 2020 Project CHIP Authors
*
* 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.
*/
/**
*
* Copyright (c) 2020 Silicon Labs
*
* 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.
*/
/***************************************************************************/
/**
* @file
* @brief It implements and manages the ESI table. The
*ESI table is shared among other plugins.
*******************************************************************************
******************************************************************************/
#pragma once
#include <app/util/af.h>
#ifndef EMBER_AF_PLUGIN_ESI_MANAGEMENT_ESI_TABLE_SIZE
#define EMBER_AF_PLUGIN_ESI_MANAGEMENT_ESI_TABLE_SIZE 3
#endif // EMBER_AF_PLUGIN_ESI_MANAGEMENT_ESI_TABLE_SIZE
#ifndef EMBER_AF_PLUGIN_ESI_MANAGEMENT_MIN_ERASING_AGE
#define EMBER_AF_PLUGIN_ESI_MANAGEMENT_MIN_ERASING_AGE 3
#endif // EMBER_AF_PLUGIN_ESI_MANAGEMENT_MIN_ERASING_AGE
#ifndef EMBER_AF_PLUGIN_ESI_MANAGEMENT_PLUGIN_CALLBACK_TABLE_SIZE
#define EMBER_AF_PLUGIN_ESI_MANAGEMENT_PLUGIN_CALLBACK_TABLE_SIZE 5
#endif // EMBER_AF_PLUGIN_ESI_MANAGEMENT_PLUGIN_CALLBACK_TABLE_SIZE
typedef struct
{
EmberEUI64 eui64;
chip::NodeId nodeId;
uint8_t networkIndex;
chip::EndpointId endpoint;
uint8_t age; // The number of discovery cycles the ESI has not been discovered.
} EmberAfPluginEsiManagementEsiEntry;
typedef void (*EmberAfEsiManagementDeletionCallback)(uint8_t);
/**
* Searches in the ESI table by the pair node (short ID, endopoint).
*
* Returns a pointer to the entry if a matching entry was found, otherwise it
* returns NULL.
*/
EmberAfPluginEsiManagementEsiEntry * emberAfPluginEsiManagementEsiLookUpByShortIdAndEndpoint(EmberNodeId shortId,
chip::EndpointId endpoint);
/**
* Searches in the ESI table by the pair node (long ID, endopoint).
*
* Returns a pointer to the entry if a matching entry was found, otherwise it
* returns NULL.
*/
EmberAfPluginEsiManagementEsiEntry * emberAfPluginEsiManagementEsiLookUpByLongIdAndEndpoint(EmberEUI64 longId,
chip::EndpointId endpoint);
/**
* Allows retrieving the index of an entry that matches the passed short ID
* and endpoint.
*
* It returns the index of the matching entry if a matching entry was found,
* otherwise it returns 0xFF.
*/
uint8_t emberAfPluginEsiManagementIndexLookUpByShortIdAndEndpoint(EmberNodeId shortId, chip::EndpointId endpoint);
/**
* Allows retrieving the index of an entry that matches the passed long ID
* and endpoint.
*
* It returns the index of the matching entry if a matching entry was found,
* otherwise it returns 0xFF.
*/
uint8_t emberAfPluginEsiManagementIndexLookUpByLongIdAndEndpoint(EmberEUI64 longId, chip::EndpointId endpoint);
/**
* Searches in the ESI table by the table index.
*
* Returns a pointer to the ESI entry stored at the index passed as
* parameter.
*/
EmberAfPluginEsiManagementEsiEntry * emberAfPluginEsiManagementEsiLookUpByIndex(uint8_t index);
/**
* Iterates through the entries in the
* table that are within a certain age threshold.
*
* If the passed pointer is NULL, it returns the first active entry with age
* lesser or equal than the passed age parameter (if any). Otherwise, it returns
* the next active entry that satisfy the age requirement. If the are no entries
* after the passed entry that satisfy the age requirement, it returns NULL.
*/
EmberAfPluginEsiManagementEsiEntry * emberAfPluginEsiManagementGetNextEntry(EmberAfPluginEsiManagementEsiEntry * entry,
uint8_t age);
/**
* Allows obtaining a free entry in the ESI table. It is the
* requester responsibility to properly set all the fields in the obtained free
* entry such as nodeId, age, and so on to avoid inconsistencies in the
* table.
*
* Returns a free entry (if any), otherwise it clears the oldest entry whose age
* is at least EMBER_AF_PLUGIN_ESI_MANAGEMENT_MIN_ERASING_AGE (if any) and
* returns it, otherwise it returns NULL.
*/
EmberAfPluginEsiManagementEsiEntry * emberAfPluginEsiManagementGetFreeEntry(void);
/**
* Deletes the entry indicated by the parameter 'index' from the
* ESI table.
*/
void emberAfPluginEsiManagementDeleteEntry(uint8_t index);
/**
* Increases the age of all the active entries in the table. A
* non-active entry is an entry whose short ID is set to EMBER_NULL_NODE_ID.
*/
void emberAfPluginEsiManagementAgeAllEntries(void);
/**
* Clears the ESI table, i.e., it sets the short ID of each entry
* to EMBER_NULL_NODE_ID.
*/
void emberAfPluginEsiManagementClearTable(void);
/**
* Allows a plugin to subscribe to ESI entries deletion
* announcements by passing its own deletion callback function. Upon an entry
* deletion, all the deletion callback function are called passing the index
* of the deleted entry.
*
* It returns true if the subscription was successful, false otherwise.
*/
bool emberAfPluginEsiManagementSubscribeToDeletionAnnouncements(EmberAfEsiManagementDeletionCallback callback);
/**
* Performs the following steps:
* - Search for the source node of the passed command in the ESI table.
* - Adds a new entry in the ESI table if the source node is not present in the
* ESI table yet, or updates the current entry if needed.
*
* @return The index of the source node of the passed command in the ESI
* table, or it returns 0xFF if the ESI was not present in the table and a new
* entry could not be added since the table was full.
**/
uint8_t emberAfPluginEsiManagementUpdateEsiAndGetIndex(const EmberAfClusterCommand * cmd);