Loading...
Searching...
No Matches
gcoap.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2015-2017 Ken Bannister. All rights reserved.
3 * 2017 Freie Universität Berlin
4 *
5 * This file is subject to the terms and conditions of the GNU Lesser
6 * General Public License v2.1. See the file LICENSE in the top level
7 * directory for more details.
8 */
9
10#pragma once
11
398
399#include <stdint.h>
400
401#include "event/callback.h"
402#include "event/timeout.h"
403#include "net/ipv6/addr.h"
404#include "net/sock/udp.h"
405#if IS_USED(MODULE_GCOAP_DTLS)
406#include "net/sock/dtls.h"
407#endif
408#include "net/nanocoap.h"
409#include "net/nanocoap/cache.h"
410#include "timex.h"
411
412#ifdef __cplusplus
413extern "C" {
414#endif
415
425#ifndef CONFIG_GCOAP_PORT
426#define CONFIG_GCOAP_PORT (5683)
427#endif
431#ifndef CONFIG_GCOAPS_PORT
432#define CONFIG_GCOAPS_PORT (5684)
433#endif
434
438#ifndef CONFIG_GCOAP_DTLS_HANDSHAKE_TIMEOUT_MSEC
439#define CONFIG_GCOAP_DTLS_HANDSHAKE_TIMEOUT_MSEC (3 * MS_PER_SEC)
440#endif
441
447#ifndef CONFIG_GCOAP_DTLS_MINIMUM_AVAILABLE_SESSIONS
448#define CONFIG_GCOAP_DTLS_MINIMUM_AVAILABLE_SESSIONS (1)
449#endif
450
455#ifndef CONFIG_GCOAP_DTLS_MINIMUM_AVAILABLE_SESSIONS_TIMEOUT_MSEC
456#define CONFIG_GCOAP_DTLS_MINIMUM_AVAILABLE_SESSIONS_TIMEOUT_MSEC (15 * MS_PER_SEC)
457#endif
458
462#ifndef CONFIG_GCOAP_PDU_BUF_SIZE
463#define CONFIG_GCOAP_PDU_BUF_SIZE (128)
464#endif
465
469#ifndef CONFIG_GCOAP_REQ_WAITING_MAX
470#define CONFIG_GCOAP_REQ_WAITING_MAX (2)
471#endif
473
477#define GCOAP_TOKENLEN_MAX (8)
478
482#define GCOAP_HEADER_MAXLEN (sizeof(coap_hdr_t) + GCOAP_TOKENLEN_MAX)
483
490#ifndef CONFIG_GCOAP_TOKENLEN
491#define CONFIG_GCOAP_TOKENLEN (2)
492#endif
493
497#define GCOAP_PAYLOAD_MARKER (0xFF)
498
505#ifndef CONFIG_GCOAP_NO_AUTO_INIT
506#define CONFIG_GCOAP_NO_AUTO_INIT 0
507#endif
508
513#define GCOAP_MEMO_UNUSED (0)
514#define GCOAP_MEMO_RETRANSMIT (1)
515#define GCOAP_MEMO_WAIT (2)
516#define GCOAP_MEMO_RESP (3)
517#define GCOAP_MEMO_TIMEOUT (4)
518#define GCOAP_MEMO_ERR (5)
519#define GCOAP_MEMO_RESP_TRUNC (6)
522
526#define GCOAP_SEND_LIMIT_NON (-1)
527
528#ifdef DOXYGEN
538#define CONFIG_GCOAP_NO_RETRANS_BACKOFF
539#endif
540
547#ifndef CONFIG_GCOAP_NON_TIMEOUT_MSEC
548#define CONFIG_GCOAP_NON_TIMEOUT_MSEC (5000U)
549#endif
550
559#ifndef CONFIG_GCOAP_OBS_CLIENTS_MAX
560#define CONFIG_GCOAP_OBS_CLIENTS_MAX (2)
561#endif
562
572#ifndef CONFIG_GCOAP_OBS_NOTIFIERS_MAX
573#define CONFIG_GCOAP_OBS_NOTIFIERS_MAX (2)
574#endif
575
584#ifndef CONFIG_GCOAP_OBS_REGISTRATIONS_MAX
585#define CONFIG_GCOAP_OBS_REGISTRATIONS_MAX (2)
586#endif
587
592#define GCOAP_OBS_MEMO_UNUSED (0)
593#define GCOAP_OBS_MEMO_IDLE (1)
594#define GCOAP_OBS_MEMO_PENDING (2)
596
617#ifndef CONFIG_GCOAP_OBS_VALUE_WIDTH
618#define CONFIG_GCOAP_OBS_VALUE_WIDTH (3)
619#endif
620
624#if (CONFIG_GCOAP_OBS_VALUE_WIDTH == 3)
625#define GCOAP_OBS_TICK_EXPONENT (0)
626#elif (CONFIG_GCOAP_OBS_VALUE_WIDTH == 2)
627#define GCOAP_OBS_TICK_EXPONENT (6)
628#elif (CONFIG_GCOAP_OBS_VALUE_WIDTH == 1)
629#define GCOAP_OBS_TICK_EXPONENT (14)
630#endif
631
636#define GCOAP_OBS_INIT_OK (0)
637#define GCOAP_OBS_INIT_ERR (-1)
638#define GCOAP_OBS_INIT_UNUSED (-2)
640
645#ifndef GCOAP_DTLS_EXTRA_STACKSIZE
646#if IS_USED(MODULE_GCOAP_DTLS)
647#define GCOAP_DTLS_EXTRA_STACKSIZE (THREAD_STACKSIZE_DEFAULT)
648#else
649#define GCOAP_DTLS_EXTRA_STACKSIZE (0)
650#endif
651#endif
652
656#if IS_USED(MODULE_GCOAP_FILESERVER)
657#include "vfs.h"
658#define GCOAP_VFS_EXTRA_STACKSIZE (VFS_DIR_BUFFER_SIZE + VFS_FILE_BUFFER_SIZE)
659#else
660#define GCOAP_VFS_EXTRA_STACKSIZE (0)
661#endif
662
663#ifndef GCOAP_STACK_SIZE
664#define GCOAP_STACK_SIZE (THREAD_STACKSIZE_DEFAULT + DEBUG_EXTRA_STACKSIZE \
665 + sizeof(coap_pkt_t) + GCOAP_DTLS_EXTRA_STACKSIZE \
666 + GCOAP_VFS_EXTRA_STACKSIZE)
667#endif
669
674#ifndef CONFIG_GCOAP_RESEND_BUFS_MAX
675#define CONFIG_GCOAP_RESEND_BUFS_MAX (1)
676#endif
677
683#define COAP_LINK_FLAG_INIT_RESLIST (1)
685
687
691typedef struct {
692 unsigned content_format;
693 size_t link_pos;
694 uint16_t flags;
697
709typedef ssize_t (*gcoap_link_encoder_t)(const coap_resource_t *resource, char *buf,
710 size_t maxlen, coap_link_encoder_ctx_t *context);
711
716#define GCOAP_RESOURCE_FOUND (0)
717#define GCOAP_RESOURCE_WRONG_METHOD (1)
718#define GCOAP_RESOURCE_NO_PATH (2)
719#define GCOAP_RESOURCE_ERROR (3)
721
726
740 const coap_resource_t **resource,
741 coap_pkt_t *pdu);
742
754
758typedef struct {
760 union {
761 sock_udp_t *udp;
762#if IS_USED(MODULE_GCOAP_DTLS) || defined(DOXYGEN)
763 sock_dtls_t *dtls;
764#endif
766#if IS_USED(MODULE_GCOAP_DTLS) || defined(DOXYGEN)
770#endif
772
804
809
816typedef void (*gcoap_resp_handler_t)(const gcoap_request_memo_t *memo,
817 coap_pkt_t* pdu,
818 const sock_udp_ep_t *remote);
819
823typedef struct {
824 uint8_t *pdu_buf;
825 size_t pdu_len;
827
856
869
880
897
911 const coap_resource_t *last_resource,
912 const char *uri_path);
913
940int gcoap_req_init_path_buffer(coap_pkt_t *pdu, uint8_t *buf, size_t len,
941 unsigned code, const char *path,
942 size_t path_len);
943
968static inline int gcoap_req_init(coap_pkt_t *pdu, uint8_t *buf, size_t len,
969 unsigned code, const char *path)
970{
971 return gcoap_req_init_path_buffer(pdu, buf, len, code, path,
972 (path) ? strlen(path) : 0U);
973}
974
987static inline ssize_t gcoap_request(coap_pkt_t *pdu, uint8_t *buf, size_t len,
988 unsigned code, char *path)
989{
990 if (gcoap_req_init(pdu, buf, len, code, path) == 0) {
991 if (IS_USED(MODULE_NANOCOAP_CACHE)) {
992 /* remove ETag option slack added for cache validation */
993 coap_opt_remove(pdu, COAP_OPT_ETAG);
994 }
996 }
997 return -1;
998}
999
1022ssize_t gcoap_req_send(const uint8_t *buf, size_t len,
1023 const sock_udp_ep_t *remote, const sock_udp_ep_t *local,
1024 gcoap_resp_handler_t resp_handler, void *context,
1025 gcoap_socket_type_t tl_type);
1026
1040int gcoap_resp_init(coap_pkt_t *pdu, uint8_t *buf, size_t len, unsigned code);
1041
1053static inline ssize_t gcoap_response(coap_pkt_t *pdu, uint8_t *buf,
1054 size_t len, unsigned code)
1055{
1056 return (gcoap_resp_init(pdu, buf, len, code) == 0)
1058 : -1;
1059}
1060
1079int gcoap_obs_init(coap_pkt_t *pdu, uint8_t *buf, size_t len,
1080 const coap_resource_t *resource);
1081
1095size_t gcoap_obs_send(const uint8_t *buf, size_t len,
1096 const coap_resource_t *resource);
1097
1126int gcoap_obs_req_forget(const sock_udp_ep_t *remote, const uint8_t *token,
1127 size_t tokenlen);
1128
1136uint8_t gcoap_op_state(void);
1137
1160int gcoap_get_resource_list(void *buf, size_t maxlen, uint8_t cf,
1161 gcoap_socket_type_t tl_type);
1162
1176ssize_t gcoap_encode_link(const coap_resource_t *resource, char *buf,
1177 size_t maxlen, coap_link_encoder_ctx_t *context);
1178
1179#if IS_USED(MODULE_GCOAP_DTLS) || defined(DOXYGEN)
1188#endif
1189
1198{
1199 if (memo->send_limit == GCOAP_SEND_LIMIT_NON) {
1200 return (coap_hdr_t *)&memo->msg.hdr_buf[0];
1201 }
1202 else {
1203 return (coap_hdr_t *)memo->msg.data.pdu_buf;
1204 }
1205}
1206
1207#ifdef __cplusplus
1208}
1209#endif
1210
Provides a callback-with-argument event type.
Provides functionality to trigger events after timeout.
int16_t kernel_pid_t
Unique process identifier.
Definition sched.h:138
int gcoap_req_init_path_buffer(coap_pkt_t *pdu, uint8_t *buf, size_t len, unsigned code, const char *path, size_t path_len)
Initializes a CoAP request PDU on a buffer.
int gcoap_get_resource_list(void *buf, size_t maxlen, uint8_t cf, gcoap_socket_type_t tl_type)
Get the resource list, currently only CoRE Link Format (COAP_FORMAT_LINK) supported.
int gcoap_resp_init(coap_pkt_t *pdu, uint8_t *buf, size_t len, unsigned code)
Initializes a CoAP response packet on a buffer.
ssize_t(* gcoap_link_encoder_t)(const coap_resource_t *resource, char *buf, size_t maxlen, coap_link_encoder_ctx_t *context)
Handler function to write a resource link.
Definition gcoap.h:709
void gcoap_register_listener(gcoap_listener_t *listener)
Starts listening for resource paths.
static coap_hdr_t * gcoap_request_memo_get_hdr(const gcoap_request_memo_t *memo)
Get the header of a request from a gcoap_request_memo_t.
Definition gcoap.h:1197
static int gcoap_req_init(coap_pkt_t *pdu, uint8_t *buf, size_t len, unsigned code, const char *path)
Initializes a CoAP request PDU on a buffer.
Definition gcoap.h:968
#define GCOAP_TOKENLEN_MAX
Maximum length in bytes for a token.
Definition gcoap.h:477
gcoap_socket_type_t
CoAP socket types.
Definition gcoap.h:749
int gcoap_obs_init(coap_pkt_t *pdu, uint8_t *buf, size_t len, const coap_resource_t *resource)
Initializes a CoAP Observe notification packet on a buffer, for the observer registered for a resourc...
ssize_t gcoap_req_send(const uint8_t *buf, size_t len, const sock_udp_ep_t *remote, const sock_udp_ep_t *local, gcoap_resp_handler_t resp_handler, void *context, gcoap_socket_type_t tl_type)
Sends a buffer containing a CoAP request to the provided endpoint.
const coap_resource_t * gcoap_get_resource_by_path_iterator(const gcoap_listener_t **last_listener, const coap_resource_t *last_resource, const char *uri_path)
Iterate through all registered listeners and check for a resource, matching by uri_path.
#define GCOAP_HEADER_MAXLEN
Maximum length in bytes for a header, including the token.
Definition gcoap.h:482
sock_dtls_t * gcoap_get_sock_dtls(void)
Get the underlying DTLS socket of gcoap.
void(* gcoap_resp_handler_t)(const gcoap_request_memo_t *memo, coap_pkt_t *pdu, const sock_udp_ep_t *remote)
Handler function for a server response, including the state for the originating request.
Definition gcoap.h:816
#define GCOAP_SEND_LIMIT_NON
Value for send_limit in request memo when non-confirmable type.
Definition gcoap.h:526
ssize_t gcoap_encode_link(const coap_resource_t *resource, char *buf, size_t maxlen, coap_link_encoder_ctx_t *context)
Writes a resource in CoRE Link Format to a provided buffer.
struct gcoap_request_memo gcoap_request_memo_t
Forward declaration of the request memo type.
Definition gcoap.h:808
struct gcoap_listener gcoap_listener_t
Forward declaration of the gcoap listener state container.
Definition gcoap.h:725
size_t gcoap_obs_send(const uint8_t *buf, size_t len, const coap_resource_t *resource)
Sends a buffer containing a CoAP Observe notification to the observer registered for a resource.
int gcoap_obs_req_forget(const sock_udp_ep_t *remote, const uint8_t *token, size_t tokenlen)
Forgets (invalidates) an existing observe request.
static ssize_t gcoap_response(coap_pkt_t *pdu, uint8_t *buf, size_t len, unsigned code)
Writes a complete CoAP response PDU when there is no payload.
Definition gcoap.h:1053
int(* gcoap_request_matcher_t)(gcoap_listener_t *listener, const coap_resource_t **resource, coap_pkt_t *pdu)
Handler function for the request matcher strategy.
Definition gcoap.h:739
kernel_pid_t gcoap_init(void)
Initializes the gcoap thread and device.
uint8_t gcoap_op_state(void)
Provides important operational statistics.
static ssize_t gcoap_request(coap_pkt_t *pdu, uint8_t *buf, size_t len, unsigned code, char *path)
Writes a complete CoAP request PDU when there is not a payload.
Definition gcoap.h:987
@ GCOAP_SOCKET_TYPE_UDP
Unencrypted UDP transport.
Definition gcoap.h:751
@ GCOAP_SOCKET_TYPE_UNDEF
undefined
Definition gcoap.h:750
@ GCOAP_SOCKET_TYPE_DTLS
DTLS-over-UDP transport.
Definition gcoap.h:752
#define CONFIG_NANOCOAP_CACHE_KEY_LENGTH
The length of the cache key in bytes.
Definition cache.h:47
#define COAP_OPT_FINISH_NONE
no special handling required
Definition nanocoap.h:182
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.
ssize_t coap_opt_finish(coap_pkt_t *pkt, uint16_t flags)
Finalizes options as required and prepares for payload.
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:635
struct _sock_tl_ep sock_udp_ep_t
An end point for a UDP sock object.
Definition udp.h:293
int socket(int domain, int type, int protocol)
Create an endpoint for communication.
Definitions for IPv6 addresses.
#define IS_USED(module)
Checks whether a module is being used or not.
Definition modules.h:70
nanocoap-cache API
nanocoap API
DTLS sock definitions.
UDP sock definitions.
Raw CoAP PDU header structure.
Definition nanocoap.h:190
CoAP PDU parsing context structure.
Definition nanocoap.h:221
Type for CoAP resource entry.
Definition nanocoap.h:300
Callback Event structure definition.
Definition callback.h:48
Timeout Event structure.
Definition timeout.h:49
A modular collection of resources for a server.
Definition gcoap.h:776
gcoap_link_encoder_t link_encoder
Writes a link for a resource.
Definition gcoap.h:789
struct gcoap_listener * next
Next listener in list.
Definition gcoap.h:790
size_t resources_len
Length of array.
Definition gcoap.h:778
gcoap_socket_type_t tl_type
Transport type for the listener.
Definition gcoap.h:788
const coap_resource_t * resources
First element in the array of resources.
Definition gcoap.h:777
gcoap_request_matcher_t request_matcher
Function that picks a suitable request handler from a request.
Definition gcoap.h:802
Memo for Observe registration and notifications.
Definition gcoap.h:860
unsigned token_len
Actual length of token attribute.
Definition gcoap.h:866
uint8_t token[GCOAP_TOKENLEN_MAX]
Client token for notifications.
Definition gcoap.h:864
gcoap_socket_t socket
Transport type to observer.
Definition gcoap.h:867
const coap_resource_t * resource
Entity being observed.
Definition gcoap.h:863
sock_udp_ep_t * notifier
Local endpoint to send notifications.
Definition gcoap.h:862
uint16_t last_msgid
Message ID of last notification.
Definition gcoap.h:865
sock_udp_ep_t * observer
Client endpoint; unused if null.
Definition gcoap.h:861
Memo to handle a response for a request.
Definition gcoap.h:831
void * context
ptr to user defined context data
Definition gcoap.h:843
gcoap_resp_handler_t resp_handler
Callback for the response.
Definition gcoap.h:842
event_callback_t resp_tmout_cb
Callback for response timeout.
Definition gcoap.h:845
unsigned state
State of this memo, a GCOAP_MEMO...
Definition gcoap.h:832
int send_limit
Remaining resends, 0 if none; GCOAP_SEND_LIMIT_NON if non-confirmable.
Definition gcoap.h:833
gcoap_resend_t data
Endpoint and PDU buffer, for resend.
Definition gcoap.h:838
uint8_t cache_key[CONFIG_NANOCOAP_CACHE_KEY_LENGTH]
Cache key for the request.
Definition gcoap.h:853
sock_udp_ep_t remote_ep
Remote endpoint.
Definition gcoap.h:841
union gcoap_request_memo::@376103145064361232062134223007277344126205344350 msg
Request message data; if confirmable, supports resending message.
gcoap_socket_t socket
Transport type to remote endpoint.
Definition gcoap.h:846
uint8_t hdr_buf[GCOAP_HEADER_MAXLEN]
Copy of PDU header, if no resends.
Definition gcoap.h:836
event_timeout_t resp_evt_tmout
Limits wait for response.
Definition gcoap.h:844
Extends request memo for resending a confirmable request.
Definition gcoap.h:823
uint8_t * pdu_buf
Buffer containing the PDU.
Definition gcoap.h:824
size_t pdu_len
Length of pdu_buf.
Definition gcoap.h:825
CoAP socket to handle multiple transport types.
Definition gcoap.h:758
gcoap_socket_type_t type
Type of stored socket.
Definition gcoap.h:759
sock_dtls_session_t ctx_dtls_session
Session object for the stored socket.
Definition gcoap.h:767
Utility library for comparing and computing timestamps.