snac2

Fork of https://codeberg.org/grunfink/snac2
git clone https://git.inz.fi/snac2
Log | Files | Refs | README | LICENSE

commit be3e5c96182974e569b58699aee18af71f86e13f
parent 52f27123bbd6cf8101a86618c6aa04f52a07543a
Author: default <nobody@localhost>
Date:   Mon, 18 Dec 2023 13:24:07 +0100

Added some crash checks.

Diffstat:
Mactivitypub.c | 6++++++
Mhttpd.c | 2+-
2 files changed, 7 insertions(+), 1 deletion(-)

diff --git a/activitypub.c b/activitypub.c @@ -2323,6 +2323,12 @@ int activitypub_post_handler(const xs_dict *req, const char *q_path, return 400; } + if (xs_is_null(payload)) { + *body = xs_str_new("no payload"); + *ctype = "text/plain"; + return 400; + } + if (xs_str_in(i_ctype, "application/activity+json") == -1 && xs_str_in(i_ctype, "application/ld+json") == -1) return 0; diff --git a/httpd.c b/httpd.c @@ -382,7 +382,7 @@ void httpd_connection(FILE *f) srv_archive("RECV", NULL, req, payload, p_size, status, headers, body, b_size); /* JSON validation check */ - if (strcmp(ctype, "application/json") == 0) { + if (!xs_is_null(body) && strcmp(ctype, "application/json") == 0) { xs *j = xs_json_loads(body); if (j == NULL) {