[addon] remove memory cache as dynamic ttl is not supported
This commit is contained in:
@@ -9,7 +9,7 @@ const USER_AGENT_KEY_PREFIX = `${GLOBAL_KEY_PREFIX}|agent`;
|
|||||||
|
|
||||||
const STREAM_TTL = process.env.STREAM_TTL || 4 * 60 * 60; // 4 hours
|
const STREAM_TTL = process.env.STREAM_TTL || 4 * 60 * 60; // 4 hours
|
||||||
const STREAM_EMPTY_TTL = process.env.STREAM_EMPTY_TTL || 30 * 60; // 30 minutes
|
const STREAM_EMPTY_TTL = process.env.STREAM_EMPTY_TTL || 30 * 60; // 30 minutes
|
||||||
const RESOLVED_URL_TTL = 60; // 1 minutes
|
const RESOLVED_URL_TTL = 2 * 60; // 2 minutes
|
||||||
const PROXY_TTL = 60 * 60; // 60 minutes
|
const PROXY_TTL = 60 * 60; // 60 minutes
|
||||||
const USER_AGENT_TTL = 2 * 24 * 60 * 60; // 2 days
|
const USER_AGENT_TTL = 2 * 24 * 60 * 60; // 2 days
|
||||||
// When the streams are empty we want to cache it for less time in case of timeouts or failures
|
// When the streams are empty we want to cache it for less time in case of timeouts or failures
|
||||||
@@ -17,7 +17,6 @@ const USER_AGENT_TTL = 2 * 24 * 60 * 60; // 2 days
|
|||||||
const MONGO_URI = process.env.MONGODB_URI;
|
const MONGO_URI = process.env.MONGODB_URI;
|
||||||
const NO_CACHE = process.env.NO_CACHE || false;
|
const NO_CACHE = process.env.NO_CACHE || false;
|
||||||
|
|
||||||
const memoryCache = initiateMemoryCache();
|
|
||||||
const remoteCache = initiateRemoteCache();
|
const remoteCache = initiateRemoteCache();
|
||||||
|
|
||||||
function initiateRemoteCache() {
|
function initiateRemoteCache() {
|
||||||
@@ -31,26 +30,19 @@ function initiateRemoteCache() {
|
|||||||
collection: 'torrentio_addon_collection',
|
collection: 'torrentio_addon_collection',
|
||||||
useNewUrlParser: true,
|
useNewUrlParser: true,
|
||||||
useUnifiedTopology: false,
|
useUnifiedTopology: false,
|
||||||
ttl: STREAM_TTL
|
ttl: STREAM_EMPTY_TTL
|
||||||
},
|
},
|
||||||
ttl: STREAM_TTL,
|
ttl: STREAM_EMPTY_TTL,
|
||||||
ignoreCacheErrors: true
|
ignoreCacheErrors: true
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
return cacheManager.caching({
|
return cacheManager.caching({
|
||||||
store: 'memory',
|
store: 'memory',
|
||||||
ttl: STREAM_TTL
|
ttl: STREAM_EMPTY_TTL
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function initiateMemoryCache() {
|
|
||||||
return cacheManager.caching({
|
|
||||||
store: 'memory',
|
|
||||||
ttl: STREAM_TTL
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function cacheWrap(cache, key, method, options) {
|
function cacheWrap(cache, key, method, options) {
|
||||||
if (NO_CACHE || !cache) {
|
if (NO_CACHE || !cache) {
|
||||||
return method();
|
return method();
|
||||||
@@ -65,15 +57,15 @@ function cacheWrapStream(id, method) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function cacheWrapResolvedUrl(id, method) {
|
function cacheWrapResolvedUrl(id, method) {
|
||||||
return cacheWrap(memoryCache, `${RESOLVED_URL_KEY_PREFIX}:${id}`, method, { ttl: { RESOLVED_URL_TTL } });
|
return cacheWrap(remoteCache, `${RESOLVED_URL_KEY_PREFIX}:${id}`, method, { ttl: RESOLVED_URL_TTL });
|
||||||
}
|
}
|
||||||
|
|
||||||
function cacheWrapProxy(id, method) {
|
function cacheWrapProxy(id, method) {
|
||||||
return cacheWrap(memoryCache, `${PROXY_KEY_PREFIX}:${id}`, method, { ttl: { PROXY_TTL } });
|
return cacheWrap(remoteCache, `${PROXY_KEY_PREFIX}:${id}`, method, { ttl: PROXY_TTL });
|
||||||
}
|
}
|
||||||
|
|
||||||
function cacheUserAgent(id, method) {
|
function cacheUserAgent(id, method) {
|
||||||
return cacheWrap(memoryCache, `${USER_AGENT_KEY_PREFIX}:${id}`, method, { ttl: { USER_AGENT_TTL } });
|
return cacheWrap(remoteCache, `${USER_AGENT_KEY_PREFIX}:${id}`, method, { ttl: USER_AGENT_TTL });
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = { cacheWrapStream, cacheWrapResolvedUrl, cacheWrapProxy, cacheUserAgent };
|
module.exports = { cacheWrapStream, cacheWrapResolvedUrl, cacheWrapProxy, cacheUserAgent };
|
||||||
|
|||||||
Reference in New Issue
Block a user