mirror of
https://github.com/ahmadk953/tasko.git
synced 2025-01-31 00:53:37 +00:00
68 lines
1.6 KiB
JavaScript
68 lines
1.6 KiB
JavaScript
|
import { CacheHandler } from '@neshca/cache-handler';
|
||
|
import createLruHandler from '@neshca/cache-handler/local-lru';
|
||
|
import createRedisHandler from '@neshca/cache-handler/redis-stack';
|
||
|
import { createClient } from 'redis';
|
||
|
|
||
|
CacheHandler.onCreation(async () => {
|
||
|
let client;
|
||
|
|
||
|
try {
|
||
|
client = createClient({
|
||
|
url: process.env.REDIS_URL,
|
||
|
});
|
||
|
|
||
|
client.on('error', (error) => {
|
||
|
if (typeof process.env.NEXT_PRIVATE_DEBUG_CACHE !== 'undefined') {
|
||
|
console.error('Redis client error:', error);
|
||
|
}
|
||
|
});
|
||
|
} catch (error) {
|
||
|
console.warn('Failed to create Redis client:', error);
|
||
|
}
|
||
|
|
||
|
if (client) {
|
||
|
try {
|
||
|
console.info('Connecting Redis client...');
|
||
|
|
||
|
await client.connect();
|
||
|
console.info('Redis client connected.');
|
||
|
} catch (error) {
|
||
|
console.warn('Failed to connect Redis client:', error);
|
||
|
|
||
|
console.warn('Disconnecting the Redis client...');
|
||
|
client
|
||
|
.disconnect()
|
||
|
.then(() => {
|
||
|
console.info('Redis client disconnected.');
|
||
|
})
|
||
|
.catch(() => {
|
||
|
console.warn(
|
||
|
'Failed to quit the Redis client after failing to connect.'
|
||
|
);
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** @type {import("@neshca/cache-handler").Handler | null} */
|
||
|
let handler;
|
||
|
|
||
|
if (client?.isReady) {
|
||
|
handler = await createRedisHandler({
|
||
|
client,
|
||
|
keyPrefix: 'tasko:',
|
||
|
timeoutMs: 1000,
|
||
|
});
|
||
|
} else {
|
||
|
handler = createLruHandler();
|
||
|
console.warn(
|
||
|
'Falling back to LRU handler because Redis client is not available.'
|
||
|
);
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
handlers: [handler],
|
||
|
};
|
||
|
});
|
||
|
|
||
|
export default CacheHandler;
|