buddy: remove http_conn
[siplcs.git] / src / core / sipe-http.h
blobd0924200dd6dc5ca25445d1a179801c90bbf6d07
1 /**
2 * @file sipe-http.h
4 * pidgin-sipe
6 * Copyright (C) 2013 SIPE Project <http://sipe.sourceforge.net/>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
24 /* Public interface to HTTP request service */
27 * Interface dependencies:
29 * <glib.h>
32 /* Forward declarations */
33 struct sipe_core_private;
34 struct sipe_http_request;
35 struct sipe_http_session;
37 /**
38 * HTTP response callback
40 * @param sipe_private SIPE core private data
41 * @param status status code
42 * @param headers response headers (@c NULL if request aborted)
43 * @param body response body (@c NULL if request aborted)
44 * @param callback_data callback data
46 typedef void (sipe_http_response_callback)(struct sipe_core_private *sipe_private,
47 guint status,
48 GSList *headers,
49 const gchar *body,
50 gpointer callback_data);
52 /* HTTP status codes */
53 #define SIPE_HTTP_STATUS_OK 200
55 /**
56 * Free HTTP data
58 * @param sipe_private SIPE core private data
60 void sipe_http_free(struct sipe_core_private *sipe_private);
62 /**
63 * Start HTTP session
65 * @return pointer to opaque HTTP session data structure
67 struct sipe_http_session *sipe_http_session_start(void);
69 /**
70 * Close HTTP session
72 * @param session pointer to opaque HTTP session data structure
74 void sipe_http_session_close(struct sipe_http_session *session);
76 /**
77 * Create HTTP GET request
79 * @param sipe_private SIPE core private data
80 * @param uri URI
81 * @param headers additional headers (may be @c NULL)
83 * @return pointer to opaque HTTP request data structure (@c NULL if failed)
85 struct sipe_http_request *sipe_http_request_get(struct sipe_core_private *sipe_private,
86 const gchar *uri,
87 const gchar *headers,
88 sipe_http_response_callback *callback,
89 gpointer callback_data);
91 /**
92 * Create HTTP POST request
94 * @param sipe_private SIPE core private data
95 * @param uri URI
96 * @param headers additional headers (may be @c NULL)
97 * @param body body contents
98 * @param content_type body content type
100 * @return pointer to opaque HTTP request data structure (@c NULL if failed)
102 struct sipe_http_request *sipe_http_request_post(struct sipe_core_private *sipe_private,
103 const gchar *uri,
104 const gchar *headers,
105 const gchar *body,
106 const gchar *content_type,
107 sipe_http_response_callback *callback,
108 gpointer callback_data);
111 * Cancel pending HTTP request
113 * @param pointer to opaque HTTP request data structure
115 void sipe_http_request_cancel(struct sipe_http_request *request);
118 * Assign request to HTTP session
120 * @param request pointer to opaque HTTP request data structure
121 * @param session pointer to opaque HTTP session data structure
123 void sipe_http_request_session(struct sipe_http_request *request,
124 struct sipe_http_session *session);