-
Notifications
You must be signed in to change notification settings - Fork 2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
sys/net/*coap: Make APIs (more) transport agnostic #20900
base: master
Are you sure you want to change the base?
sys/net/*coap: Make APIs (more) transport agnostic #20900
Conversation
This PR is not ready for review yet, I just want to make the work more transparent. |
99877b3
to
d832957
Compare
c13f6d0
to
34b0d34
Compare
Could the Then users who just upgrade their applications would see a deprecation rather than breakage, and would just need to follow that deprecation's pointers ("use the setters and getters") before either they go to the next release or they enable any of the new modules. The Rust wrappers (affected in RIOT-OS/rust-riot-wrappers#129) could then do the same: use the old ways unless a new module is enabled, and after the next release they can go all-in with the new accessor, and thus always work with the current release and with the mai^Wmaster branch. |
To clarify: If it's only the Rust wrappers affected, workarounds are possible (but necessary) to make things work there by detecting whether any code getter/setter is present. But if making it easier for riot-wrappers also eases other users' transitions, maybe we should do that. I can work with either outcome. |
I think adding an unnamed |
Yes, an unnamed union CI should probably not interfere here because that'd also impede the Rust side -- but after the next release, the old item can go away anyway, and then we're enforcing the deprecation. Until then I think we'll have to rely on people following the deprecation. |
6cc1b64
to
061ca01
Compare
73c2c8e
to
c51264d
Compare
c51264d
to
7a3f62e
Compare
7a3f62e
to
d68e00e
Compare
d68e00e
to
a73f365
Compare
Another rebase to resolve merge conflicts. |
We had a discussion out of band and concluded that there is a risk that !20900 changes APIs that end up being deprecated when UniCoAP lands. We agreed to put PR on hold for now, so that we don’t end up forcing users to jump through two API deprecation hoops when this could be done with just one. |
3e6c331
to
d82eecf
Compare
df0bc7b
to
e4c6f33
Compare
e4c6f33
to
7eebbf3
Compare
This allows sending a separate response with CoAP Options and adds a helper to detect duplicate requests, so that resource handlers can repeat their empty ACK on duplicates.
This adds the new `nanocoap_server_observe` module that implements the server side of the CoAP Observe option. It does require cooperation from the resource handler to work, though.
This changes the API of nanocoap with the goal to reduce the expose of UDP specifics in the API. The plan is to eventually support transports such as CoAP over TCP and CoAP over WebSocket directly in nanocoap while sharing most of the code, as e.g. the CoAP Option processing remains identical. Specifically, the plan is to unlock a transport with modules and introduce overhead for dispatching to specific transport only when multiple transports are actually in use. Support for OSCORE directly in nanocoap is probably not sensible, as the serialization is very much unlike the other transports. A unified CoAP API for multiple transports including OSCORE is probably best implemented on top. But when limited to the boring set of CoAP transports, we probably can support them well with nanocoap with less overhead. Breaking API Changes: ===================== - `coap_parse()` now returns `ssize_t` instead of `int` - This function is not really user facing, so the impact should be limited - This is useful for stream transports where the buffer may contain data of more than one packet. The return value contains the number of bytes actually consumed, which will match the buffer size for non-stream transports. API Changes: ============ - `coap_pkt_t` now contains a `uint8_t *buf` pointer instead of a `coap_hdr_t *hdr` pointer to the beginning of the buffer - This will also work when the buffer is used by non-UDP transports - A deprecated `coap_udp_hdr_t *hdr` has been crammed into an unnamed `union` with `uint8_t *buf`. For architectures where pointers have the same memory layout regardless of type (e.g. all of the supported ones), this will make `hdr` an alias for `buf`. - The alias will only be provided if no transport besides UDP is used in nanocoap. So existing apps will continue to work, new apps that want to support other transports need to move to adapt. - `coap_hdr_t` has been renamed to `coap_udp_hdr_t` - A deprecated alias was created for deprecation - `coap_hdr*()` functions have been deprecated - Equivalent `coap_pkt*()` functions have been created that work on `coap_pkt_t *` instead of `coap_hdr_t *` - If non-UDP transports are used, the deprecated `coap_hdr*()` will probably not be exposed to avoid footguns. - `coap_build_hdr()` has been renamed to `coap_build_udp_hdr()` and that works on an `uint8_t *` buffer with a given length, rather than on a `coap_hdr_t *` with a *figers crossed* length - a deprecated `coap_build_hdr()` function was added that calls to `coap_build_udp_hdr()` and has the same signature, so that users have time to update
7eebbf3
to
e1f7edb
Compare
Contribution description
This changes the API of nanocoap with the goal to reduce the expose of UDP specifics in the API. The plan is to eventually support transports such as CoAP over TCP and CoAP over WebSocket directly in nanocoap while sharing most of the code, as e.g. the CoAP Option processing remains identical. Specifically, the plan is to unlock a transport with modules and introduce overhead for dispatching to specific transport only when multiple transports are actually in use.
Support for OSCORE directly in nanocoap is probably not sensible, as the serialization is very much unlike the other transports. A unified CoAP API for multiple transports including OSCORE is probably best implemented on top. But when limited to the boring set of CoAP transports, we probably can support them well with nanocoap with less overhead.
API Changes:
Breaking API Changes:
coap_parse()
now returnsssize_t
instead ofint
API Changes:
coap_pkt_t
now contains auint8_t *buf
pointer instead of acoap_hdr_t *hdr
pointer to the beginning of the buffercoap_udp_hdr_t *hdr
has been crammed into an unnamedunion
withuint8_t *buf
. For architectures where pointers have the same memory layout regardless of type (e.g. all of the supported ones), this will makehdr
an alias forbuf
.coap_hdr_t
has been renamed tocoap_udp_hdr_t
coap_hdr*()
functions have been deprecatedcoap_pkt*()
functions have been created that work oncoap_pkt_t *
instead ofcoap_hdr_t *
coap_hdr*()
will probably not be exposed to avoid footguns.coap_build_hdr()
has been renamed tocoap_build_udp_hdr()
and that works on anuint8_t *
buffer with a given length, rather than on acoap_hdr_t *
with a figers crossed lengthcoap_build_hdr()
function was added that calls tocoap_build_udp_hdr()
and has the same signature, so that users have time to updateInternal users have been updated, except for tests.
The deprecated functions will probably exposed only when nanocoap is used with only UDP as transport, as those will wreak havoc on non-UDP CoAP packets. That should be fine, as existing apps hardly will make use of other transports anyway.
Testing procedure
Existing apps and tests should work as before. I will do some limited testing soon and do more rigorous testing once an implementation of nanocoap using TCP as transport is ready. Otherwise there are likely still UDP specifics in the API that I have overlooked.
Issues/PRs references
See also #20792