mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
89 lines
2.4 KiB
C
89 lines
2.4 KiB
C
|
/*
|
||
|
* Copyright (C) 2017-2018 Freie Universität Berlin
|
||
|
*
|
||
|
* This file is subject to the terms and conditions of the GNU Lesser
|
||
|
* General Public License v2.1. See the file LICENSE in the top level
|
||
|
* directory for more details.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @defgroup net_cord_ep_standalone CoRE RD Endpoint Standalone Extension
|
||
|
* @ingroup net_cord_ep
|
||
|
* @brief Run a CoRE Resource Directory endpoint standalone
|
||
|
*
|
||
|
* This sub-module enables a CoRE RD endpoint to manage is registration state
|
||
|
* with a RD autonomously by periodically running the update procedure. This
|
||
|
* is implemented by running a dedicated thread.
|
||
|
*
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief CoRE Resource Directory endpoint standalone extension
|
||
|
*
|
||
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
||
|
*/
|
||
|
|
||
|
#ifndef NET_CORD_EP_STANDALONE_H
|
||
|
#define NET_CORD_EP_STANDALONE_H
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief Possible types of events triggered by the cord_ep_standalone module
|
||
|
*/
|
||
|
typedef enum {
|
||
|
CORD_EP_REGISTERED,
|
||
|
CORD_EP_DEREGISTERED,
|
||
|
CORD_EP_UPDATED,
|
||
|
} cord_ep_standalone_event_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Callback function signature for RD endpoint state synchronization
|
||
|
*
|
||
|
* The registered callback function is executed in the context of the dedicated
|
||
|
* standalone RD endpoint's thread.
|
||
|
*
|
||
|
* @param[in] t type of event
|
||
|
*/
|
||
|
typedef void(*cord_ep_standalone_cb_t)(cord_ep_standalone_event_t event);
|
||
|
|
||
|
/**
|
||
|
* @brief Spawn a new thread that takes care of sending periodic updates to an
|
||
|
* active RD entry
|
||
|
*
|
||
|
* @warning This function must only be called once (typically during system
|
||
|
* initialization)
|
||
|
*/
|
||
|
void cord_ep_standalone_run(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Register a callback to be notified about RD endpoint state changes
|
||
|
*
|
||
|
* Only a single callback can be active at any point in time, so setting a new
|
||
|
* callback will override the existing one.
|
||
|
*
|
||
|
* @pre @p cb != NULL
|
||
|
*
|
||
|
* @param[in] cb callback to execute on RD endpoint state changes
|
||
|
*/
|
||
|
void cord_ep_standalone_reg_cb(cord_ep_standalone_cb_t cb);
|
||
|
|
||
|
/**
|
||
|
* @brief Signal the cord_ep thread about connection status change
|
||
|
*
|
||
|
* @note This function should not be called by a user, but it is called from
|
||
|
* withing the cord_ep implementation
|
||
|
*
|
||
|
* @param[in] connected set to true if we are connected to a RD
|
||
|
*/
|
||
|
void cord_ep_standalone_signal(bool connected);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* NET_CORD_EP_STANDALONE_H */
|
||
|
/** @} */
|