7 <<
"ready: " << response->ready << std::endl
8 <<
"response: " << std::endl
9 << response->content << std::endl
10 <<
"error_code: " << response->error_code << std::endl
11 <<
"status_code: " << response->status_code << std::endl
12 <<
"retry_attempt: " << response->retry_attempt << std::endl
13 <<
"----------------------------------------" << std::endl;
25 std::vector<std::string> paths = {
"/delay/3",
"/delay/5",
"/delay/7"};
28 KURLYK_PRINT <<
"Sending multiple GET requests and immediately calling deinit()..." << std::endl;
29 for (
const auto& path : paths) {
39 KURLYK_PRINT <<
"Kurlyk library deinitialized. Waiting to see callback responses..." << std::endl;
A client class for making HTTP requests to a specific host.
void set_connect_timeout(long connect_timeout)
Sets the connection timeout duration.
void set_timeout(long timeout)
Sets the timeout duration for HTTP requests.
void set_user_agent(const std::string &user_agent)
Sets the User-Agent header.
bool get(const std::string &path, const QueryParams &query, const Headers &headers, HttpResponseCallback callback)
Sends a GET request.
void cancel_requests()
Cancels the active request associated with this client and waits for its completion.
void print_response(const kurlyk::HttpResponsePtr &response)
Main header file for the Kurlyk library, providing HTTP and WebSocket support.
void init(const bool use_async=true)
Initializes the Kurlyk library, setting up necessary managers and the network worker.
std::unique_ptr< HttpResponse > HttpResponsePtr
A unique pointer to an HttpResponse object for memory management.
void deinit()
Deinitializes the Kurlyk library, stopping the network worker and releasing resources.
utils::CaseInsensitiveMultimap Headers
Alias for HTTP headers, providing a case-insensitive unordered multimap.
utils::CaseInsensitiveMultimap QueryParams
Alias for query parameters in HTTP requests, stored case-insensitively.