ERP-node/backend-node/src/controllers/dynamicFormController.ts

350 lines
8.9 KiB
TypeScript
Raw Normal View History

import { Response } from "express";
import { dynamicFormService } from "../services/dynamicFormService";
import { AuthenticatedRequest } from "../types/auth";
// 폼 데이터 저장
export const saveFormData = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { companyCode, userId } = req.user as any;
const { screenId, tableName, data } = req.body;
// 필수 필드 검증
if (!screenId || !tableName || !data) {
return res.status(400).json({
success: false,
message: "필수 필드가 누락되었습니다. (screenId, tableName, data)",
});
}
// 메타데이터 추가 (사용자가 입력한 경우에만 company_code 추가)
const formDataWithMeta = {
...data,
created_by: userId,
updated_by: userId,
screen_id: screenId,
};
// company_code는 사용자가 명시적으로 입력한 경우에만 추가
if (data.company_code !== undefined) {
formDataWithMeta.company_code = data.company_code;
} else if (companyCode && companyCode !== "*") {
// 기본 company_code가 '*'가 아닌 경우에만 추가
formDataWithMeta.company_code = companyCode;
}
const result = await dynamicFormService.saveFormData(
screenId,
tableName,
formDataWithMeta
);
res.json({
success: true,
data: result,
message: "데이터가 성공적으로 저장되었습니다.",
});
} catch (error: any) {
console.error("❌ 폼 데이터 저장 실패:", error);
res.status(500).json({
success: false,
message: error.message || "데이터 저장에 실패했습니다.",
});
}
};
// 폼 데이터 업데이트
export const updateFormData = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { id } = req.params;
const { companyCode, userId } = req.user as any;
const { tableName, data } = req.body;
if (!tableName || !data) {
return res.status(400).json({
success: false,
message: "필수 필드가 누락되었습니다. (tableName, data)",
});
}
// 메타데이터 추가
const formDataWithMeta = {
...data,
updated_by: userId,
updated_at: new Date(),
};
const result = await dynamicFormService.updateFormData(
parseInt(id),
tableName,
formDataWithMeta
);
res.json({
success: true,
data: result,
message: "데이터가 성공적으로 업데이트되었습니다.",
});
} catch (error: any) {
console.error("❌ 폼 데이터 업데이트 실패:", error);
res.status(500).json({
success: false,
message: error.message || "데이터 업데이트에 실패했습니다.",
});
}
};
2025-09-18 18:49:30 +09:00
// 폼 데이터 부분 업데이트 (변경된 필드만)
export const updateFormDataPartial = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { id } = req.params;
const { companyCode, userId } = req.user as any;
const { tableName, originalData, newData } = req.body;
if (!tableName || !originalData || !newData) {
return res.status(400).json({
success: false,
message:
"필수 필드가 누락되었습니다. (tableName, originalData, newData)",
});
}
console.log("🔄 컨트롤러: 부분 업데이트 요청:", {
id,
tableName,
originalData,
newData,
});
// 메타데이터 추가
const newDataWithMeta = {
...newData,
updated_by: userId,
};
const result = await dynamicFormService.updateFormDataPartial(
parseInt(id),
tableName,
originalData,
newDataWithMeta
);
res.json({
success: true,
data: result,
message: "데이터가 성공적으로 업데이트되었습니다.",
});
} catch (error: any) {
console.error("❌ 부분 업데이트 실패:", error);
res.status(500).json({
success: false,
message: error.message || "부분 업데이트에 실패했습니다.",
});
}
};
// 폼 데이터 삭제
export const deleteFormData = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { id } = req.params;
const { companyCode } = req.user as any;
const { tableName } = req.body;
if (!tableName) {
return res.status(400).json({
success: false,
message: "필수 필드가 누락되었습니다. (tableName)",
});
}
await dynamicFormService.deleteFormData(parseInt(id), tableName);
res.json({
success: true,
message: "데이터가 성공적으로 삭제되었습니다.",
});
} catch (error: any) {
console.error("❌ 폼 데이터 삭제 실패:", error);
res.status(500).json({
success: false,
message: error.message || "데이터 삭제에 실패했습니다.",
});
}
};
2025-09-18 18:49:30 +09:00
// 테이블의 기본키 조회
export const getTablePrimaryKeys = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { tableName } = req.params;
if (!tableName) {
return res.status(400).json({
success: false,
message: "테이블명이 누락되었습니다.",
});
}
console.log(`🔑 테이블 ${tableName}의 기본키 조회 요청`);
const primaryKeys = await dynamicFormService.getTablePrimaryKeys(tableName);
console.log(`✅ 테이블 ${tableName}의 기본키:`, primaryKeys);
res.json({
success: true,
data: primaryKeys,
message: "기본키 조회가 완료되었습니다.",
});
} catch (error: any) {
console.error("❌ 기본키 조회 실패:", error);
res.status(500).json({
success: false,
message: error.message || "기본키 조회에 실패했습니다.",
});
}
};
// 단일 폼 데이터 조회
export const getFormData = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { id } = req.params;
const { companyCode } = req.user as any;
const data = await dynamicFormService.getFormData(parseInt(id));
if (!data) {
return res.status(404).json({
success: false,
message: "데이터를 찾을 수 없습니다.",
});
}
res.json({
success: true,
data: data,
});
} catch (error: any) {
console.error("❌ 폼 데이터 단건 조회 실패:", error);
res.status(500).json({
success: false,
message: error.message || "데이터 조회에 실패했습니다.",
});
}
};
// 화면별 폼 데이터 목록 조회
export const getFormDataList = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { screenId } = req.params;
const { companyCode } = req.user as any;
const {
page = 1,
size = 10,
search = "",
sortBy = "created_at",
sortOrder = "desc",
} = req.query;
const result = await dynamicFormService.getFormDataList(
parseInt(screenId as string),
{
page: parseInt(page as string),
size: parseInt(size as string),
search: search as string,
sortBy: sortBy as string,
sortOrder: sortOrder as "asc" | "desc",
}
);
res.json({
success: true,
data: result,
});
} catch (error: any) {
console.error("❌ 폼 데이터 목록 조회 실패:", error);
res.status(500).json({
success: false,
message: error.message || "데이터 조회에 실패했습니다.",
});
}
};
// 폼 데이터 검증
export const validateFormData = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { tableName, data } = req.body;
if (!tableName || !data) {
return res.status(400).json({
success: false,
message: "필수 필드가 누락되었습니다. (tableName, data)",
});
}
const validationResult = await dynamicFormService.validateFormData(
tableName,
data
);
res.json({
success: true,
data: validationResult,
});
} catch (error: any) {
console.error("❌ 폼 데이터 검증 실패:", error);
res.status(500).json({
success: false,
message: error.message || "데이터 검증에 실패했습니다.",
});
}
};
// 테이블 컬럼 정보 조회 (검증용)
export const getTableColumns = async (
req: AuthenticatedRequest,
res: Response
): Promise<Response | void> => {
try {
const { tableName } = req.params;
const columns = await dynamicFormService.getTableColumns(tableName);
res.json({
success: true,
data: {
tableName,
columns,
},
});
} catch (error: any) {
console.error("❌ 테이블 컬럼 정보 조회 실패:", error);
res.status(500).json({
success: false,
message: error.message || "테이블 정보 조회에 실패했습니다.",
});
}
};