feat: WebSocket temps réel + Finance Workflow + corrections

- Task #6: WebSocket /ws/dashboard + Kafka events (5 topics)
  * Backend: KafkaEventProducer, KafkaEventConsumer
  * Mobile: WebSocketService (reconnection, heartbeat, typed events)
  * DashboardBloc: Auto-refresh depuis WebSocket events

- Finance Workflow: approbations + budgets (backend + mobile)
  * Backend: entities, services, resources, migrations Flyway V6
  * Mobile: features finance_workflow complète avec BLoC

- Corrections DI: interfaces IRepository partout
  * IProfileRepository, IOrganizationRepository, IMembreRepository
  * GetIt configuré avec @injectable

- Spec-Kit: constitution + templates mis à jour
  * .specify/memory/constitution.md enrichie
  * Templates agent, plan, spec, tasks, checklist

- Nettoyage: fichiers temporaires supprimés

Signed-off-by: lions dev Team
This commit is contained in:
dahoud
2026-03-15 02:12:17 +00:00
parent bbc409de9d
commit e8ad874015
635 changed files with 58160 additions and 20674 deletions

View File

@@ -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();
}

View 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();
}
}

View 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();
}
}

View 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();
}
}

View 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();
}
}

View 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);
}
}