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

@@ -6,12 +6,14 @@ import 'package:superport/services/mock_data_service.dart';
import 'package:superport/utils/constants.dart';
import 'package:superport/core/errors/failures.dart';
import 'package:superport/models/equipment_unified_model.dart' as legacy;
import 'package:superport/core/utils/debug_logger.dart';
// companyTypeToString 함수 import
import 'package:superport/utils/constants.dart'
show companyTypeToString, CompanyType;
import 'package:superport/models/company_model.dart';
import 'package:superport/models/address_model.dart';
import 'package:superport/core/utils/equipment_status_converter.dart';
// 장비 목록 화면의 상태 및 비즈니스 로직을 담당하는 컨트롤러
class EquipmentListController extends ChangeNotifier {
@@ -56,19 +58,48 @@ class EquipmentListController extends ChangeNotifier {
try {
if (_useApi) {
// API 호출
final apiEquipments = await _equipmentService.getEquipments(
DebugLogger.log('장비 목록 API 호출 시작', tag: 'EQUIPMENT', data: {
'page': _currentPage,
'perPage': _perPage,
'statusFilter': selectedStatusFilter,
});
// DTO 형태로 가져와서 status 정보 유지
final apiEquipmentDtos = await _equipmentService.getEquipmentsWithStatus(
page: _currentPage,
perPage: _perPage,
status: selectedStatusFilter,
status: selectedStatusFilter != null ? EquipmentStatusConverter.clientToServer(selectedStatusFilter) : null,
);
// API 모델을 UnifiedEquipment로 변환
final List<UnifiedEquipment> unifiedEquipments = apiEquipments.map((equipment) {
DebugLogger.log('장비 목록 API 응답', tag: 'EQUIPMENT', data: {
'count': apiEquipmentDtos.length,
'firstItem': apiEquipmentDtos.isNotEmpty ? {
'id': apiEquipmentDtos.first.id,
'equipmentNumber': apiEquipmentDtos.first.equipmentNumber,
'manufacturer': apiEquipmentDtos.first.manufacturer,
'status': apiEquipmentDtos.first.status,
} : null,
});
// DTO를 UnifiedEquipment로 변환 (status 정보 포함)
final List<UnifiedEquipment> unifiedEquipments = apiEquipmentDtos.map((dto) {
final equipment = Equipment(
id: dto.id,
manufacturer: dto.manufacturer,
name: dto.modelName ?? dto.equipmentNumber,
category: '', // 세부 정보는 상세 조회에서 가져와야 함
subCategory: '',
subSubCategory: '',
serialNumber: dto.serialNumber,
quantity: 1,
inDate: dto.createdAt,
);
return UnifiedEquipment(
id: equipment.id,
id: dto.id,
equipment: equipment,
date: DateTime.now(), // 실제로는 API에서 날짜 정보를 가져와야 함
status: EquipmentStatus.in_, // 기본값, 실제로는 API에서 가져와야 함
date: dto.createdAt,
status: EquipmentStatusConverter.serverToClient(dto.status), // 서버 status를 클라이언트 status로 변환
);
}).toList();