Files
web/packages/trpc/lib/routers/user/utils/getBasicUser.ts
Joakim Jäderberg 99537b13e8 Merged in chore/add-error-details-for-sentry (pull request #3378)
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
2026-01-12 09:01:44 +00:00

78 lines
1.9 KiB
TypeScript

import * as Sentry from "@sentry/nextjs"
import { createCounter } from "@scandic-hotels/common/telemetry"
import * as api from "../../../api"
import { cache } from "../../../DUPLICATED/cache"
import {
extractResponseDetails,
serverErrorByStatus,
sessionExpiredError,
} from "../../../errors"
import { getBasicUserSchema } from "../output"
import type z from "zod"
import type { DeepPartial } from "../../../types/deepPartial"
export const getBasicUser = cache(
async ({
token,
}: {
token: { expires_at?: number; access_token: string }
}) => {
const getBasicUserCounter = createCounter("user.getBasicUser")
const metricsGetBasicUser = getBasicUserCounter.init()
metricsGetBasicUser.start()
const now = Date.now()
if (token.expires_at && token.expires_at < now) {
throw sessionExpiredError()
}
const apiResponse = await api.get(api.endpoints.v2.Profile.basicProfile, {
headers: {
Authorization: `Bearer ${token.access_token}`,
},
})
if (!apiResponse.ok) {
await metricsGetBasicUser.httpError(apiResponse)
throw serverErrorByStatus(
apiResponse.status,
await extractResponseDetails(apiResponse),
"getBasicUser failed"
)
}
const apiJson = await apiResponse.json()
const verifiedData = getBasicUserSchema.safeParse(apiJson)
if (!verifiedData.success) {
addUserToSentry(apiJson)
metricsGetBasicUser.validationError(verifiedData.error)
throw verifiedData.error
}
metricsGetBasicUser.success()
return verifiedData.data
}
)
function addUserToSentry(apiJson: unknown) {
const typedData = apiJson as DeepPartial<z.input<typeof getBasicUserSchema>>
if (
typeof typedData?.profileId === "undefined" ||
typeof typedData?.membershipNumber === "undefined"
) {
return
}
Sentry.setUser({
id: typedData?.profileId,
username: typedData?.membershipNumber,
})
}