summaryrefslogtreecommitdiff
path: root/src/libtipidee
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2023-10-27 14:33:26 +0000
committerLaurent Bercot <ska@appnovation.com>2023-10-27 14:33:26 +0000
commitffd8df879dea5b306b1a1615c2eabe0d463a3a3b (patch)
tree278ef36a856c2ddc756a1474d69906be7dfbf316 /src/libtipidee
parentd05b3963381a4cd0329bced938d79a23bb392658 (diff)
downloadtipidee-ffd8df879dea5b306b1a1615c2eabe0d463a3a3b.tar.xz
custom-headers revamp, can be removed now
Signed-off-by: Laurent Bercot <ska@appnovation.com>
Diffstat (limited to 'src/libtipidee')
-rw-r--r--src/libtipidee/tipidee_response_header_preparebuiltin.c14
-rw-r--r--src/libtipidee/tipidee_response_header_writeall.c1
-rw-r--r--src/libtipidee/tipidee_response_header_writemerge.c9
3 files changed, 11 insertions, 13 deletions
diff --git a/src/libtipidee/tipidee_response_header_preparebuiltin.c b/src/libtipidee/tipidee_response_header_preparebuiltin.c
index a04b666..56978c7 100644
--- a/src/libtipidee/tipidee_response_header_preparebuiltin.c
+++ b/src/libtipidee/tipidee_response_header_preparebuiltin.c
@@ -18,11 +18,15 @@ int tipidee_response_header_preparebuiltin (tipidee_response_header *tab, uint32
if (pos++ >= len) return 0 ;
tab[i].options = (uint8_t)s[pos] ;
if (pos++ >= len) return 0 ;
- tab[i].value = s + pos ;
- next = memchr(s + pos, 0, len - pos) ;
- if (!next) return 0 ;
- pos = next - s ;
- if (pos++ >= len) return 0 ;
+ if (tab[i].options & 0x80) tab[i].value = 0 ;
+ else
+ {
+ tab[i].value = s + pos ;
+ next = memchr(s + pos, 0, len - pos) ;
+ if (!next) return 0 ;
+ pos = next - s ;
+ if (pos++ >= len) return 0 ;
+ }
}
return pos == len ;
}
diff --git a/src/libtipidee/tipidee_response_header_writeall.c b/src/libtipidee/tipidee_response_header_writeall.c
index a61a80d..b94578d 100644
--- a/src/libtipidee/tipidee_response_header_writeall.c
+++ b/src/libtipidee/tipidee_response_header_writeall.c
@@ -11,6 +11,7 @@ size_t tipidee_response_header_writeall (buffer *b, tipidee_response_header cons
if (options & 1) m += buffer_putsnoflush(b, "Connection: close\r\n") ;
for (uint32_t i = 0 ; i < rhdrn ; i++)
{
+ if (!rhdr[i].value) continue ;
m += buffer_putsnoflush(b, rhdr[i].key) ;
m += buffer_putnoflush(b, ": ", 2) ;
m += buffer_putsnoflush(b, rhdr[i].value) ;
diff --git a/src/libtipidee/tipidee_response_header_writemerge.c b/src/libtipidee/tipidee_response_header_writemerge.c
index b8b1e10..d31aadc 100644
--- a/src/libtipidee/tipidee_response_header_writemerge.c
+++ b/src/libtipidee/tipidee_response_header_writemerge.c
@@ -16,19 +16,13 @@ static int tipidee_response_header_cmp (void const *a, void const *b)
size_t tipidee_response_header_writemerge (buffer *b, tipidee_response_header const *rhdr, uint32_t rhdrn, tipidee_headers const *hdr, uint32_t options, tain const *stamp)
{
- static char const *const nope_table[] =
- {
- "Connection",
- "Content-Length",
- "Date",
- "Status"
- } ;
char fmt[128] ;
size_t m = buffer_putnoflush(b, fmt, tipidee_response_header_date(fmt, 128, stamp)) ;
if (options & 1) m += buffer_putsnoflush(b, "Connection: close\r\n") ;
for (uint32_t i = 0 ; i < rhdrn ; i++)
{
+ if (!rhdr[i].value) continue ;
if (rhdr[i].options & 1 && tipidee_headers_search(hdr, rhdr[i].key)) continue ;
m += buffer_putsnoflush(b, rhdr[i].key) ;
m += buffer_putnoflush(b, ": ", 2) ;
@@ -41,7 +35,6 @@ size_t tipidee_response_header_writemerge (buffer *b, tipidee_response_header co
tipidee_response_header const *p ;
char const *key = hdr->buf + hdr->list[i].left ;
if (!strncasecmp(key, "X-CGI-", 6)) continue ;
- if (bsearch(key, nope_table, sizeof(nope_table) / sizeof(char const *const), sizeof(char const *const), (int (*)(void const *, void const *))&strcasecmp)) continue ;
p = bsearch(key, rhdr, rhdrn, sizeof(tipidee_response_header), &tipidee_response_header_cmp) ;
if (p && !(p->options & 1)) continue ;
m += buffer_putsnoflush(b, key) ;