Merged in fix/site-config-revalidate (pull request #1751)

fix: site-config - use correct cache keys and invalidate them

* fix: site-config - use correct cache keys and invalidate them


Approved-by: Joakim Jäderberg
This commit is contained in:
Linus Flood
2025-04-08 10:27:26 +00:00
parent 73cb423c95
commit d30cc7e2be
2 changed files with 157 additions and 158 deletions

View File

@@ -23,6 +23,7 @@ const validateJsonBody = z.object({
data: z.object({
content_type: z.object({
uid: z.string(),
content_type_uid: z.string(),
}),
entry: z.object({
breadcrumbs: z
@@ -90,6 +91,14 @@ export async function POST(request: NextRequest) {
const cacheClient = await getCacheClient()
const contentTypeUidTag = generateTag(
entryLocale,
content_type.content_type_uid
)
console.info(`Revalidating tag by content_type_uid: ${contentTypeUidTag}`)
revalidateTag(contentTypeUidTag)
await cacheClient.deleteKey(contentTypeUidTag, { fuzzy: true })
console.info(`Revalidating refsTag: ${refsTag}`)
revalidateTag(refsTag)
await cacheClient.deleteKey(refsTag, { fuzzy: true })

View File

@@ -20,7 +20,6 @@ import { notFound } from "@/server/errors/trpc"
import { contentstackBaseProcedure, router } from "@/server/trpc"
import { langInput } from "@/server/utils"
import { getCacheClient } from "@/services/dataCache"
import {
generateRefsResponseTag,
generateTag,
@@ -605,10 +604,7 @@ export const baseQueryRouter = router({
.input(langInput)
.query(async ({ input, ctx }) => {
const lang = input.lang ?? ctx.lang
const cacheClient = await getCacheClient()
return await cacheClient.cacheOrGet(
generateRefsResponseTag(lang, "site_config", "root"),
async () => {
getSiteConfigRefCounter.add(1, { lang })
console.info(
"contentstack.siteConfig.ref start",
@@ -666,11 +662,8 @@ export const baseQueryRouter = router({
return null
}
const connections = getSiteConfigConnections(
validatedSiteConfigRef.data
)
const siteConfigUid =
responseRef.data.all_site_config.items[0].system.uid
const connections = getSiteConfigConnections(validatedSiteConfigRef.data)
const siteConfigUid = responseRef.data.all_site_config.items[0].system.uid
const tags = [
generateTagsFromSystem(lang, connections),
@@ -761,8 +754,5 @@ export const baseQueryRouter = router({
}
: null,
}
},
"max"
)
}),
})