fix: conditionally use user token or service token for booking

This commit is contained in:
Christel Westerberg
2024-11-14 16:28:41 +01:00
parent aec6361cd7
commit 06da80c9f0

View File

@@ -2,7 +2,7 @@ import { metrics } from "@opentelemetry/api"
import * as api from "@/lib/api" import * as api from "@/lib/api"
import { getVerifiedUser } from "@/server/routers/user/query" import { getVerifiedUser } from "@/server/routers/user/query"
import { router, serviceProcedure } from "@/server/trpc" import { router, safeProtectedServiceProcedure } from "@/server/trpc"
import { getMembership } from "@/utils/user" import { getMembership } from "@/utils/user"
@@ -35,16 +35,14 @@ async function getMembershipNumber(
} }
export const bookingMutationRouter = router({ export const bookingMutationRouter = router({
create: serviceProcedure.input(createBookingInput).mutation(async function ({ create: safeProtectedServiceProcedure
ctx, .input(createBookingInput)
input, .mutation(async function ({ ctx, input }) {
}) { const accessToken = ctx.session?.token.access_token ?? ctx.serviceToken
const { checkInDate, checkOutDate, hotelId } = input const { checkInDate, checkOutDate, hotelId } = input
// TODO: add support for user token OR service token in procedure
// then we can fetch membership number if user token exists
const loggingAttributes = { const loggingAttributes = {
// membershipNumber: await getMembershipNumber(ctx.session), membershipNumber: await getMembershipNumber(ctx.session),
checkInDate, checkInDate,
checkOutDate, checkOutDate,
hotelId, hotelId,
@@ -59,7 +57,7 @@ export const bookingMutationRouter = router({
}) })
) )
const headers = { const headers = {
Authorization: `Bearer ${ctx.serviceToken}`, Authorization: `Bearer ${accessToken}`,
} }
const apiResponse = await api.post(api.endpoints.v1.Booking.bookings, { const apiResponse = await api.post(api.endpoints.v1.Booking.bookings, {