summaryrefslogtreecommitdiffstats
path: root/avahi-daemon/dbus-protocol.c
diff options
context:
space:
mode:
authorTrent Lloyd <lathiat@bur.st>2005-07-04 20:36:12 +0000
committerTrent Lloyd <lathiat@bur.st>2005-07-04 20:36:12 +0000
commit05b0b1d0aad6b9613fff841000815a05486f130b (patch)
treeb478e0a69cc03cddcb0d3cac3939561f268617d3 /avahi-daemon/dbus-protocol.c
parent89b7a2522394dc6c546156b35d197ee00ca6a016 (diff)
* Remove support for dbus 0.23.
git-svn-id: file:///home/lennart/svn/public/avahi/trunk@162 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe
Diffstat (limited to 'avahi-daemon/dbus-protocol.c')
-rw-r--r--avahi-daemon/dbus-protocol.c80
1 files changed, 46 insertions, 34 deletions
diff --git a/avahi-daemon/dbus-protocol.c b/avahi-daemon/dbus-protocol.c
index 4bd9caa..8bf7538 100644
--- a/avahi-daemon/dbus-protocol.c
+++ b/avahi-daemon/dbus-protocol.c
@@ -31,13 +31,29 @@
#include "dbus-protocol.h"
-static DBusConnection *bus = NULL;
+typedef struct Server Server;
+typedef struct Client Client;
+
+struct Client {
+ int id;
+};
+
+struct Server {
+ DBusConnection *bus;
+ GSList *clients;
+ int nextid;
+};
+
+static Server *server = NULL;
static DBusHandlerResult
do_register (DBusConnection *conn, DBusMessage *message)
{
DBusError error;
char *s;
+ Client *client;
+ DBusMessage *reply;
+ DBusMessageIter iter;
dbus_error_init (&error);
@@ -49,12 +65,16 @@ do_register (DBusConnection *conn, DBusMessage *message)
{
g_warning ("Error parsing register attempt");
dbus_error_free (&error);
-
- return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
+ } else {
+ client = g_malloc (sizeof (Client));
+ client->id = server->nextid;
+ server->nextid++;
+
+ server->clients = g_slist_append (server->clients, client);
+
+ g_message ("Register received: idstring=(%s), dbus-id=(%s), client-id=(%d)", s, dbus_message_get_sender (message), client->id);
}
- g_message ("Register received from: %s (dbus: %s)", s, dbus_message_get_sender (message));
-
return DBUS_HANDLER_RESULT_HANDLED;
}
@@ -72,11 +92,7 @@ signal_filter (DBusConnection *conn, DBusMessage *message, void *user_data)
dbus_message_get_member (message));
if (dbus_message_is_signal (message,
-#ifdef DBUS_USE_NEW_API
- DBUS_INTERFACE_LOCAL,
-#else
- DBUS_INTERFACE_ORG_FREEDESKTOP_LOCAL,
-#endif
+ DBUS_INTERFACE_LOCAL,
"Disconnected"))
{
/* No, we shouldn't quit, but until we get somewhere
@@ -90,13 +106,8 @@ signal_filter (DBusConnection *conn, DBusMessage *message, void *user_data)
{
return do_register (conn, message);
} else if (dbus_message_is_signal (message,
-#ifdef DBUS_USE_NEW_API
- DBUS_INTERFACE_DBUS,
- "NameAcquired"))
-#else
- DBUS_INTERFACE_ORG_FREEDESKTOP_DBUS,
- "ServiceAcquired"))
-#endif
+ DBUS_INTERFACE_DBUS,
+ "NameAcquired"))
{
char *name;
@@ -129,35 +140,36 @@ dbus_protocol_setup (GMainLoop *loop)
dbus_error_init (&error);
- bus = dbus_bus_get (DBUS_BUS_SYSTEM, &error);
+ server = g_malloc (sizeof (server));
+
+ server->clients = NULL;
+ server->nextid = 1;
- if (bus == NULL)
+ server->bus = dbus_bus_get (DBUS_BUS_SYSTEM, &error);
+
+ if (server->bus == NULL)
{
g_warning ("dbus_bus_get(): %s", error.message);
dbus_error_free (&error);
- return 1;
+ return 1;
}
- dbus_connection_setup_with_g_main (bus, NULL);
- dbus_connection_set_exit_on_disconnect (bus, FALSE);
+ dbus_connection_setup_with_g_main (server->bus, NULL);
+ dbus_connection_set_exit_on_disconnect (server->bus, FALSE);
-#ifdef DBUS_USE_NEW_API
- dbus_bus_request_name (bus, DBUS_SERVICE_AVAHI, 0, &error);
-#else
- dbus_bus_acquire_service (bus, DBUS_SERVICE_AVAHI, 0, &error);
-#endif
+ dbus_bus_request_name (server->bus, DBUS_SERVICE_AVAHI, 0, &error);
if (dbus_error_is_set (&error))
{
g_warning ("dbus_error_is_set (): %s", error.message);
dbus_error_free (&error);
- return 1;
+ return 1;
}
- dbus_connection_add_filter (bus, signal_filter, loop, NULL);
- dbus_bus_add_match (bus,
+ dbus_connection_add_filter (server->bus, signal_filter, loop, NULL);
+ dbus_bus_add_match (server->bus,
"type='method_call',interface='org.freedesktop.Avahi'",
&error);
@@ -166,7 +178,7 @@ dbus_protocol_setup (GMainLoop *loop)
g_warning ("dbus_bus_add_match (): %s", error.message);
dbus_error_free (&error);
- return 1;
+ return 1;
}
return 0;
@@ -175,8 +187,8 @@ dbus_protocol_setup (GMainLoop *loop)
void
dbus_protocol_shutdown ()
{
- if (bus) {
- dbus_connection_disconnect(bus);
- dbus_connection_unref(bus);
+ if (server->bus) {
+ dbus_connection_disconnect(server->bus);
+ dbus_connection_unref(server->bus);
}
}