2018-09-12 09:42:40 +02:00
|
|
|
/*
|
|
|
|
* 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_coap CoAP defines
|
|
|
|
* @ingroup net
|
|
|
|
* @brief Generic CoAP values as defined by RFC7252
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Generic CoAP values as defined by RFC7252
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef NET_COAP_H
|
|
|
|
#define NET_COAP_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default CoAP port
|
|
|
|
*/
|
|
|
|
#define COAP_PORT (5683)
|
|
|
|
|
2022-09-29 11:26:03 +02:00
|
|
|
#define COAP_V1 (1) /**< Identifier for CoAP version 1 (RFC 7252) */
|
|
|
|
|
2018-09-12 09:42:40 +02:00
|
|
|
/**
|
|
|
|
* @name CoAP option numbers
|
|
|
|
* @{
|
|
|
|
*/
|
2022-05-17 09:20:54 +02:00
|
|
|
#define COAP_OPT_IF_MATCH (1)
|
2018-09-12 09:42:40 +02:00
|
|
|
#define COAP_OPT_URI_HOST (3)
|
2022-03-09 18:57:02 +01:00
|
|
|
#define COAP_OPT_ETAG (4)
|
2022-05-17 09:20:54 +02:00
|
|
|
#define COAP_OPT_IF_NONE_MATCH (5)
|
2018-09-12 09:42:40 +02:00
|
|
|
#define COAP_OPT_OBSERVE (6)
|
|
|
|
#define COAP_OPT_LOCATION_PATH (8)
|
|
|
|
#define COAP_OPT_URI_PATH (11)
|
|
|
|
#define COAP_OPT_CONTENT_FORMAT (12)
|
2020-04-17 13:43:52 +02:00
|
|
|
#define COAP_OPT_MAX_AGE (14)
|
2018-09-12 09:42:40 +02:00
|
|
|
#define COAP_OPT_URI_QUERY (15)
|
2019-04-29 15:25:24 +02:00
|
|
|
#define COAP_OPT_ACCEPT (17)
|
2018-09-12 09:42:40 +02:00
|
|
|
#define COAP_OPT_LOCATION_QUERY (20)
|
|
|
|
#define COAP_OPT_BLOCK2 (23)
|
|
|
|
#define COAP_OPT_BLOCK1 (27)
|
2020-03-13 15:31:38 +01:00
|
|
|
#define COAP_OPT_PROXY_URI (35)
|
|
|
|
#define COAP_OPT_PROXY_SCHEME (39)
|
2018-09-12 09:42:40 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Message types -- confirmable, non-confirmable, etc.
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_TYPE_CON (0)
|
|
|
|
#define COAP_TYPE_NON (1)
|
|
|
|
#define COAP_TYPE_ACK (2)
|
|
|
|
#define COAP_TYPE_RST (3)
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name CoAP method codes used in header
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_CLASS_REQ (0)
|
|
|
|
#define COAP_METHOD_GET (1)
|
|
|
|
#define COAP_METHOD_POST (2)
|
|
|
|
#define COAP_METHOD_PUT (3)
|
|
|
|
#define COAP_METHOD_DELETE (4)
|
2018-10-18 12:12:31 +02:00
|
|
|
#define COAP_METHOD_FETCH (5)
|
|
|
|
#define COAP_METHOD_PATCH (6)
|
|
|
|
#define COAP_METHOD_IPATCH (7)
|
2018-09-12 09:42:40 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Empty CoAP message code
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_CODE_EMPTY (0)
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Response message codes: success
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_CLASS_SUCCESS (2)
|
|
|
|
#define COAP_CODE_CREATED ((2 << 5) | 1)
|
|
|
|
#define COAP_CODE_DELETED ((2 << 5) | 2)
|
|
|
|
#define COAP_CODE_VALID ((2 << 5) | 3)
|
|
|
|
#define COAP_CODE_CHANGED ((2 << 5) | 4)
|
|
|
|
#define COAP_CODE_204 ((2 << 5) | 4)
|
|
|
|
#define COAP_CODE_CONTENT ((2 << 5) | 5)
|
|
|
|
#define COAP_CODE_205 ((2 << 5) | 5)
|
2019-01-05 01:43:18 +01:00
|
|
|
#define COAP_CODE_CONTINUE ((2 << 5) | 31)
|
2018-09-12 09:42:40 +02:00
|
|
|
#define COAP_CODE_231 ((2 << 5) | 31)
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Response message codes: client error
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_CLASS_CLIENT_FAILURE (4)
|
|
|
|
#define COAP_CODE_BAD_REQUEST ((4 << 5) | 0)
|
|
|
|
#define COAP_CODE_UNAUTHORIZED ((4 << 5) | 1)
|
|
|
|
#define COAP_CODE_BAD_OPTION ((4 << 5) | 2)
|
|
|
|
#define COAP_CODE_FORBIDDEN ((4 << 5) | 3)
|
|
|
|
#define COAP_CODE_PATH_NOT_FOUND ((4 << 5) | 4)
|
|
|
|
#define COAP_CODE_404 ((4 << 5) | 4)
|
|
|
|
#define COAP_CODE_METHOD_NOT_ALLOWED ((4 << 5) | 5)
|
|
|
|
#define COAP_CODE_NOT_ACCEPTABLE ((4 << 5) | 6)
|
|
|
|
#define COAP_CODE_REQUEST_ENTITY_INCOMPLETE ((4 << 5) | 8)
|
2018-10-18 12:12:31 +02:00
|
|
|
#define COAP_CODE_CONFLICT ((4 << 5) | 9)
|
2019-01-05 01:43:18 +01:00
|
|
|
#define COAP_CODE_PRECONDITION_FAILED ((4 << 5) | 12)
|
|
|
|
#define COAP_CODE_REQUEST_ENTITY_TOO_LARGE ((4 << 5) | 13)
|
|
|
|
#define COAP_CODE_UNSUPPORTED_CONTENT_FORMAT ((4 << 5) | 15)
|
2018-10-18 12:12:31 +02:00
|
|
|
#define COAP_CODE_UNPROCESSABLE_ENTITY ((4 << 5) | 22)
|
2018-09-12 09:42:40 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Response message codes: server error
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_CLASS_SERVER_FAILURE (5)
|
|
|
|
#define COAP_CODE_INTERNAL_SERVER_ERROR ((5 << 5) | 0)
|
|
|
|
#define COAP_CODE_NOT_IMPLEMENTED ((5 << 5) | 1)
|
|
|
|
#define COAP_CODE_BAD_GATEWAY ((5 << 5) | 2)
|
|
|
|
#define COAP_CODE_SERVICE_UNAVAILABLE ((5 << 5) | 3)
|
|
|
|
#define COAP_CODE_GATEWAY_TIMEOUT ((5 << 5) | 4)
|
|
|
|
#define COAP_CODE_PROXYING_NOT_SUPPORTED ((5 << 5) | 5)
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Content-Format option codes
|
2018-10-03 21:27:31 +02:00
|
|
|
* @anchor net_coap_format
|
2018-09-12 09:42:40 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2018-10-18 12:13:49 +02:00
|
|
|
#define COAP_FORMAT_TEXT (0)
|
|
|
|
#define COAP_FORMAT_LINK (40)
|
|
|
|
#define COAP_FORMAT_XML (41)
|
|
|
|
#define COAP_FORMAT_OCTET (42)
|
|
|
|
#define COAP_FORMAT_EXI (47)
|
|
|
|
#define COAP_FORMAT_JSON (50)
|
|
|
|
#define COAP_FORMAT_JSON_PATCH_JSON (51)
|
|
|
|
#define COAP_FORMAT_MERGE_PATCH_JSON (52)
|
|
|
|
#define COAP_FORMAT_CBOR (60)
|
|
|
|
#define COAP_FORMAT_SENML_JSON (110)
|
|
|
|
#define COAP_FORMAT_SENSML_JSON (111)
|
|
|
|
#define COAP_FORMAT_SENML_CBOR (112)
|
|
|
|
#define COAP_FORMAT_SENSML_CBOR (113)
|
|
|
|
#define COAP_FORMAT_SENML_EXI (114)
|
|
|
|
#define COAP_FORMAT_SENSML_EXI (115)
|
|
|
|
#define COAP_FORMAT_SENML_XML (310)
|
|
|
|
#define COAP_FORMAT_SENSML_XML (311)
|
2021-07-21 16:10:37 +02:00
|
|
|
#define COAP_FORMAT_DNS_MESSAGE (65053) /**< NON STANDARD! */
|
2018-09-12 09:42:40 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Observe (RFC 7641) constants
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_OBS_REGISTER (0)
|
|
|
|
#define COAP_OBS_DEREGISTER (1)
|
|
|
|
/** @} */
|
|
|
|
|
2020-05-21 16:30:15 +02:00
|
|
|
/**
|
|
|
|
* @name CoAP message format constants
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_TOKEN_LENGTH_MAX (8)
|
|
|
|
/** @} */
|
2022-03-09 18:57:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @name CoAP option constants
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_ETAG_LENGTH_MAX (8U) /**< maximum length of the ETag option */
|
|
|
|
/** @} */
|
2020-05-21 16:30:15 +02:00
|
|
|
|
2018-09-12 09:42:40 +02:00
|
|
|
/**
|
2018-12-29 17:49:53 +01:00
|
|
|
* @defgroup net_coap_conf CoAP compile configurations
|
|
|
|
* @ingroup net_coap
|
|
|
|
* @ingroup config
|
2018-09-12 09:42:40 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2018-12-30 16:19:45 +01:00
|
|
|
/**
|
|
|
|
* @name Timing parameters
|
2018-12-30 16:32:08 +01:00
|
|
|
*
|
|
|
|
* These parameters are defined as configurable in [RFC 7252, section 4.8.1]
|
|
|
|
* (https://tools.ietf.org/html/rfc7252#section-4.8.1).
|
2018-12-30 16:19:45 +01:00
|
|
|
* @{
|
|
|
|
*/
|
2018-12-29 17:49:53 +01:00
|
|
|
/**
|
2022-01-05 22:38:16 +01:00
|
|
|
* @brief Timeout in milliseconds for a response to a confirmable request
|
2018-12-29 17:49:53 +01:00
|
|
|
*
|
|
|
|
* This value is for the response to the *initial* confirmable message. The
|
|
|
|
* timeout doubles for subsequent retries. To avoid synchronization of resends
|
|
|
|
* across hosts, the actual timeout is chosen randomly between
|
2022-01-05 22:38:16 +01:00
|
|
|
* @ref CONFIG_COAP_ACK_TIMEOUT_MS and
|
|
|
|
* (@ref CONFIG_COAP_ACK_TIMEOUT_MS * @ref CONFIG_COAP_RANDOM_FACTOR_1000 / 1000).
|
2018-12-29 17:49:53 +01:00
|
|
|
*/
|
2022-01-05 22:38:16 +01:00
|
|
|
#ifndef CONFIG_COAP_ACK_TIMEOUT_MS
|
2022-08-20 16:32:20 +02:00
|
|
|
#define CONFIG_COAP_ACK_TIMEOUT_MS (2000UL)
|
2018-12-29 17:49:53 +01:00
|
|
|
#endif
|
|
|
|
|
2020-01-27 17:05:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Used to calculate upper bound for timeout
|
|
|
|
*
|
|
|
|
* This represents the `ACK_RANDOM_FACTOR`
|
|
|
|
* ([RFC 7252, section 4.2](https://tools.ietf.org/html/rfc7252#section-4.2))
|
|
|
|
* multiplied by 1000, to avoid floating point arithmetic.
|
|
|
|
*
|
2022-01-05 22:38:16 +01:00
|
|
|
* See @ref CONFIG_COAP_ACK_TIMEOUT_MS
|
2020-01-27 17:05:22 +01:00
|
|
|
*/
|
2020-01-28 20:29:40 +01:00
|
|
|
#ifndef CONFIG_COAP_RANDOM_FACTOR_1000
|
|
|
|
#define CONFIG_COAP_RANDOM_FACTOR_1000 (1500)
|
2018-12-29 17:49:53 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @brief Maximum number of retransmissions for a confirmable request */
|
2020-01-28 21:29:04 +01:00
|
|
|
#ifndef CONFIG_COAP_MAX_RETRANSMIT
|
|
|
|
#define CONFIG_COAP_MAX_RETRANSMIT (4)
|
2018-12-29 17:49:53 +01:00
|
|
|
#endif
|
|
|
|
/** @} */
|
2018-12-30 16:19:45 +01:00
|
|
|
/** @} */
|
2018-12-29 17:49:53 +01:00
|
|
|
|
|
|
|
/**
|
2018-12-30 16:19:45 +01:00
|
|
|
* @name Fixed timing parameters
|
2018-12-29 17:49:53 +01:00
|
|
|
* @{
|
|
|
|
*/
|
2018-09-12 09:42:40 +02:00
|
|
|
#define COAP_NSTART (1)
|
|
|
|
#define COAP_DEFAULT_LEISURE (5)
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Blockwise transfer (RFC7959)
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define COAP_BLOCKWISE_NUM_OFF (4)
|
|
|
|
#define COAP_BLOCKWISE_MORE_OFF (3)
|
|
|
|
#define COAP_BLOCKWISE_SZX_MASK (0x07)
|
|
|
|
#define COAP_BLOCKWISE_SZX_MAX (7)
|
|
|
|
/** @} */
|
|
|
|
|
2022-01-06 13:08:59 +01:00
|
|
|
/**
|
|
|
|
* @brief Coap block-wise-transfer size SZX
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
COAP_BLOCKSIZE_16 = 0,
|
|
|
|
COAP_BLOCKSIZE_32,
|
|
|
|
COAP_BLOCKSIZE_64,
|
|
|
|
COAP_BLOCKSIZE_128,
|
|
|
|
COAP_BLOCKSIZE_256,
|
|
|
|
COAP_BLOCKSIZE_512,
|
|
|
|
COAP_BLOCKSIZE_1024,
|
|
|
|
} coap_blksize_t;
|
|
|
|
|
2018-09-12 09:42:40 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* NET_COAP_H */
|
|
|
|
/** @} */
|