diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2022-09-08 09:48:03 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2022-09-08 09:48:03 +0000 |
commit | f76597299f32495fbf8f909bd50d3e422998c006 (patch) | |
tree | a6b9f5258ab6863787f3966449297fde33d8263f /usr.sbin/rpki-client/http.c | |
parent | 8a481224c499b058eacdb600a7e89190028e42bc (diff) |
Adjust HTTP header parsing to follow RFC more closely.
RFC9112 allows any amount of space/tabs between the ':' and the value.
Until now this code required exactly one space which works most of the
time but is not RFC compliant.
Problem reported by Ties de Kock (tdekock (at) ripe.net)
OK tb@
Diffstat (limited to 'usr.sbin/rpki-client/http.c')
-rw-r--r-- | usr.sbin/rpki-client/http.c | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/usr.sbin/rpki-client/http.c b/usr.sbin/rpki-client/http.c index be8443eaacf..128069a6f8e 100644 --- a/usr.sbin/rpki-client/http.c +++ b/usr.sbin/rpki-client/http.c @@ -1,4 +1,4 @@ -/* $OpenBSD: http.c,v 1.65 2022/08/30 14:33:26 tb Exp $ */ +/* $OpenBSD: http.c,v 1.66 2022/09/08 09:48:02 claudio Exp $ */ /* * Copyright (c) 2020 Nils Fisher <nils_fisher@hotmail.com> * Copyright (c) 2020 Claudio Jeker <claudio@openbsd.org> @@ -1164,11 +1164,11 @@ http_redirect(struct http_connection *conn) static int http_parse_header(struct http_connection *conn, char *buf) { -#define CONTENTLEN "Content-Length: " -#define LOCATION "Location: " -#define CONNECTION "Connection: " -#define TRANSFER_ENCODING "Transfer-Encoding: " -#define LAST_MODIFIED "Last-Modified: " +#define CONTENTLEN "Content-Length:" +#define LOCATION "Location:" +#define CONNECTION "Connection:" +#define TRANSFER_ENCODING "Transfer-Encoding:" +#define LAST_MODIFIED "Last-Modified:" const char *errstr; char *cp, *redirurl; char *locbase, *loctail; @@ -1178,10 +1178,9 @@ http_parse_header(struct http_connection *conn, char *buf) if (*cp == '\0') return 0; else if (strncasecmp(cp, CONTENTLEN, sizeof(CONTENTLEN) - 1) == 0) { - size_t s; cp += sizeof(CONTENTLEN) - 1; - if ((s = strcspn(cp, " \t")) != 0) - *(cp + s) = 0; + cp += strspn(cp, " \t"); + cp[strcspn(cp, " \t")] = '\0'; conn->iosz = strtonum(cp, 0, MAX_CONTENTLEN, &errstr); if (errstr != NULL) { warnx("Content-Length of %s is %s", @@ -1191,6 +1190,7 @@ http_parse_header(struct http_connection *conn, char *buf) } else if (http_isredirect(conn) && strncasecmp(cp, LOCATION, sizeof(LOCATION) - 1) == 0) { cp += sizeof(LOCATION) - 1; + cp += strspn(cp, " \t"); /* * If there is a colon before the first slash, this URI * is not relative. RFC 3986 4.2 @@ -1232,11 +1232,13 @@ http_parse_header(struct http_connection *conn, char *buf) } else if (strncasecmp(cp, TRANSFER_ENCODING, sizeof(TRANSFER_ENCODING) - 1) == 0) { cp += sizeof(TRANSFER_ENCODING) - 1; + cp += strspn(cp, " \t"); cp[strcspn(cp, " \t")] = '\0'; if (strcasecmp(cp, "chunked") == 0) conn->chunked = 1; } else if (strncasecmp(cp, CONNECTION, sizeof(CONNECTION) - 1) == 0) { cp += sizeof(CONNECTION) - 1; + cp += strspn(cp, " \t"); cp[strcspn(cp, " \t")] = '\0'; if (strcasecmp(cp, "close") == 0) conn->keep_alive = 0; @@ -1245,6 +1247,7 @@ http_parse_header(struct http_connection *conn, char *buf) } else if (strncasecmp(cp, LAST_MODIFIED, sizeof(LAST_MODIFIED) - 1) == 0) { cp += sizeof(LAST_MODIFIED) - 1; + cp += strspn(cp, " \t"); free(conn->last_modified); if ((conn->last_modified = strdup(cp)) == NULL) err(1, NULL); |