18#if COAP_SERVER_SUPPORT 
   21#ifdef COAP_EPOLL_SUPPORT 
   23#include <sys/timerfd.h> 
   27#define min(a,b) ((a) < (b) ? (a) : (b)) 
   38#define PRINT_WITH_OFFSET(Buf,Offset,Char)                \ 
   39  if ((Offset) == 0) {                                        \ 
   40    (*(Buf)++) = (Char);                                \ 
   48#define PRINT_COND_WITH_OFFSET(Buf,Bufend,Offset,Char,Result) {                \ 
   49    if ((Buf) < (Bufend)) {                                                \ 
   50      PRINT_WITH_OFFSET(Buf,Offset,Char);                                \ 
   60#define COPY_COND_WITH_OFFSET(Buf,Bufend,Offset,Str,Length,Result) {        \ 
   62    for (i = 0; i < (Length); i++) {                                        \ 
   63      PRINT_COND_WITH_OFFSET((Buf), (Bufend), (Offset), (Str)[i], (Result)); \ 
   69      int match_prefix, 
int match_substring) {
 
   76  if (match_substring) {
 
   77    const uint8_t *next_token = text->
s;
 
   78    size_t remaining_length = text->
length;
 
   79    while (remaining_length) {
 
   81      const uint8_t *token = next_token;
 
   82      next_token = (
unsigned char *)memchr(token, 
' ', remaining_length);
 
   85        token_length = next_token - token;
 
   86        remaining_length -= (token_length + 1);
 
   89        token_length = remaining_length;
 
   93      if ((match_prefix || pattern->
length == token_length) &&
 
   94          memcmp(token, pattern->
s, pattern->
length) == 0)
 
  100  return (match_prefix || pattern->
length == text->
length) &&
 
  101         memcmp(text->
s, pattern->
s, pattern->
length) == 0;
 
  106                     size_t *buflen, 
size_t offset,
 
  122                         size_t *buflen, 
size_t offset,
 
  125  unsigned char *p = buf;
 
  126  const uint8_t *bufend = buf + *buflen;
 
  127  size_t left, written = 0;
 
  129  const size_t old_offset = offset;
 
  130  int subsequent_resource = 0;
 
  131#ifdef WITHOUT_QUERY_FILTER 
  136#define MATCH_URI       0x01 
  137#define MATCH_PREFIX    0x02 
  138#define MATCH_SUBSTRING 0x04 
  140    {2, (
const uint8_t *)
"rt"},
 
  141    {2, (
const uint8_t *)
"if"},
 
  142    {3, (
const uint8_t *)
"rel"},
 
  148#ifndef WITHOUT_QUERY_FILTER 
  151    resource_param.
s = query_filter->
s;
 
  153           resource_param.
s[resource_param.
length] != 
'=')
 
  158      if (resource_param.
length == 4 &&
 
  159          memcmp(resource_param.
s, 
"href", 4) == 0)
 
  162      for (rt_attributes = _rt_attributes; rt_attributes->
s; rt_attributes++) {
 
  164            memcmp(resource_param.
s, rt_attributes->
s, rt_attributes->
length) == 0) {
 
  165          flags |= MATCH_SUBSTRING;
 
  172          query_filter->
s + resource_param.
length + 1;
 
  174      assert((resource_param.
length + 1) <= query_filter->
length);
 
  175      query_pattern.length =
 
  178      if ((query_pattern.s[0] == 
'/') && ((flags & MATCH_URI) == MATCH_URI)) {
 
  180        query_pattern.length--;
 
  183      if (query_pattern.length &&
 
  184          query_pattern.s[query_pattern.length-1] == 
'*') {
 
  185        query_pattern.length--;
 
  186        flags |= MATCH_PREFIX;
 
  198#ifndef WITHOUT_QUERY_FILTER 
  199    if (resource_param.
length) { 
 
  201      if (flags & MATCH_URI) {        
 
  202        if (!match(r->uri_path, &query_pattern, (flags & MATCH_PREFIX) != 0,
 
  203                   (flags & MATCH_SUBSTRING) != 0))
 
  209        if (!attr || !attr->
value)
 
  211        unquoted_val = *attr->
value;
 
  212        if (attr->
value->
s[0] == 
'"') {          
 
  216        if (!(match(&unquoted_val, &query_pattern,
 
  217                    (flags & MATCH_PREFIX) != 0,
 
  218                    (flags & MATCH_SUBSTRING) != 0)))
 
  224    if (!subsequent_resource) {        
 
  225      subsequent_resource = 1;
 
  227      PRINT_COND_WITH_OFFSET(p, bufend, offset, 
',', written);
 
  252  if (result + old_offset - offset < *buflen) {
 
  276    } 
else if (!uri_path) {
 
  293static const uint8_t coap_unknown_resource_uri[] =
 
  307    r->
flags = flags & ~COAP_RESOURCE_FLAGS_RELEASE_URI;
 
  321static const uint8_t coap_proxy_resource_uri[] =
 
  326                              size_t host_name_count,
 
  327                              const char *host_name_list[], 
int flags) {
 
  339    for (i = 0; i < (
sizeof(r->
handler) / 
sizeof(r->
handler[0])); i++) {
 
  342    if (host_name_count) {
 
  346        for (i = 0; i < host_name_count; i++) {
 
  349                                 strlen(host_name_list[i]));
 
  351            coap_log_err(
"coap_resource_proxy_uri_init: unable to add host name\n");
 
  362    r->
flags = flags & ~COAP_RESOURCE_FLAGS_RELEASE_URI;
 
  364    coap_log_debug(
"coap_resource_proxy_uri_init2: no memory left\n");
 
  372                             size_t host_name_count, 
const char *host_name_list[]) {
 
  377static const uint8_t coap_rev_proxy_resource_uri[] =
 
  392                                     sizeof(coap_rev_proxy_resource_uri)-1);
 
  393    r->
flags = flags & ~COAP_RESOURCE_FLAGS_RELEASE_URI;
 
  416  if (!resource || !name)
 
  450  if (!resource || !name)
 
  481typedef enum coap_deleting_resource_t {
 
  482  COAP_DELETING_RESOURCE,
 
  483  COAP_NOT_DELETING_RESOURCE,
 
  484  COAP_DELETING_RESOURCE_ON_EXIT
 
  485} coap_deleting_resource_t;
 
  488                                  coap_deleting_resource_t deleting);
 
  491coap_free_resource(
coap_resource_t *resource, coap_deleting_resource_t deleting) {
 
  499    coap_notify_observers(resource->
context, resource, deleting);
 
  517  LL_FOREACH_SAFE(resource->
subscribers, obs, otmp) {
 
  526  assert(resource->
ref);
 
  566      coap_log_warn(
"coap_add_resource: Duplicate uri_path '%*.*s', old resource deleted\n",
 
  572#if COAP_WITH_OBSERVE_PERSIST 
  573    if (context->unknown_pdu && context->dyn_resource_save_file &&
 
  577      raw_packet.
s = context->unknown_pdu->token -
 
  578                     context->unknown_pdu->hdr_size;
 
  579      raw_packet.
length = context->unknown_pdu->used_size +
 
  580                          context->unknown_pdu->hdr_size;
 
  586  assert(resource->
context == NULL);
 
  624  } 
else if (context) {
 
  636  coap_free_resource(resource, COAP_DELETING_RESOURCE);
 
  649  HASH_ITER(hh, context->
resources, res, rtmp) {
 
  650    HASH_DELETE(hh, context->
resources, res);
 
  651    coap_free_resource(res, COAP_DELETING_RESOURCE_ON_EXIT);
 
  657    coap_free_resource(context->
unknown_resource, COAP_DELETING_RESOURCE_ON_EXIT);
 
  691                unsigned char *buf, 
size_t *len, 
size_t *offset) {
 
  692  unsigned char *p = buf;
 
  693  const uint8_t *bufend = buf + *len;
 
  697  const size_t old_offset = *offset;
 
  700  PRINT_COND_WITH_OFFSET(p, bufend, *offset, 
'<', *len);
 
  701  PRINT_COND_WITH_OFFSET(p, bufend, *offset, 
'/', *len);
 
  703  COPY_COND_WITH_OFFSET(p, bufend, *offset,
 
  706  PRINT_COND_WITH_OFFSET(p, bufend, *offset, 
'>', *len);
 
  710    PRINT_COND_WITH_OFFSET(p, bufend, *offset, 
';', *len);
 
  712    COPY_COND_WITH_OFFSET(p, bufend, *offset,
 
  716      PRINT_COND_WITH_OFFSET(p, bufend, *offset, 
'=', *len);
 
  718      COPY_COND_WITH_OFFSET(p, bufend, *offset,
 
  724    COPY_COND_WITH_OFFSET(p, bufend, *offset, 
";obs", 4, *len);
 
  727#if COAP_OSCORE_SUPPORT 
  730    COPY_COND_WITH_OFFSET(p, bufend, *offset, 
";osc", 4, *len);
 
  741  if (result + old_offset - *offset < *len) {
 
  760  assert(method > 0 && (
size_t)(method-1) <
 
  762  resource->
handler[method-1] = handler;
 
  825                                               cache_ignore_options,
 
  826                                               sizeof(cache_ignore_options)/
sizeof(cache_ignore_options[0]));
 
  828      s = coap_find_observer_cache_key(resource, session, cache_key);
 
  843#if (COAP_RESOURCE_MAX_SUBSCRIBER > 0) 
  844  uint32_t subscriber_count = 0;
 
  845  LL_COUNT(resource->
subscribers, s, subscriber_count);
 
  846  if (subscriber_count >= COAP_RESOURCE_MAX_SUBSCRIBER) {
 
  862  if (s->
pdu == NULL) {
 
  872  if (cache_key == NULL) {
 
  875                                               cache_ignore_options,
 
  876                                               sizeof(cache_ignore_options)/
sizeof(cache_ignore_options[0]));
 
  877    if (cache_key == NULL) {
 
  891  coap_log_debug(
"create new subscription %p key 0x%02x%02x%02x%02x\n",
 
  892                 (
void *)s, s->cache_key->key[0], s->cache_key->key[1],
 
  893                 s->cache_key->key[2], s->cache_key->key[3]);
 
  899#if COAP_OSCORE_SUPPORT 
  902    if (session->recipient_ctx && session->recipient_ctx->recipient_id) {
 
  916      uint8_t info_buffer[60];
 
  917      uint8_t *info_buf = info_buffer;
 
  918      size_t info_len = 
sizeof(info_buffer);
 
  925                                   session->recipient_ctx->recipient_id->s,
 
  926                                   session->recipient_ctx->recipient_id->length);
 
  927      if (session->recipient_ctx->osc_ctx &&
 
  928          session->recipient_ctx->osc_ctx->id_context) {
 
  931                                     session->recipient_ctx->osc_ctx->id_context->s,
 
  932                                     session->recipient_ctx->osc_ctx->id_context->length);
 
  938        if (association->
aad) {
 
  954        if (association->
nonce) {
 
  981#if COAP_OSCORE_SUPPORT 
 1015    char outbuf[2 * 8 + 1] = 
"";
 
 1021      size_t size = strlen(outbuf);
 
 1023      snprintf(&outbuf[size], 
sizeof(outbuf)-size, 
"%02x",
 
 1028    coap_log_debug(
"removed subscription '/%*.*s%s%*.*s' (%p) with token '%s' key 0x%02x%02x%02x%02x\n",
 
 1029                   uri_path ? (
int)uri_path->
length : 0, uri_path ? (int)uri_path->length : 0,
 
 1030                   uri_path ? (char *)uri_path->s : 
"",
 
 1031                   uri_query ? 
"?" : 
"",
 
 1032                   uri_query ? (int)uri_query->length : 0, uri_query ? (int)uri_query->length : 0,
 
 1033                   uri_query ? (char *)uri_query->s : 
"",
 
 1034                   (void *)s, outbuf, s->cache_key->key[0], s->cache_key->key[1],
 
 1035                   s->cache_key->key[2], s-> cache_key->key[3]);
 
 1084                                               cache_ignore_options,
 
 1085                                               sizeof(cache_ignore_options)/
sizeof(cache_ignore_options[0]));
 
 1087      s = coap_find_observer_cache_key(resource, session, cache_key);
 
 1122                      coap_deleting_resource_t deleting) {
 
 1167           (obs->
non_cnt >= COAP_OBS_MAX_NON))) {
 
 1184        coap_log_debug(
"coap_check_notify: pdu init failed, resource stays " 
 1185                       "partially dirty\n");
 
 1186        goto next_one_fail_no_pending;
 
 1191        coap_log_debug(
"coap_check_notify: cannot add token, resource stays " 
 1192                       "partially dirty\n");
 
 1194        goto next_one_fail_no_pending;
 
 1202           obs->
non_cnt < COAP_OBS_MAX_NON)) {
 
 1208      case COAP_NOT_DELETING_RESOURCE:
 
 1224#if COAP_Q_BLOCK_SUPPORT 
 1260          coap_log_warn(
"handle_request: Invalid PDU response code (%d.%02d)\n",
 
 1262                        response->
code & 0x1f);
 
 1283      case COAP_DELETING_RESOURCE_ON_EXIT:
 
 1292      case COAP_DELETING_RESOURCE:
 
 1322#if COAP_Q_BLOCK_SUPPORT 
 1328          mid = coap_send_q_block2(obs_session, r, query, obs_pdu->
code,
 
 1329                                   block, response, 1);
 
 1337#if COAP_Q_BLOCK_SUPPORT 
 1341        coap_log_debug(
"*  %s: coap_check_notify: sending failed, resource stays " 
 1350next_one_fail_no_pending:
 
 1440    coap_log_debug(
"coap_resource_set_get_observable: Not supported for Unknown or Proxy URIs\n");
 
 1468      coap_notify_observers(context, r, COAP_NOT_DELETING_RESOURCE);
 
 1475                             uint32_t start_observe_no) {
 
 1479  resource->
observe = start_observe_no & 0xffffff;
 
 1499  LL_FOREACH_SAFE(resource->
subscribers, obs, otmp) {
 
 1500    if (obs->
session == session &&
 
 1505      if (obs->
fail_cnt >= COAP_OBS_MAX_FAIL) {
 
 1521    coap_remove_failed_observers(context, r, session, token);
 
int coap_is_af_unix(const coap_address_t *a)
Checks if given address a denotes a AF_UNIX address.
 
Library specific build wrapper for coap_internal.h.
 
void * coap_malloc_type(coap_memory_tag_t type, size_t size)
Allocates a chunk of size bytes and returns a pointer to the newly allocated memory.
 
void coap_free_type(coap_memory_tag_t type, void *p)
Releases the memory that was allocated by coap_malloc_type().
 
COAP_DEPRECATED COAP_API int coap_resource_set_dirty(coap_resource_t *r, const coap_string_t *query)
 
void coap_check_code_lg_xmit(const coap_session_t *session, const coap_pdu_t *request, coap_pdu_t *response, const coap_resource_t *resource, const coap_string_t *query)
The function checks that the code in a newly formed lg_xmit created by coap_add_data_large_response_l...
 
int coap_get_block_b(const coap_session_t *session, const coap_pdu_t *pdu, coap_option_num_t number, coap_block_b_t *block)
Initializes block from pdu.
 
void coap_delete_cache_key(coap_cache_key_t *cache_key)
Delete the cache-key.
 
coap_cache_key_t * coap_cache_derive_key_w_ignore(const coap_session_t *session, const coap_pdu_t *pdu, coap_cache_session_based_t session_based, const uint16_t *ignore_options, size_t ignore_count)
Calculates a cache-key for the given CoAP PDU.
 
@ COAP_CACHE_IS_SESSION_BASED
 
uint64_t coap_tick_t
This data type represents internal timer ticks with COAP_TICKS_PER_SECOND resolution.
 
#define COAP_TICKS_PER_SECOND
Use ms resolution on POSIX systems.
 
#define RESOURCES_ADD(r, obj)
 
void coap_delete_all_resources(coap_context_t *context)
Deletes all resources from given context and frees their storage.
 
void coap_resource_release_lkd(coap_resource_t *resource)
Decrement reference counter on a resource.
 
coap_print_status_t coap_print_wellknown_lkd(coap_context_t *context, unsigned char *buf, size_t *buflen, size_t offset, const coap_string_t *query_filter)
Prints the names of all known resources for context to buf.
 
void coap_delete_attr(coap_attr_t *attr)
Deletes an attribute.
 
coap_resource_t * coap_get_resource_from_uri_path_lkd(coap_context_t *context, coap_str_const_t *uri_path)
Returns the resource identified by the unique string uri_path.
 
void coap_resource_reference_lkd(coap_resource_t *resource)
Increment reference counter on a resource.
 
void coap_add_resource_lkd(coap_context_t *context, coap_resource_t *resource)
Registers the given resource for context.
 
#define RESOURCES_FIND(r, k, res)
 
int coap_delete_resource_lkd(coap_context_t *context, coap_resource_t *resource)
Deletes a resource identified by resource.
 
#define RESOURCES_DELETE(r, obj)
 
#define RESOURCES_ITER(r, tmp)
 
COAP_API coap_resource_t * coap_get_resource_from_uri_path(coap_context_t *context, coap_str_const_t *uri_path)
Returns the resource identified by the unique string uri_path.
 
#define COAP_RESOURCE_FLAGS_NOTIFY_NON
Observe Notifications will be sent non-confirmable by default.
 
coap_resource_t * coap_resource_proxy_uri_init(coap_method_handler_t handler, size_t host_name_count, const char *host_name_list[])
Creates a new resource object for handling proxy URIs.
 
coap_attr_t * coap_add_attr(coap_resource_t *resource, coap_str_const_t *name, coap_str_const_t *value, int flags)
Registers a new attribute with the given resource.
 
#define COAP_ATTR_FLAGS_RELEASE_VALUE
 
coap_print_status_t coap_print_link(const coap_resource_t *resource, unsigned char *buf, size_t *len, size_t *offset)
Writes a description of this resource in link-format to given text buffer.
 
coap_resource_t * coap_resource_proxy_uri_init2(coap_method_handler_t handler, size_t host_name_count, const char *host_name_list[], int flags)
Creates a new resource object for handling proxy URIs with configurable control over multicast reques...
 
#define COAP_RESOURCE_FLAGS_NOTIFY_NON_ALWAYS
Observe Notifications will always be sent non-confirmable.
 
#define COAP_RESOURCE_HANDLE_WELLKNOWN_CORE
Define this when invoking coap_resource_unknown_init2() if .well-known/core is to be passed to the un...
 
#define COAP_ATTR_FLAGS_RELEASE_NAME
 
void coap_resource_set_mode(coap_resource_t *resource, int mode)
Sets the notification message type of resource resource to given mode.
 
#define COAP_PRINT_STATUS_TRUNC
 
void(* coap_method_handler_t)(coap_resource_t *resource, coap_session_t *session, const coap_pdu_t *request, const coap_string_t *query, coap_pdu_t *response)
Definition of message handler function.
 
void coap_resource_release_userdata_handler(coap_context_t *context, coap_resource_release_userdata_handler_t callback)
Defines the context wide callback to use to when the resource is deleted to release the data held in ...
 
#define COAP_RESOURCE_FLAGS_OSCORE_ONLY
Define this resource as an OSCORE enabled access only.
 
COAP_API coap_print_status_t coap_print_wellknown(coap_context_t *context, unsigned char *buf, size_t *buflen, size_t offset, const coap_string_t *query_filter)
Prints the names of all known resources for context to buf.
 
#define COAP_RESOURCE_FLAGS_NOTIFY_CON
Observe Notifications will be sent confirmable.
 
coap_resource_t * coap_resource_reverse_proxy_init(coap_method_handler_t handler, int flags)
Creates a new resource object for the reverse-proxy resource handler with control over multicast requ...
 
COAP_API int coap_delete_resource(coap_context_t *context, coap_resource_t *resource)
Deletes a resource identified by resource.
 
void coap_register_handler(coap_resource_t *resource, coap_request_t method, coap_method_handler_t handler)
Registers the specified handler as message handler for the request type method.
 
#define COAP_PRINT_STATUS_MAX
 
void(* coap_resource_release_userdata_handler_t)(void *user_data)
Definition of release resource user_data callback function.
 
void coap_register_request_handler(coap_resource_t *resource, coap_request_t method, coap_method_handler_t handler)
Registers the specified handler as message handler for the request type method.
 
coap_resource_t * coap_resource_init(coap_str_const_t *uri_path, int flags)
Creates a new resource object and initializes the link field to the string uri_path.
 
void coap_resource_set_userdata(coap_resource_t *resource, void *data)
Sets the user_data.
 
uint32_t coap_print_status_t
Status word to encode the result of conditional print or copy operations such as coap_print_link().
 
#define COAP_PRINT_STATUS_ERROR
 
coap_str_const_t * coap_resource_get_uri_path(coap_resource_t *resource)
Get the uri_path from a resource.
 
coap_resource_t * coap_resource_unknown_init2(coap_method_handler_t put_handler, int flags)
Creates a new resource object for the unknown resource handler with support for PUT and configurable ...
 
coap_str_const_t * coap_attr_get_value(coap_attr_t *attribute)
Returns attribute's value.
 
#define COAP_PRINT_OUTPUT_LENGTH(v)
 
coap_attr_t * coap_find_attr(coap_resource_t *resource, coap_str_const_t *name)
Returns resource's coap_attr_t object with given name if found, NULL otherwise.
 
void * coap_resource_get_userdata(coap_resource_t *resource)
Gets the user_data.
 
COAP_API void coap_add_resource(coap_context_t *context, coap_resource_t *resource)
Registers the given resource for context.
 
#define COAP_RESOURCE_FLAGS_RELEASE_URI
The URI passed to coap_resource_init() is free'd by coap_delete_resource().
 
coap_resource_t * coap_resource_unknown_init(coap_method_handler_t put_handler)
Creates a new resource object for the unknown resource handler with support for PUT.
 
uint16_t coap_new_message_id_lkd(coap_session_t *session)
Returns a new message id and updates session->tx_mid accordingly.
 
coap_mid_t coap_send_internal(coap_session_t *session, coap_pdu_t *pdu, coap_pdu_t *request_pdu)
Sends a CoAP message to given peer.
 
int coap_check_code_class(coap_session_t *session, coap_pdu_t *pdu)
Check whether the pdu contains a valid code class.
 
void coap_cancel_all_messages(coap_context_t *context, coap_session_t *session, coap_bin_const_t *token)
Cancels all outstanding messages for session session that have the specified token.
 
void coap_ticks(coap_tick_t *t)
Returns the current value of an internal tick counter.
 
unsigned int coap_encode_var_safe(uint8_t *buf, size_t length, unsigned int val)
Encodes multiple-length byte sequences.
 
#define coap_lock_callback(func)
Dummy for no thread-safe code.
 
#define coap_lock_unlock()
Dummy for no thread-safe code.
 
#define coap_lock_check_locked()
Dummy for no thread-safe code.
 
#define coap_lock_callback_release(func, failed)
Dummy for no thread-safe code.
 
#define coap_lock_lock(failed)
Dummy for no thread-safe code.
 
#define coap_log_debug(...)
 
coap_log_t coap_get_log_level(void)
Get the current logging level.
 
void coap_show_pdu(coap_log_t level, const coap_pdu_t *pdu)
Display the contents of the specified pdu.
 
const char * coap_session_str(const coap_session_t *session)
Get session description.
 
#define coap_log_warn(...)
 
#define coap_log_err(...)
 
void coap_persist_set_observe_num(coap_resource_t *resource, uint32_t observe_num)
Sets the current observe number value.
 
void coap_resource_set_get_observable(coap_resource_t *resource, int mode)
Set whether a resource is observable.
 
COAP_API void coap_check_notify(coap_context_t *context)
Checks all known resources to see if they are dirty and then notifies subscribed observers.
 
COAP_API int coap_resource_notify_observers(coap_resource_t *resource, const coap_string_t *query)
Initiate the sending of an Observe packet for all observers of resource, optionally matching query if...
 
size_t oscore_cbor_put_nil(uint8_t **buffer, size_t *buf_size)
 
size_t oscore_cbor_put_bytes(uint8_t **buffer, size_t *buf_size, const uint8_t *bytes, size_t bytes_len)
 
size_t oscore_cbor_put_array(uint8_t **buffer, size_t *buf_size, size_t elements)
 
oscore_association_t * oscore_find_association(coap_session_t *session, coap_bin_const_t *token)
 
coap_pdu_t * coap_pdu_reference_lkd(coap_pdu_t *pdu)
Increment reference counter on a pdu to stop it prematurely getting freed off when coap_delete_pdu() ...
 
void coap_delete_pdu_lkd(coap_pdu_t *pdu)
Dispose of an CoAP PDU and free off associated storage.
 
int coap_remove_option(coap_pdu_t *pdu, coap_option_num_t number)
Removes (first) option of given number from the pdu.
 
coap_pdu_t * coap_pdu_duplicate_lkd(const coap_pdu_t *old_pdu, coap_session_t *session, size_t token_length, const uint8_t *token, coap_opt_filter_t *drop_options)
Duplicate an existing PDU.
 
COAP_STATIC_INLINE void coap_pdu_release_lkd(coap_pdu_t *pdu)
 
size_t coap_add_option_internal(coap_pdu_t *pdu, coap_option_num_t number, size_t len, const uint8_t *data)
Adds option of given number to pdu that is passed as first parameter.
 
#define COAP_OPTION_BLOCK2
 
int coap_mid_t
coap_mid_t is used to store the CoAP Message ID of a CoAP PDU.
 
coap_request_t
CoAP PDU Request methods.
 
#define COAP_RESPONSE_CODE(N)
 
#define COAP_RESPONSE_CLASS(C)
 
#define COAP_OPTION_OSCORE
 
int coap_add_token(coap_pdu_t *pdu, size_t len, const uint8_t *data)
Adds token of length len to pdu.
 
#define COAP_OPTION_Q_BLOCK2
 
int coap_get_data(const coap_pdu_t *pdu, size_t *len, const uint8_t **data)
Retrieves the length and data pointer of specified PDU.
 
coap_pdu_t * coap_pdu_init(coap_pdu_type_t type, coap_pdu_code_t code, coap_mid_t mid, size_t size)
Creates a new CoAP PDU with at least enough storage space for the given size maximum message size.
 
#define COAP_INVALID_MID
Indicates an invalid message id.
 
#define COAP_OPTION_MAXAGE
 
#define COAP_OPTION_OBSERVE
 
#define COAP_DEFAULT_URI_WELLKNOWN
well-known resources URI
 
int coap_add_data(coap_pdu_t *pdu, size_t len, const uint8_t *data)
Adds given data to the pdu that is passed as first parameter.
 
size_t coap_session_max_pdu_size_lkd(const coap_session_t *session)
Get maximum acceptable PDU size.
 
void coap_session_release_lkd(coap_session_t *session)
Decrement reference counter on a session.
 
coap_session_t * coap_session_reference_lkd(coap_session_t *session)
Increment reference counter on a session.
 
#define COAP_PROTO_NOT_RELIABLE(p)
 
void coap_delete_bin_const(coap_bin_const_t *s)
Deletes the given const binary data and releases any memory allocated.
 
void coap_delete_str_const(coap_str_const_t *s)
Deletes the given const string and releases any memory allocated.
 
coap_bin_const_t * coap_new_bin_const(const uint8_t *data, size_t size)
Take the specified byte array (text) and create a coap_bin_const_t * Returns a new const binary objec...
 
#define coap_binary_equal(binary1, binary2)
Compares the two binary data for equality.
 
#define coap_string_equal(string1, string2)
Compares the two strings for equality.
 
coap_str_const_t * coap_new_str_const(const uint8_t *data, size_t size)
Returns a new const string object with at least size+1 bytes storage allocated, and the provided data...
 
void coap_delete_string(coap_string_t *s)
Deletes the given string and releases any memory allocated.
 
void coap_delete_observer_internal(coap_resource_t *resource, coap_session_t *session, coap_subscription_t *subscription)
Removes specific subscription for session for resource and releases the allocated storage.
 
void coap_check_notify_lkd(coap_context_t *context)
Checks all known resources to see if they are dirty and then notifies subscribed observers.
 
int coap_delete_observer_request(coap_resource_t *resource, coap_session_t *session, const coap_bin_const_t *token, coap_pdu_t *request)
Removes any subscription for session observer from resource and releases the allocated storage.
 
int coap_delete_observer(coap_resource_t *resource, coap_session_t *session, const coap_bin_const_t *token)
Removes any subscription for session observer from resource and releases the allocated storage.
 
coap_subscription_t * coap_find_observer(coap_resource_t *resource, coap_session_t *session, const coap_bin_const_t *token)
Returns a subscription object for given peer.
 
void coap_delete_observers(coap_context_t *context, coap_session_t *session)
Removes any subscription for session and releases the allocated storage.
 
void coap_handle_failed_notify(coap_context_t *context, coap_session_t *session, const coap_bin_const_t *token)
Handles a failed observe notify.
 
int coap_resource_notify_observers_lkd(coap_resource_t *resource, const coap_string_t *query)
Initiate the sending of an Observe packet for all observers of resource, optionally matching query if...
 
void coap_subscription_init(coap_subscription_t *)
 
coap_subscription_t * coap_add_observer(coap_resource_t *resource, coap_session_t *session, const coap_bin_const_t *token, const coap_pdu_t *pdu)
Adds the specified peer as observer for resource.
 
void coap_touch_observer(coap_context_t *context, coap_session_t *session, const coap_bin_const_t *token)
Flags that data is ready to be sent to observers.
 
coap_string_t * coap_get_uri_path(const coap_pdu_t *request)
Extract uri_path string from request PDU.
 
coap_string_t * coap_get_query(const coap_pdu_t *request)
Extract query string from request PDU according to escape rules in 6.5.8.
 
coap_address_t local
local address and port
 
Limits the number of subscribers for each resource that this server support.
 
coap_str_const_t * value
Value of the attribute (can be NULL)
 
coap_str_const_t * name
Name of the attribute.
 
CoAP binary data definition with const data.
 
size_t length
length of binary data
 
const uint8_t * s
read-only binary data
 
Structure of Block options with BERT support.
 
unsigned int aszx
block size (0-7 including BERT
 
unsigned int m
1 if more blocks follow, 0 otherwise
 
unsigned int szx
block size (0-6)
 
The CoAP stack's global state is stored in a coap_context_t object.
 
coap_observe_added_t observe_added
Called when there is a new observe subscription request.
 
coap_resource_t * resources
hash table or list of known resources
 
coap_dyn_resource_added_t dyn_resource_added
Callback to save dynamic resource when created.
 
coap_resource_release_userdata_handler_t release_userdata
function to release user_data when resource is deleted
 
void * observe_user_data
App provided data for use in observe_added or observe_deleted.
 
coap_track_observe_value_t track_observe_value
Callback to save observe value when updated.
 
uint8_t observe_pending
Observe response pending.
 
uint32_t observe_save_freq
How frequently to update observe value.
 
uint8_t observe_no_clear
Observe 4.04 not to be sent on deleting resource.
 
coap_resource_t * proxy_uri_resource
can be used for handling proxy URI resources
 
coap_observe_deleted_t observe_deleted
Called when there is a observe subscription de-register request.
 
coap_resource_t * unknown_resource
can be used for handling unknown resources
 
coap_resource_deleted_t resource_deleted
Invoked when resource is deleted.
 
coap_address_t bind_addr
local interface address
 
coap_tick_t last_all_sent
Last time all data sent or 0.
 
coap_tick_t last_obs
Last time used (Observe tracking) or 0.
 
uint8_t * token
first byte of token (or extended length bytes prefix), if any, or options
 
size_t max_size
maximum size for token, options and payload, or zero for variable size pdu
 
coap_pdu_code_t code
request method (value 1–31) or response code (value 64-255)
 
uint8_t hdr_size
actual size used for protocol-specific header (0 until header is encoded)
 
coap_bin_const_t actual_token
Actual token in pdu.
 
coap_mid_t mid
message id, if any, in regular host byte order
 
size_t used_size
used bytes of storage for token, options and payload
 
coap_pdu_type_t type
message type
 
Abstraction of resource that can be attached to coap_context_t.
 
unsigned int dirty
set to 1 if resource has changed
 
unsigned int partiallydirty
set to 1 if some subscribers have not yet been notified of the last change
 
unsigned int list_being_traversed
resource subscriber list being traversed
 
coap_subscription_t * subscribers
list of observers for this resource
 
void * user_data
This pointer is under user control.
 
coap_str_const_t ** proxy_name_list
Array valid names this host is known by (proxy support)
 
coap_str_const_t * uri_path
Request URI Path for this resource.
 
unsigned int observe
The next value for the Observe option.
 
coap_context_t * context
Pointer back to the context that 'owns' this resource.
 
coap_method_handler_t handler[7]
Used to store handlers for the seven coap methods GET, POST, PUT, DELETE, FETCH, PATCH and IPATCH.
 
uint32_t ref
Resource reference count.
 
unsigned int is_proxy_uri
resource created for proxy URI handler
 
unsigned int is_dynamic
create unknown resource dynamically
 
unsigned int is_unknown
resource created for unknown handler
 
coap_attr_t * link_attr
attributes to be included with the link format
 
unsigned int is_reverse_proxy
resource created for reverse proxy URI handler
 
unsigned int observable
can be observed
 
size_t proxy_name_count
Count of valid names this host is known by (proxy support)
 
int flags
zero or more COAP_RESOURCE_FLAGS_* or'd together
 
Abstraction of virtual session that can be attached to coap_context_t (client) or coap_endpoint_t (se...
 
coap_lg_xmit_t * lg_xmit
list of large transmissions
 
unsigned ref_subscriptions
reference count of current subscriptions
 
coap_endpoint_t * endpoint
session's endpoint
 
coap_addr_tuple_t addr_info
remote/local address info
 
coap_proto_t proto
protocol used
 
uint8_t con_active
Active CON request sent.
 
coap_context_t * context
session's context
 
CoAP string data definition with const data.
 
const uint8_t * s
read-only string data
 
size_t length
length of string
 
CoAP string data definition.
 
size_t length
length of string
 
Number of notifications that may be sent non-confirmable before a confirmable message is sent to dete...
 
uint8_t dirty
set if the notification temporarily could not be sent (in that case, the resource's partially dirty f...
 
uint8_t non_cnt
up to 255 non-confirmable notifies allowed
 
coap_cache_key_t * cache_key
 
struct coap_session_t * session
subscriber session
 
uint8_t fail_cnt
up to 255 confirmable notifies can fail
 
coap_pdu_t * pdu
cache_key to identify requester
 
coap_bin_const_t * partial_iv