Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[local_auth_darwin] - Converts implementation to Swift #7586

Open
wants to merge 62 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
b49f5c5
feat:: migrate objC to Swift
Mairramer Sep 5, 2024
e4f1902
fix
Mairramer Sep 5, 2024
b86edf2
new changes
Mairramer Sep 5, 2024
c7b79c0
more work
Mairramer Sep 5, 2024
5b8bcf1
small fix
Mairramer Sep 5, 2024
a77bd18
another fix
Mairramer Sep 5, 2024
2a34903
Merge branch 'main' into migrate-local_auth-to-swift
Mairramer Sep 5, 2024
fa42c8a
refactor
Mairramer Nov 6, 2024
5c89d1f
Merge branch 'refs/heads/main' into migrate-local_auth-to-swift
Mairramer Nov 6, 2024
bea5a37
some improves
Mairramer Nov 6, 2024
37cf5e1
fix
Mairramer Nov 6, 2024
db60196
fix
Mairramer Nov 6, 2024
272451f
fix
Mairramer Nov 6, 2024
f3b140b
more code
Mairramer Nov 7, 2024
d471e2d
more fixes
Mairramer Nov 8, 2024
fe12dda
fix test
Mairramer Nov 8, 2024
f1ba9a2
some clean ups
Mairramer Nov 8, 2024
b0420e6
fix
Mairramer Nov 8, 2024
4f7d1fb
add author
Mairramer Nov 8, 2024
1410b39
fix
Mairramer Nov 8, 2024
6aaff99
fix
Mairramer Nov 8, 2024
3fce86c
fix
Mairramer Nov 8, 2024
942f173
fix
Mairramer Nov 8, 2024
f9b51e7
fix
Mairramer Nov 8, 2024
2e23838
fix
Mairramer Nov 8, 2024
06f2490
fix
Mairramer Nov 8, 2024
0a3f74d
fix loop
Mairramer Nov 9, 2024
40e2fa0
fix
Mairramer Nov 9, 2024
99e82cf
improves
Mairramer Nov 9, 2024
d74e64d
test
Mairramer Nov 11, 2024
93c85d4
fix
Mairramer Nov 11, 2024
959be13
fix
Mairramer Nov 11, 2024
544b2d7
some rollabacks
Mairramer Nov 12, 2024
154d08a
small changes
Mairramer Nov 25, 2024
8755ede
Merge branch 'main' into migrate-local_auth-to-swift
Mairramer Nov 25, 2024
f0b9292
fix
Mairramer Nov 25, 2024
8c2e70e
fix
Mairramer Nov 25, 2024
9c287f6
fix
Mairramer Nov 25, 2024
3ea9a86
fix
Mairramer Nov 25, 2024
4b69657
new changes
Mairramer Nov 26, 2024
690a71d
Merge branch 'main' into migrate-local_auth-to-swift
Mairramer Nov 26, 2024
d6c736c
fix
Mairramer Nov 26, 2024
8996e4c
some reworks
Mairramer Dec 6, 2024
fbf4b38
Merge branch 'main' into migrate-local_auth-to-swift
Mairramer Dec 6, 2024
4639b88
some fixes
Mairramer Dec 6, 2024
5258731
new changes
Mairramer Dec 6, 2024
9ebba78
solve problems
Mairramer Dec 7, 2024
663ff05
some fixes
Mairramer Dec 7, 2024
92f3d3f
some fixes
Mairramer Dec 7, 2024
350c6ab
fixes
Mairramer Dec 9, 2024
c664e92
fixes
Mairramer Dec 9, 2024
dbea0df
fix
Mairramer Dec 9, 2024
ce53e27
fix
Mairramer Dec 9, 2024
b495f10
fix
Mairramer Dec 9, 2024
71e0d04
Update CHANGELOG.md
Mairramer Dec 9, 2024
5081932
fix
Mairramer Dec 9, 2024
6cdf882
fix
Mairramer Dec 9, 2024
d0d3c98
Merge branch 'main' into migrate-local_auth-to-swift
Mairramer Dec 9, 2024
e1f94fe
fix
Mairramer Dec 9, 2024
f088874
fix
Mairramer Dec 9, 2024
90e5a08
small changes
Mairramer Dec 10, 2024
78939f5
Merge branch 'main' into migrate-local_auth-to-swift
Mairramer Dec 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
small changes
  • Loading branch information
Mairramer committed Nov 25, 2024
commit 154d08adaa55abe3c8efe1a8af3b3a598cd5d1cb
Original file line number Diff line number Diff line change
Expand Up @@ -2,23 +2,21 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

/// Protocol for the UIAlertController API.
/// Protocol for the AlertController API.
///
/// This protocol exists to allow injecting an alternate implementation for testing.
protocol AlertController {
func showAlert(
message: String, dismissTitle: String, openSettingsTitle: String?,
completion: @escaping (Bool) -> Void)
completion: @escaping (Bool) -> Void
)
}

