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:
@@ -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());
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user