libcoap  4.0.3
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
Macros | Functions
resource.c File Reference
#include "config.h"
#include "net.h"
#include "debug.h"
#include "resource.h"
#include "subscribe.h"
#include "utlist.h"
#include "mem.h"

Go to the source code of this file.

Macros

#define COAP_MALLOC_TYPE(Type)   ((coap_##Type##_t *)coap_malloc(sizeof(coap_##Type##_t)))
#define COAP_FREE_TYPE(Type, Object)   coap_free(Object)
#define min(a, b)   ((a) < (b) ? (a) : (b))
#define MATCH_URI   0x01
#define MATCH_PREFIX   0x02
#define MATCH_SUBSTRING   0x04
#define INET6_ADDRSTRLEN   40

Functions

int match (const str *text, const str *pattern, int match_prefix, int match_substring)
int print_wellknown (coap_context_t *context, unsigned char *buf, size_t *buflen, coap_opt_t *query_filter)
 Prints the names of all known resources to buf.
coap_resource_tcoap_resource_init (const unsigned char *uri, size_t len, int flags)
 Creates a new resource object and initializes the link field to the string of length len.
coap_attr_tcoap_add_attr (coap_resource_t *resource, const unsigned char *name, size_t nlen, const unsigned char *val, size_t vlen, int flags)
 Registers a new attribute with the given resource.
coap_attr_tcoap_find_attr (coap_resource_t *resource, const unsigned char *name, size_t nlen)
 Returns resource's coap_attr_t object with given name if found, NULL otherwise.
void coap_delete_attr (coap_attr_t *attr)
 Deletes an attribute.
void coap_hash_request_uri (const coap_pdu_t *request, coap_key_t key)
 Calculates the hash key for the resource requested by the Uri-Options of request.
void coap_add_resource (coap_context_t *context, coap_resource_t *resource)
 Registers the given resource for context.
int coap_delete_resource (coap_context_t *context, coap_key_t key)
 Deletes a resource identified by key.
coap_resource_tcoap_get_resource_from_key (coap_context_t *context, coap_key_t key)
 Returns the resource identified by the unique string key.
int coap_print_link (const coap_resource_t *resource, unsigned char *buf, size_t *len)
 Writes a description of this resource in link-format to given text buffer.
coap_subscription_tcoap_find_observer (coap_resource_t *resource, const coap_address_t *peer, const str *token)
 Returns a subscription object for given peer.
coap_subscription_tcoap_add_observer (coap_resource_t *resource, const coap_address_t *observer, const str *token)
 Adds the specified peer as observer for resource.
void coap_touch_observer (coap_context_t *context, const coap_address_t *observer, const str *token)
 Marks an observer as alive.
void coap_delete_observer (coap_resource_t *resource, const coap_address_t *observer, const str *token)
 Removes any subscription for observer from resource and releases the allocated storage.
static void coap_notify_observers (coap_context_t *context, coap_resource_t *r)
void coap_check_notify (coap_context_t *context)
 Checks for all known resources, if they are dirty and notifies subscribed observers.
static void coap_remove_failed_observers (coap_context_t *context, coap_resource_t *resource, const coap_address_t *peer, const str *token)
 Checks the failure counter for (peer, token) and removes peer from the list of observers for the given resource when COAP_OBS_MAX_FAIL is reached.
void coap_handle_failed_notify (coap_context_t *context, const coap_address_t *peer, const str *token)

Macro Definition Documentation

#define COAP_FREE_TYPE (   Type,
  Object 
)    coap_free(Object)

Definition at line 21 of file resource.c.

#define COAP_MALLOC_TYPE (   Type)    ((coap_##Type##_t *)coap_malloc(sizeof(coap_##Type##_t)))

Definition at line 19 of file resource.c.

#define INET6_ADDRSTRLEN   40
#define MATCH_PREFIX   0x02
#define MATCH_SUBSTRING   0x04
#define MATCH_URI   0x01
#define min (   a,
 
)    ((a) < (b) ? (a) : (b))

Definition at line 48 of file resource.c.

Function Documentation

coap_attr_t* coap_add_attr ( coap_resource_t resource,
const unsigned char *  name,
size_t  nlen,
const unsigned char *  val,
size_t  vlen,
int  flags 
)

Registers a new attribute with the given resource.

As the attributes str fields will point to name and val the caller must ensure that these pointers are valid during the attribute's lifetime.

Parameters
resourceThe resource to register the attribute with.
nameThe attribute's name.
nlenLength of name.
valThe attribute's value or NULL if none.
vlenLength of val if specified.
flagsFlags for memory management (in particular release of memory)
Returns
A pointer to the new attribute or NULL on error.

Definition at line 257 of file resource.c.

coap_subscription_t* coap_add_observer ( coap_resource_t resource,
const coap_address_t observer,
const str token 
)

Adds the specified peer as observer for resource.

The subscription is identified by the given token. This function returns the registered subscription information if the observer has been added, or NULL on error.

Parameters
resourceThe observed resource.
observerThe remote peer that wants to received status updates.
tokenThe token that identifies this subscription.
token_lengthThe actual length of token. Must be 0 when token is NULL.
Returns
A pointer to the added/updated subscription information or NULL on error.

Definition at line 486 of file resource.c.

void coap_add_resource ( coap_context_t context,
coap_resource_t resource 
)

Registers the given resource for context.

