import 'dart:convert'; import 'dart:typed_data'; import 'package:flutter_secure_storage/flutter_secure_storage.dart'; import 'package:hive_flutter/hive_flutter.dart'; import 'package:selfprivacy/logic/models/hive/backblaze_bucket.dart'; import 'package:selfprivacy/logic/models/hive/backblaze_credential.dart'; import 'package:selfprivacy/logic/models/hive/server_details.dart'; import 'package:selfprivacy/logic/models/hive/server_domain.dart'; import 'package:selfprivacy/logic/models/hive/user.dart'; class HiveConfig { static Future init() async { await Hive.initFlutter(); Hive.registerAdapter(UserAdapter()); Hive.registerAdapter(ServerHostingDetailsAdapter()); Hive.registerAdapter(ServerDomainAdapter()); Hive.registerAdapter(BackblazeCredentialAdapter()); Hive.registerAdapter(BackblazeBucketAdapter()); Hive.registerAdapter(ServerVolumeAdapter()); Hive.registerAdapter(DnsProviderAdapter()); Hive.registerAdapter(ServerProviderAdapter()); await Hive.openBox(BNames.appSettingsBox); var cipher = HiveAesCipher( await getEncryptedKey(BNames.serverInstallationEncryptionKey)); await Hive.openBox(BNames.usersDeprecated); await Hive.openBox(BNames.usersBox, encryptionCipher: cipher); Box deprecatedUsers = Hive.box(BNames.usersDeprecated); if (deprecatedUsers.isNotEmpty) { Box users = Hive.box(BNames.usersBox); users.addAll(deprecatedUsers.values.toList()); deprecatedUsers.clear(); } await Hive.openBox(BNames.serverInstallationBox, encryptionCipher: cipher); } static Future getEncryptedKey(String encKey) async { final secureStorage = FlutterSecureStorage(); var hasEncryptionKey = await secureStorage.containsKey(key: encKey); if (!hasEncryptionKey) { var key = Hive.generateSecureKey(); await secureStorage.write(key: encKey, value: base64UrlEncode(key)); } String? string = await secureStorage.read(key: encKey); return base64Url.decode(string!); } } /// Mappings for the different boxes and their keys class BNames { /// App settings box. Contains app settings like [isDarkModeOn], [isOnboardingShowing] static String appSettingsBox = 'appSettings'; /// A boolean field of [appSettingsBox] box. static String isDarkModeOn = 'isDarkModeOn'; /// A boolean field of [appSettingsBox] box. static String isOnboardingShowing = 'isOnboardingShowing'; /// Encryption key to decrypt [serverInstallationBox] and [usersBox] box. static String serverInstallationEncryptionKey = 'key'; /// Server installation box. Contains server details and provider tokens. static String serverInstallationBox = 'appConfig'; /// A List field of [serverInstallationBox] box. static String rootKeys = 'rootKeys'; /// A boolean field of [serverInstallationBox] box. static String hasFinalChecked = 'hasFinalChecked'; /// A boolean field of [serverInstallationBox] box. static String isServerStarted = 'isServerStarted'; /// A [ServerDomain] field of [serverInstallationBox] box. static String serverDomain = 'cloudFlareDomain'; /// A String field of [serverInstallationBox] box. static String hetznerKey = 'hetznerKey'; /// A String field of [serverInstallationBox] box. static String cloudFlareKey = 'cloudFlareKey'; /// A [User] field of [serverInstallationBox] box. static String rootUser = 'rootUser'; /// A [ServerHostingDetails] field of [serverInstallationBox] box. static String serverDetails = 'hetznerServer'; /// A [BackblazeCredential] field of [serverInstallationBox] box. static String backblazeCredential = 'backblazeKey'; /// A [BackblazeBucket] field of [serverInstallationBox] box. static String backblazeBucket = 'backblazeBucket'; /// A boolean field of [serverInstallationBox] box. static String isLoading = 'isLoading'; /// A boolean field of [serverInstallationBox] box. static String isServerResetedFirstTime = 'isServerResetedFirstTime'; /// A boolean field of [serverInstallationBox] box. static String isServerResetedSecondTime = 'isServerResetedSecondTime'; /// Deprecated users box as it is unencrypted static String usersDeprecated = 'users'; /// Box with users static String usersBox = 'usersEncrypted'; }