backup: 사용하지 않는 파일 삭제 전 복구 지점

- 전체 371개 파일 중 82개 미사용 파일 식별
- Phase 1: 33개 파일 삭제 예정 (100% 안전)
- Phase 2: 30개 파일 삭제 검토 예정
- Phase 3: 19개 파일 수동 검토 예정

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
JiWoong Sul
2025-09-02 19:51:40 +09:00
parent 650cd4be55
commit c419f8f458
149 changed files with 12934 additions and 3644 deletions

View File

@@ -1,4 +1,5 @@
import 'package:injectable/injectable.dart';
import 'package:superport/core/constants/app_constants.dart';
import 'package:superport/data/models/zipcode_dto.dart';
import 'package:superport/data/repositories/zipcode_repository.dart';
@@ -6,29 +7,20 @@ abstract class ZipcodeUseCase {
/// 우편번호 검색 (페이지네이션 지원)
Future<ZipcodeListResponse> searchZipcodes({
int page = 1,
int limit = 20,
int limit = AppConstants.defaultPageSize,
String? search,
String? sido,
String? gu,
});
/// 우편번호로 정확한 주소 조회
Future<ZipcodeDto?> getZipcodeByNumber(int zipcode);
/// 시도별 구 목록 조회
Future<List<String>> getGuListBySido(String sido);
/// 전체 시도 목록 조회
Future<List<String>> getAllSidoList();
/// 주소 문자열로 우편번호 검색 (최적화된 검색)
Future<List<ZipcodeDto>> searchByAddress(String address);
/// 우편번호 유효성 검사
bool validateZipcode(int zipcode);
/// 검색어 유효성 검사 및 정규화
String normalizeSearchQuery(String query);
/// Hierarchy API - 시도 목록 조회
Future<HierarchyResponse> getHierarchySidos();
/// Hierarchy API - 구/군 목록 조회
Future<HierarchyResponse> getHierarchyGusBySido(String sido);
}
@Injectable(as: ZipcodeUseCase)
@@ -40,14 +32,14 @@ class ZipcodeUseCaseImpl implements ZipcodeUseCase {
@override
Future<ZipcodeListResponse> searchZipcodes({
int page = 1,
int limit = 20,
int limit = AppConstants.defaultPageSize,
String? search,
String? sido,
String? gu,
}) async {
// 비즈니스 로직: 페이지네이션 유효성 검사
if (page < 1) page = 1;
if (limit < 1 || limit > 100) limit = 20;
if (limit < 1 || limit > 100) limit = AppConstants.defaultPageSize;
// 검색어 정규화
final normalizedSearch = search != null && search.isNotEmpty
@@ -63,58 +55,6 @@ class ZipcodeUseCaseImpl implements ZipcodeUseCase {
);
}
@override
Future<ZipcodeDto?> getZipcodeByNumber(int zipcode) async {
// 우편번호 유효성 검사
if (!validateZipcode(zipcode)) {
throw ArgumentError('유효하지 않은 우편번호입니다. (5자리 숫자)');
}
return await _repository.getByZipcode(zipcode);
}
@override
Future<List<String>> getGuListBySido(String sido) async {
if (sido.trim().isEmpty) {
throw ArgumentError('시도명을 입력해주세요.');
}
final normalizedSido = sido.trim();
return await _repository.getGuBySido(normalizedSido);
}
@override
Future<List<String>> getAllSidoList() async {
return await _repository.getAllSido();
}
@override
Future<List<ZipcodeDto>> searchByAddress(String address) async {
if (address.trim().isEmpty) {
return [];
}
final normalizedAddress = normalizeSearchQuery(address);
try {
// 먼저 전체 검색으로 시도
final response = await _repository.search(
search: normalizedAddress,
limit: 10, // 상위 10개만 가져오기
);
return response.items;
} catch (e) {
// 검색 실패 시 빈 목록 반환
return [];
}
}
@override
bool validateZipcode(int zipcode) {
// 한국 우편번호는 5자리 숫자 (00000 ~ 99999)
return zipcode >= 0 && zipcode <= 99999;
}
@override
String normalizeSearchQuery(String query) {
@@ -131,5 +71,18 @@ class ZipcodeUseCaseImpl implements ZipcodeUseCase {
return normalized;
}
@override
Future<HierarchyResponse> getHierarchySidos() async {
return await _repository.getHierarchySidos();
}
@override
Future<HierarchyResponse> getHierarchyGusBySido(String sido) async {
if (sido.trim().isEmpty) {
throw ArgumentError('시도명을 입력해주세요.');
}
return await _repository.getHierarchyGusBySido(sido.trim());
}
}