1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#include "curlresult.h"
#include <QDebug>
CurlResult::CurlResult(void* userData) :
userData(userData),
curlError(CURL_LAST)
{
}
CurlResult::~CurlResult() {
foreach (struct curl_slist* slist, slists) {
curl_slist_free_all(slist);
}
}
size_t CurlResult::write_data(void *buffer, size_t characterSize, size_t bufferSize, void *userp) {
CurlResult* userData = static_cast<CurlResult*>(userp);
if (userData) {
userData->data.write((const char*)buffer, characterSize*bufferSize);
return bufferSize;
}
return 0;
}
CURL* CurlResult::defaultClient() {
CURL* handle = curl_easy_init();
curl_easy_setopt(handle, CURLOPT_TIMEOUT, 15);
curl_easy_setopt(handle, CURLOPT_NOSIGNAL, 1);
// read CA dir/file from env, for guix
static char* caFile = getenv("SSL_CERT_FILE");
if (caFile) {
curl_easy_setopt(handle, CURLOPT_CAINFO, caFile);
}
static char* caDir = getenv("SSL_CERT_DIR");
if (caDir) {
curl_easy_setopt(handle, CURLOPT_CAPATH, caDir);
}
return handle;
}
CURL* CurlResult::curlClient(QString url) {
CURL* handle = defaultClient();
curl_easy_setopt(handle, CURLOPT_URL, url.toUtf8().data());
curl_easy_setopt(handle, CURLOPT_WRITEFUNCTION, CurlResult::write_data);
curl_easy_setopt(handle, CURLOPT_WRITEDATA, this);
return handle;
}
void CurlResult::print() {
qDebug() << data.str().data();
}