security: accept NULL domain for NTLM
[siplcs.git] / src / core / sipe-http.h
blob47f1a9655b062d5c90972a60956f7a017b5497da
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
28 * Interface dependencies:
30 * <glib.h>
33 /* Forward declarations */
34 struct sipe_core_private;
35 struct sipe_http_request;
36 struct sipe_http_session;
38 /**
39 * HTTP response callback
41 * @param sipe_private SIPE core private data
42 * @param status status code
43 * @param headers response headers (@c NULL if request aborted)
44 * @param body response body (@c NULL if request aborted)
45 * @param callback_data callback data
47 typedef void (sipe_http_response_callback)(struct sipe_core_private *sipe_private,
48 guint status,
49 GSList *headers,
50 const gchar *body,
51 gpointer callback_data);
53 /* HTTP response status codes */
54 #define SIPE_HTTP_STATUS_OK 200
55 #define SIPE_HTTP_STATUS_REDIRECTION 300 /* - 399 */
56 #define SIPE_HTTP_STATUS_CLIENT_ERROR 400 /* - 499 */
57 #define SIPE_HTTP_STATUS_CLIENT_UNAUTHORIZED 401
58 #define SIPE_HTTP_STATUS_CLIENT_FORBIDDEN 403
60 /**
61 * Free HTTP data
63 * @param sipe_private SIPE core private data
65 void sipe_http_free(struct sipe_core_private *sipe_private);
67 /**
68 * Start HTTP session
70 * @return pointer to opaque HTTP session data structure
72 struct sipe_http_session *sipe_http_session_start(void);
74 /**
75 * Close HTTP session
77 * @param session pointer to opaque HTTP session data structure
79 void sipe_http_session_close(struct sipe_http_session *session);
81 /**
82 * Create HTTP GET request
84 * @param sipe_private SIPE core private data
85 * @param uri URI
86 * @param headers additional headers (may be @c NULL)
87 * @param callback callback function
88 * @param callback_data callback data
90 * @return pointer to opaque HTTP request data structure (@c NULL if failed)
92 struct sipe_http_request *sipe_http_request_get(struct sipe_core_private *sipe_private,
93 const gchar *uri,
94 const gchar *headers,
95 sipe_http_response_callback *callback,
96 gpointer callback_data);
98 /**
99 * Create HTTP POST request
101 * @param sipe_private SIPE core private data
102 * @param uri URI
103 * @param headers additional headers (may be @c NULL)
104 * @param body body contents
105 * @param content_type body content type
106 * @param callback callback function
107 * @param callback_data callback data
109 * @return pointer to opaque HTTP request data structure (@c NULL if failed)
111 struct sipe_http_request *sipe_http_request_post(struct sipe_core_private *sipe_private,
112 const gchar *uri,
113 const gchar *headers,
114 const gchar *body,
115 const gchar *content_type,
116 sipe_http_response_callback *callback,
117 gpointer callback_data);
120 * HTTP request is ready to be sent
122 * @param request pointer to opaque HTTP request data structure
124 void sipe_http_request_ready(struct sipe_http_request *request);
127 * Cancel pending HTTP request
129 * @param request pointer to opaque HTTP request data structure
131 void sipe_http_request_cancel(struct sipe_http_request *request);
134 * Assign request to HTTP session
136 * @param request pointer to opaque HTTP request data structure
137 * @param session pointer to opaque HTTP session data structure
139 void sipe_http_request_session(struct sipe_http_request *request,
140 struct sipe_http_session *session);
143 * Allow redirection of HTTP request
145 * @param request pointer to opaque HTTP request data structure
147 void sipe_http_request_allow_redirect(struct sipe_http_request *request);
150 * Provide authentication information for HTTP request
152 * @param request pointer to opaque HTTP request data structure
153 * @param domain domain name (MUST stay valid for duration of request!)
154 * @param user user name (MUST stay valid for duration of request!)
155 * @param password Password (MUST stay valid for duration of request!)
157 void sipe_http_request_authentication(struct sipe_http_request *request,
158 const gchar *domain,
159 const gchar *user,
160 const gchar *password);