diff --git a/Network/NetworkConnectivity.cpp b/Network/NetworkConnectivity.cpp index be51c02c72..1e53165fd2 100644 --- a/Network/NetworkConnectivity.cpp +++ b/Network/NetworkConnectivity.cpp @@ -178,9 +178,9 @@ namespace WPEFramework { else { if(isConnectivityMonitorEndpointSet()) - internetState = testConnectivity(getConnectivityMonitorEndpoints(), 10000, ipversion); + internetState = testConnectivity(getConnectivityMonitorEndpoints(), TEST_CONNECTIVITY_DEFAULT_TIMEOUT_MS, ipversion, false); else - internetState = testConnectivity(getConnectivityDefaultEndpoints(), 10000, ipversion); + internetState = testConnectivity(getConnectivityDefaultEndpoints(), TEST_CONNECTIVITY_DEFAULT_TIMEOUT_MS, ipversion, false); } return internetState; @@ -237,7 +237,8 @@ namespace WPEFramework { static bool curlVerboseEnabled() { std::ifstream fileStream("/tmp/network.plugin.debug"); - return fileStream.is_open(); + //return fileStream.is_open(); + return true; } static long current_time () @@ -253,7 +254,7 @@ namespace WPEFramework { return size * nmemb; } - nsm_internetState Connectivity::testConnectivity(const std::vector& endpoints, long timeout_ms, nsm_ipversion ipversion) + nsm_internetState Connectivity::testConnectivity(const std::vector& endpoints, long timeout_ms, nsm_ipversion ipversion, bool connectOnly) { long deadline = current_time() + timeout_ms, time_now = 0, time_earlier = 0; if(endpoints.size() < 1) { @@ -288,7 +289,10 @@ namespace WPEFramework { curl_easy_setopt(curl_easy_handle, CURLOPT_HTTPHEADER, chunk); curl_easy_setopt(curl_easy_handle, CURLOPT_USERAGENT, "RDKCaptiveCheck/1.0"); /* set CURLOPT_HTTPGET option insted of CURLOPT_CONNECT_ONLY bcause we need to get the captiveportal URI not just connection only */ - curl_easy_setopt(curl_easy_handle, CURLOPT_HTTPGET, 1L); + if(connectOnly) + curl_easy_setopt(curl_easy_handle, CURLOPT_CONNECT_ONLY, 1L); + else + curl_easy_setopt(curl_easy_handle, CURLOPT_HTTPGET, 1L); curl_easy_setopt(curl_easy_handle, CURLOPT_WRITEFUNCTION, writeFunction); curl_easy_setopt(curl_easy_handle, CURLOPT_TIMEOUT_MS, deadline - current_time()); if ((ipversion == CURL_IPRESOLVE_V4) || (ipversion == CURL_IPRESOLVE_V6)) @@ -323,7 +327,11 @@ namespace WPEFramework { continue; if (CURLE_OK == msg->data.result) { curl_easy_getinfo(msg->easy_handle, CURLINFO_PRIVATE, &endpoint); - if (curl_easy_getinfo(msg->easy_handle, CURLINFO_RESPONSE_CODE, &response_code) == CURLE_OK) { + if(connectOnly) { + LOGINFO("curl check type CURLOPT_CONNECT_ONLY"); + response_code = HttpStatus_204_No_Content; + } + else if (curl_easy_getinfo(msg->easy_handle, CURLINFO_RESPONSE_CODE, &response_code) == CURLE_OK) { if(curlVerboseEnabled()) LOGINFO("endpoint = <%s> response code <%d>",endpoint, static_cast(response_code)); if (HttpStatus_302_Found == response_code) { @@ -334,8 +342,13 @@ namespace WPEFramework { } } } - else + else { LOGERR("endpoint = <%s> error = %d (%s)", endpoint, msg->data.result, curl_easy_strerror(msg->data.result)); + // if (msg->data.result == CURLE_OPERATION_TIMEDOUT) + // { + // response_code = HttpStatus_204_No_Content; + // } + } http_responses.push_back(response_code); } time_earlier = time_now; @@ -503,7 +516,12 @@ namespace WPEFramework { nsm_internetState InternetConnectionState = nsm_internetState::UNKNOWN; while (!stopFlag) { - InternetConnectionState = testConnectivity(getConnectivityMonitorEndpoints(), 10000, NSM_IPRESOLVE_WHATEVER); + if(g_internetState.load() == nsm_internetState::FULLY_CONNECTED) + /*if previous check was fully connected then do connect only curl check*/ + InternetConnectionState = testConnectivity(getConnectivityMonitorEndpoints(), TEST_CONNECTIVITY_DEFAULT_TIMEOUT_MS, NSM_IPRESOLVE_WHATEVER, true); + else + InternetConnectionState = testConnectivity(getConnectivityMonitorEndpoints(), TEST_CONNECTIVITY_DEFAULT_TIMEOUT_MS, NSM_IPRESOLVE_WHATEVER, false); + if(g_internetState.load() != InternetConnectionState) { g_internetState.store(InternetConnectionState); diff --git a/Network/NetworkConnectivity.h b/Network/NetworkConnectivity.h index 316ee5f8a7..70ee0b93ef 100644 --- a/Network/NetworkConnectivity.h +++ b/Network/NetworkConnectivity.h @@ -13,6 +13,7 @@ #define CAPTIVEPORTAL_MAX_LEN 512 #define DEFAULT_MONITOR_TIMEOUT 60 // in seconds #define MONITOR_TIMEOUT_INTERVAL_MIN 5 +#define TEST_CONNECTIVITY_DEFAULT_TIMEOUT_MS 5000 enum nsm_ipversion { NSM_IPRESOLVE_WHATEVER = 0, /* default, resolves addresses to all IP*/ @@ -81,7 +82,7 @@ namespace WPEFramework { } ~Connectivity(){} - nsm_internetState testConnectivity(const std::vector& endpoints, long timeout_ms, nsm_ipversion ipversion); + nsm_internetState testConnectivity(const std::vector& endpoints, long timeout_ms, nsm_ipversion ipversion, bool connectOnly); std::vector getConnectivityDefaultEndpoints() { return m_defaultEndpoints; }; std::string getCaptivePortal() { const std::lock_guard lock(capitiveMutex); return g_captivePortal; } void setCaptivePortal(const char* captivePortal) {const std::lock_guard lock(capitiveMutex); g_captivePortal = captivePortal; }