Neuro Vault MCP

Neuro Vault MCP

An MCP server that provides semantic search and vault operations for Obsidian notes, enabling agents to recall and manage notes with provenance and low token usage.

Category
Visit Server

README

Neuro Vault MCP

๐Ÿง ๐Ÿ’พ Make your personal vault usable by agents. Low-token retrieval, explicit provenance, and safe writes for your Obsidian notes โ€” in Claude Code, Cursor, Windsurf, and any MCP client.

https://github.com/user-attachments/assets/25c1bafb-7b90-43ac-aa50-50e85705fb5b

npm version Node.js License: ISC

Your second brain stops being a folder you open between contexts and becomes a first-class participant in every project. Agents can recall the right notes, inspect the evidence, and write back through vault-aware operations โ€” without grepping the whole folder or flooding the context window.

"What did I write about that idea last month?" โ€” and now your assistant can actually answer.


โœจ Why Neuro Vault?

  • ๐Ÿง  Semantic search that already knows your vault โ€” reuses Smart Connections embeddings. No re-indexing, no API keys, no extra infrastructure.
  • ๐ŸŽฏ Quick or deep, your call โ€” fast direct lookups for "find that note", or exploratory mode with related-note expansion when the question is fuzzy.
  • ๐Ÿงพ Context with provenance, not mystery memory โ€” results come back with paths, matched queries, block-level snippets, and backlink counts so the assistant can show where an answer came from.
  • ๐Ÿงญ A real navigation toolkit for your agent โ€” instead of grepping files and opening notes one by one, your assistant walks the vault like a database: filter by tags and properties, batch-read metadata, traverse the wikilink graph, discover the structure, jump to semantic neighbours.
  • ๐Ÿ”Ž Ask structured questions in plain language โ€” "active projects tagged #ai", "todo tasks with a deadline this week", "meeting notes from Work/ newest first" โ€” one call, ranked answer, no chains of reads.
  • โœ๏ธ Full write surface for your notes โ€” create, in-place replace, or rewrite the whole body; manage frontmatter, tags, and daily notes. Frontmatter and creation route through the Obsidian CLI so Smart Connections, sync, and other plugins stay in the loop; in-place edits write directly to disk and the watcher catches up.
  • โšก Zero infrastructure โ€” local stdio MCP server, in-memory index, no database, no background processes, no watchers.
  • ๐Ÿ”Œ Drop-in for any MCP client โ€” Claude Code, Cursor, Windsurf โ€” configuration is a single JSON block.

๐Ÿงฐ Two superpowers, one server

Most "vault MCP" servers give you one or the other. Neuro Vault gives you both, and lets your assistant pick the right one per question:

๐Ÿ”ญ Semantic recall ๐Ÿ›  Vault operations
What it does Finds notes by meaning, not keywords. Surfaces neighbours and duplicates. Reads, writes, edits notes (in-place replace and full-body rewrite); manages frontmatter, tags, daily notes.
Best for "What did I think about X?", fuzzy recall, exploratory research. Structured queries, capturing decisions, updating tasks, batch reads.
Powered by Smart Connections embeddings (already in your vault). The official Obsidian CLI โ€” Smart Connections, sync, plugins all stay in sync.

The two work together: semantic search finds the right region of the vault, vault operations let the assistant actually do something with what it found.


โœจ What it looks like in practice

Before: "Could you check my notes about that LangGraph experiment?" โ†’ Assistant lists Notes/, opens 12 files, greps for "LangGraph", gives up halfway, you paste the relevant note manually.

After: "Could you check my notes about that LangGraph experiment?" โ†’ One semantic search, top-3 ranked notes back, follow-up question already grounded in your own writing.

A few more questions Neuro Vault makes one-shot:

"What are my active projects tagged #ai with a deadline this quarter?" "Show meeting notes from Work/ from the last two weeks, newest first." "Find notes similar to this one I'm reading." "Append today's decision to the daily note." "What's on my agenda today โ€” and what did I capture in other notes since this morning?" "What did past-me write about retrieval policy before I started building it?"

One question, one answer. Your assistant stops being a file browser and starts being an actual second brain.

โ†’ See docs/guide/vault-operations.md for the full query language and examples.


๐Ÿ” Hybrid search: scope semantic with structural filters

