[gnome-pilot] Register GpilotDaemon to dbus, try dbus-send.
- From: Matthew Charles Davey <mcdavey src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-pilot] Register GpilotDaemon to dbus, try dbus-send.
- Date: Mon, 9 Aug 2010 08:08:04 +0000 (UTC)
commit 3460962f47ff3e0ad024d7305910dc92878a2a83
Author: Halton Huo <halton huo sun com>
Date: Wed Mar 10 16:16:15 2010 +0800
Register GpilotDaemon to dbus, try dbus-send.
dbus-send --session --dest=org.gnome.GnomePilot \
--type=method_call --print-reply --reply-timeout=2000 \
/org/gnome/GnomePilot/Daemon \
org.gnome.GnomePilot.Daemon.Noop
.gitignore | 2 +-
gpilotd/Makefile.am | 12 +-
gpilotd/gnome-pilot-client.gob | 6 +-
gpilotd/gpilot-daemon.c | 114 +++++++++++++++++---
gpilotd/gpilot-daemon.h | 16 ++--
gpilotd/gpilotd.c | 99 ++++++++++++++++-
....service.in => org.gnome.GnomePilot.service.in} | 2 +-
7 files changed, 212 insertions(+), 39 deletions(-)
---
diff --git a/.gitignore b/.gitignore
index 171ef96..280b93e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -56,7 +56,7 @@ conduits/file/file.conduit
conduits/file/gpilot-install-file
conduits/file/palm.keys
conduits/test/test.conduit
-gpilotd/org.gnome.GPilotd.service
+gpilotd/org.gnome.GnomePilot.service
gpilotd/gpilot-daemon-glue.h
gpilotd/gnome-pilot-client-private.h
gpilotd/gnome-pilot-client.c
diff --git a/gpilotd/Makefile.am b/gpilotd/Makefile.am
index fc11c32..4df19b0 100644
--- a/gpilotd/Makefile.am
+++ b/gpilotd/Makefile.am
@@ -106,8 +106,8 @@ DBUS_SRCLIST = \
BUILT_SOURCES = $(DBUS_SRCLIST) $(GOB_BUILT_SRCS) gpmarshal.c gpmarshal.h
-gpilot-daemon-glue.h: gpilot-daemon.xml Makefile.am
- dbus-binding-tool --prefix=gpilot_daemon --mode=glib-server --output=gpilot-daemon-glue.h $(srcdir)/gpilot-daemon.xml
+gpilot-daemon-glue.h: gpilot-daemon.xml
+ dbus-binding-tool --prefix=gpilot_daemon --mode=glib-server $< > gpilot-daemon-glue.h
CLEANFILES = $(DBUS_SRCLIST) $(service_DATA)
MAINTAINERCLEANFILES = $(GOB_BUILT_SRCS)
@@ -221,9 +221,9 @@ gpilotd_session_wrapper_LDADD = \
servicedir = $(datadir)/dbus-1/services
-service_DATA = org.gnome.GPilotd.service
+service_DATA = org.gnome.GnomePilot.service
-org.gnome.GPilotd.service: org.gnome.GPilotd.service.in \
+org.gnome.GnomePilot.service: org.gnome.GnomePilot.service.in \
Makefile
@sed -e "s|[ ]libexecdir[@]|$(libexecdir)|" $< > $@
@@ -234,11 +234,11 @@ devicedir = $(datadir)/gnome-pilot
device_DATA = devices.xml
EXTRA_DIST = \
- org.gnome.GPilotd.service.in \
+ org.gnome.GnomePilot.service.in \
gpmarshal.list \
gpmarshal.h \
gpmarshal.c \
- gpilotd-daemon.xml \
+ gpilot-daemon.xml \
$(gobfiles) \
$(mime_DATA) \
$(device_DATA) \
diff --git a/gpilotd/gnome-pilot-client.gob b/gpilotd/gnome-pilot-client.gob
index c5bfc99..2dff904 100644
--- a/gpilotd/gnome-pilot-client.gob
+++ b/gpilotd/gnome-pilot-client.gob
@@ -50,9 +50,9 @@
#include <gpilotd/gpilot-daemon.h>
-#define GP_DBUS_NAME "org.gnome.GPilotd"
-#define GP_DBUS_PATH "/org/gnome/GPilotd"
-#define GP_DBUS_INTERFACE "org.gnome.GPilotd"
+#define GP_DBUS_NAME "org.gnome.GnomePilot"
+#define GP_DBUS_PATH "/org/gnome/GnomePilot/Daemon"
+#define GP_DBUS_INTERFACE "org.gnome.GnomePilot.Daemon"
#define IS_STR_SET(x) (x != NULL && x[0] != '\0')
diff --git a/gpilotd/gpilot-daemon.c b/gpilotd/gpilot-daemon.c
index 4619ba6..011a895 100644
--- a/gpilotd/gpilot-daemon.c
+++ b/gpilotd/gpilot-daemon.c
@@ -59,6 +59,8 @@
#include <libhal.h>
#endif
+#define GP_DBUS_PATH "/org/gnome/GnomePilot/Daemon"
+
#define GPILOT_DAEMON_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GPILOT_TYPE_DAEMON, GpilotDaemonPrivate))
#define DEBUG_CODE
@@ -67,6 +69,8 @@ static void gpilot_daemon_class_init (GpilotDaemonClass *klass);
static void gpilot_daemon_init (GpilotDaemon *daemon);
static void gpilot_daemon_finalize (GObject *object);
+static gpointer daemon_object = NULL;
+
/* Set to true when the config should be reloaded */
static void monitor_channel (GPilotDevice *dev, GPilotContext *context);
static gboolean device_in (GIOChannel *, GIOCondition, GPilotContext *);
@@ -102,6 +106,9 @@ struct GpilotDaemonPrivate
GHashTable *notifications;
/* maps from a client_id to GSList** of pilotnames begin monitored */
GHashTable *monitors;
+
+ DBusGProxy *bus_proxy;
+ DBusGConnection *connection;
};
enum {
@@ -1686,7 +1693,13 @@ gpilot_daemon_reread_config (GpilotDaemon *daemon,
}
/* A no-operation call, used by client to occasionally
- check to see if the daemon has blown up */
+ check to see if the daemon has blown up
+Example:
+dbus-send --session --dest=org.gnome.GnomePilot \
+--type=method_call --print-reply --reply-timeout=2000 \
+/org/gnome/GnomePilot/Daemon \
+org.gnome.GnomePilot.Daemon.Noop
+*/
gboolean
gpilot_daemon_noop (GpilotDaemon *daemon)
{
@@ -1699,7 +1712,7 @@ gpilot_daemon_request_install (GpilotDaemon *daemon,
const char *pilot_name,
const char *filename,
const char *description,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error)
@@ -1760,7 +1773,7 @@ gboolean
gpilot_daemon_request_restore (GpilotDaemon *daemon,
const char *pilot_name,
const char *directory,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error)
@@ -1822,7 +1835,7 @@ gpilot_daemon_request_conduit (GpilotDaemon *daemon,
const char *pilot_name,
const char *conduit_name,
GNOME_Pilot_ConduitOperation operation,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error)
@@ -1904,7 +1917,7 @@ gpilot_daemon_remove_request (GpilotDaemon *daemon,
gboolean
gpilot_daemon_get_system_info (GpilotDaemon *daemon,
const char *cradle,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error)
@@ -2239,10 +2252,16 @@ gpilot_daemon_get_databases_from_cache (GpilotDaemon *daemon,
}
/* admin operations */
+/* Example:
+dbus-send --session --dest=org.gnome.GnomePilot \
+--type=method_call --print-reply --reply-timeout=2000 \
+/org/gnome/GnomePilot/Daemon \
+org.gnome.GnomePilot.Daemon.GetUserInfo
+*/
gboolean
gpilot_daemon_get_user_info (GpilotDaemon *daemon,
const char *cradle,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error)
@@ -2277,7 +2296,7 @@ gboolean
gpilot_daemon_set_user_info (GpilotDaemon *daemon,
const char *cradle,
gboolean continue_sync,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long uid,
const char *username,
@@ -2808,6 +2827,53 @@ dbus_notify_daemon_error (const gchar *pilot_id,
}
static void
+bus_name_owner_changed (DBusGProxy *bus_proxy,
+ const char *service_name,
+ const char *old_service_name,
+ const char *new_service_name,
+ GpilotDaemon *daemon)
+{
+ g_debug ("NameOwnerChanged: service_name='%s', old_service_name='%s' new_service_name='%s'",
+ service_name, old_service_name, new_service_name);
+}
+
+static gboolean
+register_daemon (GpilotDaemon *daemon)
+{
+ GError *error = NULL;
+
+ daemon->priv->connection = dbus_g_bus_get (DBUS_BUS_SESSION, &error);
+ if (daemon->priv->connection == NULL) {
+ if (error != NULL) {
+ g_critical ("error getting session bus: %s", error->message);
+ g_error_free (error);
+ }
+ exit (1);
+ }
+
+ daemon->priv->bus_proxy = dbus_g_proxy_new_for_name (daemon->priv->connection,
+ DBUS_SERVICE_DBUS,
+ DBUS_PATH_DBUS,
+ DBUS_INTERFACE_DBUS);
+
+ dbus_g_proxy_add_signal (daemon->priv->bus_proxy,
+ "NameOwnerChanged",
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_INVALID);
+ dbus_g_proxy_connect_signal (daemon->priv->bus_proxy,
+ "NameOwnerChanged",
+ G_CALLBACK (bus_name_owner_changed),
+ daemon,
+ NULL);
+
+ dbus_g_connection_register_g_object (daemon->priv->connection, GP_DBUS_PATH, G_OBJECT (daemon));
+
+ return TRUE;
+}
+
+static void
gpilot_daemon_class_init (GpilotDaemonClass *klass)
{
GObjectClass *object_class = G_OBJECT_CLASS (klass);
@@ -2847,10 +2913,10 @@ gpilot_daemon_class_init (GpilotDaemonClass *klass)
2,
G_TYPE_STRING,
G_TYPE_UINT);
- signals [USERINFO_REQUESTED] = g_signal_new ("userinfo-requested",
+ signals [USERINFO_REQUESTED] = g_signal_new ("user-info-requested",
G_TYPE_FROM_CLASS (object_class),
G_SIGNAL_RUN_LAST,
- G_STRUCT_OFFSET (GpilotDaemonClass, userinfo_requested),
+ G_STRUCT_OFFSET (GpilotDaemonClass, user_info_requested),
NULL,
NULL,
gp_marshal_VOID__STRING_UINT_STRING,
@@ -2859,10 +2925,10 @@ gpilot_daemon_class_init (GpilotDaemonClass *klass)
G_TYPE_STRING,
G_TYPE_UINT,
G_TYPE_STRING);
- signals [SYSINFO_REQUESTED] = g_signal_new ("sysinfo-requested",
+ signals [SYSINFO_REQUESTED] = g_signal_new ("sys-info-requested",
G_TYPE_FROM_CLASS (object_class),
G_SIGNAL_RUN_LAST,
- G_STRUCT_OFFSET (GpilotDaemonClass, sysinfo_requested),
+ G_STRUCT_OFFSET (GpilotDaemonClass, sys_info_requested),
NULL,
NULL,
gp_marshal_VOID__STRING_UINT_UINT_UINT_STRING_STRING_STRING_UINT,
@@ -2982,6 +3048,8 @@ gpilot_daemon_class_init (GpilotDaemonClass *klass)
G_TYPE_BOOLEAN);
g_type_class_add_private (klass, sizeof (GpilotDaemonPrivate));
+
+ dbus_g_object_type_install_info (GPILOT_TYPE_DAEMON, &dbus_glib_gpilot_daemon_object_info);
}
static void
@@ -3054,7 +3122,7 @@ gpilot_daemon_finalize (GObject *object)
g_return_if_fail (object != NULL);
g_return_if_fail (GPILOT_IS_DAEMON (object));
- daemon= GPILOT_DAEMON(object);
+ daemon= GPILOT_DAEMON (object);
g_return_if_fail (daemon->priv != NULL);
@@ -3067,15 +3135,31 @@ gpilot_daemon_finalize (GObject *object)
NULL);
g_hash_table_destroy (daemon->priv->notifications);
+ if (daemon->priv->bus_proxy != NULL) {
+ g_object_unref (daemon->priv->bus_proxy);
+ }
+
G_OBJECT_CLASS (gpilot_daemon_parent_class)->finalize (object);
}
GpilotDaemon*
gpilot_daemon_new ()
{
- GObject *object;
+ if (daemon_object != NULL) {
+ g_object_ref (daemon_object);
+ } else {
+ gboolean res;
+
+ daemon_object = g_object_new (GPILOT_TYPE_DAEMON, NULL);
+ g_object_add_weak_pointer (daemon_object,
+ (gpointer *) &daemon_object);
+ res = register_daemon (daemon_object);
+ if (! res) {
+ g_object_unref (daemon_object);
+ return NULL;
+ }
- object = g_object_new (GPILOT_TYPE_DAEMON, NULL);
+ }
- return GPILOT_DAEMON (object);
+ return GPILOT_DAEMON (daemon_object);
}
diff --git a/gpilotd/gpilot-daemon.h b/gpilotd/gpilot-daemon.h
index 82957c4..7af15e1 100644
--- a/gpilotd/gpilot-daemon.h
+++ b/gpilotd/gpilot-daemon.h
@@ -59,11 +59,11 @@ typedef struct
void (* request_completed) (GpilotDaemon *gpilot,
const char *pilot_id,
unsigned long request_id);
- void (* userinfo_requested) (GpilotDaemon *gpilot,
+ void (* user_info_requested) (GpilotDaemon *gpilot,
const char *device,
unsigned long uid,
const char *username);
- void (* sysinfo_requested) (GpilotDaemon *gpilot,
+ void (* sys_info_requested) (GpilotDaemon *gpilot,
const char *pilot_id,
int rom_size,
int ram_size,
@@ -182,14 +182,14 @@ gboolean gpilot_daemon_request_install (GpilotDaemon *daemon,
const char *pilot_name,
const char *filename,
const char *description,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error);
gboolean gpilot_daemon_request_restore (GpilotDaemon *daemon,
const char *pilot_name,
const char *directory,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error);
@@ -197,7 +197,7 @@ gboolean gpilot_daemon_request_conduit (GpilotDaemon *daemon,
const char *pilot_name,
const char *conduit_name,
GNOME_Pilot_ConduitOperation operation,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error);
@@ -207,7 +207,7 @@ gboolean gpilot_daemon_remove_request (GpilotDaemon *daemon,
/* information operations */
gboolean gpilot_daemon_get_system_info (GpilotDaemon *daemon,
const char *cradle,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error);
@@ -266,14 +266,14 @@ gboolean gpilot_daemon_get_databases_from_cache
/* admin operations */
gboolean gpilot_daemon_get_user_info (GpilotDaemon *daemon,
const char *cradle,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long *handle,
GError **error);
gboolean gpilot_daemon_set_user_info (GpilotDaemon *daemon,
const char *cradle,
gboolean continue_sync,
- GNOME_Pilot_Survival survival,
+ GNOME_Pilot_Survival survival,
unsigned long timeout,
unsigned long uid,
const char *username,
diff --git a/gpilotd/gpilotd.c b/gpilotd/gpilotd.c
index 33057cb..34e72a7 100644
--- a/gpilotd/gpilotd.c
+++ b/gpilotd/gpilotd.c
@@ -27,10 +27,19 @@
#include "config.h"
#endif
+#include <sys/types.h>
+#include <sys/stat.h>
+
+#include <glib.h>
#include <glib/gi18n.h>
+#include <dbus/dbus-glib.h>
+#include <dbus/dbus-glib-lowlevel.h>
+
#include "gpilot-daemon.h"
+#define GPILOTD_DBUS_NAME "org.gnome.GnomePilot"
+
static void remove_pid_file (void);
static void
@@ -138,12 +147,82 @@ dump_build_info (void)
g_string_free (str, TRUE);
}
+static DBusGConnection *
+get_session_bus (void)
+{
+ GError *error;
+ DBusGConnection *bus;
+ DBusConnection *connection;
+
+ error = NULL;
+ bus = dbus_g_bus_get (DBUS_BUS_SESSION, &error);
+ if (bus == NULL) {
+ g_warning ("Couldn't connect to system bus: %s",
+ error->message);
+ g_error_free (error);
+ goto out;
+ }
+
+ connection = dbus_g_connection_get_connection (bus);
+ dbus_connection_set_exit_on_disconnect (connection, FALSE);
+
+ out:
+ return bus;
+}
+
+static gboolean
+dbus_acquire_name (DBusGConnection *connection)
+{
+ DBusGProxy *bus_proxy;
+ GError *error;
+ guint result;
+ gboolean ret;
+
+ ret = FALSE;
+ bus_proxy = dbus_g_proxy_new_for_name (connection,
+ DBUS_SERVICE_DBUS,
+ DBUS_PATH_DBUS,
+ DBUS_INTERFACE_DBUS);
+ if (bus_proxy == NULL) {
+ goto out;
+ }
+
+ error = NULL;
+ if (!dbus_g_proxy_call (bus_proxy,
+ "RequestName",
+ &error,
+ G_TYPE_STRING, GPILOTD_DBUS_NAME,
+ G_TYPE_UINT, DBUS_NAME_FLAG_DO_NOT_QUEUE,
+ G_TYPE_INVALID,
+ G_TYPE_UINT, &result,
+ G_TYPE_INVALID)) {
+ if (error != NULL) {
+ g_warning ("Failed to acquire %s: %s", GPILOTD_DBUS_NAME, error->message);
+ g_error_free (error);
+ } else {
+ g_warning ("Failed to acquire %s", GPILOTD_DBUS_NAME);
+ }
+ goto out;
+ }
+
+ if (result == DBUS_REQUEST_NAME_REPLY_EXISTS) {
+ g_warning (_("gpilotd already running; exiting ...\n"));
+ goto out;
+ }
+
+ ret = TRUE;
+
+ out:
+ return ret;
+}
+
int
main (int argc, char *argv[])
{
- GMainLoop *loop;
- GpilotDaemon *daemon;
- int ret;
+ GMainLoop *loop;
+ GpilotDaemon *daemon;
+ DBusGConnection *connection;
+ int ret;
/*g_log_set_always_fatal (G_LOG_LEVEL_ERROR |
G_LOG_LEVEL_CRITICAL |
@@ -154,8 +233,6 @@ main (int argc, char *argv[])
g_message ("%s %s starting...", PACKAGE, VERSION);
dump_build_info ();
- loop = g_main_loop_new (NULL, FALSE);
-
#ifdef WITH_HAL
if ((hal_ctx = gpilotd_hal_init ()) != NULL)
hal_initialised = 1; /* if 0, fall back to polling sysfs */
@@ -167,11 +244,23 @@ main (int argc, char *argv[])
g_type_init ();
+ connection = get_session_bus ();
+ if (connection == NULL) {
+ goto out;
+ }
+
daemon = gpilot_daemon_new ();
if (daemon == NULL) {
goto out;
}
+ if (! dbus_acquire_name (connection) ) {
+ g_warning ("Could not acquire name; bailing out");
+ goto out;
+ }
+
+ loop = g_main_loop_new (NULL, FALSE);
+
signal (SIGTERM, sig_term_handler);
signal (SIGINT, sig_int_handler);
signal (SIGHUP, sig_hup_handler);
diff --git a/gpilotd/org.gnome.GPilotd.service.in b/gpilotd/org.gnome.GnomePilot.service.in
similarity index 61%
rename from gpilotd/org.gnome.GPilotd.service.in
rename to gpilotd/org.gnome.GnomePilot.service.in
index 2f7b4f0..45140a5 100644
--- a/gpilotd/org.gnome.GPilotd.service.in
+++ b/gpilotd/org.gnome.GnomePilot.service.in
@@ -1,3 +1,3 @@
[D-BUS Service]
-Name=org.gnome.GPilotd
+Name=org.gnome.GnomePilot
Exec= libexecdir@/gpilotd
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]