From f5b37a4d9c826da1b1342b6265bb5b80ab3a0536 Mon Sep 17 00:00:00 2001 From: Stephan Date: Wed, 1 Apr 2020 10:01:42 -0400 Subject: [PATCH 1/5] Added ability to pass device token and device fingerprint from app that references this SDK. --- Source/OktaAuthSdk.swift | 4 ++++ Source/Statuses/OktaAuthStatusUnauthenticated.swift | 5 ++++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/Source/OktaAuthSdk.swift b/Source/OktaAuthSdk.swift index 9fee242..e8721c8 100644 --- a/Source/OktaAuthSdk.swift +++ b/Source/OktaAuthSdk.swift @@ -17,12 +17,16 @@ public class OktaAuthSdk { public class func authenticate(with url: URL, username: String, password: String?, + deviceToken: String?, + deviceFingerprint: String?, onStatusChange: @escaping (_ newStatus: OktaAuthStatus) -> Void, onError: @escaping (_ error: OktaError) -> Void) { let unauthenticatedStatus = OktaAuthStatusUnauthenticated(oktaDomain: url) unauthenticatedStatus.authenticate(username: username, password: password ?? "", + deviceToken: deviceToken ?? "", + deviceFingerprint: deviceFingerprint ?? "", onStatusChange:onStatusChange, onError:onError) } diff --git a/Source/Statuses/OktaAuthStatusUnauthenticated.swift b/Source/Statuses/OktaAuthStatusUnauthenticated.swift index 5194331..9d3b6df 100644 --- a/Source/Statuses/OktaAuthStatusUnauthenticated.swift +++ b/Source/Statuses/OktaAuthStatusUnauthenticated.swift @@ -21,12 +21,15 @@ open class OktaAuthStatusUnauthenticated : OktaAuthStatus { open func authenticate(username: String, password: String, + deviceToken: String, + deviceFingerprint: String, onStatusChange: @escaping (_ newStatus: OktaAuthStatus) -> Void, onError: @escaping (_ error: OktaError) -> Void) { restApi.primaryAuthentication(username: username, password: password, - deviceFingerprint: nil) + deviceToken: deviceToken, + deviceFingerprint: deviceFingerprint) { result in self.handleServerResponse(result, onStatusChanged: onStatusChange, From 5fa8c94effc6332fea112f8c7b58e1b945e0b42b Mon Sep 17 00:00:00 2001 From: kochste77 Date: Fri, 3 Apr 2020 17:02:39 -0400 Subject: [PATCH 2/5] Update E2ETests.swift Added deviceToken and deviceFingerprint parameters to fix E2E tests. --- Tests/E2E/E2ETests.swift | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/Tests/E2E/E2ETests.swift b/Tests/E2E/E2ETests.swift index 8a3b5c9..4ee89bf 100644 --- a/Tests/E2E/E2ETests.swift +++ b/Tests/E2E/E2ETests.swift @@ -45,7 +45,7 @@ class E2ETests: XCTestCase { func testPrimaryAuthFlowSuccess() { let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: primaryAuthUser!.password, onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: primaryAuthUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTAssertTrue(status.statusType == .success) self.verifyBasicInfoForStatus(status: status) let successStatus = status as! OktaAuthStatusSuccess @@ -61,7 +61,7 @@ class E2ETests: XCTestCase { func testPrimaryAuthFlowFailure() { let ex = expectation(description: "Operation should fail!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: "Wrong password", onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: "Wrong password", deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTFail("Unexpected status") ex.fulfill() }) { error in @@ -78,7 +78,7 @@ class E2ETests: XCTestCase { func testFactorChallengeSuccess() { var factorRequiredStatus: OktaAuthStatusFactorRequired? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorRequiredUser!.username, password: factorRequiredUser!.password, onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorRequiredUser!.username, password: factorRequiredUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTAssertTrue(status.statusType == .MFARequired) factorRequiredStatus = status as? OktaAuthStatusFactorRequired if let factorRequiredStatus = factorRequiredStatus { @@ -130,7 +130,7 @@ class E2ETests: XCTestCase { var factorEnrollStatus: OktaAuthStatusFactorEnroll? var pushFactor: OktaFactorPush? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTAssertTrue(status.statusType == .MFAEnroll) factorEnrollStatus = status as? OktaAuthStatusFactorEnroll if let factorEnrollStatus = factorEnrollStatus { @@ -218,7 +218,7 @@ class E2ETests: XCTestCase { var factorEnrollStatus: OktaAuthStatusFactorEnroll? var smsFactor: OktaFactorSms? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTAssertTrue(status.statusType == .MFAEnroll) factorEnrollStatus = status as? OktaAuthStatusFactorEnroll if let factorEnrollStatus = factorEnrollStatus { @@ -257,7 +257,7 @@ class E2ETests: XCTestCase { var factorEnrollStatus: OktaAuthStatusFactorEnroll? var totpFactor: OktaFactorTotp? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTAssertTrue(status.statusType == .MFAEnroll) factorEnrollStatus = status as? OktaAuthStatusFactorEnroll if let factorEnrollStatus = factorEnrollStatus { From 7dfaec54dc22ecd21199c114a2f5aa64ada6c569 Mon Sep 17 00:00:00 2001 From: kochste77 Date: Fri, 3 Apr 2020 17:18:00 -0400 Subject: [PATCH 3/5] Update OktaAuthStatusUnauthenticatedTests.swift Added deviceToken and deviceFingerprint parameters to fix unit tests. --- Tests/Statuses/OktaAuthStatusUnauthenticatedTests.swift | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Tests/Statuses/OktaAuthStatusUnauthenticatedTests.swift b/Tests/Statuses/OktaAuthStatusUnauthenticatedTests.swift index 66e568c..4cf298a 100644 --- a/Tests/Statuses/OktaAuthStatusUnauthenticatedTests.swift +++ b/Tests/Statuses/OktaAuthStatusUnauthenticatedTests.swift @@ -25,6 +25,8 @@ class OktaAuthStatusUnauthenticatedTests: XCTestCase { status.authenticate( username: "test", password: "test", + deviceToken: "deviceToken", + deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTAssertEqual(AuthStatus.success, status.statusType) ex.fulfill() @@ -48,6 +50,8 @@ class OktaAuthStatusUnauthenticatedTests: XCTestCase { status.authenticate( username: "test", password: "test", + deviceToken: "deviceToken", + deviceFingerprint: "deviceFingerprint", onStatusChange: { status in XCTFail("Unexpected status change: \(status)") ex.fulfill() From 5ec5521229c32befa2bcc9ff855311f65e334ae7 Mon Sep 17 00:00:00 2001 From: kochste77 Date: Sun, 5 Apr 2020 16:16:23 -0400 Subject: [PATCH 4/5] Update E2ETests.swift Passing nil for deviceFingerprint parameter. --- Tests/E2E/E2ETests.swift | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/Tests/E2E/E2ETests.swift b/Tests/E2E/E2ETests.swift index 4ee89bf..1880c0e 100644 --- a/Tests/E2E/E2ETests.swift +++ b/Tests/E2E/E2ETests.swift @@ -13,7 +13,7 @@ import XCTest @testable import OktaAuthNative -class E2ETests: XCTestCase { +class E2ETests: XCTestCase let username = ProcessInfo.processInfo.environment["USERNAME"]! let password = ProcessInfo.processInfo.environment["PASSWORD"]! @@ -45,7 +45,7 @@ class E2ETests: XCTestCase { func testPrimaryAuthFlowSuccess() { let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: primaryAuthUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: primaryAuthUser!.password, deviceToken: "deviceToken", deviceFingerprint: nil, onStatusChange: { status in XCTAssertTrue(status.statusType == .success) self.verifyBasicInfoForStatus(status: status) let successStatus = status as! OktaAuthStatusSuccess @@ -61,7 +61,7 @@ class E2ETests: XCTestCase { func testPrimaryAuthFlowFailure() { let ex = expectation(description: "Operation should fail!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: "Wrong password", deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: primaryAuthUser!.username, password: "Wrong password", deviceToken: "deviceToken", deviceFingerprint: nil, onStatusChange: { status in XCTFail("Unexpected status") ex.fulfill() }) { error in @@ -78,7 +78,7 @@ class E2ETests: XCTestCase { func testFactorChallengeSuccess() { var factorRequiredStatus: OktaAuthStatusFactorRequired? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorRequiredUser!.username, password: factorRequiredUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorRequiredUser!.username, password: factorRequiredUser!.password, deviceToken: "deviceToken", deviceFingerprint: nil, onStatusChange: { status in XCTAssertTrue(status.statusType == .MFARequired) factorRequiredStatus = status as? OktaAuthStatusFactorRequired if let factorRequiredStatus = factorRequiredStatus { @@ -130,7 +130,7 @@ class E2ETests: XCTestCase { var factorEnrollStatus: OktaAuthStatusFactorEnroll? var pushFactor: OktaFactorPush? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: nil, onStatusChange: { status in XCTAssertTrue(status.statusType == .MFAEnroll) factorEnrollStatus = status as? OktaAuthStatusFactorEnroll if let factorEnrollStatus = factorEnrollStatus { @@ -218,7 +218,7 @@ class E2ETests: XCTestCase { var factorEnrollStatus: OktaAuthStatusFactorEnroll? var smsFactor: OktaFactorSms? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: nil, onStatusChange: { status in XCTAssertTrue(status.statusType == .MFAEnroll) factorEnrollStatus = status as? OktaAuthStatusFactorEnroll if let factorEnrollStatus = factorEnrollStatus { @@ -257,7 +257,7 @@ class E2ETests: XCTestCase { var factorEnrollStatus: OktaAuthStatusFactorEnroll? var totpFactor: OktaFactorTotp? let ex = expectation(description: "Operation should succeed!") - OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: "deviceFingerprint", onStatusChange: { status in + OktaAuthSdk.authenticate(with: URL(string: urlString)!, username: factorEnrollmentUser!.username, password: factorEnrollmentUser!.password, deviceToken: "deviceToken", deviceFingerprint: nil, onStatusChange: { status in XCTAssertTrue(status.statusType == .MFAEnroll) factorEnrollStatus = status as? OktaAuthStatusFactorEnroll if let factorEnrollStatus = factorEnrollStatus { From 9d5edccc40336796223c968bbba3975dc41f2b1b Mon Sep 17 00:00:00 2001 From: kochste77 Date: Sun, 5 Apr 2020 16:20:49 -0400 Subject: [PATCH 5/5] Update E2ETests.swift Added accidentally removed curly brace. --- Tests/E2E/E2ETests.swift | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Tests/E2E/E2ETests.swift b/Tests/E2E/E2ETests.swift index 1880c0e..8ce5dfe 100644 --- a/Tests/E2E/E2ETests.swift +++ b/Tests/E2E/E2ETests.swift @@ -13,7 +13,7 @@ import XCTest @testable import OktaAuthNative -class E2ETests: XCTestCase +class E2ETests: XCTestCase { let username = ProcessInfo.processInfo.environment["USERNAME"]! let password = ProcessInfo.processInfo.environment["PASSWORD"]!