1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/include/net/dhcpv6/client.h
Martine Lenders 1048d67c76
dhcpv6: provide initial client implementation
This implements a client for DHCPv6 IA_PD (Identity Association for
Prefix Delegation). Goal was to have a IETF-compliant alternative to
UHCP. The implementation was based on RFC 8415.
2020-01-16 12:36:03 +01:00

169 lines
5.0 KiB
C

/*
* Copyright (C) 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_dhcpv6_client DHCPv6 client
* @ingroup net_dhcpv6
* @brief DHCPv6 client implementation
* @{
*
* @file
* @brief DHCPv6 client definitions
*
* @author Martine Lenders <m.lenders@fu-berlin.de>
*/
#ifndef NET_DHCPV6_CLIENT_H
#define NET_DHCPV6_CLIENT_H
#include "byteorder.h"
#include "event.h"
#include "net/ipv6/addr.h"
#include "thread.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name Auto-initialization parameters
*/
#ifndef DHCPV6_CLIENT_STACK_SIZE
#define DHCPV6_CLIENT_STACK_SIZE (THREAD_STACKSIZE_DEFAULT) /**< stack size */
#endif
#ifndef DHCPV6_CLIENT_PRIORITY
#define DHCPV6_CLIENT_PRIORITY (THREAD_PRIORITY_MAIN - 2) /**< priority */
#endif
/** @} */
/**
* @brief Static length of the DUID
*/
#define DHCPV6_CLIENT_DUID_LEN (sizeof(dhcpv6_duid_l2_t) + 8U)
#define DHCPV6_CLIENT_BUFLEN (256) /**< length for send and receive buffer */
#ifndef DHCPV6_CLIENT_SERVER_MAX
#define DHCPV6_CLIENT_SERVER_MAX (1U) /**< maximum number of servers to store */
#endif
#ifndef DHCPV6_CLIENT_PFX_LEASE_MAX
#define DHCPV6_CLIENT_PFX_LEASE_MAX (1U) /**< maximum number of prefix leases to store */
#endif
/**
* @name DHCPv6 unique identifier (DUID) definitions
* @see [RFC 8415, section 11](https://tools.ietf.org/html/rfc8415#section-11)
* @{
*/
/**
* @brief DUID based on link-layer address plus time
*/
typedef struct __attribute__((packed)) {
network_uint16_t type; /**< @ref DHCPV6_DUID_TYPE_L2 */
network_uint16_t l2type; /**< [hardware type](@ref net_arp_hwtype)) */
/* link-layer address follows this header */
} dhcpv6_duid_l2_t;
#if defined(MODULE_AUTO_INIT_DHCPV6_CLIENT) || defined(DOXYGEN)
/**
* @brief Auto-initializes the client in its own thread
*
* @note Only available with (and called by) the `dhcpv6_client_auto_init`
* module.
*/
void dhcpv6_client_auto_init(void);
#endif /* MODULE_DHCPV6_CLIENT_AUTO_INIT */
/**
* @brief Initializes the client
*
* @pre `event_queue->waiter != NULL`
*
* @param[in] event_queue Event queue to use with the client. Needs to be
* initialized in the handler thread.
* @param[in] netif The network interface the client should listen on.
* SOCK_ADDR_ANY_NETIF for any interface
*/
void dhcpv6_client_init(event_queue_t *event_queue, uint16_t netif);
/**
* @brief Let the server start listening
*
* This needs to be called *after* all desired [configuration functions]
* (@ref net_dhcpv6_client_conf) where called.
*/
void dhcpv6_client_start(void);
/**
* @name Configuration functions
* @anchor net_dhcpv6_client_conf
* @{
*/
/**
* @brief Configures the client to request prefix delegation for a network
* interface from a server
*
* @pre `pfx_len <= 128`
*
* @param[in] netif The interface to request the prefix delegation for.
* @param[in] pfx_len The desired length of the prefix (note that the server
* might not consider this request). Must be <= 128
*/
void dhcpv6_client_req_ia_pd(unsigned netif, unsigned pfx_len);
/** @} */
/**
* @name Stack-specific functions
*
* These functions need to be provided by the network-stack implementation.
* @{
*/
/**
* @brief Get the link-layer address DUID for the client
*
* @param[in] netif The network interface the client is bound to. May be
* SOCK_ADDR_ANY_NETIF for any interface.
* @param[out] duid The resulting DUID.
*
* @return length of the @p duid on success.
* @return 0, on error.
*/
unsigned dhcpv6_client_get_duid_l2(unsigned netif, dhcpv6_duid_l2_t *duid);
/**
* @brief Configures a prefix delegation lease that is provided by the server.
*
* @param[in] netif Network interface the prefix delegation was for.
* @param[in] pfx Prefix for the prefix delegation.
* @param[in] pfx_len Length of @p pfx in bits.
* @param[in] valid Valid lifetime of the prefix delegation.
* @param[in] pref Preferred lifetime of the prefix delegation.
*/
void dhcpv6_client_conf_prefix(unsigned netif, const ipv6_addr_t *pfx,
unsigned pfx_len, uint32_t valid,
uint32_t pref);
/**
* @brief Determines how long the prefix delegation lease is still valid.
*
* @param[in] netif Network interface the prefix delegation was for.
* @param[in] pfx Prefix of the prefix delegation
* @param[in] pfx_len Length of @p pfx in bits.
*
* @return Remaining valid lifetime of the prefix delegation lease in seconds.
*/
uint32_t dhcpv6_client_prefix_valid_until(unsigned netif,
const ipv6_addr_t *pfx,
unsigned pfx_len);
/** @} */
#ifdef __cplusplus
}
#endif
#endif /* NET_DHCPV6_CLIENT_H */
/** @} */