zoom-automation
Zoom Automation via Rube MCP
Automate Zoom operations including meeting scheduling, webinar management, cloud recording retrieval, participant tracking, and usage reporting through Composio's Zoom toolkit.
Toolkit docs: composio.dev/toolkits/zoom
Prerequisites
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active Zoom connection via
RUBE_MANAGE_CONNECTIONSwith toolkitzoom - Always call
RUBE_SEARCH_TOOLSfirst to get current tool schemas - Most features require a paid Zoom account (Pro plan or higher)
Setup
Get Rube MCP: Add https://rube.app/mcp as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.
- Verify Rube MCP is available by confirming
RUBE_SEARCH_TOOLSresponds - Call
RUBE_MANAGE_CONNECTIONSwith toolkitzoom - If connection is not ACTIVE, follow the returned auth link to complete Zoom OAuth
- Confirm connection status shows ACTIVE before running any workflows
Core Workflows
1. Create and Schedule Meetings
When to use: User wants to create a new Zoom meeting with specific time, duration, and settings
Tool sequence:
ZOOM_GET_USER- Verify authenticated user and check license type [Prerequisite]ZOOM_CREATE_A_MEETING- Create the meeting with topic, time, duration, and settings [Required]ZOOM_GET_A_MEETING- Retrieve full meeting details including join_url [Optional]ZOOM_UPDATE_A_MEETING- Modify meeting settings or reschedule [Optional]ZOOM_ADD_A_MEETING_REGISTRANT- Register participants for registration-enabled meetings [Optional]
Key parameters:
userId: Always use"me"for user-level appstopic: Meeting subject linetype:1(instant),2(scheduled),3(recurring no fixed time),8(recurring fixed time)start_time: ISO 8601 format (yyyy-MM-ddTHH:mm:ssZfor UTC oryyyy-MM-ddTHH:mm:sswith timezone field)timezone: Timezone ID (e.g.,"America/New_York")duration: Duration in minutessettings__auto_recording:"none","local", or"cloud"settings__waiting_room: Boolean to enable waiting roomsettings__join_before_host: Boolean (disabled when waiting room is enabled)settings__meeting_invitees: Array of invitee objects with email addresses
Pitfalls:
start_timemust be in the future; Zoom stores and returns times in UTC regardless of input timezone- If no
start_timeis set for type2, it becomes an instant meeting that expires after 30 days - The
join_urlfor participants andstart_urlfor host come from the create response - persist these start_urlexpires in 2 hours (or 90 days forcustCreateusers)- Meeting creation is rate-limited to 100 requests/day
- Setting names use double underscores for nesting (e.g.,
settings__host_video)
2. List and Manage Meetings
When to use: User wants to view upcoming, live, or past meetings
Tool sequence:
ZOOM_LIST_MEETINGS- List meetings by type (scheduled, live, upcoming, previous) [Required]ZOOM_GET_A_MEETING- Get detailed info for a specific meeting [Optional]ZOOM_UPDATE_A_MEETING- Modify meeting details [Optional]
Key parameters:
userId: Use"me"for authenticated usertype:"scheduled"(default),"live","upcoming","upcoming_meetings","previous_meetings"page_size: Records per page (default 30)next_page_token: Pagination token from previous responsefrom/to: Date range filters
Pitfalls:
ZOOM_LIST_MEETINGSexcludes instant meetings and only shows unexpired scheduled meetings- For past meetings, use
type: "previous_meetings" - Pagination: always follow
next_page_tokenuntil empty to get complete results - Token expiration:
next_page_tokenexpires after 15 minutes - Meeting IDs can exceed 10 digits; store as long integers, not standard integers
3. Manage Recordings
When to use: User wants to list, retrieve, or delete cloud recordings
Tool sequence:
ZOOM_LIST_ALL_RECORDINGS- List all cloud recordings for a user within a date range [Required]ZOOM_GET_MEETING_RECORDINGS- Get recordings for a specific meeting [Optional]ZOOM_DELETE_MEETING_RECORDINGS- Move recordings to trash or permanently delete [Optional]ZOOM_LIST_ARCHIVED_FILES- List archived meeting/webinar files [Optional]
Key parameters:
userId: Use"me"for authenticated userfrom/to: Date range inyyyy-mm-ddformat (max 1 month range)meetingId: Meeting ID or UUID for specific recording retrievalaction:"trash"(recoverable) or"delete"(permanent) for deletioninclude_fields: Set to"download_access_token"to get JWT for downloading recordingstrash: Settrueto list recordings from trash
Pitfalls:
- Date range maximum is 1 month; API auto-adjusts
fromif range exceeds this - Cloud Recording must be enabled on the account
- UUIDs starting with
/or containing//must be double URL-encoded ZOOM_DELETE_MEETING_RECORDINGSdefaults to"trash"action (recoverable);"delete"is permanent- Download URLs require the OAuth token in the Authorization header for passcode-protected recordings
- Requires Pro plan or higher
4. Get Meeting Participants and Reports
When to use: User wants to see who attended a past meeting or get usage statistics
Tool sequence:
ZOOM_GET_PAST_MEETING_PARTICIPANTS- List attendees of a completed meeting [Required]ZOOM_GET_A_MEETING- Get meeting details and registration info for upcoming meetings [Optional]ZOOM_GET_DAILY_USAGE_REPORT- Get daily usage statistics (meetings, participants, minutes) [Optional]ZOOM_GET_A_MEETING_SUMMARY- Get AI-generated meeting summary [Optional]
Key parameters:
meetingId: Meeting ID (latest instance) or UUID (specific occurrence)page_size: Records per page (default 30)next_page_token: Pagination token for large participant lists
Pitfalls:
ZOOM_GET_PAST_MEETING_PARTICIPANTSonly works for completed meetings on paid plans- Solo meetings (no other participants) return empty results
- UUID encoding: UUIDs starting with
/or containing//must be double-encoded - Always paginate with
next_page_tokenuntil empty to avoid dropping attendees ZOOM_GET_A_MEETING_SUMMARYrequires a paid plan with AI Companion enabled; free accounts get 400 errorsZOOM_GET_DAILY_USAGE_REPORThas a Heavy rate limit; avoid frequent calls
5. Manage Webinars
When to use: User wants to list webinars or register participants for webinars
Tool sequence:
ZOOM_LIST_WEBINARS- List scheduled or upcoming webinars [Required]ZOOM_GET_A_WEBINAR- Get detailed webinar information [Optional]ZOOM_ADD_A_WEBINAR_REGISTRANT- Register a participant for a webinar [Optional]
Key parameters:
userId: Use"me"for authenticated usertype:"scheduled"(default) or"upcoming"page_size: Records per page (default 30)next_page_token: Pagination token
Pitfalls:
- Webinar features require Pro plan or higher with Webinar add-on
- Free/basic accounts cannot use webinar tools
- Only shows unexpired webinars
- Registration must be enabled on the webinar for
ZOOM_ADD_A_WEBINAR_REGISTRANTto work
Common Patterns
ID Resolution
- User ID: Always use
"me"for user-level apps to refer to the authenticated user - Meeting ID: Numeric ID (store as long integer); use for latest instance
- Meeting UUID: Use for specific occurrence of recurring meetings; double-encode if starts with
/or contains// - Occurrence ID: Use with recurring meetings to target a specific occurrence
Pagination
Most Zoom list endpoints use token-based pagination:
- Follow
next_page_tokenuntil it is empty or missing - Token expires after 15 minutes
- Set explicit
page_size(default 30, varies by endpoint) - Do not use
page_number(deprecated on many endpoints)
Time Handling
- Zoom stores all times in UTC internally
- Provide
timezonefield alongsidestart_timefor local time input - Use ISO 8601 format:
yyyy-MM-ddTHH:mm:ssZ(UTC) oryyyy-MM-ddTHH:mm:ss(with timezone field) - Date-only fields use
yyyy-mm-ddformat
Known Pitfalls
Plan Requirements
- Most recording and participant features require Pro plan or higher
- Webinar features require Webinar add-on
- AI meeting summaries require AI Companion feature enabled
- Archived files require "Meeting and Webinar Archiving" enabled by Zoom Support
Rate Limits
- Meeting creation: 100 requests/day, 100 updates per meeting in 24 hours
ZOOM_GET_PAST_MEETING_PARTICIPANTS: Moderate throttle; add delays for batch processingZOOM_GET_DAILY_USAGE_REPORT: Heavy rate limitZOOM_GET_A_MEETING,ZOOM_GET_MEETING_RECORDINGS: Light rate limitZOOM_LIST_MEETINGS,ZOOM_LIST_ALL_RECORDINGS: Medium rate limit
Parameter Quirks
- Nested settings use double underscore notation (e.g.,
settings__waiting_room) start_urlexpires in 2 hours; renew via API if neededjoin_before_hostis automatically disabled whenwaiting_roomistrue- Recurring meeting fields (
recurrence__*) only apply to type3and8 passwordfield has max 10 characters with alphanumeric and@,-,_,*only
Quick Reference
| Task | Tool Slug | Key Params |
|---|---|---|
| Create meeting | ZOOM_CREATE_A_MEETING |
userId, topic, start_time, type |
| Get meeting details | ZOOM_GET_A_MEETING |
meetingId |
| Update meeting | ZOOM_UPDATE_A_MEETING |
meetingId, fields to update |
| List meetings | ZOOM_LIST_MEETINGS |
userId, type, page_size |
| Get user info | ZOOM_GET_USER |
userId |
| List recordings | ZOOM_LIST_ALL_RECORDINGS |
userId, from, to |
| Get recording | ZOOM_GET_MEETING_RECORDINGS |
meetingId |
| Delete recording | ZOOM_DELETE_MEETING_RECORDINGS |
meetingId, action |
| Past participants | ZOOM_GET_PAST_MEETING_PARTICIPANTS |
meetingId, page_size |
| Daily usage report | ZOOM_GET_DAILY_USAGE_REPORT |
date params |
| Meeting summary | ZOOM_GET_A_MEETING_SUMMARY |
meetingId |
| List webinars | ZOOM_LIST_WEBINARS |
userId, type |
| Get webinar | ZOOM_GET_A_WEBINAR |
webinar ID |
| Register for meeting | ZOOM_ADD_A_MEETING_REGISTRANT |
meetingId, participant details |
| Register for webinar | ZOOM_ADD_A_WEBINAR_REGISTRANT |
webinar ID, participant details |
| List archived files | ZOOM_LIST_ARCHIVED_FILES |
from, to |
Powered by Composio