only check expiration on downloaded files
This commit is contained in:
parent
c51acfcc1b
commit
439b812494
|
@ -445,19 +445,21 @@ static char *url_cache_get(url_cache_t *cache, switch_core_session_t *session, c
|
||||||
url_cache_lock(cache, session);
|
url_cache_lock(cache, session);
|
||||||
u = switch_core_hash_find(cache->map, url);
|
u = switch_core_hash_find(cache->map, url);
|
||||||
|
|
||||||
|
if (u && u->status == CACHED_URL_AVAILABLE) {
|
||||||
/* check if expired */
|
/* check if expired */
|
||||||
if (u && switch_time_now() >= (u->download_time + u->max_age)) {
|
if (switch_time_now() >= (u->download_time + u->max_age)) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Cached URL has expired.\n");
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Cached URL has 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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* make sure file hasn't been deleted */
|
/* make sure file hasn't been deleted */
|
||||||
if (u && switch_file_exists(u->filename, pool) != SWITCH_STATUS_SUCCESS) {
|
if (switch_file_exists(u->filename, pool) != SWITCH_STATUS_SUCCESS) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Cached URL file is missing.\n");
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_INFO, "Cached URL file is missing.\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;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!u && download) {
|
if (!u && download) {
|
||||||
/* URL is not cached, let's add it.*/
|
/* URL is not cached, let's add it.*/
|
||||||
|
@ -872,8 +874,6 @@ SWITCH_STANDARD_API(http_cache_put)
|
||||||
char *args = NULL;
|
char *args = NULL;
|
||||||
char *argv[10] = { 0 };
|
char *argv[10] = { 0 };
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
//switch_memory_pool_t *pool = NULL;
|
|
||||||
switch_memory_pool_t *lpool = NULL;
|
|
||||||
|
|
||||||
if (zstr(cmd) || strncmp("http://", cmd, strlen("http://"))) {
|
if (zstr(cmd) || strncmp("http://", cmd, strlen("http://"))) {
|
||||||
stream->write_function(stream, "USAGE: %s\n", HTTP_PUT_SYNTAX);
|
stream->write_function(stream, "USAGE: %s\n", HTTP_PUT_SYNTAX);
|
||||||
|
@ -889,15 +889,6 @@ SWITCH_STANDARD_API(http_cache_put)
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
if (session) {
|
|
||||||
pool = switch_core_session_get_pool(session);
|
|
||||||
} else {
|
|
||||||
switch_core_new_memory_pool(&lpool);
|
|
||||||
pool = lpool;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
status = http_put(session, argv[0], argv[1]);
|
status = http_put(session, argv[0], argv[1]);
|
||||||
if (status == SWITCH_STATUS_SUCCESS) {
|
if (status == SWITCH_STATUS_SUCCESS) {
|
||||||
stream->write_function(stream, "+OK\n");
|
stream->write_function(stream, "+OK\n");
|
||||||
|
@ -905,10 +896,6 @@ SWITCH_STANDARD_API(http_cache_put)
|
||||||
stream->write_function(stream, "-ERR\n");
|
stream->write_function(stream, "-ERR\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lpool) {
|
|
||||||
switch_core_destroy_memory_pool(&lpool);
|
|
||||||
}
|
|
||||||
|
|
||||||
done:
|
done:
|
||||||
switch_safe_free(args);
|
switch_safe_free(args);
|
||||||
return status;
|
return status;
|
||||||
|
|
Loading…
Reference in New Issue