with Google Sheets and Expensify?
Emit new event each time a comment is added to a spreadsheet.
Emit new event each time a row or rows are added to the bottom of a spreadsheet.
Emit new event each time a row or rows are added to the bottom of a spreadsheet.
Emit new event each time a row or cell is updated in a spreadsheet.
Emit new event each time a new worksheet is created in a spreadsheet.
Add a single row of data to Google Sheets. See the documentation
Add multiple rows of data to a Google Sheet. See the documentation
Creates a new report with transactions in a user's account. See docs here
Get all values or values from a range of cells using A1 notation. See the documentation
The Google Sheets API allows for the creation, reading, updating, and deletion of data within Google Sheets, enabling a robust platform for spreadsheet management and data manipulation. Through Pipedream, you can craft serverless workflows that respond to various triggers, such as webhook events, emails, or scheduled times, to interact with Google Sheets. This synergy can automate reporting, synchronize data across applications, manage inventory, track leads in a CRM, or even conduct survey analysis by updating and retrieving sheet data on the fly.
import { axios } from "@pipedream/platform"
export default defineComponent({
  props: {
    google_sheets: {
      type: "app",
      app: "google_sheets",
    }
  },
  async run({steps, $}) {
    return await axios($, {
      url: `https://www.googleapis.com/oauth2/v1/userinfo`,
      headers: {
        Authorization: `Bearer ${this.google_sheets.$auth.oauth_access_token}`,
      },
    })
  },
})
The Expensify API enables the automation of expense reporting and management tasks. By harnessing this API within Pipedream, you can craft workflows that streamline the expense submission process, synchronize financial data across platforms, and trigger actions based on expense report statuses. With Pipedream’s serverless platform, these automations can run in the background, allowing for real-time data processing and interaction between Expensify and a myriad of other apps and services.
import { axios } from "@pipedream/platform"
export default defineComponent({
  props: {
    expensify: {
      type: "app",
      app: "expensify",
    }
  },
  async run({ steps, $ }) {
    // The Expensify API requires the request data to be sent as
    // a URL-encoded form with a key of "requestJobDescription".
    // The value of this key must be a JSON string.
    
    // First, define the JSON object as per the Expensify API documentation.
    const requestJobDescription = {
      type: "get",
      credentials: {
          partnerUserID: this.expensify.$auth.partnerUserId,
          partnerUserSecret: this.expensify.$auth.partnerUserSecret,
      },
      inputSettings: {
          type: "policyList",
      }
    };
    // Use URLSearchParams to create a properly formatted form body.
    const formData = new URLSearchParams();
    formData.append('requestJobDescription', JSON.stringify(requestJobDescription));
    // Make the API call with the correctly formatted data.
    return await axios($, {
      method: "post",
      url: `https://integrations.expensify.com/Integration-Server/ExpensifyIntegrations`,
      data: formData,
      // It's good practice to explicitly set the Content-Type header
      // to match the data format.
      headers: {
        'Content-Type': 'application/x-www-form-urlencoded',
      },
    });
  },
})





