From 1324ae06ec95e3b451c02df2fcf5278d87ff18cb Mon Sep 17 00:00:00 2001 From: Michal Vasko Date: Tue, 26 Jul 2022 13:45:34 +0200 Subject: [PATCH] err netconf UPDATE check asprintf return value Refs #1245 --- src/err_netconf.c | 26 ++++++++++++++++++++------ 1 file changed, 20 insertions(+), 6 deletions(-) diff --git a/src/err_netconf.c b/src/err_netconf.c index 5556cc8e..bf2fccfd 100644 --- a/src/err_netconf.c +++ b/src/err_netconf.c @@ -183,8 +183,10 @@ np_err_sr2nc_edit(sr_session_ctx_t *ev_sess, const sr_session_ctx_t *err_sess) ptr = strchr(err->message + 23, '\"'); /* create error message */ - asprintf(&str, "Required leafref target with value \"%.*s\" missing.", (int)(ptr - (err->message + 23)), - err->message + 23); + if (asprintf(&str, "Required leafref target with value \"%.*s\" missing.", (int)(ptr - (err->message + 23)), + err->message + 23) == -1) { + goto mem_error; + } /* instance-required */ assert(path); @@ -195,8 +197,10 @@ np_err_sr2nc_edit(sr_session_ctx_t *ev_sess, const sr_session_ctx_t *err_sess) ptr = strchr(err->message + 29, '\"'); /* create error message */ - asprintf(&str, "Required instance-identifier \"%.*s\" missing.", (int)(ptr - (err->message + 29)), - err->message + 29); + if (asprintf(&str, "Required instance-identifier \"%.*s\" missing.", (int)(ptr - (err->message + 29)), + err->message + 29) == -1) { + goto mem_error; + } /* instance-required */ assert(path); @@ -216,8 +220,10 @@ np_err_sr2nc_edit(sr_session_ctx_t *ev_sess, const sr_session_ctx_t *err_sess) ptr = strchr(err->message + 6, '\"'); /* create error message */ - asprintf(&str, "Missing insert anchor \"%.*s\" instance.", (int)(ptr - (err->message + 6)), - err->message + 6); + if (asprintf(&str, "Missing insert anchor \"%.*s\" instance.", (int)(ptr - (err->message + 6)), + err->message + 6) == -1) { + goto mem_error; + } /* missing-instance */ sr_session_set_netconf_error(ev_sess, "protocol", "bad-attribute", "missing-instance", NULL, str, 0); @@ -266,6 +272,14 @@ np_err_sr2nc_edit(sr_session_ctx_t *ev_sess, const sr_session_ctx_t *err_sess) sr_session_dup_error((sr_session_ctx_t *)err_sess, ev_sess); } + free(path); + free(str); + free(str2); + return; + +mem_error: + sr_session_set_error_message(ev_sess, "Memory allocation failed."); + free(path); free(str); free(str2);