mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
220 lines
6.9 KiB
C
220 lines
6.9 KiB
C
|
/*
|
||
|
* Copyright (C) 2021 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_gcoap_dns DNS over CoAP client implementation
|
||
|
* @ingroup net_gcoap
|
||
|
*
|
||
|
* @brief A DNS over CoAP client prototype based on gCoAP.
|
||
|
*
|
||
|
* DNS over CoAP allows a node to use a CoAP server to resolve DNS request, following
|
||
|
* [draft-lenders-dns-over-coap](https://datatracker.ietf.org/doc/draft-lenders-dns-over-coap/).
|
||
|
*
|
||
|
* The `gcoap_dns` module does not replace the @ref sock_dns_query function when built, and is not
|
||
|
* used as a back-end to @ref netutils_get_ipv6 automatically. It does, however, provide a drop-in
|
||
|
* replacement for @ref sock_dns_query in its @ref gcoap_dns_query function.
|
||
|
*
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief `gcoap_dns` definitions
|
||
|
*
|
||
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
||
|
*/
|
||
|
#ifndef NET_GCOAP_DNS_H
|
||
|
#define NET_GCOAP_DNS_H
|
||
|
|
||
|
#include <stdint.h>
|
||
|
|
||
|
#include "mutex.h"
|
||
|
#include "net/credman.h"
|
||
|
#include "net/coap.h"
|
||
|
#include "net/gcoap.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @defgroup gcoap_dns_config GCoAP DNS over CoAP client configuration
|
||
|
* @ingroup config
|
||
|
* @{
|
||
|
*/
|
||
|
/**
|
||
|
* @brief maximum length of the URI for the DNS server
|
||
|
*/
|
||
|
#ifndef CONFIG_GCOAP_DNS_SERVER_URI_LEN
|
||
|
#define CONFIG_GCOAP_DNS_SERVER_URI_LEN 64U
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief maximum number of credentials that can be added with @ref gcoap_dns_cred_add()
|
||
|
*/
|
||
|
#ifndef CONFIG_GCOAP_DNS_CREDS_MAX
|
||
|
#if IS_USED(MODULE_GCOAP_DTLS) || defined(DOXYGEN)
|
||
|
#define CONFIG_GCOAP_DNS_CREDS_MAX 1U
|
||
|
#else
|
||
|
#define CONFIG_GCOAP_DNS_CREDS_MAX 0U
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief size of the buffer used to build a CoAP request
|
||
|
*/
|
||
|
#ifndef CONFIG_GCOAP_DNS_PDU_BUF_SIZE
|
||
|
#define CONFIG_GCOAP_DNS_PDU_BUF_SIZE 128U
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief block-size used for requests (both Block2 control and Block1)
|
||
|
*
|
||
|
* Should be less than @ref CONFIG_GCOAP_DNS_PDU_BUF_SIZE or
|
||
|
* @ref CONFIG_GCOAP_PDU_BUF_SIZE and must be a power
|
||
|
* of 2
|
||
|
*/
|
||
|
#ifndef CONFIG_GCOAP_DNS_BLOCK_SIZE
|
||
|
#define CONFIG_GCOAP_DNS_BLOCK_SIZE 64U
|
||
|
#endif
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @brief Query a domain name via CoAP synchronously
|
||
|
*
|
||
|
* @param[in] domain_name A '\0'-terminated domain name. Must not be NULL.
|
||
|
* @param[out] addr_out The resolved address. Must not be NULL.
|
||
|
* @param[in] family The desired address family for @p addr_out.
|
||
|
* @ref AF_UNSPEC for any address family (an IPv6
|
||
|
* address will take preference over an IPv4 address).
|
||
|
*
|
||
|
* @return length of @p addr_out in bytes on success
|
||
|
* @return -EAFNOSUPPORT, if the hostname of the URI resolves to an unknown address family.
|
||
|
* @return -EBADMSG, when receiving erroneous response or response containing
|
||
|
* an error code.
|
||
|
* @return -ECONNABORTED, if CoAP request cannot be sent.
|
||
|
* @return -ECONNREFUSED, if no URI is set for the client (see @ref gcoap_dns_server_uri_set()).
|
||
|
* @return -EDESTADDRREQ, if CoAP response was received from an unexpected
|
||
|
* remote.
|
||
|
* @return -EHOSTUNREACH, if the hostname of the URI can not be resolved
|
||
|
* @return -ENOBUFS, if there was not enough buffer space for the request.
|
||
|
* @return -ENOBUFS, if length of received CoAP body is greater than
|
||
|
* @ref CONFIG_DNS_MSG_LEN.
|
||
|
* @return -ENOENT, if Zone-ID of the URI can not be found locally.
|
||
|
* @return -ENOMSG, if CoAP response did not contain a DNS response.
|
||
|
* @return -ENOTRECOVERABLE, on gCoAP-internal error.
|
||
|
* @return -ENOTSUP, if credential can not be added for to client.
|
||
|
* @return -ETIMEDOUT, if CoAP request timed out.
|
||
|
*/
|
||
|
int gcoap_dns_query(const char *domain_name, void *addr_out, int family);
|
||
|
|
||
|
/**
|
||
|
* @brief Sets and checks a URI for a DoC server
|
||
|
*
|
||
|
* @param[in] uri A URI. May be NULL to remove the URI.
|
||
|
Unless the @ref net_sock_dns module is also used, the host
|
||
|
component of the URI needs to be an IP literal.
|
||
|
*
|
||
|
* @return length of @p uri on success (0 when URI is removed).
|
||
|
* @return -EINVAL, if @p uri is not a valid URI for DNS over CoAP.
|
||
|
* @return -ENOBUFS, if the client implementation has not enough buffer space
|
||
|
* to process the URI.
|
||
|
*/
|
||
|
int gcoap_dns_server_uri_set(const char *uri);
|
||
|
|
||
|
/**
|
||
|
* @brief Checks if the URI for the DoC server is set.
|
||
|
*
|
||
|
* @retval true A URI for the DoC server is set.
|
||
|
* @retval false There is no URI set for the DoC server.
|
||
|
*/
|
||
|
bool gcoap_dns_server_uri_is_set(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Gets the URI for the DoC server
|
||
|
*
|
||
|
* @param[out] uri The current URI for the DoC server
|
||
|
* @param[in] uri_len Maximum length for @p uri
|
||
|
*
|
||
|
* @return Length of the @p uri on return. 0, if no URI is set.
|
||
|
* @return -ENOBUFS, if the configured URI is longer than @p uri_len.
|
||
|
*/
|
||
|
ssize_t gcoap_dns_server_uri_get(char *uri, size_t uri_len);
|
||
|
|
||
|
/**
|
||
|
* @brief Deletes all added credentials
|
||
|
*
|
||
|
* This also removes the credentials from the @ref net_credman and the GCoAP DTLS sock.
|
||
|
*/
|
||
|
void gcoap_dns_cred_reset(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Adds a credential for the use with the configured DoC server.
|
||
|
*
|
||
|
* @pre creds != NULL.
|
||
|
*
|
||
|
* @param[in] creds A crential. May not be NULL.
|
||
|
*
|
||
|
* @return 0 on success
|
||
|
* @return -ENOTSUP if DTLS is not supported (because `gcoap_dtls` is not compiled in)
|
||
|
* @return -ENOMEM if @ref CONFIG_GCOAP_DNS_CREDS_MAX is exceeded (duplicates may be added).
|
||
|
* @return -EBADF if the credential can not be added to @ref net_credman or the GCoAP DTLS sock.
|
||
|
*/
|
||
|
int gcoap_dns_cred_add(credman_credential_t *creds);
|
||
|
|
||
|
/**
|
||
|
* @brief Remove a credential for the use with the configured DoC server
|
||
|
*
|
||
|
* This also removes the credentials from the @ref net_credman and the GCoAP DTLS sock.
|
||
|
*
|
||
|
* @param[in] tag The tag of the credential.
|
||
|
* @param[in] type The type of the credential.
|
||
|
*/
|
||
|
void gcoap_dns_cred_remove(credman_tag_t tag, credman_type_t type);
|
||
|
|
||
|
/**
|
||
|
* @brief Deletes the proxy URI.
|
||
|
*/
|
||
|
void gcoap_dns_server_proxy_reset(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Sets and checks a proxy URI.
|
||
|
*
|
||
|
* @param[in] proxy A proxy URI. Must contain a `dns` query variable.
|
||
|
*
|
||
|
* @return length of @p proxy on success.
|
||
|
* @return -ENOBUFS, if the client implementation has not enough buffer space
|
||
|
* to process the proxy URI.
|
||
|
* @return -ENOSUP, if module `gcoap_dns_proxied` is not compiled in.
|
||
|
*/
|
||
|
int gcoap_dns_server_proxy_set(const char *proxy);
|
||
|
|
||
|
/**
|
||
|
* @brief Checks if a proxy URI is set.
|
||
|
*
|
||
|
* @retval true A proxy URI is set.
|
||
|
* @retval false There is no URI set for the DoC server.
|
||
|
*/
|
||
|
bool gcoap_dns_server_proxy_is_set(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Gets the proxy URI
|
||
|
*
|
||
|
* @param[out] proxy The current proxy URI
|
||
|
* @param[in] proxy_len Maximum length for @p proxy
|
||
|
*
|
||
|
* @return Length of the @p proxy on return. 0, if no URI is set.
|
||
|
* @return -ENOBUFS, if the configured URI is longer than @p proxy_len.
|
||
|
*/
|
||
|
ssize_t gcoap_dns_server_proxy_get(char *proxy, size_t proxy_len);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* NET_GCOAP_DNS_H */
|
||
|
/** @} */
|