The Keep MCP server provides a comprehensive interface for managing Google Keep notes programmatically via the Model Context Protocol.
Search and Retrieval:
Find notes by text query with optional filters (labels, colors, pinned, archived, trashed status)
Retrieve a single note by its ID
Note Creation and Update:
Create text notes with title and content (automatically tagged with
keep-mcplabel)Create checklist notes (to-do/shopping lists)
Update an existing note's title and text
Checklist Management:
Add, update (text and checked state), and delete checklist items
Note State and Lifecycle:
Set note color (12 options: DEFAULT, RED, ORANGE, YELLOW, GREEN, TEAL, BLUE, CERULEAN, PURPLE, PINK, BROWN, GRAY)
Pin/unpin, archive/unarchive, trash/restore, or mark notes for deletion
Label Management:
List, create, and delete labels
Add or remove labels from notes
Collaborator Management:
List, add, and remove collaborators on a note
Media Management:
List media attachments for a note, including their links
Safety Controls:
By default, modification operations are restricted to notes with the
keep-mcplabelSet
UNSAFE_MODEto allow modifications to any note
Enables interaction with Google Keep notes, providing capabilities to search for notes, create new notes, update existing notes, and mark notes for deletion. Notes created through the integration are automatically labeled for tracking purposes.
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., "@Keep MCPfind my shopping list from yesterday"
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.
keep-mcp
MCP server for Google Keep
How to use
Add the MCP server to your MCP servers:
Add your credentials:
GOOGLE_EMAIL: Your Google account email addressGOOGLE_MASTER_TOKEN: Your Google account master token
Check https://gkeepapi.readthedocs.io/en/latest/#obtaining-a-master-token and https://github.com/simon-weber/gpsoauth?tab=readme-ov-file#alternative-flow for more information.
Related MCP server: Google Drive MCP Server
Features
Query and read tools
find: Search notes with optional filters for labels, colors, pinned, archived, and trashedget_note: Get a single note by ID
Creation and update tools
create_note: Create a new note with title and text (automatically adds keep-mcp label)create_list: Create a checklist noteupdate_note: Update a note's title and textadd_list_item: Add an item to a checklist noteupdate_list_item: Update checklist item text and checked statedelete_list_item: Delete a checklist item
Note state tools
set_note_color: Set a note color (valid values: DEFAULT, RED, ORANGE, YELLOW, GREEN, TEAL, BLUE, CERULEAN, PURPLE, PINK, BROWN, GRAY)pin_note: Pin or unpin a notearchive_note: Archive or unarchive a notetrash_note: Move a note to trashrestore_note: Restore a trashed/deleted notedelete_note: Mark a note for deletion
Labels, collaborators, and media tools
list_labels: List labelscreate_label: Create a labeldelete_label: Delete a labeladd_label_to_note: Add a label to a noteremove_label_from_note: Remove a label from a notelist_note_collaborators: List collaborator emails for a noteadd_note_collaborator: Add a collaborator email to a noteremove_note_collaborator: Remove a collaborator email from a notelist_note_media: List media blobs for a note (with media links)
By default, all destructive and modification operations are restricted to notes that have were created by the MCP server (i.e. have the keep-mcp label). Set UNSAFE_MODE to true to bypass this restriction.
Local development (uv + make)
If you prefer a JS-style workflow (npm i, npm start), use the included Makefile:
Run the real-account smoke test with credentials:
Equivalent direct uv commands (without make):
Testing
Unit tests (default)
The project includes a lightweight unit test suite under tests/.
It validates:
note serialization shape for note and list objects (including labels, collaborators, media, and list items)
modification safety behavior (
keep-mcplabel requirement andUNSAFE_MODE=trueoverride)MCP tool behavior in
src/server/cli.pyusing mocked Keep client objects (tool happy paths and key error paths)
Run locally:
Smoke test against a real Keep account
For additional confidence, run a basic lifecycle smoke test against a dedicated test account:
What it does:
create note
update note
pin/unpin
archive/unarchive
trash/restore
delete
This script is intended for manual verification and is not run in CI.
CI checks
GitHub Actions runs on every pull request and executes:
lint (
ruff check .)unit tests with coverage (
pytest -q --cov=src/server --cov-report=term-missing --cov-fail-under=70)bytecode sanity (
python -m compileall src)
Publishing
Automatic publish on merge to main (GitHub Actions)
This repo includes a release workflow at .github/workflows/release.yml that runs on every push to main (including merged PRs).
It will:
inspect commits since the last release tag (
vX.Y.Z)compute the next semantic version from Conventional Commit types
skip publishing when there are no releasable commit types
run lint and unit tests
build
dist/*publish to PyPI
create a GitHub release/tag
v<computed-version>with generated notes
Version bump rules:
major: commit subject with
!(example:feat!:orfix(api)!:) or commit body containingBREAKING CHANGEminor:
feat:patch:
fix:,perf:,revert:no release:
docs:,chore:,ci:,test:,refactor:(unless the commit is marked as breaking)
Required repository secret:
PYPI_API_TOKEN: a PyPI API token (recommended scope: this project only)
Manual publish
To publish manually to PyPI:
Update the version in
pyproject.tomlBuild the package:
pipx run buildUpload to PyPI:
pipx run twine upload --repository pypi dist/*
Run locally with MCP clients
This is useful when you want a client to run this server from your local checkout instead of PyPI.
Create a local virtualenv and install in editable mode:
Add the server to your MCP client config.
config.toml clients (Codex, Goose, etc.)
JSON mcpServers clients (Claude Desktop, Cursor, Cline, etc.)
Alternative (without make):
Notes:
Run
make installonce before starting from an MCP client.Only the repo root path is required (no absolute
/.venv/bin/pythonpath).Ensure
makeanduvare in yourPATH.Restart your MCP client after updating config files.
UNSAFE_MODEis optional; keep it"false"unless you explicitly want to modify non-keep-mcpnotes.
Troubleshooting
If you get "DeviceManagementRequiredOrSyncDisabled" check https://admin.google.com/ac/devices/settings/general and turn "Turn off mobile management (Unmanaged)"