2017-03-02 12:50:09 +00:00
# Android Installation
2017-04-27 12:18:12 +01:00
## 1) Setup google-services.json
2017-04-06 13:01:18 +01:00
Download the `google-services.json` file provided by Firebase in the _Add Firebase to Android_ platform menu in your Firebase configuration console. This file should be downloaded to `YOUR_PROJECT/android/app/google-services.json` .
2017-03-02 12:50:09 +00:00
2017-04-06 13:01:18 +01:00
Next you'll have to add the google-services gradle plugin in order to parse it.
Add the google-services gradle plugin as a dependency in the *project* level build.gradle
`android/build.gradle`
```java
buildscript {
// ...
dependencies {
// ...
classpath 'com.google.gms:google-services:3.0.0'
}
}
2017-03-02 12:50:09 +00:00
```
2017-04-06 13:01:18 +01:00
In your app build.gradle file, add the gradle plugin at the VERY BOTTOM of the file (below all dependencies)
`android/app/build.gradle`
```java
apply plugin: 'com.google.gms.google-services'
2017-03-02 12:50:09 +00:00
```
2017-04-27 12:18:12 +01:00
## 2) Link RNFirebase
2017-03-02 12:50:09 +00:00
2017-04-06 13:01:18 +01:00
To install `react-native-firebase` in your project, you'll need to import the package from `io.invertase.firebase` in your project's `android/app/src/main/java/com/[app name]/MainApplication.java` and list it as a package for ReactNative in the `getPackages()` function:
2017-03-02 12:50:09 +00:00
```java
package com.youcompany.application;
// ...
import io.invertase.firebase.RNFirebasePackage;
// ...
public class MainApplication extends Application implements ReactApplication {
// ...
@Override
protected List< ReactPackage > getPackages() {
return Arrays.< ReactPackage > asList(
new MainReactPackage(),
new RNFirebasePackage() // < -- Add this line
);
}
};
// ...
}
```
2017-04-06 13:01:18 +01:00
You'll also need to list it in our `android/app/build.gradle` file as a dependency that we want React Native to compile. In the `dependencies` listing, add the `compile` line:
2017-03-02 12:50:09 +00:00
```java
dependencies {
compile project(':react-native-firebase')
}
```
2017-03-17 14:39:50 +00:00
Add the project path to `android/settings.gradle` :
2017-03-02 12:50:09 +00:00
2017-03-13 10:25:43 +00:00
```
include ':react-native-firebase'
project(':react-native-firebase').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-firebase/android')
```
2017-03-17 14:39:50 +00:00
2017-04-27 12:18:12 +01:00
## 3) Cloud Messaging (optional)
2017-04-06 13:01:18 +01:00
2017-03-17 14:39:50 +00:00
If you plan on using [Firebase Cloud Messaging ](https://firebase.google.com/docs/cloud-messaging/ ), add the following to `android/app/src/main/AndroidManifest.xml` .
Add permissions:
2017-04-11 12:50:39 +01:00
```xml
2017-03-17 14:39:50 +00:00
< manifest . . . >
< uses-permission android:name = "android.permission.INTERNET" / >
< uses-permission android:name = "android.permission.RECEIVE_BOOT_COMPLETED" / >
< uses-permission android:name = "android.permission.VIBRATE" / >
```
Set app [launch mode ](https://inthecheesefactory.com/blog/understand-android-activity-launchmode/en ) inside application props:
2017-04-11 12:50:39 +01:00
```xml
2017-03-17 14:39:50 +00:00
< application
...
android:launchMode="singleTop"
>
```
Add messaging service:
2017-04-11 12:50:39 +01:00
```xml
2017-03-17 14:39:50 +00:00
< application . . . >
< service
android:name="io.invertase.firebase.messaging.MessagingService"
android:enabled="true"
android:exported="true">
< intent-filter >
< action android:name = "com.google.firebase.MESSAGING_EVENT" / >
< / intent-filter >
< / service >
< service android:name = "io.invertase.firebase.messaging.InstanceIdService" android:exported = "false" >
< intent-filter >
< action android:name = "com.google.firebase.INSTANCE_ID_EVENT" / >
< / intent-filter >
< / service >
```
2017-03-27 13:48:50 +01:00
If you would like to schedule local notifications then you also need to add the following:
2017-04-11 12:50:39 +01:00
```xml
2017-03-27 13:48:50 +01:00
< receiver android:name = "io.invertase.firebase.messaging.RNFirebaseLocalMessagingPublisher" / >
< receiver android:enabled = "true" android:exported = "true" android:name = "io.invertase.firebase.messaging.RNFirebaseSystemBootEventReceiver" >
< intent-filter >
< action android:name = "android.intent.action.BOOT_COMPLETED" / >
< action android:name = "android.intent.action.QUICKBOOT_POWERON" / >
< action android:name = "com.htc.intent.action.QUICKBOOT_POWERON" / >
< category android:name = "android.intent.category.DEFAULT" / >
< / intent-filter >
< / receiver >
```