← Google Calendar

New Calendar from Google Calendar API

Pipedream makes it easy to connect APIs for Google Calendar and 900+ other apps remarkably fast.

Trigger workflow on
New Calendar from the Google Calendar API
Next, do this
Connect to 900+ APIs using code and no-code building blocks
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

Trigger a workflow on New Calendar with Google Calendar API. When you configure and deploy the workflow, it will run on Pipedream's servers 24x7 for free.

  1. Configure the New Calendar trigger
    1. Connect your Google Calendar account
    2. Configure timer
  2. Add steps to connect to 900+ APIs using code and no-code building blocks
  3. Deploy the workflow
  4. Send a test event to validate your setup
  5. Turn on the trigger

Integrations

Send Message with Discord Webhook API on New Calendar from Google Calendar API
Google Calendar + Discord Webhook
 
Try it
Add Multiple Rows with Google Sheets API on New Calendar from Google Calendar API
Google Calendar + Google Sheets
 
Try it
Get Film with SWAPI API on New Calendar from Google Calendar API
Google Calendar + SWAPI - Star Wars
 
Try it
Create Multiple Records with Airtable API on New Calendar from Google Calendar API
Google Calendar + Airtable
 
Try it
Custom Request with HTTP / Webhook API on New Calendar from Google Calendar API
Google Calendar + HTTP / Webhook
 
Try it

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.

New Calendar on Google Calendar
Description:Emit an event when a calendar is created.
Version:0.1.1
Key:google_calendar-new-calendar

Code

import googleCalendar from "../../google_calendar.app.mjs";

export default {
  key: "google_calendar-new-calendar",
  name: "New Calendar",
  description: "Emit an event when a calendar is created.",
  version: "0.1.1",
  type: "source",
  props: {
    db: "$.service.db",
    googleCalendar,
    timer: {
      type: "$.interface.timer",
      default: {
        intervalSeconds: 15 * 60,
      },
    },
  },
  hooks: {
    async activate() {
      // get list of calendars
      const { items: calendars = [] } = await this.googleCalendar.listCalendars();
      this.emitNewCalendars(calendars);
      const calendarIds = calendars.map((item) => item.id);
      this.setCalendarIds(calendarIds);
    },
    deactivate() {
      this.setCalendarIds([]);
    },
  },
  methods: {
    setCalendarIds(calendarIds) {
      this.db.set("calendarIds", calendarIds);
    },
    getCalendarIds() {
      return this.db.get("calendarIds") || [];
    },
    generateMeta(calendar) {
      const {
        summary,
        id,
      } = calendar;
      return {
        summary,
        id,
        ts: Date.now(),
      };
    },
    emitNewCalendars(calendars) {
      const previousCalendarIds = this.getCalendarIds();

      for (const calendar of calendars) {
        if (!previousCalendarIds.includes(calendar.id)) {
          const meta = this.generateMeta(calendar);
          this.$emit(calendar, meta);
        }
      }
    },
  },
  async run() {
    const { items: calendars = [] } = await this.googleCalendar.listCalendars();

    this.emitNewCalendars(calendars);

    const calendarIds = calendars.map((item) => item.id);
    this.setCalendarIds(calendarIds);
  },
};

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
N/Adb$.service.dbThis component uses $.service.db to maintain state between component invocations.
Google CalendargoogleCalendarappThis component uses the Google Calendar app.
timer$.interface.timer

Authentication

Google Calendar uses OAuth authentication. When you connect your Google Calendar account, Pipedream will open a popup window where you can sign into Google Calendar and grant Pipedream permission to connect to your account. Pipedream securely stores and automatically refreshes the OAuth tokens so you can easily authenticate any Google Calendar API.

Pipedream requests the following authorization scopes when you connect your account:

emailprofilehttps://www.googleapis.com/auth/calendar.eventshttps://www.googleapis.com/auth/calendar.readonlyhttps://www.googleapis.com/auth/calendar.settings.readonly

About Google Calendar

Scheduling calendar service developed by Google

More Ways to Use Google Calendar

Triggers

Event Start from the Google Calendar API

Emits a specified time before an event starts

 
Try it
New or Updated Event (Instant) from the Google Calendar API

Emit new calendar events when an event is created or updated (does not emit cancelled events)

 
Try it
New Event from the Google Calendar API

Emits when an event is created

 
Try it
Event Search from the Google Calendar API

Emit when an event is created that matches a search

 
Try it
Event Cancelled from the Google Calendar API

Emits when an event is cancelled or deleted

 
Try it

Actions

Add Quick Event with the Google Calendar API

Create an event to the Google Calendar. See the docs here

 
Try it
Create Event with the Google Calendar API

Create an event to the Google Calendar. See the docs here

 
Try it
Delete an Event with the Google Calendar API

Delete an event to the Google Calendar. See the docs here

 
Try it
List calendars from user account with the Google Calendar API

Retrieve calendars from the user account. See the docs here

 
Try it
Retrieve Calendar Details with the Google Calendar API

Retrieve Calendar details of a Google Calendar. See the docs here

 
Try it