Skip to content

Commit

Permalink
fix: update rejectOnNotFound -> find(Fist|Unique)OrThrow (#3829)
Browse files Browse the repository at this point in the history
* fix: update rejectOnNotFound -> find(Fist|Unique)OrThrow

* fix: add back custom errohandling

* feat: handle notfounderror in getServerErrorFromUnknown

Co-authored-by: Agusti Fernandez Pardo <git@agusti.me>
Co-authored-by: Omar López <zomars@me.com>
  • Loading branch information
3 people authored Aug 31, 2022
1 parent eeabb53 commit 58c4c89
Show file tree
Hide file tree
Showing 26 changed files with 37 additions and 67 deletions.
9 changes: 3 additions & 6 deletions apps/web/pages/api/book/event.ts
Original file line number Diff line number Diff line change
Expand Up @@ -112,8 +112,7 @@ function isAvailable(busyTimes: BufferedBusyTimes, time: dayjs.ConfigType, lengt
}

const getEventTypesFromDB = async (eventTypeId: number) => {
const eventType = await prisma.eventType.findUnique({
rejectOnNotFound: true,
const eventType = await prisma.eventType.findUniqueOrThrow({
where: {
id: eventTypeId,
},
Expand Down Expand Up @@ -662,10 +661,8 @@ async function handler(req: NextApiRequest) {

if (typeof eventType.price === "number" && eventType.price > 0) {
/* Validate if there is any stripe_payment credential for this user */
await prisma.credential.findFirst({
rejectOnNotFound(err) {
throw new HttpError({ statusCode: 400, message: "Missing stripe credentials", cause: err });
},
/* note: removes custom error message about stripe */
await prisma.credential.findFirstOrThrow({
where: {
type: "stripe_payment",
userId: organizerUser.id,
Expand Down
9 changes: 3 additions & 6 deletions apps/web/pages/api/book/request-reschedule.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,7 @@ const rescheduleSchema = z.object({
});

const findUserDataByUserId = async (userId: number) => {
return await prisma.user.findUnique({
rejectOnNotFound: true,
return await prisma.user.findUniqueOrThrow({
where: {
id: userId,
},
Expand Down Expand Up @@ -76,7 +75,7 @@ const handler = async (
return res.status(501).end();
}

const bookingToReschedule = await prisma.booking.findFirst({
const bookingToReschedule = await prisma.booking.findFirstOrThrow({
select: {
id: true,
uid: true,
Expand All @@ -95,7 +94,6 @@ const handler = async (
dynamicGroupSlugRef: true,
destinationCalendar: true,
},
rejectOnNotFound: true,
where: {
uid: bookingId,
NOT: {
Expand Down Expand Up @@ -127,14 +125,13 @@ const handler = async (
if (bookingToReschedule && user) {
let event: Partial<EventType> = {};
if (bookingToReschedule.eventTypeId) {
event = await prisma.eventType.findFirst({
event = await prisma.eventType.findFirstOrThrow({
select: {
title: true,
users: true,
schedulingType: true,
recurringEvent: true,
},
rejectOnNotFound: true,
where: {
id: bookingToReschedule.eventTypeId,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/cancel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@ async function handler(req: NextApiRequest, res: NextApiResponse) {
throw new HttpError({ statusCode: 404, message: "User not found" });
}

const organizer = await prisma.user.findFirst({
const organizer = await prisma.user.findFirstOrThrow({
where: {
id: bookingToDelete.userId,
},
Expand All @@ -117,7 +117,6 @@ async function handler(req: NextApiRequest, res: NextApiResponse) {
timeZone: true,
locale: true,
},
rejectOnNotFound: true,
});

const attendeesListPromises = bookingToDelete.attendees.map(async (attendee) => {
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/import/calendly.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,7 @@ type CalendlyEventType = {

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
const session = await getSession({ req });
const authenticatedUser = await prisma.user.findFirst({
rejectOnNotFound: true,
const authenticatedUser = await prisma.user.findFirstOrThrow({
where: {
id: session?.user.id,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/import/savvycal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,7 @@ type SavvyCalEventType = {

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
const session = await getSession({ req });
const authenticatedUser = await prisma.user.findFirst({
rejectOnNotFound: true,
const authenticatedUser = await prisma.user.findFirstOrThrow({
where: {
id: session?.user.id,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/intent-username/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,12 @@ export async function getHandler(req: NextApiRequest, res: NextApiResponse) {
try {
const session = await getSession({ req });
const userId = session?.user?.id;
const user = await prisma.user.findFirst({
const user = await prisma.user.findFirstOrThrow({
select: {
id: true,
metadata: true,
},
where: { id: userId },
rejectOnNotFound: true,
});
const checkPremiumUsernameResult = await checkUsername(intentUsername);

Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/me.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
return;
}

const user = await prisma.user.findUnique({
rejectOnNotFound: true,
const user = await prisma.user.findUniqueOrThrow({
where: {
id: session.user.id,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/upgrade.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
throw new HttpCode({ statusCode: 405, message: "Method Not Allowed" });
}

const user = await prisma.user.findUnique({
rejectOnNotFound: true,
const user = await prisma.user.findUniqueOrThrow({
where: {
id: session.user.id,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/user/[id].ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
return res.status(400).json({ message: "No user id provided" });
}

const authenticatedUser = await prisma.user.findFirst({
rejectOnNotFound: true,
const authenticatedUser = await prisma.user.findFirstOrThrow({
where: {
id: session.user.id,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/api/user/me.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)

if (req.method === "DELETE") {
// Get user
const user = await prisma.user.findUnique({
rejectOnNotFound: true,
const user = await prisma.user.findUniqueOrThrow({
where: {
id: session.user?.id,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/pages/auth/forgot-password/[id].tsx
Original file line number Diff line number Diff line change
Expand Up @@ -206,8 +206,7 @@ export async function getServerSideProps(context: GetServerSidePropsContext) {
const id = context.params?.id as string;

try {
const resetPasswordRequest = await prisma.resetPasswordRequest.findUnique({
rejectOnNotFound: true,
const resetPasswordRequest = await prisma.resetPasswordRequest.findUniqueOrThrow({
where: {
id,
},
Expand Down
3 changes: 1 addition & 2 deletions apps/web/playwright/fixtures/users.ts
Original file line number Diff line number Diff line change
Expand Up @@ -61,8 +61,7 @@ export const createUsersFixture = (page: Page, workerInfo: WorkerInfo) => {
length: 30,
},
});
const user = await prisma.user.findUnique({
rejectOnNotFound: true,
const user = await prisma.user.findUniqueOrThrow({
where: { id: _user.id },
include: userIncludes,
});
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/applecalendar/api/add.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
if (req.method === "POST") {
const { username, password } = req.body;
// Get user
const user = await prisma.user.findFirst({
rejectOnNotFound: true,
const user = await prisma.user.findFirstOrThrow({
where: {
id: req.session?.user?.id,
},
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/caldavcalendar/api/add.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
if (req.method === "POST") {
const { username, password, url } = req.body;
// Get user
const user = await prisma.user.findFirst({
rejectOnNotFound: true,
const user = await prisma.user.findFirstOrThrow({
where: {
id: req.session?.user?.id,
},
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/exchange2013calendar/api/add.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,7 @@ const bodySchema = z
async function postHandler(req: NextApiRequest, res: NextApiResponse) {
const body = bodySchema.parse(req.body);
// Get user
const user = await prisma.user.findFirst({
rejectOnNotFound: true,
const user = await prisma.user.findFirstOrThrow({
where: {
id: req.session?.user?.id,
},
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/exchange2016calendar/api/add.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,7 @@ const bodySchema = z
async function postHandler(req: NextApiRequest, res: NextApiResponse) {
const body = bodySchema.parse(req.body);
// Get user
const user = await prisma.user.findFirst({
rejectOnNotFound: true,
const user = await prisma.user.findFirstOrThrow({
where: {
id: req.session?.user?.id,
},
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/slackmessaging/api/add.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,7 @@ async function handler(req: NextApiRequest) {

const { client_id } = await getSlackAppKeys();
// Get user
await prisma.user.findFirst({
rejectOnNotFound: true,
await prisma.user.findFirstOrThrow({
where: {
id: req.session.user.id,
},
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/slackmessaging/lib/actions/createEvent.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,7 @@ export default async function createEvent(req: NextApiRequest, res: NextApiRespo

// Im sure this query can be made more efficient... The JSON filtering wouldnt work when doing it directly on user.
const foundUser = await db.credential
.findFirst({
rejectOnNotFound: true,
.findFirstOrThrow({
...WhereCredsEqualsId(user.id),
})
.user({
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/tandemvideo/api/add.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,7 @@ let base_url = "";
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
if (req.method === "GET") {
// Get user
await prisma.user.findFirst({
rejectOnNotFound: true,
await prisma.user.findFirstOrThrow({
where: {
id: req.session?.user?.id,
},
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/vital/api/webhook.ts
Original file line number Diff line number Diff line change
Expand Up @@ -57,8 +57,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
try {
if (event.data.user_id) {
const json = { userVitalId: event.data.user_id as string };
const credential = await prisma.credential.findFirst({
rejectOnNotFound: true,
const credential = await prisma.credential.findFirstOrThrow({
where: {
type: "vital_other",
key: {
Expand Down
6 changes: 2 additions & 4 deletions packages/app-store/vital/lib/reschedule.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import { getCalendar } from "../../_utils/getCalendar";
type PersonAttendeeCommonFields = Pick<User, "id" | "email" | "name" | "locale" | "timeZone" | "username">;

const Reschedule = async (bookingUid: string, cancellationReason: string) => {
const bookingToReschedule = await prisma.booking.findFirst({
const bookingToReschedule = await prisma.booking.findFirstOrThrow({
select: {
id: true,
uid: true,
Expand All @@ -42,7 +42,6 @@ const Reschedule = async (bookingUid: string, cancellationReason: string) => {
},
},
},
rejectOnNotFound: true,
where: {
uid: bookingUid,
NOT: {
Expand All @@ -55,13 +54,12 @@ const Reschedule = async (bookingUid: string, cancellationReason: string) => {

if (bookingToReschedule && bookingToReschedule.eventTypeId && bookingToReschedule.user) {
const userOwner = bookingToReschedule.user;
const event = await prisma.eventType.findFirst({
const event = await prisma.eventType.findFirstOrThrow({
select: {
title: true,
users: true,
schedulingType: true,
},
rejectOnNotFound: true,
where: {
id: bookingToReschedule.eventTypeId,
},
Expand Down
6 changes: 2 additions & 4 deletions packages/app-store/wipemycalother/lib/reschedule.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import { getCalendar } from "../../_utils/getCalendar";
type PersonAttendeeCommonFields = Pick<User, "id" | "email" | "name" | "locale" | "timeZone" | "username">;

const Reschedule = async (bookingUid: string, cancellationReason: string) => {
const bookingToReschedule = await prisma.booking.findFirst({
const bookingToReschedule = await prisma.booking.findFirstOrThrow({
select: {
id: true,
uid: true,
Expand All @@ -42,7 +42,6 @@ const Reschedule = async (bookingUid: string, cancellationReason: string) => {
},
},
},
rejectOnNotFound: true,
where: {
uid: bookingUid,
NOT: {
Expand All @@ -55,13 +54,12 @@ const Reschedule = async (bookingUid: string, cancellationReason: string) => {

if (bookingToReschedule && bookingToReschedule.eventTypeId && bookingToReschedule.user) {
const userOwner = bookingToReschedule.user;
const event = await prisma.eventType.findFirst({
const event = await prisma.eventType.findFirstOrThrow({
select: {
title: true,
users: true,
schedulingType: true,
},
rejectOnNotFound: true,
where: {
id: bookingToReschedule.eventTypeId,
},
Expand Down
3 changes: 1 addition & 2 deletions packages/app-store/zoomvideo/api/add.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@ import { getZoomAppKeys } from "../lib";

async function handler(req: NextApiRequest) {
// Get user
await prisma.user.findFirst({
rejectOnNotFound: true,
await prisma.user.findFirstOrThrow({
where: {
id: req.session?.user?.id,
},
Expand Down
9 changes: 3 additions & 6 deletions packages/core/builders/CalendarEvent/builder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -95,8 +95,7 @@ export class CalendarEventBuilder implements ICalendarEventBuilder {
private async getUserById(userId: number) {
let resultUser: User | null;
try {
resultUser = await prisma.user.findUnique({
rejectOnNotFound: true,
resultUser = await prisma.user.findUniqueOrThrow({
where: {
id: userId,
},
Expand All @@ -111,8 +110,7 @@ export class CalendarEventBuilder implements ICalendarEventBuilder {
private async getEventFromEventId(eventTypeId: number) {
let resultEventType;
try {
resultEventType = await prisma.eventType.findUnique({
rejectOnNotFound: true,
resultEventType = await prisma.eventType.findUniqueOrThrow({
where: {
id: eventTypeId,
},
Expand Down Expand Up @@ -223,8 +221,7 @@ export class CalendarEventBuilder implements ICalendarEventBuilder {
public async setUsersFromId(userId: User["id"]) {
let resultUser: User | null;
try {
resultUser = await prisma.user.findUnique({
rejectOnNotFound: true,
resultUser = await prisma.user.findUniqueOrThrow({
where: {
id: userId,
},
Expand Down
5 changes: 4 additions & 1 deletion packages/lib/server/getServerErrorFromUnknown.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { PrismaClientKnownRequestError } from "@prisma/client/runtime";
import { PrismaClientKnownRequestError, NotFoundError } from "@prisma/client/runtime";
import Stripe from "stripe";
import { ZodError, ZodIssue } from "zod";

Expand Down Expand Up @@ -42,6 +42,9 @@ export function getServerErrorFromUnknown(cause: unknown): HttpError {
if (cause instanceof PrismaClientKnownRequestError) {
return new HttpError({ statusCode: 400, message: cause.message, cause });
}
if (cause instanceof NotFoundError) {
return new HttpError({ statusCode: 404, message: cause.message, cause });
}
if (cause instanceof Stripe.errors.StripeInvalidRequestError) {
return new HttpError({ statusCode: 400, message: cause.message, cause });
}
Expand Down
3 changes: 1 addition & 2 deletions packages/trpc/server/routers/viewer/bookings.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ export const bookingsRouter = createProtectedRouter()
const { booking } = ctx;

try {
const organizer = await ctx.prisma.user.findFirst({
const organizer = await ctx.prisma.user.findFirstOrThrow({
where: {
id: booking.userId || 0,
},
Expand All @@ -106,7 +106,6 @@ export const bookingsRouter = createProtectedRouter()
timeZone: true,
locale: true,
},
rejectOnNotFound: true,
});

const tOrganizer = await getTranslation(organizer.locale ?? "en", "common");
Expand Down

0 comments on commit 58c4c89

Please sign in to comment.