search_notes accepts an optional filter to narrow the candidate set before semantic ranking โ€” combining the precision of query_notes with the recall of vector search. Useful when domain-relevant notes are crowded out by larger narrative clusters.

{ "query": "trading lessons", "filter": { "tags": ["trading"] } }

filter accepts path_prefix (string or array), exclude_path_prefix (string or array โ€” drops matched subtrees), tags (ANY-of), and a frontmatter sift filter. Composition is include โ†’ exclude โ†’ tags โ†’ frontmatter โ†’ threshold โ†’ semantic. See the Semantic Search guide for full details.


๐Ÿ— How it works

flowchart LR
    You([You]) --> AI[AI assistant]
    AI <-->|MCP| NV[Neuro Vault]
    NV <--> Vault[(Obsidian vault)]

You ask, the assistant calls Neuro Vault, Neuro Vault reads your vault โ€” semantic search uses embeddings already in .smart-env/, vault operations go through the obsidian CLI. No database, no background processes.

For module wiring and internal data flow, see docs/architecture/module-structure.md.


โšก Quickstart

npm install -g neuro-vault-mcp

Single vault

Add to your MCP client config (here: Claude Code's ~/.claude/settings.json):

{
  "mcpServers": {
    "neuro-vault": {
      "command": "neuro-vault-mcp",
      "args": ["--vault", "/absolute/path/to/your/vault"]
    }
  }
}

Vault directory names must match ^[a-zA-Z0-9_-]{1,64}$ โ€” ASCII letters, digits, _, or -; 1โ€“64 chars. Spaces and Unicode are rejected. The MCP-side alias is the directory basename, so if Obsidian shows the vault as "My Vault", the directory itself must be My_Vault or similar.

๐Ÿ—‚ Multi-vault โ€” two vaults, one server

Pass --vault once per vault:

neuro-vault-mcp \
  --vault /Users/me/Vaults/Sandbox \
  --vault /Users/me/Vaults/TeamWiki

Two vaults registered, with names Sandbox and TeamWiki. In your MCP config:

{
  "mcpServers": {
    "neuro-vault": {
      "command": "neuro-vault-mcp",
      "args": ["--vault", "/Users/me/Vaults/Sandbox", "--vault", "/Users/me/Vaults/TeamWiki"]
    }
  }
}

Two vaults cannot share the same directory basename โ€” the basename doubles as the alias and must be unique. If you have a basename collision, rename one of the directories.

With multiple vaults registered:

  • Every tool accepts an optional vault: "<name>" parameter to target a specific vault.
  • search_notes, query_notes, get_vault_overview, list_tags, and list_properties fan out across all registered vaults when vault is omitted. The response shape switches to results_by_vault: [...] (one entry per vault) plus skipped_vaults: [...] for any vault the tool could not reach and failed_vaults: [...] for per-vault runtime errors ({ vault, error: { code, message, details? } }). A single failed vault does not abort the whole call.
  • All other tools (writes, reads of specific paths, single-vault diagnostics) require an explicit vault in multi-vault mode. Omitting it returns VAULT_REQUIRED.
  • Semantic fan-out silently skips vaults whose Smart Connections .smart-env/multi/ index is unavailable. Targeting such a vault explicitly with vault: "<name>" returns SEMANTIC_INDEX_NOT_FOUND.

Then ask your assistant:

"What did I write about building AI agents?"

On first run the embedding model downloads automatically (~40 MB). Subsequent starts are fast.

For other clients (Cursor / Windsurf / npx), see docs/guide/installation.md.


๐Ÿ“š Documentation

Every tool accepts an optional vault parameter. In multi-vault mode, search_notes, query_notes, and get_vault_overview fan out across all registered vaults when vault is omitted.

User guide lives in docs/guide/:

Architecture / internals: docs/architecture/.


Vault-specific conventions for external agents

When the server starts, it looks for <vault>/.neuro-vault/for-external-agents.md. If the file exists, its content is appended to the MCP instructions that clients receive at initialize, under a ## Vault-specific conventions section. Use this file to teach external agents vault-specific rules that cannot be derived from the snapshot โ€” for example, closed sets of frontmatter type values, or folders that are off-limits for writes. The file is optional; without it the server still ships sane defaults plus a pointer to get_vault_overview.


๐Ÿ“„ License

ISC โ€” see LICENSE.

Changelog: Releases

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured