Documentation

Documentation

Includes

uthash.h

#include "uthash.h"
#include "uthash.h"

async.h

#include "async.h"
#include "async.h"

str.h

#include "str.h"
#include "str.h"

pdu.h

#include "pdu.h"
#include "pdu.h"

coap_net.h

#include "coap_net.h"
#include "coap_net.h"

subscribe.h

#include "subscribe.h"
#include "subscribe.h"

Macros

Marco COAP_RESOURCE_H_

#define COAP_RESOURCE_H_


      

Marco COAP_RESOURCE_CHECK_TIME

#define COAP_RESOURCE_CHECK_TIME 2
/** The interval in seconds to check if resources have changed. */

Marco COAP_ATTR_FLAGS_RELEASE_NAME

#define COAP_ATTR_FLAGS_RELEASE_NAME 1


      

Marco COAP_ATTR_FLAGS_RELEASE_VALUE

#define COAP_ATTR_FLAGS_RELEASE_VALUE 2


      

Marco COAP_RESOURCE_FLAGS_RELEASE_URI

#define COAP_RESOURCE_FLAGS_RELEASE_URI 1
/** The URI passed to coap_resource_init() is free'd by coap_delete_resource(). */

Marco COAP_RESOURCE_FLAGS_NOTIFY_NON

#define COAP_RESOURCE_FLAGS_NOTIFY_NON 0
/**
 * Notifications will be sent non-confirmable by default. RFC 7641 Section 4.5
 * https://tools.ietf.org/html/rfc7641#section-4.5
 */

Marco COAP_RESOURCE_FLAGS_NOTIFY_CON

#define COAP_RESOURCE_FLAGS_NOTIFY_CON 2
/**
 * Notifications will be sent confirmable by default. RFC 7641 Section 4.5
 * https://tools.ietf.org/html/rfc7641#section-4.5
 */

Marco COAP_PRINT_STATUS_MASK

#define COAP_PRINT_STATUS_MASK 4026531840u


      

Marco COAP_PRINT_OUTPUT_LENGTH(v)

#define COAP_PRINT_OUTPUT_LENGTH(v) ((v) & ~COAP_PRINT_STATUS_MASK)


      

Marco COAP_PRINT_STATUS_ERROR

#define COAP_PRINT_STATUS_ERROR 2147483648u


      

Marco COAP_PRINT_STATUS_TRUNC

#define COAP_PRINT_STATUS_TRUNC 1073741824u


      

Marco RESOURCES_ADD(r, obj)

#define RESOURCES_ADD(r, obj) \
 HASH_ADD(hh, (r), uri_path->s[0], (obj)->uri_path->length, (obj))


      

Marco RESOURCES_DELETE(r, obj)

#define RESOURCES_DELETE(r, obj) \
 HASH_DELETE(hh, (r), (obj))


      

Marco RESOURCES_ITER(r,tmp)

#define RESOURCES_ITER(r,tmp) \
 coap_resource_t *tmp, *rtmp; \
 HASH_ITER(hh, (r), tmp, rtmp)


      

Marco RESOURCES_FIND(r, k, res)

#define RESOURCES_FIND(r, k, res) {                    \
   HASH_FIND(hh, (r), (k)->s, (k)->length, (res)); \
 }

      

Functions

Func coap_add_resource

void coap_add_resource(coap_context_t *context, coap_resource_t *resource);
/**
 * Registers the given @p resource for @p context. The resource must have been
 * created by coap_resource_init() or coap_resource_unknown_init(), the
 * storage allocated for the resource will be released by coap_delete_resource().
 *
 * @param context  The context to use.
 * @param resource The resource to store.
 */

Func coap_delete_resource

int coap_delete_resource(coap_context_t *context, coap_resource_t *resource);
/**
 * Deletes a resource identified by @p resource. The storage allocated for that
 * resource is freed, and removed from the context.
 *
 * @param context  The context where the resources are stored.
 * @param resource The resource to delete.
 *
 * @return         @c 1 if the resource was found (and destroyed),
 *                 @c 0 otherwise.
 */

Func coap_delete_all_resources

void coap_delete_all_resources(coap_context_t *context);
/**
 * Deletes all resources from given @p context and frees their storage.
 *
 * @param context The CoAP context with the resources to be deleted.
 */

Func coap_delete_attr

void coap_delete_attr(coap_attr_t *attr);
/**
 * Deletes an attribute.
 * Note: This is for internal use only, as it is not deleted from its chain.
 *
 * @param attr Pointer to a previously created attribute.
 *
 */
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. @p
 * len must be initialized to the maximum length of @p buf and will be set to
 * the number of characters actually written if successful. This function
 * returns @c 1 on success or @c 0 on error.
 *
 * @param resource The resource to describe.
 * @param buf      The output buffer to write the description to.
 * @param len      Must be initialized to the length of @p buf and
 *                 will be set to the length of the printed link description.
 * @param offset   The offset within the resource description where to
 *                 start writing into @p buf. This is useful for dealing
 *                 with the Block2 option. @p offset is updated during
 *                 output as it is consumed.
 *
 * @return If COAP_PRINT_STATUS_ERROR is set, an error occured. Otherwise,
 *         the lower 28 bits will indicate the number of characters that
 *         have actually been output into @p buffer. The flag
 *         COAP_PRINT_STATUS_TRUNC indicates that the output has been
 *         truncated.
 */

Func coap_register_handler

void coap_register_handler(coap_resource_t *resource,
                          unsigned char method,
                          coap_method_handler_t handler);
/**
 * Registers the specified @p handler as message handler for the request type @p
 * method
 *
 * @param resource The resource for which the handler shall be registered.
 * @param method   The CoAP request method to handle.
 * @param handler  The handler to register with @p resource.
 */

Func coap_touch_observer

void coap_touch_observer(coap_context_t *context,
                        coap_session_t *session,
                        const coap_binary_t *token);
/**
 * Marks an observer as alive.
 *
 * @param context  The CoAP context to use.
 * @param session  The observer's session
 * @param token    The corresponding token that has been used for the
 *                 subscription.
 */

Func coap_delete_observer

int coap_delete_observer(coap_resource_t *resource,
                        coap_session_t *session,
                        const coap_binary_t *token);
/**
 * Removes any subscription for @p observer from @p resource and releases the
 * allocated storage. The result is @c 1 if an observation relationship with @p
 * observer and @p token existed, @c 0 otherwise.
 *
 * @param resource The observed resource.
 * @param session  The observer's session.
 * @param token    The token that identifies this subscription or @c NULL for
 *                 any token.
 * @return         @c 1 if the observer has been deleted, @c 0 otherwise.
 */

Func coap_delete_observers

void coap_delete_observers(coap_context_t *context, coap_session_t *session);
/**
 * Removes any subscription for @p session and releases the allocated storage.
 *
 * @param context  The CoAP context to use.
 * @param session  The observer's session.
 */

Func coap_check_notify

void coap_check_notify(coap_context_t *context);
/**
 * Checks for all known resources, if they are dirty and notifies subscribed
 * observers.
 */

Func coap_print_wellknown

coap_print_status_t coap_print_wellknown(coap_context_t *,
                                        unsigned char *,
                                        size_t *, size_t,
                                        coap_opt_t *);


      

Func coap_handle_failed_notify

void
coap_handle_failed_notify(coap_context_t *,
                         coap_session_t *,
                         const coap_binary_t *);


      

Func coap_resource_notify_observers

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 @p resource,
 * optionally matching @p query if not NULL
 *
 * @param resource The CoAP resource to use.
 * @param query    The Query to match against or NULL
 *
 * @return         @c 1 if the Observe has been triggered, @c 0 otherwise.
 */

Vars

