177 lines
6.1 KiB
C
177 lines
6.1 KiB
C
|
/*
|
||
|
* uri.h -- helper functions for URI treatment
|
||
|
*
|
||
|
* Copyright (C) 2010-2020 Olaf Bergmann <bergmann@tzi.org>
|
||
|
*
|
||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||
|
*
|
||
|
* This file is part of the CoAP library libcoap. Please see README for terms
|
||
|
* of use.
|
||
|
*/
|
||
|
|
||
|
#ifndef COAP_URI_H_
|
||
|
#define COAP_URI_H_
|
||
|
|
||
|
#include <stdint.h>
|
||
|
|
||
|
#include "str.h"
|
||
|
|
||
|
/**
|
||
|
* The scheme specifiers. Secure schemes have an odd numeric value,
|
||
|
* others are even.
|
||
|
*/
|
||
|
typedef enum coap_uri_scheme_t {
|
||
|
COAP_URI_SCHEME_COAP = 0,
|
||
|
COAP_URI_SCHEME_COAPS, /* 1 */
|
||
|
COAP_URI_SCHEME_COAP_TCP, /* 2 */
|
||
|
COAP_URI_SCHEME_COAPS_TCP, /* 3 */
|
||
|
COAP_URI_SCHEME_HTTP, /* 4 Proxy-Uri only */
|
||
|
COAP_URI_SCHEME_HTTPS /* 5 Proxy-Uri only */
|
||
|
} coap_uri_scheme_t;
|
||
|
|
||
|
/** This mask can be used to check if a parsed URI scheme is secure. */
|
||
|
#define COAP_URI_SCHEME_SECURE_MASK 0x01
|
||
|
|
||
|
/**
|
||
|
* Representation of parsed URI. Components may be filled from a string with
|
||
|
* coap_split_uri() or coap_split_proxy_uri() and can be used as input for
|
||
|
* option-creation functions.
|
||
|
*/
|
||
|
typedef struct {
|
||
|
coap_str_const_t host; /**< host part of the URI */
|
||
|
uint16_t port; /**< The port in host byte order */
|
||
|
coap_str_const_t path; /**< Beginning of the first path segment.
|
||
|
Use coap_split_path() to create Uri-Path options */
|
||
|
coap_str_const_t query; /**< The query part if present */
|
||
|
|
||
|
/** The parsed scheme specifier. */
|
||
|
enum coap_uri_scheme_t scheme;
|
||
|
} coap_uri_t;
|
||
|
|
||
|
static inline int
|
||
|
coap_uri_scheme_is_secure(const coap_uri_t *uri) {
|
||
|
return uri && ((uri->scheme & COAP_URI_SCHEME_SECURE_MASK) != 0);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Creates a new coap_uri_t object from the specified URI. Returns the new
|
||
|
* object or NULL on error. The memory allocated by the new coap_uri_t
|
||
|
* must be released using coap_free().
|
||
|
*
|
||
|
* @param uri The URI path to copy.
|
||
|
* @param length The length of uri.
|
||
|
*
|
||
|
* @return New URI object or NULL on error.
|
||
|
*/
|
||
|
coap_uri_t *coap_new_uri(const uint8_t *uri, unsigned int length);
|
||
|
|
||
|
/**
|
||
|
* Clones the specified coap_uri_t object. Thie function allocates sufficient
|
||
|
* memory to hold the coap_uri_t structure and its contents. The object must
|
||
|
* be released with coap_free(). */
|
||
|
coap_uri_t *coap_clone_uri(const coap_uri_t *uri);
|
||
|
|
||
|
/**
|
||
|
* @defgroup uri_parse URI Parsing Functions
|
||
|
*
|
||
|
* CoAP PDUs contain normalized URIs with their path and query split into
|
||
|
* multiple segments. The functions in this module help splitting strings.
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Parses a given string into URI components. The identified syntactic
|
||
|
* components are stored in the result parameter @p uri. Optional URI
|
||
|
* components that are not specified will be set to { 0, 0 }, except for the
|
||
|
* port which is set to the default port for the protocol. This function
|
||
|
* returns @p 0 if parsing succeeded, a value less than zero otherwise.
|
||
|
*
|
||
|
* @param str_var The string to split up.
|
||
|
* @param len The actual length of @p str_var
|
||
|
* @param uri The coap_uri_t object to store the result.
|
||
|
*
|
||
|
* @return @c 0 on success, or < 0 on error.
|
||
|
*
|
||
|
*/
|
||
|
int coap_split_uri(const uint8_t *str_var, size_t len, coap_uri_t *uri);
|
||
|
|
||
|
/**
|
||
|
* Parses a given string into URI components. The identified syntactic
|
||
|
* components are stored in the result parameter @p uri. Optional URI
|
||
|
* components that are not specified will be set to { 0, 0 }, except for the
|
||
|
* port which is set to default port for the protocol. This function returns
|
||
|
* @p 0 if parsing succeeded, a value less than zero otherwise.
|
||
|
* Note: This function enforces that the given string is in Proxy-Uri format
|
||
|
* as well as supports different schema such as http.
|
||
|
*
|
||
|
* @param str_var The string to split up.
|
||
|
* @param len The actual length of @p str_var
|
||
|
* @param uri The coap_uri_t object to store the result.
|
||
|
*
|
||
|
* @return @c 0 on success, or < 0 on error.
|
||
|
*
|
||
|
*/
|
||
|
int coap_split_proxy_uri(const uint8_t *str_var, size_t len, coap_uri_t *uri);
|
||
|
|
||
|
/**
|
||
|
* Splits the given URI path into segments. Each segment is preceded
|
||
|
* by an option pseudo-header with delta-value 0 and the actual length
|
||
|
* of the respective segment after percent-decoding.
|
||
|
*
|
||
|
* @param s The path string to split.
|
||
|
* @param length The actual length of @p s.
|
||
|
* @param buf Result buffer for parsed segments.
|
||
|
* @param buflen Maximum length of @p buf. Will be set to the actual number
|
||
|
* of bytes written into buf on success.
|
||
|
*
|
||
|
* @return The number of segments created or @c -1 on error.
|
||
|
*/
|
||
|
int coap_split_path(const uint8_t *s,
|
||
|
size_t length,
|
||
|
unsigned char *buf,
|
||
|
size_t *buflen);
|
||
|
|
||
|
/**
|
||
|
* Splits the given URI query into segments. Each segment is preceded
|
||
|
* by an option pseudo-header with delta-value 0 and the actual length
|
||
|
* of the respective query term.
|
||
|
*
|
||
|
* @param s The query string to split.
|
||
|
* @param length The actual length of @p s.
|
||
|
* @param buf Result buffer for parsed segments.
|
||
|
* @param buflen Maximum length of @p buf. Will be set to the actual number
|
||
|
* of bytes written into buf on success.
|
||
|
*
|
||
|
* @return The number of segments created or @c -1 on error.
|
||
|
*
|
||
|
* @bug This function does not reserve additional space for delta > 12.
|
||
|
*/
|
||
|
int coap_split_query(const uint8_t *s,
|
||
|
size_t length,
|
||
|
unsigned char *buf,
|
||
|
size_t *buflen);
|
||
|
|
||
|
/**
|
||
|
* Extract query string from request PDU according to escape rules in 6.5.8.
|
||
|
* @param request Request PDU.
|
||
|
* @return Reconstructed and escaped query string part or @c NULL if
|
||
|
* no query was contained in @p request. The coap_string_t
|
||
|
* object returned by this function must be released with
|
||
|
* coap_delete_string.
|
||
|
*/
|
||
|
coap_string_t *coap_get_query(const coap_pdu_t *request);
|
||
|
|
||
|
/**
|
||
|
* Extract uri_path string from request PDU
|
||
|
* @param request Request PDU.
|
||
|
* @return Reconstructed and escaped uri path string part or @c NULL
|
||
|
* if no URI-Path was contained in @p request. The
|
||
|
* coap_string_t object returned by this function must be
|
||
|
* released with coap_delete_string.
|
||
|
*/
|
||
|
coap_string_t *coap_get_uri_path(const coap_pdu_t *request);
|
||
|
|
||
|
/** @} */
|
||
|
|
||
|
#endif /* COAP_URI_H_ */
|