1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

examples/nanocoap_server: add endpoint with separate response

This commit is contained in:
Benjamin Valentin 2024-01-16 16:51:35 +01:00
parent dd458cb993
commit 63d5a5aafa
2 changed files with 15 additions and 7 deletions

View File

@ -47,6 +47,13 @@ endif
HIGH_MEMORY_BOARDS := native same54-xpro mcb2388 HIGH_MEMORY_BOARDS := native same54-xpro mcb2388
ifneq (,$(filter $(BOARD),$(HIGH_MEMORY_BOARDS))) ifneq (,$(filter $(BOARD),$(HIGH_MEMORY_BOARDS)))
# enable separate response
USEMODULE += nanocoap_server_separate
USEMODULE += event_callback
USEMODULE += event_thread
USEMODULE += event_timeout_ztimer
# enable fileserver
USEMODULE += nanocoap_fileserver USEMODULE += nanocoap_fileserver
USEMODULE += vfs_default USEMODULE += vfs_default

View File

@ -10,8 +10,12 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include "event/callback.h"
#include "event/timeout.h"
#include "event/thread.h"
#include "fmt.h" #include "fmt.h"
#include "net/nanocoap.h" #include "net/nanocoap.h"
#include "net/nanocoap_sock.h"
#include "hashes/sha256.h" #include "hashes/sha256.h"
#include "kernel_defines.h" #include "kernel_defines.h"
@ -185,16 +189,14 @@ NANOCOAP_RESOURCE(sha256) {
/* separate response requires an event thread to execute it */ /* separate response requires an event thread to execute it */
#ifdef MODULE_EVENT_THREAD #ifdef MODULE_EVENT_THREAD
static nanocoap_server_response_ctx_t _separate_ctx; static nanocoap_server_response_ctx_t _separate_ctx;
static bool _separate_in_progress;
static void _send_response(void *ctx) static void _send_response(void *ctx)
{ {
const char response[] = "This is a delayed response."; const char response[] = "This is a delayed response.";
puts("_separate_handler(): send delayed response"); puts("_separate_handler(): send delayed response");
nanocoap_sock_send_separate(ctx, COAP_CODE_CONTENT, COAP_TYPE_NON, nanocoap_server_send_separate(ctx, COAP_CODE_CONTENT, COAP_TYPE_NON,
response, sizeof(response)); response, sizeof(response));
_separate_in_progress = false;
} }
static ssize_t _separate_handler(coap_pkt_t *pkt, uint8_t *buf, size_t len, coap_request_ctx_t *context) static ssize_t _separate_handler(coap_pkt_t *pkt, uint8_t *buf, size_t len, coap_request_ctx_t *context)
@ -202,21 +204,20 @@ static ssize_t _separate_handler(coap_pkt_t *pkt, uint8_t *buf, size_t len, coap
static event_timeout_t event_timeout; static event_timeout_t event_timeout;
static event_callback_t event_timed = EVENT_CALLBACK_INIT(_send_response, &_separate_ctx); static event_callback_t event_timed = EVENT_CALLBACK_INIT(_send_response, &_separate_ctx);
if (_separate_in_progress) { if (event_timeout_is_pending(&event_timeout)) {
puts("_separate_handler(): response already scheduled"); puts("_separate_handler(): response already scheduled");
return coap_build_reply(pkt, COAP_CODE_SERVICE_UNAVAILABLE, buf, len, 0); return coap_build_reply(pkt, COAP_CODE_SERVICE_UNAVAILABLE, buf, len, 0);
} }
puts("_separate_handler(): send ACK, schedule response"); puts("_separate_handler(): send ACK, schedule response");
nanocoap_sock_prepare_separate(&_separate_ctx, pkt, context); nanocoap_server_prepare_separate(&_separate_ctx, pkt, context);
_separate_in_progress = true;
event_timeout_ztimer_init(&event_timeout, ZTIMER_MSEC, EVENT_PRIO_MEDIUM, event_timeout_ztimer_init(&event_timeout, ZTIMER_MSEC, EVENT_PRIO_MEDIUM,
&event_timed.super); &event_timed.super);
event_timeout_set(&event_timeout, 1 * MS_PER_SEC); event_timeout_set(&event_timeout, 1 * MS_PER_SEC);
return coap_build_empty_ack(pkt, buf, len); return coap_build_empty_ack(pkt, (void *)buf);
} }
NANOCOAP_RESOURCE(separate) { NANOCOAP_RESOURCE(separate) {