Add feature to add headers

This commit is contained in:
Bob Polis 2024-03-31 15:58:04 +02:00
parent 47d673e50a
commit a8e216e2a1
3 changed files with 33 additions and 10 deletions

View File

@ -1,7 +1,7 @@
LDLIBS := -lcurl -lsclogging -lscterm LDLIBS := -lcurl -lsclogging -lscterm
MAJOR := 1 MAJOR := 1
MINOR := 1 MINOR := 2
PATCH := 0 PATCH := 0
GENERATELIBHEADER := 1 GENERATELIBHEADER := 1

View File

@ -54,18 +54,20 @@ std::string requester::post(const std::string& url, const std::string& json) {
curl_easy_setopt(_h.get(), CURLOPT_POST, 1L); curl_easy_setopt(_h.get(), CURLOPT_POST, 1L);
curl_easy_setopt(_h.get(), CURLOPT_POSTFIELDS, json.c_str()); curl_easy_setopt(_h.get(), CURLOPT_POSTFIELDS, json.c_str());
curl_easy_setopt(_h.get(), CURLOPT_POSTFIELDSIZE, json.size()); curl_easy_setopt(_h.get(), CURLOPT_POSTFIELDSIZE, json.size());
add_header("Content-Type: application/json");
struct curl_slist* headers {nullptr}; perform_with_headers();
headers = curl_slist_append(headers, "Content-Type: application/json");
std::unique_ptr<struct curl_slist, void(*)(struct curl_slist*)> hdrs {headers, curl_slist_free_all};
curl_easy_setopt(_h.get(), CURLOPT_HTTPHEADER, headers);
perform();
return _text; return _text;
} }
void requester::add_header(const std::string& hdr) {
_headers.push_back(hdr);
}
void requester::perform() { void requester::perform() {
_text = ""; _text = ""; // clear response text
curl_easy_setopt(_h.get(), CURLOPT_WRITEDATA, this); curl_easy_setopt(_h.get(), CURLOPT_WRITEDATA, this); // setup callback user data
// perform request
auto success = curl_easy_perform(_h.get()); auto success = curl_easy_perform(_h.get());
if (success != CURLE_OK) { if (success != CURLE_OK) {
std::ostringstream oss; std::ostringstream oss;
@ -74,6 +76,22 @@ void requester::perform() {
} }
} }
void requester::perform_with_headers() {
if (_headers.size()) {
// setup headers
struct curl_slist* headers {nullptr};
for (const auto& hdr : _headers) {
headers = curl_slist_append(headers, hdr.c_str());
}
curl_easy_setopt(_h.get(), CURLOPT_HTTPHEADER, headers);
std::unique_ptr<struct curl_slist, void(*)(struct curl_slist*)> hdrs {headers, curl_slist_free_all};
_headers.clear(); // start fresh for next request
perform();
} else {
perform();
}
}
void requester::check_status(long status) { void requester::check_status(long status) {
auto success = curl_easy_getinfo(_h.get(), CURLINFO_RESPONSE_CODE, &_status); auto success = curl_easy_getinfo(_h.get(), CURLINFO_RESPONSE_CODE, &_status);
if (success != CURLE_OK || _status != status) { if (success != CURLE_OK || _status != status) {

View File

@ -3,6 +3,7 @@
#include <string> #include <string>
#include <memory> #include <memory>
#include <vector>
#include <curl/curl.h> #include <curl/curl.h>
#include <libsclogging.hpp> #include <libsclogging.hpp>
@ -31,16 +32,20 @@ namespace sc {
// perform a http get request // perform a http get request
std::string get(const std::string& url); std::string get(const std::string& url);
// perform a http post request // perform a http post request with a json payload
std::string post(const std::string& url, const std::string& json); std::string post(const std::string& url, const std::string& json);
void add_header(const std::string& hdr);
private: private:
std::unique_ptr<CURL, void(*)(CURL*)> _h {nullptr, curl_easy_cleanup}; std::unique_ptr<CURL, void(*)(CURL*)> _h {nullptr, curl_easy_cleanup};
sc::logger* _logger {nullptr}; sc::logger* _logger {nullptr};
std::string _text; std::string _text;
long _status; long _status;
std::vector<std::string> _headers;
void perform(); void perform();
void perform_with_headers();
void check_status(long status); void check_status(long status);
}; };