Include more details when throwing errors for debugging in Sentry * WIP throw errors with more details for debugging in Sentry * Fix throwing response-data * Clearer message when a response fails * Add message to errors * better typings * . * Try to send profileID and membershipNumber to Sentry when we fail to parse the apiResponse * rename notFound -> notFoundError * Merge branch 'master' of bitbucket.org:scandic-swap/web into chore/add-error-details-for-sentry Approved-by: Linus Flood
68 lines
2.1 KiB
TypeScript
68 lines
2.1 KiB
TypeScript
import { createCounter } from "@scandic-hotels/common/telemetry"
|
|
|
|
import { router } from "../../.."
|
|
import { notFoundError } from "../../../errors"
|
|
import { GetHotelPage } from "../../../graphql/Query/HotelPage/HotelPage.graphql"
|
|
import { request } from "../../../graphql/request"
|
|
import { contentstackExtendedProcedureUID } from "../../../procedures"
|
|
import { generateTag } from "../../../utils/generateTag"
|
|
import { getCampaignPagesByHotelPageUid } from "../campaignPage/utils"
|
|
import { hotelPageSchema } from "./output"
|
|
import { getSortedCampaigns } from "./utils"
|
|
|
|
import type { GetHotelPageData } from "../../../types/hotelPage"
|
|
|
|
export const hotelPageQueryRouter = router({
|
|
get: contentstackExtendedProcedureUID.query(async ({ ctx }) => {
|
|
const { lang, uid } = ctx
|
|
|
|
const getHotelPageCounter = createCounter("trpc.contentstack.hotelPage.get")
|
|
const metricsGetHotelPage = getHotelPageCounter.init({ lang, uid })
|
|
|
|
metricsGetHotelPage.start()
|
|
|
|
const variables = { locale: lang, uid }
|
|
const hotelPageResponse = await request<GetHotelPageData>(
|
|
GetHotelPage,
|
|
variables,
|
|
{
|
|
key: generateTag(lang, uid),
|
|
ttl: "max",
|
|
}
|
|
)
|
|
|
|
if (!hotelPageResponse.data) {
|
|
metricsGetHotelPage.noDataError()
|
|
|
|
throw notFoundError({
|
|
message: "GetHotelPage returned no data",
|
|
errorDetails: variables,
|
|
})
|
|
}
|
|
|
|
const validatedHotelPage = hotelPageSchema.safeParse(hotelPageResponse.data)
|
|
|
|
if (!validatedHotelPage.success) {
|
|
metricsGetHotelPage.validationError(validatedHotelPage.error)
|
|
return null
|
|
}
|
|
|
|
metricsGetHotelPage.success()
|
|
|
|
const hotelCampaigns = await getCampaignPagesByHotelPageUid(uid, lang)
|
|
|
|
const hotelPage = validatedHotelPage.data.hotel_page
|
|
const { prioritizedCampaigns, ...campaignsBlockContent } =
|
|
hotelPage.campaigns
|
|
return {
|
|
...hotelPage,
|
|
campaignsBlock: hotelCampaigns?.length
|
|
? {
|
|
...campaignsBlockContent,
|
|
campaigns: getSortedCampaigns(prioritizedCampaigns, hotelCampaigns),
|
|
}
|
|
: null,
|
|
}
|
|
}),
|
|
})
|