Merged in fix/cache-fixes (pull request #1555)

fix/cache: reduce cachetime when null response from CS. Fix fuzzy delete

* fix/cache: reduce cachetime when null response from CS. Fix fuzzy delete


Approved-by: Anton Gunnarsson
This commit is contained in:
Linus Flood
2025-03-17 14:39:59 +00:00
parent c5ad3cba34
commit f183125bc6
6 changed files with 33 additions and 11 deletions

View File

@@ -10,9 +10,13 @@ export const fetchAndCacheEntry = async (path: string, lang: Lang) => {
return cache.cacheOrGet(
cacheKey,
async () => {
async (overrideTTL) => {
const { contentType, uid } = await resolveEntry(path, lang)
if (!contentType || !uid) {
overrideTTL?.("10m")
}
return {
contentType,
uid,

View File

@@ -64,7 +64,9 @@ export type DataCache = {
*/
cacheOrGet: <T>(
key: string | string[],
getDataFromSource: () => Promise<T>,
getDataFromSource: (
overrideTTL?: (cacheTime: CacheTime) => void
) => Promise<T>,
ttl: CacheTime
) => Promise<T>

View File

@@ -7,21 +7,27 @@ import { set } from "./set"
export const cacheOrGet: DataCache["cacheOrGet"] = async <T>(
key: string | string[],
callback: () => Promise<T>,
callback: (overrideTTL: (cacheTime: CacheTime) => void) => Promise<T>,
ttl: CacheTime
) => {
const cacheKey = generateCacheKey(key)
const cachedValue = await get<T>(cacheKey)
let realTTL = ttl
const overrideTTL = function (cacheTime: CacheTime) {
realTTL = cacheTime
}
if (!cachedValue) {
const perf = performance.now()
const data = await callback()
const data = await callback(overrideTTL)
cacheLogger.debug(
`Getting data '${cacheKey}' took ${(performance.now() - perf).toFixed(2)}ms`
)
await set<T>(cacheKey, data, ttl)
await set<T>(cacheKey, data, realTTL)
return data
}

View File

@@ -4,10 +4,15 @@ import { cacheLogger } from "../logger"
import { API_KEY } from "./client"
import { getCacheEndpoint } from "./endpoints"
export async function deleteKey<T>(key: string) {
export async function deleteKey<T>(key: string, opts?: { fuzzy?: boolean }) {
const perf = performance.now()
const endpoint = getCacheEndpoint(key)
const response = await fetch(getCacheEndpoint(key), {
if (opts?.fuzzy) {
endpoint.searchParams.set("fuzzy", "true")
}
const response = await fetch(endpoint, {
method: "DELETE",
cache: "no-cache",
headers: {

View File

@@ -6,13 +6,18 @@ import { set } from "./set"
export const cacheOrGet: DataCache["cacheOrGet"] = async <T>(
key: string | string[],
callback: () => Promise<T>,
callback: (overrideTTL?: (cacheTime: CacheTime) => void) => Promise<T>,
ttl: CacheTime
): Promise<T> => {
if (Array.isArray(key)) {
key = key.join("-")
}
let realTTL = ttl
const overrideTTL = function (cacheTime: CacheTime) {
realTTL = cacheTime
}
const cached = await get(key)
if (cached) {
@@ -22,8 +27,8 @@ export const cacheOrGet: DataCache["cacheOrGet"] = async <T>(
cacheLogger.debug(`Miss for key '${key}'`)
try {
const data = await callback()
await set(key, data, ttl)
const data = await callback(overrideTTL)
await set(key, data, realTTL)
return data
} catch (e) {

View File

@@ -10,7 +10,7 @@ import { cacheLogger } from "../../logger"
export const cacheOrGet: DataCache["cacheOrGet"] = async <T>(
key: string | string[],
callback: () => Promise<T>,
callback: (overrideTTL?: (cacheTime: CacheTime) => void) => Promise<T>,
ttl: CacheTime
): Promise<T> => {
if (!Array.isArray(key)) {