diff options
| author | IT Fixcomart <it@fixcomart.co.id> | 2024-11-15 07:39:14 +0000 |
|---|---|---|
| committer | IT Fixcomart <it@fixcomart.co.id> | 2024-11-15 07:39:14 +0000 |
| commit | 7ca8fce4ac97ffc31042dd4d016460a5e61284a5 (patch) | |
| tree | d0f1bb7711e2d93859e1d534551328b14a3ae78e /src/pages/api/banner-section.js | |
| parent | 49f2e6a5612d000c3a740513c1a54b73bb656d77 (diff) | |
| parent | e5544ace96dd9a200ca5876b8e9ba837ad0a26ac (diff) | |
Merged in CR/redis (pull request #379)
CR/redis
Diffstat (limited to 'src/pages/api/banner-section.js')
| -rw-r--r-- | src/pages/api/banner-section.js | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/src/pages/api/banner-section.js b/src/pages/api/banner-section.js new file mode 100644 index 00000000..7d7040c0 --- /dev/null +++ b/src/pages/api/banner-section.js @@ -0,0 +1,44 @@ +import odooApi from '@/core/api/odooApi'; +import { createClient } from 'redis'; + +const client = createClient(); + +client.on('error', (err) => console.error('Redis Client Error', err)); + +const connectRedis = async () => { + if (!client.isOpen) { + await client.connect(); + } +}; + +export default async function handler(req, res) { + try { + await connectRedis(); + const cacheKey = 'hero-banner'; + // await client.del(cacheKey); + let cachedData = await client.get(cacheKey); + + if (cachedData) { + const data = JSON.parse(cachedData); + return res.status(200).json({ data }); + } else { + const dataBannerSections = await odooApi( + 'GET', + '/api/v1/banner?type=home-banner' + ); + + // Simpan hasil fetch ke Redis dengan masa kadaluarsa 3 hari (259200 detik) + await client.set( + cacheKey, + JSON.stringify(dataBannerSections), + 'EX', + 259200 + ); + + return res.status(200).json({ data: dataBannerSections }); + } + } catch (error) { + console.error('Error interacting with Redis or fetching data:', error); + return res.status(500).json({ error: 'Internal Server Error' }); + } +} |
