From 2578d51ebd40ae0a8c6343164334358384dd55f7 Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Wed, 22 Jan 2014 18:45:38 +0100 Subject: [PATCH] bus: unescape connection name when reading it from credentials --- src/libsystemd/sd-bus/bus-creds.c | 10 +++++++++- src/libsystemd/sd-bus/bus-creds.h | 2 +- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/src/libsystemd/sd-bus/bus-creds.c b/src/libsystemd/sd-bus/bus-creds.c index 85509e881..677e94b3b 100644 --- a/src/libsystemd/sd-bus/bus-creds.c +++ b/src/libsystemd/sd-bus/bus-creds.c @@ -48,6 +48,7 @@ void bus_creds_done(sd_bus_creds *c) { free(c->unit); free(c->user_unit); free(c->slice); + free(c->unescaped_conn_name); strv_free(c->cmdline_array); strv_free(c->well_known_names); @@ -471,7 +472,14 @@ _public_ int sd_bus_creds_get_connection_name(sd_bus_creds *c, const char **ret) return -ENODATA; assert(c->conn_name); - *ret = c->conn_name; + + if (!c->unescaped_conn_name) { + c->unescaped_conn_name = sd_bus_label_unescape(c->conn_name); + if (!c->unescaped_conn_name) + return -ENOMEM; + } + + *ret = c->unescaped_conn_name; return 0; } diff --git a/src/libsystemd/sd-bus/bus-creds.h b/src/libsystemd/sd-bus/bus-creds.h index df33d34b6..81b852a59 100644 --- a/src/libsystemd/sd-bus/bus-creds.h +++ b/src/libsystemd/sd-bus/bus-creds.h @@ -65,7 +65,7 @@ struct sd_bus_creds { char *cgroup_root; - char *conn_name; + char *conn_name, *unescaped_conn_name; }; sd_bus_creds* bus_creds_new(void); -- 2.30.2