summaryrefslogtreecommitdiff
path: root/src/net
diff options
context:
space:
mode:
Diffstat (limited to 'src/net')
-rw-r--r--src/net/BoostHttpOnlySslClient.cpp26
-rw-r--r--src/net/CurlHttpClient.cpp3
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() {