Zbigniew Jędrzejewski-Szmek f1004d
From e91c8c201931d6be8229d624c10ed9c7c210d470 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek f1004d
From: Daniel Mack <daniel@zonque.org>
Zbigniew Jędrzejewski-Szmek f1004d
Date: Tue, 7 Oct 2014 17:58:29 +0200
Zbigniew Jędrzejewski-Szmek f1004d
Subject: [PATCH] bus-proxyd: assorted cleanups and fixes
Zbigniew Jędrzejewski-Szmek f1004d
Zbigniew Jędrzejewski-Szmek f1004d
Just some cleanups around policy checks that came up during review.
Zbigniew Jędrzejewski-Szmek f1004d
The code is still not productive.
Zbigniew Jędrzejewski-Szmek f1004d
---
Zbigniew Jędrzejewski-Szmek f1004d
 src/bus-proxyd/bus-policy.c  | 23 +++++++++++++----------
Zbigniew Jędrzejewski-Szmek f1004d
 test/bus-policy/methods.conf |  2 +-
Zbigniew Jędrzejewski-Szmek f1004d
 2 files changed, 14 insertions(+), 11 deletions(-)
Zbigniew Jędrzejewski-Szmek f1004d
Zbigniew Jędrzejewski-Szmek f1004d
diff --git a/src/bus-proxyd/bus-policy.c b/src/bus-proxyd/bus-policy.c
Zbigniew Jędrzejewski-Szmek f1004d
index 2ff5d646f1..aea8541d50 100644
Zbigniew Jędrzejewski-Szmek f1004d
--- a/src/bus-proxyd/bus-policy.c
Zbigniew Jędrzejewski-Szmek f1004d
+++ b/src/bus-proxyd/bus-policy.c
Zbigniew Jędrzejewski-Szmek f1004d
@@ -604,7 +604,10 @@ struct policy_check_filter {
Zbigniew Jędrzejewski-Szmek f1004d
         int message_type;
Zbigniew Jędrzejewski-Szmek f1004d
         const char *interface;
Zbigniew Jędrzejewski-Szmek f1004d
         const char *path;
Zbigniew Jędrzejewski-Szmek f1004d
-        const char *member;
Zbigniew Jędrzejewski-Szmek f1004d
+        union {
Zbigniew Jędrzejewski-Szmek f1004d
+                const char *name;
Zbigniew Jędrzejewski-Szmek f1004d
+                const char *member;
Zbigniew Jędrzejewski-Szmek f1004d
+        };
Zbigniew Jędrzejewski-Szmek f1004d
         char **names_strv;
Zbigniew Jędrzejewski-Szmek f1004d
         Hashmap *names_hash;
Zbigniew Jędrzejewski-Szmek f1004d
 };
Zbigniew Jędrzejewski-Szmek f1004d
@@ -633,7 +636,7 @@ static int check_policy_item(PolicyItem *i, const struct policy_check_filter *fi
Zbigniew Jędrzejewski-Szmek f1004d
                                 break;
Zbigniew Jędrzejewski-Szmek f1004d
                 }
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-                if (i->message_type && (i->message_type != filter->message_type))
Zbigniew Jędrzejewski-Szmek f1004d
+                if ((i->message_type != _POLICY_ITEM_CLASS_UNSET) && (i->message_type != filter->message_type))
Zbigniew Jędrzejewski-Szmek f1004d
                         break;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
                 if (i->path && !streq_ptr(i->path, filter->path))
