passforios/passAutoFillExtension/Controllers/CredentialProviderViewController.swift

76 lines
3.1 KiB
Swift
Raw Normal View History

2018-09-24 15:06:43 +08:00
//
// CredentialProviderViewController.swift
// passAutoFillExtension
//
// Created by Yishi Lin on 2018/9/24.
// Copyright © 2018 Bob Sun. All rights reserved.
//
import AuthenticationServices
import passKit
2020-12-31 21:46:50 -08:00
class CredentialProviderViewController: ASCredentialProviderViewController {
var passcodelock: PasscodeExtensionDisplay {
2021-01-31 13:17:37 +01:00
PasscodeExtensionDisplay(extensionContext: extensionContext)
2018-09-24 15:06:43 +08:00
}
2020-12-31 21:46:50 -08:00
var embeddedNavigationController: UINavigationController {
children.first as! UINavigationController
2018-09-24 15:06:43 +08:00
}
2020-12-31 21:46:50 -08:00
var passwordsViewController: PasswordsViewController {
embeddedNavigationController.viewControllers.first as! PasswordsViewController
}
2018-12-09 16:59:07 -08:00
lazy var credentialProvider = CredentialProvider(viewController: self, extensionContext: self.extensionContext)
override func viewDidLoad() {
super.viewDidLoad()
2020-12-31 21:46:50 -08:00
passcodelock.presentPasscodeLockIfNeeded(self)
2018-12-09 16:59:07 -08:00
2020-12-31 21:46:50 -08:00
let passwordsTableEntries = PasswordStore.shared.fetchPasswordEntityCoreData(withDir: false).compactMap { PasswordTableEntry($0) }
let dataSource = PasswordsTableDataSource(entries: passwordsTableEntries)
passwordsViewController.dataSource = dataSource
passwordsViewController.selectionDelegate = self
2021-01-10 13:40:17 -08:00
passwordsViewController.navigationItem.leftBarButtonItem = UIBarButtonItem(barButtonSystemItem: .cancel, target: self, action: #selector(cancel))
}
2018-12-09 16:59:07 -08:00
2020-12-31 21:46:50 -08:00
override func prepareCredentialList(for serviceIdentifiers: [ASCredentialServiceIdentifier]) {
credentialProvider.identifier = serviceIdentifiers.first
2020-12-31 21:46:50 -08:00
let url = serviceIdentifiers.first.flatMap { URL(string: $0.identifier) }
passwordsViewController.navigationItem.prompt = url?.host
2021-08-26 23:12:13 +02:00
passwordsViewController.showPasswordsWithSuggestion(matching: url?.host ?? "")
}
override func provideCredentialWithoutUserInteraction(for credentialIdentity: ASPasswordCredentialIdentity) {
credentialProvider.identifier = credentialIdentity.serviceIdentifier
if !PasscodeLock.shared.hasPasscode, Defaults.isRememberPGPPassphraseOn {
credentialProvider.credentials(for: credentialIdentity)
} else {
extensionContext.cancelRequest(withError: NSError(domain: ASExtensionErrorDomain, code: ASExtensionError.userInteractionRequired.rawValue))
}
}
override func prepareInterfaceToProvideCredential(for credentialIdentity: ASPasswordCredentialIdentity) {
guard let identifier = credentialIdentity.recordIdentifier else {
return
}
credentialProvider.identifier = credentialIdentity.serviceIdentifier
passwordsViewController.navigationItem.prompt = identifier
2021-08-26 23:12:13 +02:00
passwordsViewController.showPasswordsWithSuggestion(matching: identifier)
}
2021-01-10 13:40:17 -08:00
@objc
private func cancel(_: AnyObject?) {
2021-01-31 13:17:37 +01:00
extensionContext.cancelRequest(withError: NSError(domain: "PassExtension", code: 0))
2021-01-10 13:40:17 -08:00
}
2020-12-31 21:46:50 -08:00
}
2018-12-09 16:59:07 -08:00
2020-12-31 21:46:50 -08:00
extension CredentialProviderViewController: PasswordSelectionDelegate {
func selected(password: PasswordTableEntry) {
let passwordEntity = password.passwordEntity
2018-12-09 16:59:07 -08:00
credentialProvider.persistAndProvideCredentials(with: passwordEntity.getPath())
2018-09-24 15:06:43 +08:00
}
}