2 * empathy-ft-handler.h - Header for EmpathyFTHandler
3 * Copyright (C) 2009 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 * Author: Cosimo Cecchi <cosimo.cecchi@collabora.co.uk>
22 /* empathy-ft-handler.h */
24 #ifndef __EMPATHY_FT_HANDLER_H__
25 #define __EMPATHY_FT_HANDLER_H__
27 #include <glib-object.h>
30 #include <telepathy-glib/telepathy-glib.h>
32 #include "empathy-contact.h"
36 #define EMPATHY_TYPE_FT_HANDLER empathy_ft_handler_get_type()
37 #define EMPATHY_FT_HANDLER(obj) \
38 (G_TYPE_CHECK_INSTANCE_CAST ((obj), \
39 EMPATHY_TYPE_FT_HANDLER, EmpathyFTHandler))
40 #define EMPATHY_FT_HANDLER_CLASS(klass) \
41 (G_TYPE_CHECK_CLASS_CAST ((klass), \
42 EMPATHY_TYPE_FT_HANDLER, EmpathyFTHandlerClass))
43 #define EMPATHY_IS_FT_HANDLER(obj) \
44 (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EMPATHY_TYPE_FT_HANDLER))
45 #define EMPATHY_IS_FT_HANDLER_CLASS(klass) \
46 (G_TYPE_CHECK_CLASS_TYPE ((klass), EMPATHY_TYPE_FT_HANDLER))
47 #define EMPATHY_FT_HANDLER_GET_CLASS(obj) \
48 (G_TYPE_INSTANCE_GET_CLASS ((obj), \
49 EMPATHY_TYPE_FT_HANDLER, EmpathyFTHandlerClass))
57 GObjectClass parent_class;
58 } EmpathyFTHandlerClass;
60 #define EMPATHY_FT_ERROR_QUARK g_quark_from_static_string ("EmpathyFTError")
63 EMPATHY_FT_ERROR_FAILED,
64 EMPATHY_FT_ERROR_HASH_MISMATCH,
65 EMPATHY_FT_ERROR_TP_ERROR,
66 EMPATHY_FT_ERROR_SOCKET,
67 EMPATHY_FT_ERROR_NOT_SUPPORTED,
68 EMPATHY_FT_ERROR_INVALID_SOURCE_FILE,
69 EMPATHY_FT_ERROR_EMPTY_SOURCE_FILE
73 * EmpathyFTHandlerReadyCallback:
74 * @handler: the handler which is now ready
75 * @error: a #GError if the operation failed, or %NULL
76 * @user_data: user data passed to the callback
78 typedef void (* EmpathyFTHandlerReadyCallback) (EmpathyFTHandler *handler,
82 GType empathy_ft_handler_get_type (void);
85 void empathy_ft_handler_new_outgoing (EmpathyContact *contact,
88 EmpathyFTHandlerReadyCallback callback,
91 void empathy_ft_handler_new_incoming (TpFileTransferChannel *channel,
92 EmpathyFTHandlerReadyCallback callback,
94 void empathy_ft_handler_incoming_set_destination (EmpathyFTHandler *handler,
97 void empathy_ft_handler_start_transfer (EmpathyFTHandler *handler);
98 void empathy_ft_handler_cancel_transfer (EmpathyFTHandler *handler);
100 /* properties of the transfer */
101 const char * empathy_ft_handler_get_filename (EmpathyFTHandler *handler);
102 const char * empathy_ft_handler_get_content_type (EmpathyFTHandler *handler);
103 EmpathyContact * empathy_ft_handler_get_contact (EmpathyFTHandler *handler);
104 GFile * empathy_ft_handler_get_gfile (EmpathyFTHandler *handler);
105 gboolean empathy_ft_handler_get_use_hash (EmpathyFTHandler *handler);
106 gboolean empathy_ft_handler_is_incoming (EmpathyFTHandler *handler);
107 guint64 empathy_ft_handler_get_transferred_bytes (EmpathyFTHandler *handler);
108 guint64 empathy_ft_handler_get_total_bytes (EmpathyFTHandler *handler);
109 gboolean empathy_ft_handler_is_completed (EmpathyFTHandler *handler);
110 gboolean empathy_ft_handler_is_cancelled (EmpathyFTHandler *handler);
114 #endif /* __EMPATHY_FT_HANDLER_H__ */