This commit is contained in:
David Adegoke 2025-06-26 21:07:10 +03:00 committed by GitHub
commit f171fad12e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 178 additions and 4 deletions

162
lib/core/reset_service.dart Normal file
View file

@ -0,0 +1,162 @@
import 'package:cake_wallet/core/secure_storage.dart';
import 'package:cake_wallet/entities/secret_store_key.dart';
import 'package:cake_wallet/store/authentication_store.dart';
import 'package:cake_wallet/store/settings_store.dart';
import 'package:cake_wallet/entities/preferences_key.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:cw_core/utils/print_verbose.dart';
class ResetService {
ResetService({
required this.secureStorage,
required this.authenticationStore,
required this.settingsStore,
});
final SecureStorage secureStorage;
final AuthenticationStore authenticationStore;
final SettingsStore settingsStore;
static const List<String> _authKeys = [
SecureKey.allowBiometricalAuthenticationKey,
SecureKey.useTOTP2FA,
SecureKey.shouldRequireTOTP2FAForAccessingWallet,
SecureKey.shouldRequireTOTP2FAForSendsToContact,
SecureKey.shouldRequireTOTP2FAForSendsToNonContact,
SecureKey.shouldRequireTOTP2FAForSendsToInternalWallets,
SecureKey.shouldRequireTOTP2FAForExchangesToInternalWallets,
SecureKey.shouldRequireTOTP2FAForExchangesToExternalWallets,
SecureKey.shouldRequireTOTP2FAForAddingContacts,
SecureKey.shouldRequireTOTP2FAForCreatingNewWallets,
SecureKey.shouldRequireTOTP2FAForAllSecurityAndBackupSettings,
SecureKey.selectedCake2FAPreset,
SecureKey.totpSecretKey,
SecureKey.pinTimeOutDuration,
SecureKey.lastAuthTimeMilliseconds,
'PIN_CODE_PASSWORD',
];
static const List<String> _walletPreferencesKeys = [
PreferencesKey.currentWalletName,
PreferencesKey.currentWalletType,
];
bool _isAuthKey(String key) => _authKeys.contains(key);
/// Checks if this is a new install and clears any existing auth data from Storage
Future<void> resetAuthDataOnNewInstall(SharedPreferences sharedPreferences) async {
try {
final isNewInstall = sharedPreferences.getBool(PreferencesKey.isNewInstall) ?? false;
if (isNewInstall) {
await _clearExistingAuthDataOnNewInstall(sharedPreferences);
}
} catch (e) {
printV('Error during new install auth reset: $e');
}
}
/// Checks if there's existing auth data that should be cleared on new install
Future<void> _clearExistingAuthDataOnNewInstall(SharedPreferences sharedPreferences) async {
final allKeys = await secureStorage.readAll();
final authKeysFound = <String>[];
final walletPrefsFound = <String>[];
for (final key in allKeys.keys) {
if (_isAuthKey(key)) {
authKeysFound.add(key);
}
}
for (final key in _walletPreferencesKeys) {
if (sharedPreferences.containsKey(key)) {
walletPrefsFound.add(key);
}
}
if (authKeysFound.isNotEmpty || walletPrefsFound.isNotEmpty) {
printV(
'Found ${authKeysFound.length} existing auth keys in storage: ${authKeysFound.join(', ')}',
);
printV(
'Found ${walletPrefsFound.length} existing wallet preferences: ${walletPrefsFound.join(', ')}',
);
await resetAuthenticationData(sharedPreferences);
}
}
/// Resets authentication data auth store, storage and settings store
Future<void> resetAuthenticationData(SharedPreferences sharedPreferences) async {
try {
authenticationStore.state = AuthenticationState.uninitialized;
await Future.wait([
_deleteAuthenticationKeys(),
_resetSettingsStoreAuthData(),
_clearWalletPreferences(sharedPreferences),
]);
} catch (e) {
printV('An error occurred during authentication reset: $e');
rethrow;
}
}
/// Resets authentication-related data in SettingsStore to default values
Future<void> _resetSettingsStoreAuthData() async {
settingsStore.useTOTP2FA = false;
settingsStore.totpSecretKey = '';
settingsStore.shouldRequireTOTP2FAForAccessingWallet = false;
settingsStore.shouldRequireTOTP2FAForSendsToContact = false;
settingsStore.shouldRequireTOTP2FAForSendsToNonContact = false;
settingsStore.shouldRequireTOTP2FAForSendsToInternalWallets = false;
settingsStore.shouldRequireTOTP2FAForExchangesToInternalWallets = false;
settingsStore.shouldRequireTOTP2FAForExchangesToExternalWallets = false;
settingsStore.shouldRequireTOTP2FAForAddingContacts = false;
settingsStore.shouldRequireTOTP2FAForCreatingNewWallets = false;
settingsStore.shouldRequireTOTP2FAForAllSecurityAndBackupSettings = false;
settingsStore.allowBiometricalAuthentication = false;
}
Future<void> _clearWalletPreferences(SharedPreferences sharedPreferences) async {
final failedDeletions = <String>[];
for (final key in _walletPreferencesKeys) {
try {
await sharedPreferences.remove(key);
} catch (e) {
failedDeletions.add(key);
}
}
if (failedDeletions.isNotEmpty) {
printV(
'Warning: Failed to delete ${failedDeletions.length} wallet preferences: ${failedDeletions.join(', ')}',
);
} else {
printV('All wallet preferences deleted successfully');
}
}
Future<void> _deleteAuthenticationKeys() async {
final failedDeletions = <String>[];
final deletionFutures = _authKeys.map((key) async {
try {
await secureStorage.delete(key: key);
} catch (e) {
failedDeletions.add(key);
}
});
await Future.wait(deletionFutures);
if (failedDeletions.isNotEmpty) {
printV(
'Warning: Failed to delete ${failedDeletions.length} auth keys: ${failedDeletions.join(', ')}',
);
} else {
printV('All auth keys deleted successfully');
}
}
}

View file

@ -280,6 +280,7 @@ import 'cake_pay/cake_pay_payment_credantials.dart';
import 'package:cake_wallet/view_model/dev/background_sync_logs_view_model.dart';
import 'package:cake_wallet/src/screens/dev/background_sync_logs_page.dart';
import 'package:cake_wallet/core/trade_monitor.dart';
import 'package:cake_wallet/core/reset_service.dart';
final getIt = GetIt.instance;
@ -557,6 +558,14 @@ Future<void> setup({
),
);
getIt.registerFactory<ResetService>(
() => ResetService(
secureStorage: getIt.get<SecureStorage>(),
authenticationStore: getIt.get<AuthenticationStore>(),
settingsStore: getIt.get<SettingsStore>(),
),
);
getIt.registerFactory<AuthViewModel>(() => AuthViewModel(getIt.get<AuthService>(),
getIt.get<SharedPreferences>(), getIt.get<SettingsStore>(), BiometricAuth()));

View file

@ -25,7 +25,6 @@ import 'package:cake_wallet/routes.dart';
import 'package:cake_wallet/src/screens/root/root.dart';
import 'package:cake_wallet/store/app_store.dart';
import 'package:cake_wallet/store/authentication_store.dart';
import 'package:cake_wallet/themes/core/material_base_theme.dart';
import 'package:cake_wallet/themes/utils/theme_provider.dart';
import 'package:cake_wallet/store/settings_store.dart';
import 'package:cake_wallet/utils/device_info.dart';
@ -56,6 +55,7 @@ import 'package:shared_preferences/shared_preferences.dart';
import 'package:cw_core/window_size.dart';
import 'package:logging/logging.dart';
import 'package:cake_wallet/core/trade_monitor.dart';
import 'package:cake_wallet/core/reset_service.dart';
final navigatorKey = GlobalKey<NavigatorState>();
final rootKey = GlobalKey<RootState>();
@ -287,6 +287,9 @@ Future<void> initialSetup({
navigatorKey: navigatorKey,
secureStorage: secureStorage,
);
getIt.get<ResetService>().resetAuthDataOnNewInstall(sharedPreferences);
await bootstrapOffline();
final settingsStore = getIt<SettingsStore>();
if (!settingsStore.currentBuiltinTor) {