Bridges Claude to Google Drive for notebook file management without executing any code. You get tools to create, edit, and sync ipynb files between local storage and Drive, inspect cell contents, compare versions using MD5 checksums, and generate Colab URLs. Handles OAuth setup with configurable scopes (file or full Drive access), normalizes Colab-specific metadata during downloads, and reports progress for long transfers. Useful when you need an agent to prepare notebooks locally, push them to Drive for manual execution in Colab, then pull back the results for analysis. All file operations stay within a configured root directory, and the server explicitly refuses to start runtimes, execute cells, or automate the Colab browser interface.
COLAB_MCP_ROOT*Absolute local directory that bounds notebook file access.
COLAB_MCP_DRIVE_ACCESSdefault: fileGoogle Drive access mode: file for minimal access or full for discovering existing notebooks.
COLAB_MCP_GOOGLE_CREDENTIALSOptional path to the local Google OAuth Desktop client JSON.
COLAB_MCP_GOOGLE_TOKENOptional path to the local Google OAuth token JSON.
An MCP server for safely inspecting, editing, and synchronizing
Google Colab-compatible .ipynb notebooks through Google Drive.
[!IMPORTANT] This is a notebook file synchronization server, not a notebook execution service. It transfers and edits
.ipynbfiles through Google Drive. It does not connect to Colab runtimes, execute cells, click Run all, keep sessions alive, automate the Colab browser UI, or bypass Colab limits.
Use this MCP when an AI agent needs to prepare a notebook locally, synchronize it with Drive, inspect completed outputs, or return an edited notebook to the user. Open and execute the synchronized notebook separately in Colab, Jupyter, VS Code, or another notebook runtime.
Run all, or unattended Colab sessions.The MCP initialization response includes server-wide instructions that define this project as file synchronization only. Tool descriptions repeat the same boundary where it matters.
manifest.0 provides the same purpose, capabilities, and
non-goals as a typed Zero language contract for agents and repository tooling.
get_google_drive_status: diagnose dependencies, credentials, token, and scope.authorize_google_drive: explicitly open the Google OAuth browser flow.list_local_notebooks, get_local_notebook, create_local_notebookadd_local_cell, update_local_cell, delete_local_cellsearch_local_cells, clear_local_outputslist_drive_notebooks, pull_drive_notebook, push_local_notebookget_notebook_sync_status, copy_drive_notebook, get_colab_urlpull_drive_notebook and push_local_notebook synchronize notebook files.
They send MCP progress notifications when the client supplies a progress token,
but clients decide whether and how to display those notifications. They never
execute notebook code. get_colab_url returns a URL but does not open a browser.
get_notebook_sync_status compares the local notebook's upload representation
with Drive's MD5 checksum and returns in_sync, differs, remote_only, or
unknown. It also returns Drive metadata such as modification time and version.
It cannot determine whether Colab is currently executing the notebook because
Google Drive does not expose Colab runtime activity.
Run directly from PyPI with uvx:
COLAB_MCP_ROOT="$HOME/notebooks" uvx --from 'colab-drive-mcp[drive]' colab-drive-mcp
Or install from source:
git clone https://github.com/YummyTastyCode/colab-drive-mcp.git
cd colab-drive-mcp
python3 -m venv .venv
.venv/bin/pip install -e '.[drive]'
Run the server:
COLAB_MCP_ROOT="$HOME/notebooks" .venv/bin/colab-drive-mcp
Local tools can access only .ipynb files below COLAB_MCP_ROOT.
The server is published in the official MCP Registry as:
io.github.YummyTastyCode/colab-drive-mcp
First call get_google_drive_status. It does not open a browser or modify
files. Its response explains the next required step.
To enable Drive:
~/.config/colab-mcp/credentials.json.authorize_google_drive and complete the Google sign-in flow.The resulting token is stored at ~/.config/colab-mcp/token.json.
Override these locations with:
COLAB_MCP_GOOGLE_CREDENTIALSCOLAB_MCP_GOOGLE_TOKENNever commit OAuth credentials or tokens.
The default mode is file, using Google's narrower drive.file scope:
COLAB_MCP_DRIVE_ACCESS=file
This mode can access files created or explicitly opened by this OAuth app. It cannot reliably list all existing notebooks in a user's Drive.
To find and update existing Drive notebooks, explicitly enable full access:
COLAB_MCP_DRIVE_ACCESS=full
Changing access modes may require deleting token.json and calling
authorize_google_drive again.
codex mcp add colab-drive \
--env COLAB_MCP_ROOT="$HOME/notebooks" \
--env COLAB_MCP_DRIVE_ACCESS=file \
-- /absolute/path/to/colab-drive-mcp/.venv/bin/colab-drive-mcp
Add this server to the VS Code MCP configuration:
{
"servers": {
"colab-drive": {
"type": "stdio",
"command": "/absolute/path/to/colab-drive-mcp/.venv/bin/colab-drive-mcp",
"env": {
"COLAB_MCP_ROOT": "/absolute/path/to/notebooks",
"COLAB_MCP_DRIVE_ACCESS": "file"
}
}
}
}
Google Colab may add a metadata property to stream outputs. That property is
invalid under the standard nbformat v4 schema. During Drive downloads, this
server removes only that incompatible property. Stream text and all other
outputs are preserved.
COLAB_MCP_ROOT.authorize_google_drive call.file access unless full Drive discovery is required.This project is not affiliated with or endorsed by Google.
.venv/bin/pip install -e '.[drive,test]'
.venv/bin/pytest
csoai-org/pdf-document-mcp
xt765/mcp-document-converter
io.github.xjtlumedia/markdown-formatter
io.github.ai-aviate/better-notion
suekou/mcp-notion-server
meterlong/mcp-doc