diff options
author | chliangGoogle <chliang@google.com> | 2018-01-24 11:57:27 -0800 |
---|---|---|
committer | chliangGoogle <chliang@google.com> | 2018-01-24 11:57:27 -0800 |
commit | 44a2bc0db04fe0c695949d2be7661789f0fcb7c8 (patch) | |
tree | 1c52cd6b333b1f3d270071cd307340397e216b3d /Firebase/Messaging/FIRMessaging.m | |
parent | 7b9a5601d7d162b14935299e2bf653488f0a9f2f (diff) |
Adding enable/disable property to FCM token auto Initialization
Diffstat (limited to 'Firebase/Messaging/FIRMessaging.m')
-rw-r--r-- | Firebase/Messaging/FIRMessaging.m | 45 |
1 files changed, 43 insertions, 2 deletions
diff --git a/Firebase/Messaging/FIRMessaging.m b/Firebase/Messaging/FIRMessaging.m index 64b1ef8..2a14e04 100644 --- a/Firebase/Messaging/FIRMessaging.m +++ b/Firebase/Messaging/FIRMessaging.m @@ -37,7 +37,11 @@ #import "FIRMessagingUtilities.h" #import "FIRMessagingVersionUtilities.h" +#ifdef COCOAPODS #import "FIRReachabilityChecker.h" +#else +#import "third_party/firebase/ios/Source/FirebaseCore/Library/Private/FIRReachabilityChecker.h" +#endif #import "NSError+FIRMessaging.h" @@ -70,6 +74,14 @@ NSString * const FIRMessagingRegistrationTokenRefreshedNotification = @"com.firebase.messaging.notif.fcm-token-refreshed"; #endif // defined(__IPHONE_10_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0 +NSString *const kFIRMessagingUserDefaultsKeyAutoInitEnabled = + @"com.firebase.messaging.auto-init.enabled"; // Auto Init Enabled key stored in NSUserDefaults +NSString *const kFIRMessagingSuiteName = + @"com.firebase.messaging.user_defaults"; // Suite name for NSUserDefaults + +static NSString *const kFIRMessagingPlistAutoInitEnabled = + @"FirebaseMessagingAutoInitEnabled"; // Auto Init Enabled key stored in Info.plist + // Copied from Apple's header in case it is missing in some cases (e.g. pre-Xcode 8 builds). #ifndef NSFoundationVersionNumber_iOS_8_x_Max #define NSFoundationVersionNumber_iOS_8_x_Max 1199 @@ -120,8 +132,8 @@ NSString * const FIRMessagingRegistrationTokenRefreshedNotification = @end -@interface FIRMessaging () - <FIRMessagingClientDelegate, FIRMessagingReceiverDelegate, FIRReachabilityDelegate> +@interface FIRMessaging ()<FIRMessagingClientDelegate, FIRMessagingReceiverDelegate, + FIRReachabilityDelegate> // FIRApp properties @property(nonatomic, readwrite, copy) NSString *fcmSenderID; @@ -141,6 +153,7 @@ NSString * const FIRMessagingRegistrationTokenRefreshedNotification = @property(nonatomic, readwrite, strong) FIRMessagingRmqManager *rmq2Manager; @property(nonatomic, readwrite, strong) FIRMessagingReceiver *receiver; @property(nonatomic, readwrite, strong) FIRMessagingSyncMessageManager *syncMessageManager; +@property(nonatomic, readwrite, strong) NSUserDefaults *messagingUserDefaults; /// Message ID's logged for analytics. This prevents us from logging the same message twice /// which can happen if the user inadvertently calls `appDidReceiveMessage` along with us @@ -166,6 +179,7 @@ NSString * const FIRMessagingRegistrationTokenRefreshedNotification = if (self) { _loggedMessageIDs = [NSMutableSet set]; _instanceIDProxy = [[FIRMessagingInstanceIDProxy alloc] init]; + _messagingUserDefaults = [[NSUserDefaults alloc] initWithSuiteName:kFIRMessagingSuiteName]; } return self; } @@ -448,6 +462,33 @@ NSString * const FIRMessagingRegistrationTokenRefreshedNotification = #pragma mark - FCM +- (BOOL)isAutoInitEnabled { + // Check storage + id isAutoInitEnabledObject = + [_messagingUserDefaults objectForKey:kFIRMessagingUserDefaultsKeyAutoInitEnabled]; + if (isAutoInitEnabledObject) { + return [isAutoInitEnabledObject boolValue]; + } + + // Check Info.plist + isAutoInitEnabledObject = + [[NSBundle mainBundle] objectForInfoDictionaryKey:kFIRMessagingPlistAutoInitEnabled]; + if (isAutoInitEnabledObject) { + return [isAutoInitEnabledObject boolValue]; + } + // If none of above exists, we default assume FCM auto init is enabled. + return YES; +} + +- (void)setAutoInitEnabled:(BOOL)autoInitEnabled { + BOOL isFCMAutoInitEnabled = [self isAutoInitEnabled]; + [_messagingUserDefaults setBool:autoInitEnabled + forKey:kFIRMessagingUserDefaultsKeyAutoInitEnabled]; + if (!isFCMAutoInitEnabled && autoInitEnabled) { + self.defaultFcmToken = [self FCMToken]; + } +} + - (NSString *)FCMToken { NSString *token = self.defaultFcmToken; if (!token) { |