mystifyingyouth / rpms / polkit

Forked from rpms/polkit 2 years ago
Clone

Blame SOURCES/polkit-0.115-CVE-2018-19788.patch

b415b0
diff --git a/src/polkit/polkitunixgroup.c b/src/polkit/polkitunixgroup.c
b415b0
index c57a1aaacbb13c4e4297dd812cf5904f2f427b03..309f68918895e0f8b547f8c06f89c6fb1326fe20 100644
b415b0
--- a/src/polkit/polkitunixgroup.c
b415b0
+++ b/src/polkit/polkitunixgroup.c
b415b0
@@ -71,6 +71,7 @@ G_DEFINE_TYPE_WITH_CODE (PolkitUnixGroup, polkit_unix_group, G_TYPE_OBJECT,
b415b0
 static void
b415b0
 polkit_unix_group_init (PolkitUnixGroup *unix_group)
b415b0
 {
b415b0
+  unix_group->gid = -1; /* (git_t) -1 is not a valid GID under Linux */
b415b0
 }
b415b0
 
b415b0
 static void
b415b0
@@ -100,11 +101,14 @@ polkit_unix_group_set_property (GObject      *object,
b415b0
                                GParamSpec   *pspec)
b415b0
 {
b415b0
   PolkitUnixGroup *unix_group = POLKIT_UNIX_GROUP (object);
b415b0
+  gint val;
b415b0
 
b415b0
   switch (prop_id)
b415b0
     {
b415b0
     case PROP_GID:
b415b0
-      unix_group->gid = g_value_get_int (value);
b415b0
+      val = g_value_get_int (value);
b415b0
+      g_return_if_fail (val != -1);
b415b0
+      unix_group->gid = val;
b415b0
       break;
b415b0
 
b415b0
     default:
b415b0
@@ -131,9 +135,9 @@ polkit_unix_group_class_init (PolkitUnixGroupClass *klass)
b415b0
                                    g_param_spec_int ("gid",
b415b0
                                                      "Group ID",
b415b0
                                                      "The UNIX group ID",
b415b0
-                                                     0,
b415b0
+                                                     G_MININT,
b415b0
                                                      G_MAXINT,
b415b0
-                                                     0,
b415b0
+                                                     -1,
b415b0
                                                      G_PARAM_CONSTRUCT |
b415b0
                                                      G_PARAM_READWRITE |
b415b0
                                                      G_PARAM_STATIC_NAME |
b415b0
@@ -166,9 +170,10 @@ polkit_unix_group_get_gid (PolkitUnixGroup *group)
b415b0
  */
b415b0
 void
b415b0
 polkit_unix_group_set_gid (PolkitUnixGroup *group,
b415b0
-                          gint gid)
b415b0
+                           gint gid)
b415b0
 {
b415b0
   g_return_if_fail (POLKIT_IS_UNIX_GROUP (group));
b415b0
+  g_return_if_fail (gid != -1);
b415b0
   group->gid = gid;
b415b0
 }
b415b0
 
b415b0
@@ -183,6 +188,8 @@ polkit_unix_group_set_gid (PolkitUnixGroup *group,
b415b0
 PolkitIdentity *
b415b0
 polkit_unix_group_new (gint gid)
b415b0
 {
b415b0
+  g_return_val_if_fail (gid != -1, NULL);
b415b0
+
b415b0
   return POLKIT_IDENTITY (g_object_new (POLKIT_TYPE_UNIX_GROUP,
b415b0
                                        "gid", gid,
b415b0
                                        NULL));
b415b0
diff --git a/src/polkit/polkitunixprocess.c b/src/polkit/polkitunixprocess.c
b415b0
index 972b7776825d5ccf677ed12ed620fc0c52352547..b02b25894ad120d88ea21d4c96ac8dca1821fcf2 100644
b415b0
--- a/src/polkit/polkitunixprocess.c
b415b0
+++ b/src/polkit/polkitunixprocess.c
b415b0
@@ -159,9 +159,14 @@ polkit_unix_process_set_property (GObject      *object,
b415b0
       polkit_unix_process_set_pid (unix_process, g_value_get_int (value));
b415b0
       break;
b415b0
 
b415b0
-    case PROP_UID:
b415b0
-      polkit_unix_process_set_uid (unix_process, g_value_get_int (value));
b415b0
+    case PROP_UID: {
b415b0
+      gint val;
b415b0
+
b415b0
+      val = g_value_get_int (value);
b415b0
+      g_return_if_fail (val != -1);
b415b0
+      polkit_unix_process_set_uid (unix_process, val);
b415b0
       break;
b415b0
+    }
b415b0
 
b415b0
     case PROP_START_TIME:
b415b0
       polkit_unix_process_set_start_time (unix_process, g_value_get_uint64 (value));
b415b0
@@ -239,7 +244,7 @@ polkit_unix_process_class_init (PolkitUnixProcessClass *klass)
b415b0
                                    g_param_spec_int ("uid",
b415b0
                                                      "User ID",
b415b0
                                                      "The UNIX user ID",
b415b0
-                                                     -1,
b415b0
+                                                     G_MININT,
b415b0
                                                      G_MAXINT,
b415b0
                                                      -1,
b415b0
                                                      G_PARAM_CONSTRUCT |
b415b0
@@ -303,7 +308,6 @@ polkit_unix_process_set_uid (PolkitUnixProcess *process,
b415b0
                              gint               uid)
b415b0
 {
b415b0
   g_return_if_fail (POLKIT_IS_UNIX_PROCESS (process));
b415b0
-  g_return_if_fail (uid >= -1);
b415b0
   process->uid = uid;
b415b0
 }
b415b0
 
b415b0
diff --git a/src/polkit/polkitunixuser.c b/src/polkit/polkitunixuser.c
b415b0
index 8bfd3a1fb05ddb56adebd097569a9977b7b922f3..234a6976c573ac65200ee08228cd50111f0c769b 100644
b415b0
--- a/src/polkit/polkitunixuser.c
b415b0
+++ b/src/polkit/polkitunixuser.c
b415b0
@@ -72,6 +72,7 @@ G_DEFINE_TYPE_WITH_CODE (PolkitUnixUser, polkit_unix_user, G_TYPE_OBJECT,
b415b0
 static void
b415b0
 polkit_unix_user_init (PolkitUnixUser *unix_user)
b415b0
 {
b415b0
+  unix_user->uid = -1;  /* (uid_t) -1 is not a valid UID under Linux */
b415b0
   unix_user->name = NULL;
b415b0
 }
b415b0
 
b415b0
@@ -112,11 +113,14 @@ polkit_unix_user_set_property (GObject      *object,
b415b0
                                GParamSpec   *pspec)
b415b0
 {
b415b0
   PolkitUnixUser *unix_user = POLKIT_UNIX_USER (object);
b415b0
+  gint val;
b415b0
 
b415b0
   switch (prop_id)
b415b0
     {
b415b0
     case PROP_UID:
b415b0
-      unix_user->uid = g_value_get_int (value);
b415b0
+      val = g_value_get_int (value);
b415b0
+      g_return_if_fail (val != -1);
b415b0
+      unix_user->uid = val;
b415b0
       break;
b415b0
 
b415b0
     default:
b415b0
@@ -144,9 +148,9 @@ polkit_unix_user_class_init (PolkitUnixUserClass *klass)
b415b0
                                    g_param_spec_int ("uid",
b415b0
                                                      "User ID",
b415b0
                                                      "The UNIX user ID",
b415b0
-                                                     0,
b415b0
+                                                     G_MININT,
b415b0
                                                      G_MAXINT,
b415b0
-                                                     0,
b415b0
+                                                     -1,
b415b0
                                                      G_PARAM_CONSTRUCT |
b415b0
                                                      G_PARAM_READWRITE |
b415b0
                                                      G_PARAM_STATIC_NAME |
b415b0
@@ -182,6 +186,7 @@ polkit_unix_user_set_uid (PolkitUnixUser *user,
b415b0
                           gint uid)
b415b0
 {
b415b0
   g_return_if_fail (POLKIT_IS_UNIX_USER (user));
b415b0
+  g_return_if_fail (uid != -1);
b415b0
   user->uid = uid;
b415b0
 }
b415b0
 
b415b0
@@ -196,6 +201,8 @@ polkit_unix_user_set_uid (PolkitUnixUser *user,
b415b0
 PolkitIdentity *
b415b0
 polkit_unix_user_new (gint uid)
b415b0
 {
b415b0
+  g_return_val_if_fail (uid != -1, NULL);
b415b0
+
b415b0
   return POLKIT_IDENTITY (g_object_new (POLKIT_TYPE_UNIX_USER,
b415b0
                                         "uid", uid,
b415b0
                                         NULL));
b415b0
diff --git a/test/data/etc/group b/test/data/etc/group
b415b0
index 12ef328b21b346ee3828ce3aaf15cca83858bd1d..b9acab97211fdf7db521dc0939b2dcfc2c9e350b 100644
b415b0
--- a/test/data/etc/group
b415b0
+++ b/test/data/etc/group
b415b0
@@ -5,3 +5,4 @@ john:x:500:
b415b0
 jane:x:501:
b415b0
 sally:x:502:
b415b0
 henry:x:503:
b415b0
+highuid2:x:4000000000:
b415b0
diff --git a/test/data/etc/passwd b/test/data/etc/passwd
b415b0
index 8544febcd8b1720e5577dfb3f0672a6fef29e701..5cf14a5620259f79806192ca935fee84a29ac96d 100644
b415b0
--- a/test/data/etc/passwd
b415b0
+++ b/test/data/etc/passwd
b415b0
@@ -3,3 +3,5 @@ john:x:500:500:John Done:/home/john:/bin/bash
b415b0
 jane:x:501:501:Jane Smith:/home/jane:/bin/bash
b415b0
 sally:x:502:502:Sally Derp:/home/sally:/bin/bash
b415b0
 henry:x:503:503:Henry Herp:/home/henry:/bin/bash
b415b0
+highuid1:x:2147483648:2147483648:The first high uid:/home/highuid1:/sbin/nologin
b415b0
+highuid2:x:4000000000:4000000000:An example high uid:/home/example:/sbin/nologin
b415b0
diff --git a/test/data/etc/polkit-1/rules.d/10-testing.rules b/test/data/etc/polkit-1/rules.d/10-testing.rules
b415b0
index 446e62291b7fe4c5bacdceb1045350af1a9dc245..98bf062a08cb11fddb7df95d0bcdec1b1ac3587d 100644
b415b0
--- a/test/data/etc/polkit-1/rules.d/10-testing.rules
b415b0
+++ b/test/data/etc/polkit-1/rules.d/10-testing.rules
b415b0
@@ -53,6 +53,27 @@ polkit.addRule(function(action, subject) {
b415b0
     }
b415b0
 });
b415b0
 
b415b0
+polkit.addRule(function(action, subject) {
b415b0
+    if (action.id == "net.company.john_action") {
b415b0
+        if (subject.user == "john") {
b415b0
+            return polkit.Result.YES;
b415b0
+        } else {
b415b0
+            return polkit.Result.NO;
b415b0
+        }
b415b0
+    }
b415b0
+});
b415b0
+
b415b0
+polkit.addRule(function(action, subject) {
b415b0
+    if (action.id == "net.company.highuid2_action") {
b415b0
+        if (subject.user == "highuid2") {
b415b0
+            return polkit.Result.YES;
b415b0
+        } else {
b415b0
+            return polkit.Result.NO;
b415b0
+        }
b415b0
+    }
b415b0
+});
b415b0
+
b415b0
+
b415b0
 // ---------------------------------------------------------------------
b415b0
 // variables
b415b0
 
b415b0
diff --git a/test/polkitbackend/test-polkitbackendjsauthority.c b/test/polkitbackend/test-polkitbackendjsauthority.c
b415b0
index b484a26600dbde074ee7d8491f88624fdc83c39c..71aad23e2f5d1a7b15e138f23e6581a31498bad6 100644
b415b0
--- a/test/polkitbackend/test-polkitbackendjsauthority.c
b415b0
+++ b/test/polkitbackend/test-polkitbackendjsauthority.c
b415b0
@@ -330,6 +330,78 @@ static const RulesTestCase rules_test_cases[] = {
b415b0
     NULL,
b415b0
     POLKIT_IMPLICIT_AUTHORIZATION_AUTHORIZED,
b415b0
   },
b415b0
+
b415b0
+  {
b415b0
+    /* highuid1 is not a member of group 'users', see test/data/etc/group */
b415b0
+    "group_membership_with_non_member(highuid22)",
b415b0
+    "net.company.group.only_group_users",
b415b0
+    "unix-user:highuid2",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_NOT_AUTHORIZED,
b415b0
+  },
b415b0
+
b415b0
+  {
b415b0
+    /* highuid2 is not a member of group 'users', see test/data/etc/group */
b415b0
+    "group_membership_with_non_member(highuid21)",
b415b0
+    "net.company.group.only_group_users",
b415b0
+    "unix-user:highuid2",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_NOT_AUTHORIZED,
b415b0
+  },
b415b0
+
b415b0
+  {
b415b0
+    /* highuid1 is not a member of group 'users', see test/data/etc/group */
b415b0
+    "group_membership_with_non_member(highuid24)",
b415b0
+    "net.company.group.only_group_users",
b415b0
+    "unix-user:2147483648",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_NOT_AUTHORIZED,
b415b0
+  },
b415b0
+
b415b0
+  {
b415b0
+    /* highuid2 is not a member of group 'users', see test/data/etc/group */
b415b0
+    "group_membership_with_non_member(highuid23)",
b415b0
+    "net.company.group.only_group_users",
b415b0
+    "unix-user:4000000000",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_NOT_AUTHORIZED,
b415b0
+  },
b415b0
+
b415b0
+  {
b415b0
+    /* john is authorized to do this, see 10-testing.rules */
b415b0
+    "john_action",
b415b0
+    "net.company.john_action",
b415b0
+    "unix-user:john",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_AUTHORIZED,
b415b0
+  },
b415b0
+
b415b0
+  {
b415b0
+    /* only john is authorized to do this, see 10-testing.rules */
b415b0
+    "jane_action",
b415b0
+    "net.company.john_action",
b415b0
+    "unix-user:jane",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_NOT_AUTHORIZED,
b415b0
+  },
b415b0
+
b415b0
+  {
b415b0
+    /* highuid2 is authorized to do this, see 10-testing.rules */
b415b0
+    "highuid2_action",
b415b0
+    "net.company.highuid2_action",
b415b0
+    "unix-user:highuid2",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_AUTHORIZED,
b415b0
+  },
b415b0
+
b415b0
+  {
b415b0
+    /* only highuid2 is authorized to do this, see 10-testing.rules */
b415b0
+    "highuid1_action",
b415b0
+    "net.company.highuid2_action",
b415b0
+    "unix-user:highuid1",
b415b0
+    NULL,
b415b0
+    POLKIT_IMPLICIT_AUTHORIZATION_NOT_AUTHORIZED,
b415b0
+  },
b415b0
 };
b415b0
 
b415b0
 /* ---------------------------------------------------------------------------------------------------- */
b415b0