Merged in feat/SW-1488-unlink-sas-account (pull request #1349)

Implement unlink SAS flow

Approved-by: Joakim Jäderberg
This commit is contained in:
Anton Gunnarsson
2025-02-20 15:09:06 +00:00
parent fc720b1dbc
commit 340f6d1714
22 changed files with 216 additions and 82 deletions

View File

@@ -1,27 +1,50 @@
import { TRPCError } from "@trpc/server"
import { z } from "zod"
import * as api from "@/lib/api"
import { protectedProcedure } from "@/server/trpc"
import { timeout } from "@/utils/timeout"
import { getSasToken } from "./getSasToken"
const outputSchema = z.object({
// unlinked: z.boolean(),
linkingState: z.enum(["unlinked", "notLinked", "error"]),
})
export const unlinkAccount = protectedProcedure
.output(outputSchema)
.mutation(async function ({ ctx, input }) {
console.log("[SAS] unlink account")
await timeout(1000)
//TODO: Call actual API here
.mutation(async function ({ ctx }) {
const sasAuthToken = getSasToken()
throw new TRPCError({
message: "Unable to unlink account",
code: "BAD_REQUEST",
const apiResponse = await api.post(api.endpoints.v1.Profile.unlink, {
headers: {
Authorization: `Bearer ${ctx.session.token.access_token}`,
},
body: {
partner: "sas_eb",
partnerSpecific: {
eurobonusAccessToken: sasAuthToken,
},
},
})
return {
unlinked: true,
if (apiResponse.status === 204) {
console.log("[SAS] unlink account success")
return { linkingState: "unlinked" }
}
if (apiResponse.status === 400) {
const result = await apiResponse.json()
console.log("[SAS] unlink account error with response", result)
return { linkingState: "error" }
}
if (apiResponse.status === 404) {
console.log("[SAS] tried unlinking an account that was not linked")
return { linkingState: "notLinked" }
}
console.log(
`[SAS] unlink account error with status code ${apiResponse.status} and response ${await apiResponse.text()}`
)
return { linkingState: "error" }
})