#ifndef WEBCC_HTTP_CLIENT_H_ #define WEBCC_HTTP_CLIENT_H_ #include #include #include #include #include "boost/asio/deadline_timer.hpp" #include "boost/asio/io_context.hpp" #include "boost/asio/ip/tcp.hpp" #include "webcc/globals.h" #include "webcc/http_request.h" #include "webcc/http_response.h" #include "webcc/http_response_parser.h" #include "webcc/http_socket.h" namespace webcc { class HttpSocketBase; // The base class of synchronous HTTP clients. // In synchronous mode, a request won't return until the response is received // or timeout occurs. // Please don't use the same client object in multiple threads. class HttpClient { public: // The |buffer_size| is the bytes of the buffer for reading response. // 0 means default value (e.g., 1024) will be used. explicit HttpClient(std::size_t buffer_size = 0, bool ssl_verify = true); virtual ~HttpClient() = default; HttpClient(const HttpClient&) = delete; HttpClient& operator=(const HttpClient&) = delete; // Set the timeout seconds for reading response. // The |seconds| is only effective when greater than 0. void SetTimeout(int seconds); // Connect to server, send request, wait until response is received. // Set |buffer_size| to non-zero to use a different buffer size for this // specific request. bool Request(const HttpRequest& request, std::size_t buffer_size = 0, bool connect = true); HttpResponsePtr response() const { return response_; } int response_status() const { assert(response_); return response_->status(); } const std::string& response_content() const { assert(response_); return response_->content(); } bool timed_out() const { return timed_out_; } Error error() const { return error_; } public: Error Connect(const HttpRequest& request); Error DoConnect(const HttpRequest& request, const std::string& default_port); Error WriteReqeust(const HttpRequest& request); Error ReadResponse(); void DoReadResponse(Error* error); void DoWaitDeadline(); void OnDeadline(boost::system::error_code ec); void Stop(); boost::asio::io_context io_context_; std::unique_ptr socket_; std::vector buffer_; HttpResponsePtr response_; std::unique_ptr response_parser_; // Timer for the timeout control. boost::asio::deadline_timer deadline_; // Verify the certificate of the peer (remote server) or not. // HTTPS only. bool ssl_verify_; // Maximum seconds to wait before the client cancels the operation. // Only for reading response from server. int timeout_seconds_; // Request stopped due to timeout or socket error. bool stopped_; // If the error was caused by timeout or not. bool timed_out_; Error error_; }; } // namespace webcc #endif // WEBCC_HTTP_CLIENT_H_