From feb8a533e125378d31a2c50382214c74b0486a51 Mon Sep 17 00:00:00 2001 From: Anand Suthar Date: Mon, 23 Sep 2024 20:30:18 +0530 Subject: [PATCH] =?UTF-8?q?feat:=20Refactor=20API=20endpoints=20to=20use?= =?UTF-8?q?=20NextResponse=20and=20centralized=20error=20handling=20?= =?UTF-8?q?=F0=9F=8C=9F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/patient/appointment/pending/route.ts | 31 +++++--- app/api/patient/appointment/route.ts | 81 +++++++++----------- app/api/patient/medicalhistory/route.ts | 25 +++--- app/api/patient/paymenthistory/route.ts | 25 +++--- app/api/patient/route.ts | 29 ++++--- 5 files changed, 100 insertions(+), 91 deletions(-) diff --git a/app/api/patient/appointment/pending/route.ts b/app/api/patient/appointment/pending/route.ts index e1ea870..babbdc5 100644 --- a/app/api/patient/appointment/pending/route.ts +++ b/app/api/patient/appointment/pending/route.ts @@ -1,29 +1,30 @@ -import dbConfig from "@utils/db"; import { Patient, BookedAppointment } from "@models/index"; +import { dbConfig, errorHandler, STATUS_CODES } from "@utils/index"; +import { authenticateUser } from "@lib/auth/authenticateUser"; import { Types } from "mongoose"; +import { NextResponse } from "next/server"; export async function POST(req: Request) { try { const { hospital_id }: { hospital_id: string } = await req.json(); + const authHeader = req.headers.get("Authorization"); - const id = req.headers.get("x-user-id"); - const role = req.headers.get("x-user-role"); + const { id, role } = await authenticateUser(authHeader); if (!id || !role) { - return Response.json( - { error: "Missing user ID or role" }, - { status: 400 } + return errorHandler( + "Missing user ID or role", + STATUS_CODES.VALIDATION_ERROR ); } const patient_id = new Types.ObjectId(id); - await dbConfig(); const patient = await Patient.findById(patient_id); if (!patient) { - return Response.json({ error: "Patient not found" }, { status: 404 }); + return errorHandler("Patient not found", STATUS_CODES.NOT_FOUND); } // Checking if a pending appointment request exists with the hospital @@ -34,12 +35,18 @@ export async function POST(req: Request) { }); if (alreadyBookedAppointment) { - return Response.json({ hasPendingAppointment: true }, { status: 200 }); + return NextResponse.json( + { hasPendingAppointment: true }, + { status: 200 } + ); } - return Response.json({ hasPendingAppointment: false }, { status: 200 }); - } catch (error) { + return NextResponse.json({ hasPendingAppointment: false }, { status: 200 }); + } catch (error: any) { console.error("Error checking pending appointments:", error); - return Response.json({ error: "Internal Server Error" }, { status: 500 }); + return errorHandler( + error.message || "Internal Server Error", + STATUS_CODES.SERVER_ERROR + ); } } diff --git a/app/api/patient/appointment/route.ts b/app/api/patient/appointment/route.ts index 2602e7f..532e96d 100644 --- a/app/api/patient/appointment/route.ts +++ b/app/api/patient/appointment/route.ts @@ -1,4 +1,5 @@ -import { dbConfig } from "@utils/index"; +import { authenticateUser } from "@lib/auth/authenticateUser"; +import { dbConfig, errorHandler, STATUS_CODES } from "@utils/index"; import { Types } from "mongoose"; import sendEmail from "@lib/sendemail"; import { render } from "@react-email/render"; @@ -6,41 +7,35 @@ import { AppointmentBookedTemplate } from "@lib/emails/templates"; import sendNotification from "@lib/novu"; import { Patient, BookedAppointment, Doctor } from "@models/index"; import { BookingAppointmentType } from "@pft-types/patient"; +import { NextResponse } from "next/server"; -// getting patients approved appointments +// getting patient's approved appointments export async function GET(request: Request) { try { - const id = request.headers.get("x-user-id"); - const role = request.headers.get("x-user-role"); + const authHeader = request.headers.get("Authorization"); + const { id, role } = await authenticateUser(authHeader); if (!id || !role) { - return Response.json( - { error: "Missing user ID or role" }, - { status: 400 } + return errorHandler( + "Missing user ID or role", + STATUS_CODES.VALIDATION_ERROR ); } const patient_id = new Types.ObjectId(id); - await dbConfig(); - const patient = await Patient.findById(patient_id); + const patient = await Patient.findById(patient_id); if (!patient) { - return Response.json( - { error: "Patient not found" }, - { - status: 404, - } - ); + return errorHandler("Patient not found", STATUS_CODES.NOT_FOUND); } - let appointments = await BookedAppointment.find({ + const appointments = await BookedAppointment.find({ patient_id: patient._id, approved: "approved", }); const doctorIds = appointments.map((appointment) => appointment.doctor_id); - const doctors = await Doctor.find( { _id: { $in: doctorIds } }, { firstname: 1, lastname: 1, specialty: 1, profile: 1 } @@ -62,16 +57,12 @@ export async function GET(request: Request) { return appointmentObj; }); - return Response.json(updatedAppointments, { - status: 200, - }); - } catch (error) { + return NextResponse.json(updatedAppointments, { status: 200 }); + } catch (error: any) { console.error("Error getting appointments:", error); - return Response.json( - { error: "Internal Server Error" }, - { - status: 500, - } + return errorHandler( + error.message || "Internal Server Error", + STATUS_CODES.SERVER_ERROR ); } } @@ -89,24 +80,22 @@ export async function POST(req: Request) { appointment_charge, }: BookingAppointmentType = await req.json(); - const id = req.headers.get("x-user-id"); - const role = req.headers.get("x-user-role"); + const authHeader = req.headers.get("Authorization"); + const { id, role } = await authenticateUser(authHeader); if (!id || !role) { - return Response.json( - { error: "Missing user ID or role" }, - { status: 400 } + return errorHandler( + "Missing user ID or role", + STATUS_CODES.VALIDATION_ERROR ); } const patient_id = new Types.ObjectId(id); - await dbConfig(); const patient = await Patient.findById(patient_id); - if (!patient) { - return Response.json({ error: "Patient not found" }, { status: 404 }); + return errorHandler("Patient not found", STATUS_CODES.NOT_FOUND); } const appointmentData = { @@ -125,11 +114,12 @@ export async function POST(req: Request) { }; const res = await BookedAppointment.create(appointmentData); - - if (!res) - return Response.json({ - error: "Error saving appointment info", - }); + if (!res) { + return errorHandler( + "Error saving appointment info", + STATUS_CODES.SERVER_ERROR + ); + } const bookedAppointmentData = { state, @@ -167,14 +157,15 @@ export async function POST(req: Request) { "appointment-request" ); - return Response.json( - { - msg: "Appointment request added successfully", - }, + return NextResponse.json( + { msg: "Appointment request added successfully" }, { status: 200 } ); - } catch (error) { + } catch (error: any) { console.error("Error adding appointment request:", error); - return Response.json({ error: "Internal Server Error" }, { status: 500 }); + return errorHandler( + error.message || "Internal Server Error", + STATUS_CODES.SERVER_ERROR + ); } } diff --git a/app/api/patient/medicalhistory/route.ts b/app/api/patient/medicalhistory/route.ts index 48f3fe5..ee65dd6 100644 --- a/app/api/patient/medicalhistory/route.ts +++ b/app/api/patient/medicalhistory/route.ts @@ -1,5 +1,7 @@ -import { Patient, Doctor, MedicalHistory, Hospital } from "@models/index"; +import { Patient, MedicalHistory } from "@models/index"; import { Types } from "mongoose"; +import { dbConfig, errorHandler, STATUS_CODES } from "@utils/index"; +import { NextResponse } from "next/server"; export async function GET(request: Request) { try { @@ -7,17 +9,18 @@ export async function GET(request: Request) { const role = request.headers.get("x-user-role"); if (!id || !role) { - return Response.json( - { error: "Missing user ID or role" }, - { status: 400 } + return errorHandler( + "Missing user ID or role", + STATUS_CODES.VALIDATION_ERROR ); } const patient_id = new Types.ObjectId(id); + await dbConfig(); const patient = await Patient.findById(patient_id, { _id: 1 }).exec(); if (!patient) { - return Response.json({ error: "Patient not found" }, { status: 404 }); + return errorHandler("Patient not found", STATUS_CODES.NOT_FOUND); } const medicalHistory = await MedicalHistory.find( @@ -50,12 +53,12 @@ export async function GET(request: Request) { disease: history.disease, })); - return Response.json(formattedMedicalHistory); - } catch (error) { - console.error("Error fetching medical history of patient : ", error); - return Response.json( - { error: "Failed to fetch medical history" }, - { status: 500 } + return NextResponse.json(formattedMedicalHistory, { status: 200 }); + } catch (error: any) { + console.error("Error fetching medical history of patient:", error); + return errorHandler( + error.message || "Failed to fetch medical history", + STATUS_CODES.SERVER_ERROR ); } } diff --git a/app/api/patient/paymenthistory/route.ts b/app/api/patient/paymenthistory/route.ts index 8062029..a12204b 100644 --- a/app/api/patient/paymenthistory/route.ts +++ b/app/api/patient/paymenthistory/route.ts @@ -1,6 +1,7 @@ -import dbConfig from "@utils/db"; -import { Patient, Hospital, Transaction } from "@models/index"; +import { dbConfig, errorHandler, STATUS_CODES } from "@utils/index"; +import { Patient, Transaction } from "@models/index"; import { Types } from "mongoose"; +import { NextResponse } from "next/server"; export async function GET(request: Request) { try { @@ -8,22 +9,21 @@ export async function GET(request: Request) { const role = request.headers.get("x-user-role"); if (!id || !role) { - return Response.json( - { error: "Missing user ID or role" }, - { status: 400 } + return errorHandler( + "Missing user ID or role", + STATUS_CODES.VALIDATION_ERROR ); } const patient_id = new Types.ObjectId(id); - await dbConfig(); const patient = await Patient.findById(patient_id); if (!patient) { - return Response.json({ error: "Patient not found" }, { status: 404 }); + return errorHandler("Patient not found", STATUS_CODES.NOT_FOUND); } - // get all transactions where patient id matches + // get all transactions where patient ID matches const transactions = await Transaction.find({ patient: patient._id, }) @@ -45,9 +45,12 @@ export async function GET(request: Request) { }) ); - return Response.json(formattedTransactions, { status: 200 }); - } catch (error) { + return NextResponse.json(formattedTransactions, { status: 200 }); + } catch (error: any) { console.error("Error fetching payment data:", error); - return Response.json({ error: "Internal Server Error" }, { status: 500 }); + return errorHandler( + error.message || "Internal Server Error", + STATUS_CODES.SERVER_ERROR + ); } } diff --git a/app/api/patient/route.ts b/app/api/patient/route.ts index 0a4ddcf..32a6b2e 100644 --- a/app/api/patient/route.ts +++ b/app/api/patient/route.ts @@ -1,21 +1,23 @@ -import dbConfig from "@utils/db"; import Patient from "@models/patient"; +import { dbConfig, errorHandler, STATUS_CODES } from "@utils/index"; +import { authenticateUser } from "@lib/auth/authenticateUser"; import { Types } from "mongoose"; +import { NextResponse } from "next/server"; export async function GET(request: Request) { + const authHeader = request.headers.get("Authorization"); + try { - const id = request.headers.get("x-user-id"); - const role = request.headers.get("x-user-role"); + const { id, role } = await authenticateUser(authHeader); if (!id || !role) { - return Response.json( - { error: "Missing user ID or role" }, - { status: 400 } + return errorHandler( + "Missing user ID or role", + STATUS_CODES.VALIDATION_ERROR ); } const patient_id = new Types.ObjectId(id); - await dbConfig(); const projection = { @@ -25,15 +27,18 @@ export async function GET(request: Request) { current_hospital: 0, }; - const patientData = await Patient.findById(patient_id, { projection }); + const patientData = await Patient.findById(patient_id, projection); if (!patientData) { - return Response.json({ error: "Patient not found" }, { status: 404 }); + return errorHandler("Patient not found", STATUS_CODES.NOT_FOUND); } - return Response.json(patientData); - } catch (error) { + return NextResponse.json(patientData, { status: 200 }); + } catch (error: any) { console.error("Error fetching patient data:", error); - return Response.json({ error: "Internal Server Error" }, { status: 500 }); + return errorHandler( + error.message || "Internal Server Error", + STATUS_CODES.SERVER_ERROR + ); } }