summaryrefslogtreecommitdiff
path: root/app/api/general-contracts/upload-pdf/route.ts
diff options
context:
space:
mode:
authordujinkim <dujin.kim@dtsolution.co.kr>2025-12-05 09:18:28 +0000
committerdujinkim <dujin.kim@dtsolution.co.kr>2025-12-05 09:18:28 +0000
commite467b3b7905a200b98daa3787565c08a309a6dda (patch)
tree9ab8d1e7cd2bda128d7acb75fdb7811a9ef1cee9 /app/api/general-contracts/upload-pdf/route.ts
parent5233996e9bd676ce763a12e58c7955c7ca8f26c5 (diff)
(최겸) 계약 승인 요청 시 결재 상신 개발, 입찰 화학물질 soap 개발
Diffstat (limited to 'app/api/general-contracts/upload-pdf/route.ts')
-rw-r--r--app/api/general-contracts/upload-pdf/route.ts73
1 files changed, 73 insertions, 0 deletions
diff --git a/app/api/general-contracts/upload-pdf/route.ts b/app/api/general-contracts/upload-pdf/route.ts
new file mode 100644
index 00000000..9480f7f5
--- /dev/null
+++ b/app/api/general-contracts/upload-pdf/route.ts
@@ -0,0 +1,73 @@
+/**
+ * 일반계약 PDF 업로드 API
+ * 클라이언트에서 생성된 PDF를 서버에 저장
+ */
+
+import { NextRequest, NextResponse } from 'next/server';
+import { getServerSession } from 'next-auth/next';
+import { authOptions } from '@/app/api/auth/[...nextauth]/route';
+import { saveBuffer } from '@/lib/file-stroage';
+
+export async function POST(request: NextRequest) {
+ try {
+ const session = await getServerSession(authOptions);
+ if (!session?.user?.id) {
+ return NextResponse.json(
+ { success: false, error: '인증이 필요합니다' },
+ { status: 401 }
+ );
+ }
+
+ const formData = await request.formData();
+ const file = formData.get('file') as File;
+ const contractId = formData.get('contractId') as string;
+
+ if (!file) {
+ return NextResponse.json(
+ { success: false, error: '파일이 제공되지 않았습니다' },
+ { status: 400 }
+ );
+ }
+
+ // 파일을 ArrayBuffer로 읽기
+ const arrayBuffer = await file.arrayBuffer();
+ const buffer = Buffer.from(arrayBuffer);
+
+ // saveBuffer 함수를 사용해서 파일 저장
+ const saveResult = await saveBuffer({
+ buffer: buffer,
+ fileName: `${Date.now()}_${file.name}`,
+ directory: "generalContracts",
+ originalName: file.name,
+ userId: session.user.id
+ });
+
+ if (!saveResult.success) {
+ return NextResponse.json(
+ { success: false, error: saveResult.error || 'PDF 파일 저장에 실패했습니다.' },
+ { status: 500 }
+ );
+ }
+
+ const finalFilePath = saveResult.publicPath
+ ? saveResult.publicPath.replace('/api/files/', '')
+ : `/generalContracts/${saveResult.fileName}`;
+
+ return NextResponse.json({
+ success: true,
+ filePath: finalFilePath,
+ fileName: saveResult.fileName,
+ publicPath: saveResult.publicPath,
+ });
+ } catch (error) {
+ console.error('PDF 업로드 오류:', error);
+ return NextResponse.json(
+ {
+ success: false,
+ error: error instanceof Error ? error.message : 'PDF 업로드 중 오류가 발생했습니다.'
+ },
+ { status: 500 }
+ );
+ }
+}
+