MCP server for Google Calendar, Gmail, and Drive integration
Project description
Google Cloud MCP - Google Workspace MCP Server (gg-mcp)
A Model Context Protocol (MCP) server that connects AI agents to Google Workspace: Gmail, Calendar, Drive, Docs, Sheets, and Slides. Built with FastMCP.
# Install and run โ that's it
uvx gg-mcp
๏ฟฝ Table of Contents
- Quick Start (5 minutes)
- Available Tools
- Installation Options
- Environment Variables
- Troubleshooting
- Documentation
- Development
๐ Quick Start (5 minutes)
Step 1: Get Google OAuth Credentials
- Go to Google Cloud Console
- Create a project and enable OAuth consent screen (External type)
- Add required scopes (Gmail, Drive, Calendar, Docs, Sheets, Slides)
- Create OAuth 2.0 Desktop app credentials
- Copy Client ID and Client Secret
๐ Detailed guide โ
Step 2: Install & Run
export GOOGLE_CLIENT_ID="your-client-id.apps.googleusercontent.com"
export GOOGLE_CLIENT_SECRET="your-client-secret"
uvx gg-mcp
You'll see:
============================================================
๐ GOOGLE ACCOUNT AUTHENTICATION
๐ฑ Open your browser: http://localhost:3838
============================================================
Open http://localhost:3838 โ "Authorize with Google" โ Grant permissions โ
Step 3: Configure MCP Client
Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"gg-mcp": {
"command": "uvx",
"args": ["gg-mcp"],
"env": {
"GOOGLE_CLIENT_ID": "your-client-id.apps.googleusercontent.com",
"GOOGLE_CLIENT_SECRET": "your-client-secret"
}
}
}
}
Restart Claude Desktop and the tools are ready to use! ๐
๐ Available Tools (30+)
Account
get_account_info- Get the email of the authenticated Google account
Gmail
send_email- Send an email (to, subject, body)create_gmail_label- Create a new Gmail labellist_gmail_labels- List all user-created labels
Google Calendar
list_calendar_events- List upcoming events (max_results, days_back)create_calendar_event- Create an event (summary, start_time, end_time)
Google Drive
list_drive_folders- List all folders in Google Drive (root or specific parent)search_drive- Search files by query string
Google Docs
create_document- Create a new document with optional textget_document- Get the full text content of a documentappend_to_document- Append text to document endsearch_documents- Search for documents in Driveexport_document- Export document (text, html, pdf, docx)
Google Sheets
create_spreadsheet- Create a new spreadsheetread_spreadsheet- Read data from a rangeupdate_spreadsheet- Update cells with JSON 2D arrayappend_to_spreadsheet- Append rows to spreadsheetsearch_spreadsheets- Search for spreadsheets in Driveget_spreadsheet_info- Get metadata and dimensionsclear_spreadsheet_range- Clear all values in a rangebatch_update_spreadsheet- Batch update multiple rangesadd_sheet- Add a new sheet/tabexport_spreadsheet- Export (csv, xlsx, pdf, tsv)
Google Slides
create_presentation- Create a new presentationget_presentation- Get slide metadata and contentadd_slide- Add a new slide with layout selectionadd_text_to_slide- Add a text box to slidesearch_presentations- Search for presentationsdelete_slide- Delete a slide by indexexport_presentation- Export (pdf, pptx, txt)
๐ Quick Start (5 minutes)
Step 1: Get Google OAuth Credentials
- Go to Google Cloud Console
- Create a project and enable OAuth consent screen (External type)
- Add required scopes (Gmail, Drive, Calendar, Docs, Sheets, Slides)
- Create OAuth 2.0 Desktop app credentials
- Copy Client ID and Client Secret
๐ Detailed guide โ
Step 2: Install & Run
export GOOGLE_CLIENT_ID="your-client-id.apps.googleusercontent.com"
export GOOGLE_CLIENT_SECRET="your-client-secret"
uvx gg-mcp
You'll see:
============================================================
๐ GOOGLE ACCOUNT AUTHENTICATION
๐ฑ Open your browser: http://localhost:3838
============================================================
Open http://localhost:3838 โ "Authorize with Google" โ Grant permissions โ
Step 3: Configure MCP Client
Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"gg-mcp": {
"command": "uvx",
"args": ["gg-mcp"],
"env": {
"GOOGLE_CLIENT_ID": "your-client-id.apps.googleusercontent.com",
"GOOGLE_CLIENT_SECRET": "your-client-secret"
}
}
}
}
๐ฆ Installation Options
Option A: PyPI (Recommended)
pip install gg-mcp
export GOOGLE_CLIENT_ID="..."
export GOOGLE_CLIENT_SECRET="..."
gg-mcp
Option B: From Source
git clone https://github.com/tannht/google-cloud-mcp.git
cd google-cloud-mcp
uv sync
export GOOGLE_CLIENT_ID="..."
export GOOGLE_CLIENT_SECRET="..."
uv run main.py
Option C: Docker
git clone https://github.com/tannht/google-cloud-mcp.git
cd google-cloud-mcp
docker-compose up -d --build
๐ Environment Variables
| Variable | Required | Default | Purpose |
|---|---|---|---|
GOOGLE_CLIENT_ID |
Yes | โ | OAuth 2.0 Client ID |
GOOGLE_CLIENT_SECRET |
Yes | โ | OAuth 2.0 Client Secret |
GOOGLE_TOKEN_PATH |
No | .token.json |
Token file path |
GOOGLE_TOKEN_JSON |
No | โ | Token as JSON string |
AUTH_PORT |
No | 3838 |
Auth portal port |
โ Troubleshooting
| Problem | Solution |
|---|---|
403: access_denied |
Add your email to Test users in OAuth consent screen |
401: Invalid credentials |
Verify GOOGLE_CLIENT_ID and GOOGLE_CLIENT_SECRET |
Token expired |
Delete .token.json and re-authenticate |
| Can't access http://localhost:3838 | Port 3838 in use. Try AUTH_PORT=8080 |
403: API not enabled |
Enable APIs in Google Cloud Console |
๐ Documentation
- GUIDE.md - Complete user & developer guide
- MCP_CLIENTS.md - 25+ MCP client configurations
๐ ๏ธ Development
git clone https://github.com/tannht/google-cloud-mcp.git
cd google-cloud-mcp
uv sync --group dev
uv run pytest -v # Run tests
๐ Dev setup โ
๐ License
MIT
๐ฅ Contributors
- Hoang Tan (Owner)
- PubPug Assistant (Primary Developer)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gg_mcp-2.1.1.tar.gz.
File metadata
- Download URL: gg_mcp-2.1.1.tar.gz
- Upload date:
- Size: 123.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
042cca2aa42920e0cb9e0e457ae6c8f45a1ba892e00f9ec068603b1ab167778f
|
|
| MD5 |
b44a40ec4e882bbfb7a6c8a6e3eeb18e
|
|
| BLAKE2b-256 |
7f790ceb6803e2c6e2e582d48e90e6462ce6d9200a79d5fb3f80385e46b20b39
|
File details
Details for the file gg_mcp-2.1.1-py3-none-any.whl.
File metadata
- Download URL: gg_mcp-2.1.1-py3-none-any.whl
- Upload date:
- Size: 11.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
543f543bdb7780d295d65c11e21aae52c26899cdb66c457992c54bc39862a719
|
|
| MD5 |
3d0cdc0f3c06e0593e213bd34115f0a9
|
|
| BLAKE2b-256 |
85dcd9f15eb3368ebd9f54fa421d7426d3e562ca10dabcb22b3a1a32e497b4b5
|