summaryrefslogtreecommitdiff
path: root/app/api/basic-contract
diff options
context:
space:
mode:
Diffstat (limited to 'app/api/basic-contract')
-rw-r--r--app/api/basic-contract/get-template/route.ts52
1 files changed, 52 insertions, 0 deletions
diff --git a/app/api/basic-contract/get-template/route.ts b/app/api/basic-contract/get-template/route.ts
new file mode 100644
index 00000000..111532f0
--- /dev/null
+++ b/app/api/basic-contract/get-template/route.ts
@@ -0,0 +1,52 @@
+import { NextRequest, NextResponse } from 'next/server';
+import fs from 'fs/promises';
+import path from 'path';
+import db from "@/db/db";
+import { basicContractTemplates } from '@/db/schema';
+import { eq } from 'drizzle-orm';
+
+export async function POST(request: NextRequest) {
+ try {
+ const { templateId } = await request.json();
+
+ if (!templateId) {
+ return NextResponse.json({ error: '템플릿 ID가 누락되었습니다.' }, { status: 400 });
+ }
+
+ // 데이터베이스에서 템플릿 정보 가져오기
+ const template = await db.query.basicContractTemplates.findFirst({
+ where: eq(basicContractTemplates.id, templateId)
+ });
+
+ if (!template) {
+ return NextResponse.json({ error: '템플릿을 찾을 수 없습니다.' }, { status: 404 });
+ }
+
+ if (!template.filePath) {
+ return NextResponse.json({ error: '템플릿 파일 경로가 없습니다.' }, { status: 404 });
+ }
+
+ // 파일 시스템에서 파일 읽기
+ const fullPath = path.join(process.cwd(), "public", template.filePath);
+
+ try {
+ const fileBuffer = await fs.readFile(fullPath);
+
+ // 파일을 Blob으로 반환
+ return new NextResponse(fileBuffer, {
+ status: 200,
+ headers: {
+ 'Content-Type': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
+ 'Content-Disposition': `attachment; filename="${encodeURIComponent(template.fileName || 'template.docx')}"`,
+ },
+ });
+ } catch (fileError) {
+ console.error('파일 읽기 오류:', fileError);
+ return NextResponse.json({ error: '템플릿 파일을 읽을 수 없습니다.' }, { status: 500 });
+ }
+
+ } catch (error) {
+ console.error('템플릿 가져오기 오류:', error);
+ return NextResponse.json({ error: '서버 오류가 발생했습니다.' }, { status: 500 });
+ }
+}