2 * Copyright (C) 2007-2008 Collabora Ltd.
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18 * Authors: Xavier Claessens <xclaesse@gmail.com>
19 * Sjoerd Simons <sjoerd.simons@collabora.co.uk>
25 #include <glib/gi18n.h>
27 #include <telepathy-glib/util.h>
29 #include <libempathy/empathy-dispatcher.h>
30 #include <libempathy/empathy-contact-factory.h>
31 #include <libempathy/empathy-contact-manager.h>
32 #include <libempathy/empathy-tp-chat.h>
33 #include <libempathy/empathy-tp-call.h>
34 #include <libempathy/empathy-utils.h>
35 #include <libempathy/empathy-call-factory.h>
37 #include <extensions/extensions.h>
39 #include <libempathy-gtk/empathy-images.h>
40 #include <libempathy-gtk/empathy-contact-dialogs.h>
41 #include <libempathy-gtk/empathy-ui-utils.h>
43 #include "empathy-event-manager.h"
44 #include "empathy-main-window.h"
45 #include "empathy-tube-dispatch.h"
47 #define DEBUG_FLAG EMPATHY_DEBUG_DISPATCHER
48 #include <libempathy/empathy-debug.h>
50 #define GET_PRIV(obj) EMPATHY_GET_PRIV (obj, EmpathyEventManager)
53 EmpathyEventManager *manager;
54 EmpathyDispatchOperation *operation;
55 gulong approved_handler;
56 gulong claimed_handler;
57 gulong invalidated_handler;
58 /* Remove contact if applicable */
59 EmpathyContact *contact;
60 /* Tube dispatcher if applicable */
61 EmpathyTubeDispatch *tube_dispatch;
62 /* option signal handler */
64 /* optional accept widget */
66 } EventManagerApproval;
69 EmpathyDispatcher *dispatcher;
70 EmpathyContactManager *contact_manager;
72 /* Ongoing approvals */
75 /* voip ringing sound */
78 } EmpathyEventManagerPriv;
80 typedef struct _EventPriv EventPriv;
81 typedef void (*EventFunc) (EventPriv *event);
85 EmpathyEventManager *manager;
86 EventManagerApproval *approval;
99 static guint signals[LAST_SIGNAL];
101 G_DEFINE_TYPE (EmpathyEventManager, empathy_event_manager, G_TYPE_OBJECT);
103 static EmpathyEventManager * manager_singleton = NULL;
105 static EventManagerApproval *
106 event_manager_approval_new (EmpathyEventManager *manager,
107 EmpathyDispatchOperation *operation)
109 EventManagerApproval *result = g_slice_new0 (EventManagerApproval);
110 result->operation = g_object_ref (operation);
111 result->manager = manager;
117 event_manager_approval_free (EventManagerApproval *approval)
119 g_signal_handler_disconnect (approval->operation,
120 approval->approved_handler);
121 g_signal_handler_disconnect (approval->operation,
122 approval->claimed_handler);
123 g_signal_handler_disconnect (approval->operation,
124 approval->invalidated_handler);
125 g_object_unref (approval->operation);
127 if (approval->contact != NULL)
128 g_object_unref (approval->contact);
130 if (approval->tube_dispatch != NULL)
131 g_object_unref (approval->tube_dispatch);
133 if (approval->dialog != NULL)
135 gtk_widget_destroy (approval->dialog);
138 g_slice_free (EventManagerApproval, approval);
141 static void event_remove (EventPriv *event);
144 event_free (EventPriv *event)
146 g_free (event->public.icon_name);
147 g_free (event->public.header);
148 g_free (event->public.message);
150 if (event->public.contact)
152 g_object_unref (event->public.contact);
155 g_slice_free (EventPriv, event);
158 static void event_manager_ringing_finished_cb (ca_context *c, guint id,
159 int error_code, gpointer user_data);
162 event_manager_ringing_timeout_cb (gpointer data)
164 EmpathyEventManager *manager = EMPATHY_EVENT_MANAGER (data);
165 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
167 priv->voip_timeout = 0;
169 empathy_sound_play_full (empathy_main_window_get (),
170 EMPATHY_SOUND_PHONE_INCOMING, event_manager_ringing_finished_cb,
177 event_manager_ringing_idle_cb (gpointer data)
179 EmpathyEventManager *manager = EMPATHY_EVENT_MANAGER (data);
180 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
182 if (priv->ringing > 0)
183 priv->voip_timeout = g_timeout_add (500, event_manager_ringing_timeout_cb,
190 event_manager_ringing_finished_cb (ca_context *c, guint id, int error_code,
193 if (error_code == CA_ERROR_CANCELED)
196 g_idle_add (event_manager_ringing_idle_cb, user_data);
200 event_manager_start_ringing (EmpathyEventManager *manager)
202 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
206 if (priv->ringing == 1)
208 empathy_sound_play_full (empathy_main_window_get (),
209 EMPATHY_SOUND_PHONE_INCOMING, event_manager_ringing_finished_cb,
215 event_manager_stop_ringing (EmpathyEventManager *manager)
217 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
221 if (priv->ringing > 0)
224 empathy_sound_stop (EMPATHY_SOUND_PHONE_INCOMING);
226 if (priv->voip_timeout != 0)
228 g_source_remove (priv->voip_timeout);
229 priv->voip_timeout = 0;
234 event_remove (EventPriv *event)
236 EmpathyEventManagerPriv *priv = GET_PRIV (event->manager);
238 DEBUG ("Removing event %p", event);
239 priv->events = g_slist_remove (priv->events, event);
240 g_signal_emit (event->manager, signals[EVENT_REMOVED], 0, event);
245 event_manager_add (EmpathyEventManager *manager, EmpathyContact *contact,
246 const gchar *icon_name, const gchar *header, const gchar *message,
247 EventManagerApproval *approval, EventFunc func, gpointer user_data)
249 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
252 event = g_slice_new0 (EventPriv);
253 event->public.contact = contact ? g_object_ref (contact) : NULL;
254 event->public.icon_name = g_strdup (icon_name);
255 event->public.header = g_strdup (header);
256 event->public.message = g_strdup (message);
257 event->inhibit = FALSE;
259 event->user_data = user_data;
260 event->manager = manager;
261 event->approval = approval;
263 DEBUG ("Adding event %p", event);
264 priv->events = g_slist_prepend (priv->events, event);
265 g_signal_emit (event->manager, signals[EVENT_ADDED], 0, event);
269 event_channel_process_func (EventPriv *event)
271 empathy_dispatch_operation_approve (event->approval->operation);
275 event_text_channel_process_func (EventPriv *event)
277 EmpathyTpChat *tp_chat;
279 if (event->approval->handler != 0)
281 tp_chat = EMPATHY_TP_CHAT
282 (empathy_dispatch_operation_get_channel_wrapper (event->approval->operation));
284 g_signal_handler_disconnect (tp_chat, event->approval->handler);
285 event->approval->handler = 0;
288 empathy_dispatch_operation_approve (event->approval->operation);
292 event_lookup_by_approval (EmpathyEventManager *manager,
293 EventManagerApproval *approval)
295 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
297 EventPriv *retval = NULL;
299 for (l = priv->events; l; l = l->next)
301 EventPriv *event = l->data;
303 if (event->approval == approval)
314 event_update (EmpathyEventManager *manager, EventPriv *event,
315 const char *icon_name, const char *header, const char *msg)
317 g_free (event->public.icon_name);
318 g_free (event->public.header);
319 g_free (event->public.message);
321 event->public.icon_name = g_strdup (icon_name);
322 event->public.header = g_strdup (header);
323 event->public.message = g_strdup (msg);
325 g_signal_emit (manager, signals[EVENT_UPDATED], 0, event);
329 event_manager_call_window_confirmation_dialog_response_cb (GtkDialog *dialog,
330 gint response, gpointer user_data)
332 EventManagerApproval *approval = user_data;
334 gtk_widget_destroy (approval->dialog);
335 approval->dialog = NULL;
337 if (response != GTK_RESPONSE_ACCEPT)
339 EmpathyTpCall *call =
341 empathy_dispatch_operation_get_channel_wrapper (
342 approval->operation));
345 if (empathy_dispatch_operation_claim (approval->operation))
346 empathy_tp_call_close (call);
347 g_object_unref (call);
352 EmpathyCallFactory *factory = empathy_call_factory_get ();
353 empathy_call_factory_claim_channel (factory, approval->operation);
358 event_channel_process_voip_func (EventPriv *event)
364 if (event->approval->dialog != NULL)
366 gtk_window_present (GTK_WINDOW (event->approval->dialog));
370 dialog = gtk_message_dialog_new (GTK_WINDOW (empathy_main_window_get()),
371 GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT,
372 GTK_MESSAGE_QUESTION, GTK_BUTTONS_NONE, _("Incoming call"));
373 gtk_message_dialog_format_secondary_text (
374 GTK_MESSAGE_DIALOG (dialog),
375 _("%s is calling you, do you want to answer?"),
376 empathy_contact_get_name (event->approval->contact));
378 gtk_dialog_set_default_response (GTK_DIALOG (dialog),
381 button = gtk_dialog_add_button (GTK_DIALOG (dialog),
382 _("_Reject"), GTK_RESPONSE_REJECT);
383 image = gtk_image_new_from_icon_name (GTK_STOCK_CANCEL,
384 GTK_ICON_SIZE_BUTTON);
385 gtk_button_set_image (GTK_BUTTON (button), image);
387 button = gtk_dialog_add_button (GTK_DIALOG (dialog),
388 _("_Answer"), GTK_RESPONSE_ACCEPT);
390 image = gtk_image_new_from_icon_name (GTK_STOCK_APPLY, GTK_ICON_SIZE_BUTTON);
391 gtk_button_set_image (GTK_BUTTON (button), image);
393 g_signal_connect (dialog, "response",
394 G_CALLBACK (event_manager_call_window_confirmation_dialog_response_cb),
397 gtk_widget_show (dialog);
399 event->approval->dialog = dialog;
403 event_manager_chat_message_received_cb (EmpathyTpChat *tp_chat,
404 EmpathyMessage *message, EventManagerApproval *approval)
406 EmpathyContact *sender;
412 /* try to update the event if it's referring to a chat which is already in the
414 event = event_lookup_by_approval (approval->manager, approval);
416 if (event != NULL && event->inhibit && approval->handler != 0)
418 g_signal_handler_disconnect (tp_chat, approval->handler);
419 approval->handler = 0;
423 sender = empathy_message_get_sender (message);
424 header = g_strdup_printf (_("New message from %s"),
425 empathy_contact_get_name (sender));
426 msg = empathy_message_get_body (message);
428 channel = empathy_tp_chat_get_channel (tp_chat);
431 event_update (approval->manager, event, EMPATHY_IMAGE_NEW_MESSAGE, header, msg);
433 event_manager_add (approval->manager, sender, EMPATHY_IMAGE_NEW_MESSAGE, header,
434 msg, approval, event_text_channel_process_func, NULL);
437 empathy_sound_play (empathy_main_window_get (),
438 EMPATHY_SOUND_CONVERSATION_NEW);
442 event_manager_approval_done (EventManagerApproval *approval)
444 EmpathyEventManagerPriv *priv = GET_PRIV (approval->manager);
447 if (approval->operation != NULL)
451 channel_type = empathy_dispatch_operation_get_channel_type_id (
452 approval->operation);
453 if (channel_type == TP_IFACE_QUARK_CHANNEL_TYPE_STREAMED_MEDIA)
455 event_manager_stop_ringing (approval->manager);
459 priv->approvals = g_slist_remove (priv->approvals, approval);
461 for (l = priv->events; l; l = l->next)
463 EventPriv *event = l->data;
465 if (event->approval == approval)
467 event_remove (event);
472 event_manager_approval_free (approval);
476 event_manager_operation_approved_cb (EmpathyDispatchOperation *operation,
477 EventManagerApproval *approval)
479 event_manager_approval_done (approval);
483 event_manager_operation_claimed_cb (EmpathyDispatchOperation *operation,
484 EventManagerApproval *approval)
486 event_manager_approval_done (approval);
490 event_manager_operation_invalidated_cb (EmpathyDispatchOperation *operation,
491 guint domain, gint code, gchar *message,
492 EventManagerApproval *approval)
494 event_manager_approval_done (approval);
498 event_manager_media_channel_got_name_cb (EmpathyContact *contact,
499 const GError *error, gpointer user_data, GObject *object)
501 EventManagerApproval *approval = user_data;
506 /* FIXME just returning assuming the operation will be invalidated as
511 header = g_strdup_printf (_("Incoming call from %s"),
512 empathy_contact_get_name (contact));
514 event_manager_add (approval->manager,
515 approval->contact, EMPATHY_IMAGE_VOIP, header, NULL,
516 approval, event_channel_process_voip_func, NULL);
519 event_manager_start_ringing (approval->manager);
523 event_manager_media_channel_got_contact (EventManagerApproval *approval)
525 empathy_contact_call_when_ready (approval->contact,
526 EMPATHY_CONTACT_READY_NAME, event_manager_media_channel_got_name_cb,
527 approval, NULL, G_OBJECT (approval->manager));
531 event_manager_media_channel_contact_changed_cb (EmpathyTpCall *call,
532 GParamSpec *param, EventManagerApproval *approval)
534 EmpathyContact *contact;
536 g_object_get (G_OBJECT (call), "contact", &contact, NULL);
541 approval->contact = contact;
542 event_manager_media_channel_got_contact (approval);
546 event_manager_tube_approved_cb (EventPriv *event)
548 empathy_tube_dispatch_handle (event->approval->tube_dispatch);
552 event_manager_add_tube_approval (EventManagerApproval *approval,
553 EmpathyTubeDispatchAbility ability)
555 const gchar *icon_name;
559 header = g_strdup_printf (_("%s is offering you an invitation"),
560 empathy_contact_get_name (approval->contact));
562 if (ability == EMPATHY_TUBE_DISPATCHABILITY_POSSIBLE)
564 icon_name = GTK_STOCK_EXECUTE;
565 msg = _("An external application will be started to handle it.");
569 icon_name = GTK_STOCK_DIALOG_ERROR;
570 msg = _("You don't have the needed external "
571 "application to handle it.");
574 event_manager_add (approval->manager, approval->contact, icon_name, header,
575 msg, approval, event_manager_tube_approved_cb, approval);
578 /* FIXME better sound for incoming tubes ? */
579 empathy_sound_play (empathy_main_window_get (),
580 EMPATHY_SOUND_CONVERSATION_NEW);
584 event_manager_tube_dispatch_ability_cb (GObject *object,
585 GParamSpec *spec, gpointer user_data)
587 EventManagerApproval *approval = (EventManagerApproval *)user_data;
588 EmpathyTubeDispatchAbility dispatchability;
591 empathy_tube_dispatch_is_dispatchable (approval->tube_dispatch);
593 if (dispatchability != EMPATHY_TUBE_DISPATCHABILITY_UNKNOWN)
595 event_manager_add_tube_approval (approval, dispatchability);
596 g_signal_handler_disconnect (object, approval->handler);
597 approval->handler = 0;
602 event_manager_tube_got_contact_name_cb (EmpathyContact *contact,
603 const GError *error, gpointer user_data, GObject *object)
605 EventManagerApproval *approval = (EventManagerApproval *)user_data;
606 EmpathyTubeDispatchAbility dispatchability;
610 /* FIXME?, we assume that the operation gets invalidated as well (if it
615 dispatchability = empathy_tube_dispatch_is_dispatchable
616 (approval->tube_dispatch);
619 switch (dispatchability)
621 case EMPATHY_TUBE_DISPATCHABILITY_UNKNOWN:
622 approval->handler = g_signal_connect (approval->tube_dispatch,
623 "notify::dispatchability",
624 G_CALLBACK (event_manager_tube_dispatch_ability_cb), approval);
626 case EMPATHY_TUBE_DISPATCHABILITY_POSSIBLE:
628 case EMPATHY_TUBE_DISPATCHABILITY_IMPOSSIBLE:
629 event_manager_add_tube_approval (approval, dispatchability);
635 event_manager_approve_channel_cb (EmpathyDispatcher *dispatcher,
636 EmpathyDispatchOperation *operation, EmpathyEventManager *manager)
638 const gchar *channel_type;
639 EventManagerApproval *approval;
640 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
642 channel_type = empathy_dispatch_operation_get_channel_type (operation);
644 approval = event_manager_approval_new (manager, operation);
645 priv->approvals = g_slist_prepend (priv->approvals, approval);
647 approval->approved_handler = g_signal_connect (operation, "approved",
648 G_CALLBACK (event_manager_operation_approved_cb), approval);
650 approval->claimed_handler = g_signal_connect (operation, "claimed",
651 G_CALLBACK (event_manager_operation_claimed_cb), approval);
653 approval->invalidated_handler = g_signal_connect (operation, "invalidated",
654 G_CALLBACK (event_manager_operation_invalidated_cb), approval);
656 if (!tp_strdiff (channel_type, TP_IFACE_CHANNEL_TYPE_TEXT))
658 EmpathyTpChat *tp_chat =
660 empathy_dispatch_operation_get_channel_wrapper (operation));
662 approval->handler = g_signal_connect (tp_chat, "message-received",
663 G_CALLBACK (event_manager_chat_message_received_cb), approval);
666 else if (!tp_strdiff (channel_type, TP_IFACE_CHANNEL_TYPE_STREAMED_MEDIA))
668 EmpathyContact *contact;
669 EmpathyTpCall *call = EMPATHY_TP_CALL (
670 empathy_dispatch_operation_get_channel_wrapper (operation));
672 g_object_get (G_OBJECT (call), "contact", &contact, NULL);
676 g_signal_connect (call, "notify::contact",
677 G_CALLBACK (event_manager_media_channel_contact_changed_cb),
682 approval->contact = contact;
683 event_manager_media_channel_got_contact (approval);
687 else if (!tp_strdiff (channel_type, EMP_IFACE_CHANNEL_TYPE_FILE_TRANSFER))
689 EmpathyContact *contact;
693 EmpathyContactFactory *factory;
694 TpChannel *channel = empathy_dispatch_operation_get_channel (operation);
696 factory = empathy_contact_factory_dup_singleton ();
697 handle = tp_channel_get_handle (channel, NULL);
698 account = empathy_channel_get_account (channel);
700 contact = empathy_contact_factory_get_from_handle (factory, account,
703 empathy_contact_run_until_ready (contact,
704 EMPATHY_CONTACT_READY_NAME, NULL);
706 header = g_strdup_printf (_("Incoming file transfer from %s"),
707 empathy_contact_get_name (contact));
709 event_manager_add (manager, contact, EMPATHY_IMAGE_DOCUMENT_SEND,
710 header, NULL, approval, event_channel_process_func, NULL);
712 /* FIXME better sound for incoming file transfers ?*/
713 empathy_sound_play (empathy_main_window_get (),
714 EMPATHY_SOUND_CONVERSATION_NEW);
716 g_object_unref (factory);
717 g_object_unref (account);
720 else if (!tp_strdiff (channel_type, EMP_IFACE_CHANNEL_TYPE_STREAM_TUBE) ||
721 !tp_strdiff (channel_type, EMP_IFACE_CHANNEL_TYPE_DBUS_TUBE))
723 EmpathyContact *contact;
725 TpHandleType handle_type;
727 EmpathyContactFactory *factory;
728 EmpathyTubeDispatch *tube_dispatch;
731 channel = empathy_dispatch_operation_get_channel (operation);
733 handle = tp_channel_get_handle (channel, &handle_type);
735 /* Only understand p2p tubes */
736 if (handle_type != TP_HANDLE_TYPE_CONTACT)
739 factory = empathy_contact_factory_dup_singleton ();
740 account = empathy_channel_get_account (channel);
742 contact = empathy_contact_factory_get_from_handle (factory, account,
745 tube_dispatch = empathy_tube_dispatch_new (operation);
747 approval->contact = contact;
748 approval->tube_dispatch = tube_dispatch;
750 empathy_contact_call_when_ready (contact,
751 EMPATHY_CONTACT_READY_NAME, event_manager_tube_got_contact_name_cb,
752 approval, NULL, G_OBJECT (manager));
754 g_object_unref (factory);
755 g_object_unref (account);
759 DEBUG ("Unknown channel type, ignoring..");
764 event_pending_subscribe_func (EventPriv *event)
766 empathy_subscription_dialog_show (event->public.contact, NULL);
767 event_remove (event);
771 event_manager_pendings_changed_cb (EmpathyContactList *list,
772 EmpathyContact *contact, EmpathyContact *actor,
773 guint reason, gchar *message, gboolean is_pending,
774 EmpathyEventManager *manager)
776 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
777 gchar *header, *event_msg;
783 for (l = priv->events; l; l = l->next)
785 EventPriv *event = l->data;
787 if (event->public.contact == contact &&
788 event->func == event_pending_subscribe_func)
790 event_remove (event);
798 empathy_contact_run_until_ready (contact, EMPATHY_CONTACT_READY_NAME, NULL);
800 header = g_strdup_printf (_("Subscription requested by %s"),
801 empathy_contact_get_name (contact));
803 if (!EMP_STR_EMPTY (message))
804 event_msg = g_strdup_printf (_("\nMessage: %s"), message);
808 event_manager_add (manager, contact, GTK_STOCK_DIALOG_QUESTION, header,
809 event_msg, NULL, event_pending_subscribe_func, NULL);
816 event_manager_constructor (GType type,
818 GObjectConstructParam *props)
822 if (manager_singleton) {
823 retval = g_object_ref (manager_singleton);
825 retval = G_OBJECT_CLASS (empathy_event_manager_parent_class)->constructor
826 (type, n_props, props);
828 manager_singleton = EMPATHY_EVENT_MANAGER (retval);
829 g_object_add_weak_pointer (retval, (gpointer) &manager_singleton);
836 event_manager_finalize (GObject *object)
838 EmpathyEventManagerPriv *priv = GET_PRIV (object);
840 g_slist_foreach (priv->events, (GFunc) event_free, NULL);
841 g_slist_free (priv->events);
842 g_slist_foreach (priv->approvals, (GFunc) event_manager_approval_free, NULL);
843 g_slist_free (priv->approvals);
844 g_object_unref (priv->contact_manager);
845 g_object_unref (priv->dispatcher);
849 empathy_event_manager_class_init (EmpathyEventManagerClass *klass)
851 GObjectClass *object_class = G_OBJECT_CLASS (klass);
853 object_class->finalize = event_manager_finalize;
854 object_class->constructor = event_manager_constructor;
856 signals[EVENT_ADDED] =
857 g_signal_new ("event-added",
858 G_TYPE_FROM_CLASS (klass),
862 g_cclosure_marshal_VOID__POINTER,
866 signals[EVENT_REMOVED] =
867 g_signal_new ("event-removed",
868 G_TYPE_FROM_CLASS (klass),
872 g_cclosure_marshal_VOID__POINTER,
873 G_TYPE_NONE, 1, G_TYPE_POINTER);
875 signals[EVENT_UPDATED] =
876 g_signal_new ("event-updated",
877 G_TYPE_FROM_CLASS (klass),
881 g_cclosure_marshal_VOID__POINTER,
882 G_TYPE_NONE, 1, G_TYPE_POINTER);
885 g_type_class_add_private (object_class, sizeof (EmpathyEventManagerPriv));
889 empathy_event_manager_init (EmpathyEventManager *manager)
891 EmpathyEventManagerPriv *priv = G_TYPE_INSTANCE_GET_PRIVATE (manager,
892 EMPATHY_TYPE_EVENT_MANAGER, EmpathyEventManagerPriv);
894 manager->priv = priv;
896 priv->dispatcher = empathy_dispatcher_dup_singleton ();
897 priv->contact_manager = empathy_contact_manager_dup_singleton ();
898 g_signal_connect (priv->dispatcher, "approve",
899 G_CALLBACK (event_manager_approve_channel_cb), manager);
900 g_signal_connect (priv->contact_manager, "pendings-changed",
901 G_CALLBACK (event_manager_pendings_changed_cb), manager);
904 EmpathyEventManager *
905 empathy_event_manager_dup_singleton (void)
907 return g_object_new (EMPATHY_TYPE_EVENT_MANAGER, NULL);
911 empathy_event_manager_get_events (EmpathyEventManager *manager)
913 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
915 g_return_val_if_fail (EMPATHY_IS_EVENT_MANAGER (manager), NULL);
921 empathy_event_manager_get_top_event (EmpathyEventManager *manager)
923 EmpathyEventManagerPriv *priv = GET_PRIV (manager);
925 g_return_val_if_fail (EMPATHY_IS_EVENT_MANAGER (manager), NULL);
927 return priv->events ? priv->events->data : NULL;
931 empathy_event_activate (EmpathyEvent *event_public)
933 EventPriv *event = (EventPriv*) event_public;
935 g_return_if_fail (event_public != NULL);
940 event_remove (event);
944 empathy_event_inhibit_updates (EmpathyEvent *event_public)
946 EventPriv *event = (EventPriv *) event_public;
948 g_return_if_fail (event_public != NULL);
950 event->inhibit = TRUE;