Connects Claude to Gmail via OAuth, exposing tools for searching messages, sending and replying to email, managing labels, and moving threads to trash. The server supports three auth modes: loopback OAuth for local use, service accounts for delegated access, and DCR for self-hosted deployments. You can export search results to CSV, mark messages as read in batches, and work with Gmail's query syntax through dedicated prompts. Runs over stdio for desktop clients or HTTP for remote setups. Reach for this when you want Claude to triage your inbox, draft responses based on thread context, or automate label-based workflows without leaving the chat.
Public tool metadata for what this MCP can expose to an agent.
GMAIL_ADD_LABEL_TO_EMAILAdds and/or removes specified gmail labels for a message; ensure `message id` and all `label ids` are valid (use 'listlabels' for custom label ids).4 paramsAdds and/or removes specified gmail labels for a message; ensure `message id` and all `label ids` are valid (use 'listlabels' for custom label ids).
user_idstringmessage_idstringadd_label_idsarrayremove_label_idsarrayGMAIL_CREATE_EMAIL_DRAFTCreates a gmail email draft, supporting to/cc/bcc, subject, plain/html body (ensure `is html=true` for html), attachments, and threading.10 paramsCreates a gmail email draft, supporting to/cc/bcc, subject, plain/html body (ensure `is html=true` for html), attachments, and threading.
ccarraybccarraybodystringis_htmlbooleansubjectstringuser_idstringthread_idstringattachmentobjectrecipient_emailstringextra_recipientsarrayGMAIL_CREATE_LABELCreates a new label with a unique name in the specified user's gmail account.6 paramsCreates a new label with a unique name in the specified user's gmail account.
user_idstringlabel_namestringtext_colorstringbackground_colorstringlabel_list_visibilitystringmessage_list_visibilitystringGMAIL_DELETE_DRAFTPermanently deletes a specific gmail draft using its id; ensure the draft exists and the user has necessary permissions for the given `user id`.2 paramsPermanently deletes a specific gmail draft using its id; ensure the draft exists and the user has necessary permissions for the given `user id`.
user_idstringdraft_idstringGMAIL_DELETE_MESSAGEPermanently deletes a specific email message by its id from a gmail mailbox; for `user id`, use 'me' for the authenticated user or an email address to which the authenticated user has delegated access.2 paramsPermanently deletes a specific email message by its id from a gmail mailbox; for `user id`, use 'me' for the authenticated user or an email address to which the authenticated user has delegated access.
user_idstringmessage_idstringGMAIL_FETCH_EMAILSFetches a list of email messages from a gmail account, supporting filtering, pagination, and optional full content retrieval.9 paramsFetches a list of email messages from a gmail account, supporting filtering, pagination, and optional full content retrieval.
querystringuser_idstringverbosebooleanids_onlybooleanlabel_idsarraypage_tokenstringmax_resultsintegerinclude_payloadbooleaninclude_spam_trashbooleanGMAIL_FETCH_MESSAGE_BY_MESSAGE_IDFetches a specific email message by its id, provided the `message id` exists and is accessible to the authenticated `user id`.3 paramsFetches a specific email message by its id, provided the `message id` exists and is accessible to the authenticated `user id`.
formatstringuser_idstringmessage_idstringGMAIL_FETCH_MESSAGE_BY_THREAD_IDRetrieves messages from a gmail thread using its `thread id`, where the thread must be accessible by the specified `user id`.3 paramsRetrieves messages from a gmail thread using its `thread id`, where the thread must be accessible by the specified `user id`.
user_idstringthread_idstringpage_tokenstringGMAIL_GET_ATTACHMENTRetrieves a specific attachment by id from a message in a user's gmail mailbox, requiring valid message and attachment ids.4 paramsRetrieves a specific attachment by id from a message in a user's gmail mailbox, requiring valid message and attachment ids.
user_idstringfile_namestringmessage_idstringattachment_idstringGMAIL_GET_CONTACTSFetches contacts (connections) for the authenticated google account, allowing selection of specific data fields and pagination.4 paramsFetches contacts (connections) for the authenticated google account, allowing selection of specific data fields and pagination.
page_tokenstringperson_fieldsstringresource_namestringinclude_other_contactsbooleanGMAIL_GET_PEOPLERetrieves either a specific person's details (using `resource name`) or lists 'other contacts' (if `other contacts` is true), with `person fields` specifying the data to return.6 paramsRetrieves either a specific person's details (using `resource name`) or lists 'other contacts' (if `other contacts` is true), with `person fields` specifying the data to return.
page_sizeintegerpage_tokenstringsync_tokenstringperson_fieldsstringresource_namestringother_contactsbooleanGMAIL_GET_PROFILERetrieves key gmail profile information (email address, message/thread totals, history id) for a user.1 paramsRetrieves key gmail profile information (email address, message/thread totals, history id) for a user.
user_idstringGMAIL_LIST_DRAFTSRetrieves a paginated list of email drafts from a user's gmail account. use verbose=true to get full draft details including subject, body, sender, and timestamp.4 paramsRetrieves a paginated list of email drafts from a user's gmail account. use verbose=true to get full draft details including subject, body, sender, and timestamp.
user_idstringverbosebooleanpage_tokenstringmax_resultsintegerGMAIL_LIST_LABELSRetrieves a list of all system and user-created labels for the specified gmail account.1 paramsRetrieves a list of all system and user-created labels for the specified gmail account.
user_idstringGMAIL_LIST_THREADSRetrieves a list of email threads from a gmail account, identified by `user id` (email address or 'me'), supporting filtering and pagination.5 paramsRetrieves a list of email threads from a gmail account, identified by `user id` (email address or 'me'), supporting filtering and pagination.
querystringuser_idstringverbosebooleanpage_tokenstringmax_resultsintegerGMAIL_MODIFY_THREAD_LABELSAdds or removes specified existing label ids from a gmail thread, affecting all its messages; ensure the thread id is valid.4 paramsAdds or removes specified existing label ids from a gmail thread, affecting all its messages; ensure the thread id is valid.
user_idstringthread_idstringadd_label_idsarrayremove_label_idsarrayGMAIL_MOVE_TO_TRASHMoves an existing, non-deleted email message to the trash for the specified user.2 paramsMoves an existing, non-deleted email message to the trash for the specified user.
user_idstringmessage_idstringGMAIL_PATCH_LABELPatches the specified label.6 paramsPatches the specified label.
idstringnamestringcolorobjectuserIdstringlabelListVisibilitystringmessageListVisibilitystringGMAIL_REMOVE_LABELPermanently deletes a specific, existing user-created gmail label by its id for a user; cannot delete system labels.2 paramsPermanently deletes a specific, existing user-created gmail label by its id for a user; cannot delete system labels.
user_idstringlabel_idstringGMAIL_REPLY_TO_THREADSends a reply within a specific gmail thread using the original thread's subject, requiring a valid `thread id` and correctly formatted email addresses. supports attachments via the `attachment` parameter with valid `s3key`, `mimetype`, and `name`.9 paramsSends a reply within a specific gmail thread using the original thread's subject, requiring a valid `thread id` and correctly formatted email addresses. supports attachments via the `attachment` parameter with valid `s3key`, `mimetype`, and `name`.
ccarraybccarrayis_htmlbooleanuser_idstringthread_idstringattachmentobjectmessage_bodystringrecipient_emailstringextra_recipientsarrayGOOGLE_CLIENT_ID*Google OAuth client ID (required for OAuth authentication modes)
GOOGLE_CLIENT_SECRETsecretGoogle OAuth client secret (optional for public clients)
GOOGLE_SERVICE_ACCOUNT_KEY_FILEPath to service account JSON key file (required for service-account auth mode)
AUTH_MODEAuthentication mode
HEADLESSdefault: falseDisable browser auto-open, return auth URL instead (true/false)
REDIRECT_URIOAuth redirect URI (optional, default: ephemeral loopback)
RESOURCE_STORE_URIResource store URI for CSV export files (file://)
PORTHTTP server port (overrides --port)
BASE_URLBase URL for HTTP transport (used for OAuth/DCR endpoints and file links)
LOG_LEVELLogging level
DCR_MODEdefault: self-hostedDynamic Client Registration mode
DCR_VERIFY_URLExternal verification endpoint URL (required for external DCR mode)
DCR_STORE_URIdefault: file://~/.mcp-z/mcp-gmail/dcr.jsonDCR client storage URI (for self-hosted DCR mode)
io.github.mindstone/mcp-server-microsoft-teams
com.mintmcp/outlook-email
helbertparanhos/resend-email-mcp
marlinjai/email-mcp
io.github.mindstone/mcp-server-email-imap
io.github.osamahassouna/email-playbook-mcp