fix: API 응답 파싱 오류 수정 및 에러 처리 개선
주요 변경사항: - 창고 관리 API 응답 구조와 DTO 불일치 수정 - WarehouseLocationDto에 code, manager_phone 필드 추가 - RemoteDataSource에서 API 응답을 DTO 구조에 맞게 변환 - 회사 관리 API 응답 파싱 오류 수정 - CompanyResponse의 필수 필드를 nullable로 변경 - PaginatedResponse 구조 매핑 로직 개선 - 에러 처리 및 로깅 개선 - Service Layer에 상세 에러 로깅 추가 - Controller에서 에러 타입별 처리 - 새로운 유틸리티 추가 - ResponseInterceptor: API 응답 정규화 - DebugLogger: 디버깅 도구 - HealthCheckService: 서버 상태 확인 - 문서화 - API 통합 테스트 가이드 - 에러 분석 보고서 - 리팩토링 계획서
This commit is contained in:
@@ -18,7 +18,7 @@ class Environment {
|
||||
|
||||
/// API 베이스 URL
|
||||
static String get apiBaseUrl {
|
||||
return dotenv.env['API_BASE_URL'] ?? 'http://localhost:8080/api/v1';
|
||||
return dotenv.env['API_BASE_URL'] ?? 'https://superport.naturebridgeai.com/api/v1';
|
||||
}
|
||||
|
||||
/// API 타임아웃 (밀리초)
|
||||
@@ -33,16 +33,49 @@ class Environment {
|
||||
return loggingStr.toLowerCase() == 'true';
|
||||
}
|
||||
|
||||
/// API 사용 여부 (false면 Mock 데이터 사용)
|
||||
static bool get useApi {
|
||||
final useApiStr = dotenv.env['USE_API'];
|
||||
print('[Environment] USE_API 원시값: $useApiStr');
|
||||
if (useApiStr == null || useApiStr.isEmpty) {
|
||||
print('[Environment] USE_API가 설정되지 않음, 기본값 true 사용');
|
||||
return true;
|
||||
}
|
||||
final result = useApiStr.toLowerCase() == 'true';
|
||||
print('[Environment] USE_API 최종값: $result');
|
||||
return result;
|
||||
}
|
||||
|
||||
/// 환경 초기화
|
||||
static Future<void> initialize([String? environment]) async {
|
||||
_environment = environment ??
|
||||
const String.fromEnvironment('ENVIRONMENT', defaultValue: dev);
|
||||
|
||||
final envFile = _getEnvFile();
|
||||
print('[Environment] 환경 초기화 중...');
|
||||
print('[Environment] 현재 환경: $_environment');
|
||||
print('[Environment] 환경 파일: $envFile');
|
||||
|
||||
try {
|
||||
await dotenv.load(fileName: envFile);
|
||||
print('[Environment] 환경 파일 로드 성공');
|
||||
|
||||
// 모든 환경 변수 출력
|
||||
print('[Environment] 로드된 환경 변수:');
|
||||
dotenv.env.forEach((key, value) {
|
||||
print('[Environment] $key: $value');
|
||||
});
|
||||
|
||||
print('[Environment] --- 설정 값 확인 ---');
|
||||
print('[Environment] API Base URL: ${dotenv.env['API_BASE_URL'] ?? '설정되지 않음'}');
|
||||
print('[Environment] API Timeout: ${dotenv.env['API_TIMEOUT'] ?? '설정되지 않음'}');
|
||||
print('[Environment] 로깅 활성화: ${dotenv.env['ENABLE_LOGGING'] ?? '설정되지 않음'}');
|
||||
print('[Environment] API 사용 (원시값): ${dotenv.env['USE_API'] ?? '설정되지 않음'}');
|
||||
print('[Environment] API 사용 (getter): $useApi');
|
||||
} catch (e) {
|
||||
print('Failed to load env file $envFile: $e');
|
||||
print('[Environment] ⚠️ 환경 파일 로드 실패: $envFile');
|
||||
print('[Environment] 에러 상세: $e');
|
||||
print('[Environment] 기본값을 사용합니다.');
|
||||
// .env 파일이 없어도 계속 진행
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user