Loading...
Searching...
No Matches
nanocoap.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2016-18 Kaspar Schleiser <kaspar@schleiser.de>
3 * 2018 Freie Universität Berlin
4 * 2018 Inria
5 * 2018 Ken Bannister <kb2ma@runbox.com>
6 *
7 * This file is subject to the terms and conditions of the GNU Lesser
8 * General Public License v2.1. See the file LICENSE in the top level
9 * directory for more details.
10 */
11
77#ifndef NET_NANOCOAP_H
78#define NET_NANOCOAP_H
79
80#include <assert.h>
81#include <errno.h>
82#include <stdint.h>
83#include <stdbool.h>
84#include <stddef.h>
85#include <string.h>
86#include <unistd.h>
87
88#ifdef RIOT_VERSION
89#include "bitarithm.h"
90#include "bitfield.h"
91#include "byteorder.h"
92#include "iolist.h"
93#include "macros/utils.h"
94#include "net/coap.h"
95#include "modules.h"
96#else
97#include "coap.h"
98#include <arpa/inet.h>
99#endif
100
101#if defined(MODULE_SOCK_UDP) || defined(DOXYGEN)
102#include "net/sock/udp.h"
103#else
104typedef void sock_udp_ep_t;
105#endif
106
107#if defined(MODULE_NANOCOAP_RESOURCES)
108#include "xfa.h"
109#endif
110
111#ifdef __cplusplus
112extern "C" {
113#endif
114
120#define COAP_GET (0x01)
121#define COAP_POST (0x02)
122#define COAP_PUT (0x04)
123#define COAP_DELETE (0x08)
124#define COAP_FETCH (0x10)
125#define COAP_PATCH (0x20)
126#define COAP_IPATCH (0x40)
127#define COAP_IGNORE (0xFF)
129#define COAP_MATCH_SUBTREE (0x8000)
136#define COAP_FORMAT_NONE (UINT16_MAX)
137
145#ifndef CONFIG_NANOCOAP_NOPTS_MAX
146#define CONFIG_NANOCOAP_NOPTS_MAX (16)
147#endif
148
153#ifndef CONFIG_NANOCOAP_URI_MAX
154#define CONFIG_NANOCOAP_URI_MAX (64)
155#endif
156
160#ifndef CONFIG_NANOCOAP_BLOCK_SIZE_EXP_MAX
161#define CONFIG_NANOCOAP_BLOCK_SIZE_EXP_MAX (6)
162#endif
163
167#ifndef CONFIG_NANOCOAP_BLOCKSIZE_DEFAULT
168#define CONFIG_NANOCOAP_BLOCKSIZE_DEFAULT COAP_BLOCKSIZE_64
169#endif
170
172#ifndef CONFIG_NANOCOAP_QS_MAX
173#define CONFIG_NANOCOAP_QS_MAX (64)
174#endif
182#ifndef CONFIG_NANOCOAP_BLOCK_HEADER_MAX
183#define CONFIG_NANOCOAP_BLOCK_HEADER_MAX (80)
184#endif
185
193#define COAP_OPT_FINISH_NONE (0x0000)
195#define COAP_OPT_FINISH_PAYLOAD (0x0001)
201typedef struct __attribute__((packed)) {
202 uint8_t ver_t_tkl;
203 uint8_t code;
204 uint16_t id;
205} coap_hdr_t;
206
210typedef struct {
211 uint16_t opt_num;
212 uint16_t offset;
214
232typedef struct {
234 uint8_t *payload;
236 uint16_t payload_len;
237 uint16_t options_len;
240#ifdef MODULE_GCOAP
241 uint32_t observe_value;
242#endif
243} coap_pkt_t;
244
249
272typedef ssize_t (*coap_handler_t)(coap_pkt_t *pkt, uint8_t *buf, size_t len,
273 coap_request_ctx_t *context);
274
287typedef int (*coap_blockwise_cb_t)(void *arg, size_t offset, uint8_t *buf, size_t len, int more);
288
299typedef int (*coap_request_cb_t)(void *arg, coap_pkt_t *pkt);
300
306typedef uint16_t coap_method_flags_t;
307
317
321typedef const struct {
323 const size_t resources_numof;
325
333
341#if defined(MODULE_SOCK_AUX_LOCAL) || DOXYGEN
343#endif
344#if defined(MODULE_GCOAP) || DOXYGEN
351 uint32_t tl_type;
352#endif
353};
354
363
372
382
392
402
406typedef struct {
407 size_t offset;
408 uint32_t blknum;
409 uint8_t szx;
410 int8_t more;
413
417typedef struct {
418 size_t start;
419 size_t end;
420 size_t cur;
421 uint8_t *opt;
423
424#if defined(MODULE_NANOCOAP_RESOURCES) || DOXYGEN
430#define NANOCOAP_RESOURCE(name) \
431 XFA_CONST(coap_resources_xfa, 0) coap_resource_t CONCAT(coap_resource_, name) =
432#else
438extern const coap_resource_t coap_resources[];
439
445extern const unsigned coap_resources_numof;
446#endif
447
462static inline uint8_t coap_code(unsigned cls, unsigned detail)
463{
464 return (cls << 5) | detail;
465}
466
474static inline unsigned coap_get_code_class(const coap_pkt_t *pkt)
475{
476 return pkt->hdr->code >> 5;
477}
478
486static inline unsigned coap_get_code_detail(const coap_pkt_t *pkt)
487{
488 return pkt->hdr->code & 0x1f;
489}
490
498static inline unsigned coap_get_code_decimal(const coap_pkt_t *pkt)
499{
500 return (coap_get_code_class(pkt) * 100) + coap_get_code_detail(pkt);
501}
502
510static inline unsigned coap_get_code_raw(const coap_pkt_t *pkt)
511{
512 return (unsigned)pkt->hdr->code;
513}
514
522static inline coap_method_t coap_get_method(const coap_pkt_t *pkt)
523{
524 return pkt->hdr->code;
525}
526
534static inline unsigned coap_get_id(const coap_pkt_t *pkt)
535{
536 return ntohs(pkt->hdr->id);
537}
538
549static inline unsigned coap_get_token_len(const coap_pkt_t *pkt)
550{
551 uint8_t tkl = pkt->hdr->ver_t_tkl & 0xf;
552
553 if (!IS_USED(MODULE_NANOCOAP_TOKEN_EXT)) {
554 return tkl;
555 }
556
557 void *ext = pkt->hdr + 1;
558 switch (tkl) {
559 case 13:
560 return tkl + *(uint8_t *)ext;
561 case 14:
562 return tkl + 255 + byteorder_bebuftohs(ext);
563 case 15:
564 assert(0);
565 /* fall-through */
566 default:
567 return tkl;
568 }
569}
570
571static inline uint8_t *coap_hdr_data_ptr(const coap_hdr_t *hdr);
572
580static inline void *coap_get_token(const coap_pkt_t *pkt)
581{
582 return coap_hdr_data_ptr(pkt->hdr);
583}
584
592static inline unsigned coap_get_total_hdr_len(const coap_pkt_t *pkt)
593{
594 return sizeof(coap_hdr_t) + coap_get_token_len(pkt);
595}
596
606static inline unsigned coap_get_total_len(const coap_pkt_t *pkt)
607{
608 return (uintptr_t)pkt->payload - (uintptr_t)pkt->hdr + pkt->payload_len;
609}
610
621static inline unsigned coap_get_type(const coap_pkt_t *pkt)
622{
623 return (pkt->hdr->ver_t_tkl & 0x30) >> 4;
624}
625
633static inline unsigned coap_get_ver(const coap_pkt_t *pkt)
634{
635 return (pkt->hdr->ver_t_tkl & 0x60) >> 6;
636}
637
648static inline uint8_t coap_hdr_tkl_ext_len(const coap_hdr_t *hdr)
649{
650 if (!IS_USED(MODULE_NANOCOAP_TOKEN_EXT)) {
651 return 0;
652 }
653
654 switch (hdr->ver_t_tkl & 0xf) {
655 case 13:
656 return 1;
657 case 14:
658 return 2;
659 case 15:
660 assert(0);
661 /* fall-through */
662 default:
663 return 0;
664 }
665}
666
674static inline uint8_t *coap_hdr_data_ptr(const coap_hdr_t *hdr)
675{
676 return ((uint8_t *)hdr) + sizeof(coap_hdr_t) + coap_hdr_tkl_ext_len(hdr);
677}
678
685static inline void coap_hdr_set_code(coap_hdr_t *hdr, uint8_t code)
686{
687 hdr->code = code;
688}
689
698static inline void coap_hdr_set_type(coap_hdr_t *hdr, unsigned type)
699{
700 /* assert correct range of type */
701 assert(!(type & ~0x3));
702
703 hdr->ver_t_tkl &= ~0x30;
704 hdr->ver_t_tkl |= type << 4;
705}
734uint8_t *coap_find_option(coap_pkt_t *pkt, unsigned opt_num);
735
748uint8_t *coap_iterate_option(coap_pkt_t *pkt, unsigned opt_num,
749 uint8_t **opt_pos, int *opt_len);
750
760
770
783int coap_opt_get_uint(coap_pkt_t *pkt, uint16_t optnum, uint32_t *value);
784
802ssize_t coap_opt_get_string(coap_pkt_t *pkt, uint16_t optnum,
803 uint8_t *target, size_t max_len, char separator);
804
820static inline ssize_t coap_get_location_path(coap_pkt_t *pkt,
821 uint8_t *target, size_t max_len)
822{
823 return coap_opt_get_string(pkt, COAP_OPT_LOCATION_PATH,
824 target, max_len, '/');
825}
826
842static inline ssize_t coap_get_location_query(coap_pkt_t *pkt,
843 uint8_t *target, size_t max_len)
844{
845 return coap_opt_get_string(pkt, COAP_OPT_LOCATION_QUERY,
846 target, max_len, '&');
847}
848
863static inline ssize_t coap_get_uri_path(coap_pkt_t *pkt, uint8_t *target)
864{
865 return coap_opt_get_string(pkt, COAP_OPT_URI_PATH, target,
867}
868
882static inline ssize_t coap_get_uri_query_string(coap_pkt_t *pkt, char *target,
883 size_t max_len)
884{
885 return coap_opt_get_string(pkt, COAP_OPT_URI_QUERY,
886 (uint8_t *)target, max_len, '&');
887}
888
903bool coap_find_uri_query(coap_pkt_t *pkt, const char *key,
904 const char **value, size_t *len);
905
936 uint8_t **value, bool init_opt);
937
954ssize_t coap_opt_get_opaque(coap_pkt_t *pkt, unsigned opt_num, uint8_t **value);
969static inline ssize_t coap_get_proxy_uri(coap_pkt_t *pkt, char **target)
970{
971 return coap_opt_get_opaque(pkt, COAP_OPT_PROXY_URI, (uint8_t **)target);
972}
973
991void coap_block_object_init(coap_block1_t *block, size_t blknum, size_t blksize,
992 int more);
993
1009bool coap_block_finish(coap_block_slicer_t *slicer, uint16_t option);
1010
1025static inline bool coap_block1_finish(coap_block_slicer_t *slicer)
1026{
1027 return coap_block_finish(slicer, COAP_OPT_BLOCK1);
1028}
1029
1044static inline bool coap_block2_finish(coap_block_slicer_t *slicer)
1045{
1046 return coap_block_finish(slicer, COAP_OPT_BLOCK2);
1047}
1048
1059
1070 size_t blksize);
1071
1086size_t coap_blockwise_put_bytes(coap_block_slicer_t *slicer, uint8_t *bufpos,
1087 const void *c, size_t len);
1088
1102size_t coap_blockwise_put_char(coap_block_slicer_t *slicer, uint8_t *bufpos, char c);
1103
1122int coap_get_block(coap_pkt_t *pkt, coap_block1_t *block, uint16_t option);
1123
1141static inline int coap_get_block1(coap_pkt_t *pkt, coap_block1_t *block)
1142{
1143 return coap_get_block(pkt, block, COAP_OPT_BLOCK1);
1144}
1145
1155static inline int coap_get_block2(coap_pkt_t *pkt, coap_block1_t *block)
1156{
1157 return coap_get_block(pkt, block, COAP_OPT_BLOCK2);
1158}
1159
1172int coap_get_blockopt(coap_pkt_t *pkt, uint16_t option, uint32_t *blknum, uint8_t *szx);
1173
1192
1200#define coap_szx2size(szx) (1U << ((szx) + 4))
1201
1209static inline unsigned coap_size2szx(unsigned len)
1210{
1211 assert(len >= 16);
1212 return bitarithm_msb(len >> 4);
1213}
1247 bool more, uint16_t option);
1248
1267static inline ssize_t coap_opt_add_block1(coap_pkt_t *pkt,
1268 coap_block_slicer_t *slicer, bool more)
1269{
1270 return coap_opt_add_block(pkt, slicer, more, COAP_OPT_BLOCK1);
1271}
1272
1291static inline ssize_t coap_opt_add_block2(coap_pkt_t *pkt,
1292 coap_block_slicer_t *slicer, bool more)
1293{
1294 return coap_opt_add_block(pkt, slicer, more, COAP_OPT_BLOCK2);
1295}
1310ssize_t coap_opt_add_uint(coap_pkt_t *pkt, uint16_t optnum, uint32_t value);
1311
1325static inline ssize_t coap_opt_add_block1_control(coap_pkt_t *pkt, coap_block1_t *block) {
1326 return coap_opt_add_uint(pkt, COAP_OPT_BLOCK1,
1327 (block->blknum << 4) | block->szx | (block->more ? 0x8 : 0));
1328}
1329
1343static inline ssize_t coap_opt_add_block2_control(coap_pkt_t *pkt, coap_block1_t *block) {
1344 /* block.more must be zero, so no need to 'or' it in */
1345 return coap_opt_add_uint(pkt, COAP_OPT_BLOCK2,
1346 (block->blknum << 4) | block->szx);
1347}
1348
1362static inline ssize_t coap_opt_add_accept(coap_pkt_t *pkt, uint16_t format)
1363{
1364 return coap_opt_add_uint(pkt, COAP_OPT_ACCEPT, format);
1365}
1366
1380static inline ssize_t coap_opt_add_format(coap_pkt_t *pkt, uint16_t format)
1381{
1382 return coap_opt_add_uint(pkt, COAP_OPT_CONTENT_FORMAT, format);
1383}
1384
1400ssize_t coap_opt_add_opaque(coap_pkt_t *pkt, uint16_t optnum, const void *val, size_t val_len);
1401
1419ssize_t coap_opt_add_uri_query2(coap_pkt_t *pkt, const char *key, size_t key_len,
1420 const char *val, size_t val_len);
1421
1438static inline ssize_t coap_opt_add_uri_query(coap_pkt_t *pkt, const char *key,
1439 const char *val)
1440{
1441 return coap_opt_add_uri_query2(pkt, key, strlen(key), val, val ? strlen(val) : 0);
1442}
1443
1458ssize_t coap_opt_add_proxy_uri(coap_pkt_t *pkt, const char *uri);
1459
1478ssize_t coap_opt_add_chars(coap_pkt_t *pkt, uint16_t optnum, const char *chars,
1479 size_t chars_len, char separator);
1480
1498static inline ssize_t coap_opt_add_string(coap_pkt_t *pkt, uint16_t optnum,
1499 const char *string, char separator)
1500{
1501 return coap_opt_add_chars(pkt, optnum, string, strlen(string), separator);
1502}
1503
1518static inline ssize_t coap_opt_add_uri_path(coap_pkt_t *pkt, const char *path)
1519{
1520 return coap_opt_add_string(pkt, COAP_OPT_URI_PATH, path, '/');
1521}
1522
1538static inline ssize_t coap_opt_add_uri_path_buffer(coap_pkt_t *pkt,
1539 const char *path,
1540 size_t path_len)
1541{
1542 return coap_opt_add_chars(pkt, COAP_OPT_URI_PATH, path, path_len, '/');
1543}
1544
1557ssize_t coap_opt_finish(coap_pkt_t *pkt, uint16_t flags);
1558
1576ssize_t coap_opt_remove(coap_pkt_t *pkt, uint16_t optnum);
1604size_t coap_opt_put_block(uint8_t *buf, uint16_t lastonum, coap_block_slicer_t *slicer,
1605 bool more, uint16_t option);
1606
1622static inline size_t coap_opt_put_block1(uint8_t *buf, uint16_t lastonum,
1623 coap_block_slicer_t *slicer, bool more)
1624{
1625 return coap_opt_put_block(buf, lastonum, slicer, more, COAP_OPT_BLOCK1);
1626}
1627
1643static inline size_t coap_opt_put_block2(uint8_t *buf, uint16_t lastonum,
1644 coap_block_slicer_t *slicer, bool more)
1645{
1646 return coap_opt_put_block(buf, lastonum, slicer, more, COAP_OPT_BLOCK2);
1647}
1648
1660size_t coap_opt_put_uint(uint8_t *buf, uint16_t lastonum, uint16_t onum,
1661 uint32_t value);
1662
1672static inline size_t coap_opt_put_block1_control(uint8_t *buf, uint16_t lastonum,
1673 coap_block1_t *block)
1674{
1675 return coap_opt_put_uint(buf, lastonum, COAP_OPT_BLOCK1,
1676 (block->blknum << 4) | block->szx | (block->more ? 0x8 : 0));
1677}
1678
1690static inline size_t coap_opt_put_block2_control(uint8_t *buf, uint16_t lastonum,
1691 coap_block1_t *block)
1692{
1693 /* block.more must be zero, so no need to 'or' it in */
1694 return coap_opt_put_uint(buf, lastonum, COAP_OPT_BLOCK2,
1695 (block->blknum << 4) | block->szx);
1696}
1697
1711size_t coap_opt_put_string_with_len(uint8_t *buf, uint16_t lastonum, uint16_t optnum,
1712 const char *string, size_t len, char separator);
1725static inline size_t coap_opt_put_string(uint8_t *buf, uint16_t lastonum,
1726 uint16_t optnum,
1727 const char *string, char separator)
1728{
1729 return coap_opt_put_string_with_len(buf, lastonum, optnum,
1730 string, strlen(string), separator);
1731}
1732
1743static inline size_t coap_opt_put_location_path(uint8_t *buf,
1744 uint16_t lastonum,
1745 const char *location)
1746{
1747 return coap_opt_put_string(buf, lastonum, COAP_OPT_LOCATION_PATH,
1748 location, '/');
1749}
1750
1761static inline size_t coap_opt_put_location_query(uint8_t *buf,
1762 uint16_t lastonum,
1763 const char *location)
1764{
1765 return coap_opt_put_string(buf, lastonum, COAP_OPT_LOCATION_QUERY,
1766 location, '&');
1767}
1768
1779static inline size_t coap_opt_put_uri_path(uint8_t *buf, uint16_t lastonum,
1780 const char *uri)
1781{
1782 return coap_opt_put_string(buf, lastonum, COAP_OPT_URI_PATH, uri, '/');
1783}
1784
1795static inline size_t coap_opt_put_uri_query(uint8_t *buf, uint16_t lastonum,
1796 const char *uri)
1797{
1798 return coap_opt_put_string(buf, lastonum, COAP_OPT_URI_QUERY, uri, '&');
1799}
1800
1819size_t coap_opt_put_uri_pathquery(uint8_t *buf, uint16_t *lastonum, const char *uri);
1820
1831static inline size_t coap_opt_put_proxy_uri(uint8_t *buf, uint16_t lastonum,
1832 const char *uri)
1833{
1834 return coap_opt_put_string(buf, lastonum, COAP_OPT_PROXY_URI, uri, '\0');
1835}
1836
1854size_t coap_put_block1_ok(uint8_t *pkt_pos, coap_block1_t *block1, uint16_t lastonum);
1855
1872size_t coap_put_option(uint8_t *buf, uint16_t lastonum, uint16_t onum, const void *odata, size_t olen);
1873
1886static inline size_t coap_put_option_block1(uint8_t *buf, uint16_t lastonum,
1887 unsigned blknum, unsigned szx, int more)
1888{
1889 return coap_opt_put_uint(buf, lastonum, COAP_OPT_BLOCK1,
1890 (blknum << 4) | szx | (more ? 0x8 : 0));
1891}
1892
1903static inline size_t coap_put_option_ct(uint8_t *buf, uint16_t lastonum,
1904 uint16_t content_type)
1905{
1906 return coap_opt_put_uint(buf, lastonum, COAP_OPT_CONTENT_FORMAT, content_type);
1907}
1933ssize_t coap_block2_build_reply(coap_pkt_t *pkt, unsigned code,
1934 uint8_t *rbuf, unsigned rlen, unsigned payload_len,
1935 coap_block_slicer_t *slicer);
1936
1951ssize_t coap_build_hdr(coap_hdr_t *hdr, unsigned type, const void *token,
1952 size_t token_len, unsigned code, uint16_t id);
1953
1982ssize_t coap_build_reply(coap_pkt_t *pkt, unsigned code,
1983 uint8_t *rbuf, unsigned rlen, unsigned payload_len);
1984
2000
2015ssize_t coap_handle_req(coap_pkt_t *pkt, uint8_t *resp_buf, unsigned resp_buf_len,
2016 coap_request_ctx_t *ctx);
2017
2034ssize_t coap_tree_handler(coap_pkt_t *pkt, uint8_t *resp_buf,
2035 unsigned resp_buf_len, coap_request_ctx_t *ctx,
2036 const coap_resource_t *resources,
2037 size_t resources_numof);
2038
2056ssize_t coap_subtree_handler(coap_pkt_t *pkt, uint8_t *resp_buf,
2057 size_t resp_buf_len, coap_request_ctx_t *context);
2058
2066static inline coap_method_flags_t coap_method2flag(unsigned code)
2067{
2068 return (1 << (code - 1));
2069}
2070
2085int coap_parse(coap_pkt_t *pkt, uint8_t *buf, size_t len);
2086
2101void coap_pkt_init(coap_pkt_t *pkt, uint8_t *buf, size_t len, size_t header_len);
2102
2116static inline void coap_payload_advance_bytes(coap_pkt_t *pkt, size_t len)
2117{
2118 pkt->payload += len;
2119 pkt->payload_len -= len;
2120}
2121
2143ssize_t coap_payload_put_bytes(coap_pkt_t *pkt, const void *data, size_t len);
2144
2158ssize_t coap_payload_put_char(coap_pkt_t *pkt, char c);
2159
2185ssize_t coap_build_reply_header(coap_pkt_t *pkt, unsigned code,
2186 void *buf, size_t len,
2187 int ct,
2188 void **payload, size_t *payload_len_max);
2189
2212 unsigned code,
2213 uint8_t *buf, size_t len,
2214 unsigned ct,
2215 const void *payload, size_t payload_len);
2216
2222 uint8_t *buf, size_t len,
2223 coap_request_ctx_t *context);
2229#ifndef CONFIG_NANOCOAP_SERVER_WELL_KNOWN_CORE
2230#define CONFIG_NANOCOAP_SERVER_WELL_KNOWN_CORE !IS_USED(MODULE_GCOAP)
2231#endif
2232
2248int coap_match_path(const coap_resource_t *resource, const uint8_t *uri);
2249
2250#if defined(MODULE_GCOAP) || defined(DOXYGEN)
2263static inline bool coap_has_observe(coap_pkt_t *pkt)
2264{
2265 return pkt->observe_value != UINT32_MAX;
2266}
2267
2273static inline void coap_clear_observe(coap_pkt_t *pkt)
2274{
2275 pkt->observe_value = UINT32_MAX;
2276}
2277
2285static inline uint32_t coap_get_observe(coap_pkt_t *pkt)
2286{
2287 return pkt->observe_value;
2288}
2290#endif
2291
2295#define COAP_WELL_KNOWN_CORE_DEFAULT_HANDLER \
2296 { \
2297 .path = "/.well-known/core", \
2298 .methods = COAP_GET, \
2299 .handler = coap_well_known_core_default_handler \
2300 }
2301
2302#ifdef __cplusplus
2303}
2304#endif
2305#endif /* NET_NANOCOAP_H */
POSIX.1-2008 compliant version of the assert macro.
#define assert(cond)
abort the program if assertion is false
Definition assert.h:136
Helper functions for bit arithmetic.
static unsigned bitarithm_msb(unsigned v)
Returns the number of the highest '1' bit in a value.
Definition bitarithm.h:153
bitfields operations on bitfields of arbitrary length
Functions to work with different byte orders.
static uint16_t ntohs(uint16_t v)
Convert from network byte order to host byte order, 16 bit.
Definition byteorder.h:536
static uint16_t byteorder_bebuftohs(const uint8_t *buf)
Read a big endian encoded unsigned integer from a buffer into host byte order encoded variable,...
Definition byteorder.h:551
Various helper macros.
coap_method_t
CoAP method codes used in request.
Definition coap.h:171
#define CONFIG_NANOCOAP_NOPTS_MAX
Maximum number of Options in a message.
Definition nanocoap.h:146
#define CONFIG_NANOCOAP_URI_MAX
Maximum length of a resource path string read from or written to a message.
Definition nanocoap.h:154
uint32_t coap_request_ctx_get_tl_type(const coap_request_ctx_t *ctx)
Get transport the packet was received over.
uint8_t * coap_find_option(coap_pkt_t *pkt, unsigned opt_num)
Get pointer to an option field by type.
static ssize_t coap_opt_add_uri_query(coap_pkt_t *pkt, const char *key, const char *val)
Adds a single Uri-Query option in the form 'key=value' into pkt.
Definition nanocoap.h:1438
static size_t coap_opt_put_uri_query(uint8_t *buf, uint16_t lastonum, const char *uri)
Convenience function for inserting URI_QUERY option into buffer.
Definition nanocoap.h:1795
size_t coap_opt_put_block(uint8_t *buf, uint16_t lastonum, coap_block_slicer_t *slicer, bool more, uint16_t option)
Insert block option into buffer.
static size_t coap_opt_put_block2_control(uint8_t *buf, uint16_t lastonum, coap_block1_t *block)
Insert block2 option into buffer in control usage.
Definition nanocoap.h:1690
static ssize_t coap_opt_add_block2(coap_pkt_t *pkt, coap_block_slicer_t *slicer, bool more)
Add block2 option in descriptive use from a slicer object.
Definition nanocoap.h:1291
static unsigned coap_get_code_raw(const coap_pkt_t *pkt)
Get a message's raw code (class + detail)
Definition nanocoap.h:510
ssize_t coap_build_reply_header(coap_pkt_t *pkt, unsigned code, void *buf, size_t len, int ct, void **payload, size_t *payload_len_max)
Create CoAP reply header (convenience function)
void coap_pkt_init(coap_pkt_t *pkt, uint8_t *buf, size_t len, size_t header_len)
Initialize a packet struct, to build a message buffer.
int coap_match_path(const coap_resource_t *resource, const uint8_t *uri)
Checks if a CoAP resource path matches a given URI.
static size_t coap_opt_put_block1(uint8_t *buf, uint16_t lastonum, coap_block_slicer_t *slicer, bool more)
Insert block1 option into buffer.
Definition nanocoap.h:1622
static ssize_t coap_opt_add_format(coap_pkt_t *pkt, uint16_t format)
Append a Content-Format option to the pkt buffer.
Definition nanocoap.h:1380
static uint8_t coap_code(unsigned cls, unsigned detail)
Encode given code class and code detail to raw code.
Definition nanocoap.h:462
bool coap_has_unprocessed_critical_options(const coap_pkt_t *pkt)
Check whether any of the packet's options that are critical.
static ssize_t coap_opt_add_uri_path(coap_pkt_t *pkt, const char *path)
Adds one or multiple Uri-Path options in the form '/path' into pkt.
Definition nanocoap.h:1518
static ssize_t coap_get_uri_query_string(coap_pkt_t *pkt, char *target, size_t max_len)
Convenience function for getting the packet's URI_QUERY option.
Definition nanocoap.h:882
ssize_t coap_handle_req(coap_pkt_t *pkt, uint8_t *resp_buf, unsigned resp_buf_len, coap_request_ctx_t *ctx)
Handle incoming CoAP request.
static unsigned coap_get_id(const coap_pkt_t *pkt)
Get the message ID of the given CoAP packet.
Definition nanocoap.h:534
static ssize_t coap_get_location_query(coap_pkt_t *pkt, uint8_t *target, size_t max_len)
Convenience function for getting the packet's LOCATION_QUERY option.
Definition nanocoap.h:842
static size_t coap_opt_put_uri_path(uint8_t *buf, uint16_t lastonum, const char *uri)
Convenience function for inserting URI_PATH option into buffer.
Definition nanocoap.h:1779
ssize_t coap_build_reply(coap_pkt_t *pkt, unsigned code, uint8_t *rbuf, unsigned rlen, unsigned payload_len)
Build reply to CoAP request.
static ssize_t coap_opt_add_accept(coap_pkt_t *pkt, uint16_t format)
Append an Accept option to the pkt buffer.
Definition nanocoap.h:1362
ssize_t coap_opt_get_string(coap_pkt_t *pkt, uint16_t optnum, uint8_t *target, size_t max_len, char separator)
Read a full option as null terminated string into the target buffer.
size_t coap_opt_put_uint(uint8_t *buf, uint16_t lastonum, uint16_t onum, uint32_t value)
Encode the given uint option into buffer.
void coap_request_ctx_init(coap_request_ctx_t *ctx, sock_udp_ep_t *remote)
Initialize CoAP request context.
static void coap_hdr_set_code(coap_hdr_t *hdr, uint8_t code)
Write the given raw message code to given CoAP header.
Definition nanocoap.h:685
ssize_t coap_payload_put_bytes(coap_pkt_t *pkt, const void *data, size_t len)
Add payload data to the CoAP request.
uint8_t * coap_iterate_option(coap_pkt_t *pkt, unsigned opt_num, uint8_t **opt_pos, int *opt_len)
Get pointer to an option field, can be called in a loop if there are multiple options with the same n...
int coap_opt_get_uint(coap_pkt_t *pkt, uint16_t optnum, uint32_t *value)
Get a uint32 option value.
unsigned coap_get_accept(coap_pkt_t *pkt)
Get the Accept option value from a packet if present.
static size_t coap_opt_put_string(uint8_t *buf, uint16_t lastonum, uint16_t optnum, const char *string, char separator)
Encode the given string as multi-part option into buffer.
Definition nanocoap.h:1725
uint16_t coap_method_flags_t
Method flag type.
Definition nanocoap.h:306
int coap_get_block(coap_pkt_t *pkt, coap_block1_t *block, uint16_t option)
Block option getter.
static unsigned coap_get_ver(const coap_pkt_t *pkt)
Get the CoAP version number.
Definition nanocoap.h:633
ssize_t coap_opt_get_next(const coap_pkt_t *pkt, coap_optpos_t *opt, uint8_t **value, bool init_opt)
Iterate over a packet's options.
static size_t coap_opt_put_block2(uint8_t *buf, uint16_t lastonum, coap_block_slicer_t *slicer, bool more)
Insert block2 option into buffer.
Definition nanocoap.h:1643
static bool coap_block2_finish(coap_block_slicer_t *slicer)
Finish a block2 response.
Definition nanocoap.h:1044
size_t coap_blockwise_put_bytes(coap_block_slicer_t *slicer, uint8_t *bufpos, const void *c, size_t len)
Add a byte array to a block2 reply.
static uint8_t coap_hdr_tkl_ext_len(const coap_hdr_t *hdr)
Get the size of the extended Token length field (RFC 8974)
Definition nanocoap.h:648
static coap_method_t coap_get_method(const coap_pkt_t *pkt)
Get a request's method type.
Definition nanocoap.h:522
static unsigned coap_get_total_hdr_len(const coap_pkt_t *pkt)
Get the total header length (4-byte header + token length)
Definition nanocoap.h:592
ssize_t coap_subtree_handler(coap_pkt_t *pkt, uint8_t *resp_buf, size_t resp_buf_len, coap_request_ctx_t *context)
Generic coap subtree handler.
static unsigned coap_get_code_class(const coap_pkt_t *pkt)
Get a message's code class (3 most significant bits of code)
Definition nanocoap.h:474
static int coap_get_block2(coap_pkt_t *pkt, coap_block1_t *block)
Block2 option getter.
Definition nanocoap.h:1155
ssize_t coap_build_empty_ack(coap_pkt_t *pkt, coap_hdr_t *ack)
Build empty reply to CoAP request.
ssize_t coap_block2_build_reply(coap_pkt_t *pkt, unsigned code, uint8_t *rbuf, unsigned rlen, unsigned payload_len, coap_block_slicer_t *slicer)
Build reply to CoAP block2 request.
void coap_block_slicer_init(coap_block_slicer_t *slicer, size_t blknum, size_t blksize)
Initialize a block slicer struct from content information.
static ssize_t coap_get_location_path(coap_pkt_t *pkt, uint8_t *target, size_t max_len)
Convenience function for getting the packet's LOCATION_PATH option.
Definition nanocoap.h:820
size_t coap_opt_put_string_with_len(uint8_t *buf, uint16_t lastonum, uint16_t optnum, const char *string, size_t len, char separator)
Encode the given string as multi-part option into buffer.
static ssize_t coap_opt_add_string(coap_pkt_t *pkt, uint16_t optnum, const char *string, char separator)
Encode the given string as option(s) into pkt.
Definition nanocoap.h:1498
bool coap_block_finish(coap_block_slicer_t *slicer, uint16_t option)
Finish a block request (block1 or block2)
static unsigned coap_get_code_detail(const coap_pkt_t *pkt)
Get a message's code detail (5 least significant bits of code)
Definition nanocoap.h:486
ssize_t coap_reply_simple(coap_pkt_t *pkt, unsigned code, uint8_t *buf, size_t len, unsigned ct, const void *payload, size_t payload_len)
Create CoAP reply (convenience function)
static int coap_get_block1(coap_pkt_t *pkt, coap_block1_t *block)
Block1 option getter.
Definition nanocoap.h:1141
void coap_block2_init(coap_pkt_t *pkt, coap_block_slicer_t *slicer)
Initialize a block2 slicer struct for writing the payload.
static uint8_t * coap_hdr_data_ptr(const coap_hdr_t *hdr)
Get the start of data after the header.
Definition nanocoap.h:674
ssize_t(* coap_handler_t)(coap_pkt_t *pkt, uint8_t *buf, size_t len, coap_request_ctx_t *context)
Resource handler type.
Definition nanocoap.h:272
ssize_t coap_payload_put_char(coap_pkt_t *pkt, char c)
Add a single character to the payload data of the CoAP request.
ssize_t coap_well_known_core_default_handler(coap_pkt_t *pkt, uint8_t *buf, size_t len, coap_request_ctx_t *context)
Reference to the default .well-known/core handler defined by the application.
static size_t coap_opt_put_proxy_uri(uint8_t *buf, uint16_t lastonum, const char *uri)
Convenience function for inserting PROXY_URI option into buffer.
Definition nanocoap.h:1831
static void coap_hdr_set_type(coap_hdr_t *hdr, unsigned type)
Set the message type for the given CoAP header.
Definition nanocoap.h:698
static void coap_payload_advance_bytes(coap_pkt_t *pkt, size_t len)
Advance the payload pointer.
Definition nanocoap.h:2116
bool coap_find_uri_query(coap_pkt_t *pkt, const char *key, const char **value, size_t *len)
Find a URI query option of the packet.
static uint32_t coap_get_observe(coap_pkt_t *pkt)
Get the value of the observe option from the given packet.
Definition nanocoap.h:2285
static size_t coap_put_option_block1(uint8_t *buf, uint16_t lastonum, unsigned blknum, unsigned szx, int more)
Insert block1 option into buffer.
Definition nanocoap.h:1886
static ssize_t coap_opt_add_block2_control(coap_pkt_t *pkt, coap_block1_t *block)
Encode the given block2 option in control use.
Definition nanocoap.h:1343
static unsigned coap_get_type(const coap_pkt_t *pkt)
Get the message type.
Definition nanocoap.h:621
static unsigned coap_get_code_decimal(const coap_pkt_t *pkt)
Get a message's code in decimal format ((class * 100) + detail)
Definition nanocoap.h:498
ssize_t coap_opt_get_opaque(coap_pkt_t *pkt, unsigned opt_num, uint8_t **value)
Retrieve the value for an option as an opaque array of bytes.
size_t coap_put_option(uint8_t *buf, uint16_t lastonum, uint16_t onum, const void *odata, size_t olen)
Insert a CoAP option into buffer.
ssize_t coap_opt_add_opaque(coap_pkt_t *pkt, uint16_t optnum, const void *val, size_t val_len)
Encode the given buffer as an opaque data option into pkt.
static ssize_t coap_opt_add_uri_path_buffer(coap_pkt_t *pkt, const char *path, size_t path_len)
Adds one or multiple Uri-Path options in the form '/path' into pkt.
Definition nanocoap.h:1538
static void * coap_get_token(const coap_pkt_t *pkt)
Get pointer to a message's token.
Definition nanocoap.h:580
static size_t coap_opt_put_location_query(uint8_t *buf, uint16_t lastonum, const char *location)
Convenience function for inserting LOCATION_QUERY option into buffer.
Definition nanocoap.h:1761
int coap_get_blockopt(coap_pkt_t *pkt, uint16_t option, uint32_t *blknum, uint8_t *szx)
Generic block option getter.
size_t coap_blockwise_put_char(coap_block_slicer_t *slicer, uint8_t *bufpos, char c)
Add a single character to a block2 reply.
static size_t coap_opt_put_location_path(uint8_t *buf, uint16_t lastonum, const char *location)
Convenience function for inserting LOCATION_PATH option into buffer.
Definition nanocoap.h:1743
static bool coap_block1_finish(coap_block_slicer_t *slicer)
Finish a block1 request.
Definition nanocoap.h:1025
void * coap_request_ctx_get_context(const coap_request_ctx_t *ctx)
Get resource context associated with a CoAP request.
static size_t coap_put_option_ct(uint8_t *buf, uint16_t lastonum, uint16_t content_type)
Insert content type option into buffer.
Definition nanocoap.h:1903
ssize_t coap_opt_add_proxy_uri(coap_pkt_t *pkt, const char *uri)
Adds a single Proxy-URI option into pkt.
int(* coap_blockwise_cb_t)(void *arg, size_t offset, uint8_t *buf, size_t len, int more)
Coap blockwise request callback descriptor.
Definition nanocoap.h:287
static unsigned coap_size2szx(unsigned len)
Helper to encode byte size into next equal or smaller SZX value.
Definition nanocoap.h:1209
int(* coap_request_cb_t)(void *arg, coap_pkt_t *pkt)
Coap request callback descriptor.
Definition nanocoap.h:299
static size_t coap_opt_put_block1_control(uint8_t *buf, uint16_t lastonum, coap_block1_t *block)
Insert block1 option into buffer in control usage.
Definition nanocoap.h:1672
const char * coap_request_ctx_get_path(const coap_request_ctx_t *ctx)
Get resource path associated with a CoAP request.
ssize_t coap_opt_add_block(coap_pkt_t *pkt, coap_block_slicer_t *slicer, bool more, uint16_t option)
Add block option in descriptive use from a slicer object.
const sock_udp_ep_t * coap_request_ctx_get_remote_udp(const coap_request_ctx_t *ctx)
Get the remote endpoint from which the request was received.
int coap_parse(coap_pkt_t *pkt, uint8_t *buf, size_t len)
Parse a CoAP PDU.
const sock_udp_ep_t * coap_request_ctx_get_local_udp(const coap_request_ctx_t *ctx)
Get the local endpoint on which the request has been received.
void coap_block_object_init(coap_block1_t *block, size_t blknum, size_t blksize, int more)
Initialize a block struct from content information.
ssize_t coap_opt_add_chars(coap_pkt_t *pkt, uint16_t optnum, const char *chars, size_t chars_len, char separator)
Encode the given array of characters as option(s) into pkt.
ssize_t coap_opt_remove(coap_pkt_t *pkt, uint16_t optnum)
Removes an option previously added with function in the coap_opt_add_...() group.
unsigned coap_get_content_type(coap_pkt_t *pkt)
Get content type from packet.
static ssize_t coap_get_proxy_uri(coap_pkt_t *pkt, char **target)
Convenience function for getting the packet's Proxy-Uri option.
Definition nanocoap.h:969
static ssize_t coap_get_uri_path(coap_pkt_t *pkt, uint8_t *target)
Convenience function for getting the packet's URI_PATH.
Definition nanocoap.h:863
ssize_t coap_opt_add_uint(coap_pkt_t *pkt, uint16_t optnum, uint32_t value)
Encode the given uint option into pkt.
static unsigned coap_get_total_len(const coap_pkt_t *pkt)
Get the total length of a CoAP packet in the packet buffer.
Definition nanocoap.h:606
static bool coap_has_observe(coap_pkt_t *pkt)
Identifies a packet containing an observe option.
Definition nanocoap.h:2263
ssize_t coap_build_hdr(coap_hdr_t *hdr, unsigned type, const void *token, size_t token_len, unsigned code, uint16_t id)
Builds a CoAP header.
size_t coap_put_block1_ok(uint8_t *pkt_pos, coap_block1_t *block1, uint16_t lastonum)
Insert block1 option into buffer (from coap_block1_t)
static ssize_t coap_opt_add_block1(coap_pkt_t *pkt, coap_block_slicer_t *slicer, bool more)
Add block1 option in descriptive use from a slicer object.
Definition nanocoap.h:1267
static coap_method_flags_t coap_method2flag(unsigned code)
Convert message code (request method) into a corresponding bit field.
Definition nanocoap.h:2066
size_t coap_opt_put_uri_pathquery(uint8_t *buf, uint16_t *lastonum, const char *uri)
Convenience function for inserting URI_PATH and URI_QUERY into buffer This function will automaticall...
static ssize_t coap_opt_add_block1_control(coap_pkt_t *pkt, coap_block1_t *block)
Encode the given block1 option in control use.
Definition nanocoap.h:1325
ssize_t coap_tree_handler(coap_pkt_t *pkt, uint8_t *resp_buf, unsigned resp_buf_len, coap_request_ctx_t *ctx, const coap_resource_t *resources, size_t resources_numof)
Pass a coap request to a matching handler.
static unsigned coap_get_token_len(const coap_pkt_t *pkt)
Get a message's token length [in byte].
Definition nanocoap.h:549
static void coap_clear_observe(coap_pkt_t *pkt)
Clears the observe option value from a packet.
Definition nanocoap.h:2273
ssize_t coap_opt_finish(coap_pkt_t *pkt, uint16_t flags)
Finalizes options as required and prepares for payload.
ssize_t coap_opt_add_uri_query2(coap_pkt_t *pkt, const char *key, size_t key_len, const char *val, size_t val_len)
Adds a single Uri-Query option in the form 'key=value' into pkt.
struct _sock_tl_ep sock_udp_ep_t
An end point for a UDP sock object.
Definition udp.h:293
Definitions for internet operations.
iolist scatter / gather IO
Common macros and compiler attributes/pragmas configuration.
#define IS_USED(module)
Checks whether a module is being used or not.
Definition modules.h:71
Generic CoAP values as defined by RFC7252.
UDP sock definitions.
CoAP resource request handler context.
Definition nanocoap.h:338
sock_udp_ep_t * local
local endpoint of the request
Definition nanocoap.h:342
const coap_resource_t * resource
resource of the request
Definition nanocoap.h:339
sock_udp_ep_t * remote
remote endpoint of the request
Definition nanocoap.h:340
uint32_t tl_type
transport the packet was received over
Definition nanocoap.h:351
Common IP-based transport layer end point.
Definition sock.h:215
Block1 helper struct.
Definition nanocoap.h:406
int8_t more
-1 for no option, 0 for last block, 1 for more blocks coming
Definition nanocoap.h:410
uint32_t blknum
block number
Definition nanocoap.h:408
size_t offset
offset of received data
Definition nanocoap.h:407
uint8_t szx
szx value
Definition nanocoap.h:409
Blockwise transfer helper struct.
Definition nanocoap.h:417
uint8_t * opt
Pointer to the placed option
Definition nanocoap.h:421
size_t end
End offset of the current block
Definition nanocoap.h:419
size_t start
Start offset of the current block
Definition nanocoap.h:418
size_t cur
Offset of the generated content
Definition nanocoap.h:420
Raw CoAP PDU header structure.
Definition nanocoap.h:201
uint8_t ver_t_tkl
version, token, token length
Definition nanocoap.h:202
uint8_t code
CoAP code (e.g.m 205)
Definition nanocoap.h:203
uint16_t id
Req/resp ID
Definition nanocoap.h:204
CoAP option array entry.
Definition nanocoap.h:210
uint16_t offset
offset in packet
Definition nanocoap.h:212
uint16_t opt_num
full CoAP option number
Definition nanocoap.h:211
CoAP PDU parsing context structure.
Definition nanocoap.h:232
uint8_t * payload
pointer to end of the header
Definition nanocoap.h:234
uint16_t payload_len
length of payload
Definition nanocoap.h:236
coap_hdr_t * hdr
pointer to raw packet
Definition nanocoap.h:233
uint16_t options_len
length of options array
Definition nanocoap.h:237
BITFIELD(opt_crit, CONFIG_NANOCOAP_NOPTS_MAX)
unhandled critical option
iolist_t * snips
payload snips (optional)
Definition nanocoap.h:235
Type for CoAP resource subtrees.
Definition nanocoap.h:321
const size_t resources_numof
number of entries in array
Definition nanocoap.h:323
const coap_resource_t * resources
ptr to resource array
Definition nanocoap.h:322
Type for CoAP resource entry.
Definition nanocoap.h:311
const char * path
URI path of resource
Definition nanocoap.h:312
coap_method_flags_t methods
OR'ed methods this resource allows.
Definition nanocoap.h:313
coap_handler_t handler
ptr to resource handler
Definition nanocoap.h:314
void * context
ptr to user defined context data
Definition nanocoap.h:315
iolist structure definition
Definition iolist.h:39
Cross File Arrays.