Variable coap_resource_t

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
 * @p uri_path. This function returns the new coap_resource_t object.
 *
 * If the string is going to be freed off by coap_delete_resource() when
 * COAP_RESOURCE_FLAGS_RELEASE_URI is set in @p flags, then either the 's'
 * variable of coap_str_const_t has to point to constant text, or point to data
 * within the allocated coap_str_const_t parameter.
 *
 * @param uri_path The string URI path of the new resource.
 * @param flags    Flags for memory management (in particular release of
 *                 memory). Possible values:@n
 *
 *                 COAP_RESOURCE_FLAGS_RELEASE_URI
 *                  If this flag is set, the URI passed to
 *                  coap_resource_init() is free'd by
 *                  coap_delete_resource()@n
 *
 *                 COAP_RESOURCE_FLAGS_NOTIFY_CON
 *                  If this flag is set, coap-observe notifications
 *                  will be sent confirmable by default.@n
 *
 *                 COAP_RESOURCE_FLAGS_NOTIFY_NON (default)
 *                  If this flag is set, coap-observe notifications
 *                  will be sent non-confirmable by default.@n
 *
 *                  If flags is set to 0 then the
 *                  COAP_RESOURCE_FLAGS_NOTIFY_NON is considered.
 *
 * @return         A pointer to the new object or @c NULL on error.
 */

Variable coap_resource_t

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.
 *
 * In the same way that additional handlers can be added to the resource
 * created by coap_resource_init() by using coap_register_handler(), POST,
 * GET, DELETE etc. handlers can be added to this resource. It is the
 * responsibility of the application to manage the unknown resources by either
 * creating new resources with coap_resource_init() (which should have a
 * DELETE handler specified for the resource removal) or by maintaining an
 * active resource list.
 *
 * Note: There can only be one unknown resource handler per context - attaching
 *       a new one overrides the previous definition.
 *
 * Note: It is not possible to observe the unknown resource with a GET request
 *       - a separate resource needs to be reated by the PUT (or POST) handler,
 *       and make that resource observable.
 *
 * This function returns the new coap_resource_t object.
 *
 * @param put_handler The PUT handler to register with @p resource for
 *                    unknown Uri-Path.
 *
 * @return       A pointer to the new object or @c NULL on error.
 */

Variable coap_attr_t

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 @p resource. As the
 * attribute's coap_str_const_ fields will point to @p name and @p value the
 * caller must ensure that these pointers are valid during the
 * attribute's lifetime.

 * If the @p name and/or @p value string is going to be freed off at attribute
 * removal time by the setting of COAP_ATTR_FLAGS_RELEASE_NAME or
 * COAP_ATTR_FLAGS_RELEASE_VALUE in @p flags, then either the 's'
 * variable of coap_str_const_t has to point to constant text, or point to data
 * within the allocated coap_str_const_t parameter.
 *
 * @param resource The resource to register the attribute with.
 * @param name     The attribute's name as a string.
 * @param value    The attribute's value as a string or @c NULL if none.
 * @param flags    Flags for memory management (in particular release of
 *                 memory). Possible values:@n
 *
 *                 COAP_ATTR_FLAGS_RELEASE_NAME
 *                  If this flag is set, the name passed to
 *                  coap_add_attr_release() is free'd
 *                  when the attribute is deleted@n
 *
 *                 COAP_ATTR_FLAGS_RELEASE_VALUE
 *                  If this flag is set, the value passed to
 *                  coap_add_attr_release() is free'd
 *                  when the attribute is deleted@n
 *
 * @return         A pointer to the new attribute or @c NULL on error.
 */

Variable coap_attr_t

coap_attr_t *coap_find_attr(coap_resource_t *resource,
                           coap_str_const_t *name);
/**
 * Returns @p resource's coap_attr_t object with given @p name if found, @c NULL
 * otherwise.
 *
 * @param resource The resource to search for attribute @p name.
 * @param name     Name of the requested attribute as a string.
 * @return         The first attribute with specified @p name or @c NULL if none
 *                 was found.
 */

Variable coap_resource_t

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 @p uri_path. If no
 * resource was found, this function returns @c NULL.
 *
 * @param context  The context to look for this resource.
 * @param uri_path  The unique string uri of the resource.
 *
 * @return         A pointer to the resource or @c NULL if not found.
 */

Variable coap_subscription_t

coap_subscription_t *coap_add_observer(coap_resource_t *resource,
                                      coap_session_t *session,
                                      const coap_binary_t *token,
                                      coap_string_t *query,
                                      int has_block2,
                                      coap_block_t block2);
