FS-9004 [mod_http_cache] set http get timeout on thread that is actively downloading with the value from the download-timeout configuration.

This commit is contained in:
Chris Rienzo 2016-04-01 11:08:00 -04:00
parent ff0cec80f1
commit 86965a363d
1 changed files with 10 additions and 6 deletions

View File

@ -203,8 +203,8 @@ struct url_cache {
int enable_file_formats; int enable_file_formats;
/** How long to wait, in seconds, for TCP connection. If 0, use default value of 300 seconds */ /** How long to wait, in seconds, for TCP connection. If 0, use default value of 300 seconds */
long connect_timeout; long connect_timeout;
/** How long to wait, in nanoseconds, for download of file. If 0, use default value of 300 seconds (300 * 10^6 ns) */ /** How long to wait, in seconds, for download of file. If 0, use default value of 300 seconds */
long download_timeout_ns; long download_timeout;
}; };
static url_cache_t gcache; static url_cache_t gcache;
@ -625,6 +625,7 @@ static void url_cache_clear(url_cache_t *cache, switch_core_session_t *session)
*/ */
static char *url_cache_get(url_cache_t *cache, http_profile_t *profile, switch_core_session_t *session, const char *url, int download, int refresh, switch_memory_pool_t *pool) static char *url_cache_get(url_cache_t *cache, http_profile_t *profile, switch_core_session_t *session, const char *url, int download, int refresh, switch_memory_pool_t *pool)
{ {
switch_time_t download_timeout_ns = cache->download_timeout * 1000 * 1000;
char *filename = NULL; char *filename = NULL;
cached_url_t *u = NULL; cached_url_t *u = NULL;
if (zstr(url)) { if (zstr(url)) {
@ -647,7 +648,7 @@ static char *url_cache_get(url_cache_t *cache, http_profile_t *profile, switch_c
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Cached URL manually expired.\n"); switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Cached URL manually expired.\n");
url_cache_remove_soft(cache, session, u); /* will get permanently deleted upon replacement */ url_cache_remove_soft(cache, session, u); /* will get permanently deleted upon replacement */
u = NULL; u = NULL;
} else if (u->status == CACHED_URL_RX_IN_PROGRESS && switch_time_now() >= (u->download_time + cache->download_timeout_ns)) { } else if (u->status == CACHED_URL_RX_IN_PROGRESS && switch_time_now() >= (u->download_time + download_timeout_ns)) {
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Download of URL has timed out.\n"); switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Download of URL has timed out.\n");
u = NULL; u = NULL;
} }
@ -690,7 +691,7 @@ static char *url_cache_get(url_cache_t *cache, http_profile_t *profile, switch_c
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Waiting for URL %s to be available\n", url); switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Waiting for URL %s to be available\n", url);
u->waiters++; u->waiters++;
url_cache_unlock(cache, session); url_cache_unlock(cache, session);
while(u->status == CACHED_URL_RX_IN_PROGRESS && switch_time_now() < (u->download_time + cache->download_timeout_ns)) { while(u->status == CACHED_URL_RX_IN_PROGRESS && switch_time_now() < (u->download_time + download_timeout_ns)) {
switch_sleep(10 * 1000); /* 10 ms */ switch_sleep(10 * 1000); /* 10 ms */
} }
url_cache_lock(cache, session); url_cache_lock(cache, session);
@ -1090,6 +1091,9 @@ static switch_status_t http_get(url_cache_t *cache, http_profile_t *profile, cac
if (cache->connect_timeout > 0) { if (cache->connect_timeout > 0) {
switch_curl_easy_setopt(curl_handle, CURLOPT_CONNECTTIMEOUT, cache->connect_timeout); switch_curl_easy_setopt(curl_handle, CURLOPT_CONNECTTIMEOUT, cache->connect_timeout);
} }
if (cache->download_timeout > 0) {
switch_curl_easy_setopt(curl_handle, CURLOPT_TIMEOUT, cache->download_timeout);
}
if (!cache->ssl_verifypeer) { if (!cache->ssl_verifypeer) {
switch_curl_easy_setopt(curl_handle, CURLOPT_SSL_VERIFYPEER, 0L); switch_curl_easy_setopt(curl_handle, CURLOPT_SSL_VERIFYPEER, 0L);
} else { } else {
@ -1499,7 +1503,7 @@ static switch_status_t do_config(url_cache_t *cache)
cache->ssl_verifypeer = 1; cache->ssl_verifypeer = 1;
cache->enable_file_formats = 0; cache->enable_file_formats = 0;
cache->connect_timeout = 300; cache->connect_timeout = 300;
cache->download_timeout_ns = 300 * 1000 * 1000; cache->download_timeout = 300;
/* get params */ /* get params */
settings = switch_xml_child(cfg, "settings"); settings = switch_xml_child(cfg, "settings");
@ -1546,7 +1550,7 @@ static switch_status_t do_config(url_cache_t *cache)
int int_val = atoi(val); int int_val = atoi(val);
if (int_val > 0) { if (int_val > 0) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "Setting download-timeout to %s\n", val); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "Setting download-timeout to %s\n", val);
cache->download_timeout_ns = int_val * 1000 * 1000; cache->download_timeout = int_val;
} }
} else { } else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Unsupported param: %s\n", var); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Unsupported param: %s\n", var);