chiark / gitweb /
core: make sure we have enough information when doing selinux decisions
authorLennart Poettering <lennart@poettering.net>
Wed, 26 Nov 2014 17:57:37 +0000 (18:57 +0100)
committerLennart Poettering <lennart@poettering.net>
Wed, 26 Nov 2014 17:57:39 +0000 (18:57 +0100)
Let's ask for the security relevant bits in a race-free way, and augment
the rest from /proc.

src/core/dbus.c
src/core/selinux-access.c

index ec1c0d43369dd8daade84de7aab149a4e775bbec..e23d36fddcd1bb8f3a81b6dddc4d4103bc1fb9e9 100644 (file)
@@ -776,6 +776,14 @@ static int bus_setup_api(Manager *m, sd_bus *bus) {
         assert(m);
         assert(bus);
 
+        /* Let's make sure we have enough credential bits so that we can make security and selinux decisions */
+        r = sd_bus_negotiate_creds(bus, 1,
+                                   SD_BUS_CREDS_PID|SD_BUS_CREDS_UID|
+                                   SD_BUS_CREDS_EUID|SD_BUS_CREDS_EFFECTIVE_CAPS|
+                                   SD_BUS_CREDS_SELINUX_CONTEXT);
+        if (r < 0)
+                log_warning("Failed to enable credential passing, ignoring: %s", strerror(-r));
+
         r = bus_setup_api_vtables(m, bus);
         if (r < 0)
                 return r;
index a4694b33f36e5a7321388981493730779e44b965..a50dec3961cab361e0eec2c1fc0857c017cbbc57 100644 (file)
@@ -207,7 +207,8 @@ int mac_selinux_generic_access_check(
                         message,
                         SD_BUS_CREDS_PID|SD_BUS_CREDS_UID|SD_BUS_CREDS_GID|
                         SD_BUS_CREDS_CMDLINE|SD_BUS_CREDS_AUDIT_LOGIN_UID|
-                        SD_BUS_CREDS_SELINUX_CONTEXT,
+                        SD_BUS_CREDS_SELINUX_CONTEXT|
+                        SD_BUS_CREDS_AUGMENT /* get more bits from /proc */,
                         &creds);
         if (r < 0)
                 goto finish;