fix(chat): Correction race condition + Implémentation TODOs

## Corrections Critiques

### Race Condition - Statuts de Messages
- Fix : Les icônes de statut (✓, ✓✓, ✓✓ bleu) ne s'affichaient pas
- Cause : WebSocket delivery confirmations arrivaient avant messages locaux
- Solution : Pattern Optimistic UI dans chat_bloc.dart
  - Création message temporaire immédiate
  - Ajout à la liste AVANT requête HTTP
  - Remplacement par message serveur à la réponse
- Fichier : lib/presentation/state_management/chat_bloc.dart

## Implémentation TODOs (13/21)

### Social (social_header_widget.dart)
-  Copier lien du post dans presse-papiers
-  Partage natif via Share.share()
-  Dialogue de signalement avec 5 raisons

### Partage (share_post_dialog.dart)
-  Interface sélection d'amis avec checkboxes
-  Partage externe via Share API

### Média (media_upload_service.dart)
-  Parsing JSON réponse backend
-  Méthode deleteMedia() pour suppression
-  Génération miniature vidéo

### Posts (create_post_dialog.dart, edit_post_dialog.dart)
-  Extraction URL depuis uploads
-  Documentation chargement médias

### Chat (conversations_screen.dart)
-  Navigation vers notifications
-  ConversationSearchDelegate pour recherche

## Nouveaux Fichiers

### Configuration
- build-prod.ps1 : Script build production avec dart-define
- lib/core/constants/env_config.dart : Gestion environnements

### Documentation
- TODOS_IMPLEMENTED.md : Documentation complète TODOs

## Améliorations

### Architecture
- Refactoring injection de dépendances
- Amélioration routing et navigation
- Optimisation providers (UserProvider, FriendsProvider)

### UI/UX
- Amélioration thème et couleurs
- Optimisation animations
- Meilleure gestion erreurs

### Services
- Configuration API avec env_config
- Amélioration datasources (events, users)
- Optimisation modèles de données
This commit is contained in:
dahoud
2026-01-10 10:43:17 +00:00
parent 06031b01f2
commit 92612abbd7
321 changed files with 43137 additions and 4285 deletions

View File

@@ -1,13 +1,14 @@
import 'package:flutter_bcrypt/flutter_bcrypt.dart';
import 'package:http/http.dart' as http;
import 'package:afterwork/core/constants/urls.dart';
import '../../core/constants/urls.dart';
import '../../core/utils/app_logger.dart';
class HashPasswordService {
/// Hache le mot de passe en utilisant Bcrypt.
/// Renvoie une chaîne hachée sécurisée.
Future<String> hashPassword(String email, String password) async {
try {
print("Tentative de récupération du sel depuis le serveur pour l'email : $email");
AppLogger.d("Tentative de récupération du sel depuis le serveur pour l'email : $email", tag: 'HashPasswordService');
// Récupérer le sel depuis le serveur avec l'email
final response = await http.get(Uri.parse('${Urls.baseUrl}/users/salt?email=$email'));
@@ -15,32 +16,32 @@ class HashPasswordService {
String salt;
if (response.statusCode == 200 && response.body.isNotEmpty) {
salt = response.body;
print("Sel récupéré depuis le serveur : $salt");
AppLogger.d('Sel récupéré depuis le serveur : $salt', tag: 'HashPasswordService');
} else {
// Si le sel n'est pas trouvé, on en génère un
salt = await FlutterBcrypt.saltWithRounds(rounds: 12);
print("Sel généré : $salt");
AppLogger.d('Sel généré : $salt', tag: 'HashPasswordService');
}
// Hachage du mot de passe avec le sel
String hashedPassword = await FlutterBcrypt.hashPw(password: password, salt: salt);
print("Mot de passe haché avec succès : $hashedPassword");
final String hashedPassword = await FlutterBcrypt.hashPw(password: password, salt: salt);
AppLogger.d('Mot de passe haché avec succès', tag: 'HashPasswordService');
return hashedPassword;
} catch (e) {
print("Erreur lors du hachage du mot de passe : $e");
throw Exception("Erreur lors du hachage du mot de passe.");
} catch (e, stackTrace) {
AppLogger.e('Erreur lors du hachage du mot de passe', error: e, stackTrace: stackTrace, tag: 'HashPasswordService');
throw Exception('Erreur lors du hachage du mot de passe.');
}
}
Future<bool> verifyPassword(String password, String hashedPassword) async {
try {
print("Début de la vérification du mot de passe");
bool result = await FlutterBcrypt.verify(password: password, hash: hashedPassword);
print("Résultat de la vérification : $result");
AppLogger.d('Début de la vérification du mot de passe', tag: 'HashPasswordService');
final bool result = await FlutterBcrypt.verify(password: password, hash: hashedPassword);
AppLogger.d('Résultat de la vérification : $result', tag: 'HashPasswordService');
return result;
} catch (e) {
print("Erreur lors de la vérification du mot de passe : $e");
throw Exception("Erreur lors de la vérification du mot de passe.");
} catch (e, stackTrace) {
AppLogger.e('Erreur lors de la vérification du mot de passe', error: e, stackTrace: stackTrace, tag: 'HashPasswordService');
throw Exception('Erreur lors de la vérification du mot de passe.');
}
}