Files
superport/lib/core/errors/failures.dart
JiWoong Sul 162fe08618
Some checks failed
Flutter Test & Quality Check / Test on macos-latest (push) Has been cancelled
Flutter Test & Quality Check / Test on ubuntu-latest (push) Has been cancelled
Flutter Test & Quality Check / Build APK (push) Has been cancelled
refactor: Clean Architecture 적용 및 코드베이스 전면 리팩토링
## 주요 변경사항

### 아키텍처 개선
- Clean Architecture 패턴 적용 (Domain, Data, Presentation 레이어 분리)
- Use Case 패턴 도입으로 비즈니스 로직 캡슐화
- Repository 패턴으로 데이터 접근 추상화
- 의존성 주입 구조 개선

### 상태 관리 최적화
- 모든 Controller에서 불필요한 상태 관리 로직 제거
- 페이지네이션 로직 통일 및 간소화
- 에러 처리 로직 개선 (에러 메시지 한글화)
- 로딩 상태 관리 최적화

### Mock 서비스 제거
- MockDataService 완전 제거
- 모든 화면을 실제 API 전용으로 전환
- 불필요한 Mock 관련 코드 정리

### UI/UX 개선
- Overview 화면 대시보드 기능 강화
- 라이선스 만료 알림 위젯 추가
- 사이드바 네비게이션 개선
- 일관된 UI 컴포넌트 사용

### 코드 품질
- 중복 코드 제거 및 함수 추출
- 파일별 책임 분리 명확화
- 테스트 코드 업데이트

## 영향 범위
- 모든 화면의 Controller 리팩토링
- API 통신 레이어 구조 개선
- 에러 처리 및 로깅 시스템 개선

## 향후 계획
- 단위 테스트 커버리지 확대
- 통합 테스트 시나리오 추가
- 성능 모니터링 도구 통합
2025-08-11 00:04:28 +09:00

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>;