Socket
Book a DemoInstallSign in
Socket

@firebase-me/tracker

Package Overview
Dependencies
Maintainers
2
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@firebase-me/tracker

A firebase database tracker

1.0.1
latest
Source
npmnpm
Version published
Weekly downloads
0
Maintainers
2
Weekly downloads
 
Created
Source

*Alpha v0.1 This is a Firebase Usage Tracker, it is designed to to capture snapshots from firebase calls to Firestore and Realtime, Storage is not functional at this current time.

The package uses the REST API to reduce any potential overhead

to Use:

import tracker from '@firebase-me/tracker';

tracker.init(databaseUrl, auth?(optional), ping?(optional))
  • databaseURL is the realtime database url from your web credentials
  • auth - optional - only needed when initiating after the user is declared
  • ping - optional - only valid if a current auth object is processed

when the user state changes, the user auth object needs to be updated:

onAuthStateChanged(user){
    tracker.updateAuth(user)
}

If you are not using the web modules; the only required fields are the user UID and the ID token for authenticating the request. you can pass it as the user object as such {uid:"userUID", idToken:"ID token Credential"}

There are 3 ways we intend to allow users to utilize this suite: 1: Pass the snapshot from the request into the appropriate tracker method and it will update to the appropriate realtime DB. 2: Assign a custom callback function via: tracker.<service>.setCallback(myFuntion) which expects a single parameter payload(3) 3: If no callback(2) is assigned and the tracker has not been initialized: it will simply return the payload as a JSON object so you can handle it through a console log, custom integration, etc.

To use the trigger to log each respective database type:

// Firestore
tracker.firestore.trigger(snapshot|data, meta?, customPath?)
// Realtime DB
tracker.realtime.trigger(snapshot|data, meta?, customPath?)
// Storage (not implimented)
// tracker.storage.trigger(snapshot|data, meta?, customPath?)
// Custom Meta
tracker.meta.trigger(payloadObject|data, meta?, customPath?)

Each snapshot is evaluated, Firestore as Documents (supports cached tracking) Realtime DB is evaluated as Bytes and rounded to the nearest KB Meta uses the same as Realtime. Each trigger also supports custom path overrides, allowing you to define assign the snapshot path as a unique path independant of their original reference path. This can be used for custom filtering and targeting.

Standard payload:

{
    time: timestamp,
    auth: string | null,
    path: string | null,
    size: number | null,
    cache: number | null, // firestore only
    meta: string | null,
}

Storage is not functional at this time, please do not use it as it will most likely throw errors.

Keywords

firebase

FAQs

Package last updated on 20 Jul 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

About

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.

  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc

U.S. Patent No. 12,346,443 & 12,314,394. Other pending.