Loading...
Searching...
No Matches
nanocoap_sock.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2017 Kaspar Schleiser <kaspar@schleiser.de>
3 * 2018 Inria
4 * 2018 Freie Universität Berlin
5 *
6 * This file is subject to the terms and conditions of the GNU Lesser
7 * General Public License v2.1. See the file LICENSE in the top level
8 * directory for more details.
9 */
10
11#pragma once
12
138
139#include <stdint.h>
140#include <unistd.h>
141
142#include "random.h"
143#include "net/nanocoap.h"
144#include "net/sock/udp.h"
145#include "net/sock/util.h"
146#if IS_USED(MODULE_NANOCOAP_DTLS)
147#include "net/credman.h"
148#include "net/sock/dtls.h"
149#endif
150
151#ifdef __cplusplus
152extern "C" {
153#endif
154
159#ifndef CONFIG_NANOCOAP_SOCK_DTLS_TAG
160#define CONFIG_NANOCOAP_SOCK_DTLS_TAG (0xc0ab)
161#endif
162
167#ifndef CONFIG_NANOCOAP_SERVER_BUF_SIZE
168#define CONFIG_NANOCOAP_SERVER_BUF_SIZE ((1 << (CONFIG_NANOCOAP_BLOCKSIZE_DEFAULT + 3)) \
169 + CONFIG_NANOCOAP_URI_MAX + 16)
170#endif
171
175#ifndef CONFIG_NANOCOAP_SERVER_STACK_SIZE
176#define CONFIG_NANOCOAP_SERVER_STACK_SIZE THREAD_STACKSIZE_DEFAULT
177#endif
178
187#ifndef CONFIG_NANOCOAP_SOCK_BLOCK_TOKEN
188#define CONFIG_NANOCOAP_SOCK_BLOCK_TOKEN (0)
189#endif
190
194#ifndef CONFIG_NANOCOAP_SOCK_EVENT_PRIO
195# define CONFIG_NANOCOAP_SOCK_EVENT_PRIO EVENT_PRIO_MEDIUM
196#endif
197
205
209typedef struct {
211#if IS_USED(MODULE_NANOCOAP_DTLS) || defined(DOXYGEN)
217#endif
218 uint16_t msg_id;
222
226typedef struct {
228 const char *path;
229 uint32_t blknum;
231 uint8_t blksize;
233
242
246typedef struct {
249 uint8_t token[COAP_TOKEN_LENGTH_MAX];
250 uint8_t tkl;
251 uint8_t no_response;
253
277 coap_pkt_t *pkt, const coap_request_ctx_t *req);
278
290 const coap_request_ctx_t *req);
291
316 unsigned code, unsigned type,
317 const void *payload, size_t len);
318
345 void *buf, size_t buf_len,
346 unsigned code, unsigned type,
347 uint16_t msg_id);
348
369 const iolist_t *reply);
370
411
423 const coap_pkt_t *req_pkt);
424
431 uint16_t msg_id);
432
448
462 const void *payload, size_t payload_len);
463
472static inline uint16_t nanocoap_sock_next_msg_id(nanocoap_sock_t *sock)
473{
474 return sock->msg_id++;
475}
476
488int nanocoap_server(sock_udp_ep_t *local, void *buf, size_t bufsize);
489
501
513 const sock_udp_ep_t *local,
514 const sock_udp_ep_t *remote)
515{
516#if IS_USED(MODULE_NANOCOAP_DTLS)
518#endif
519 sock->msg_id = random_uint32();
520
521 return sock_udp_create(&sock->udp, local, remote, 0);
522}
523
524#if IS_USED(MODULE_NANOCOAP_DTLS) || DOXYGEN
538 const sock_udp_ep_t *remote, credman_tag_t tag);
539#endif
540
550int nanocoap_sock_url_connect(const char *url, nanocoap_sock_t *sock);
551
557static inline void nanocoap_sock_close(nanocoap_sock_t *sock)
558{
559#if IS_USED(MODULE_NANOCOAP_DTLS)
560 if (sock->type == COAP_SOCKET_TYPE_DTLS) {
561 sock_dtls_session_destroy(&sock->dtls, &sock->dtls_session);
562 sock_dtls_close(&sock->dtls);
563 }
564#endif
565 sock_udp_close(&sock->udp);
566}
567
593 uint8_t type, uint8_t method,
594 const void *token, size_t token_len);
595
619 uint8_t type, uint8_t method)
620{
621 return nanocoap_sock_builder_init_token(sock, state, type, method, NULL, 0);
622}
623
640 coap_request_cb_t cb, void *arg);
657
672ssize_t nanocoap_sock_get(nanocoap_sock_t *sock, const char *path,
673 void *response, size_t len_max);
674
689ssize_t nanocoap_sock_get_non(nanocoap_sock_t *sock, const char *path,
690 void *response, size_t len_max);
691
708ssize_t nanocoap_sock_put(nanocoap_sock_t *sock, const char *path,
709 const void *request, size_t len,
710 void *response, size_t len_max);
711
728ssize_t nanocoap_sock_put_non(nanocoap_sock_t *sock, const char *path,
729 const void *request, size_t len,
730 void *response, size_t len_max);
731
744ssize_t nanocoap_sock_put_url(const char *url,
745 const void *request, size_t len,
746 void *response, size_t len_max);
747
765ssize_t nanocoap_sock_post(nanocoap_sock_t *sock, const char *path,
766 const void *request, size_t len,
767 void *response, size_t len_max);
768
786ssize_t nanocoap_sock_post_non(nanocoap_sock_t *sock, const char *path,
787 const void *request, size_t len,
788 void *response, size_t len_max);
789
802ssize_t nanocoap_sock_post_url(const char *url,
803 const void *request, size_t len,
804 void *response, size_t len_max);
805
823ssize_t nanocoap_sock_fetch(nanocoap_sock_t *sock, const char *path,
824 const void *request, size_t len,
825 void *response, size_t len_max);
826
844ssize_t nanocoap_sock_fetch_non(nanocoap_sock_t *sock, const char *path,
845 const void *request, size_t len,
846 void *response, size_t len_max);
847
861ssize_t nanocoap_sock_fetch_url(const char *url,
862 const void *request, size_t len,
863 void *response, size_t len_max);
864
876ssize_t nanocoap_sock_delete(nanocoap_sock_t *sock, const char *path);
877
886ssize_t nanocoap_sock_delete_url(const char *url);
887
905 coap_blksize_t blksize,
906 coap_blockwise_cb_t callback, void *arg);
907
923int nanocoap_sock_get_slice(nanocoap_sock_t *sock, const char *path,
924 coap_blksize_t blksize, size_t offset,
925 void *dst, size_t len);
926
944int nanocoap_get_blockwise_url(const char *url,
945 coap_blksize_t blksize,
946 coap_blockwise_cb_t callback, void *arg);
947
967ssize_t nanocoap_get_blockwise_url_to_buf(const char *url,
968 coap_blksize_t blksize,
969 void *buf, size_t len);
970
990ssize_t nanocoap_get_blockwise_to_buf(nanocoap_sock_t *sock, const char *path,
991 coap_blksize_t blksize,
992 void *buf, size_t len);
993
1006ssize_t nanocoap_sock_request(nanocoap_sock_t *sock, coap_pkt_t *pkt, size_t len);
1007
1032 coap_request_cb_t cb, void *arg);
1033
1050ssize_t nanocoap_request(coap_pkt_t *pkt, const sock_udp_ep_t *local,
1051 const sock_udp_ep_t *remote, size_t len);
1052
1066 nanocoap_sock_t *sock,
1067 const char *url,
1068 coap_method_t method,
1069 coap_blksize_t blksize)
1070{
1071 ctx->sock = sock;
1072 ctx->path = sock_urlpath(url);
1073 ctx->blknum = 0;
1074 ctx->method = method;
1075 ctx->blksize = blksize;
1076 return nanocoap_sock_url_connect(url, ctx->sock);
1077}
1078
1100 const void *data, size_t len, bool more,
1101 coap_request_cb_t callback, void *arg);
1102#ifdef __cplusplus
1103}
1104#endif
#define WARN_UNUSED_RESULT
Attribute to add to a function whose return value should not silently be discarded.
(D)TLS credentials management module definitions
int16_t kernel_pid_t
Unique process identifier.
Definition sched.h:134
coap_blksize_t
Coap block-wise-transfer size SZX.
Definition coap.h:630
coap_method_t
CoAP method codes used in request.
Definition coap.h:170
uint16_t credman_tag_t
Tag of the credential.
Definition credman.h:95
#define CONFIG_NANOCOAP_BLOCK_HEADER_MAX
Maximum length of a CoAP header for a blockwise message.
Definition nanocoap.h:171
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:303
int(* coap_request_cb_t)(void *arg, coap_pkt_t *pkt)
Coap request callback descriptor.
Definition nanocoap.h:315
struct _coap_request_ctx coap_request_ctx_t
Forward declaration of internal CoAP resource request handler context.
Definition nanocoap.h:264
ssize_t nanocoap_server_build_separate(const nanocoap_server_response_ctx_t *ctx, void *buf, size_t buf_len, unsigned code, unsigned type, uint16_t msg_id)
Build a separate response header to a CoAP request.
int nanocoap_register_observer(const coap_request_ctx_t *req_ctx, coap_pkt_t *req_pkt)
Register an observer.
ssize_t nanocoap_sock_put_non(nanocoap_sock_t *sock, const char *path, const void *request, size_t len, void *response, size_t len_max)
Simple non-confirmable PUT.
ssize_t nanocoap_sock_get_non(nanocoap_sock_t *sock, const char *path, void *response, size_t len_max)
Simple non-confirmable GET.
ssize_t nanocoap_sock_get(nanocoap_sock_t *sock, const char *path, void *response, size_t len_max)
Simple synchronous CoAP (confirmable) GET.
ssize_t nanocoap_sock_delete(nanocoap_sock_t *sock, const char *path)
Simple synchronous CoAP (confirmable) DELETE.
void nanocoap_notify_observers(const coap_resource_t *res, const iolist_t *iol)
Notify all currently registered observers of the given resource.
ssize_t nanocoap_sock_observe_url(const char *url, coap_observe_client_t *ctx, coap_request_cb_t cb, void *arg)
Observe a CoAP resource behind a URL (via GET)
ssize_t nanocoap_sock_put(nanocoap_sock_t *sock, const char *path, const void *request, size_t len, void *response, size_t len_max)
Simple synchronous CoAP (confirmable) PUT.
void nanocoap_unregister_observer_due_to_reset(const sock_udp_ep_t *ep, uint16_t msg_id)
Unregister a stale observation due to a reset message received.
int nanocoap_sock_url_connect(const char *url, nanocoap_sock_t *sock)
Create a CoAP client socket by URL.
ssize_t nanocoap_sock_post_url(const char *url, const void *request, size_t len, void *response, size_t len_max)
Simple synchronous CoAP (confirmable) POST to URL.
ssize_t nanocoap_sock_delete_url(const char *url)
Simple synchronous CoAP (confirmable) DELETE for URL.
int nanocoap_sock_get_slice(nanocoap_sock_t *sock, const char *path, coap_blksize_t blksize, size_t offset, void *dst, size_t len)
Performs a blockwise coap get request to the specified url, store the response in a buffer.
static WARN_UNUSED_RESULT int nanocoap_sock_builder_init(nanocoap_sock_t *sock, coap_builder_t *state, uint8_t type, uint8_t method)
Initialize state for building a request.
ssize_t nanocoap_request(coap_pkt_t *pkt, const sock_udp_ep_t *local, const sock_udp_ep_t *remote, size_t len)
Simple synchronous CoAP request.
WARN_UNUSED_RESULT int nanocoap_sock_builder_init_token(nanocoap_sock_t *sock, coap_builder_t *state, uint8_t type, uint8_t method, const void *token, size_t token_len)
Initialize state for building a request.
int nanocoap_server_prepare_separate(nanocoap_server_response_ctx_t *ctx, coap_pkt_t *pkt, const coap_request_ctx_t *req)
Prepare the context for a separate response.
void nanocoap_notify_observers_simple(const coap_resource_t *res, uint32_t obs, const void *payload, size_t payload_len)
Build and send notification to observers registered to a specific resource.
kernel_pid_t nanocoap_server_start(const sock_udp_ep_t *local)
Create and start the nanoCoAP server thread.
ssize_t nanocoap_sock_request(nanocoap_sock_t *sock, coap_pkt_t *pkt, size_t len)
Simple synchronous CoAP request.
int nanocoap_server_sendv_separate(const nanocoap_server_response_ctx_t *ctx, const iolist_t *reply)
Send an already build separate response.
ssize_t nanocoap_sock_fetch(nanocoap_sock_t *sock, const char *path, const void *request, size_t len, void *response, size_t len_max)
Simple synchronous CoAP (confirmable) FETCH (RFC 8132)
int nanocoap_sock_dtls_connect(nanocoap_sock_t *sock, sock_udp_ep_t *local, const sock_udp_ep_t *remote, credman_tag_t tag)
Create a DTLS secured CoAP client socket.
ssize_t nanocoap_sock_fetch_non(nanocoap_sock_t *sock, const char *path, const void *request, size_t len, void *response, size_t len_max)
Simple non-confirmable FETCH (RFC 8132)
ssize_t nanocoap_sock_fetch_url(const char *url, const void *request, size_t len, void *response, size_t len_max)
Simple synchronous CoAP (confirmable) FETCH to URL (RFC 8132)
static uint16_t nanocoap_sock_next_msg_id(nanocoap_sock_t *sock)
Get next consecutive message ID for use when building a new CoAP request.
ssize_t nanocoap_sock_post(nanocoap_sock_t *sock, const char *path, const void *request, size_t len, void *response, size_t len_max)
Simple synchronous CoAP (confirmable) POST.
ssize_t nanocoap_sock_post_non(nanocoap_sock_t *sock, const char *path, const void *request, size_t len, void *response, size_t len_max)
Simple non-confirmable POST.
int nanocoap_server_send_separate(const nanocoap_server_response_ctx_t *ctx, unsigned code, unsigned type, const void *payload, size_t len)
Build and send a separate response to a CoAP request.
void nanocoap_unregister_observer(const coap_request_ctx_t *req_ctx, const coap_pkt_t *req_pkt)
Unregister an observer.
ssize_t nanocoap_sock_request_cb(nanocoap_sock_t *sock, coap_pkt_t *pkt, coap_request_cb_t cb, void *arg)
Simple synchronous CoAP request with callback.
static int nanocoap_block_request_connect_url(coap_block_request_t *ctx, nanocoap_sock_t *sock, const char *url, coap_method_t method, coap_blksize_t blksize)
Initialize block request context by URL and connect a socket.
ssize_t nanocoap_get_blockwise_url_to_buf(const char *url, coap_blksize_t blksize, void *buf, size_t len)
Performs a blockwise coap get request to the specified url, store the response in a buffer.
int nanocoap_get_blockwise_url(const char *url, coap_blksize_t blksize, coap_blockwise_cb_t callback, void *arg)
Performs a blockwise coap get request to the specified url.
int nanocoap_sock_block_request(coap_block_request_t *req, const void *data, size_t len, bool more, coap_request_cb_t callback, void *arg)
Do a block-wise request, send a single block.
ssize_t nanocoap_sock_put_url(const char *url, const void *request, size_t len, void *response, size_t len_max)
Simple synchronous CoAP (confirmable) PUT to URL.
static int nanocoap_sock_connect(nanocoap_sock_t *sock, const sock_udp_ep_t *local, const sock_udp_ep_t *remote)
Create a CoAP client socket.
ssize_t nanocoap_sock_unobserve_url(const char *url, coap_observe_client_t *ctx)
Stop observing a CoAP resource.
int nanocoap_sock_get_blockwise(nanocoap_sock_t *sock, const char *path, coap_blksize_t blksize, coap_blockwise_cb_t callback, void *arg)
Performs a blockwise coap get request on a socket.
bool nanocoap_server_is_remote_in_response_ctx(const nanocoap_server_response_ctx_t *ctx, const coap_request_ctx_t *req)
Check if a given separate response context was prepared for the remote endpoint of a given request.
nanocoap_socket_type_t
NanoCoAP socket types.
static void nanocoap_sock_close(nanocoap_sock_t *sock)
Close a CoAP client socket.
int nanocoap_server(sock_udp_ep_t *local, void *buf, size_t bufsize)
Start a nanoCoAP server instance.
ssize_t nanocoap_get_blockwise_to_buf(nanocoap_sock_t *sock, const char *path, coap_blksize_t blksize, void *buf, size_t len)
Performs a blockwise CoAP GET request, store the response in a buffer.
@ COAP_SOCKET_TYPE_UDP
transport is plain UDP
@ COAP_SOCKET_TYPE_DTLS
transport is DTLS
struct sock_udp sock_udp_t
forward declare for async
Definition types.h:139
struct sock_dtls sock_dtls_t
forward declare for async
Definition types.h:47
struct sock_dtls_session sock_dtls_session_t
Information about a created session.
Definition dtls.h:638
int sock_udp_create(sock_udp_t *sock, const sock_udp_ep_t *local, const sock_udp_ep_t *remote, uint16_t flags)
Creates a new UDP sock object.
void sock_udp_close(sock_udp_t *sock)
Closes a UDP sock object.
struct _sock_tl_ep sock_udp_ep_t
An end point for a UDP sock object.
Definition udp.h:295
const char * sock_urlpath(const char *url)
Returns a pointer to the path component in url.
struct iolist iolist_t
iolist forward declaration
Definition iolist.h:33
uint32_t random_uint32(void)
generates a random number on [0,0xffffffff]-interval
nanocoap API
Common interface to the software PRNG.
DTLS sock definitions.
UDP sock definitions.
Blockwise request helper struct.
nanocoap_sock_t * sock
socket used for the request
uint32_t blknum
current block number
const char * path
path on the server
coap_method_t method
request method (GET, POST, PUT)
uint8_t blksize
CoAP blocksize exponent.
Structure to hold the state for building a CoAP message.
Definition nanocoap.h:454
Observe Client helper struct.
coap_request_cb_t cb
user callback function
nanocoap_sock_t sock
socket used for the request
void * arg
callback function argument
CoAP PDU parsing context structure.
Definition nanocoap.h:229
Type for CoAP resource entry.
Definition nanocoap.h:327
Context from CoAP request for separate response.
uint8_t token[COAP_TOKEN_LENGTH_MAX]
request token
sock_udp_ep_t local
local from which to send response
uint8_t tkl
request token length
sock_udp_ep_t remote
remote to send response to
uint8_t no_response
no-response bitmap
NanoCoAP socket struct.
uint16_t msg_id
next CoAP message ID
uint8_t hdr_buf[CONFIG_NANOCOAP_BLOCK_HEADER_MAX]
buffer for CoAP header with options, token and payload marker
sock_dtls_session_t dtls_session
Session object for the stored socket.
sock_dtls_t dtls
DTLS socket.
sock_udp_t udp
UDP socket.
nanocoap_socket_type_t type
Socket type (UDP, DTLS)
sock utility function definitions