with DealMachine and Firebase Admin?
The DealMachine API allows for automation of real estate investment tasks such as property research, direct mail marketing, and lead management. By connecting the DealMachine API to Pipedream, users can automate workflows, combine real estate data with other apps, and trigger custom actions based on specific criteria. Pipedream's serverless platform provides a powerful way to interact with the DealMachine API, process data, and integrate with countless other services to optimize real estate investment strategies.
import { axios } from "@pipedream/platform"
export default defineComponent({
props: {
dealmachine: {
type: "app",
app: "dealmachine",
}
},
async run({steps, $}) {
return await axios($, {
url: `https://api.dealmachine.com/public/v1/team-members/`,
headers: {
Authorization: `Bearer ${this.dealmachine.$auth.api_key}`,
},
})
},
})
The Firebase Admin SDK API provides powerful backend functionality for Firebase apps. It allows you to interact with Firebase services like Firestore, Firebase Realtime Database, Firebase Storage, and Firebase Authentication directly from a server. With Pipedream, you can harness this API to automate complex workflows, respond to Firebase events in real-time, and integrate with countless other services.
import admin from "firebase-admin"
export default defineComponent({
props: {
firebase_admin_sdk: {
type: "app",
app: "firebase_admin_sdk",
},
},
async run({ steps, $ }) {
// Enter values for the following parameters below this code step,
// These get passed to the initializeApp method below.
const {
projectId,
clientEmail,
privateKey,
region = "firebaseio.com",
} = 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")
// See https://firebase.google.com/docs/reference/admin/node/admin.credential.html#cert
if (!admin.apps.length) {
admin.initializeApp({
credential: admin.credential.cert({
projectId,
clientEmail,
privateKey: formattedPrivateKey,
}),
databaseURL: `https://${projectId}-default-rtdb.${region}/`,
})
}
},
})