From e8ba094c3e23f332dba5f2d9794c5e4c100ba568 Mon Sep 17 00:00:00 2001 From: teor Date: Mon, 19 Aug 2019 16:36:20 +1000 Subject: [PATCH] nodelist: Clear buffers and detect more caller errors in describe.c Part of 21003. --- src/feature/nodelist/describe.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/src/feature/nodelist/describe.c b/src/feature/nodelist/describe.c index b64d4335a6..7ec18438c1 100644 --- a/src/feature/nodelist/describe.c +++ b/src/feature/nodelist/describe.c @@ -44,6 +44,13 @@ format_node_description(char *buf, if (!buf) return ""; + memset(buf, 0, NODE_DESC_BUF_LEN); + + if (!id_digest) { + memcpy(buf, "", 17); + return buf; + } + buf[0] = '$'; base16_encode(buf+1, HEX_DIGEST_LEN+1, id_digest, DIGEST_LEN); cp = buf+1+HEX_DIGEST_LEN; @@ -122,6 +129,8 @@ node_describe(const node_t *node) nickname = node->ri->nickname; addr32h = node->ri->addr; ipv6_addr = &node->ri->ipv6_addr; + } else { + return ""; } return format_node_description(buf, @@ -179,6 +188,16 @@ extend_info_describe(const extend_info_t *ei) void router_get_verbose_nickname(char *buf, const routerinfo_t *router) { + if (!buf) + return; + + memset(buf, 0, MAX_VERBOSE_NICKNAME_LEN+1); + + if (!router) { + memcpy(buf, "", 7); + return; + } + buf[0] = '$'; base16_encode(buf+1, HEX_DIGEST_LEN+1, router->cache_info.identity_digest, DIGEST_LEN); -- 2.47.3