lite-google-workspace-mcp
Provides tools for searching, reading, sending, drafting, and managing labels and filters in Gmail.
Provides tools for managing events, out-of-office, focus time, and checking availability via free/busy queries.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@lite-google-workspace-mcpCheck my calendar for today"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
lite-google-workspace-mcp
Lightweight MCP server for Gmail and Google Calendar. Each Google account runs as an independent process on its own port.
How it works
Claude Code --HTTP--> lite-google-workspace-mcp (port 8001) --Google API--> account-A@gmail.com
--HTTP--> lite-google-workspace-mcp (port 8002) --Google API--> account-B@umd.eduOne process per Google account, each listening on a separate port
OAuth tokens stored locally at
~/.config/lite-google-workspace-mcp/tokens/<account>.jsonToken refresh handled automatically via
google-auth21 tools exposed per account: Gmail (search, read, send, draft, labels, filters) + Calendar (events, free/busy, OOO, focus time)
Related MCP server: mcp-gsuite
Prerequisites
A GCP project with Gmail API and Google Calendar API enabled
An OAuth 2.0 credential (Web application type) with redirect URI
http://localhost:8000/oauth2callbackDownload the credential JSON and save it as
~/.config/lite-google-workspace-mcp/client_secret.json
Install
git clone https://github.com/WhymustIhaveaname/lite-google-workspace-mcp.git
cd lite-google-workspace-mcp
uv syncFirst-time setup
1. Configure ports
Create ~/.config/lite-google-workspace-mcp/config.toml:
[accounts.myaccount]
port = 8001
[accounts.work]
port = 8002
allowed_recipients = ["boss@company.com", "team@company.com"]The account name is just a label you choose. It maps to a token file and a port.
allowed_recipients is optional. When set, send_gmail_message and draft_gmail_message will only allow sending to the listed addresses (checked against to/cc/bcc, case-insensitive). Omit it to allow sending to anyone.
2. Authorize accounts
uv run lite-google-workspace-mcp auth myaccountThis prints an OAuth URL and opens your browser. Sign in with the Google account you want to link, grant permissions (you can skip some scopes if you want), and the token is saved locally.
Repeat for each account.
3. Start the server
Manual:
uv run lite-google-workspace-mcp serve --account myaccountWith systemd (recommended):
cp contrib/lite-google-workspace-mcp@.service ~/.config/systemd/user/
systemctl --user daemon-reload
systemctl --user enable --now lite-google-workspace-mcp@myaccount4. Connect to Claude Code
claude mcp add --scope user --transport http lite-gmail-myaccount http://localhost:8001/mcpRe-authorization
If a token expires or you want to change granted scopes:
# Stop the service first (auth uses port 8000 which must be free)
systemctl --user stop lite-google-workspace-mcp@myaccount
# Re-authorize
uv run lite-google-workspace-mcp auth myaccount
# Restart
systemctl --user start lite-google-workspace-mcp@myaccountTools
Gmail (13 tools)
Tool | Description |
search_gmail_messages | Search by Gmail query syntax |
get_gmail_message_content | Read a single message |
get_gmail_messages_content_batch | Read multiple messages |
get_gmail_thread_content | Read an entire thread |
get_gmail_threads_content_batch | Read multiple threads |
get_gmail_attachment_content | Download attachment |
send_gmail_message | Send (plain text or HTML, with attachments) |
draft_gmail_message | Create a draft |
list_gmail_labels | List all labels |
manage_gmail_label | Create/update/delete labels |
list_gmail_filters | List all filters |
manage_gmail_filter | Create/delete filters |
modify_gmail_message_labels | Add/remove labels on a message |
batch_modify_gmail_message_labels | Bulk label modification |
Calendar (8 tools)
Tool | Description |
list_calendars | List all calendars |
get_events | Query events by time range |
manage_event | Create/update/delete events |
manage_out_of_office | Create/update/delete OOO blocks |
manage_focus_time | Create/update/delete focus time |
query_freebusy | Check availability |
create_calendar | Create a new calendar |
Development
uv sync --extra dev
uv run pytest
uv run ruff check src/This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/WhymustIhaveaname/lite-google-workspace-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server