Another bloated Obsidian MCP Server
A Model Context Protocol (MCP) server that provides AI assistants with secure access to Obsidian vaults. Enables reading, writing, searching, and managing notes without requiring Obsidian to be running.
README
Another bloated Obsidian MCP Server
[!CAUTION] 🔴🔴🔴 EXPERIMENTAL PROJECT - DO NOT USE IN PRODUCTION 🔴🔴🔴
This is an experimental project created primarily through AI-assisted development using Claude Code, with minimal human intervention. It is intended solely for testing and learning purposes.
This project should NOT be used for:
- Production environments
- Critical data or important vaults
- Any scenario where data integrity is essential
Use at your own risk. The code may contain bugs, security vulnerabilities, or unexpected behaviors.
Support notice: This project will likely not receive attention for bugs or issues reported by third parties. If you're interested in contributing or reporting issues, you may not get a response as this project may not be maintained long-term. However, this could change after the experimentation phase.
A Model Context Protocol (MCP) server that provides AI assistants with secure access to Obsidian vaults. Enables reading, writing, searching, and managing notes without requiring Obsidian to be running.
Features
- Direct filesystem access - Works without Obsidian running
- Multi-vault support - Manage multiple vaults simultaneously
- Configurable tool groups - Enable only the features you need
- Full CRUD operations - Create, read, update, delete notes
- YAML frontmatter - Parse and manipulate note metadata
- Tag management - Add, remove, and search by tags
- Link analysis - Backlinks, outlinks, orphans, broken links, link graph
- Daily notes - Create and manage daily journal entries
- Templates - Apply templates with variable substitution
- Obsidian Bases - Query dynamic note views based on filters
- Batch operations - Process multiple notes efficiently
- Attachment tracking - List and find unused attachments
- Backup system - Create and restore note backups
- Security-first - Path traversal protection, symlink escape prevention
Requirements
- Node.js 18+
- npm or yarn
Installation
# Clone the repository
git clone https://github.com/yourusername/obsidian-mcp-server.git
cd obsidian-mcp-server
# Install dependencies
npm install
# or
yarn install
# Build (optional - can run directly with tsx)
npm run build
Quick Start
# Start the server with a vault
npm start /path/to/your/vault
# With specific tool groups
npm start /path/to/your/vault --tools=vault,notes,search
# With a custom vault name
npm start /path/to/your/vault my-vault
Configuration
Option 1: Claude Code CLI (Recommended)
# Add the MCP server
claude mcp add obsidian \
--transport stdio \
--scope user \
-- npx tsx /path/to/obsidian-mcp-server/src/index.ts /path/to/vault
# With specific tool groups
claude mcp add obsidian \
--transport stdio \
--scope user \
-- npx tsx /path/to/obsidian-mcp-server/src/index.ts /path/to/vault --tools=vault,notes,search
Scope options:
user- Available in all projects (saved in~/.claude.json)local- Current project onlyproject- Shared with team (saved in.mcp.json)
Useful commands:
claude mcp list # List configured servers
claude mcp get obsidian # View server details
claude mcp remove obsidian # Remove server
Option 2: Manual Configuration
Edit ~/.claude.json:
{
"mcpServers": {
"obsidian": {
"type": "stdio",
"command": "npx",
"args": [
"tsx",
"/path/to/obsidian-mcp-server/src/index.ts",
"/path/to/your/vault",
"--tools=vault,notes,search"
]
}
}
}
Option 3: Claude Desktop App
Edit the config file at ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"obsidian": {
"command": "npx",
"args": [
"tsx",
"/path/to/obsidian-mcp-server/src/index.ts",
"/path/to/your/vault",
"--tools=vault,notes,search"
]
}
}
}
Tool Groups
| Group | Tools | Description |
|---|---|---|
vault |
list_vaults, set_active_vault, register_vault | Vault management |
notes |
list_notes, read_note, create_note, update_note, delete_note, rename_note, move_note | Note CRUD operations |
search |
search_vault | Full-text search |
frontmatter |
get_frontmatter, update_frontmatter, remove_frontmatter_field, add_to_array_field, remove_from_array_field | YAML metadata |
tags |
list_tags, add_tag, remove_tag, search_by_tag | Tag management |
links |
get_outlinks, get_backlinks, find_orphans, find_broken_links, get_link_graph | Link analysis |
daily |
get_daily_note, create_daily_note, list_daily_notes, append_to_daily | Daily notes |
templates |
list_templates, get_template, apply_template, create_from_template | Template system |
bases |
list_bases, get_base, query_base | Obsidian Bases |
batch |
batch_move, batch_delete, batch_update_frontmatter, batch_add_tag, batch_remove_tag, batch_read_notes | Batch operations |
attachments |
list_attachments, get_attachment_info, find_unused_attachments, get_attachments_in_note | Attachment management |
backup |
create_note_backup, list_backups, restore_backup, delete_old_backups | Backup system |
Special values:
all- Enable all tool groups (default)none- Disable all tools (for testing)
Configuration Examples
Read-Only Access
--tools=vault,notes,search
Safe for exploration without modifying notes.
Daily Productivity
--tools=vault,notes,search,daily,tags
Quick capture, daily notes, and tag organization.
Knowledge Analysis
--tools=vault,notes,search,links,tags
Explore connections, find orphans, analyze the knowledge graph.
Content Creation
--tools=vault,notes,search,templates,frontmatter
Create notes from templates, manage metadata.
Full Access
--tools=all
All features enabled.
Multi-Vault Setup
Create ~/.obsidian-mcp/config.json:
{
"vaults": {
"personal": "/Users/you/Obsidian/Personal",
"work": "/Users/you/Obsidian/Work",
"research": "/Users/you/Obsidian/Research"
},
"defaultVault": "personal"
}
Switch between vaults using set_active_vault tool.
Environment Variables
| Variable | Description |
|---|---|
OBSIDIAN_MCP_TOOLS |
Comma-separated list of tool groups |
LOG_LEVEL |
Logging level: debug, info, warn, error |
CLI Reference
# Show help
npm start -- --help
# Start with vault
npm start /path/to/vault [vault-name] [--tools=groups]
# Examples
npm start /path/to/vault # All tools
npm start /path/to/vault my-vault # With custom name
npm start /path/to/vault --tools=vault,notes # Specific groups
Troubleshooting
Server doesn't connect
- Verify the vault path exists and is absolute
- Check Node.js version:
node --version(requires 18+) - Test manually:
npm start /path/to/vault - For Claude Code: use
/mcpto check status and errors - For Claude Desktop: check logs in
~/Library/Logs/Claude/mcp*.log
"Tool X is not enabled" error
The tool you're trying to use is not in your enabled groups. Check your --tools configuration and add the required group.
Permission errors
Ensure the user running the MCP server has read/write access to the vault directory.
Path not found
- Use absolute paths, not relative
- Ensure the vault contains a
.obsidianfolder - Check for typos in the path
Development
# Development mode (auto-reload)
npm run dev
# Build
npm run build
# Type check
npx tsc --noEmit
# Run tests
npm test
# Run tests with coverage
npm run test:coverage
Documentation
- API Reference - Complete tool documentation
- Architecture - System design
- Configuration - All configuration options
- Security - Security model
- Error Codes - Error reference
- Contributing - Development guide
Security
This server implements multiple security measures:
- Path validation - Prevents path traversal attacks
- Symlink protection - Blocks symlink escape attempts
- Input validation - All inputs validated with Zod schemas
- Reserved name blocking - Prevents system file conflicts
See SECURITY.md for details.
Inspiration
This project is inspired by mcp-obsidian.
License
MIT
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.