Files
superport/lib/core/config/environment.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

111 lines
3.3 KiB
Dart

import 'package:flutter_dotenv/flutter_dotenv.dart';
import 'package:flutter/foundation.dart';
/// 환경 설정 관리 클래스
class Environment {
static const String dev = 'development';
static const String prod = 'production';
static late String _environment;
/// 현재 환경
static String get current => _environment;
/// 개발 환경 여부
static bool get isDevelopment => _environment == dev;
/// 프로덕션 환경 여부
static bool get isProduction => _environment == prod;
/// API 베이스 URL
static String get apiBaseUrl {
try {
return dotenv.env['API_BASE_URL'] ?? 'http://43.201.34.104:8080/api/v1';
} catch (e) {
// dotenv가 초기화되지 않은 경우 기본값 반환
return 'http://43.201.34.104:8080/api/v1';
}
}
/// API 타임아웃 (밀리초)
static int get apiTimeout {
try {
final timeoutStr = dotenv.env['API_TIMEOUT'] ?? '30000';
return int.tryParse(timeoutStr) ?? 30000;
} catch (e) {
return 30000;
}
}
/// 로깅 활성화 여부
static bool get enableLogging {
try {
final loggingStr = dotenv.env['ENABLE_LOGGING'] ?? 'false';
return loggingStr.toLowerCase() == 'true';
} catch (e) {
return true; // 테스트 환경에서는 기본적으로 로깅 활성화
}
}
/// API 사용 여부 (Mock 서비스 제거로 항상 true)
static bool get useApi => true;
/// 환경 초기화
static Future<void> initialize([String? environment]) async {
_environment = environment ??
const String.fromEnvironment('ENVIRONMENT', defaultValue: dev);
final envFile = _getEnvFile();
if (kDebugMode) {
debugPrint('[Environment] 환경 초기화 중...');
debugPrint('[Environment] 현재 환경: $_environment');
debugPrint('[Environment] 환경 파일: $envFile');
}
try {
await dotenv.load(fileName: envFile);
if (kDebugMode) {
debugPrint('[Environment] 환경 파일 로드 성공');
// 모든 환경 변수 출력
debugPrint('[Environment] 로드된 환경 변수:');
dotenv.env.forEach((key, value) {
debugPrint('[Environment] $key: $value');
});
debugPrint('[Environment] --- 설정 값 확인 ---');
debugPrint('[Environment] API Base URL: ${dotenv.env['API_BASE_URL'] ?? '설정되지 않음'}');
debugPrint('[Environment] API Timeout: ${dotenv.env['API_TIMEOUT'] ?? '설정되지 않음'}');
debugPrint('[Environment] 로깅 활성화: ${dotenv.env['ENABLE_LOGGING'] ?? '설정되지 않음'}');
}
} catch (e) {
if (kDebugMode) {
debugPrint('[Environment] ⚠️ 환경 파일 로드 실패: $envFile');
debugPrint('[Environment] 에러 상세: $e');
debugPrint('[Environment] 기본값을 사용합니다.');
}
// .env 파일이 없어도 계속 진행
}
}
/// 환경별 파일 경로 반환
static String _getEnvFile() {
switch (_environment) {
case prod:
return '.env.production';
case dev:
default:
return '.env.development';
}
}
/// 환경 변수 가져오기
static String? get(String key) {
return dotenv.env[key];
}
/// 환경 변수 존재 여부 확인
static bool has(String key) {
return dotenv.env.containsKey(key);
}
}