diff options
Diffstat (limited to 'src/net')
-rw-r--r-- | src/net/BoostHttpOnlySslClient.cpp | 26 | ||||
-rw-r--r-- | src/net/CurlHttpClient.cpp | 3 |
2 files changed, 29 insertions, 0 deletions
diff --git a/src/net/BoostHttpOnlySslClient.cpp b/src/net/BoostHttpOnlySslClient.cpp index 301d0c8..6e59649 100644 --- a/src/net/BoostHttpOnlySslClient.cpp +++ b/src/net/BoostHttpOnlySslClient.cpp @@ -48,6 +48,32 @@ string BoostHttpOnlySslClient::makeRequest(const Url& url, const vector<HttpReqA string requestText = _httpParser.generateRequest(url, args, false); write(socket, buffer(requestText.c_str(), requestText.length())); + fd_set fileDescriptorSet; + struct timeval timeStruct; + + // set the timeout to 20 seconds + timeStruct.tv_sec = 20; + timeStruct.tv_usec = 0; + FD_ZERO(&fileDescriptorSet); + + // We'll need to get the underlying native socket for this select call, in order + // to add a simple timeout on the read: + + int nativeSocket = socket.lowest_layer().native_handle(); + + FD_SET(nativeSocket,&fileDescriptorSet); + select(nativeSocket+1,&fileDescriptorSet,NULL,NULL,&timeStruct); + + if(!FD_ISSET(nativeSocket,&fileDescriptorSet)){ // timeout + + std::string sMsg("TIMEOUT on read client data. Client IP: "); + + sMsg.append(socket.next_layer().remote_endpoint().address().to_string()); + _ioService.reset(); + + throw std::exception(); + } + string response; #ifdef TGBOT_CHANGE_READ_BUFFER_SIZE diff --git a/src/net/CurlHttpClient.cpp b/src/net/CurlHttpClient.cpp index 6dc43f8..13973cc 100644 --- a/src/net/CurlHttpClient.cpp +++ b/src/net/CurlHttpClient.cpp @@ -11,6 +11,9 @@ namespace TgBot { CurlHttpClient::CurlHttpClient() : _httpParser() { curlSettings = curl_easy_init(); + + curl_easy_setopt(curlSettings, CURLOPT_CONNECTTIMEOUT, 20); + curl_easy_setopt(curlSettings, CURLOPT_TIMEOUT, 25); } CurlHttpClient::~CurlHttpClient() { |