From 67c6a63081dd06a9be2a061e50f947ce9e1b1bb7 Mon Sep 17 00:00:00 2001 From: Allan Nathanson <42244061+Allan-N@users.noreply.github.com> Date: Tue, 16 Jul 2024 08:50:38 -0400 Subject: [PATCH] Fix issue where bad registration info leads to NULL dereference crash (#355) When you start off with a "rpt_http_registrations.conf" containing an error and attempt to register then you may get back an unexpected response. If you don't check for the unexpected then you can end up with a crash. This change adds a missing check for the unexpected (lack of "data"). --- res/res_rpt_http_registrations.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/res/res_rpt_http_registrations.c b/res/res_rpt_http_registrations.c index c84b13d..1d6963c 100644 --- a/res/res_rpt_http_registrations.c +++ b/res/res_rpt_http_registrations.c @@ -249,8 +249,9 @@ static int http_register(struct http_registry *reg) port = ast_json_integer_get(ast_json_object_get(json, "port")); refresh = ast_json_integer_get(ast_json_object_get(json, "refresh")); data = ast_json_dump_string(ast_json_object_get(json, "data")); - ast_debug(2, "Response: ipaddr=%s, port=%d, refresh=%d, data=%s\n", ipaddr, port, refresh, data); - if (strstr(data, "successfully registered")) { + ast_debug(2, "Response: ipaddr=%s, port=%d, refresh=%d, data=%s\n", + ipaddr, port, refresh, data); + if (data && strstr(data, "successfully registered")) { ast_copy_string(reg->perceived, ipaddr, sizeof(reg->perceived)); reg->perceived_port = port; reg->refresh = refresh; @@ -336,7 +337,12 @@ static char *handle_show_registrations(struct ast_cli_entry *e, int cmd, struct ast_copy_string(perceived, "", sizeof(perceived)); } snprintf(host, sizeof(host), "%s", ast_sockaddr_stringify(®->addr)); - ast_cli(a->fd, FORMAT, host, reg->username, reg->perceived_port ? perceived : "", reg->refresh, reg->registered ? "Registered" : "Not Registered"); + ast_cli(a->fd, FORMAT, + host, + reg->username, + reg->perceived_port ? perceived : "", + reg->refresh, + reg->registered ? "Registered" : "Not Registered"); counter++; } AST_RWLIST_UNLOCK(®istrations);