libmicrohttpd

HTTP/1.x server C library (MHD 1.x, stable)
Log | Files | Refs | Submodules | README | LICENSE

commit 228ddbd181aa6562331f3841649637d73e9d3855
parent 20001736f8970e3fdf0e8dc6018bfe2cfdeec950
Author: Evgeny Grin (Karlson2k) <k2k@narod.ru>
Date:   Tue,  9 Aug 2022 19:59:20 +0300

digestauth: limit nonce-count to uint32_t

Diffstat:
Msrc/microhttpd/digestauth.c | 6+++---
Msrc/microhttpd/internal.h | 2+-
2 files changed, 4 insertions(+), 4 deletions(-)

diff --git a/src/microhttpd/digestauth.c b/src/microhttpd/digestauth.c @@ -590,7 +590,7 @@ check_nonce_nc (struct MHD_Connection *connection, mod = daemon->nonce_nc_size; if (0 == mod) return MHD_CHECK_NONCENC_STALE; /* no array! */ - if (nc >= UINT64_MAX - 64) + if (nc >= UINT32_MAX - 64) return MHD_CHECK_NONCENC_STALE; /* Overflow, unrealistically high value */ nn = &daemon->nnc[get_nonce_nc_idx (mod, nonce, noncelen)]; @@ -649,7 +649,7 @@ check_nonce_nc (struct MHD_Connection *connection, else if (nc > nn->nc) { /* 'nc' is larger, shift bitmask and bump limit */ - const uint64_t jump_size = nc - nn->nc; + const uint32_t jump_size = (uint32_t) nc - nn->nc; if (64 > jump_size) { /* small jump, less than mask width */ @@ -661,7 +661,7 @@ check_nonce_nc (struct MHD_Connection *connection, nn->nmask = (UINT64_C (1) << 63); else nn->nmask = 0; /* big jump, unset all bits in the mask */ - nn->nc = nc; + nn->nc = (uint32_t) nc; ret = MHD_CHECK_NONCENC_OK; } else if (nc < nn->nc) diff --git a/src/microhttpd/internal.h b/src/microhttpd/internal.h @@ -268,7 +268,7 @@ struct MHD_NonceNc * 'nc' value. * This 'nc' value was already used by the client. */ - uint64_t nc; + uint32_t nc; /** * Bitmask over the previous 64 nonce counter values (down to to nc-64).