Zbigniew Jędrzejewski-Szmek 62fe94
From bb7dd0b04a6e89674100476eed0bbd05c6a4cbd8 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Daniel Mack <zonque@gmail.com>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Mon, 18 Aug 2014 19:55:32 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] bus: add kdbus endpoint types
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Add types to describe endpoints and associated policy entries,
Zbigniew Jędrzejewski-Szmek 62fe94
and add a BusEndpoint instace to ExecContext.
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 Makefile.am             |  2 ++
Zbigniew Jędrzejewski-Szmek 62fe94
 src/core/bus-endpoint.c | 90 +++++++++++++++++++++++++++++++++++++++++++++++++
Zbigniew Jędrzejewski-Szmek 62fe94
 src/core/bus-endpoint.h | 42 +++++++++++++++++++++++
Zbigniew Jędrzejewski-Szmek 62fe94
 src/core/execute.c      |  3 ++
Zbigniew Jędrzejewski-Szmek 62fe94
 src/core/execute.h      |  4 +++
Zbigniew Jędrzejewski-Szmek 62fe94
 5 files changed, 141 insertions(+)
Zbigniew Jędrzejewski-Szmek 62fe94
 create mode 100644 src/core/bus-endpoint.c
Zbigniew Jędrzejewski-Szmek 62fe94
 create mode 100644 src/core/bus-endpoint.h
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/Makefile.am b/Makefile.am
Zbigniew Jędrzejewski-Szmek 62fe94
index 68a78963c1..35c877fe2a 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/Makefile.am
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/Makefile.am
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1028,6 +1028,8 @@ libsystemd_core_la_SOURCES = \
Zbigniew Jędrzejewski-Szmek 62fe94
 	src/core/busname.h \
Zbigniew Jędrzejewski-Szmek 62fe94
 	src/core/bus-common.c \
Zbigniew Jędrzejewski-Szmek 62fe94
 	src/core/bus-common.h \
Zbigniew Jędrzejewski-Szmek 62fe94
+	src/core/bus-endpoint.c \
Zbigniew Jędrzejewski-Szmek 62fe94
+	src/core/bus-endpoint.h \
Zbigniew Jędrzejewski-Szmek 62fe94
 	src/core/target.c \
Zbigniew Jędrzejewski-Szmek 62fe94
 	src/core/target.h \
