import type { NextApiRequest, NextApiResponse } from "next"; import { getServerSession } from "next-auth/next"; import { authOptions } from "pages/api/auth/[...nextauth]"; import { prisma } from "@/lib/api/db"; import readFile from "@/lib/api/storage/readFile"; export default async function Index(req: NextApiRequest, res: NextApiResponse) { const session = await getServerSession(req, res, authOptions); const userId = session?.user.id; const userEmail = session?.user.email?.toLowerCase(); const queryId = Number(req.query.id); if (!queryId) return res .setHeader("Content-Type", "text/plain") .status(401) .send("Invalid parameters."); if (!userId || !userEmail) return res .setHeader("Content-Type", "text/plain") .status(401) .send("You must be logged in."); if (userId !== queryId) { const targetUser = await prisma.user.findUnique({ where: { id: queryId, }, }); if ( targetUser?.isPrivate && !targetUser.whitelistedUsers.includes(userEmail) ) { return res .setHeader("Content-Type", "text/plain") .send("This profile is private."); } } const { file, contentType } = await readFile({ filePath: `uploads/avatar/${queryId}.jpg`, }); res.setHeader("Content-Type", contentType); return res.send(file); }