Add notification
This commit is contained in:
@@ -3,6 +3,7 @@ import 'package:cloud_firestore/cloud_firestore.dart';
|
||||
import '../models/user.dart';
|
||||
import '../services/auth_service.dart';
|
||||
import '../services/error_service.dart';
|
||||
import '../services/notification_service.dart';
|
||||
|
||||
/// Repository for authentication operations and user data management.
|
||||
///
|
||||
@@ -57,6 +58,7 @@ class AuthRepository {
|
||||
email: email,
|
||||
password: password,
|
||||
);
|
||||
await _saveFCMToken(firebaseUser.user!.uid);
|
||||
return await getUserFromFirestore(firebaseUser.user!.uid);
|
||||
} catch (e) {
|
||||
_errorService.showError(message: 'Utilisateur ou mot de passe incorrect');
|
||||
@@ -102,6 +104,9 @@ class AuthRepository {
|
||||
);
|
||||
|
||||
await _firestore.collection('users').doc(user.id).set(user.toMap());
|
||||
if (user.id != null) {
|
||||
await _saveFCMToken(user.id!);
|
||||
}
|
||||
return user;
|
||||
} catch (e) {
|
||||
_errorService.showError(message: 'Erreur lors de la création du compte');
|
||||
@@ -149,6 +154,9 @@ class AuthRepository {
|
||||
);
|
||||
|
||||
await _firestore.collection('users').doc(user.id).set(user.toMap());
|
||||
if (user.id != null) {
|
||||
await _saveFCMToken(user.id!);
|
||||
}
|
||||
return user;
|
||||
}
|
||||
return null;
|
||||
@@ -163,6 +171,9 @@ class AuthRepository {
|
||||
final firebaseUser = await _authService.signInWithGoogle();
|
||||
final user = await getUserFromFirestore(firebaseUser.user!.uid);
|
||||
if (user != null) {
|
||||
if (user.id != null) {
|
||||
await _saveFCMToken(user.id!);
|
||||
}
|
||||
return user;
|
||||
} else {
|
||||
throw Exception('Utilisateur non trouvé');
|
||||
@@ -211,6 +222,9 @@ class AuthRepository {
|
||||
);
|
||||
|
||||
await _firestore.collection('users').doc(user.id).set(user.toMap());
|
||||
if (user.id != null) {
|
||||
await _saveFCMToken(user.id!);
|
||||
}
|
||||
return user;
|
||||
}
|
||||
return null;
|
||||
@@ -225,6 +239,9 @@ class AuthRepository {
|
||||
final firebaseUser = await _authService.signInWithApple();
|
||||
final user = await getUserFromFirestore(firebaseUser.user!.uid);
|
||||
if (user != null) {
|
||||
if (user.id != null) {
|
||||
await _saveFCMToken(user.id!);
|
||||
}
|
||||
return user;
|
||||
} else {
|
||||
throw Exception('Utilisateur non trouvé');
|
||||
@@ -258,7 +275,7 @@ class AuthRepository {
|
||||
///
|
||||
/// [uid] - The Firebase user ID to look up
|
||||
///
|
||||
/// Returns the [User] model if found, null otherwise.
|
||||
/// Returns the [User] model if successful, null otherwise.
|
||||
Future<User?> getUserFromFirestore(String uid) async {
|
||||
try {
|
||||
final doc = await _firestore.collection('users').doc(uid).get();
|
||||
@@ -271,4 +288,19 @@ class AuthRepository {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
/// Helper method to save the FCM token for the authenticated user.
|
||||
Future<void> _saveFCMToken(String userId) async {
|
||||
try {
|
||||
final token = await NotificationService().getFCMToken();
|
||||
if (token != null) {
|
||||
await _firestore.collection('users').doc(userId).set({
|
||||
'fcmToken': token,
|
||||
}, SetOptions(merge: true));
|
||||
}
|
||||
} catch (e) {
|
||||
// Non-blocking error
|
||||
print('Error saving FCM token: $e');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user