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:
@@ -23,6 +23,7 @@ const validateJsonBody = z.object({
|
|||||||
data: z.object({
|
data: z.object({
|
||||||
content_type: z.object({
|
content_type: z.object({
|
||||||
uid: z.string(),
|
uid: z.string(),
|
||||||
|
content_type_uid: z.string(),
|
||||||
}),
|
}),
|
||||||
entry: z.object({
|
entry: z.object({
|
||||||
breadcrumbs: z
|
breadcrumbs: z
|
||||||
@@ -90,6 +91,14 @@ export async function POST(request: NextRequest) {
|
|||||||
|
|
||||||
const cacheClient = await getCacheClient()
|
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}`)
|
console.info(`Revalidating refsTag: ${refsTag}`)
|
||||||
revalidateTag(refsTag)
|
revalidateTag(refsTag)
|
||||||
await cacheClient.deleteKey(refsTag, { fuzzy: true })
|
await cacheClient.deleteKey(refsTag, { fuzzy: true })
|
||||||
|
|||||||
@@ -20,7 +20,6 @@ import { notFound } from "@/server/errors/trpc"
|
|||||||
import { contentstackBaseProcedure, router } from "@/server/trpc"
|
import { contentstackBaseProcedure, router } from "@/server/trpc"
|
||||||
import { langInput } from "@/server/utils"
|
import { langInput } from "@/server/utils"
|
||||||
|
|
||||||
import { getCacheClient } from "@/services/dataCache"
|
|
||||||
import {
|
import {
|
||||||
generateRefsResponseTag,
|
generateRefsResponseTag,
|
||||||
generateTag,
|
generateTag,
|
||||||
@@ -605,164 +604,155 @@ export const baseQueryRouter = router({
|
|||||||
.input(langInput)
|
.input(langInput)
|
||||||
.query(async ({ input, ctx }) => {
|
.query(async ({ input, ctx }) => {
|
||||||
const lang = input.lang ?? ctx.lang
|
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",
|
|
||||||
JSON.stringify({ query: { lang } })
|
|
||||||
)
|
|
||||||
const responseRef = await request<GetSiteConfigRefData>(
|
|
||||||
GetSiteConfigRef,
|
|
||||||
{
|
|
||||||
locale: lang,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
key: generateRefsResponseTag(lang, "site_config"),
|
|
||||||
ttl: "max",
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
if (!responseRef.data) {
|
getSiteConfigRefCounter.add(1, { lang })
|
||||||
const notFoundError = notFound(responseRef)
|
console.info(
|
||||||
getSiteConfigRefFailCounter.add(1, {
|
"contentstack.siteConfig.ref start",
|
||||||
lang,
|
JSON.stringify({ query: { lang } })
|
||||||
error_type: "not_found",
|
|
||||||
error: JSON.stringify({ code: notFoundError.code }),
|
|
||||||
})
|
|
||||||
console.error(
|
|
||||||
"contentstack.siteConfig.refs not found error",
|
|
||||||
JSON.stringify({
|
|
||||||
query: {
|
|
||||||
lang,
|
|
||||||
},
|
|
||||||
error: { code: notFoundError.code },
|
|
||||||
})
|
|
||||||
)
|
|
||||||
throw notFoundError
|
|
||||||
}
|
|
||||||
|
|
||||||
const validatedSiteConfigRef = siteConfigRefSchema.safeParse(
|
|
||||||
responseRef.data
|
|
||||||
)
|
|
||||||
|
|
||||||
if (!validatedSiteConfigRef.success) {
|
|
||||||
getSiteConfigRefFailCounter.add(1, {
|
|
||||||
lang,
|
|
||||||
error_type: "validation_error",
|
|
||||||
error: JSON.stringify(validatedSiteConfigRef.error),
|
|
||||||
})
|
|
||||||
console.error(
|
|
||||||
"contentstack.siteConfig.refs validation error",
|
|
||||||
JSON.stringify({
|
|
||||||
query: {
|
|
||||||
lang,
|
|
||||||
},
|
|
||||||
error: validatedSiteConfigRef.error,
|
|
||||||
})
|
|
||||||
)
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
const connections = getSiteConfigConnections(
|
|
||||||
validatedSiteConfigRef.data
|
|
||||||
)
|
|
||||||
const siteConfigUid =
|
|
||||||
responseRef.data.all_site_config.items[0].system.uid
|
|
||||||
|
|
||||||
const tags = [
|
|
||||||
generateTagsFromSystem(lang, connections),
|
|
||||||
generateTag(lang, siteConfigUid),
|
|
||||||
].flat()
|
|
||||||
|
|
||||||
getSiteConfigRefSuccessCounter.add(1, { lang })
|
|
||||||
console.info(
|
|
||||||
"contentstack.siteConfig.refs success",
|
|
||||||
JSON.stringify({ query: { lang } })
|
|
||||||
)
|
|
||||||
|
|
||||||
getSiteConfigCounter.add(1, { lang })
|
|
||||||
console.info(
|
|
||||||
"contentstack.siteConfig start",
|
|
||||||
JSON.stringify({ query: { lang } })
|
|
||||||
)
|
|
||||||
const [siteConfigResponse, contactConfig] = await Promise.all([
|
|
||||||
request<GetSiteConfigData>(
|
|
||||||
GetSiteConfig,
|
|
||||||
{
|
|
||||||
locale: lang,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
key: tags,
|
|
||||||
ttl: "max",
|
|
||||||
}
|
|
||||||
),
|
|
||||||
getContactConfig(lang),
|
|
||||||
])
|
|
||||||
|
|
||||||
if (!siteConfigResponse.data) {
|
|
||||||
const notFoundError = notFound(siteConfigResponse)
|
|
||||||
|
|
||||||
getSiteConfigFailCounter.add(1, {
|
|
||||||
lang,
|
|
||||||
error_type: "not_found",
|
|
||||||
error: JSON.stringify({ code: notFoundError.code }),
|
|
||||||
})
|
|
||||||
|
|
||||||
console.error(
|
|
||||||
"contentstack.siteConfig not found error",
|
|
||||||
JSON.stringify({
|
|
||||||
query: { lang },
|
|
||||||
error: { code: notFoundError.code },
|
|
||||||
})
|
|
||||||
)
|
|
||||||
|
|
||||||
throw notFoundError
|
|
||||||
}
|
|
||||||
|
|
||||||
const validatedSiteConfig = siteConfigSchema.safeParse(
|
|
||||||
siteConfigResponse.data
|
|
||||||
)
|
|
||||||
|
|
||||||
if (!validatedSiteConfig.success) {
|
|
||||||
getSiteConfigFailCounter.add(1, {
|
|
||||||
lang,
|
|
||||||
error_type: "validation_error",
|
|
||||||
error: JSON.stringify(validatedSiteConfig.error),
|
|
||||||
})
|
|
||||||
console.error(
|
|
||||||
"contentstack.siteConfig validation error",
|
|
||||||
JSON.stringify({
|
|
||||||
query: { lang },
|
|
||||||
error: validatedSiteConfig.error,
|
|
||||||
})
|
|
||||||
)
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
getSiteConfigSuccessCounter.add(1, { lang })
|
|
||||||
console.info(
|
|
||||||
"contentstack.siteConfig success",
|
|
||||||
JSON.stringify({ query: { lang } })
|
|
||||||
)
|
|
||||||
|
|
||||||
const { sitewideAlert } = validatedSiteConfig.data
|
|
||||||
|
|
||||||
return {
|
|
||||||
...validatedSiteConfig.data,
|
|
||||||
sitewideAlert: sitewideAlert
|
|
||||||
? {
|
|
||||||
...sitewideAlert,
|
|
||||||
phoneContact: contactConfig
|
|
||||||
? getAlertPhoneContactData(sitewideAlert, contactConfig)
|
|
||||||
: null,
|
|
||||||
}
|
|
||||||
: null,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"max"
|
|
||||||
)
|
)
|
||||||
|
const responseRef = await request<GetSiteConfigRefData>(
|
||||||
|
GetSiteConfigRef,
|
||||||
|
{
|
||||||
|
locale: lang,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: generateRefsResponseTag(lang, "site_config"),
|
||||||
|
ttl: "max",
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
if (!responseRef.data) {
|
||||||
|
const notFoundError = notFound(responseRef)
|
||||||
|
getSiteConfigRefFailCounter.add(1, {
|
||||||
|
lang,
|
||||||
|
error_type: "not_found",
|
||||||
|
error: JSON.stringify({ code: notFoundError.code }),
|
||||||
|
})
|
||||||
|
console.error(
|
||||||
|
"contentstack.siteConfig.refs not found error",
|
||||||
|
JSON.stringify({
|
||||||
|
query: {
|
||||||
|
lang,
|
||||||
|
},
|
||||||
|
error: { code: notFoundError.code },
|
||||||
|
})
|
||||||
|
)
|
||||||
|
throw notFoundError
|
||||||
|
}
|
||||||
|
|
||||||
|
const validatedSiteConfigRef = siteConfigRefSchema.safeParse(
|
||||||
|
responseRef.data
|
||||||
|
)
|
||||||
|
|
||||||
|
if (!validatedSiteConfigRef.success) {
|
||||||
|
getSiteConfigRefFailCounter.add(1, {
|
||||||
|
lang,
|
||||||
|
error_type: "validation_error",
|
||||||
|
error: JSON.stringify(validatedSiteConfigRef.error),
|
||||||
|
})
|
||||||
|
console.error(
|
||||||
|
"contentstack.siteConfig.refs validation error",
|
||||||
|
JSON.stringify({
|
||||||
|
query: {
|
||||||
|
lang,
|
||||||
|
},
|
||||||
|
error: validatedSiteConfigRef.error,
|
||||||
|
})
|
||||||
|
)
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
|
const connections = getSiteConfigConnections(validatedSiteConfigRef.data)
|
||||||
|
const siteConfigUid = responseRef.data.all_site_config.items[0].system.uid
|
||||||
|
|
||||||
|
const tags = [
|
||||||
|
generateTagsFromSystem(lang, connections),
|
||||||
|
generateTag(lang, siteConfigUid),
|
||||||
|
].flat()
|
||||||
|
|
||||||
|
getSiteConfigRefSuccessCounter.add(1, { lang })
|
||||||
|
console.info(
|
||||||
|
"contentstack.siteConfig.refs success",
|
||||||
|
JSON.stringify({ query: { lang } })
|
||||||
|
)
|
||||||
|
|
||||||
|
getSiteConfigCounter.add(1, { lang })
|
||||||
|
console.info(
|
||||||
|
"contentstack.siteConfig start",
|
||||||
|
JSON.stringify({ query: { lang } })
|
||||||
|
)
|
||||||
|
const [siteConfigResponse, contactConfig] = await Promise.all([
|
||||||
|
request<GetSiteConfigData>(
|
||||||
|
GetSiteConfig,
|
||||||
|
{
|
||||||
|
locale: lang,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: tags,
|
||||||
|
ttl: "max",
|
||||||
|
}
|
||||||
|
),
|
||||||
|
getContactConfig(lang),
|
||||||
|
])
|
||||||
|
|
||||||
|
if (!siteConfigResponse.data) {
|
||||||
|
const notFoundError = notFound(siteConfigResponse)
|
||||||
|
|
||||||
|
getSiteConfigFailCounter.add(1, {
|
||||||
|
lang,
|
||||||
|
error_type: "not_found",
|
||||||
|
error: JSON.stringify({ code: notFoundError.code }),
|
||||||
|
})
|
||||||
|
|
||||||
|
console.error(
|
||||||
|
"contentstack.siteConfig not found error",
|
||||||
|
JSON.stringify({
|
||||||
|
query: { lang },
|
||||||
|
error: { code: notFoundError.code },
|
||||||
|
})
|
||||||
|
)
|
||||||
|
|
||||||
|
throw notFoundError
|
||||||
|
}
|
||||||
|
|
||||||
|
const validatedSiteConfig = siteConfigSchema.safeParse(
|
||||||
|
siteConfigResponse.data
|
||||||
|
)
|
||||||
|
|
||||||
|
if (!validatedSiteConfig.success) {
|
||||||
|
getSiteConfigFailCounter.add(1, {
|
||||||
|
lang,
|
||||||
|
error_type: "validation_error",
|
||||||
|
error: JSON.stringify(validatedSiteConfig.error),
|
||||||
|
})
|
||||||
|
console.error(
|
||||||
|
"contentstack.siteConfig validation error",
|
||||||
|
JSON.stringify({
|
||||||
|
query: { lang },
|
||||||
|
error: validatedSiteConfig.error,
|
||||||
|
})
|
||||||
|
)
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
|
getSiteConfigSuccessCounter.add(1, { lang })
|
||||||
|
console.info(
|
||||||
|
"contentstack.siteConfig success",
|
||||||
|
JSON.stringify({ query: { lang } })
|
||||||
|
)
|
||||||
|
|
||||||
|
const { sitewideAlert } = validatedSiteConfig.data
|
||||||
|
|
||||||
|
return {
|
||||||
|
...validatedSiteConfig.data,
|
||||||
|
sitewideAlert: sitewideAlert
|
||||||
|
? {
|
||||||
|
...sitewideAlert,
|
||||||
|
phoneContact: contactConfig
|
||||||
|
? getAlertPhoneContactData(sitewideAlert, contactConfig)
|
||||||
|
: null,
|
||||||
|
}
|
||||||
|
: null,
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user