Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
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
26 changes: 26 additions & 0 deletions FirebaseAuth/Sources/Swift/Backend/AuthBackend.swift
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,32 @@ final class AuthBackend: AuthBackendProtocol {
#endif // !os(iOS)
}

// MARK: passkeys

public func startPasskeyEnrollment(request: StartPasskeyEnrollmentRequest) async throws
-> StartPasskeyEnrollmentResponse {
guard #available(iOS 16.0, macOS 12.0, tvOS 16.0, *) else {
throw AuthErrorUtils.error(
code: AuthErrorCode.operationNotAllowed,
message: "OS version is not supported for this action."
)
}
let response = try await call(with: request) as StartPasskeyEnrollmentResponse
return response
}

public func finalizePasskeyEnrollment(request: FinalizePasskeyEnrollmentRequest) async throws
-> FinalizePasskeyEnrollmentResponse {
guard #available(iOS 16.0, macOS 12.0, tvOS 16.0, *) else {
throw AuthErrorUtils.error(
code: AuthErrorCode.operationNotAllowed,
message: "OS version is not supported for this action."
)
}
let response = try await call(with: request) as FinalizePasskeyEnrollmentResponse
return response
}

/// Calls the RPC using HTTP request.
///
/// Possible error responses:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import Foundation

/// Represents the request for the `finalizePasskeyEnrollment` endpoint.
@available(iOS 13, *)
class FinalizePasskeyEnrollmentRequest: IdentityToolkitRequest, AuthRPCRequest {
typealias Response = FinalizePasskeyEnrollmentResponse
var unencodedHTTPRequestBody: [String: AnyHashable]?

/// GCIP endpoint for finalizePasskeyEnrollment RPC.
let kFinalizePasskeyEnrollmentEndpoint = "accounts/passkeyEnrollment:finalize"

/// The raw user access token.
let idToken: String
// name of user or passkey ?.?
let name: String
/// The credential ID.
var credentialID: String = "id"
/// The CollectedClientData object from the authenticator.
var clientDataJson: String = "clientDataJSON"
/// The attestation object from the authenticator.
var attestationObject: String = "response"

/// The request configuration.
let requestConfiguration: AuthRequestConfiguration?

/// Initializes a new `FinalizePasskeyEnrollmentRequest`.
///
/// - Parameters:
/// - IDToken: The raw user access token.
/// - name: The passkey name.
/// - credentialID: The credential ID.
/// - clientDataJson: The CollectedClientData object from the authenticator.
/// - attestationObject: The attestation object from the authenticator.
/// - requestConfiguration: The request configuration.
init(idToken: String, name: String, credentialID: String, clientDataJson: String,
attestationObject: String, requestConfiguration: AuthRequestConfiguration) {
self.idToken = idToken
self.name = name
self.credentialID = credentialID
self.clientDataJson = clientDataJson
self.attestationObject = attestationObject
self.requestConfiguration = requestConfiguration
super.init(
endpoint: kFinalizePasskeyEnrollmentEndpoint,
requestConfiguration: requestConfiguration,
useIdentityPlatform: true
)
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import Foundation

/// Represents the response from the `finalizePasskeyEnrollment` endpoint.
@available(iOS 13, *)
struct FinalizePasskeyEnrollmentResponse: AuthRPCResponse {
/// The ID token for the authenticated user.
public let idToken: String

/// The refresh token for the authenticated user.
public let refreshToken: String

private static let kIdTokenKey = "idToken"
private static let kRefreshTokenKey = "refreshToken"

/// Initializes a new `FinalizePasskeyEnrollmentResponse` from a dictionary.
///
/// - Parameter dictionary: The dictionary containing the response data.
/// - Throws: An error if parsing fails.
public init(dictionary: [String: AnyHashable]) throws {
guard let idToken = dictionary[Self.kIdTokenKey] as? String,
let refreshToken = dictionary[Self.kRefreshTokenKey] as? String else {
throw AuthErrorUtils.unexpectedResponse(deserializedResponse: dictionary)
}
self.idToken = idToken
self.refreshToken = refreshToken
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import Foundation

/// Represents the parameters for the `startPasskeyEnrollment` endpoint.
@available(iOS 13, *)
class StartPasskeyEnrollmentRequest: IdentityToolkitRequest, AuthRPCRequest {
typealias Response = StartPasskeyEnrollmentResponse
var unencodedHTTPRequestBody: [String: AnyHashable]?

/// The raw user access token.
let idToken: String

/// The tenant ID for the request.
let tenantId: String?

/// The endpoint for the request.
private let kStartPasskeyEnrollmentEndpoint = "accounts/passkeyEnrollment:start"

/// The request configuration.
let requestConfiguration: AuthRequestConfiguration?

/// Initializes a new `StartPasskeyEnrollmentRequest`.
///
/// - Parameters:
/// - idToken: The raw user access token.
/// - requestConfiguration: The request configuration.
/// - tenantId: The tenant ID for the request.
init(idToken: String, requestConfiguration: AuthRequestConfiguration?, tenantId: String? = nil) {
self.idToken = idToken
self.requestConfiguration = requestConfiguration
self.tenantId = tenantId
super.init(
endpoint: kStartPasskeyEnrollmentEndpoint,
requestConfiguration: requestConfiguration!,
useIdentityPlatform: true
)
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
import Foundation

/// Represents the response from the `startPasskeyEnrollment` endpoint.
@available(iOS 13, *)
struct StartPasskeyEnrollmentResponse: AuthRPCResponse {
/// The RP ID of the FIDO Relying Party.
private(set) var rpID: String = "fir-ios-auth-sample.web.app.com"

/// The user ID.
private(set) var userID: Data

/// The FIDO challenge.
private(set) var challenge: Data

/// The name of the field in the response JSON for CredentialCreationOptions.
private let kOptionsKey = "credentialCreationOptions"

/// The name of the field in the response JSON for Relying Party.
private let kRpKey = "rp"

/// The name of the field in the response JSON for User.
private let kUserKey = "user"

/// The name of the field in the response JSON for ids.
private let kIDKey = "id"

/// The name of the field in the response JSON for challenge.
private let kChallengeKey = "challenge"

/// Initializes a new `StartPasskeyEnrollmentResponse` from a dictionary.
///
/// - Parameters:
/// - dictionary: The dictionary containing the response data.
/// - Throws: An error if parsing fails.
init(dictionary: [String: AnyHashable]) throws {
guard let options = dictionary[kOptionsKey] as? [String: AnyHashable] else {
throw NSError(
domain: "com.firebase.auth",
code: -1,
userInfo: [NSLocalizedDescriptionKey: "Missing credentialCreationOptions"]
)
}

guard let rp = options[kRpKey] as? [String: AnyHashable],
let rpID = rp[kIDKey] as? String, !rpID.isEmpty else {
throw NSError(
domain: "com.firebase.auth",
code: -1,
userInfo: [NSLocalizedDescriptionKey: "Missing or invalid rpID"]
)
}

guard let user = options[kUserKey] as? [String: AnyHashable],
let userID = user[kIDKey] as? String, !userID.isEmpty,
let userIDData = userID.data(using: .utf8) else {
throw NSError(
domain: "com.firebase.auth",
code: -1,
userInfo: [NSLocalizedDescriptionKey: "Missing or invalid userID"]
)
}

guard let challenge = options[kChallengeKey] as? String, !challenge.isEmpty,
let challengeData = challenge.data(using: .utf8) else {
throw NSError(
domain: "com.firebase.auth",
code: -1,
userInfo: [NSLocalizedDescriptionKey: "Missing or invalid challenge"]
)
}
self.rpID = rpID
self.userID = userIDData
self.challenge = challengeData
}

// MARK: - AuthRPCResponse default implementation

func clientError(shortErrorMessage: String, detailedErrorMessage: String? = nil) -> Error? {
return nil
}
}
59 changes: 59 additions & 0 deletions FirebaseAuth/Sources/Swift/User/User.swift
Original file line number Diff line number Diff line change
Expand Up @@ -1047,6 +1047,65 @@
}
}

// MARK: Passkey Implementation

/// Current user object.
var currentUser: User?

/// Starts the passkey enrollment flow, creating a platform public key registration request.
///
/// - Parameter name: The desired name for the passkey.
/// - Returns: The ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest.
@available(iOS 15.0, *)
public func startPasskeyEnrollmentWithName(withName name: String?) async throws
-> ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest {

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / xcodebuild (iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / xcodebuild (iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, macOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, macOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, macOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, watchOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, watchOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, watchOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, tvOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, visionOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, visionOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, tvOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, visionOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, tvOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, catalyst)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, catalyst)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, catalyst)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-14, Xcode_16.2, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-14, Xcode_16.2, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope

Check failure on line 1061 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-14, Xcode_16.2, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistrationRequest' in scope
let idToken = rawAccessToken()
let request = StartPasskeyEnrollmentRequest(
idToken: idToken,
requestConfiguration: requestConfiguration,
tenantId: auth?.tenantID
)
let response = try await backend.startPasskeyEnrollment(request: request)
// Cache the passkey name
passkeyName = name
let provider =
ASAuthorizationPlatformPublicKeyCredentialProvider(relyingPartyIdentifier: response.rpID)
let registrationRequest = provider.createCredentialRegistrationRequest(
challenge: response.challenge,
name: passkeyName ?? "Unnamed account (Apple)",
userID: response.userID
)
return registrationRequest
}

@available(iOS 15.0, *)
public func finalizePasskeyEnrollmentWithPlatformCredentials(platformCredential: ASAuthorizationPlatformPublicKeyCredentialRegistration) async throws

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / xcodebuild (iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / xcodebuild (iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / storage-combine-integration

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, macOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, macOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, macOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, watchOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, watchOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, watchOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, tvOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, visionOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, tvOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, visionOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, visionOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, tvOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, catalyst)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, catalyst)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-15, Xcode_16.4, catalyst)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-14, Xcode_16.2, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-14, Xcode_16.2, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope

Check failure on line 1082 in FirebaseAuth/Sources/Swift/User/User.swift

View workflow job for this annotation

GitHub Actions / spm / spm (macos-14, Xcode_16.2, iOS)

cannot find type 'ASAuthorizationPlatformPublicKeyCredentialRegistration' in scope
-> AuthDataResult {
let credentialID = platformCredential.credentialID.base64EncodedString() ?? "nil"
let clientDataJson = platformCredential.rawClientDataJSON.base64EncodedString() ?? "nil"
let attestationObject = platformCredential.rawAttestationObject!.base64EncodedString()

let rawAccessToken = self.rawAccessToken
let request = FinalizePasskeyEnrollmentRequest(
idToken: rawAccessToken(),
name: passkeyName!,
credentialID: credentialID,
clientDataJson: clientDataJson,
attestationObject: attestationObject!,
requestConfiguration: auth!.requestConfiguration
)

let response = try await backend.finalizePasskeyEnrollment(request: request)

let user = try await auth!.completeSignIn(
withAccessToken: response.idToken,
accessTokenExpirationDate: nil,
refreshToken: response.refreshToken,
anonymous: false
)
return AuthDataResult(withUser: user, additionalUserInfo: nil)
}

// MARK: Internal implementations below

func rawAccessToken() -> String {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ enum AuthMenu: String {
case phoneEnroll
case totpEnroll
case multifactorUnenroll
case passkeySignUp

// More intuitively named getter for `rawValue`.
var id: String { rawValue }
Expand Down Expand Up @@ -139,6 +140,9 @@ enum AuthMenu: String {
return "TOTP Enroll"
case .multifactorUnenroll:
return "Multifactor unenroll"
// Passkey
case .passkeySignUp:
return "Sign Up with Passkey"
}
}

Expand Down Expand Up @@ -220,6 +224,8 @@ enum AuthMenu: String {
self = .totpEnroll
case "Multifactor unenroll":
self = .multifactorUnenroll
case "Sign Up with Passkey":
self = .passkeySignUp
default:
return nil
}
Expand Down Expand Up @@ -354,9 +360,17 @@ class AuthMenuData: DataSourceProvidable {
return Section(headerDescription: header, items: items)
}

static var passkeySection: Section {
let header = "Passkey"
let items: [Item] = [
Item(title: AuthMenu.passkeySignUp.name),
]
return Section(headerDescription: header, items: items)
}

static let sections: [Section] =
[settingsSection, providerSection, emailPasswordSection, otherSection, recaptchaSection,
customAuthDomainSection, appSection, oobSection, multifactorSection]
customAuthDomainSection, appSection, oobSection, multifactorSection, passkeySection]

static var authLinkSections: [Section] {
let allItems = [providerSection, emailPasswordSection, otherSection].flatMap { $0.items }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -523,6 +523,23 @@ extension AccountLinkingViewController: DataSourceProvidable {
}
}

// MARK: - Passkey Enrollment

@available(iOS 16.0, *)
private func handlePasskeyEnrollment(platformCredential: ASAuthorizationPlatformPublicKeyCredentialRegistration) {
let user = Auth.auth().currentUser
Task {
do {
let authResult = try await user?.finalizePasskeyEnrollmentWithPlatformCredentials(
platformCredential: platformCredential
)
print("Passkey Enrollment succeeded with uid: \(authResult?.user.uid ?? "empty with uid")")
} catch {
print("Passkey Enrollment failed with error: \(error)")
}
}
}

// MARK: - Implementing Sign in with Apple with Firebase

extension AccountLinkingViewController: ASAuthorizationControllerDelegate,
Expand Down
Loading
Loading