1 /* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
3 * Copyright (C) 2007-2008 Collabora Ltd.
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2.1 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 * Authors: Xavier Claessens <xclaesse@gmail.com>
22 #ifndef __EMPATHY_DISPATCHER_H__
23 #define __EMPATHY_DISPATCHER_H__
28 #include <telepathy-glib/channel.h>
30 #include "empathy-contact.h"
31 #include "empathy-handler.h"
32 #include "empathy-dispatch-operation.h"
36 #define EMPATHY_TYPE_DISPATCHER (empathy_dispatcher_get_type ())
37 #define EMPATHY_DISPATCHER(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), EMPATHY_TYPE_DISPATCHER, EmpathyDispatcher))
38 #define EMPATHY_DISPATCHER_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), EMPATHY_TYPE_DISPATCHER, EmpathyDispatcherClass))
39 #define EMPATHY_IS_DISPATCHER(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), EMPATHY_TYPE_DISPATCHER))
40 #define EMPATHY_IS_DISPATCHER_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), EMPATHY_TYPE_DISPATCHER))
41 #define EMPATHY_DISPATCHER_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), EMPATHY_TYPE_DISPATCHER, EmpathyDispatcherClass))
43 #define EMPATHY_DISPATCHER_NON_USER_ACTION (G_GINT64_CONSTANT (0))
45 typedef struct _EmpathyDispatcher EmpathyDispatcher;
46 typedef struct _EmpathyDispatcherClass EmpathyDispatcherClass;
48 struct _EmpathyDispatcher
54 struct _EmpathyDispatcherClass
56 GObjectClass parent_class;
59 /* Will be called when the channel is ready for dispatching. The requestor
60 * handle the channel itself by calling empathy_dispatch_operation_handles */
61 typedef void (EmpathyDispatcherRequestCb) (
62 EmpathyDispatchOperation *dispatch, const GError *error,
64 typedef void (EmpathyDispatcherFindChannelClassCb) (
65 GList *channel_classes, gpointer user_data);
67 GType empathy_dispatcher_get_type (void) G_GNUC_CONST;
69 void empathy_dispatcher_create_channel (EmpathyDispatcher *dispatcher,
70 TpConnection *connection,
73 EmpathyDispatcherRequestCb *callback,
76 /* Requesting 1 to 1 text channels */
77 void empathy_dispatcher_chat_with_contact_id (TpConnection *connection,
78 const gchar *contact_id,
80 EmpathyDispatcherRequestCb *callback,
82 void empathy_dispatcher_chat_with_contact (EmpathyContact *contact,
84 EmpathyDispatcherRequestCb *callback,
87 /* Request a file channel to a specific contact */
88 void empathy_dispatcher_send_file_to_contact (EmpathyContact *contact,
89 const gchar *filename, guint64 size, guint64 date,
90 const gchar *content_type, EmpathyDispatcherRequestCb *callback,
93 /* Request a muc channel */
94 void empathy_dispatcher_join_muc (TpConnection *connection,
95 const gchar *roomname,
97 EmpathyDispatcherRequestCb *callback,
100 void empathy_dispatcher_find_requestable_channel_classes_async
101 (EmpathyDispatcher *dispatcher, TpConnection *connection,
102 const gchar *channel_type, guint handle_type,
103 EmpathyDispatcherFindChannelClassCb callback, gpointer user_data,
104 const char *first_property_name, ...);
106 GList * empathy_dispatcher_find_requestable_channel_classes
107 (EmpathyDispatcher *dispatcher, TpConnection *connection,
108 const gchar *channel_type, guint handle_type,
109 const char *first_property_name, ...);
111 /* Create the dispatcher singleton */
112 EmpathyDispatcher * empathy_dispatcher_new (const gchar *name,
117 empathy_dispatcher_add_handler (EmpathyDispatcher *dispatcher,
123 empathy_dispatcher_remove_handler (EmpathyDispatcher *dispatcher,
124 EmpathyHandler *handler);
126 /* Get the dispatcher singleton */
127 EmpathyDispatcher * empathy_dispatcher_dup_singleton (void);
131 #endif /* __EMPATHY_DISPATCHER_H__ */