]> git.meshlink.io Git - catta/commitdiff
import basic dbus code into the daemon, with auto-fu magic, etc
authorTrent Lloyd <lathiat@bur.st>
Wed, 18 May 2005 10:34:44 +0000 (10:34 +0000)
committerTrent Lloyd <lathiat@bur.st>
Wed, 18 May 2005 10:34:44 +0000 (10:34 +0000)
git-svn-id: file:///home/lennart/svn/public/avahi/trunk@75 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe

configure.ac
daemon/Makefile.am
daemon/main.c

index a6e0462d8847da6e73ac86ebce0cee169c1d81a6..4e58fb0f2a40a8388fbb38290b60b075d75659a9 100644 (file)
@@ -62,6 +62,11 @@ PKG_CHECK_MODULES(GLIB20, [ glib-2.0 >= 2.4.0 ])
 AC_SUBST(GLIB20_CFLAGS)
 AC_SUBST(GLIB20_LIBS)
 
+# Check for DBUS
+PKG_CHECK_MODULES(DBUS, [ dbus-1 >= 0.23, dbus-glib-1 >= 0.23 ])
+AC_SUBST(DBUS_CFLAGS)
+AC_SUBST(DBUS_LIBS)
+
 # If using GCC specify some additional parameters
 if test "x$GCC" = "xyes" ; then
    CFLAGS="$CFLAGS -pipe -W -Wall -pedantic"
index fb3eeb8178ec07c99e5a6cc3dd3da73b07876090..7f2bc9b30f7ad7dfc14377395ebd769954154db1 100644 (file)
@@ -23,6 +23,10 @@ AM_CFLAGS=-I$(top_srcdir) -D_GNU_SOURCE
 AM_CFLAGS+=$(GLIB20_CFLAGS)
 AM_LDADD=$(GLIB20_LIBS)
 
+# DBUS
+AM_CFLAGS+=$(DBUS_CFLAGS)
+AM_LDADD+=$(DBUS_LIBS)
+
 # This cool debug trap works on i386/gcc only
 AM_CFLAGS+='-DDEBUG_TRAP=__asm__("int $$3")'
 
index c986de0ae42773510c118651cdff4be074a1dc8e..60caed7b1d7c588655b006027cc93c51f6f7b841 100644 (file)
 
 #include <avahi-core/core.h>
 
+#define DBUS_API_SUBJECT_TO_CHANGE
+#include <dbus/dbus.h>
+#include <dbus/dbus-glib-lowlevel.h>
+
+#define DBUS_SERVICE_AVAHI "org.freedesktop.Avahi"
+
+static DBusHandlerResult
+do_register (DBusConnection *conn, DBusMessage *message)
+{
+       DBusError error;
+       char *s;
+
+       dbus_error_init (&error);
+
+       dbus_message_get_args (message, &error,
+                       DBUS_TYPE_STRING, &s,
+                       DBUS_TYPE_INVALID);
+
+       if (dbus_error_is_set (&error))
+       {
+               g_warning ("Error parsing register attempt");
+               dbus_error_free (&error);
+
+               return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
+       }
+
+       g_message ("Register received from: %s", s);
+
+       return DBUS_HANDLER_RESULT_HANDLED;
+}
+
+static DBusHandlerResult
+signal_filter (DBusConnection *conn, DBusMessage *message, void *user_data)
+{
+       GMainLoop *loop = user_data;
+       DBusError error;
+
+       dbus_error_init (&error);
+
+       g_message ("dbus: interface=%s, path=%s, member=%s",
+                       dbus_message_get_interface (message),
+                       dbus_message_get_path (message),
+                       dbus_message_get_member (message));
+
+       if (dbus_message_is_signal (message, DBUS_INTERFACE_LOCAL,
+                               "Disconnected"))
+       {
+               /* No, we shouldn't quit, but until we get somewhere
+                * usefull such that we can restore our state, we will */
+               g_warning ("Disconnnected from d-bus");
+
+               g_main_loop_quit (loop);
+               return DBUS_HANDLER_RESULT_HANDLED;
+       } else if (dbus_message_is_method_call (message, DBUS_SERVICE_AVAHI,
+                               "Register"))
+       {
+               return do_register (conn, message);
+       } else if (dbus_message_is_signal (message, DBUS_SERVICE_DBUS,
+                               "NameAcquired"))
+       {
+               char *name;
+
+               dbus_message_get_args (message, &error,
+                               DBUS_TYPE_STRING, &name,
+                               DBUS_TYPE_INVALID);
+
+               if (dbus_error_is_set (&error))
+               {
+                       g_warning ("Error parsing NameAcquired message");
+                       dbus_error_free (&error);
+
+                       return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
+               }
+
+               g_message ("dbus: NameAcquired (%s)", name);
+
+               return DBUS_HANDLER_RESULT_HANDLED;
+       }
+
+       g_message ("dbus: missed event");
+
+       return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
+}
+               
 int main(int argc, char *argv[]) {
-    AvahiServer *avahi;
     GMainLoop *loop = NULL;
-
-    avahi = avahi_server_new(NULL);
+    DBusConnection *bus;
+    DBusError error;
 
     loop = g_main_loop_new(NULL, FALSE);
+
+    dbus_error_init (&error);
+
+    bus = dbus_bus_get (DBUS_BUS_SYSTEM, &error);
+
+    if (bus == NULL)
+    {
+           g_warning ("dbus_bus_get(): %s", error.message);
+           dbus_error_free (&error);
+
+           return -1;
+    }
+
+    dbus_connection_setup_with_g_main (bus, NULL);
+
+    dbus_bus_request_name (bus, DBUS_SERVICE_AVAHI, 0, &error);
+
+    if (dbus_error_is_set (&error))
+    {
+           g_warning ("dbus_bus_request_name (): %s", error.message);
+           dbus_error_free (&error);
+
+           return -1;
+    }
+
+    dbus_connection_add_filter (bus, signal_filter, loop, NULL);
+    dbus_bus_add_match (bus,
+                   "type='method_call',interface='org.freedesktop.Avahi'",
+                   &error);
+
+    if (dbus_error_is_set (&error))
+    {
+           g_warning ("dbus_bus_add_match (): %s", error.message);
+           dbus_error_free (&error);
+
+           return -1;
+    }
+
     g_main_loop_run(loop);
     g_main_loop_unref(loop);
     
-    avahi_server_free(avahi);
-    
     return 0;
 }