/* eslint-disable import/prefer-default-export */ import KeychainService from './keychain/KeychainService'; import Setting from '../models/Setting'; import uuid from '../uuid'; import { migrateLocalSyncInfo } from './synchronizer/syncInfoUtils'; // This function takes care of initialising both the keychain service and settings. // // Loading the settings became more complicated with the keychain integration. This is because // the settings needs a keychain service, and the keychain service needs a clientId, which // is set dynamically and saved to the settings. // In other words, it's not possible to load the settings without the KS service and it's not // possible to initialise the KS service without the settings. // The solution is to fetch just the client ID directly from the database. // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied export async function loadKeychainServiceAndSettings(KeychainServiceDriver: any) { const clientIdSetting = await Setting.loadOne('clientId'); const clientId = clientIdSetting ? clientIdSetting.value : uuid.create(); KeychainService.instance().initialize(new KeychainServiceDriver(Setting.value('appId'), clientId)); Setting.setKeychainService(KeychainService.instance()); await Setting.load(); // This is part of the migration to the new sync target info. It needs to be // set as early as possible since it's used to tell if E2EE is enabled, it // contains the master keys, etc. Once it has been set, it becomes a noop // on future calls. await migrateLocalSyncInfo(Setting.db()); if (!clientIdSetting) Setting.setValue('clientId', clientId); await KeychainService.instance().detectIfKeychainSupported(); }