aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2010-06-21 19:15:25 +0800
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2010-06-22 17:59:25 +0800
commit6b7a7b32680892b3e5cc45e8ef012fc323d06a4c (patch)
treea5e940d66cb8ec9b23b7c14b560be4bc33864ed5
parentf43fbe8cdb7adf761c2b23206b4c13ee5efc3332 (diff)
downloadgsoc2013-empathy-6b7a7b32680892b3e5cc45e8ef012fc323d06a4c.tar
gsoc2013-empathy-6b7a7b32680892b3e5cc45e8ef012fc323d06a4c.tar.gz
gsoc2013-empathy-6b7a7b32680892b3e5cc45e8ef012fc323d06a4c.tar.bz2
gsoc2013-empathy-6b7a7b32680892b3e5cc45e8ef012fc323d06a4c.tar.lz
gsoc2013-empathy-6b7a7b32680892b3e5cc45e8ef012fc323d06a4c.tar.xz
gsoc2013-empathy-6b7a7b32680892b3e5cc45e8ef012fc323d06a4c.tar.zst
gsoc2013-empathy-6b7a7b32680892b3e5cc45e8ef012fc323d06a4c.zip
call-factory: use TpSimpleHandler to handle incoming calls (#622368)
-rw-r--r--libempathy/empathy-call-factory.c130
-rw-r--r--libempathy/empathy-call-factory.h3
2 files changed, 120 insertions, 13 deletions
diff --git a/libempathy/empathy-call-factory.c b/libempathy/empathy-call-factory.c
index d02b58327..b45b8621b 100644
--- a/libempathy/empathy-call-factory.c
+++ b/libempathy/empathy-call-factory.c
@@ -22,12 +22,25 @@
#include <stdio.h>
#include <stdlib.h>
+#include <telepathy-glib/simple-handler.h>
+#include <telepathy-glib/interfaces.h>
+#include <telepathy-glib/util.h>
+
#include "empathy-marshal.h"
#include "empathy-call-factory.h"
#include "empathy-utils.h"
G_DEFINE_TYPE(EmpathyCallFactory, empathy_call_factory, G_TYPE_OBJECT)
+static void handle_channels_cb (TpSimpleHandler *handler,
+ TpAccount *account,
+ TpConnection *connection,
+ GList *channels,
+ GList *requests_satisfied,
+ gint64 user_action_time,
+ TpHandleChannelsContext *context,
+ gpointer user_data);
+
/* signal enum */
enum
{
@@ -39,6 +52,7 @@ static guint signals[LAST_SIGNAL] = {0};
/* private structure */
typedef struct {
+ TpBaseClient *handler;
gboolean dispose_has_run;
} EmpathyCallFactoryPriv;
@@ -51,8 +65,54 @@ empathy_call_factory_init (EmpathyCallFactory *obj)
{
EmpathyCallFactoryPriv *priv = G_TYPE_INSTANCE_GET_PRIVATE (obj,
EMPATHY_TYPE_CALL_FACTORY, EmpathyCallFactoryPriv);
+ TpDBusDaemon *dbus;
+ GError *error = NULL;
obj->priv = priv;
+
+ dbus = tp_dbus_daemon_dup (&error);
+ if (dbus == NULL)
+ {
+ g_warning ("Failed to get TpDBusDaemon: %s", error->message);
+ g_error_free (error);
+ return;
+ }
+
+ priv->handler = tp_simple_handler_new (dbus, FALSE, FALSE,
+ "Empathy.AudioVideo", FALSE, handle_channels_cb, obj, NULL);
+
+ tp_base_client_take_handler_filter (priv->handler, tp_asv_new (
+ TP_PROP_CHANNEL_CHANNEL_TYPE, G_TYPE_STRING,
+ TP_IFACE_CHANNEL_TYPE_STREAMED_MEDIA,
+ TP_PROP_CHANNEL_TARGET_HANDLE_TYPE, G_TYPE_UINT, TP_HANDLE_TYPE_CONTACT,
+ NULL));
+
+ tp_base_client_take_handler_filter (priv->handler, tp_asv_new (
+ TP_PROP_CHANNEL_CHANNEL_TYPE, G_TYPE_STRING,
+ TP_IFACE_CHANNEL_TYPE_STREAMED_MEDIA,
+ TP_PROP_CHANNEL_TARGET_HANDLE_TYPE, G_TYPE_UINT, TP_HANDLE_TYPE_CONTACT,
+ TP_PROP_CHANNEL_TYPE_STREAMED_MEDIA_INITIAL_AUDIO, G_TYPE_BOOLEAN, TRUE,
+ NULL));
+
+ tp_base_client_take_handler_filter (priv->handler, tp_asv_new (
+ TP_PROP_CHANNEL_CHANNEL_TYPE, G_TYPE_STRING,
+ TP_IFACE_CHANNEL_TYPE_STREAMED_MEDIA,
+ TP_PROP_CHANNEL_TARGET_HANDLE_TYPE, G_TYPE_UINT, TP_HANDLE_TYPE_CONTACT,
+ TP_PROP_CHANNEL_TYPE_STREAMED_MEDIA_INITIAL_VIDEO, G_TYPE_BOOLEAN, TRUE,
+ NULL));
+
+ tp_base_client_add_handler_capabilities_varargs (priv->handler,
+ "org.freedesktop.Telepathy.Channel.Interface.MediaSignalling/ice-udp",
+ "org.freedesktop.Telepathy.Channel.Interface.MediaSignalling/gtalk-p2p",
+ NULL);
+
+ if (!tp_base_client_register (priv->handler, &error))
+ {
+ g_warning ("Failed to register Handler: %s", error->message);
+ g_error_free (error);
+ }
+
+ g_object_unref (dbus);
}
static GObject *
@@ -159,6 +219,7 @@ empathy_call_factory_new_call_with_streams (EmpathyCallFactory *factory,
handler, TRUE);
g_object_unref (handler);
+#endif
}
@@ -176,26 +237,75 @@ empathy_call_factory_new_call (EmpathyCallFactory *factory,
empathy_call_factory_new_call_with_streams (factory, contact, TRUE, FALSE);
}
-void
-empathy_call_factory_claim_channel (EmpathyCallFactory *factory,
- EmpathyDispatchOperation *operation)
+static void
+create_call_handler (EmpathyCallFactory *factory,
+ EmpathyTpCall *call)
{
EmpathyCallHandler *handler;
- EmpathyTpCall *call;
g_return_if_fail (factory != NULL);
- g_return_if_fail (operation != NULL);
-
- call = EMPATHY_TP_CALL (
- empathy_dispatch_operation_get_channel_wrapper (operation));
handler = empathy_call_handler_new_for_channel (call);
- empathy_dispatch_operation_claim (operation);
- /* FIXME should actually look at the channel */
g_signal_emit (factory, signals[NEW_CALL_HANDLER], 0,
handler, FALSE);
g_object_unref (handler);
}
+static void
+call_status_changed_cb (EmpathyTpCall *call,
+ GParamSpec *spec,
+ EmpathyCallFactory *self)
+{
+ if (empathy_tp_call_get_status (call) <= EMPATHY_TP_CALL_STATUS_READYING)
+ return;
+
+ create_call_handler (self, call);
+
+ g_signal_handlers_disconnect_by_func (call, call_status_changed_cb, self);
+ g_object_unref (call);
+}
+
+static void
+handle_channels_cb (TpSimpleHandler *handler,
+ TpAccount *account,
+ TpConnection *connection,
+ GList *channels,
+ GList *requests_satisfied,
+ gint64 user_action_time,
+ TpHandleChannelsContext *context,
+ gpointer user_data)
+{
+ EmpathyCallFactory *self = user_data;
+ GList *l;
+
+ for (l = channels; l != NULL; l = g_list_next (l))
+ {
+ TpChannel *channel = l->data;
+ EmpathyTpCall *call;
+
+ if (tp_proxy_get_invalidated (channel) != NULL)
+ continue;
+
+ if (tp_channel_get_channel_type_id (channel) !=
+ TP_IFACE_QUARK_CHANNEL_TYPE_STREAMED_MEDIA)
+ continue;
+
+ call = empathy_tp_call_new (channel);
+
+ if (empathy_tp_call_get_status (call) <= EMPATHY_TP_CALL_STATUS_READYING)
+ {
+ /* We have to wait that the TpCall is ready as the
+ * call-handler rely on it. */
+ tp_g_signal_connect_object (call, "notify::status",
+ G_CALLBACK (call_status_changed_cb), self, 0);
+ continue;
+ }
+
+ create_call_handler (self, call);
+ g_object_unref (call);
+ }
+
+ tp_handle_channels_context_accept (context);
+}
diff --git a/libempathy/empathy-call-factory.h b/libempathy/empathy-call-factory.h
index 27b205973..f7cd9d240 100644
--- a/libempathy/empathy-call-factory.h
+++ b/libempathy/empathy-call-factory.h
@@ -70,9 +70,6 @@ void empathy_call_factory_new_call (EmpathyCallFactory *factory,
void empathy_call_factory_new_call_with_streams (EmpathyCallFactory *factory,
EmpathyContact *contact, gboolean initial_audio, gboolean initial_video);
-void empathy_call_factory_claim_channel (EmpathyCallFactory *factory,
- EmpathyDispatchOperation *operation);
-
G_END_DECLS
#endif /* #ifndef __EMPATHY_CALL_FACTORY_H__*/