mirror of
https://github.com/marcogll/TaxHacker_s23.git
synced 2026-01-13 13:25:18 +00:00
45 lines
1.4 KiB
TypeScript
45 lines
1.4 KiB
TypeScript
import { getCurrentUser } from "@/lib/auth"
|
|
import { fileExists, fullPathForFile } from "@/lib/files"
|
|
import { getFileById } from "@/models/files"
|
|
import fs from "fs/promises"
|
|
import { NextResponse } from "next/server"
|
|
|
|
export async function GET(request: Request, { params }: { params: Promise<{ fileId: string }> }) {
|
|
const { fileId } = await params
|
|
const user = await getCurrentUser()
|
|
|
|
if (!fileId) {
|
|
return new NextResponse("No fileId provided", { status: 400 })
|
|
}
|
|
|
|
try {
|
|
// Find file in database
|
|
const file = await getFileById(fileId, user.id)
|
|
|
|
if (!file || file.userId !== user.id) {
|
|
return new NextResponse("File not found or does not belong to the user", { status: 404 })
|
|
}
|
|
|
|
// Check if file exists
|
|
const fullFilePath = await fullPathForFile(user, file)
|
|
const isFileExists = await fileExists(fullFilePath)
|
|
if (!isFileExists) {
|
|
return new NextResponse(`File not found on disk: ${file.path}`, { status: 404 })
|
|
}
|
|
|
|
// Read file
|
|
const fileBuffer = await fs.readFile(fullFilePath)
|
|
|
|
// Return file with proper content type
|
|
return new NextResponse(fileBuffer, {
|
|
headers: {
|
|
"Content-Type": file.mimetype,
|
|
"Content-Disposition": `attachment; filename="${file.filename}"`,
|
|
},
|
|
})
|
|
} catch (error) {
|
|
console.error("Error serving file:", error)
|
|
return new NextResponse("Internal Server Error", { status: 500 })
|
|
}
|
|
}
|