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>
29 #include <telepathy-glib/telepathy-glib.h>
31 #include "empathy-contact.h"
35 #define EMPATHY_TYPE_FT_HANDLER empathy_ft_handler_get_type()
36 #define EMPATHY_FT_HANDLER(obj) \
37 (G_TYPE_CHECK_INSTANCE_CAST ((obj), \
38 EMPATHY_TYPE_FT_HANDLER, EmpathyFTHandler))
39 #define EMPATHY_FT_HANDLER_CLASS(klass) \
40 (G_TYPE_CHECK_CLASS_CAST ((klass), \
41 EMPATHY_TYPE_FT_HANDLER, EmpathyFTHandlerClass))
42 #define EMPATHY_IS_FT_HANDLER(obj) \
43 (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EMPATHY_TYPE_FT_HANDLER))
44 #define EMPATHY_IS_FT_HANDLER_CLASS(klass) \
45 (G_TYPE_CHECK_CLASS_TYPE ((klass), EMPATHY_TYPE_FT_HANDLER))
46 #define EMPATHY_FT_HANDLER_GET_CLASS(obj) \
47 (G_TYPE_INSTANCE_GET_CLASS ((obj), \
48 EMPATHY_TYPE_FT_HANDLER, EmpathyFTHandlerClass))
56 GObjectClass parent_class
;
57 } EmpathyFTHandlerClass
;
59 #define EMPATHY_FT_ERROR_QUARK g_quark_from_static_string ("EmpathyFTError")
62 EMPATHY_FT_ERROR_FAILED
,
63 EMPATHY_FT_ERROR_HASH_MISMATCH
,
64 EMPATHY_FT_ERROR_TP_ERROR
,
65 EMPATHY_FT_ERROR_SOCKET
,
66 EMPATHY_FT_ERROR_NOT_SUPPORTED
,
67 EMPATHY_FT_ERROR_INVALID_SOURCE_FILE
,
68 EMPATHY_FT_ERROR_EMPTY_SOURCE_FILE
72 * EmpathyFTHandlerReadyCallback:
73 * @handler: the handler which is now ready
74 * @error: a #GError if the operation failed, or %NULL
75 * @user_data: user data passed to the callback
77 typedef void (* EmpathyFTHandlerReadyCallback
) (EmpathyFTHandler
*handler
,
81 GType
empathy_ft_handler_get_type (void);
84 void empathy_ft_handler_new_outgoing (EmpathyContact
*contact
,
87 EmpathyFTHandlerReadyCallback callback
,
90 void empathy_ft_handler_new_incoming (TpFileTransferChannel
*channel
,
91 EmpathyFTHandlerReadyCallback callback
,
93 void empathy_ft_handler_incoming_set_destination (EmpathyFTHandler
*handler
,
96 void empathy_ft_handler_start_transfer (EmpathyFTHandler
*handler
);
97 void empathy_ft_handler_cancel_transfer (EmpathyFTHandler
*handler
);
99 /* properties of the transfer */
100 const char * empathy_ft_handler_get_filename (EmpathyFTHandler
*handler
);
101 const char * empathy_ft_handler_get_content_type (EmpathyFTHandler
*handler
);
102 EmpathyContact
* empathy_ft_handler_get_contact (EmpathyFTHandler
*handler
);
103 GFile
* empathy_ft_handler_get_gfile (EmpathyFTHandler
*handler
);
104 gboolean
empathy_ft_handler_get_use_hash (EmpathyFTHandler
*handler
);
105 gboolean
empathy_ft_handler_is_incoming (EmpathyFTHandler
*handler
);
106 guint64
empathy_ft_handler_get_transferred_bytes (EmpathyFTHandler
*handler
);
107 guint64
empathy_ft_handler_get_total_bytes (EmpathyFTHandler
*handler
);
108 gboolean
empathy_ft_handler_is_completed (EmpathyFTHandler
*handler
);
109 gboolean
empathy_ft_handler_is_cancelled (EmpathyFTHandler
*handler
);
113 #endif /* __EMPATHY_FT_HANDLER_H__ */