fix: conditionally use user token or service token for booking
This commit is contained in:
@@ -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, {
|
||||||
|
|||||||
Reference in New Issue
Block a user