# Android Installation ## 1) Link RNFirebase Run `react-native link react-native-firebase` ## 2) Setup google-services.json 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`. 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` ```groovy buildscript { // ... dependencies { // ... classpath 'com.google.gms:google-services:3.1.1' } } ``` In your app build.gradle file, add the gradle plugin at the VERY BOTTOM of the file (below all dependencies) `android/app/build.gradle` ```groovy apply plugin: 'com.google.gms.google-services' ``` ## 3) Setup Firebase Now you need to the required Firebase dependencies in our `android/app/build.gradle` so that they are compiled as part of React Native. In the `dependencies` listing, add the appropriate `compile` lines: ```groovy dependencies { // This should be added already compile(project(':react-native-firebase')) { transitive = false } // RNFirebase required dependencies compile "com.google.firebase:firebase-core:11.4.2" compile "com.google.android.gms:play-services-base:11.4.2" // RNFirebase optional dependencies compile "com.google.firebase:firebase-ads:11.4.2" compile "com.google.firebase:firebase-auth:11.4.2" compile "com.google.firebase:firebase-config:11.4.2" compile "com.google.firebase:firebase-crash:11.4.2" compile "com.google.firebase:firebase-database:11.4.2" compile "com.google.firebase:firebase-firestore:11.4.2" compile "com.google.firebase:firebase-invites:11.4.2" compile "com.google.firebase:firebase-messaging:11.4.2" compile "com.google.firebase:firebase-perf:11.4.2" compile "com.google.firebase:firebase-storage:11.4.2" } ``` Google Play services from 11.2.0 onwards require their dependencies to be downloaded from Google's Maven respository so add the required reference to the repositories section of the *project* level build.gradle `android/build.gradle` ```groovy allprojects { repositories { mavenLocal() jcenter() maven { // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm url "$rootDir/../node_modules/react-native/android" } // ------------------------------------------------- // Add this below the existing maven property above // ------------------------------------------------- maven { url 'https://maven.google.com' } } } ``` ## 4) Install RNFirebase modules RNFirebase is split into separate modules to allow you to only include the Firebase functionality that you need in your application. To install `react-native-firebase` in your project, you'll need to import the packages you need from `io.invertase.firebase` in your project's `android/app/src/main/java/com/[app name]/MainApplication.java` and list them as packages for ReactNative in the `getPackages()` function: ```java package com.youcompany.application; // ... // Required package import io.invertase.firebase.RNFirebasePackage; // <-- This should be added already // Optional packages - add as appropriate import io.invertase.firebase.admob.RNFirebaseAdMobPackage; //Firebase AdMob import io.invertase.firebase.analytics.RNFirebaseAnalyticsPackage; // Firebase Analytics import io.invertase.firebase.auth.RNFirebaseAuthPackage; // Firebase Auth import io.invertase.firebase.config.RNFirebaseRemoteConfigPackage; // Firebase Remote Config import io.invertase.firebase.crash.RNFirebaseCrashPackage; // Firebase Crash Reporting import io.invertase.firebase.database.RNFirebaseDatabasePackage; // Firebase Realtime Database import io.invertase.firebase.firestore.RNFirebaseFirestorePackage; // Firebase Firestore import io.invertase.firebase.links.RNFirebaseLinksPackage; // Firebase Links import io.invertase.firebase.messaging.RNFirebaseMessagingPackage; // Firebase Cloud Messaging import io.invertase.firebase.perf.RNFirebasePerformancePackage; // Firebase Performance import io.invertase.firebase.storage.RNFirebaseStoragePackage; // Firebase Storage // ... public class MainApplication extends Application implements ReactApplication { // ... @Override protected List getPackages() { return Arrays.asList( new MainReactPackage(), new RNFirebasePackage(), // <-- This should be added already // Add these packages as appropriate new RNFirebaseAdMobPackage(), new RNFirebaseAnalyticsPackage(), new RNFirebaseAuthPackage(), new RNFirebaseRemoteConfigPackage(), new RNFirebaseCrashPackage(), new RNFirebaseDatabasePackage(), new RNFirebaseFirestorePackage(), new RNFirebaseLinksPackage(), new RNFirebaseMessagingPackage(), new RNFirebasePerformancePackage(), new RNFirebaseStoragePackage() ); } }; // ... } ``` ## 5) Cloud Messaging (optional) 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: ```xml ``` Set app [launch mode](https://inthecheesefactory.com/blog/understand-android-activity-launchmode/en) inside activity props: ```xml ``` Add messaging service: ```xml ``` If you would like to schedule local notifications then you also need to add the following: ```xml ``` ## 6) Performance Monitoring (optional) If you'd like to take advantage of Firebase's [Performance Monitoring](https://firebase.google.com/docs/perf-mon/), the following additions to your project setup are required: In your projects `android/build.gradle` file, add the plugin to your dependencies: ```groovy dependencies { // ... classpath 'com.google.firebase:firebase-plugins:1.1.0' } ``` At the top of your `android/app/build.gradle` file, below other plugins, apply the `firebase-perf` plugin: ```groovy apply plugin: "com.android.application" apply plugin: "com.google.firebase.firebase-perf" ``` In the same file, add the `firebase-perf` module to your dependencies: ```groovy dependencies { // ... compile "com.google.firebase:firebase-perf:11.4.2" } ``` ## 7) Dynamic Links (optional) If you plan on using [Firebase Dynamic Links](https://firebase.google.com/docs/dynamic-links/): Make sure to setup dynamic links for Android as described [here](https://firebase.google.com/docs/dynamic-links/android/receive#set-up-firebase-and-the-dynamic-links-sdk) In `android/app/src/main/AndroidManifest.xml`, add a new intent filter to the activity that handles deep links for your app (for react-native this is usually MainActivity), and specify the host and the scheme: ```xml ```