Connects Claude to your local UpNote SQLite database for reads (search, fetch, list by notebook or tag) and uses the upnote:// URL scheme for writes. You get full note text back, so Claude can summarize across your notes or pull out specifics without you copy-pasting. Creating notes works through x-callback-url, which means you can't set tags programmatically, but everything else (title, markdown body, notebook placement) goes through. Best on macOS where paths are verified; Windows support is best-effort with a guessable default DB location you might need to override. Useful when you want conversational access to your notes without leaving the chat or manually searching the app.
A hybrid MCP server that lets your AI assistant work with your UpNote notes:
Under the hood: reads come from the local UpNote SQLite database (read-only),
so real content comes back as text; writes go through the upnote:// URL scheme
(x-callback-url) and never touch the database.
The write side (URL scheme) is based on chadthornton/upnote-mcp (MIT).
Once it's registered, just talk to your AI assistant in plain language — it picks the right tool for you. No commands or syntax to memorize. For example:
Reading, searching, summarizing, and creating all happen through natural conversation.
%APPDATA%\UpNote\. This path is
not verified by the author — if reads fail, set UPNOTE_LENS_DB (see below).Give your MCP client (Claude, etc.) a link to
llms-install.md and it will run the steps and set everything
up for you.
Pick the first option that fits what you already have. Each option includes how to register it in Claude.
Claude Desktop config file (referenced in each option):
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json- Windows:
%APPDATA%\Claude\claude_desktop_config.json
Requires uv installed once
(brew install uv, or curl -LsSf https://astral.sh/uv/install.sh | sh).
After that there's no package install step — uvx downloads, caches, and
runs upnote-lens-mcp on demand.
Claude Code:
claude mcp add upnote-lens -- uvx upnote-lens-mcp
Claude Desktop:
{ "mcpServers": { "upnote-lens": { "command": "uvx", "args": ["upnote-lens-mcp"] } } }
pip install upnote-lens-mcp
Claude Code:
claude mcp add upnote-lens -- upnote-lens-mcp
Claude Desktop:
{ "mcpServers": { "upnote-lens": { "command": "upnote-lens-mcp" } } }
When you can't use PyPI/pip, install straight from the repo with uv. (No uv yet?
curl -LsSf https://astral.sh/uv/install.sh | sh.)
Claude Code:
claude mcp add upnote-lens -- uvx --from git+https://github.com/AwesomeHye/upnote-lens-mcp upnote-lens-mcp
Claude Desktop:
{ "mcpServers": { "upnote-lens": { "command": "uvx", "args": ["--from", "git+https://github.com/AwesomeHye/upnote-lens-mcp", "upnote-lens-mcp"] } } }
| Tool | Description |
|---|---|
search_notes(query, limit=20) | Substring search over title/body. Returns id, title, updated time, snippet |
get_note(note_id, include_html=False) | Full title + body text of a note (optionally raw HTML) |
list_recent(limit=20) | Most recently updated notes |
list_notebooks() | Notebooks with note counts and parent |
list_notes_in_notebook(notebook_id, limit=50) | Notes inside a notebook |
list_tags() | Tags with note counts |
list_notes_by_tag(tag_title, limit=50) | Notes carrying a tag |
upnote:// URL scheme)| Tool | Description |
|---|---|
create_note(title, content, notebook?, markdown=True, new_window=False) | Create a note. content is Markdown by default. notebook matches by name. Tags can't be set (see below) |
open_note(note_id, new_window=False) | Open an existing note in the app |
open_notebook(notebook_id) | Open a notebook in the app |
Tag limitation: UpNote's
note/newURL scheme has no tag parameter, and hashtags placed in the body stay as plain text rather than becoming real tags (they only convert to tags when typed in the editor). If you need tags, add them manually in the app after the note is created.
If the database isn't in the default location (or you're on Windows), point at it with an environment variable:
UPNOTE_LENS_DB=/path/to/upnote.sqlite3
Default paths:
~/Library/Containers/com.getupnote.desktop/Data/Library/Application Support/UpNote/upnote.sqlite3%APPDATA%\UpNote\upnote.sqlite3MIT. See LICENSE for details. The URL-scheme formats and launch approach on the write side are adapted from chadthornton/upnote-mcp (MIT).
io.github.pipeworx-io/brave-search
marcopesani/mcp-server-serper
brave/brave-search-mcp-server
com.mcparmory/google-search-console
acamolese/google-search-console-mcp
io.github.sarahpark/google-search-console