Skip to content
Firebase scripts and rules
JavaScript
Branch: master
Clone or download
ben3 ben3
Latest commit a0397f4 Aug 2, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
functions Added reciprocal contacts Aug 2, 2019
.gitignore Added reciprocal contacts Aug 2, 2019
README.MD Added reciprocal contacts Aug 2, 2019
chat-sdk-rules.json Added reciprocal contacts Aug 2, 2019
chat-sdk-storage-rules.json Added reciprocal contacts Aug 2, 2019
firebase.json Added reciprocal contacts Aug 2, 2019

README.MD

Firebase Environment Setup

There are a few steps you need to complete to get your Firebase environment ready:

  1. Setup Push Notifications
  2. Enable the security and search rules
  3. Enable the storage rules

Setup Firebase Cloud Functions

To handle push notifications, we use Firebase Cloud Functions. This service allows you to upload a script to Firebase hosting. This script monitors the realtime database and whenever a new messsage is detected, it sends a push notification to the recipient.

Below is a summary of the steps that are required to setup push using the Firebase Cloud Functions script. For further instructions you can look at the Firebase Documentation.

  1. Run firebase login and login using the browser
  2. Make a new directory to store your push functions in. It can be called anything
  3. Navigate to that directory using the terminal
  4. Run firebase init functions
  5. Choose the correct app from the list
  6. Choose JavaScript
  7. Choose y for ESLint
  8. Choose Y to install node dependencies
  9. Find the functions directory you've just created and add the files: index.js and package.json from Github
  10. If you are using the user blocking module ensure that the variable in the script blockedUsersEnabled is set to true
  11. Run firebase deploy

Now the script is active and push notifications will be set out automatically.

Deploy the Firebase rules

Firebase secures your data by allowing you to write rules to govern who can access the database and what can be written. On the Firebase dashboard click Database then the Rules tab.

Copy the contents of the rules.json file into the rules and click publish.

OR

Update your firebase.json file as follows:

"database": {
  "rules": "chat-sdk-rules.json"
}

Copy the chat-sdk-rules.json file into your project directory then run:

firebase deploy --only database:rules

Deploy the storage rules

Make sure storage is enabled for your project. On the Firebase dashboard click Storage and follow the instructions to enable storage.

The storage rules are needed to enable image storage and upload for image messages and user profiles.

Update your firebase.json file as follows:

"storage": {
	"rules": "chat-sdk-storage-rules.json"
}

Copy the chat-sdk-storage-rules.json file into your project directory then run:

firebase deploy --only storage
You can’t perform that action at this time.