Files
web/apps/scandic-web/server/routers/partners/sas/linkAccount.ts
Anton Gunnarsson b354398c69 Merged in fix/improve-sas-error-logging (pull request #1854)
Improve SAS flow logging

* Improve logging


Approved-by: Joakim Jäderberg
2025-04-24 12:30:34 +00:00

72 lines
2.0 KiB
TypeScript

import * as Sentry from "@sentry/nextjs"
import { z } from "zod"
import * as api from "@/lib/api"
import { protectedProcedure } from "@/server/trpc"
import { getSasToken } from "./getSasToken"
const outputSchema = z.object({
linkingState: z.enum([
"linked",
"alreadyLinked",
"dateOfBirthMismatch",
"error",
]),
})
export const linkAccount = protectedProcedure
.output(outputSchema)
.mutation(async function ({ ctx }) {
const sasAuthToken = getSasToken()
console.log("[SAS] link account")
const apiResponse = await api.post(api.endpoints.v1.Profile.link, {
headers: {
Authorization: `Bearer ${ctx.session.token.access_token}`,
},
body: {
partner: "sas_eb",
tocDate: getCurrentDateWithoutTime(),
partnerSpecific: {
eurobonusAccessToken: sasAuthToken,
},
},
})
const linkedAndBoosted = apiResponse.status === 200
const linkedWithoutBoost = apiResponse.status === 204
const linkedWithUnknownBoost = apiResponse.status === 202
const linked =
linkedAndBoosted || linkedWithoutBoost || linkedWithUnknownBoost
if (linked) {
console.log("[SAS] link account done")
return { linkingState: "linked" }
}
if (apiResponse.status === 400) {
const result = await apiResponse.json()
if (result.errors?.some((x: any) => x.detail.includes("birth date"))) {
return { linkingState: "dateOfBirthMismatch" }
}
console.log("[SAS] link account error with response", result)
return { linkingState: "error" }
}
if (apiResponse.status === 409) {
return { linkingState: "alreadyLinked" }
}
const errorMessage = `[SAS] link account error with status code ${apiResponse.status} and response ${await apiResponse.text()}`
console.warn(errorMessage)
Sentry.captureMessage(errorMessage)
return { linkingState: "error" }
})
function getCurrentDateWithoutTime() {
return new Date().toISOString().slice(0, 10)
}