Mercurial > pidgin
comparison src/protocols/msn/httpconn.h @ 10463:9bed28273ec7
[gaim-migrate @ 11737]
Felipe Contreras fixed the MSN HTTP Method. Yay! Thanks Felipe.
committer: Tailor Script <tailor@pidgin.im>
author | Stu Tomlinson <stu@nosnilmot.com> |
---|---|
date | Fri, 31 Dec 2004 16:34:22 +0000 |
parents | |
children | bcfea6c3d5c9 |
comparison
equal
deleted
inserted
replaced
10462:f7b32dd67bdf | 10463:9bed28273ec7 |
---|---|
1 /** | |
2 * @file httpconn.h HTTP connection | |
3 * | |
4 * gaim | |
5 * | |
6 * Gaim is the legal property of its developers, whose names are too numerous | |
7 * to list here. Please refer to the COPYRIGHT file distributed with this | |
8 * source distribution. | |
9 * | |
10 * This program is free software; you can redistribute it and/or modify | |
11 * it under the terms of the GNU General Public License as published by | |
12 * the Free Software Foundation; either version 2 of the License, or | |
13 * (at your option) any later version. | |
14 * | |
15 * This program is distributed in the hope that it will be useful, | |
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
18 * GNU General Public License for more details. | |
19 * | |
20 * You should have received a copy of the GNU General Public License | |
21 * along with this program; if not, write to the Free Software | |
22 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
23 */ | |
24 #ifndef _MSN_HTTPCONN_H_ | |
25 #define _MSN_HTTPCONN_H_ | |
26 | |
27 typedef struct _MsnHttpConn MsnHttpConn; | |
28 | |
29 #include "servconn.h" | |
30 | |
31 struct _MsnHttpConn | |
32 { | |
33 MsnSession *session; | |
34 MsnServConn *servconn; | |
35 | |
36 char *full_session_id; | |
37 char *session_id; | |
38 | |
39 int timer; | |
40 | |
41 gboolean waiting_response; | |
42 gboolean dirty; /**< The flag that states if we should poll. */ | |
43 gboolean connected; | |
44 | |
45 char *host; | |
46 GList *queue; | |
47 | |
48 int fd; | |
49 int inpa; | |
50 | |
51 char *rx_buf; | |
52 int rx_len; | |
53 | |
54 #if 0 | |
55 GQueue *servconn_queue; | |
56 #endif | |
57 | |
58 gboolean virgin; | |
59 }; | |
60 | |
61 MsnHttpConn *msn_httpconn_new(MsnServConn *servconn); | |
62 void msn_httpconn_destroy(MsnHttpConn *httpconn); | |
63 size_t msn_httpconn_write(MsnHttpConn *httpconn, const char *buf, size_t size); | |
64 | |
65 gboolean msn_httpconn_connect(MsnHttpConn *httpconn, | |
66 const char *host, int port); | |
67 void msn_httpconn_disconnect(MsnHttpConn *httpconn); | |
68 | |
69 #if 0 | |
70 void msn_httpconn_queue_servconn(MsnHttpConn *httpconn, MsnServConn *servconn); | |
71 #endif | |
72 | |
73 #if 0 | |
74 /** | |
75 * Initializes the HTTP data for a session. | |
76 * | |
77 * @param session The session. | |
78 */ | |
79 void msn_http_session_init(MsnSession *session); | |
80 | |
81 /** | |
82 * Uninitializes the HTTP data for a session. | |
83 * | |
84 * @param session The session. | |
85 */ | |
86 void msn_http_session_uninit(MsnSession *session); | |
87 | |
88 /** | |
89 * Writes data to the server using the HTTP connection method. | |
90 * | |
91 * @param servconn The server connection. | |
92 * @param buf The data to write. | |
93 * @param size The size of the data to write. | |
94 * @param server_type The optional server type. | |
95 * | |
96 * @return The number of bytes written. | |
97 */ | |
98 size_t msn_http_servconn_write(MsnServConn *servconn, const char *buf, | |
99 size_t size, const char *server_type); | |
100 | |
101 /** | |
102 * Polls the server for data. | |
103 * | |
104 * @param servconn The server connection. | |
105 */ | |
106 void msn_http_servconn_poll(MsnServConn *servconn); | |
107 | |
108 /** | |
109 * Processes an incoming message and returns a string the rest of MSN | |
110 * can deal with. | |
111 * | |
112 * @param servconn The server connection. | |
113 * @param buf The incoming buffer. | |
114 * @param size The incoming size. | |
115 * @param ret_buf The returned buffer. | |
116 * @param ret_len The returned length. | |
117 * @param error TRUE if there was an HTTP error. | |
118 * | |
119 * @return TRUE if the returned buffer is ready to be processed. | |
120 * FALSE otherwise. | |
121 */ | |
122 gboolean msn_http_servconn_parse_data(MsnServConn *servconn, | |
123 const char *buf, size_t size, | |
124 char **ret_buf, size_t *ret_size, | |
125 gboolean *error); | |
126 #endif | |
127 | |
128 #endif /* _MSN_HTTPCONN_H_ */ |