231 lines
8.5 KiB
Markdown
231 lines
8.5 KiB
Markdown
# 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<ReactPackage> getPackages() {
|
|
return Arrays.<ReactPackage>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
|
|
<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 activity props:
|
|
```xml
|
|
<activity
|
|
...
|
|
android:launchMode="singleTop"
|
|
>
|
|
```
|
|
|
|
Add messaging service:
|
|
```xml
|
|
<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>
|
|
```
|
|
|
|
If you would like to schedule local notifications then you also need to add the following:
|
|
```xml
|
|
<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>
|
|
```
|
|
|
|
## 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
|
|
<intent-filter>
|
|
<action android:name="android.intent.action.VIEW"/>
|
|
<category android:name="android.intent.category.DEFAULT"/>
|
|
<category android:name="android.intent.category.BROWSABLE"/>
|
|
<data android:host="yoursite.example.com" android:scheme="http"/>
|
|
<data android:host="yoursite.example.com" android:scheme="https"/>
|
|
</intent-filter>
|
|
```
|