Google Docs & Gmail MCP Server
Enables appending text to Google Docs and creating Gmail drafts with interactive approval via terminal.
README
Google Docs & Gmail MCP Server
A Python-based MCP-style FastAPI server that integrates with Google Docs and Gmail APIs.
Features
- Append to Doc (
POST /append_to_doc): Appends text content to a Google Document. - Create Email Draft (
POST /create_email_draft): Creates a Gmail draft. - Terminal Approval Gate: Before executing any action, the server outputs the details in the console and blocks waiting for operator approval
Approve? (y/n).
Setup Instructions
1. Enable Google APIs & Get Credentials
To run the server, you need to download OAuth client credentials from the Google Cloud Console.
- Go to the Google Cloud Console.
- Create a new project or select an existing one.
- Enable the Google Docs API and Gmail API under APIs & Services > Library.
- Configure the OAuth Consent Screen:
- Choose user type (External or Internal).
- Add the scopes:
https://www.googleapis.com/auth/documentshttps://www.googleapis.com/auth/gmail.compose
- Add your Gmail account under Test users.
- Create Credentials:
- Go to APIs & Services > Credentials.
- Click Create Credentials > OAuth client ID.
- Select application type Desktop App and name it (e.g.,
MCP Google Server). - Click Create, then download the client secrets JSON.
- Rename the downloaded file to
credentials.jsonand place it in the project root directory (google-mcp-server/credentials.json).
Note: credentials.json and token.json (created after authentication) are added to .gitignore to prevent committing them to VCS.
2. Install Dependencies
It is recommended to run in a Python virtual environment:
# Create and activate virtual environment
python3 -m venv .venv
source .venv/bin/activate
# Install required packages
pip install -r requirements.txt
3. Run the Server
Start the FastAPI application:
python server.py
- On the first run, a browser window will open asking you to log into your Google Account.
- Grant permissions for the Docs and Gmail scopes.
- Once completed, the browser will show "The authentication flow has completed..." and
token.jsonwill be saved to the directory. - Subsequent startups will automatically load credentials from
token.jsonand skip the browser login.
Note: The server binds to 127.0.0.1:8000 to prevent external network access.
API Usage & Verification
1. Append Text to a Google Doc
Sends a request to append text to the Google Document specified by doc_id.
Request:
curl -X POST http://127.0.0.1:8000/append_to_doc \
-H "Content-Type: application/json" \
-d '{
"doc_id": "YOUR_DOCUMENT_ID_HERE",
"content": "\nThis text was appended via the MCP-style server!"
}'
Terminal Prompt:
========================================
ACTION REQUESTED: append_to_doc
Payload: {'doc_id': 'YOUR_DOCUMENT_ID_HERE', 'content': '\nThis text was appended via the MCP-style server!'}
========================================
Approve? (y/n):
- Type
yand press Enter to execute the append operation. - Type
n(or any other input) to abort. The endpoint returns403 Forbidden.
2. Create a Gmail Draft
Sends a request to create a draft email.
Request:
curl -X POST http://127.0.0.1:8000/create_email_draft \
-H "Content-Type: application/json" \
-d '{
"to": "recipient@example.com",
"subject": "Hello from MCP",
"body": "This is a draft generated by the Google MCP server."
}'
Terminal Prompt:
========================================
ACTION REQUESTED: create_email_draft
Payload: {'to': 'recipient@example.com', 'subject': 'Hello from MCP', 'body': 'This is a draft generated by the Google MCP server.'}
========================================
Approve? (y/n):
- Type
yand press Enter to execute the draft creation. - Type
n(or any other input) to abort. The endpoint returns403 Forbidden.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.