- 네트워크 레이어 구현 (Dio 기반 ApiClient) - 환경별 설정 관리 시스템 구축 - 의존성 주입 설정 (GetIt) - API 엔드포인트 상수 정의 - 인터셉터 구현 (Auth, Error, Logging) - 프로젝트 아키텍처 개선 (core, data, di 디렉토리 구조) - API 통합 계획서 및 요구사항 문서 작성 - 필요 패키지 추가 (dio, flutter_secure_storage, get_it 등)
65 lines
1.7 KiB
Dart
65 lines
1.7 KiB
Dart
import 'package:flutter_dotenv/flutter_dotenv.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 {
|
|
return dotenv.env['API_BASE_URL'] ?? 'http://localhost:8080/api/v1';
|
|
}
|
|
|
|
/// API 타임아웃 (밀리초)
|
|
static int get apiTimeout {
|
|
final timeoutStr = dotenv.env['API_TIMEOUT'] ?? '30000';
|
|
return int.tryParse(timeoutStr) ?? 30000;
|
|
}
|
|
|
|
/// 로깅 활성화 여부
|
|
static bool get enableLogging {
|
|
final loggingStr = dotenv.env['ENABLE_LOGGING'] ?? 'false';
|
|
return loggingStr.toLowerCase() == 'true';
|
|
}
|
|
|
|
/// 환경 초기화
|
|
static Future<void> initialize([String? environment]) async {
|
|
_environment = environment ??
|
|
const String.fromEnvironment('ENVIRONMENT', defaultValue: dev);
|
|
|
|
final envFile = _getEnvFile();
|
|
await dotenv.load(fileName: envFile);
|
|
}
|
|
|
|
/// 환경별 파일 경로 반환
|
|
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);
|
|
}
|
|
} |