## 주요 변경사항 ### 아키텍처 개선 - Clean Architecture 패턴 적용 (Domain, Data, Presentation 레이어 분리) - Use Case 패턴 도입으로 비즈니스 로직 캡슐화 - Repository 패턴으로 데이터 접근 추상화 - 의존성 주입 구조 개선 ### 상태 관리 최적화 - 모든 Controller에서 불필요한 상태 관리 로직 제거 - 페이지네이션 로직 통일 및 간소화 - 에러 처리 로직 개선 (에러 메시지 한글화) - 로딩 상태 관리 최적화 ### Mock 서비스 제거 - MockDataService 완전 제거 - 모든 화면을 실제 API 전용으로 전환 - 불필요한 Mock 관련 코드 정리 ### UI/UX 개선 - Overview 화면 대시보드 기능 강화 - 라이선스 만료 알림 위젯 추가 - 사이드바 네비게이션 개선 - 일관된 UI 컴포넌트 사용 ### 코드 품질 - 중복 코드 제거 및 함수 추출 - 파일별 책임 분리 명확화 - 테스트 코드 업데이트 ## 영향 범위 - 모든 화면의 Controller 리팩토링 - API 통신 레이어 구조 개선 - 에러 처리 및 로깅 시스템 개선 ## 향후 계획 - 단위 테스트 커버리지 확대 - 통합 테스트 시나리오 추가 - 성능 모니터링 도구 통합
149 lines
3.0 KiB
Dart
149 lines
3.0 KiB
Dart
import 'package:dartz/dartz.dart';
|
|
|
|
/// 실패 처리를 위한 추상 클래스
|
|
abstract class Failure {
|
|
final String message;
|
|
final String? code;
|
|
|
|
const Failure({
|
|
required this.message,
|
|
this.code,
|
|
});
|
|
|
|
@override
|
|
bool operator ==(Object other) =>
|
|
identical(this, other) ||
|
|
other is Failure &&
|
|
runtimeType == other.runtimeType &&
|
|
message == other.message &&
|
|
code == other.code;
|
|
|
|
@override
|
|
int get hashCode => message.hashCode ^ code.hashCode;
|
|
}
|
|
|
|
/// 서버 실패
|
|
class ServerFailure extends Failure {
|
|
final int? statusCode;
|
|
final Map<String, dynamic>? errors;
|
|
final dynamic originalError;
|
|
|
|
const ServerFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.statusCode,
|
|
this.errors,
|
|
this.originalError,
|
|
});
|
|
}
|
|
|
|
/// 캐시 실패
|
|
class CacheFailure extends Failure {
|
|
const CacheFailure({
|
|
required super.message,
|
|
super.code,
|
|
});
|
|
}
|
|
|
|
/// 네트워크 실패
|
|
class NetworkFailure extends Failure {
|
|
final dynamic originalError;
|
|
|
|
const NetworkFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.originalError,
|
|
});
|
|
}
|
|
|
|
/// 인증 실패
|
|
class AuthenticationFailure extends Failure {
|
|
final dynamic originalError;
|
|
|
|
const AuthenticationFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.originalError,
|
|
});
|
|
}
|
|
|
|
/// 권한 실패
|
|
class AuthorizationFailure extends Failure {
|
|
final dynamic originalError;
|
|
|
|
const AuthorizationFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.originalError,
|
|
});
|
|
}
|
|
|
|
/// 유효성 검사 실패
|
|
class ValidationFailure extends Failure {
|
|
final Map<String, List<String>>? fieldErrors;
|
|
final Map<String, dynamic>? errors; // 기존 코드와 호환성을 위해 추가
|
|
final dynamic originalError; // 원본 에러 정보
|
|
|
|
const ValidationFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.fieldErrors,
|
|
this.errors,
|
|
this.originalError,
|
|
});
|
|
}
|
|
|
|
/// 리소스 찾을 수 없음 실패
|
|
class NotFoundFailure extends Failure {
|
|
final String? resourceType;
|
|
final String? resourceId;
|
|
|
|
const NotFoundFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.resourceType,
|
|
this.resourceId,
|
|
});
|
|
}
|
|
|
|
/// 중복 리소스 실패
|
|
class DuplicateFailure extends Failure {
|
|
final String? field;
|
|
final String? value;
|
|
|
|
const DuplicateFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.field,
|
|
this.value,
|
|
});
|
|
}
|
|
|
|
/// 비즈니스 로직 실패
|
|
class BusinessFailure extends Failure {
|
|
const BusinessFailure({
|
|
required super.message,
|
|
super.code,
|
|
});
|
|
}
|
|
|
|
/// 알 수 없는 실패
|
|
class UnknownFailure extends Failure {
|
|
final dynamic originalError;
|
|
|
|
const UnknownFailure({
|
|
required super.message,
|
|
super.code,
|
|
this.originalError,
|
|
});
|
|
}
|
|
|
|
/// AuthFailure는 AuthenticationFailure의 별칭
|
|
typedef AuthFailure = AuthenticationFailure;
|
|
|
|
/// PermissionFailure는 AuthorizationFailure의 별칭
|
|
typedef PermissionFailure = AuthorizationFailure;
|
|
|
|
/// 타입 정의
|
|
typedef FutureEither<T> = Future<Either<Failure, T>>;
|
|
typedef FutureVoid = FutureEither<void>; |