147 lines
4.1 KiB
TypeScript
147 lines
4.1 KiB
TypeScript
import { Request, Response } from "express";
|
|
import { logger } from "../utils/logger";
|
|
import { AuthenticatedRequest } from "../types/auth";
|
|
import { ApiResponse } from "../types/common";
|
|
import { EventTriggerService } from "../services/eventTriggerService";
|
|
|
|
/**
|
|
* 조건부 연결 조건 테스트
|
|
*/
|
|
export async function testConditionalConnection(
|
|
req: AuthenticatedRequest,
|
|
res: Response
|
|
): Promise<void> {
|
|
try {
|
|
logger.info("=== 조건부 연결 조건 테스트 시작 ===");
|
|
|
|
const { diagramId } = req.params;
|
|
const { testData } = req.body;
|
|
const companyCode = req.user?.companyCode;
|
|
|
|
if (!companyCode) {
|
|
const response: ApiResponse<null> = {
|
|
success: false,
|
|
message: "회사 코드가 필요합니다.",
|
|
error: {
|
|
code: "MISSING_COMPANY_CODE",
|
|
details: "인증된 사용자의 회사 코드를 찾을 수 없습니다.",
|
|
},
|
|
};
|
|
res.status(400).json(response);
|
|
return;
|
|
}
|
|
|
|
if (!diagramId || !testData) {
|
|
const response: ApiResponse<null> = {
|
|
success: false,
|
|
message: "다이어그램 ID와 테스트 데이터가 필요합니다.",
|
|
error: {
|
|
code: "MISSING_REQUIRED_FIELDS",
|
|
details: "diagramId와 testData가 필요합니다.",
|
|
},
|
|
};
|
|
res.status(400).json(response);
|
|
return;
|
|
}
|
|
|
|
const result = await EventTriggerService.testConditionalConnection(
|
|
parseInt(diagramId),
|
|
testData,
|
|
companyCode
|
|
);
|
|
|
|
const response: ApiResponse<any> = {
|
|
success: true,
|
|
message: "조건부 연결 테스트를 성공적으로 완료했습니다.",
|
|
data: result,
|
|
};
|
|
|
|
res.status(200).json(response);
|
|
} catch (error) {
|
|
logger.error("조건부 연결 테스트 실패:", error);
|
|
const response: ApiResponse<null> = {
|
|
success: false,
|
|
message: "조건부 연결 테스트에 실패했습니다.",
|
|
error: {
|
|
code: "CONDITIONAL_CONNECTION_TEST_FAILED",
|
|
details:
|
|
error instanceof Error
|
|
? error.message
|
|
: "알 수 없는 오류가 발생했습니다.",
|
|
},
|
|
};
|
|
res.status(500).json(response);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 조건부 연결 액션 수동 실행
|
|
*/
|
|
export async function executeConditionalActions(
|
|
req: AuthenticatedRequest,
|
|
res: Response
|
|
): Promise<void> {
|
|
try {
|
|
logger.info("=== 조건부 연결 액션 수동 실행 시작 ===");
|
|
|
|
const { diagramId } = req.params;
|
|
const { triggerType, tableName, data } = req.body;
|
|
const companyCode = req.user?.companyCode;
|
|
|
|
if (!companyCode) {
|
|
const response: ApiResponse<null> = {
|
|
success: false,
|
|
message: "회사 코드가 필요합니다.",
|
|
error: {
|
|
code: "MISSING_COMPANY_CODE",
|
|
details: "인증된 사용자의 회사 코드를 찾을 수 없습니다.",
|
|
},
|
|
};
|
|
res.status(400).json(response);
|
|
return;
|
|
}
|
|
|
|
if (!diagramId || !triggerType || !tableName || !data) {
|
|
const response: ApiResponse<null> = {
|
|
success: false,
|
|
message: "필수 필드가 누락되었습니다.",
|
|
error: {
|
|
code: "MISSING_REQUIRED_FIELDS",
|
|
details: "diagramId, triggerType, tableName, data가 모두 필요합니다.",
|
|
},
|
|
};
|
|
res.status(400).json(response);
|
|
return;
|
|
}
|
|
|
|
const results = await EventTriggerService.executeEventTriggers(
|
|
triggerType,
|
|
tableName,
|
|
data,
|
|
companyCode
|
|
);
|
|
|
|
const response: ApiResponse<any[]> = {
|
|
success: true,
|
|
message: "조건부 연결 액션을 성공적으로 실행했습니다.",
|
|
data: results,
|
|
};
|
|
|
|
res.status(200).json(response);
|
|
} catch (error) {
|
|
logger.error("조건부 연결 액션 실행 실패:", error);
|
|
const response: ApiResponse<null> = {
|
|
success: false,
|
|
message: "조건부 연결 액션 실행에 실패했습니다.",
|
|
error: {
|
|
code: "CONDITIONAL_ACTION_EXECUTION_FAILED",
|
|
details:
|
|
error instanceof Error
|
|
? error.message
|
|
: "알 수 없는 오류가 발생했습니다.",
|
|
},
|
|
};
|
|
res.status(500).json(response);
|
|
}
|
|
}
|