FIRMultiFactor.m 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /*
  2. * Copyright 2019 Google
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #include <TargetConditionals.h>
  17. #if TARGET_OS_IOS
  18. #import "FIRMultiFactor.h"
  19. #import "FIRMultiFactor+Internal.h"
  20. #import "FIRAuth_Internal.h"
  21. #import "FIRAuthBackend+MultiFactor.h"
  22. #import "FIRAuthDataResult_Internal.h"
  23. #import "FIRMultiFactorInfo+Internal.h"
  24. #import "FIRStartMFAEnrollmentRequest.h"
  25. #import "FIRUser_Internal.h"
  26. #import "FIRMultiFactorSession+Internal.h"
  27. #if TARGET_OS_IOS
  28. #import "FIRPhoneAuthCredential_Internal.h"
  29. #import "FIRPhoneMultiFactorAssertion.h"
  30. #import "FIRPhoneMultiFactorAssertion+Internal.h"
  31. #endif
  32. NS_ASSUME_NONNULL_BEGIN
  33. static NSString *kEnrolledFactorsCodingKey = @"enrolledFactors";
  34. static NSString *kUserCodingKey = @"user";
  35. @implementation FIRMultiFactor
  36. - (void)getSessionWithCompletion:(nullable FIRMultiFactorSessionCallback)completion {
  37. FIRMultiFactorSession *session = [FIRMultiFactorSession sessionForCurrentUser];
  38. if (completion) {
  39. completion(session, nil);
  40. }
  41. }
  42. - (void)enrollWithAssertion:(FIRMultiFactorAssertion*)assertion
  43. displayName:(nullable NSString *)displayName
  44. completion:(nullable FIRAuthVoidErrorCallback)completion {
  45. #if TARGET_OS_IOS
  46. FIRPhoneMultiFactorAssertion *phoneAssertion = (FIRPhoneMultiFactorAssertion *)assertion;
  47. FIRAuthProtoFinalizeMFAPhoneRequestInfo *finalizeMFAPhoneRequestInfo =
  48. [[FIRAuthProtoFinalizeMFAPhoneRequestInfo alloc] initWithSessionInfo:phoneAssertion.authCredential.verificationID
  49. verificationCode:phoneAssertion.authCredential.verificationCode];
  50. FIRFinalizeMFAEnrollmentRequest *request =
  51. [[FIRFinalizeMFAEnrollmentRequest alloc] initWithIDToken:self.user.rawAccessToken
  52. MFAProvider:phoneAssertion.factorID
  53. displayName:displayName
  54. verificationInfo:finalizeMFAPhoneRequestInfo
  55. requestConfiguration:self.user.requestConfiguration];
  56. [FIRAuthBackend finalizeMultiFactorEnrollment:request
  57. callback:^(FIRFinalizeMFAEnrollmentResponse * _Nullable response,
  58. NSError * _Nullable error) {
  59. if (error) {
  60. if (completion) {
  61. completion(error);
  62. }
  63. } else {
  64. [FIRAuth.auth completeSignInWithAccessToken:response.IDToken
  65. accessTokenExpirationDate:nil
  66. refreshToken:response.refreshToken
  67. anonymous:NO
  68. callback:^(FIRUser *_Nullable user, NSError *_Nullable error) {
  69. FIRAuthDataResult* result = [[FIRAuthDataResult alloc] initWithUser:user additionalUserInfo:nil];
  70. FIRAuthDataResultCallback decoratedCallback =
  71. [FIRAuth.auth signInFlowAuthDataResultCallbackByDecoratingCallback:^(FIRAuthDataResult *_Nullable authResult,
  72. NSError *_Nullable error) {
  73. if (completion) {
  74. completion(error);
  75. }
  76. }];
  77. decoratedCallback(result, error);
  78. }];
  79. }
  80. }];
  81. #endif
  82. }
  83. - (void)unenrollWithInfo:(FIRMultiFactorInfo *)factorInfo
  84. completion:(nullable FIRAuthVoidErrorCallback)completion {
  85. [self unenrollWithFactorUID:factorInfo.UID completion:completion];
  86. }
  87. - (void)unenrollWithFactorUID:(NSString *)factorUID
  88. completion:(nullable FIRAuthVoidErrorCallback)completion {
  89. FIRWithdrawMFARequest *request = [[FIRWithdrawMFARequest alloc] initWithIDToken:self.user.rawAccessToken
  90. MFAEnrollmentID:factorUID
  91. requestConfiguration:self.user.requestConfiguration];
  92. [FIRAuthBackend withdrawMultiFactor:request
  93. callback:^(FIRWithdrawMFAResponse *_Nullable response, NSError * _Nullable error) {
  94. if (error) {
  95. if (completion) {
  96. completion(error);
  97. }
  98. } else {
  99. [FIRAuth.auth completeSignInWithAccessToken:response.IDToken
  100. accessTokenExpirationDate:nil
  101. refreshToken:response.refreshToken
  102. anonymous:NO
  103. callback:^(FIRUser *_Nullable user, NSError *_Nullable error) {
  104. FIRAuthDataResult* result = [[FIRAuthDataResult alloc] initWithUser:user additionalUserInfo:nil];
  105. FIRAuthDataResultCallback decoratedCallback =
  106. [FIRAuth.auth signInFlowAuthDataResultCallbackByDecoratingCallback:^(FIRAuthDataResult *_Nullable authResult,
  107. NSError *_Nullable error) {
  108. if (error) {
  109. [[FIRAuth auth] signOut:NULL];
  110. }
  111. if (completion) {
  112. completion(error);
  113. }
  114. }];
  115. decoratedCallback(result, error);
  116. }];
  117. }
  118. }];
  119. }
  120. #pragma mark - Internal
  121. - (instancetype)initWithMFAEnrollments:(NSArray<FIRAuthProtoMFAEnrollment *> *)MFAEnrollments {
  122. self = [super init];
  123. if (self) {
  124. NSMutableArray<FIRMultiFactorInfo *> *multiFactorInfoArray = [[NSMutableArray alloc] init];
  125. for (FIRAuthProtoMFAEnrollment *MFAEnrollment in MFAEnrollments) {
  126. FIRMultiFactorInfo *multiFactorInfo = [[FIRMultiFactorInfo alloc] initWithProto:MFAEnrollment];
  127. [multiFactorInfoArray addObject:multiFactorInfo];
  128. }
  129. _enrolledFactors = [multiFactorInfoArray copy];
  130. }
  131. return self;
  132. }
  133. #pragma mark - NSSecureCoding
  134. + (BOOL)supportsSecureCoding {
  135. return YES;
  136. }
  137. - (nullable instancetype)initWithCoder:(NSCoder *)aDecoder {
  138. self = [self init];
  139. if (self) {
  140. NSArray<FIRMultiFactorInfo *> *enrolledFactors
  141. = [aDecoder decodeObjectOfClass:[NSArray<FIRMultiFactorInfo *> class]
  142. forKey:kEnrolledFactorsCodingKey];
  143. _enrolledFactors = enrolledFactors;
  144. _user = [aDecoder decodeObjectOfClass:[FIRUser class] forKey:kUserCodingKey];
  145. }
  146. return self;
  147. }
  148. - (void)encodeWithCoder:(NSCoder *)aCoder {
  149. [aCoder encodeObject:_enrolledFactors forKey:kEnrolledFactorsCodingKey];
  150. [aCoder encodeObject:_user forKey:kUserCodingKey];
  151. }
  152. @end
  153. NS_ASSUME_NONNULL_END
  154. #endif