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:
JiWoong Sul
2025-07-31 19:15:39 +09:00
parent ad2c699ff7
commit f08b7fec79
89 changed files with 10521 additions and 892 deletions

View File

@@ -76,14 +76,31 @@ class CompanyRemoteDataSourceImpl implements CompanyRemoteDataSource {
);
if (response.statusCode == 200) {
final apiResponse = ApiResponse<PaginatedResponse<CompanyListDto>>.fromJson(
response.data,
(json) => PaginatedResponse<CompanyListDto>.fromJson(
json as Map<String, dynamic>,
(item) => CompanyListDto.fromJson(item as Map<String, dynamic>),
),
);
return apiResponse.data!;
// API 응답을 직접 파싱
final responseData = response.data;
if (responseData != null && responseData['success'] == true && responseData['data'] != null) {
final List<dynamic> dataList = responseData['data'];
final pagination = responseData['pagination'] ?? {};
// CompanyListDto로 변환
final items = dataList.map((item) => CompanyListDto.fromJson(item as Map<String, dynamic>)).toList();
// PaginatedResponse 생성
return PaginatedResponse<CompanyListDto>(
items: items,
page: pagination['page'] ?? page,
size: pagination['per_page'] ?? perPage,
totalElements: pagination['total'] ?? 0,
totalPages: pagination['total_pages'] ?? 1,
first: (pagination['page'] ?? page) == 1,
last: (pagination['page'] ?? page) == (pagination['total_pages'] ?? 1),
);
} else {
throw ApiException(
message: responseData?['error']?['message'] ?? 'Failed to load companies',
statusCode: response.statusCode,
);
}
} else {
throw ApiException(
message: 'Failed to load companies',