diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-09-08 08:24:47 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-09-08 08:24:47 -0400 |
commit | f5092e711fb08dfdf7a356f8c58f10effe6fb831 (patch) | |
tree | 84e1c3313b40207b626a7f2f165aabc8881502c4 /src/or/control.c | |
parent | a9d4df9a0807704bf5cd1355c57ad0dc2a677a88 (diff) | |
parent | 3cace828a9b42c62a73d1e3b79161a7f68aca40e (diff) | |
download | tor-f5092e711fb08dfdf7a356f8c58f10effe6fb831.tar.gz tor-f5092e711fb08dfdf7a356f8c58f10effe6fb831.zip |
Merge branch 'maint-0.2.9' into maint-0.3.0
Diffstat (limited to 'src/or/control.c')
-rw-r--r-- | src/or/control.c | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/src/or/control.c b/src/or/control.c index 04cd8e8dc1..879d9bbed9 100644 --- a/src/or/control.c +++ b/src/or/control.c @@ -3593,12 +3593,15 @@ handle_control_postdescriptor(control_connection_t *conn, uint32_t len, int cache = 0; /* eventually, we may switch this to 1 */ const char *cp = memchr(body, '\n', len); - smartlist_t *args = smartlist_new(); - tor_assert(cp); + + if (cp == NULL) { + connection_printf_to_buf(conn, "251 Empty body\r\n"); + return 0; + } ++cp; char *cmdline = tor_memdup_nulterm(body, cp-body); - + smartlist_t *args = smartlist_new(); smartlist_split_string(args, cmdline, " ", SPLIT_SKIP_SPACE|SPLIT_IGNORE_BLANK, 0); SMARTLIST_FOREACH_BEGIN(args, char *, option) { @@ -4191,14 +4194,19 @@ handle_control_hspost(control_connection_t *conn, const char *body) { static const char *opt_server = "SERVER="; - smartlist_t *args = smartlist_new(); smartlist_t *hs_dirs = NULL; const char *encoded_desc = body; size_t encoded_desc_len = len; char *cp = memchr(body, '\n', len); + if (cp == NULL) { + connection_printf_to_buf(conn, "251 Empty body\r\n"); + return 0; + } char *argline = tor_strndup(body, cp-body); + smartlist_t *args = smartlist_new(); + /* If any SERVER= options were specified, try parse the options line */ if (!strcasecmpstart(argline, opt_server)) { /* encoded_desc begins after a newline character */ |