The resource must have been created by coap_resource_init(), the storage allocated for the resource will be released by coap_delete_resource().

Parameters
contextThe context to use.
resourceThe resource to store.

Definition at line 344 of file resource.c.

void coap_check_notify ( coap_context_t context)

Checks for all known resources, if they are dirty and notifies subscribed observers.

Definition at line 620 of file resource.c.

void coap_delete_attr ( coap_attr_t attr)

Deletes an attribute.

Parameters
attrPointer to a previously created attribute

Definition at line 317 of file resource.c.

void coap_delete_observer ( coap_resource_t resource,
const coap_address_t observer,
const str token 
)

Removes any subscription for observer from resource and releases the allocated storage.

Parameters
resourceThe observed resource.
observerThe observer's address.
tokenThe token that identifies this subscription or NULL for any token.

Definition at line 548 of file resource.c.

int coap_delete_resource ( coap_context_t context,
coap_key_t  key 
)

Deletes a resource identified by key.

The storage allocated for that resource is freed.

Parameters
contextThe context where the resources are stored.
keyThe unique key for the resource to delete.
Returns
1 if the resource was found (and destroyed), 0 otherwise.

Definition at line 351 of file resource.c.

coap_attr_t* coap_find_attr ( coap_resource_t resource,
const unsigned char *  name,
size_t  nlen 
)

Returns resource's coap_attr_t object with given name if found, NULL otherwise.

Parameters
resourceThe resource to search for attribute name.
nameName of the requested attribute.
nlenActual length of name.
Returns
The first attribute with specified name or NULL if none was found.

Definition at line 295 of file resource.c.

coap_subscription_t* coap_find_observer ( coap_resource_t resource,
const coap_address_t peer,
const str token 
)

Returns a subscription object for given peer.

Parameters
resourceThe observed resource.
peerThe address to search for.
tokenThe token that identifies this subscription or NULL for any token.
Returns
A valid subscription if exists or NULL otherwise.

Definition at line 468 of file resource.c.

coap_resource_t* coap_get_resource_from_key ( coap_context_t context,
coap_key_t  key 
)

Returns the resource identified by the unique string key.

If no resource was found, this function returns NULL.

Parameters
contextThe context to look for this resource.
keyThe unique key of the resource.
Returns
A pointer to the resource or NULL if not found.

Definition at line 394 of file resource.c.

void coap_handle_failed_notify ( coap_context_t context,
const coap_address_t peer,
const str token 
)

Definition at line 693 of file resource.c.

void coap_hash_request_uri ( const coap_pdu_t request,
coap_key_t  key 
)

Calculates the hash key for the resource requested by the Uri-Options of request.

This function calls coap_hash() for every path segment.

Parameters
requestThe requesting pdu.
keyThe resulting hash is stored in key

Definition at line 328 of file resource.c.

static void coap_notify_observers ( coap_context_t context,
coap_resource_t r 
)
static

Definition at line 562 of file resource.c.

int coap_print_link ( const coap_resource_t resource,
unsigned char *  buf,
size_t *  len 
)

Writes a description of this resource in link-format to given text buffer.

len must be initialized to the maximum length of buf and will be set to the number of characters actually written if successful. This function returns 1 on success or 0 on error.

Parameters
resourceThe resource to describe.
bufThe output buffer to write the description to.
lenMust be initialized to the length of buf and will be set to the number of characters written on success.
Returns
1 on success, or 0 on error. If 0, len is undefined.

Definition at line 418 of file resource.c.

static void coap_remove_failed_observers ( coap_context_t context,
coap_resource_t resource,
const coap_address_t peer,
const str token 
)
static

Checks the failure counter for (peer, token) and removes peer from the list of observers for the given resource when COAP_OBS_MAX_FAIL is reached.

Parameters
contextThe CoAP context to use
resourceThe resource to check for (peer, token)
peerThe observer's address
tokenThe token that has been used for subscription.

Definition at line 651 of file resource.c.

coap_resource_t* coap_resource_init ( const unsigned char *  uri,
size_t  len,
int  flags 
)

Creates a new resource object and initializes the link field to the string of length len.

This function returns the new coap_resource_t object.

Parameters
uriThe URI path of the new resource.
lenThe length of uri.
flagsFlags for memory management (in particular release of memory)
Returns
A pointer to the new object or NULL on error.

Definition at line 226 of file resource.c.

void coap_touch_observer ( coap_context_t context,
const coap_address_t observer,
const str token 
)

Marks an observer as alive.

Parameters
contextThe CoAP context to use
observerThe transport address of the observer
tokenThe corresponding token that has been used for the subscription

Definition at line 522 of file resource.c.

int match ( const str text,
const str pattern,
int  match_prefix,
int  match_substring 
)

Definition at line 51 of file resource.c.

int print_wellknown ( coap_context_t context,
unsigned char *  buf,
size_t *  buflen,
coap_opt_t query_filter 
)

Prints the names of all known resources to buf.

This function sets buflen to the number of bytes actually written and returns 1 on succes. On error, the value in buflen is undefined and the return value will be 0.

Parameters
contextThe context with the resource map.
bufThe buffer to write the result.
buflenMust be initialized to the maximum length of buf and will be set to the number of bytes written on return.
query_filterA filter query according to Link Format
Returns
0 on error or 1 on success.

Definition at line 105 of file resource.c.