-
Notifications
You must be signed in to change notification settings - Fork 1.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
Implemented start passkey sign in rpc call Defined startPasskeySignInRequest & Response Added Unit tests
- Loading branch information
1 parent
1dd888a
commit dfa40c0
Showing
8 changed files
with
573 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
32 changes: 32 additions & 0 deletions
32
FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInRequest.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
/* | ||
* Copyright 2023 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
#import "FirebaseAuth/Sources/Backend/FIRAuthRPCRequest.h" | ||
#import "FirebaseAuth/Sources/Backend/FIRIdentityToolkitRequest.h" | ||
|
||
NS_ASSUME_NONNULL_BEGIN | ||
|
||
/** @class FIRStartPasskeySignInRequest | ||
@brief Represents the parameters for the startPasskeySignIn endpoint. | ||
*/ | ||
@interface FIRStartPasskeySignInRequest : FIRIdentityToolkitRequest <FIRAuthRPCRequest> | ||
|
||
- (nullable instancetype)initWithRequestConfiguration: | ||
(FIRAuthRequestConfiguration *)requestConfiguration; | ||
|
||
@end | ||
|
||
NS_ASSUME_NONNULL_END |
57 changes: 57 additions & 0 deletions
57
FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInRequest.m
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
/* | ||
* Copyright 2023 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
#import "FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInRequest.h" | ||
|
||
NS_ASSUME_NONNULL_BEGIN | ||
|
||
/** | ||
@var kStartPasskeySignInEndPoint | ||
@brief GCIP endpoint for startPasskeySignIn rpc | ||
*/ | ||
static NSString *const kStartPasskeySignInEndPoint = @"accounts/passkeySignIn:start"; | ||
|
||
/** | ||
@var kTenantIDKey | ||
@brief The key for the tenant id value in the request. | ||
*/ | ||
static NSString *const kTenantIDKey = @"tenantId"; | ||
|
||
@implementation FIRStartPasskeySignInRequest | ||
|
||
- (nullable instancetype)initWithRequestConfiguration: | ||
(FIRAuthRequestConfiguration *)requestConfiguration { | ||
self = [super initWithEndpoint:kStartPasskeySignInEndPoint | ||
requestConfiguration:requestConfiguration]; | ||
|
||
if (self) { | ||
self.useIdentityPlatform = YES; | ||
} | ||
|
||
return self; | ||
} | ||
|
||
- (nullable id)unencodedHTTPRequestBodyWithError:(NSError *__autoreleasing _Nullable *)error { | ||
NSMutableDictionary *postBody = [NSMutableDictionary dictionary]; | ||
if (self.tenantID) { | ||
postBody[kTenantIDKey] = self.tenantID; | ||
} | ||
return [postBody copy]; | ||
} | ||
|
||
@end | ||
|
||
NS_ASSUME_NONNULL_END |
41 changes: 41 additions & 0 deletions
41
FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInResponse.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
/* | ||
* Copyright 2023 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
#import "FirebaseAuth/Sources/Backend/FIRAuthRPCResponse.h" | ||
|
||
NS_ASSUME_NONNULL_BEGIN | ||
|
||
/** | ||
@class FIRStartPasskeySignInResponse | ||
@brief Represents the response from the startPasskeySignIn endpoint. | ||
*/ | ||
@interface FIRStartPasskeySignInResponse : NSObject <FIRAuthRPCResponse> | ||
|
||
/** | ||
@property rpID | ||
@brief The RP ID of the FIDO Relying Party. | ||
*/ | ||
@property(nonatomic, readonly, copy) NSString *rpID; | ||
|
||
/** | ||
@property challenge | ||
@brief The FIDO challenge. | ||
*/ | ||
@property(nonatomic, readonly, copy) NSString *challenge; | ||
|
||
@end | ||
|
||
NS_ASSUME_NONNULL_END |
56 changes: 56 additions & 0 deletions
56
FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInResponse.m
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
/* | ||
* Copyright 2023 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
#import "FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInResponse.h" | ||
|
||
/** | ||
@var kOptionsKey | ||
@brief Parameters specified for the authenticator to sign a challenge. | ||
*/ | ||
static const NSString *kOptionsKey = @"credentialRequestOptions"; | ||
|
||
/** | ||
@var kRpIdKey | ||
@brief The relying party identifier. | ||
*/ | ||
static const NSString *kRpIdKey = @"rpId"; | ||
|
||
/** | ||
@var kChallengeKey | ||
@brief The name of the field in the response JSON for challenge. | ||
*/ | ||
static const NSString *kChallengeKey = @"challenge"; | ||
|
||
@implementation FIRStartPasskeySignInResponse | ||
|
||
- (BOOL)setWithDictionary:(nonnull NSDictionary *)dictionary | ||
error:(NSError *__autoreleasing _Nullable *_Nullable)error { | ||
if (dictionary[kOptionsKey] == nil) { | ||
return NO; | ||
} | ||
if (dictionary[kOptionsKey][kRpIdKey] == nil) { | ||
return NO; | ||
} | ||
if (dictionary[kOptionsKey][kChallengeKey] == nil) { | ||
return NO; | ||
} | ||
|
||
_rpID = dictionary[kOptionsKey][kRpIdKey]; | ||
_challenge = dictionary[kOptionsKey][kChallengeKey]; | ||
return YES; | ||
} | ||
|
||
@end |
96 changes: 96 additions & 0 deletions
96
FirebaseAuth/Tests/Unit/FIRStartPasskeySignInRequestTests.m
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,96 @@ | ||
/* | ||
* Copyright 2023 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
#import <TargetConditionals.h> | ||
#if TARGET_OS_IOS || TARGET_OS_TV || TARGET_OS_OSX || TARGET_OS_MACCATALYST | ||
|
||
#import <XCTest/XCTest.h> | ||
|
||
#import "FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInRequest.h" | ||
#import "FirebaseAuth/Sources/Backend/RPC/FIRStartPasskeySignInResponse.h" | ||
#import "FirebaseAuth/Sources/Public/FirebaseAuth/FIRAuthErrors.h" | ||
#import "FirebaseAuth/Tests/Unit/FIRFakeBackendRPCIssuer.h" | ||
|
||
/** | ||
@var kTestAPIKey | ||
@brief Fake API key used for testing. | ||
*/ | ||
static NSString *const kTestAPIKey = @"APIKey"; | ||
|
||
/** | ||
@var kTestFirebaseAppID | ||
@brief Fake Firebase app ID used for testing. | ||
*/ | ||
static NSString *const kTestFirebaseAppID = @"appID"; | ||
|
||
/** | ||
@var kExpectedAPIURL | ||
@brief The expected URL for the test calls. | ||
*/ | ||
static NSString *const kExpectedAPIURL = | ||
@"https://identitytoolkit.googleapis.com/v2/accounts/passkeySignIn:start?key=APIKey"; | ||
|
||
/** | ||
@class FIRStartPasskeySignInRequestTests | ||
@brief Tests for @c FIRStartPasskeySignInRequest. | ||
*/ | ||
@interface FIRStartPasskeySignInRequestTests : XCTestCase | ||
@end | ||
|
||
@implementation FIRStartPasskeySignInRequestTests { | ||
/** | ||
@brief This backend RPC issuer is used to fake network responses for each test in the suite. | ||
In the @c setUp method we initialize this and set @c FIRAuthBackend's RPC issuer to it. | ||
*/ | ||
FIRFakeBackendRPCIssuer *_RPCIssuer; | ||
|
||
/** | ||
@brief This is the request configuration used for testing. | ||
*/ | ||
FIRAuthRequestConfiguration *_requestConfiguration; | ||
} | ||
|
||
- (void)setUp { | ||
[super setUp]; | ||
FIRFakeBackendRPCIssuer *RPCIssuer = [[FIRFakeBackendRPCIssuer alloc] init]; | ||
[FIRAuthBackend setDefaultBackendImplementationWithRPCIssuer:RPCIssuer]; | ||
_RPCIssuer = RPCIssuer; | ||
_requestConfiguration = [[FIRAuthRequestConfiguration alloc] initWithAPIKey:kTestAPIKey | ||
appID:kTestFirebaseAppID]; | ||
} | ||
|
||
- (void)tearDown { | ||
_RPCIssuer = nil; | ||
_requestConfiguration = nil; | ||
[FIRAuthBackend setDefaultBackendImplementationWithRPCIssuer:nil]; | ||
[super tearDown]; | ||
} | ||
|
||
- (void)testStartPasskeySignInRequest { | ||
FIRStartPasskeySignInRequest *request = | ||
[[FIRStartPasskeySignInRequest alloc] initWithRequestConfiguration:_requestConfiguration]; | ||
|
||
[FIRAuthBackend startPasskeySignIn:request | ||
callback:^(FIRStartPasskeySignInResponse *_Nullable response, | ||
NSError *_Nullable error){ | ||
}]; | ||
|
||
XCTAssertEqualObjects(_RPCIssuer.requestURL.absoluteString, kExpectedAPIURL); | ||
XCTAssertNotNil(_RPCIssuer.decodedRequest); | ||
} | ||
|
||
@end | ||
#endif |
Oops, something went wrong.