Zbigniew Jędrzejewski-Szmek 62fe94
 	src/core/snapshot.c \
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/core/bus-endpoint.c b/src/core/bus-endpoint.c
Zbigniew Jędrzejewski-Szmek 62fe94
new file mode 100644
Zbigniew Jędrzejewski-Szmek 62fe94
index 0000000000..8d11974db4
Zbigniew Jędrzejewski-Szmek 62fe94
--- /dev/null
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/core/bus-endpoint.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -0,0 +1,90 @@
Zbigniew Jędrzejewski-Szmek 62fe94
+/***
Zbigniew Jędrzejewski-Szmek 62fe94
+  This file is part of systemd.
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  Copyright 2014 Daniel Mack
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  systemd is free software; you can redistribute it and/or modify it
Zbigniew Jędrzejewski-Szmek 62fe94
+  under the terms of the GNU Lesser General Public License as published by
Zbigniew Jędrzejewski-Szmek 62fe94
+  the Free Software Foundation; either version 2.1 of the License, or
Zbigniew Jędrzejewski-Szmek 62fe94
+  (at your option) any later version.
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  systemd is distributed in the hope that it will be useful, but
Zbigniew Jędrzejewski-Szmek 62fe94
+  WITHOUT ANY WARRANTY; without even the implied warranty of
Zbigniew Jędrzejewski-Szmek 62fe94
+  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Zbigniew Jędrzejewski-Szmek 62fe94
+  Lesser General Public License for more details.
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  You should have received a copy of the GNU Lesser General Public License
Zbigniew Jędrzejewski-Szmek 62fe94
+  along with systemd; If not, see <http://www.gnu.org/licenses/>.
Zbigniew Jędrzejewski-Szmek 62fe94
+***/
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+#include <stdlib.h>
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+#include "bus-endpoint.h"
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+int bus_endpoint_new(BusEndpoint **ep)
Zbigniew Jędrzejewski-Szmek 62fe94
+{
Zbigniew Jędrzejewski-Szmek 62fe94
+        assert(ep);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        *ep = new0(BusEndpoint, 1);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (!*ep)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
+}
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+int bus_endpoint_add_policy(BusEndpoint *ep, const char *name, BusPolicyAccess access)
Zbigniew Jędrzejewski-Szmek 62fe94
+{
Zbigniew Jędrzejewski-Szmek 62fe94
+        _cleanup_free_ BusEndpointPolicy *po;
Zbigniew Jędrzejewski-Szmek 62fe94
+        _cleanup_free_ char *key;
Zbigniew Jędrzejewski-Szmek 62fe94
+        int r;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        assert(ep);
Zbigniew Jędrzejewski-Szmek 62fe94
+        assert(name);
Zbigniew Jędrzejewski-Szmek 62fe94
+        assert(access > _BUS_POLICY_ACCESS_INVALID && access < _BUS_POLICY_ACCESS_MAX);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        /* check if we already have this name in the policy list. If we do, see if the new access level
Zbigniew Jędrzejewski-Szmek 62fe94
+         * is higher than the exising one, and upgrade the entry in that case. Otherwise, do nothing.
Zbigniew Jędrzejewski-Szmek 62fe94
+         */
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (ep->policy_hash) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                po = hashmap_get(ep->policy_hash, name);
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (po) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                        if (po->access < access)
Zbigniew Jędrzejewski-Szmek 62fe94
+                                po->access = access;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+                        return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
+                }
Zbigniew Jędrzejewski-Szmek 62fe94
+        } else {
Zbigniew Jędrzejewski-Szmek 62fe94
+                ep->policy_hash = hashmap_new(string_hash_func, string_compare_func);
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (!ep->policy_hash)
Zbigniew Jędrzejewski-Szmek 62fe94
+                        return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 62fe94
+        }
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        po = new0(BusEndpointPolicy, 1);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (!po)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        key = strdup(name);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (!key)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        po->name = key;
Zbigniew Jędrzejewski-Szmek 62fe94
+        po->access = access;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        r = hashmap_put(ep->policy_hash, key, po);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (r < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return r;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        po = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
+        key = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
+        return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
+}
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+void bus_endpoint_free(BusEndpoint *endpoint)
Zbigniew Jędrzejewski-Szmek 62fe94
+{
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (!endpoint)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        hashmap_free_free_free(endpoint->policy_hash);
Zbigniew Jędrzejewski-Szmek 62fe94
+        free(endpoint);
Zbigniew Jędrzejewski-Szmek 62fe94
+}
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/core/bus-endpoint.h b/src/core/bus-endpoint.h
Zbigniew Jędrzejewski-Szmek 62fe94
new file mode 100644
Zbigniew Jędrzejewski-Szmek 62fe94
index 0000000000..2c5415f34e
Zbigniew Jędrzejewski-Szmek 62fe94
--- /dev/null
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/core/bus-endpoint.h
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -0,0 +1,42 @@
Zbigniew Jędrzejewski-Szmek 62fe94
+/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+#pragma once
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+/***
Zbigniew Jędrzejewski-Szmek 62fe94
+  This file is part of systemd.
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  Copyright 2014 Daniel Mack
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  systemd is free software; you can redistribute it and/or modify it
Zbigniew Jędrzejewski-Szmek 62fe94
+  under the terms of the GNU Lesser General Public License as published by
Zbigniew Jędrzejewski-Szmek 62fe94
+  the Free Software Foundation; either version 2.1 of the License, or
Zbigniew Jędrzejewski-Szmek 62fe94
+  (at your option) any later version.
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  systemd is distributed in the hope that it will be useful, but
Zbigniew Jędrzejewski-Szmek 62fe94
+  WITHOUT ANY WARRANTY; without even the implied warranty of
Zbigniew Jędrzejewski-Szmek 62fe94
+  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Zbigniew Jędrzejewski-Szmek 62fe94
+  Lesser General Public License for more details.
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+  You should have received a copy of the GNU Lesser General Public License
Zbigniew Jędrzejewski-Szmek 62fe94
+  along with systemd; If not, see <http://www.gnu.org/licenses/>.
Zbigniew Jędrzejewski-Szmek 62fe94
+***/
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+typedef struct BusEndpoint BusEndpoint;
Zbigniew Jędrzejewski-Szmek 62fe94
+typedef struct BusEndpointPolicy BusEndpointPolicy;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+#include "bus-common.h"
Zbigniew Jędrzejewski-Szmek 62fe94
+#include "hashmap.h"
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+struct BusEndpointPolicy {
Zbigniew Jędrzejewski-Szmek 62fe94
+        char *name;
Zbigniew Jędrzejewski-Szmek 62fe94
+        BusPolicyAccess access;
Zbigniew Jędrzejewski-Szmek 62fe94
+};
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+struct BusEndpoint {
Zbigniew Jędrzejewski-Szmek 62fe94
+        Hashmap *policy_hash;
Zbigniew Jędrzejewski-Szmek 62fe94
+};
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+int bus_endpoint_new(BusEndpoint **ep);
Zbigniew Jędrzejewski-Szmek 62fe94
+void bus_endpoint_free(BusEndpoint *endpoint);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+int bus_endpoint_add_policy(BusEndpoint *ep, const char *name, BusPolicyAccess access);
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/core/execute.c b/src/core/execute.c
Zbigniew Jędrzejewski-Szmek 62fe94
index 0a5914759f..a88e1b1953 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/core/execute.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/core/execute.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1908,6 +1908,9 @@ void exec_context_done(ExecContext *c) {
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         strv_free(c->runtime_directory);
Zbigniew Jędrzejewski-Szmek 62fe94
         c->runtime_directory = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        bus_endpoint_free(c->bus_endpoint);
Zbigniew Jędrzejewski-Szmek 62fe94
+        c->bus_endpoint = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 int exec_context_destroy_runtime_directory(ExecContext *c, const char *runtime_prefix) {
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/core/execute.h b/src/core/execute.h
Zbigniew Jędrzejewski-Szmek 62fe94
index f31f0c9f27..e3cebfd72c 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/core/execute.h
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/core/execute.h
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -41,6 +41,7 @@ typedef struct ExecParameters ExecParameters;
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "fdset.h"
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "missing.h"
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "namespace.h"
Zbigniew Jędrzejewski-Szmek 62fe94
+#include "bus-endpoint.h"
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 typedef enum ExecInput {
Zbigniew Jędrzejewski-Szmek 62fe94
         EXEC_INPUT_NULL,
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -188,6 +189,9 @@ struct ExecContext {
Zbigniew Jędrzejewski-Szmek 62fe94
         bool ioprio_set:1;
Zbigniew Jędrzejewski-Szmek 62fe94
         bool cpu_sched_set:1;
Zbigniew Jędrzejewski-Szmek 62fe94
         bool no_new_privileges_set:1;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        /* custom dbus enpoint */
Zbigniew Jędrzejewski-Szmek 62fe94
+        BusEndpoint *bus_endpoint;
Zbigniew Jędrzejewski-Szmek 62fe94
 };
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "cgroup.h"