cherry2250 f6f6e450cd 모든 localhost API 엔드포인트를 Gateway URL로 변경
- 모든 API 클라이언트에서 localhost 참조 제거
- Gateway URL 하드코딩: http://kt-event-marketing-api.20.214.196.128.nip.io
- 프로덕션/개발 환경 구분 제거
- 런타임 설정 로직 제거
- Dockerfile 및 배포 설정 추가
2025-10-30 14:05:07 +09:00

65 lines
2.0 KiB
TypeScript

import { NextRequest, NextResponse } from 'next/server';
/**
* Mock API: 이벤트 목적 선택 (Step 1)
* 백엔드 API가 준비될 때까지 사용하는 임시 Mock API
*
* POST /api/v1/events/objectives
*/
export async function POST(request: NextRequest) {
try {
const body = await request.json();
const { objective } = body;
// 백엔드 API 호출 시도
const EVENT_HOST = 'http://kt-event-marketing-api.20.214.196.128.nip.io';
const backendUrl = `${EVENT_HOST}/api/events/objectives`;
try {
const backendResponse = await fetch(backendUrl, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Authorization': request.headers.get('Authorization') || '',
},
body: JSON.stringify(body),
});
// 백엔드가 정상 응답하면 그대로 반환
if (backendResponse.ok) {
const data = await backendResponse.json();
return NextResponse.json(data, { status: backendResponse.status });
}
} catch (backendError) {
console.warn('⚠️ 백엔드 API 호출 실패, Mock 데이터 반환:', backendError);
}
// 백엔드 실패 시 Mock 데이터 반환
// shared/api/eventApi의 selectObjective가 반환하는 형식과 일치
const mockEventId = `evt_${Date.now()}_${Math.random().toString(36).substring(7)}`;
const mockResponse = {
eventId: mockEventId,
objective: objective,
status: 'DRAFT' as const,
createdAt: new Date().toISOString(),
};
console.log('🎭 Mock API Response:', mockResponse);
return NextResponse.json(mockResponse, { status: 201 });
} catch (error) {
console.error('❌ Mock API Error:', error);
return NextResponse.json(
{
success: false,
errorCode: 'MOCK_ERROR',
message: 'Mock API 오류가 발생했습니다',
details: error instanceof Error ? error.message : 'Unknown error',
},
{ status: 500 }
);
}
}