aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmessage/llhttpclient.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llmessage/llhttpclient.cpp')
-rw-r--r--linden/indra/llmessage/llhttpclient.cpp40
1 files changed, 37 insertions, 3 deletions
diff --git a/linden/indra/llmessage/llhttpclient.cpp b/linden/indra/llmessage/llhttpclient.cpp
index 392dfd0..e36503a 100644
--- a/linden/indra/llmessage/llhttpclient.cpp
+++ b/linden/indra/llmessage/llhttpclient.cpp
@@ -252,6 +252,7 @@ static void request(
252 LLURLRequest::ERequestAction method, 252 LLURLRequest::ERequestAction method,
253 Injector* body_injector, 253 Injector* body_injector,
254 LLHTTPClient::ResponderPtr responder, 254 LLHTTPClient::ResponderPtr responder,
255 const LLSD& headers,
255 const F32 timeout=HTTP_REQUEST_EXPIRY_SECS) 256 const F32 timeout=HTTP_REQUEST_EXPIRY_SECS)
256{ 257{
257 if (!LLHTTPClient::hasPump()) 258 if (!LLHTTPClient::hasPump())
@@ -263,6 +264,19 @@ static void request(
263 264
264 LLURLRequest *req = new LLURLRequest(method, url); 265 LLURLRequest *req = new LLURLRequest(method, url);
265 req->requestEncoding(""); 266 req->requestEncoding("");
267
268 if (headers.isMap())
269 {
270 LLSD::map_const_iterator iter = headers.beginMap();
271 LLSD::map_const_iterator end = headers.endMap();
272
273 for (; iter != end; ++iter)
274 {
275 std::ostringstream header;
276 header << iter->first << ": " << iter->second.asString() ;
277 req->addHeader(header.str().c_str());
278 }
279 }
266 if (!gCABundle.empty()) 280 if (!gCABundle.empty())
267 { 281 {
268 req->checkRootCertificate(true, gCABundle.c_str()); 282 req->checkRootCertificate(true, gCABundle.c_str());
@@ -287,17 +301,37 @@ static void request(
287 theClientPump->addChain(chain, timeout); 301 theClientPump->addChain(chain, timeout);
288} 302}
289 303
304static void request(
305 const std::string& url,
306 LLURLRequest::ERequestAction method,
307 Injector* body_injector,
308 LLHTTPClient::ResponderPtr responder,
309 const F32 timeout=HTTP_REQUEST_EXPIRY_SECS)
310{
311 request(url, method, body_injector, responder, LLSD(), timeout);
312}
313
314void LLHTTPClient::get(const std::string& url, ResponderPtr responder, const LLSD& headers, const F32 timeout)
315{
316 request(url, LLURLRequest::HTTP_GET, NULL, responder, headers, timeout);
317}
318
290void LLHTTPClient::get(const std::string& url, ResponderPtr responder, const F32 timeout) 319void LLHTTPClient::get(const std::string& url, ResponderPtr responder, const F32 timeout)
291{ 320{
292 request(url, LLURLRequest::HTTP_GET, NULL, responder, timeout); 321 get(url, responder, LLSD(), timeout);
293} 322}
294 323
295void LLHTTPClient::get(const std::string& url, const LLSD& query, ResponderPtr responder, const F32 timeout) 324void LLHTTPClient::get(const std::string& url, const LLSD& query, ResponderPtr responder, const LLSD& headers, const F32 timeout)
296{ 325{
297 LLURI uri; 326 LLURI uri;
298 327
299 uri = LLURI::buildHTTP(url, LLSD::emptyArray(), query); 328 uri = LLURI::buildHTTP(url, LLSD::emptyArray(), query);
300 get(uri.asString(), responder, timeout); 329 get(uri.asString(), responder, headers, timeout);
330}
331
332void LLHTTPClient::get(const std::string& url, const LLSD& query, ResponderPtr responder, const F32 timeout)
333{
334 get(url, query, responder, LLSD(), timeout);
301} 335}
302 336
303// A simple class for managing data returned from a curl http request. 337// A simple class for managing data returned from a curl http request.