aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmessage/llcurl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llmessage/llcurl.cpp')
-rw-r--r--linden/indra/llmessage/llcurl.cpp60
1 files changed, 27 insertions, 33 deletions
diff --git a/linden/indra/llmessage/llcurl.cpp b/linden/indra/llmessage/llcurl.cpp
index f03cebc..834ec4b 100644
--- a/linden/indra/llmessage/llcurl.cpp
+++ b/linden/indra/llmessage/llcurl.cpp
@@ -101,6 +101,12 @@ void LLCurl::setCAFile(const std::string& file)
101 sCAFile = file; 101 sCAFile = file;
102} 102}
103 103
104//static
105std::string LLCurl::getVersionString()
106{
107 return std::string(curl_version());
108}
109
104////////////////////////////////////////////////////////////////////////////// 110//////////////////////////////////////////////////////////////////////////////
105 111
106LLCurl::Responder::Responder() 112LLCurl::Responder::Responder()
@@ -113,6 +119,15 @@ LLCurl::Responder::~Responder()
113} 119}
114 120
115// virtual 121// virtual
122void LLCurl::Responder::error(
123 U32 status,
124 const std::string& reason,
125 const LLSD&)
126{
127 error(status, reason);
128}
129
130// virtual
116void LLCurl::Responder::error(U32 status, const std::string& reason) 131void LLCurl::Responder::error(U32 status, const std::string& reason)
117{ 132{
118 llinfos << status << ": " << reason << llendl; 133 llinfos << status << ": " << reason << llendl;
@@ -124,38 +139,16 @@ void LLCurl::Responder::result(const LLSD& content)
124} 139}
125 140
126// virtual 141// virtual
127void LLCurl::Responder::completedRaw(U32 status, const std::string& reason, 142void LLCurl::Responder::completedRaw(
128 const LLChannelDescriptors& channels, 143 U32 status,
129 const LLIOPipe::buffer_ptr_t& buffer) 144 const std::string& reason,
145 const LLChannelDescriptors& channels,
146 const LLIOPipe::buffer_ptr_t& buffer)
130{ 147{
131 if (isGoodStatus(status)) 148 LLSD content;
132 { 149 LLBufferStream istr(channels, buffer.get());
133 LLSD content; 150 LLSDSerialize::fromXML(content, istr);
134 LLBufferStream istr(channels, buffer.get()); 151 completed(status, reason, content);
135 LLSDSerialize::fromXML(content, istr);
136/*
137 const S32 parseError = -1;
138 if(LLSDSerialize::fromXML(content, istr) == parseError)
139 {
140 mStatus = 498;
141 mReason = "Client Parse Error";
142 }
143*/
144 completed(status, reason, content);
145 }
146 else if (status == 400)
147 {
148 // Get reason from buffer
149 char tbuf[4096];
150 S32 len = 4096;
151 buffer->readAfter(channels.in(), NULL, (U8*)tbuf, len);
152 tbuf[len] = 0;
153 completed(status, std::string(tbuf), LLSD());
154 }
155 else
156 {
157 completed(status, reason, LLSD());
158 }
159} 152}
160 153
161// virtual 154// virtual
@@ -167,7 +160,7 @@ void LLCurl::Responder::completed(U32 status, const std::string& reason, const L
167 } 160 }
168 else 161 else
169 { 162 {
170 error(status, reason); 163 error(status, reason, content);
171 } 164 }
172} 165}
173 166
@@ -281,7 +274,7 @@ LLCurl::Easy::~Easy()
281 curl_easy_cleanup(mCurlEasyHandle); 274 curl_easy_cleanup(mCurlEasyHandle);
282 --gCurlEasyCount; 275 --gCurlEasyCount;
283 curl_slist_free_all(mHeaders); 276 curl_slist_free_all(mHeaders);
284 for_each(mStrings.begin(), mStrings.end(), DeletePointer()); 277 for_each(mStrings.begin(), mStrings.end(), DeletePointerArray());
285} 278}
286 279
287void LLCurl::Easy::resetState() 280void LLCurl::Easy::resetState()
@@ -882,6 +875,7 @@ void LLCurlEasyRequest::sendRequest(const std::string& url)
882{ 875{
883 llassert_always(!mRequestSent); 876 llassert_always(!mRequestSent);
884 mRequestSent = true; 877 mRequestSent = true;
878 lldebugs << url << llendl;
885 if (mEasy) 879 if (mEasy)
886 { 880 {
887 mEasy->setHeaders(); 881 mEasy->setHeaders();