← Firebase Admin SDK

Save Event to Firestore with Firebase Admin SDK API

Pipedream makes it easy to connect APIs for Firebase Admin SDK and 800+ other apps remarkably fast.

Trigger workflow on
HTTP requests, schedules and app events
Next, do this
Save Event to Firestore with the Firebase Admin SDK API
No credit card required
Into to Pipedream
Watch us build a workflow
Watch us build a workflow
7 min
Watch now ➜
Trusted by 250,000+ developers from startups to Fortune 500 companies:
Trusted by 250,000+ developers from startups to Fortune 500 companies

Developers Pipedream

Getting Started

Create a workflow to Save Event to Firestore with the Firebase Admin SDK API. When you configure and deploy the workflow, it will run on Pipedream's servers 24x7 for free.

  1. Configure the Save Event to Firestore action
    1. Connect your Firebase Admin SDK account
    2. Configure deliveryId
    3. Configure firestoreCollection
    4. Configure data
  2. Select a trigger to run your workflow on HTTP requests, schedules or app events
  3. Deploy the workflow
  4. Send a test event to validate your setup
  5. Turn on the trigger

Details

This is a pre-built, open source component from Pipedream's GitHub repo. The component is developed by Pipedream and the community, and verified and maintained by Pipedream.

To contribute an update to an existing component or create a new component, create a PR on GitHub. If you're new to Pipedream component development, you can start with quickstarts for trigger span and action development, and then review the component API reference.

Save Event to Firestore on Firebase Admin SDK
Description:
Version:0.4.2
Key:firebase_admin_sdk-replicate-event-firestore

Code

// legacy_hash_id: a_rJipb5
import admin from "firebase-admin";
import lodash from "lodash";

export default {
  key: "firebase_admin_sdk-replicate-event-firestore",
  name: "Save Event to Firestore",
  version: "0.4.2",
  type: "action",
  props: {
    firebase_admin_sdk: {
      type: "app",
      app: "firebase_admin_sdk",
    },
    deliveryId: {
      type: "string",
    },
    firestoreCollection: {
      type: "string",
    },
    data: {
      type: "string",
    },
  },
  async run({ $ }) {
    // Enter values for the following parameters below this code step,
    // These get passed to the initializeApp method below.
    const {
      projectId,
      clientEmail,
      privateKey,
    } = this.firebase_admin_sdk.$auth;

    // Before passing the privateKey to the initializeApp constructor,
    // we have to replace newline characters with literal newlines
    const formattedPrivateKey = privateKey.replace(/\\n/g, "\n");

    const app = admin.initializeApp({
      credential: admin.credential.cert({
        projectId,
        clientEmail,
        privateKey: formattedPrivateKey,
      }),
    });

    const db = admin.firestore();
    const deliveryId = this.deliveryId;

    let updates = [];
    updates.push(`updating ${deliveryId}`);

    const p1 = db.collection(this.firestoreCollection).doc(deliveryId)
      .set(lodash.assign({}, this.data, {
        pipedream: {
          updatedAt: (new Date().toISOString()),
        },
      }))
      .then(function() {
        updates.push("Updated successfully");
        app.delete().then(function() {
          updates.push("App deleted successfully");
        })
          .catch(function(error) {
            updates.push("Error deleting app:", error);
          });
      })
      .catch(function(error) {
        updates.push("Error writing:", error);
      });

    const result = await Promise.all([
      p1,
    ]);

    $.export("updates", updates);

    return result;
  },
};

Configuration

This component may be configured based on the props defined in the component code. Pipedream automatically prompts for input values in the UI and CLI.
LabelPropTypeDescription
Firebase Admin SDKfirebase_admin_sdkappThis component uses the Firebase Admin SDK app.
deliveryIdstring
firestoreCollectionstring
datastring

Authentication

Firebase Admin SDK uses API keys for authentication. When you connect your Firebase Admin SDK account, Pipedream securely stores the keys so you can easily authenticate to Firebase Admin SDK APIs in both code and no-code steps.

Follow these instructions to generate a private key tied to your Firebase service account. This will generate a JSON file that contains the project ID, private key, and client email that you should paste below.

When entering the private key, please add the full string included in the JSON file, from -----BEGIN PRIVATE KEY----- to -----END PRIVATE KEY-----, with all newline characters included.

About Firebase Admin SDK

Firebase is Google's mobile platform that helps you quickly develop high-quality apps and grow your business.