iceshrimp/packages/backend/src/misc/fetch-meta.ts

47 lines
1.0 KiB
TypeScript
Raw Normal View History

2023-01-13 13:40:33 +09:00
import { db } from "@/db/postgre.js";
import { Meta } from "@/models/entities/meta.js";
2019-04-24 08:11:19 +09:00
let cache: Meta;
export async function fetchMeta(noCache = false): Promise<Meta> {
if (!noCache && cache) return cache;
2023-01-13 13:40:33 +09:00
return await db.transaction(async (transactionalEntityManager) => {
// New IDs are prioritized because multiple records may have been created due to past bugs.
2022-03-27 16:16:13 +09:00
const metas = await transactionalEntityManager.find(Meta, {
order: {
2023-01-13 13:40:33 +09:00
id: "DESC",
2021-12-09 23:58:30 +09:00
},
});
2022-03-27 16:16:13 +09:00
const meta = metas[0];
if (meta) {
2019-04-24 08:11:19 +09: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,
{
2023-01-13 13:40:33 +09:00
id: "x",
},
2023-01-13 13:40:33 +09:00
["id"],
)
2023-01-13 13:40:33 +09:00
.then((x) =>
transactionalEntityManager.findOneByOrFail(Meta, x.identifiers[0]),
);
2019-04-24 08:11:19 +09:00
cache = saved;
return saved;
}
});
}
2019-04-24 08:11:19 +09:00
setInterval(() => {
2023-01-13 13:40:33 +09:00
fetchMeta(true).then((meta) => {
2019-04-24 08:11:19 +09:00
cache = meta;
});
2021-03-19 18:22:34 +09:00
}, 1000 * 10);