Google MCP
A all-in-one Google Workspace MCP server
Google MCP Server
A comprehensive Model Context Protocol (MCP) server for Google integration, providing access to Google Calendar, Docs, Sheets, Slides, Drive, Gmail, Contacts, YouTube, Tasks, Forms, Chat, and Meet.
Features
Google Forms
- Create and manage Google Forms
- Add questions (multiple choice, short answer, checkboxes, etc.)
- Add page breaks, text items, images, and videos
- List and retrieve form responses
- Update form settings (quiz mode, etc.)
Google Chat
- List, create, and manage Chat spaces
- Send, update, and delete messages
- Add and remove reactions
- Manage space members
- Thread support for conversations
Google Meet
- Create meeting spaces with access controls
- Schedule meetings via Calendar integration
- Create instant meetings
- List and access conference records
- View participant information
- Access meeting recordings and transcripts
Google Calendar
- List calendars and events
- Create, update, and delete events
- Quick add events using natural language
- Get today's events and upcoming events
- Check free/busy availability
Google Gmail
- Read, search, and list emails
- Send emails and reply to threads
- Mark as read/unread, trash messages
- List labels and organize emails
Google Contacts (People API)
- List, search, and manage contacts
- Create, update, and delete contacts
- List contact groups
Google Drive
- List, search, and browse files and folders
- Upload, download, copy, move, and delete files
- Create folders
- Rename files
Google Docs
- Create new documents with optional initial content
- Read document content
- Insert and append text
- Find and replace text
- List all documents
Google Sheets
- Create spreadsheets with multiple sheets
- Read values from ranges
- Update and append values
- Clear ranges
- Add and delete sheets
- List all spreadsheets
Google Slides
- Create and manage presentations
- Add, delete, and duplicate slides
- Add text boxes and images
- Find and replace text
- List all presentations
Google YouTube
- Search videos, channels, and playlists
- Get video and channel details
- View and manage playlists
- Get video comments
- View subscriptions and liked videos
- Rate videos
Google Tasks (Keep Alternative)
- Manage task lists (similar to Keep categories)
- Create, update, complete, and delete tasks
- Tasks support notes/descriptions (similar to Keep notes)
- Convenience "notes" tools that provide Keep-like functionality
Note: Google Keep does not have an official public API. This server uses Google Tasks API as an alternative, which provides similar note-taking capabilities through tasks with descriptions.
Installation
# Clone the repository
cd google-mcp
# Install dependencies
pnpm install
# Build the project
pnpm build
Google Cloud Setup
Before using this server, you need to set up Google Cloud credentials:
1. Create a Google Cloud Project
- Go to Google Cloud Console
- Create a new project or select an existing one
- Enable the following APIs:
- Google Calendar API
- Google Docs API
- Google Sheets API
- Google Slides API
- Google Drive API
- Gmail API
- People API (Contacts)
- YouTube Data API v3
- Google Tasks API
- Google Forms API
- Google Chat API
- Google Meet REST API
2. Create OAuth 2.0 Credentials
- Navigate to APIs & Services > Credentials
- Click Create Credentials > OAuth client ID
- Select Desktop app as the application type
- Download the JSON file
3. Place Credentials File
Save the downloaded JSON file as credentials.json at the appropriate location for your platform:
Linux:
~/.config/google-mcp/credentials.json
(or $XDG_CONFIG_HOME/google-mcp/credentials.json if XDG_CONFIG_HOME is set)
macOS:
~/Library/Application Support/google-mcp/credentials.json
Windows:
%APPDATA%\google-mcp\credentials.json
(typically C:\Users\<username>\AppData\Roaming\google-mcp\credentials.json)
The file should look like:
{
"installed": {
"client_id": "YOUR_CLIENT_ID.apps.googleusercontent.com",
"project_id": "your-project-id",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_secret": "YOUR_CLIENT_SECRET",
"redirect_uris": ["http://localhost:3000/oauth2callback"]
}
}
Usage with Cursor/Claude
Add to your MCP settings configuration:
{
"mcpServers": {
"google": {
"command": "node",
"args": ["/path/to/google-mcp/dist/index.js"]
}
}
}
Or if running from the project directory:
{
"mcpServers": {
"google": {
"command": "npx",
"args": ["tsx", "/path/to/google-mcp/src/index.ts"]
}
}
}
Authentication
On first use, call the google_auth tool to initiate OAuth authentication:
- The server will provide a URL to authenticate
- Open the URL in a browser and sign in with your Google account
- Grant the requested permissions
- Authentication will complete automatically
Tokens are stored locally and will be refreshed automatically:
- Linux:
~/.local/share/google-mcp/tokens.json(or$XDG_DATA_HOME/google-mcp/) - macOS:
~/Library/Application Support/google-mcp/tokens.json - Windows:
%APPDATA%\google-mcp\tokens.json
Available Tools
Authentication
| Tool | Description |
|---|---|
google_auth | Initiate OAuth authentication |
google_auth_status | Check authentication status |
google_auth_code | Manually set auth code |
google_logout | Log out and clear tokens |
Google Calendar
| Tool | Description |
|---|---|
calendar_list | List all calendars |
calendar_get | Get calendar details |
calendar_list_events | List events from calendar |
calendar_get_event | Get event details |
calendar_create_event | Create new event |
calendar_update_event | Update existing event |
calendar_delete_event | Delete an event |
calendar_quick_add | Add event via natural language |
calendar_get_freebusy | Check availability |
calendar_today | Get today's events |
calendar_upcoming | Get upcoming events |
Google Gmail
| Tool | Description |
|---|---|
gmail_get_profile | Get Gmail profile info |
gmail_list_labels | List Gmail labels |
gmail_list_messages | List emails |
gmail_get_message | Get specific email |
gmail_send | Send an email |
gmail_reply | Reply to an email |
gmail_trash | Move to trash |
gmail_mark_read | Mark as read |
gmail_mark_unread | Mark as unread |
gmail_search | Search emails |
gmail_get_unread | Get unread emails |
gmail_get_thread | Get email thread |
Google Contacts
| Tool | Description |
|---|---|
contacts_list | List contacts |
contacts_get | Get contact details |
contacts_search | Search contacts |
contacts_create | Create contact |
contacts_delete | Delete contact |
contacts_list_groups | List contact groups |
Google Drive
| Tool | Description |
|---|---|
drive_list_files | List files with filtering |
drive_get_file | Get file metadata |
drive_download_file | Download file content |
drive_upload_file | Upload a new file |
drive_delete_file | Delete a file |
drive_create_folder | Create a new folder |
drive_search | Search files by content |
drive_move_file | Move file to folder |
drive_copy_file | Copy a file |
drive_rename_file | Rename a file |
Google Docs
| Tool | Description |
|---|---|
docs_create | Create a new document |
docs_read | Read document content |
docs_insert_text | Insert text at position |
docs_append_text | Append text to end |
docs_replace_text | Find and replace text |
docs_list | List all documents |
Google Sheets
| Tool | Description |
|---|---|
sheets_create | Create spreadsheet |
sheets_get | Get spreadsheet info |
sheets_read | Read values from range |
sheets_update | Update values in range |
sheets_append | Append rows |
sheets_clear | Clear a range |
sheets_add_sheet | Add a new sheet |
sheets_delete_sheet | Delete a sheet |
sheets_list | List all spreadsheets |
Google Slides
| Tool | Description |
|---|---|
slides_create | Create presentation |
slides_get | Get presentation |
slides_list | List presentations |
slides_add_slide | Add a slide |
slides_delete_slide | Delete a slide |
slides_add_text | Add text box |
slides_add_image | Add image |
slides_replace_text | Find/replace text |
slides_duplicate_slide | Duplicate slide |
Google YouTube
| Tool | Description |
|---|---|
youtube_search | Search YouTube |
youtube_get_video | Get video details |
youtube_get_channel | Get channel details |
youtube_get_my_channel | Get your channel |
youtube_list_playlists | List your playlists |
youtube_get_playlist_items | Get playlist videos |
youtube_get_video_comments | Get video comments |
youtube_list_subscriptions | List subscriptions |
youtube_list_liked_videos | List liked videos |
youtube_rate_video | Like/dislike video |
Google Tasks
| Tool | Description |
|---|---|
tasks_list_tasklists | List task lists |
tasks_create_tasklist | Create task list |
tasks_delete_tasklist | Delete task list |
tasks_list_tasks | List tasks |
tasks_create_task | Create a task |
tasks_update_task | Update a task |
tasks_delete_task | Delete a task |
tasks_complete_task | Mark task complete |
Notes (Keep-like)
| Tool | Description |
|---|---|
notes_create | Create a quick note |
notes_list | List all notes |
notes_update | Update a note |
notes_delete | Delete a note |
Google Forms
| Tool | Description |
|---|---|
forms_create | Create a new form |
forms_get | Get form details |
forms_update_info | Update title/description |
forms_add_question | Add a question |
forms_delete_item | Delete form item |
forms_list_responses | List form responses |
forms_get_response | Get specific response |
forms_add_page_break | Add page break |
forms_add_text | Add text item |
forms_add_image | Add image |
forms_add_video | Add YouTube video |
Google Chat
| Tool | Description |
|---|---|
chat_list_spaces | List Chat spaces |
chat_get_space | Get space details |
chat_create_space | Create a space |
chat_delete_space | Delete a space |
chat_list_messages | List messages |
chat_get_message | Get message details |
chat_send_message | Send a message |
chat_update_message | Update a message |
chat_delete_message | Delete a message |
chat_list_members | List space members |
chat_add_member | Add a member |
chat_remove_member | Remove a member |
chat_add_reaction | Add emoji reaction |
Google Meet
| Tool | Description |
|---|---|
meet_create_space | Create meeting space |
meet_get_space | Get space details |
meet_end_conference | End active meeting |
meet_schedule | Schedule a meeting |
meet_create_instant | Create instant meeting |
meet_get_by_event | Get meeting from event |
meet_list_upcoming | List upcoming meetings |
meet_list_conference_records | List past meetings |
meet_get_conference_record | Get meeting record |
meet_list_participants | List participants |
meet_list_recordings | List recordings |
meet_get_recording | Get recording |
meet_list_transcripts | List transcripts |
meet_get_transcript | Get transcript |
meet_list_transcript_entries | Get transcript text |
Examples
Send an Email
Use gmail_send with to "recipient@example.com", subject "Hello", and body "This is a test email."
Create a Calendar Event
Use calendar_create_event with summary "Team Meeting", startDateTime "2025-01-15T10:00:00-05:00", and endDateTime "2025-01-15T11:00:00-05:00"
Search YouTube
Use youtube_search with query "MCP tutorial" and type "video"
Create a Google Doc
Use docs_create with title "Meeting Notes" and content "# Weekly Meeting\n\nAttendees: ..."
Read a Spreadsheet
Use sheets_read with spreadsheetId "abc123" and range "Sheet1!A1:D10"
Search Drive
Use drive_search with query "quarterly report"
Create a Note
Use notes_create with title "Shopping List" and content "- Milk\n- Eggs\n- Bread"
Create a Google Form
Use forms_create with title "Customer Survey" and description "Help us improve our service"
Send a Chat Message
Use chat_send_message with spaceName "spaces/AAAAA" and text "Hello team!"
Schedule a Google Meet
Use meet_schedule with summary "Team Standup", startTime "2025-01-15T09:00:00-05:00", and endTime "2025-01-15T09:30:00-05:00"
Development
# Run in development mode with hot reload
pnpm dev
# Build for production
pnpm build
# Run tests
pnpm test
License
MIT License - see LICENSE for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Related Servers
Runbook
Integrates with Runbook to allow listing, reading, and searching over documents.
MCP Prompt Manager
A server for managing local prompt files, allowing AI models to create, retrieve, update, and delete them.
MCP Shrimp Task Manager
An intelligent task management system based on MCP, providing an efficient programming workflow framework for AI Agents with an optional web-based GUI.
Shortcut
Interact with the Shortcut project management tool, formerly known as Clubhouse.
delinea-mcp
Official Delinea MCP server for the Delinea Secret Server and Platform APIs
FireHydrant
An MCP server for interacting with the FireHydrant incident management platform API.
incident.io
An MCP server for interacting with the incident.io V2 API for incident management.
Browser Use
An AI-driven server for browser automation using natural language commands, implementing the Model Context Protocol (MCP).
macOS Defaults
Read and write macOS user defaults and settings.
Kibela
Manage content on the Kibela knowledge sharing platform.