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

sys/net/gcoap/forward_proxy: clean up code

Introduce an _cep_set_req_etag() helper function and drop the
_cep_set_req_etag_len() helper to avoid use of preprocessor
conditionals in the code.
This commit is contained in:
Marian Buschsieweke 2024-04-15 18:26:20 +02:00
parent 3cdc4379b7
commit bb79f3e550
No known key found for this signature in database
GPG Key ID: 77AA882EC78084E6

View File

@ -61,7 +61,15 @@ static void _cep_set_in_use(client_ep_t *cep);
static uint8_t _cep_get_response_type(client_ep_t *cep);
static void _cep_set_response_type(client_ep_t *cep, uint8_t resp_type);
static uint8_t _cep_get_req_etag_len(client_ep_t *cep);
static void _cep_set_req_etag_len(client_ep_t *cep, uint8_t req_etag_len);
/**
* @brief Store the given ETag in the given client endpoint
* @param[out] cep client endpoint to store the ETag in
* @param[in] etag ETag to store
* @param[in] etag_len length of @p etag in bytes
*/
static void _cep_set_req_etag(client_ep_t *cep, const void *etag,
uint8_t etag_len);
const coap_resource_t forward_proxy_resources[] = {
{ "/", COAP_IGNORE, _forward_proxy_handler, NULL },
@ -89,7 +97,7 @@ static client_ep_t *_allocate_client_ep(const sock_udp_ep_t *ep)
cep++) {
if (!_cep_in_use(cep)) {
_cep_set_in_use(cep);
_cep_set_req_etag_len(cep, 0);
_cep_set_req_etag(cep, NULL, 0);
memcpy(&cep->ep, ep, sizeof(*ep));
return cep;
}
@ -346,11 +354,7 @@ static int _gcoap_forward_proxy_copy_options(coap_pkt_t *pkt,
if (IS_USED(MODULE_NANOCOAP_CACHE) && opt.opt_num == COAP_OPT_ETAG) {
if (_cep_get_req_etag_len(cep) == 0) {
/* TODO: what to do on multiple ETags? */
_cep_set_req_etag_len(cep, (uint8_t)optlen);
#if IS_USED(MODULE_NANOCOAP_CACHE)
/* req_tag in cep is pre-processor guarded so we need to as well */
memcpy(cep->req_etag, value, optlen);
#endif
_cep_set_req_etag(cep, value, optlen);
}
/* skip original ETag of request, otherwise we might accidentally fill the cache
* with 2.03 Valid responses which would require additional handling.
@ -525,13 +529,20 @@ static uint8_t _cep_get_req_etag_len(client_ep_t *cep)
return 0;
}
static void _cep_set_req_etag_len(client_ep_t *cep, uint8_t req_etag_len)
static void _cep_set_req_etag(client_ep_t *cep, const void *etag,
uint8_t etag_len)
{
if (IS_USED(MODULE_NANOCOAP_CACHE)) {
(void)cep;
(void)etag;
(void)etag_len;
#if MODULE_NANOCOAP_CACHE
if (etag_len <= COAP_ETAG_LENGTH_MAX) {
cep->flags &= ~CLIENT_EP_FLAGS_ETAG_LEN_MASK;
cep->flags |= (req_etag_len << CLIENT_EP_FLAGS_ETAG_LEN_POS)
& CLIENT_EP_FLAGS_ETAG_LEN_MASK;
cep->flags |= (etag_len << CLIENT_EP_FLAGS_ETAG_LEN_POS)
& CLIENT_EP_FLAGS_ETAG_LEN_MASK;
memcpy(cep->req_etag, etag, etag_len);
}
#endif
}
/** @} */