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 de profil (Clean Architecture - Domain Layer)
library profile_repository;
import '../../../members/data/models/membre_complete_model.dart';
/// Interface du repository pour la gestion du profil utilisateur
/// Contrat défini dans la couche Domain, implémenté dans la couche Data
abstract class IProfileRepository {
/// Récupère le profil du membre connecté (GET /api/membres/me)
Future<MembreCompletModel?> getMe();
/// Récupère un profil par email (recherche)
Future<MembreCompletModel?> getProfileByEmail(String email);
/// Met à jour le profil d'un membre (PUT /api/membres/{id})
Future<MembreCompletModel> updateProfile(String id, MembreCompletModel membre);
/// Met à jour la photo de profil
/// Utilise l'endpoint de mise à jour générale avec copyWith
Future<MembreCompletModel> updateAvatar(String id, String photoUrl);
/// Change le mot de passe via Keycloak (POST /api/auth/change-password)
/// Proxy vers l'API Keycloak pour changement de mot de passe
Future<void> changePassword(String id, String oldPassword, String newPassword);
/// Met à jour les préférences utilisateur (PUT /api/membres/{id}/preferences)
/// Fallback sur stockage local si endpoint backend non disponible
Future<Map<String, dynamic>> updatePreferences(String id, Map<String, dynamic> preferences);
/// Supprime le compte utilisateur (POST /api/membres/{id}/desactiver)
/// Soft delete: marque le compte comme inactif au lieu de supprimer les données
Future<void> deleteAccount(String id);
}