[systemd-commits] src/core

Lennart Poettering lennart at kemper.freedesktop.org
Wed Mar 6 08:24:29 PST 2013


 src/core/dbus.c |   21 ++++++++++++++++++---
 1 file changed, 18 insertions(+), 3 deletions(-)

New commits:
commit 92f303495868f7d6971b7f42c69f63cb0e2e0ebd
Author: Simon McVittie <simon.mcvittie at collabora.co.uk>
Date:   Thu Feb 7 21:14:56 2013 +0000

    bus: Escape environment-based D-Bus addresses properly
    
    If XDG_RUNTIME_DIR contains a character like ":" (for instance if it's
    formed from an X11 display name), then it isn't valid to substitute
    it into a D-Bus address without escaping.
    
    http://bugs.freedesktop.org/show_bug.cgi?id=60499

diff --git a/src/core/dbus.c b/src/core/dbus.c
index 2a1c660..08aff1f 100644
--- a/src/core/dbus.c
+++ b/src/core/dbus.c
@@ -1077,18 +1077,33 @@ static int bus_init_private(Manager *m) {
         } else {
                 const char *e;
                 char *p;
+                char *escaped;
 
                 e = secure_getenv("XDG_RUNTIME_DIR");
                 if (!e)
                         return 0;
 
-                if (asprintf(&p, "unix:path=%s/systemd/private", e) < 0) {
+                if (asprintf(&p, "%s/systemd/private", e) < 0) {
                         r = log_oom();
                         goto fail;
                 }
 
-                mkdir_parents_label(p+10, 0755);
-                unlink(p+10);
+                mkdir_parents_label(p, 0755);
+                unlink(p);
+                free(p);
+
+                escaped = dbus_address_escape_value(e);
+                if (!escaped) {
+                        r = log_oom();
+                        goto fail;
+                }
+                if (asprintf(&p, "unix:path=%s/systemd/private", escaped) < 0) {
+                        dbus_free(escaped);
+                        r = log_oom();
+                        goto fail;
+                }
+                dbus_free(escaped);
+
                 m->private_bus = dbus_server_listen(p, &error);
                 free(p);
         }



More information about the systemd-commits mailing list