PUBLISHED_FROM=6fa0be81ce429b8db9e3ed572cb4a876b6fb2693
This commit is contained in:
Sergey Lyubka 2019-07-12 10:23:36 +01:00 committed by Cesanta Bot
parent b6196371bb
commit 1a38e91042
3 changed files with 7 additions and 3 deletions

View File

@ -6289,7 +6289,7 @@ int mg_parse_http(const char *s, int n, struct http_message *hm, int is_req) {
} }
} else { } else {
s = mg_skip(s, end, " ", &hm->proto); s = mg_skip(s, end, " ", &hm->proto);
if (end - s < 4 || s[3] != ' ') return -1; if (end - s < 4 || s[0] < '0' || s[0] > '9' || s[3] != ' ') return -1;
hm->resp_code = atoi(s); hm->resp_code = atoi(s);
if (hm->resp_code < 100 || hm->resp_code >= 600) return -1; if (hm->resp_code < 100 || hm->resp_code >= 600) return -1;
s += 4; s += 4;

View File

@ -455,7 +455,7 @@ int mg_parse_http(const char *s, int n, struct http_message *hm, int is_req) {
} }
} else { } else {
s = mg_skip(s, end, " ", &hm->proto); s = mg_skip(s, end, " ", &hm->proto);
if (end - s < 4 || s[3] != ' ') return -1; if (end - s < 4 || s[0] < '0' || s[0] > '9' || s[3] != ' ') return -1;
hm->resp_code = atoi(s); hm->resp_code = atoi(s);
if (hm->resp_code < 100 || hm->resp_code >= 600) return -1; if (hm->resp_code < 100 || hm->resp_code >= 600) return -1;
s += 4; s += 4;

View File

@ -17,7 +17,7 @@ else
COMMON_PARENT = $(SRC_DIR) COMMON_PARENT = $(SRC_DIR)
endif endif
TEST_SOURCES = unit_test.c test_util.c test_main.c TEST_SOURCES = unit_test.c test_util.c test_main.c fuzz.c
AMALGAMATED_SOURCES = ../mongoose.c AMALGAMATED_SOURCES = ../mongoose.c
KRYPTON_PATH = $(REPO_ROOT)/krypton KRYPTON_PATH = $(REPO_ROOT)/krypton
@ -118,6 +118,10 @@ clean_index_cgi:
@echo -e "CLEAN\tindex.cgi" @echo -e "CLEAN\tindex.cgi"
@rm -f data/cgi/index.cgi* @rm -f data/cgi/index.cgi*
fuzz:
$(CC) fuzz.c ../mongoose.c -o /tmp/$@ -fsanitize=fuzzer,address -g -I..
/tmp/$@
# Interactive: # Interactive:
# docker run -v $(CURDIR)/../..:/cesanta -t -i --entrypoint=/bin/bash cesanta/mongoose_test # docker run -v $(CURDIR)/../..:/cesanta -t -i --entrypoint=/bin/bash cesanta/mongoose_test
docker: docker: