Colin Walters d163e5d
From 166978a09cf5edff4028e670b6074215a4c75eca Mon Sep 17 00:00:00 2001
Colin Walters d163e5d
From: Colin Walters <walters@verbum.org>
Colin Walters d163e5d
Date: Thu, 14 Feb 2013 10:19:34 -0500
Colin Walters d163e5d
Subject: [PATCH] CVE-2013-0292: dbus-gproxy: Verify sender of NameOwnerChanged signals to be o.f.DBus
Colin Walters d163e5d
Colin Walters d163e5d
Anyone can hop on the bus and emit a signal whose interface is
Colin Walters d163e5d
o.f.DBus; it's expected at the moments that clients (and notably DBus
Colin Walters d163e5d
libraries) check the sender.
Colin Walters d163e5d
Colin Walters d163e5d
This could previously be used to trick a system service using dbus-glib
Colin Walters d163e5d
into thinking a malicious signal came from a privileged source, by
Colin Walters d163e5d
claiming that ownership of the privileged source's well-known name had
Colin Walters d163e5d
changed from the privileged source's real unique name to the attacker's
Colin Walters d163e5d
unique name.
Colin Walters d163e5d
Colin Walters d163e5d
[altered to be NULL-safe so it won't crash on peer connections -smcv]
Colin Walters d163e5d
Signed-off-by: Simon McVittie <simon.mcvittie@collabora.co.uk>
Colin Walters d163e5d
Reviewed-by: Simon McVittie <simon.mcvittie@collabora.co.uk>
Colin Walters d163e5d
---
Colin Walters d163e5d
 dbus/dbus-gproxy.c |    7 ++++---
Colin Walters d163e5d
 1 files changed, 4 insertions(+), 3 deletions(-)
Colin Walters d163e5d
Colin Walters d163e5d
diff --git a/dbus/dbus-gproxy.c b/dbus/dbus-gproxy.c
Colin Walters d163e5d
index 2fc52f9..c3ae9ec 100644
Colin Walters d163e5d
--- a/dbus/dbus-gproxy.c
Colin Walters d163e5d
+++ b/dbus/dbus-gproxy.c
Colin Walters d163e5d
@@ -1250,8 +1250,11 @@ dbus_g_proxy_manager_filter (DBusConnection    *connection,
Colin Walters d163e5d
       GSList *tmp;
Colin Walters d163e5d
       const char *sender;
Colin Walters d163e5d
 
Colin Walters d163e5d
+      sender = dbus_message_get_sender (message);
Colin Walters d163e5d
+
Colin Walters d163e5d
       /* First we handle NameOwnerChanged internally */
Colin Walters d163e5d
-      if (dbus_message_is_signal (message,
Colin Walters d163e5d
+      if (g_strcmp0 (sender, DBUS_SERVICE_DBUS) == 0 &&
Colin Walters d163e5d
+	  dbus_message_is_signal (message,
Colin Walters d163e5d
 				  DBUS_INTERFACE_DBUS,
Colin Walters d163e5d
 				  "NameOwnerChanged"))
Colin Walters d163e5d
 	{
Colin Walters d163e5d
@@ -1280,8 +1283,6 @@ dbus_g_proxy_manager_filter (DBusConnection    *connection,
Colin Walters d163e5d
 	    }
Colin Walters d163e5d
 	}
Colin Walters d163e5d
 
Colin Walters d163e5d
-      sender = dbus_message_get_sender (message);
Colin Walters d163e5d
-
Colin Walters d163e5d
       /* dbus spec requires these, libdbus validates */
Colin Walters d163e5d
       g_assert (dbus_message_get_path (message) != NULL);
Colin Walters d163e5d
       g_assert (dbus_message_get_interface (message) != NULL);
Colin Walters d163e5d
-- 
Colin Walters d163e5d
1.7.1
Colin Walters d163e5d