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

fix: removed the possibility of concurrent webauth transactions to handle continuation misuse #848

Merged
merged 12 commits into from
May 8, 2024
Merged
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
10 changes: 10 additions & 0 deletions Auth0/Auth0WebAuth.swift
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,11 @@ final class Auth0WebAuth: WebAuth {
}

func start(_ callback: @escaping (WebAuthResult<Credentials>) -> Void) {

if self.storage.current != nil {
return callback(.failure(WebAuthError(code: .transactionActiveAlready)))
}

guard let redirectURL = self.redirectURL else {
return callback(.failure(WebAuthError(code: .noBundleIdentifier)))
}
Expand Down Expand Up @@ -207,6 +212,11 @@ final class Auth0WebAuth: WebAuth {
}

func clearSession(federated: Bool, callback: @escaping (WebAuthResult<Void>) -> Void) {

if self.storage.current != nil {
return callback(.failure(WebAuthError(code: .transactionActiveAlready)))
}

let endpoint = federated ?
URL(string: "v2/logout?federated", relativeTo: self.url)! :
URL(string: "v2/logout", relativeTo: self.url)!
Expand Down
2 changes: 1 addition & 1 deletion Auth0/AuthenticationError.swift
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,7 @@ extension AuthenticationError {

return "Received error with code \(self.code)."
}

}

// MARK: - Equatable
Expand Down
3 changes: 3 additions & 0 deletions Auth0/WebAuthError.swift
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ public struct WebAuthError: Auth0Error {

enum Code: Equatable {
case noBundleIdentifier
case transactionActiveAlready
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are tests for WebAuthError, those should be updated as well: https://github.com/auth0/Auth0.swift/blob/master/Auth0Tests/WebAuthErrorSpec.swift

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for pointing it out, included tests for it now.

case invalidInvitationURL(String)
case userCancelled
case noAuthorizationCode([String: String])
Expand Down Expand Up @@ -79,6 +80,8 @@ extension WebAuthError {
switch self.code {
case .noBundleIdentifier: return "Unable to retrieve the bundle identifier from Bundle.main.bundleIdentifier,"
+ " or it could not be used to build a valid URL."
case .transactionActiveAlready: return "Failed to start this transaction, as there is an active transaction at the"
+ " moment."
case .invalidInvitationURL(let url): return "The invitation URL (\(url)) is missing the 'invitation' and/or"
+ " the 'organization' query parameters."
case .userCancelled: return "The user cancelled the Web Auth operation."
Expand Down
7 changes: 7 additions & 0 deletions Auth0Tests/WebAuthErrorSpec.swift
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,13 @@ class WebAuthErrorSpec: QuickSpec {
expect(error.localizedDescription) == message
}

it("should return message for transaction active already") {
let message = "Failed to start this transaction, as there is an active transaction at the"
+ " moment."
let error = WebAuthError(code: .transactionActiveAlready)
expect(error.localizedDescription) == message
}

it("should return message for invalid invitation URL") {
let url = "https://samples.auth0.com"
let message = "The invitation URL (\(url)) is missing the 'invitation' and/or"
Expand Down
2 changes: 2 additions & 0 deletions Auth0Tests/WebAuthSpec.swift
Original file line number Diff line number Diff line change
Expand Up @@ -475,6 +475,7 @@ class WebAuthSpec: QuickSpec {

beforeEach {
auth = newWebAuth()
TransactionStore.shared.clear()
}

it("should start the supplied provider") {
Expand Down Expand Up @@ -600,6 +601,7 @@ class WebAuthSpec: QuickSpec {

beforeEach {
auth = newWebAuth()
TransactionStore.shared.clear()
}

it("should start the supplied provider") {
Expand Down
Loading