You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

98 lines
3.4 KiB

/*
* Copyright 2017 Google
*
* 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 "FIRAdditionalUserInfo_Internal.h"
#import "FIRVerifyAssertionResponse.h"
NS_ASSUME_NONNULL_BEGIN
@implementation FIRAdditionalUserInfo
/** @var kProviderIDCodingKey
@brief The key used to encode the providerID property for NSSecureCoding.
*/
static NSString *const kProviderIDCodingKey = @"providerID";
/** @var kProfileCodingKey
@brief The key used to encode the profile property for NSSecureCoding.
*/
static NSString *const kProfileCodingKey = @"profile";
/** @var kUsernameCodingKey
@brief The key used to encode the username property for NSSecureCoding.
*/
static NSString *const kUsernameCodingKey = @"username";
/** @var kNewUserKey
@brief The key used to encode the newUser property for NSSecureCoding.
*/
static NSString *const kNewUserKey = @"newUser";
+ (nullable instancetype)userInfoWithVerifyAssertionResponse:
(FIRVerifyAssertionResponse *)verifyAssertionResponse {
return [[self alloc] initWithProviderID:verifyAssertionResponse.providerID
profile:verifyAssertionResponse.profile
username:verifyAssertionResponse.username
isNewUser:verifyAssertionResponse.isNewUser];
}
- (nullable instancetype)initWithProviderID:(nullable NSString *)providerID
profile:(nullable NSDictionary<NSString *, NSObject *> *)profile
username:(nullable NSString *)username
isNewUser:(BOOL)isNewUser {
self = [super init];
if (self) {
_providerID = [providerID copy];
if (profile) {
_profile = [[NSDictionary alloc] initWithDictionary:profile copyItems:YES];
}
_username = [username copy];
_newUser = isNewUser;
}
return self;
}
#pragma mark - NSSecureCoding
+ (BOOL)supportsSecureCoding {
return YES;
}
- (nullable instancetype)initWithCoder:(NSCoder *)aDecoder {
NSString *providerID =
[aDecoder decodeObjectOfClass:[NSString class] forKey:kProviderIDCodingKey];
NSDictionary<NSString *, NSObject *> *profile =
[aDecoder decodeObjectOfClass:[NSDictionary class] forKey:kProfileCodingKey];
NSString *username = [aDecoder decodeObjectOfClass:[NSString class] forKey:kUsernameCodingKey];
NSNumber *isNewUser = [aDecoder decodeObjectOfClass:[NSNumber class] forKey:kNewUserKey];
return [self initWithProviderID:providerID
profile:profile
username:username
isNewUser:isNewUser.boolValue];
}
- (void)encodeWithCoder:(NSCoder *)aCoder {
[aCoder encodeObject:_providerID forKey:kProviderIDCodingKey];
[aCoder encodeObject:_profile forKey:kProfileCodingKey];
[aCoder encodeObject:_username forKey:kUsernameCodingKey];
[aCoder encodeObject:[NSNumber numberWithBool:_newUser] forKey:kNewUserKey];
}
@end
NS_ASSUME_NONNULL_END