Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/romainvialard/firebaseapp
Google Apps Script binding for Firebase Realtime Database
https://github.com/romainvialard/firebaseapp
apps-script firebase firebase-realtime-database google-apps-script
Last synced: about 2 months ago
JSON representation
Google Apps Script binding for Firebase Realtime Database
- Host: GitHub
- URL: https://github.com/romainvialard/firebaseapp
- Owner: RomainVialard
- License: apache-2.0
- Created: 2017-04-24T08:08:33.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2021-02-01T11:26:01.000Z (almost 4 years ago)
- Last Synced: 2024-11-20T06:14:28.400Z (about 2 months ago)
- Topics: apps-script, firebase, firebase-realtime-database, google-apps-script
- Language: JavaScript
- Homepage:
- Size: 104 KB
- Stars: 117
- Watchers: 13
- Forks: 30
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# FirebaseApp
The Google Apps Script binding for the Firebase Realtime Database# Install
Best it to copy the content of this file in your Google Apps Script project:
https://github.com/RomainVialard/FirebaseApp/blob/master/src/Code.gsYou can also add it as a library, though this is not recommended.
https://developers.google.com/apps-script/guides/libraries
Library's script ID: **1VlYLzhwx0YEoxIe62eItLAZeobVt_l-GQUKt2MXXuBHFVsqBkl9C_yBB**# Documentation / Reference
## Class FirebaseApp
## `getDatabaseByUrl(url, optSecret)`
Retrieves a database by url
* **Parameters:**
* `url` — `string` — - the database url
* `[optSecret]` — `string` — - a Firebase app secret
* **Returns:** `Database` — the Database found at the given URL## `encodeAsFirebaseKey(string)`
Returns a valid Firebase key from a given string Firebase Keys can't contain any of the following characters: . $ # [ ] / https://firebase.google.com/docs/database/usage/limits#data_tree https://groups.google.com/forum/#!msg/firebase-talk/vtX8lfxxShk/skzA5vQFdosJ
* **Parameters:** `string` — `string` — - the string to encode
* **Returns:** `string` — the encoded string## `decodeFirebaseKey(string)`
Returns a decoded string from a Firebase key encoded by encodeAsFirebaseKey()
* **Parameters:** `string` — `string` — - the encoded Firebase key
* **Returns:** `string` — the decoded string## `signInWithIdp(firebaseConfig, idToken)`
Signs in or signs up a user using credentials from an Identity Provider (IdP) - eg: google.com. https://cloud.google.com/identity-platform/docs/reference/rest/v1/accounts/signInWithIdp
* **Parameters:**
* `firebaseConfig` — `object` — - see the "Get config object for your web app" section in the page linked below.https://support.google.com/firebase/answer/7015592?hl=en
* `idToken` — `string` — - an OpenID Connect identity token retrieved via ScriptApp.getIdentityToken()
* **Returns:** `object` — the auth token granting access to firebase## Class Database
## `createAuthToken(userEmail, optAuthData, serviceAccountEmail, privateKey)`Generates an authorization token to firebase
* **Parameters:**
* `userEmail` — `string` — the email account of the user you want to authenticate
* `optAuthData` — `object` — key-pairs of data to be associated to this user.
* `serviceAccountEmail` — `string` — the email of the service account used to generate this token
* `privateKey` — `string` — the private key of this service account
* **Returns:** `object` — the auth token granting access to firebase## `createAuthTokenFromServiceAccount(userEmail, optCustomClaims)`
Generates an authorization token to Firebase
* **Parameters:**
* `userEmail` — `string` — - the email account of the user you want to authenticate
* `optCustomClaims` — `object` — - key-pairs of data to be associated to this user (aka custom claims).
* **Returns:** `object` — the auth token granting access to firebase## `createLegacyAuthToken(userEmail, optCustomClaims)`
Generates an authorization token to firebase
* **Parameters:**
* `userEmail` — `string` — the email account of the user you want to authenticate
* `optCustomClaims` — `object` — - key-pairs of data to be associated to this user (aka custom claims).
* **Returns:** `object` — the auth token granting access to firebase## `getData(path, optQueryParameters)`
Returns the data at this path
* **Parameters:**
* `path` — `string` — - the path where the data is stored
* `[optQueryParameters]` — `OptQueryParameters` — - a set of query parameters
* **Returns:** `object` — the data found at the given path## `getAllData(requests)`
Returns data in all specified paths
* **Parameters:** `{Array.} requests - array of requests
* **Returns:** `object` — responses to each requests## `pushData(path, data, optQueryParameters)`
Generates a new child location using a unique key
* **Parameters:**
* `path` — `string` — - the path where to create a new child
* `data` — `object` — - the data to be written at the generated location
* `[optQueryParameters]` — `OptQueryParameters` — - a set of query parameters
* **Returns:** `string` — the child name of the new data that was added## `setData(path, data, optQueryParameters)`
Write data at the specified path
* **Parameters:**
* `path` — `string` — - the path where to write data
* `data` — `object` — - the data to be written at the specified path
* `[optQueryParameters]` — `OptQueryParameters` — - a set of query parameters
* **Returns:** `object` — the data written## `updateData(path, data, optQueryParameters)`
Update specific children at the specified path without overwriting existing data
* **Parameters:**
* `path` — `string` — - the path where to update data
* `data` — `object` — - the children to overwrite
* `[optQueryParameters]` — `OptQueryParameters` — a - set of query parameters
* **Returns:** `object` — the data written## `removeData(path, optQueryParameters)`
Delete data at the specified path
* **Parameters:**
* `path` — `string` — - the path where to delete data
* `[optQueryParameters]` — `OptQueryParameters` — - a set of query parameters
* **Returns:** `null` —## `getUrlFromPath(path)`
Gets the absolute URL from the specified path
* **Parameters:** `path` — `string` — - the path / location to convert to URL
* **Returns:** `string` — an encoded URL that is ready to be put into a browser#Tutorials
https://sites.google.com/site/scriptsexamples/new-connectors-to-google-services/firebase/tutorials