Initial commit: unionflow-mobile-apps
Application Flutter complète (sans build artifacts). Signed-off-by: lions dev Team
This commit is contained in:
@@ -0,0 +1,33 @@
|
||||
/// Interface du repository pour la gestion de la configuration système
|
||||
library i_system_config_repository;
|
||||
|
||||
import '../../data/models/system_config_model.dart';
|
||||
import '../../data/models/cache_stats_model.dart';
|
||||
import '../../data/models/system_metrics_model.dart';
|
||||
|
||||
/// Interface définissant le contrat pour la gestion de la configuration système
|
||||
abstract class ISystemConfigRepository {
|
||||
/// Récupère la configuration système actuelle
|
||||
Future<SystemConfigModel> getConfig();
|
||||
|
||||
/// Met à jour la configuration système
|
||||
Future<SystemConfigModel> updateConfig(Map<String, dynamic> config);
|
||||
|
||||
/// Récupère les statistiques du cache
|
||||
Future<CacheStatsModel> getCacheStats();
|
||||
|
||||
/// Récupère les métriques système
|
||||
Future<SystemMetricsModel> getMetrics();
|
||||
|
||||
/// Vide le cache applicatif
|
||||
Future<void> clearCache();
|
||||
|
||||
/// Teste la connexion à la base de données
|
||||
Future<Map<String, dynamic>> testDatabase();
|
||||
|
||||
/// Teste la configuration email
|
||||
Future<Map<String, dynamic>> testEmail();
|
||||
|
||||
/// Réinitialise la configuration aux valeurs par défaut
|
||||
Future<SystemConfigModel> resetConfig();
|
||||
}
|
||||
22
lib/features/settings/domain/usecases/clear_cache.dart
Normal file
22
lib/features/settings/domain/usecases/clear_cache.dart
Normal file
@@ -0,0 +1,22 @@
|
||||
/// Use Case: Vider le cache applicatif
|
||||
library clear_cache;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/system_config_repository.dart';
|
||||
|
||||
/// Vide le cache applicatif
|
||||
///
|
||||
/// Use case pour nettoyer le cache et libérer de l'espace mémoire
|
||||
/// Endpoint: POST /api/system/cache/clear
|
||||
@injectable
|
||||
class ClearCache {
|
||||
final ISystemConfigRepository _repository;
|
||||
|
||||
ClearCache(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// Vide complètement le cache applicatif
|
||||
Future<void> call() async {
|
||||
return _repository.clearCache();
|
||||
}
|
||||
}
|
||||
23
lib/features/settings/domain/usecases/get_cache_stats.dart
Normal file
23
lib/features/settings/domain/usecases/get_cache_stats.dart
Normal file
@@ -0,0 +1,23 @@
|
||||
/// Use Case: Récupérer les statistiques du cache
|
||||
library get_cache_stats;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/system_config_repository.dart';
|
||||
import '../../data/models/cache_stats_model.dart';
|
||||
|
||||
/// Récupère les statistiques du cache applicatif
|
||||
///
|
||||
/// Use case pour consulter l'état du cache (taille, hits/miss, etc.)
|
||||
/// Endpoint: GET /api/system/cache/stats
|
||||
@injectable
|
||||
class GetCacheStats {
|
||||
final ISystemConfigRepository _repository;
|
||||
|
||||
GetCacheStats(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// Retourne les statistiques du cache (CacheStatsModel)
|
||||
Future<CacheStatsModel> call() async {
|
||||
return _repository.getCacheStats();
|
||||
}
|
||||
}
|
||||
23
lib/features/settings/domain/usecases/get_settings.dart
Normal file
23
lib/features/settings/domain/usecases/get_settings.dart
Normal file
@@ -0,0 +1,23 @@
|
||||
/// Use Case: Récupérer la configuration système
|
||||
library get_settings;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/system_config_repository.dart';
|
||||
import '../../data/models/system_config_model.dart';
|
||||
|
||||
/// Récupère la configuration système actuelle
|
||||
///
|
||||
/// Use case pour récupérer tous les paramètres de configuration système
|
||||
/// Endpoint: GET /api/system/config
|
||||
@injectable
|
||||
class GetSettings {
|
||||
final ISystemConfigRepository _repository;
|
||||
|
||||
GetSettings(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// Retourne la configuration système actuelle (SystemConfigModel)
|
||||
Future<SystemConfigModel> call() async {
|
||||
return _repository.getConfig();
|
||||
}
|
||||
}
|
||||
23
lib/features/settings/domain/usecases/reset_settings.dart
Normal file
23
lib/features/settings/domain/usecases/reset_settings.dart
Normal file
@@ -0,0 +1,23 @@
|
||||
/// Use Case: Réinitialiser la configuration système
|
||||
library reset_settings;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/system_config_repository.dart';
|
||||
import '../../data/models/system_config_model.dart';
|
||||
|
||||
/// Réinitialise la configuration système aux valeurs par défaut
|
||||
///
|
||||
/// Use case pour restaurer tous les paramètres à leur état initial
|
||||
/// Endpoint: POST /api/system/config/reset (ou DELETE /api/system/config)
|
||||
@injectable
|
||||
class ResetSettings {
|
||||
final ISystemConfigRepository _repository;
|
||||
|
||||
ResetSettings(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// Restaure la configuration aux valeurs par défaut du système
|
||||
Future<SystemConfigModel> call() async {
|
||||
return _repository.resetConfig();
|
||||
}
|
||||
}
|
||||
24
lib/features/settings/domain/usecases/update_settings.dart
Normal file
24
lib/features/settings/domain/usecases/update_settings.dart
Normal file
@@ -0,0 +1,24 @@
|
||||
/// Use Case: Mettre à jour la configuration système
|
||||
library update_settings;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/system_config_repository.dart';
|
||||
import '../../data/models/system_config_model.dart';
|
||||
|
||||
/// Met à jour la configuration système
|
||||
///
|
||||
/// Use case pour modifier les paramètres de configuration système
|
||||
/// Endpoint: PUT /api/system/config
|
||||
@injectable
|
||||
class UpdateSettings {
|
||||
final ISystemConfigRepository _repository;
|
||||
|
||||
UpdateSettings(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// [config] : Map contenant les paramètres à mettre à jour
|
||||
/// Retourne la configuration mise à jour
|
||||
Future<SystemConfigModel> call(Map<String, dynamic> config) async {
|
||||
return _repository.updateConfig(config);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user