[PATCH v4 13/18] session_policy_ivi: Add policy plugin for IVI

Daniel Wagner wagi at monom.org
Wed Nov 14 08:26:12 PST 2012


From: Daniel Wagner <daniel.wagner at bmw-carit.de>

Add only the empty 'framework'. In the following patches we add
step by step the implementation.
---
 Makefile.plugins             | 12 ++++++
 configure.ac                 |  6 +++
 plugins/session_policy_ivi.c | 91 ++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 109 insertions(+)
 create mode 100644 plugins/session_policy_ivi.c

diff --git a/Makefile.plugins b/Makefile.plugins
index a6cda48..be878c5 100644
--- a/Makefile.plugins
+++ b/Makefile.plugins
@@ -235,6 +235,18 @@ plugins_session_policy_la_LDFLAGS = $(plugin_ldflags)
 endif
 endif
 
+if SESSION_POLICY_IVI
+if SESSION_POLICY_IVI_BUILTIN
+builtin_modules += session_policy_ivi
+builtin_sources += plugins/session_policy_ivi.c
+else
+plugin_LTLIBRARIES += plugins/session_policy_ivi.la
+plugin_objects += $(plugins_session_policy_ivi_la_OBJECTS)
+plugins_session_policy_ivi_la_CFLAGS = $(plugin_cflags)
+plugins_session_policy_ivi_la_LDFLAGS = $(plugin_ldflags)
+endif
+endif
+
 EXTRA_DIST += plugins/polkit.policy
 
 plugins/net.connman.policy: plugins/polkit.policy
diff --git a/configure.ac b/configure.ac
index d9dba39..a83051d 100644
--- a/configure.ac
+++ b/configure.ac
@@ -258,6 +258,12 @@ AC_ARG_ENABLE(session-policy,
 AM_CONDITIONAL(SESSION_POLICY, test "${enable_session_policy}" != "no")
 AM_CONDITIONAL(SESSION_POLICY_BUILTIN, test "${enable_session_policy}" = "builtin")
 
+AC_ARG_ENABLE(session-policy-ivi,
+	AC_HELP_STRING([--enable-session-policy-ivi], [enable IVI Session policy configuration support]),
+			[enable_session_policy_ivi=${enableval}], [enable_session_policy_ivi="no"])
+AM_CONDITIONAL(SESSION_POLICY_IVI, test "${enable_session_policy_ivi}" != "no")
+AM_CONDITIONAL(SESSION_POLICY_IVI_BUILTIN, test "${enable_session_policy_ivi}" = "builtin")
+
 AC_ARG_WITH(stats-max-file-size, AC_HELP_STRING([--with-stats-max-file-size=SIZE],
 			[Maximal size of a statistics round robin file]),
 			[stats_max_file_size=${withval}])
diff --git a/plugins/session_policy_ivi.c b/plugins/session_policy_ivi.c
new file mode 100644
index 0000000..2c30b05
--- /dev/null
+++ b/plugins/session_policy_ivi.c
@@ -0,0 +1,91 @@
+/*
+ *
+ *  Connection Manager
+ *
+ *  Copyright (C) 2012  BMW Car IT GbmH. All rights reserved.
+ *
+ *  This program is free software; you can redistribute it and/or modify
+ *  it under the terms of the GNU General Public License version 2 as
+ *  published by the Free Software Foundation.
+ *
+ *  This program is distributed in the hope that it will be useful,
+ *  but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *  GNU General Public License for more details.
+ *
+ *  You should have received a copy of the GNU General Public License
+ *  along with this program; if not, write to the Free Software
+ *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ *
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <errno.h>
+
+#include <glib.h>
+
+#include <gdbus.h>
+
+#define CONNMAN_API_SUBJECT_TO_CHANGE
+#include <connman/plugin.h>
+#include <connman/log.h>
+#include <connman/session.h>
+#include <connman/dbus.h>
+
+static DBusConnection *connection;
+
+static int policy_ivi_create(struct connman_session *session,
+				connman_session_config_cb callback,
+				void *user_data)
+{
+	DBG("session %p", session);
+
+	return -ENOMEM;
+}
+
+static void policy_ivi_destroy(struct connman_session *session)
+{
+	DBG("session %p", session);
+}
+
+static struct connman_session_policy session_policy_ivi = {
+	.name = "session ivi policy configuration",
+	.priority = CONNMAN_SESSION_POLICY_PRIORITY_DEFAULT,
+	.create = policy_ivi_create,
+	.destroy = policy_ivi_destroy,
+};
+
+static int session_policy_ivi_init(void)
+{
+	int err;
+
+	connection = connman_dbus_get_connection();
+	if (connection == NULL)
+		return -EIO;
+
+	err = connman_session_policy_register(&session_policy_ivi);
+	if (err < 0)
+		goto err;
+
+	return 0;
+
+err:
+	dbus_connection_unref(connection);
+
+	return err;
+}
+
+static void session_policy_ivi_exit(void)
+{
+	connman_session_policy_unregister(&session_policy_ivi);
+
+	dbus_connection_unref(connection);
+}
+
+CONNMAN_PLUGIN_DEFINE(session_policy_ivi,
+		"Session IVI policy configuration plugin",
+		VERSION, CONNMAN_PLUGIN_PRIORITY_DEFAULT,
+		session_policy_ivi_init, session_policy_ivi_exit)
-- 
1.8.0.rc0




More information about the connman mailing list