mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-19 08:03:50 +02:00
Key Backup setup: Create the key backup using 4S if it exists
This commit is contained in:
@@ -44,11 +44,11 @@ final class KeyBackupSetupCoordinator: KeyBackupSetupCoordinatorType {
|
||||
// MARK: - Public methods
|
||||
|
||||
func start() {
|
||||
|
||||
// Set key backup setup intro as root controller
|
||||
let keyBackupSetupIntroViewController = self.createSetupIntroViewController()
|
||||
keyBackupSetupIntroViewController.delegate = self
|
||||
self.navigationRouter.setRootModule(keyBackupSetupIntroViewController)
|
||||
if self.session.crypto.recoveryService.hasRecovery() {
|
||||
showUnlockSecureBackup()
|
||||
} else {
|
||||
showSetupIntro()
|
||||
}
|
||||
}
|
||||
|
||||
func toPresentable() -> UIViewController {
|
||||
@@ -57,6 +57,13 @@ final class KeyBackupSetupCoordinator: KeyBackupSetupCoordinatorType {
|
||||
|
||||
// MARK: - Private methods
|
||||
|
||||
private func showSetupIntro() {
|
||||
// Set key backup setup intro as root controller
|
||||
let keyBackupSetupIntroViewController = self.createSetupIntroViewController()
|
||||
keyBackupSetupIntroViewController.delegate = self
|
||||
self.navigationRouter.setRootModule(keyBackupSetupIntroViewController)
|
||||
}
|
||||
|
||||
private func createSetupIntroViewController() -> KeyBackupSetupIntroViewController {
|
||||
|
||||
let backupState = self.session.crypto.backup?.state ?? MXKeyBackupStateUnknown
|
||||
@@ -80,6 +87,17 @@ final class KeyBackupSetupCoordinator: KeyBackupSetupCoordinatorType {
|
||||
return KeyBackupSetupIntroViewController.instantiate(isABackupAlreadyExists: isABackupAlreadyExists, encryptionKeysExportPresenter: encryptionKeysExportPresenter)
|
||||
}
|
||||
|
||||
private func showUnlockSecureBackup() {
|
||||
let recoveryGoal: SecretsRecoveryGoal = .unlockSecureBackup { (privateKey, completion) in
|
||||
self.createKeyBackupUsingSecureBackup(privateKey: privateKey, completion: completion)
|
||||
}
|
||||
|
||||
let coordinator = SecretsRecoveryCoordinator(session: self.session, recoveryMode: .passphraseOrKey, recoveryGoal: recoveryGoal, navigationRouter: self.navigationRouter)
|
||||
coordinator.delegate = self
|
||||
coordinator.start()
|
||||
self.add(childCoordinator: coordinator)
|
||||
}
|
||||
|
||||
private func showSetupPassphrase(animated: Bool) {
|
||||
let keyBackupSetupPassphraseCoordinator = KeyBackupSetupPassphraseCoordinator(session: self.session)
|
||||
keyBackupSetupPassphraseCoordinator.delegate = self
|
||||
@@ -104,6 +122,34 @@ final class KeyBackupSetupCoordinator: KeyBackupSetupCoordinatorType {
|
||||
viewController.delegate = self
|
||||
self.navigationRouter.push(viewController, animated: animated, popCompletion: nil)
|
||||
}
|
||||
|
||||
private func showSetupWithSecureBackupSuccess(animated: Bool) {
|
||||
|
||||
let viewController = KeyBackupSetupSuccessFromSecureBackupViewController.instantiate()
|
||||
viewController.delegate = self
|
||||
self.navigationRouter.push(viewController, animated: animated, popCompletion: nil)
|
||||
}
|
||||
|
||||
private func createKeyBackupUsingSecureBackup(privateKey: Data, completion: @escaping (Result<Void, Error>) -> Void) {
|
||||
guard let keyBackup = session.crypto.backup, let recoveryService = session.crypto.recoveryService else {
|
||||
return
|
||||
}
|
||||
|
||||
keyBackup.prepareKeyBackupVersion(withPassword: nil, success: { megolmBackupCreationInfo in
|
||||
keyBackup.createKeyBackupVersion(megolmBackupCreationInfo, success: { _ in
|
||||
recoveryService.updateRecovery(forSecrets: [MXSecretId.keyBackup.takeUnretainedValue() as String], withPrivateKey: privateKey) {
|
||||
completion(.success(Void()))
|
||||
} failure: { error in
|
||||
completion(.failure(error))
|
||||
}
|
||||
|
||||
}, failure: { error in
|
||||
completion(.failure(error))
|
||||
})
|
||||
}, failure: { error in
|
||||
completion(.failure(error))
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
// MARK: - KeyBackupSetupIntroViewControllerDelegate
|
||||
@@ -133,6 +179,17 @@ extension KeyBackupSetupCoordinator: KeyBackupSetupPassphraseCoordinatorDelegate
|
||||
}
|
||||
}
|
||||
|
||||
// MARK: - SecretsRecoveryCoordinatorDelegate
|
||||
extension KeyBackupSetupCoordinator: SecretsRecoveryCoordinatorDelegate {
|
||||
func secretsRecoveryCoordinatorDidRecover(_ coordinator: SecretsRecoveryCoordinatorType) {
|
||||
self.showSetupWithSecureBackupSuccess(animated: true)
|
||||
}
|
||||
|
||||
func secretsRecoveryCoordinatorDidCancel(_ coordinator: SecretsRecoveryCoordinatorType) {
|
||||
self.delegate?.keyBackupSetupCoordinatorDidCancel(self)
|
||||
}
|
||||
}
|
||||
|
||||
// MARK: - KeyBackupSetupSuccessFromPassphraseViewControllerDelegate
|
||||
extension KeyBackupSetupCoordinator: KeyBackupSetupSuccessFromPassphraseViewControllerDelegate {
|
||||
func keyBackupSetupSuccessFromPassphraseViewControllerDidTapDoneAction(_ viewController: KeyBackupSetupSuccessFromPassphraseViewController) {
|
||||
@@ -146,3 +203,10 @@ extension KeyBackupSetupCoordinator: KeyBackupSetupSuccessFromRecoveryKeyViewCon
|
||||
self.delegate?.keyBackupSetupCoordinatorDidSetupRecoveryKey(self)
|
||||
}
|
||||
}
|
||||
|
||||
// MARK: - KeyBackupSetupSuccessFromSecureBackupViewControllerDelegate
|
||||
extension KeyBackupSetupCoordinator: KeyBackupSetupSuccessFromSecureBackupViewControllerDelegate {
|
||||
func keyBackupSetupSuccessFromSecureBackupViewControllerDidTapDoneAction(_ viewController: KeyBackupSetupSuccessFromSecureBackupViewController) {
|
||||
self.delegate?.keyBackupSetupCoordinatorDidSetupRecoveryKey(self)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user