aboutsummaryrefslogtreecommitdiffhomepage
path: root/Firebase/Auth/Source/FIRAdditionalUserInfo.m
blob: c6ba37c645328ac037e7542ac94548353681e3c9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*
 * 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