refactor(apps): 重构数据层目录结构并新增启动预热编排器
This commit is contained in:
@@ -2,42 +2,37 @@ import 'package:dio/dio.dart';
|
||||
import 'package:flutter_secure_storage/flutter_secure_storage.dart';
|
||||
import 'package:get_it/get_it.dart';
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
import '../../data/cache/cache_invalidator.dart';
|
||||
import '../../data/cache/hybrid_cache_store.dart';
|
||||
import '../../data/cache/memory_cache_store.dart';
|
||||
import '../../data/cache/persistent_cache_store.dart';
|
||||
import '../../data/repositories/calendar_event_repository.dart';
|
||||
import '../../data/repositories/calendar_repository.dart';
|
||||
import '../../data/repositories/friend_repository.dart';
|
||||
import '../../data/repositories/inbox_repository.dart';
|
||||
import '../../data/repositories/user_repository.dart';
|
||||
import '../../data/cache/cache_store.dart';
|
||||
import '../../features/calendar/data/repositories/calendar_repository.dart';
|
||||
import '../../features/contacts/data/repositories/friend_repository.dart';
|
||||
import '../../features/messages/data/repositories/inbox_repository.dart';
|
||||
import '../../features/contacts/data/repositories/user_repository.dart';
|
||||
import '../../core/auth/session_controller.dart';
|
||||
import '../../core/network/api_client.dart';
|
||||
import '../../core/network/i_api_client.dart';
|
||||
import '../../core/storage/app_preferences.dart';
|
||||
import '../../core/storage/token_storage.dart';
|
||||
import '../../data/network/api_client.dart';
|
||||
import '../../data/network/i_api_client.dart';
|
||||
import '../../data/storage/token_storage.dart';
|
||||
import '../../core/config/env.dart';
|
||||
import '../../data/services/local_notification_service.dart';
|
||||
import '../../features/auth/data/auth_api.dart';
|
||||
import '../../features/auth/data/auth_repository.dart';
|
||||
import '../../features/auth/data/auth_repository_impl.dart';
|
||||
import '../../features/auth/data/apis/auth_api.dart';
|
||||
import '../../features/auth/data/repositories/auth_repository.dart';
|
||||
import '../../features/auth/data/repositories/auth_repository_impl.dart';
|
||||
import '../../features/auth/presentation/bloc/auth_bloc.dart';
|
||||
import '../../features/auth/presentation/bloc/auth_event.dart';
|
||||
import '../../features/chat/presentation/bloc/chat_bloc.dart';
|
||||
import '../../features/calendar/data/calendar_api.dart';
|
||||
import '../../data/services/calendar_service.dart';
|
||||
import '../../features/notification/domain/services/reminder_action_executor.dart';
|
||||
import '../../features/chat/data/repositories/chat_history_repository.dart';
|
||||
import '../../features/calendar/data/apis/calendar_api.dart';
|
||||
import '../../features/calendar/data/services/calendar_service.dart';
|
||||
import '../../shared/state/calendar_state_manager.dart';
|
||||
import '../../features/contacts/data/friends_api.dart';
|
||||
import '../../features/messages/data/inbox_api.dart';
|
||||
import '../../features/settings/data/settings_api.dart';
|
||||
import '../../features/settings/data/services/automation_jobs_api.dart';
|
||||
import '../../features/settings/data/services/user_profile_cache_repository.dart';
|
||||
import '../../features/contacts/data/apis/friends_api.dart';
|
||||
import '../../features/messages/data/apis/inbox_api.dart';
|
||||
import '../../features/settings/data/apis/settings_api.dart';
|
||||
import '../../features/settings/data/apis/automation_jobs_api.dart';
|
||||
import '../../features/settings/data/repositories/user_profile_cache_repository.dart';
|
||||
import '../../features/settings/data/services/user_profile_service.dart';
|
||||
import '../../features/settings/data/services/memory_service.dart';
|
||||
import '../../features/contacts/data/users/users_api.dart';
|
||||
import '../../features/todo/data/todo_api.dart';
|
||||
import '../../features/todo/data/todo_repository.dart';
|
||||
import '../../features/contacts/data/apis/users_api.dart';
|
||||
import '../../features/todo/data/apis/todo_api.dart';
|
||||
import '../../features/todo/data/repositories/todo_repository.dart';
|
||||
import '../services/app_prewarm_orchestrator.dart';
|
||||
import '../services/auth_session_controller.dart';
|
||||
|
||||
final sl = GetIt.instance;
|
||||
@@ -71,10 +66,9 @@ Future<void> configureDependencies() async {
|
||||
|
||||
final sharedPreferences = await SharedPreferences.getInstance();
|
||||
sl.registerSingleton<SharedPreferences>(sharedPreferences);
|
||||
sl.registerSingleton<AppPreferences>(AppPreferences(sharedPreferences));
|
||||
|
||||
final memoryCacheStore = MemoryCacheStore();
|
||||
final persistentCacheStore = PersistentCacheStore();
|
||||
final persistentCacheStore = PersistentCacheStore(prefs: sharedPreferences);
|
||||
final hybridCacheStore = HybridCacheStore(
|
||||
memory: memoryCacheStore,
|
||||
persistent: persistentCacheStore,
|
||||
@@ -100,10 +94,6 @@ Future<void> configureDependencies() async {
|
||||
|
||||
final calendarApi = CalendarApi(apiClient);
|
||||
sl.registerSingleton<CalendarApi>(calendarApi);
|
||||
sl.registerSingleton<CalendarEventRepository>(
|
||||
CalendarEventRepositoryImpl(apiClient),
|
||||
);
|
||||
|
||||
final calendarService = CalendarService(
|
||||
apiClient: apiClient,
|
||||
invalidator: sl<CacheInvalidator>(),
|
||||
@@ -116,17 +106,11 @@ Future<void> configureDependencies() async {
|
||||
);
|
||||
sl.registerSingleton<CalendarRepository>(calendarRepository);
|
||||
|
||||
sl.registerSingleton<LocalNotificationService>(LocalNotificationService());
|
||||
|
||||
final reminderActionExecutor = ReminderActionExecutor(
|
||||
calendarService: calendarService,
|
||||
notificationService: sl<LocalNotificationService>(),
|
||||
);
|
||||
sl.registerSingleton<ReminderActionExecutor>(reminderActionExecutor);
|
||||
|
||||
final friendsApi = FriendsApi(apiClient);
|
||||
sl.registerSingleton<FriendsApi>(friendsApi);
|
||||
sl.registerSingleton<FriendRepository>(FriendRepositoryImpl(apiClient));
|
||||
sl.registerSingleton<FriendRepository>(
|
||||
FriendRepositoryImpl(apiClient: apiClient, store: hybridCacheStore),
|
||||
);
|
||||
|
||||
final settingsApi = SettingsApi(apiClient);
|
||||
sl.registerSingleton<SettingsApi>(settingsApi);
|
||||
@@ -139,7 +123,15 @@ Future<void> configureDependencies() async {
|
||||
|
||||
final inboxApi = InboxApi(apiClient);
|
||||
sl.registerSingleton<InboxApi>(inboxApi);
|
||||
sl.registerSingleton<InboxRepository>(InboxRepositoryImpl(apiClient));
|
||||
sl.registerSingleton<InboxRepository>(
|
||||
InboxRepositoryImpl(apiClient: apiClient, store: hybridCacheStore),
|
||||
);
|
||||
|
||||
final chatHistoryRepository = ChatHistoryRepository(
|
||||
apiClient: apiClient,
|
||||
store: hybridCacheStore,
|
||||
);
|
||||
sl.registerSingleton<ChatHistoryRepository>(chatHistoryRepository);
|
||||
|
||||
final todoApi = TodoApi(apiClient);
|
||||
sl.registerSingleton<TodoApi>(todoApi);
|
||||
@@ -163,10 +155,20 @@ Future<void> configureDependencies() async {
|
||||
);
|
||||
sl.registerSingleton<AuthRepository>(authRepository);
|
||||
|
||||
sl.registerSingleton<AppPrewarmOrchestrator>(
|
||||
AppPrewarmOrchestrator(
|
||||
calendarRepository: calendarRepository,
|
||||
inboxRepository: sl<InboxRepository>(),
|
||||
chatHistoryRepository: chatHistoryRepository,
|
||||
),
|
||||
);
|
||||
|
||||
final authBloc = AuthBloc(authRepository);
|
||||
sl.registerSingleton<AuthBloc>(authBloc);
|
||||
sl.registerSingleton<SessionController>(AuthSessionController(authBloc));
|
||||
sl.registerSingleton<ChatBloc>(ChatBloc(apiClient: apiClient));
|
||||
sl.registerSingleton<ChatBloc>(
|
||||
ChatBloc(apiClient: apiClient, historyRepository: chatHistoryRepository),
|
||||
);
|
||||
|
||||
apiClient.setRefreshCallback((token) async {
|
||||
try {
|
||||
|
||||
Reference in New Issue
Block a user