2017-04-27 12:18:12 +01:00
# iOS Installation
2017-03-02 12:50:09 +00:00
2017-07-23 15:01:04 +02:00
Please note that there is a known issue when using Cocoapods with the `use_frameworks!` enabled. This is explained [here ](https://github.com/invertase/react-native-firebase/issues/252#issuecomment-316340974 ). Unfortunately we don't currently have a workaround, but are engaging with Firebase directly to try and resolve the problem.
2017-07-19 11:25:12 +01:00
2017-06-13 17:27:35 +01:00
## 1) Setup GoogleService-Info.plist
2017-06-13 16:18:12 +01:00
Setup the `GoogleService-Info.plist` file by following the instructions and adding it to the root of your project at `ios/[YOUR APP NAME]/GoogleService-Info.plist` [here ](https://firebase.google.com/docs/ios/setup#add_firebase_to_your_app ).
2017-03-28 09:22:25 +01:00
2017-04-27 12:18:12 +01:00
### 1.1) Initialisation
2017-04-06 13:11:43 +01:00
Make sure you've added the following to the top of your `ios/[YOUR APP NAME]]/AppDelegate.m` file:
2017-03-02 12:50:09 +00:00
2017-03-28 09:22:25 +01:00
`#import <Firebase.h>`
2017-03-02 12:50:09 +00:00
2017-06-13 16:18:12 +01:00
and this to the `didFinishLaunchingWithOptions:(NSDictionary *)launchOptions` method before the `return` statement:
2017-03-28 09:22:25 +01:00
`[FIRApp configure];`
2017-06-20 10:17:56 +01:00
## 2) Setup RNFirebase
2017-05-03 08:40:15 +01:00
2017-06-20 10:17:56 +01:00
Unfortunately, due to the fact that Firebase is much easier to setup using Cocoapods, *we do not recommend* `react-native link` as it is not customisable enough for our needs and we have had numerous problems reported.
2017-03-28 09:22:25 +01:00
2017-06-13 16:18:12 +01:00
### 2.0) If you don't already have Cocoapods set up
Follow the instructions to install Cocoapods and create your Podfile [here ](https://firebase.google.com/docs/ios/setup#add_the_sdk ).
2017-03-02 12:50:09 +00:00
2017-06-30 14:18:10 +01:00
**NOTE: The Podfile needs to be initialised in the `ios` directory of your project. Make sure to update cocoapods libs first by running `pod update` **
2017-03-28 09:22:25 +01:00
2017-06-13 17:22:41 +01:00
#### Troubleshooting
1) When running `pod install` you may encounter an error saying that a `tvOSTests` target is declared twice. This appears to be a bug with `pod init` and the way that react native is set up.
2017-05-03 08:40:15 +01:00
2017-06-13 17:22:41 +01:00
**Resolution:**
- Open your Podfile
- Remove the duplicate `tvOSTests` target nested within the main project target
- Re-run `pod install` .
2017-04-27 12:18:12 +01:00
2017-06-13 17:22:41 +01:00
2) When running `pod install` you may encounter a number of warnings relating to `target overrides 'OTHER_LDFLAGS'` .
2017-03-27 12:38:33 +01:00
2017-06-13 17:22:41 +01:00
**Resolution:**
- Open Xcode
- Select your project
- For each target:
-- Select the target
-- Click Build settings
-- Search for `other linker flags`
-- Add `$(inherited)` as the top line if it doesn't already exist
- Re-run `pod install`
2017-03-27 12:38:33 +01:00
2017-06-13 17:22:41 +01:00
3) When running `pod install` you may encounter a warning that a default iOS platform has been assigned. If you wish to specify a different minimum version:
2017-03-27 12:38:33 +01:00
2017-06-13 17:22:41 +01:00
**Resolution**
- Open your Podfile
- Uncomment the `# platform :ios, '9.0'` line by removing the `#` character
- Change the version as required
2017-03-27 12:38:33 +01:00
2017-06-13 16:18:12 +01:00
### 2.1) Add the required pods
2017-06-13 17:22:41 +01:00
Simply add the following to your `Podfile` either at the top level, or within the main project target:
2017-03-28 09:22:25 +01:00
```ruby
# Required by RNFirebase
pod 'Firebase/Core'
2017-06-16 13:45:45 +01:00
pod 'RNFirebase', :path => '../node_modules/react-native-firebase'
# [OPTIONAL PODS] - comment out pods for firebase products you won't be using.
pod 'Firebase/AdMob'
pod 'Firebase/Analytics'
pod 'Firebase/Auth'
2017-03-28 09:22:25 +01:00
pod 'Firebase/Crash'
pod 'Firebase/Database'
pod 'Firebase/DynamicLinks'
pod 'Firebase/Messaging'
pod 'Firebase/RemoteConfig'
pod 'Firebase/Storage'
```
2017-08-03 08:54:10 +01:00
If you do not already have React and Yoga installed as pods, then add Yoga and React to your `Podfile` as follows:
2017-03-28 09:22:25 +01:00
```ruby
2017-06-13 16:18:12 +01:00
pod "Yoga", :path => "../node_modules/react-native/ReactCommon/yoga"
pod 'React', :path => '../node_modules/react-native', :subspecs => [
2017-06-13 17:22:41 +01:00
'BatchedBridge', # Required For React Native 0.45.0+
2017-06-13 16:18:12 +01:00
'Core',
# Add any other subspecs you want to use in your project
]
2017-03-28 09:22:25 +01:00
```
2017-06-13 17:22:41 +01:00
Run `pod install` .
2017-05-03 08:40:15 +01:00
**NOTE: You need to use the `ios/[YOUR APP NAME].xcworkspace` instead of the `ios/[YOUR APP NAME].xcproj` file from now on.**
2017-05-02 09:36:17 +01:00
2017-06-13 17:22:41 +01:00
#### Troubleshooting
1) You receive an error `No podspec found for 'RNFirebase'`
**Resolution**
- Run `npm install --save react-native-firebase` from the root of your project
2017-05-02 09:36:17 +01:00
## 3) Cloud Messaging (optional)
If you plan on using [Firebase Cloud Messaging ](https://firebase.google.com/docs/cloud-messaging/ ) then, you need to:
**NOTE: FCM does not work on the iOS simulator, you must test is using a real device. This is a restriction enforced by Apple for some unknown reason.**
### 3.1) Set up certificates
Follow the instructions at https://firebase.google.com/docs/cloud-messaging/ios/certs
### 3.2) Enable capabilities
In Xcode, enable the following capabilities:
1) Push Notifications
2017-05-11 09:54:23 +01:00
2) Background modes > Remote notifications
2017-05-02 09:36:17 +01:00
### 3.3) Update `AppDelegate.h`
Add the following import:
`@import UserNotifications;`
Change the interface descriptor to:
`@interface AppDelegate : UIResponder <UIApplicationDelegate,UNUserNotificationCenterDelegate>`
### 3.4) Update `AppDelegate.m`
Add the following import:
`#import "RNFirebaseMessaging.h"`
Add the following to the `didFinishLaunchingWithOptions:(NSDictionary *)launchOptions` method after `[FIRApp Configure]` :
`[[UNUserNotificationCenter currentNotificationCenter] setDelegate:self];`
Add the following methods:
2017-05-02 10:56:33 +01:00
```objectivec
2017-05-02 09:36:17 +01:00
-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification * )notification {
[RNFirebaseMessaging didReceiveLocalNotification:notification];
}
2017-05-30 10:04:27 +01:00
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(nonnull NSDictionary * )userInfo {
[RNFirebaseMessaging didReceiveRemoteNotification:userInfo];
}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(nonnull NSDictionary * )userInfo
2017-06-16 13:45:45 +01:00
fetchCompletionHandler:(nonnull void (^)(UIBackgroundFetchResult))completionHandler{
2017-05-02 09:36:17 +01:00
[RNFirebaseMessaging didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
}
2017-07-19 12:49:18 +01:00
- (void)userNotificationCenter:(UNUserNotificationCenter *)center
willPresentNotification:(UNNotification *)notification
withCompletionHandler:(void (^)(UNNotificationPresentationOptions))completionHandler {
[RNFirebaseMessaging willPresentNotification:notification withCompletionHandler:completionHandler];
}
- (void)userNotificationCenter:(UNUserNotificationCenter *)center
didReceiveNotificationResponse:(UNNotificationResponse *)response
withCompletionHandler:(void (^)())completionHandler {
[RNFirebaseMessaging didReceiveNotificationResponse:response withCompletionHandler:completionHandler];
}
2017-05-02 09:36:17 +01:00
```
2017-05-30 10:04:27 +01:00
### 3.5) Debugging
If you're having problems with messages not being received, check out the following blog post for help:
https://firebase.googleblog.com/2017/01/debugging-firebase-cloud-messaging-on.html