Files
afterwork/lib/data/services/preferences_helper.dart
2024-11-02 15:27:26 +00:00

99 lines
4.1 KiB
Dart

import 'package:shared_preferences/shared_preferences.dart';
/// Classe pour gérer les préférences utilisateur à l'aide de SharedPreferences.
/// Permet de stocker et récupérer des informations de manière non sécurisée,
/// contrairement au stockage sécurisé qui est utilisé pour des données sensibles.
/// Chaque action est loguée pour assurer la traçabilité complète dans le terminal.
class PreferencesHelper {
// Initialisation de SharedPreferences en tant que Future
final Future<SharedPreferences> _prefs = SharedPreferences.getInstance();
/// Sauvegarde une chaîne de caractères (String) dans les préférences.
/// Les actions sont loguées et les erreurs capturées pour garantir une sauvegarde correcte.
Future<void> setString(String key, String value) async {
print("[LOG] Sauvegarde dans les préférences : clé = $key, valeur = $value");
final prefs = await _prefs;
final success = await prefs.setString(key, value);
if (success) {
print("[LOG] Sauvegarde réussie pour la clé : $key");
} else {
print("[ERROR] Échec de la sauvegarde pour la clé : $key");
}
}
/// Récupère une chaîne de caractères depuis les préférences.
/// Retourne la valeur ou null si aucune donnée n'est trouvée.
Future<String?> getString(String key) async {
print("[LOG] Récupération depuis les préférences pour la clé : $key");
final prefs = await _prefs;
final value = prefs.getString(key);
print("[LOG] Valeur récupérée pour la clé $key : $value");
return value;
}
/// Supprime une entrée dans les préférences.
/// Logue chaque étape de la suppression.
Future<void> remove(String key) async {
print("[LOG] Suppression dans les préférences pour la clé : $key");
final prefs = await _prefs;
final success = await prefs.remove(key);
if (success) {
print("[LOG] Suppression réussie pour la clé : $key");
} else {
print("[ERROR] Échec de la suppression pour la clé : $key");
}
}
/// Sauvegarde l'identifiant utilisateur dans les préférences.
/// Logue l'action et assure la robustesse de l'opération.
Future<void> saveUserId(String userId) async {
print("[LOG] Sauvegarde de l'userId dans les préférences : $userId");
await setString('user_id', userId);
}
/// Récupère l'identifiant utilisateur depuis les préférences.
/// Retourne l'ID ou null en cas d'échec.
Future<String?> getUserId() async {
print("[LOG] Récupération de l'userId depuis les préférences.");
return await getString('user_id');
}
/// Sauvegarde le nom d'utilisateur dans les préférences.
/// Logue l'opération pour assurer un suivi complet.
Future<void> saveUserName(String userName) async {
print("[LOG] Sauvegarde du userName dans les préférences : $userName");
await setString('user_name', userName);
}
/// Récupère le nom d'utilisateur depuis les préférences.
/// Retourne le nom ou null en cas d'échec.
Future<String?> getUserName() async {
print("[LOG] Récupération du userName depuis les préférences.");
return await getString('user_name');
}
/// Sauvegarde le prénom de l'utilisateur dans les préférences.
/// Logue l'opération pour assurer un suivi complet.
Future<void> saveUserLastName(String userLastName) async {
print("[LOG] Sauvegarde du userLastName dans les préférences : $userLastName");
await setString('user_last_name', userLastName);
}
/// Récupère le prénom de l'utilisateur depuis les préférences.
/// Retourne le prénom ou null en cas d'échec.
Future<String?> getUserLastName() async {
print("[LOG] Récupération du userLastName depuis les préférences.");
return await getString('user_last_name');
}
/// Supprime toutes les informations utilisateur dans les préférences.
/// Logue chaque étape de la suppression.
Future<void> clearUserInfo() async {
print("[LOG] Suppression des informations utilisateur (userId, userName, userLastName) des préférences.");
await remove('user_id');
await remove('user_name');
await remove('user_last_name');
print("[LOG] Suppression réussie des informations utilisateur.");
}
}