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 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);
|
||||
}
|
||||
23
lib/features/profile/domain/usecases/change_password.dart
Normal file
23
lib/features/profile/domain/usecases/change_password.dart
Normal file
@@ -0,0 +1,23 @@
|
||||
/// Use Case: Changer le mot de passe
|
||||
library change_password;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/profile_repository.dart';
|
||||
|
||||
/// Change le mot de passe de l'utilisateur via Keycloak
|
||||
/// Endpoint: POST /api/auth/change-password
|
||||
@injectable
|
||||
class ChangePassword {
|
||||
final IProfileRepository _repository;
|
||||
|
||||
ChangePassword(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// [id] : Identifiant du membre
|
||||
/// [oldPassword] : Ancien mot de passe (validation)
|
||||
/// [newPassword] : Nouveau mot de passe
|
||||
/// Lève une exception si l'ancien mot de passe est incorrect
|
||||
Future<void> call(String id, String oldPassword, String newPassword) async {
|
||||
return _repository.changePassword(id, oldPassword, newPassword);
|
||||
}
|
||||
}
|
||||
23
lib/features/profile/domain/usecases/delete_account.dart
Normal file
23
lib/features/profile/domain/usecases/delete_account.dart
Normal file
@@ -0,0 +1,23 @@
|
||||
/// Use Case: Supprimer le compte utilisateur
|
||||
library delete_account;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/profile_repository.dart';
|
||||
|
||||
/// Supprime le compte utilisateur (soft delete via désactivation)
|
||||
/// Endpoint: POST /api/membres/{id}/desactiver
|
||||
/// Marque le compte comme inactif au lieu de supprimer les données
|
||||
@injectable
|
||||
class DeleteAccount {
|
||||
final IProfileRepository _repository;
|
||||
|
||||
DeleteAccount(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// [id] : Identifiant du membre
|
||||
/// Lance une suppression de compte (soft delete via désactivation)
|
||||
/// L'utilisateur sera déconnecté après cette opération
|
||||
Future<void> call(String id) async {
|
||||
return _repository.deleteAccount(id);
|
||||
}
|
||||
}
|
||||
20
lib/features/profile/domain/usecases/get_profile.dart
Normal file
20
lib/features/profile/domain/usecases/get_profile.dart
Normal file
@@ -0,0 +1,20 @@
|
||||
/// Use Case: Récupérer le profil du membre connecté
|
||||
library get_profile;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../../../members/data/models/membre_complete_model.dart';
|
||||
import '../repositories/profile_repository.dart';
|
||||
|
||||
/// Récupère le profil du membre connecté via l'endpoint /api/membres/me
|
||||
@injectable
|
||||
class GetProfile {
|
||||
final IProfileRepository _repository;
|
||||
|
||||
GetProfile(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// Retourne le profil du membre connecté ou null si non trouvé
|
||||
Future<MembreCompletModel?> call() async {
|
||||
return _repository.getMe();
|
||||
}
|
||||
}
|
||||
23
lib/features/profile/domain/usecases/update_avatar.dart
Normal file
23
lib/features/profile/domain/usecases/update_avatar.dart
Normal file
@@ -0,0 +1,23 @@
|
||||
/// Use Case: Mettre à jour la photo de profil
|
||||
library update_avatar;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../../../members/data/models/membre_complete_model.dart';
|
||||
import '../repositories/profile_repository.dart';
|
||||
|
||||
/// Met à jour la photo de profil (avatar) d'un membre
|
||||
/// Utilise l'endpoint de mise à jour générale avec copyWith
|
||||
@injectable
|
||||
class UpdateAvatar {
|
||||
final IProfileRepository _repository;
|
||||
|
||||
UpdateAvatar(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// [id] : Identifiant du membre
|
||||
/// [photoUrl] : URL de la nouvelle photo de profil
|
||||
/// Retourne le profil mis à jour avec la nouvelle photo
|
||||
Future<MembreCompletModel> call(String id, String photoUrl) async {
|
||||
return _repository.updateAvatar(id, photoUrl);
|
||||
}
|
||||
}
|
||||
24
lib/features/profile/domain/usecases/update_preferences.dart
Normal file
24
lib/features/profile/domain/usecases/update_preferences.dart
Normal file
@@ -0,0 +1,24 @@
|
||||
/// Use Case: Mettre à jour les préférences utilisateur
|
||||
library update_preferences;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../repositories/profile_repository.dart';
|
||||
|
||||
/// Met à jour les préférences utilisateur (langue, notifications, thème, etc.)
|
||||
/// Endpoint: PUT /api/membres/{id}/preferences
|
||||
/// Fallback sur stockage local si endpoint non disponible
|
||||
@injectable
|
||||
class UpdatePreferences {
|
||||
final IProfileRepository _repository;
|
||||
|
||||
UpdatePreferences(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// [id] : Identifiant du membre
|
||||
/// [preferences] : Map contenant les préférences à mettre à jour
|
||||
/// Exemple: { "langue": "fr", "notificationsEmail": true, "theme": "dark" }
|
||||
/// Retourne les préférences mises à jour
|
||||
Future<Map<String, dynamic>> call(String id, Map<String, dynamic> preferences) async {
|
||||
return _repository.updatePreferences(id, preferences);
|
||||
}
|
||||
}
|
||||
22
lib/features/profile/domain/usecases/update_profile.dart
Normal file
22
lib/features/profile/domain/usecases/update_profile.dart
Normal file
@@ -0,0 +1,22 @@
|
||||
/// Use Case: Mettre à jour le profil utilisateur
|
||||
library update_profile;
|
||||
|
||||
import 'package:injectable/injectable.dart';
|
||||
import '../../../members/data/models/membre_complete_model.dart';
|
||||
import '../repositories/profile_repository.dart';
|
||||
|
||||
/// Met à jour les informations du profil utilisateur
|
||||
@injectable
|
||||
class UpdateProfile {
|
||||
final IProfileRepository _repository;
|
||||
|
||||
UpdateProfile(this._repository);
|
||||
|
||||
/// Exécute le use case
|
||||
/// [id] : Identifiant du membre
|
||||
/// [membre] : Modèle avec les données mises à jour
|
||||
/// Retourne le profil mis à jour
|
||||
Future<MembreCompletModel> call(String id, MembreCompletModel membre) async {
|
||||
return _repository.updateProfile(id, membre);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user