Feat/SW-618 payment non happy path * feat(SW-618): filter out expired saved cards * feat(SW-618): Added payment error codes and way of showing messages based on code * feat(SW-618): show error message if max retries has been reached and remove search param after showing toast * fix(SW-618): move fallback error codes * fix(SW-618): remove ref from stopping useEffect to run twice * fix(SW-618): refactored logic for toast message and minor fixes * fix(SW-618): remove error message enum due to static analysis problems Approved-by: Christian Andolf Approved-by: Arvid Norlin
76 lines
2.1 KiB
TypeScript
76 lines
2.1 KiB
TypeScript
import { NextRequest, NextResponse } from "next/server"
|
|
|
|
import {
|
|
BOOKING_CONFIRMATION_NUMBER,
|
|
PaymentErrorCodeEnum,
|
|
} from "@/constants/booking"
|
|
import { Lang } from "@/constants/languages"
|
|
import {
|
|
bookingConfirmation,
|
|
payment,
|
|
} from "@/constants/routes/hotelReservation"
|
|
import { serverClient } from "@/lib/trpc/server"
|
|
import { getPublicURL } from "@/server/utils"
|
|
|
|
export async function GET(
|
|
request: NextRequest,
|
|
{ params }: { params: { lang: string; status: string } }
|
|
): Promise<NextResponse> {
|
|
const publicURL = getPublicURL(request)
|
|
|
|
console.log(`[payment-callback] callback started`)
|
|
const lang = params.lang as Lang
|
|
const status = params.status
|
|
|
|
const queryParams = request.nextUrl.searchParams
|
|
const confirmationNumber = queryParams.get(BOOKING_CONFIRMATION_NUMBER)
|
|
|
|
if (status === "success" && confirmationNumber) {
|
|
const confirmationUrl = new URL(`${publicURL}/${bookingConfirmation[lang]}`)
|
|
confirmationUrl.searchParams.set(
|
|
BOOKING_CONFIRMATION_NUMBER,
|
|
confirmationNumber
|
|
)
|
|
|
|
console.log(`[payment-callback] redirecting to: ${confirmationUrl}`)
|
|
return NextResponse.redirect(confirmationUrl)
|
|
}
|
|
|
|
const returnUrl = new URL(`${publicURL}/${payment[lang]}`)
|
|
returnUrl.search = queryParams.toString()
|
|
|
|
if (confirmationNumber) {
|
|
try {
|
|
const bookingStatus = await serverClient().booking.status({
|
|
confirmationNumber,
|
|
})
|
|
if (bookingStatus.metadata) {
|
|
returnUrl.searchParams.set(
|
|
"errorCode",
|
|
bookingStatus.metadata.errorCode?.toString() ?? ""
|
|
)
|
|
}
|
|
} catch (error) {
|
|
console.error(
|
|
`[payment-callback] failed to get booking status for ${confirmationNumber}, status: ${status}`
|
|
)
|
|
|
|
if (status === "cancel") {
|
|
returnUrl.searchParams.set(
|
|
"errorCode",
|
|
PaymentErrorCodeEnum.Cancelled.toString()
|
|
)
|
|
}
|
|
if (status === "error") {
|
|
returnUrl.searchParams.set(
|
|
"errorCode",
|
|
PaymentErrorCodeEnum.Failed.toString()
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
console.log(`[payment-callback] redirecting to: ${returnUrl}`)
|
|
return NextResponse.redirect(returnUrl)
|
|
}
|