/**
 * Adds the specified peer as observer for @p resource. The subscription is
 * identified by the given @p token. This function returns the registered
 * subscription information if the @p observer has been added, or @c NULL on
 * error.
 *
 * @param resource        The observed resource.
 * @param session         The observer's session
 * @param token           The token that identifies this subscription.
 * @param query           The query string, if any. subscription will
                          take ownership of the string.
 * @param has_block2      If Option Block2 defined.
 * @param block2          Contents of Block2 if Block 2 defined.
 * @return                A pointer to the added/updated subscription
 *                        information or @c NULL on error.
 */

Variable coap_subscription_t

coap_subscription_t *coap_find_observer(coap_resource_t *resource,
                                       coap_session_t *session,
                                       const coap_binary_t *token);
/**
 * Returns a subscription object for given @p peer.
 *
 * @param resource The observed resource.
 * @param session  The observer's session
 * @param token    The token that identifies this subscription or @c NULL for
 *                 any token.
 * @return         A valid subscription if exists or @c NULL otherwise.
 */

Variable COAP_DEPRECATED

COAP_DEPRECATED int
coap_resource_set_dirty(coap_resource_t *r,
                       const coap_string_t *query);
/**
 * @deprecated use coap_resource_notify_observers() instead.
 */

Consts

Types

Typedefs

Typedef coap_method_handler_t

typedef void (*coap_method_handler_t)
 (coap_context_t *,
  struct coap_resource_t *,
  coap_session_t *,
  coap_pdu_t *,
  coap_binary_t * /* token */,
  coap_string_t * /* query string */,
  coap_pdu_t * /* response */);
/**
 * Definition of message handler function (@sa coap_resource_t).
 */

Typedef coap_attr_t;

typedef struct coap_attr_t {
 struct coap_attr_t *next;
 coap_str_const_t *name;
 coap_str_const_t *value;
 int flags;
} coap_attr_t;


      

Typedef coap_resource_t;

typedef struct coap_resource_t {
 unsigned int dirty:1;         /**< set to 1 if resource has changed */
 unsigned int partiallydirty:1; /**< set to 1 if some subscribers have not yet
                                  *   been notified of the last change */
 unsigned int observable:1;    /**< can be observed */
 unsigned int cacheable:1;     /**< can be cached */
 unsigned int is_unknown:1;    /**< resource created for unknown handler */

 /**
   * Used to store handlers for the seven coap methods @c GET, @c POST, @c PUT,
   * @c DELETE, @c FETCH, @c PATCH and @c IPATCH.
   * coap_dispatch() will pass incoming requests to the handler
   * that corresponds to its request method or generate a 4.05 response if no
   * handler is available.
   */
 coap_method_handler_t handler[7];

 UT_hash_handle hh;

 coap_attr_t *link_attr; /**< attributes to be included with the link format */
 coap_subscription_t *subscribers; /**< list of observers for this resource */

 /**
   * Request URI Path for this resource. This field will point into static
   * or allocated memory which must remain there for the duration of the
   * resource.
   */
 coap_str_const_t *uri_path; /**< the key used for hash lookup for this resource */
 int flags;

 /**
  * The next value for the Observe option. This field must be increased each
  * time the resource changes. Only the lower 24 bits are sent.
  */
 unsigned int observe;

 /**
   * This pointer is under user control. It can be used to store context for
   * the coap handler.
   */
 void *user_data;

} coap_resource_t;


      

Typedef coap_print_status_t

typedef unsigned int coap_print_status_t;
/**
 * Status word to encode the result of conditional print or copy operations such
 * as coap_print_link(). The lower 28 bits of coap_print_status_t are used to
 * encode the number of characters that has actually been printed, bits 28 to 31
 * encode the status.  When COAP_PRINT_STATUS_ERROR is set, an error occurred
 * during output. In this case, the other bits are undefined.
 * COAP_PRINT_STATUS_TRUNC indicates that the output is truncated, i.e. the
 * printing would have exceeded the current buffer.
 */