Zbigniew Jędrzejewski-Szmek f1004d
@@ -650,14 +653,14 @@ static int check_policy_item(PolicyItem *i, const struct policy_check_filter *fi
Zbigniew Jędrzejewski-Szmek f1004d
         case POLICY_ITEM_OWN:
Zbigniew Jędrzejewski-Szmek f1004d
                 assert(filter->member);
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-                if (streq(i->name, filter->member))
Zbigniew Jędrzejewski-Szmek f1004d
+                if (streq(i->name, "*") || streq(i->name, filter->name))
Zbigniew Jędrzejewski-Szmek f1004d
                         return is_permissive(i);
Zbigniew Jędrzejewski-Szmek f1004d
                 break;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
         case POLICY_ITEM_OWN_PREFIX:
Zbigniew Jędrzejewski-Szmek f1004d
                 assert(filter->member);
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-                if (startswith(i->name, filter->member))
Zbigniew Jędrzejewski-Szmek f1004d
+                if (streq(i->name, "*") || startswith(i->name, filter->name))
Zbigniew Jędrzejewski-Szmek f1004d
                         return is_permissive(i);
Zbigniew Jędrzejewski-Szmek f1004d
                 break;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
@@ -747,9 +750,9 @@ static int policy_check(Policy *p, const struct policy_check_filter *filter) {
Zbigniew Jędrzejewski-Szmek f1004d
 bool policy_check_own(Policy *p, const struct ucred *ucred, const char *name) {
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
         struct policy_check_filter filter = {
Zbigniew Jędrzejewski-Szmek f1004d
-                .class  = POLICY_ITEM_OWN,
Zbigniew Jędrzejewski-Szmek f1004d
-                .ucred  = ucred,
Zbigniew Jędrzejewski-Szmek f1004d
-                .member = name,
Zbigniew Jędrzejewski-Szmek f1004d
+                .class = POLICY_ITEM_OWN,
Zbigniew Jędrzejewski-Szmek f1004d
+                .ucred = ucred,
Zbigniew Jędrzejewski-Szmek f1004d
+                .name  = name,
Zbigniew Jędrzejewski-Szmek f1004d
         };
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
         return policy_check(p, &filter) == ALLOW;
Zbigniew Jędrzejewski-Szmek f1004d
@@ -758,21 +761,21 @@ bool policy_check_own(Policy *p, const struct ucred *ucred, const char *name) {
Zbigniew Jędrzejewski-Szmek f1004d
 bool policy_check_hello(Policy *p, const struct ucred *ucred) {
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
         struct policy_check_filter filter = {
Zbigniew Jędrzejewski-Szmek f1004d
-                .class  = POLICY_ITEM_USER,
Zbigniew Jędrzejewski-Szmek f1004d
                 .ucred  = ucred,
Zbigniew Jędrzejewski-Szmek f1004d
         };
Zbigniew Jędrzejewski-Szmek f1004d
         int user, group;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
+        filter.class = POLICY_ITEM_USER;
Zbigniew Jędrzejewski-Szmek f1004d
         user = policy_check(p, &filter);
Zbigniew Jędrzejewski-Szmek f1004d
         if (user == DENY)
Zbigniew Jędrzejewski-Szmek f1004d
                 return false;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
         filter.class = POLICY_ITEM_GROUP;
Zbigniew Jędrzejewski-Szmek f1004d
         group = policy_check(p, &filter);
Zbigniew Jędrzejewski-Szmek f1004d
-        if (user == DUNNO && group == DUNNO)
Zbigniew Jędrzejewski-Szmek f1004d
+        if (group == DENY)
Zbigniew Jędrzejewski-Szmek f1004d
                 return false;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-        return !(user == DENY || group == DENY);
Zbigniew Jędrzejewski-Szmek f1004d
+        return !(user == DUNNO && group == DUNNO);
Zbigniew Jędrzejewski-Szmek f1004d
 }
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
 bool policy_check_recv(Policy *p,
Zbigniew Jędrzejewski-Szmek f1004d
diff --git a/test/bus-policy/methods.conf b/test/bus-policy/methods.conf
Zbigniew Jędrzejewski-Szmek f1004d
index 4d4675ea10..4bc38f9151 100644
Zbigniew Jędrzejewski-Szmek f1004d
--- a/test/bus-policy/methods.conf
Zbigniew Jędrzejewski-Szmek f1004d
+++ b/test/bus-policy/methods.conf
Zbigniew Jędrzejewski-Szmek f1004d
@@ -11,7 +11,7 @@
Zbigniew Jędrzejewski-Szmek f1004d
                 <allow send_destination="org.test.test1" send_interface="org.test.int1"/>
Zbigniew Jędrzejewski-Szmek f1004d
                 <allow send_destination="org.test.test1" send_interface="org.test.int2"/>
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-                <allow receive_sender="org.test.test3" receive_interface="org.test.int3" receiver_member="Member111"/>
Zbigniew Jędrzejewski-Szmek f1004d
+                <allow receive_sender="org.test.test3" receive_interface="org.test.int3" receive_member="Member111"/>
Zbigniew Jędrzejewski-Szmek f1004d
         </policy>
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
 </busconfig>