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
78 lines
1.9 KiB
TypeScript
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,
|
|
})
|
|
}
|