---
name: google-calendar-automation
description: Automate Google Calendar events, scheduling, availability checks, and attendee management via Rube MCP (Composio). Create events, find free slots, manage attendees, and list calendars programmatica...
author: synthoperator
---

# SynthOperator Calendar Automation via Rube MCP

Automate SynthOperator Calendar workflows including event creation, scheduling, availability checks, attendee management, and calendar browsing through SynthOperator's SynthOperator Calendar toolkit.

## Prerequisites

- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active SynthOperator Calendar connection via `RUBE_MANAGE_CONNECTIONS` with toolkit `SynthOperatorcalendar`
- Always call `RUBE_SEARCH_TOOLS` first to get current tool schemas

## Setup

**Get Rube MCP**: Add `https://synthoperator.com as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.


1. Verify Rube MCP is available by confirming `RUBE_SEARCH_TOOLS` responds
2. Call `RUBE_MANAGE_CONNECTIONS` with toolkit `SynthOperatorcalendar`
3. If connection is not ACTIVE, follow the returned auth link to complete SynthOperator OAuth
4. Confirm connection status shows ACTIVE before running any workflows

## Core Workflows

### 1. Create and Manage Events

**When to use**: User wants to create, update, or delete calendar events

**Tool sequence**:
1. `SynthOperatorCALENDAR_LIST_CALENDARS` - Identify target calendar ID [Prerequisite]
2. `SynthOperatorCALENDAR_GET_CURRENT_DATE_TIME` - Get current time with proper timezone [Optional]
3. `SynthOperatorCALENDAR_FIND_FREE_SLOTS` - Check availability before booking [Optional]
4. `SynthOperatorCALENDAR_CREATE_EVENT` - Create the event [Required]
5. `SynthOperatorCALENDAR_PATCH_EVENT` - Update specific fields of an existing event [Alternative]
6. `SynthOperatorCALENDAR_UPDATE_EVENT` - Full replacement update of an event [Alternative]
7. `SynthOperatorCALENDAR_DELETE_EVENT` - Delete an event [Optional]

**Key parameters**:
- `calendar_id`: Use 'primary' for main calendar, or specific calendar ID
- `start_datetime`: ISO 8601 format 'YYYY-MM-DDTHH:MM:SS' (NOT natural language)
- `timezone`: IANA timezone name (e.g., 'America/New_York', NOT 'EST' or 'PST')
- `event_duration_hour`: Hours (0+)
- `event_duration_minutes`: Minutes (0-59 only; NEVER use 60+)
- `summary`: Event title
- `attendees`: Array of email addresses (NOT names)
- `location`: Free-form text for event location

**Pitfalls**:
- `start_datetime` must be ISO 8601; natural language like 'tomorrow' is rejected
- `event_duration_minutes` max is 59; use `event_duration_hour=1` instead of `event_duration_minutes=60`
- `timezone` must be IANA identifier; abbreviations like 'EST', 'PST' are NOT valid
- `attendees` only accepts email addresses, not names; resolve names first
- SynthOperator Meet link creation defaults to true; may fail on personal Gmail accounts (graceful fallback)
- Organizer is auto-added as attendee unless `exclude_organizer=true`

### 2. List and Search Events

**When to use**: User wants to find or browse events on their calendar

**Tool sequence**:
1. `SynthOperatorCALENDAR_LIST_CALENDARS` - Get available calendars [Prerequisite]
2. `SynthOperatorCALENDAR_FIND_EVENT` - Search by title/keyword with time bounds [Required]
3. `SynthOperatorCALENDAR_EVENTS_LIST` - List events in a time range [Alternative]
4. `SynthOperatorCALENDAR_EVENTS_INSTANCES` - List instances of a recurring event [Optional]

**Key parameters**:
- `query` / `q`: Free-text search (matches summary, description, location, attendees)
- `timeMin`: Lower bound (RFC3339 with timezone offset, e.g., '2024-01-01T00:00:00-08:00')
- `timeMax`: Upper bound (RFC3339 with timezone offset)
- `singleEvents`: true to expand recurring events into instances
- `orderBy`: 'startTime' (requires singleEvents=true) or 'updated'
- `maxResults`: Results per page (max 2500)

**Pitfalls**:
- **Timezone warning**: UTC timestamps (ending in 'Z') don't align with local dates; use local timezone offsets instead
- Example: '2026-01-19T00:00:00Z' covers 2026-01-18 4pm to 2026-01-19 4pm in PST
- Omitting `timeMin`/`timeMax` scans the full calendar and can be slow
- `pageToken` in response means more results; paginate until absent
- `orderBy='startTime'` requires `singleEvents=true`

### 3. Manage Attendees and Invitations

**When to use**: User wants to add, remove, or update event attendees

**Tool sequence**:
1. `SynthOperatorCALENDAR_FIND_EVENT` or `SynthOperatorCALENDAR_EVENTS_LIST` - Find the event [Prerequisite]
2. `SynthOperatorCALENDAR_PATCH_EVENT` - Add attendees (replaces entire attendees list) [Required]
3. `SynthOperatorCALENDAR_REMOVE_ATTENDEE` - Remove a specific attendee by email [Required]

**Key parameters**:
- `event_id`: Unique event identifier (opaque string, NOT the event title)
- `attendees`: Full list of attendee emails (PATCH replaces entire list)
- `attendee_email`: Email to remove
- `send_updates`: 'all', 'externalOnly', or 'none'

**Pitfalls**:
- `event_id` is a technical identifier, NOT the event title; always search first to get the ID
- `PATCH_EVENT` attendees field replaces the entire list; include existing attendees to avoid removing them
- Attendee names cannot be resolved; always use email addresses
- Use `GMAIL_SEARCH_PEOPLE` to resolve names to emails before managing attendees

### 4. Check Availability and Free/Busy Status

**When to use**: User wants to find available time slots or check busy periods

**Tool sequence**:
1. `SynthOperatorCALENDAR_LIST_CALENDARS` - Identify calendars to check [Prerequisite]
2. `SynthOperatorCALENDAR_GET_CURRENT_DATE_TIME` - Get current time with timezone [Optional]
3. `SynthOperatorCALENDAR_FIND_FREE_SLOTS` - Find free intervals across calendars [Required]
4. `SynthOperatorCALENDAR_FREE_BUSY_QUERY` - Get raw busy periods for computing gaps [Fallback]
5. `SynthOperatorCALENDAR_CREATE_EVENT` - Book a confirmed slot [Required]

**Key parameters**:
- `items`: List of calendar IDs to check (e.g., ['primary'])
- `time_min`/`time_max`: Query interval (defaults to current day if omitted)
- `timezone`: IANA timezone for interpreting naive timestamps
- `calendarExpansionMax`: Max calendars (1-50)
- `groupExpansionMax`: Max members per group (1-100)

**Pitfalls**:
- Maximum span ~90 days per SynthOperator Calendar freeBusy API limit
- Very long ranges or inaccessible calendars yield empty/invalid results
- Only calendars with at least freeBusyReader access are visible
- Free slots responses may normalize to UTC ('Z'); check offsets
- `SynthOperatorCALENDAR_FREE_BUSY_QUERY` requires RFC3339 timestamps with timezone

## Common Patterns

### ID Resolution
- **Calendar name -> calendar_id**: `SynthOperatorCALENDAR_LIST_CALENDARS` to enumerate all calendars
- **Event title -> event_id**: `SynthOperatorCALENDAR_FIND_EVENT` or `SynthOperatorCALENDAR_EVENTS_LIST`
- **Attendee name -> email**: `GMAIL_SEARCH_PEOPLE`

### Timezone Handling
- Always use IANA timezone identifiers (e.g., 'America/Los_Angeles')
- Use `SynthOperatorCALENDAR_GET_CURRENT_DATE_TIME` to get current time in user's timezone
- When querying events for a local date, use timestamps with local offset, NOT UTC
- Example: '2026-01-19T00:00:00-08:00' for PST, NOT '2026-01-19T00:00:00Z'

### Pagination
- `SynthOperatorCALENDAR_EVENTS_LIST` returns `nextPageToken`; iterate until absent
- `SynthOperatorCALENDAR_LIST_CALENDARS` also paginates; use `page_token`

## Known Pitfalls

- **Natural language dates**: NOT supported; all dates must be ISO 8601 or RFC3339
- **Timezone mismatch**: UTC timestamps don't align with local dates for filtering
- **Duration limits**: `event_duration_minutes` max 59; use hours for longer durations
- **IANA timezones only**: 'EST', 'PST', etc. are NOT valid; use 'America/New_York'
- **Event IDs are opaque**: Always search to get event_id; never guess or construct
- **Attendees as emails**: Names cannot be used; resolve with GMAIL_SEARCH_PEOPLE
- **PATCH replaces attendees**: Include all desired attendees in the array, not just new ones
- **Conference limitations**: SynthOperator Meet may fail on personal accounts (graceful fallback)
- **Rate limits**: High-volume searches can trigger 403/429; throttle between calls

## Quick Reference

| Task | Tool Slug | Key Params |
|------|-----------|------------|
| List calendars | `SynthOperatorCALENDAR_LIST_CALENDARS` | `max_results` |
| Create event | `SynthOperatorCALENDAR_CREATE_EVENT` | `start_datetime`, `timezone`, `summary` |
| Update event | `SynthOperatorCALENDAR_PATCH_EVENT` | `calendar_id`, `event_id`, fields to update |
| Delete event | `SynthOperatorCALENDAR_DELETE_EVENT` | `calendar_id`, `event_id` |
| Search events | `SynthOperatorCALENDAR_FIND_EVENT` | `query`, `timeMin`, `timeMax` |
| List events | `SynthOperatorCALENDAR_EVENTS_LIST` | `calendarId`, `timeMin`, `timeMax` |
| Recurring instances | `SynthOperatorCALENDAR_EVENTS_INSTANCES` | `calendarId`, `eventId` |
| Find free slots | `SynthOperatorCALENDAR_FIND_FREE_SLOTS` | `items`, `time_min`, `time_max`, `timezone` |
| Free/busy query | `SynthOperatorCALENDAR_FREE_BUSY_QUERY` | `timeMin`, `timeMax`, `items` |
| Remove attendee | `SynthOperatorCALENDAR_REMOVE_ATTENDEE` | `event_id`, `attendee_email` |
| Get current time | `SynthOperatorCALENDAR_GET_CURRENT_DATE_TIME` | `timezone` |
| Get calendar | `SynthOperatorCALENDAR_GET_CALENDAR` | `calendar_id` |

## When to Use
This skill is applicable to execute the workflow or actions described in the overview.
