JSPM

  • Created
  • Published
  • Downloads 3529
  • Score
    100M100P100Q89475F
  • License MIT

Helpful abstraction on the Firebase admin API

Package Exports

  • @forest-fire/real-time-admin

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@forest-fire/real-time-admin) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Build Status Coverage Status MIT license

A minimal abstraction over the Firebase ADMIN API

Basic Usage

Meant for backend nodejs micro-services which interact with Firebase's Admin API using a "service policy" to authenticate.

import DB from 'abstracted-admin';
const db = new DB();
// Get a list of records
const users = await db.getValue<IUser[]>('users');
// Push a new value onto a list
const company: ICompany = {
  name: "Acme",
  employees: 500
}
db.push<ICompany>('/companies', company);

Authentication

All of the Authentication is done transparently as soon as requests are made to the database. In order for this library to achieve this it will need the following environment variables set:

  • FIREBASE_SERVICE_ACCOUNT - this should be a URI-Encoded string of the JSON data which you exported at the time you created a Service Account on Google.
  • FIREBASE_DATA_ROOT_URL - comes from the Firebase console and dictates which DB to connect to

Mocking

This library supports simple redirecting of all operations to the firemock mocking library; see related projects) and the "Mocking" section of the docs here for more details. In cases where mocking is being used, authentication (and security rights for paths) are not supported and therefore the above ENV variables are not required.

Documentation

Gitbook