import { db } from '@/db/postgre.js'; import { Meta } from '@/models/entities/meta.js'; let cache: Meta; export async function fetchMeta(noCache = false): Promise { if (!noCache && cache) return cache; return await db.transaction(async transactionalEntityManager => { // 過去のバグでレコードが複数出来てしまっている可能性があるので新しいIDを優先する const metas = await transactionalEntityManager.find(Meta, { order: { id: 'DESC', }, }); const meta = metas[0]; if (meta) { cache = meta; return meta; } else { const saved = await transactionalEntityManager.save(Meta, { id: 'x', }) as Meta; cache = saved; return saved; } }); } setInterval(() => { fetchMeta(true).then(meta => { cache = meta; }); }, 1000 * 10);