jormungandr-bite/packages/backend/src/misc/fetch-meta.ts

45 lines
1 KiB
TypeScript
Raw Normal View History

import { db } from '@/db/postgre.js';
import { Meta } from '@/models/entities/meta.js';
2019-04-23 17:11:19 -06:00
let cache: Meta;
export async function fetchMeta(noCache = false): Promise<Meta> {
if (!noCache && cache) return cache;
return await db.transaction(async transactionalEntityManager => {
// New IDs are prioritized because multiple records may have been created due to past bugs.
2022-03-27 01:16:13 -06:00
const metas = await transactionalEntityManager.find(Meta, {
order: {
2021-12-09 07:58:30 -07:00
id: 'DESC',
},
});
2022-03-27 01:16:13 -06:00
const meta = metas[0];
if (meta) {
2019-04-23 17:11:19 -06:00
cache = meta;
return meta;
} else {
// If fetchMeta is called at the same time when meta is empty, this part may be called at the same time, so use fail-safe upsert.
const saved = await transactionalEntityManager
.upsert(
Meta,
{
id: 'x',
},
['id'],
)
.then((x) => transactionalEntityManager.findOneByOrFail(Meta, x.identifiers[0]));
2019-04-23 17:11:19 -06:00
cache = saved;
return saved;
}
});
}
2019-04-23 17:11:19 -06:00
setInterval(() => {
fetchMeta(true).then(meta => {
cache = meta;
});
2021-03-19 03:22:34 -06:00
}, 1000 * 10);