diff options
-rw-r--r-- | libempathy/empathy-ft-handler.c | 71 |
1 files changed, 36 insertions, 35 deletions
diff --git a/libempathy/empathy-ft-handler.c b/libempathy/empathy-ft-handler.c index beb57b1ed..bd789ff29 100644 --- a/libempathy/empathy-ft-handler.c +++ b/libempathy/empathy-ft-handler.c @@ -117,6 +117,8 @@ typedef struct { GCancellable *cancellable; gboolean use_hash; + EmpathyDispatcher *dispatcher; + /* request for the new transfer */ GHashTable *request; @@ -236,6 +238,12 @@ do_dispose (GObject *object) g_hash_table_unref (priv->request); priv->request = NULL; } + + if (priv->dispatcher != NULL) + { + g_object_unref (priv->dispatcher); + priv->dispatcher = NULL; + } G_OBJECT_CLASS (empathy_ft_handler_parent_class)->dispose (object); } @@ -442,6 +450,7 @@ empathy_ft_handler_init (EmpathyFTHandler *self) self->priv = priv; priv->cancellable = g_cancellable_new (); + priv->dispatcher = empathy_dispatcher_dup_singleton (); } /* private functions */ @@ -659,46 +668,16 @@ ft_handler_create_channel_cb (EmpathyDispatchOperation *operation, static void ft_handler_push_to_dispatcher (EmpathyFTHandler *handler) { - EmpathyDispatcher *dispatcher; TpConnection *connection; EmpathyFTHandlerPriv *priv = GET_PRIV (handler); DEBUG ("Pushing request to the dispatcher"); - dispatcher = empathy_dispatcher_dup_singleton (); connection = empathy_contact_get_connection (priv->contact); /* I want to own a reference to the request, and destroy it later */ - empathy_dispatcher_create_channel (dispatcher, connection, + empathy_dispatcher_create_channel (priv->dispatcher, connection, g_hash_table_ref (priv->request), ft_handler_create_channel_cb, handler); - - g_object_unref (dispatcher); -} - -static gboolean -ft_handler_check_if_allowed (EmpathyFTHandler *handler) -{ - EmpathyDispatcher *dispatcher; - EmpathyFTHandlerPriv *priv = GET_PRIV (handler); - TpConnection *connection; - GStrv allowed; - gboolean res = TRUE; - - dispatcher = empathy_dispatcher_dup_singleton (); - connection = empathy_contact_get_connection (priv->contact); - - allowed = empathy_dispatcher_find_channel_class (dispatcher, connection, - TP_IFACE_CHANNEL_TYPE_FILE_TRANSFER, TP_HANDLE_TYPE_CONTACT); - - if (!tp_strv_contains ((const gchar * const *) allowed, - TP_IFACE_CHANNEL ".TargetHandle")) - res = FALSE; - - DEBUG ("check if FT allowed: %s", res ? "True" : "False"); - - g_object_unref (dispatcher); - - return res; } static void @@ -954,13 +933,21 @@ ft_handler_read_async_cb (GObject *source, } static void -ft_handler_complete_request (EmpathyFTHandler *handler) -{ +find_channel_class_cb (GStrv channel_class, + gpointer user_data) +{ + EmpathyFTHandler *handler = user_data; EmpathyFTHandlerPriv *priv = GET_PRIV (handler); + gboolean allowed = TRUE; GError *myerr = NULL; - /* check if FT is allowed before firing up the I/O machinery */ - if (!ft_handler_check_if_allowed (handler)) + if (!tp_strv_contains ((const gchar * const *) channel_class, + TP_IFACE_CHANNEL ".TargetHandle")) + allowed = FALSE; + + DEBUG ("check if FT allowed: %s", allowed ? "True" : "False"); + + if (!allowed) { g_set_error_literal (&myerr, EMPATHY_FT_ERROR_QUARK, EMPATHY_FT_ERROR_NOT_SUPPORTED, @@ -985,6 +972,20 @@ ft_handler_complete_request (EmpathyFTHandler *handler) } static void +ft_handler_complete_request (EmpathyFTHandler *handler) +{ + EmpathyFTHandlerPriv *priv = GET_PRIV (handler); + TpConnection *connection; + + /* check if FT is allowed before firing up the I/O machinery */ + connection = empathy_contact_get_connection (priv->contact); + + empathy_dispatcher_find_channel_class_async (priv->dispatcher, connection, + TP_IFACE_CHANNEL_TYPE_FILE_TRANSFER, TP_HANDLE_TYPE_CONTACT, + find_channel_class_cb, handler); +} + +static void callbacks_data_free (gpointer user_data) { CallbacksData *data = user_data; |