/// Defines the empty `DefaultAlertController` class so that extensions can implement `showAlert`.
class DefaultAlertController {}

/// Default implementation of AlertController for iOS and macOS.
#if os(iOS)
import UIKit

// Extension for AlertControllerProtocol on iOS
extension DefaultAlertController: AlertController {
class DefaultAlertController: AlertController {
func showAlert(
message: String, dismissTitle: String, openSettingsTitle: String?,
completion: @escaping (Bool) -> Void
Expand All @@ -30,8 +28,7 @@ class DefaultAlertController {}
alert.addAction(dismissAction)

if let openSettingsTitle = openSettingsTitle {
let openSettingsAction = UIAlertAction(title: openSettingsTitle, style: .default) {
_ in
let openSettingsAction = UIAlertAction(title: openSettingsTitle, style: .default) { _ in
if let url = URL(string: UIApplication.openSettingsURLString) {
UIApplication.shared.open(url, options: [:], completionHandler: nil)
}
Expand All @@ -40,16 +37,14 @@ class DefaultAlertController {}
alert.addAction(openSettingsAction)
}

UIApplication.shared.delegate?.window??.rootViewController?.present(
alert, animated: true)
UIApplication.shared.delegate?.window??.rootViewController?.present(alert, animated: true)
}
}

#elseif os(macOS)
import AppKit

// Extension for AlertControllerProtocol on macOS
extension DefaultAlertController: AlertController {
class DefaultAlertController: AlertController {
func showAlert(
message: String, dismissTitle: String, openSettingsTitle: String?,
completion: @escaping (Bool) -> Void
Expand All @@ -65,8 +60,7 @@ class DefaultAlertController {}
alert.beginSheetModal(for: NSApplication.shared.keyWindow!) { response in
if response == .alertSecondButtonReturn,
let url = URL(
string:
"x-apple.systempreferences:com.apple.preference.security?Privacy_Biometric"
string: "x-apple.systempreferences:com.apple.preference.security?Privacy_Biometric"
)
{
NSWorkspace.shared.open(url)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,29 +16,4 @@ protocol AuthContext {
_ policy: LAPolicy, localizedReason: String, reply: @escaping (Bool, Error?) -> Void)
}

/// Default implementation of AuthContext.
class DefaultAuthContext: AuthContext {
private let context = LAContext()
}

/// Default implementation of AuthContext. This is a thin wrapper around LAContext.
extension DefaultAuthContext {
var biometryType: LABiometryType {
context.biometryType
}

var localizedFallbackTitle: String? {
get { context.localizedFallbackTitle }
set { context.localizedFallbackTitle = newValue }
}

func canEvaluatePolicy(_ policy: LAPolicy, error: NSErrorPointer) -> Bool {
context.canEvaluatePolicy(policy, error: error)
}

func evaluatePolicy(
_ policy: LAPolicy, localizedReason: String, reply: @escaping (Bool, Error?) -> Void
) {
context.evaluatePolicy(policy, localizedReason: localizedReason, reply: reply)
}
}
extension LAContext: AuthContext {}
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ public final class LocalAuthPlugin: NSObject, FlutterPlugin, LocalAuthApi {
private var lastCallState: StickyAuthState?

init(
authContext: AuthContext = DefaultAuthContext(),
authContext: AuthContext = LAContext(),
alertController: AlertController = DefaultAlertController()
) {
self.authContext = authContext
Expand All @@ -56,19 +56,16 @@ public final class LocalAuthPlugin: NSObject, FlutterPlugin, LocalAuthApi {
public static func register(with registrar: FlutterPluginRegistrar) {
let instance = LocalAuthPlugin()
#if os(iOS)
// iOS-specific implementation
let messenger = registrar.messenger()
LocalAuthApiSetup.setUp(binaryMessenger: messenger, api: instance)
#elseif os(macOS)
// macOS-specific implementation
let messenger = registrar.messenger
LocalAuthApiSetup.setUp(binaryMessenger: messenger, api: instance)
#endif

LocalAuthApiSetup.setUp(binaryMessenger: messenger, api: instance)
}

func isDeviceSupported() throws -> Bool {
var error: NSError?
return authContext.canEvaluatePolicy(.deviceOwnerAuthentication, error: &error)
return authContext.canEvaluatePolicy(.deviceOwnerAuthentication, error: nil)
}

func deviceCanSupportBiometrics() throws -> Bool {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,6 @@ class LocalAuthDarwin extends LocalAuthPlatform {
return AuthStrings(
reason: localizedReason,
lockOut: messages?.lockOut ?? macOSLockOut,
goToSettingsButton: '',
goToSettingsDescription:
messages?.goToSettingsDescription ?? macOSGoToSettingsDescription,
cancelButton: messages?.cancelButton ?? macOSCancelButton,
Expand Down