Google Docs & Gmail MCP Server

Google Docs & Gmail MCP Server

Enables appending text to Google Docs and creating Gmail drafts with interactive approval via terminal.

Category
Visit Server

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.

  1. Go to the Google Cloud Console.
  2. Create a new project or select an existing one.
  3. Enable the Google Docs API and Gmail API under APIs & Services > Library.
  4. Configure the OAuth Consent Screen:
    • Choose user type (External or Internal).
    • Add the scopes:
      • https://www.googleapis.com/auth/documents
      • https://www.googleapis.com/auth/gmail.compose
    • Add your Gmail account under Test users.
  5. 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.
  6. Rename the downloaded file to credentials.json and 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.json will be saved to the directory.
  • Subsequent startups will automatically load credentials from token.json and 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 y and press Enter to execute the append operation.
  • Type n (or any other input) to abort. The endpoint returns 403 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 y and press Enter to execute the draft creation.
  • Type n (or any other input) to abort. The endpoint returns 403 Forbidden.

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured