1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #12231 from kb2ma/coap/refine_api_purpose

net/nanocoap: rebalance application vs. option API doc
This commit is contained in:
Ken Bannister 2019-10-15 18:25:50 -04:00 committed by GitHub
commit fe8bb49e39
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 26 additions and 20 deletions

View File

@ -22,7 +22,8 @@
* gcoap allocates a RIOT message processing thread, so a single instance can * gcoap allocates a RIOT message processing thread, so a single instance can
* serve multiple applications. This approach also means gcoap uses a single UDP * serve multiple applications. This approach also means gcoap uses a single UDP
* port, which supports RFC 6282 compression. Internally, gcoap depends on the * port, which supports RFC 6282 compression. Internally, gcoap depends on the
* nanocoap package for base level structs and functionality. * nanocoap package for base level structs and functionality. gcoap uses
* nanocoap's Packet API to write message options.
* *
* gcoap supports the Observe extension (RFC 7641) for a server. gcoap provides * gcoap supports the Observe extension (RFC 7641) for a server. gcoap provides
* functions to generate and send an observe notification that are similar to * functions to generate and send an observe notification that are similar to

View File

@ -19,32 +19,27 @@
* provides high and low level interfaces to CoAP options, including Block. * provides high and low level interfaces to CoAP options, including Block.
* *
* nanocoap includes the core structs to store message information. It also * nanocoap includes the core structs to store message information. It also
* also provides support for sending and receiving messages, such as * provides helper functions for use before sending and after receiving a
* coap_parse() to read an incoming message. * message, such as coap_parse() to read an incoming message.
* *
* The documentation here mostly categorizes and lists the contents of * ## Application APIs
* nanocoap. To use nanocoap in an application, see the APIs that are built
* with it: [nanocoap sock](group__net__nanosock.html) and
* [gcoap](group__net__gcoap.html).
* *
* ## Option APIs * This page provides reference documentation for the contents of nanocoap. To
* use nanocoap in an application, see the functional APIs that are built with
* it. [nanocoap sock](group__net__nanosock.html) is for a targeted client or
* server with lesser resource requirements, and [gcoap](group__net__gcoap.html)
* provides a more featureful messaging hub.
*
* ### Option APIs
* *
* For both server responses and client requests, CoAP uses an Option mechanism * For both server responses and client requests, CoAP uses an Option mechanism
* to encode message metadata that is not required for each message. For * to encode message metadata that is not required for each message. For
* example, the resource URI path is required only for a request, and is encoded * example, the resource URI path is required only for a request, and is encoded
* as the Uri-Path option. * as the Uri-Path option.
* *
* nanocoap provides two APIs for writing CoAP options: * nanocoap sock uses the simpler Buffer API, described in the section
* * _Options Write Buffer API_. gcoap uses the more convenient Packet API,
* - **Buffer API** requires only a reference to the buffer for the message. * described in the section _Options Write Packet API_.
* However, the caller must provide the last option number written as well as
* the buffer position. The caller is primarily responsible for tracking and
* managing the space remaining in the buffer.
*
* - **Packet API** uses a coap_pkt_t struct to conveniently track each
* option as it is written and prepare for any payload. The caller must monitor
* space remaining in the buffer; however, the API *will not* write past the
* end of the buffer, and returns -ENOSPC when it is full.
* *
* For either API, the caller *must* write options in order by option number * For either API, the caller *must* write options in order by option number
* (see "CoAP option numbers" in [CoAP defines](group__net__coap.html)). * (see "CoAP option numbers" in [CoAP defines](group__net__coap.html)).
@ -805,7 +800,12 @@ static inline unsigned coap_szx2size(unsigned szx)
* @name Functions -- Options Write Packet API * @name Functions -- Options Write Packet API
* *
* Use a coap_pkt_t struct to manage writing Options to the PDU. * Use a coap_pkt_t struct to manage writing Options to the PDU.
*
* The caller must monitor space remaining in the buffer; however, the API
* *will not* write past the end of the buffer, and returns -ENOSPC when it is
* full.
*/ */
/**@{*/
/** /**
* @brief Add block option in descriptive use from a slicer object * @brief Add block option in descriptive use from a slicer object
* *
@ -1002,6 +1002,10 @@ ssize_t coap_opt_finish(coap_pkt_t *pkt, uint16_t flags);
* @name Functions -- Options Write Buffer API * @name Functions -- Options Write Buffer API
* *
* Write PDU Options directly to the array of bytes for a message. * Write PDU Options directly to the array of bytes for a message.
*
* The caller must provide the last option number written as well as the buffer
* position. The caller is primarily responsible for tracking and managing the
* space remaining in the buffer.
*/ */
/**@{*/ /**@{*/
/** /**

View File

@ -17,7 +17,8 @@
* interface to RIOT's sock networking API to read and write CoAP messages. * interface to RIOT's sock networking API to read and write CoAP messages.
* For a server, nanocoap sock accepts a list of resource paths with callbacks * For a server, nanocoap sock accepts a list of resource paths with callbacks
* for writing the response. For a client, nanocoap sock provides a function * for writing the response. For a client, nanocoap sock provides a function
* to send a request and waits for the server response. * to send a request and waits for the server response. nanocoap sock uses
* nanocoap's Buffer API to write message options.
* *
* ## Server Operation ## * ## Server Operation ##
* *