Another bloated Obsidian MCP Server
Provides AI assistants with secure access to Obsidian vaults, enabling reading, writing, searching, and managing notes, including YAML frontmatter, tags, links, daily notes, templates, batch operations, attachments, and backups.
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., "@Another bloated Obsidian MCP Serversearch my vault for 'project ideas'"
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.
Another bloated Obsidian MCP Server
🔴🔴🔴 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 buildQuick 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-vaultConfiguration
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,searchScope 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 serverOption 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 |
| list_vaults, set_active_vault, register_vault | Vault management |
| list_notes, read_note, create_note, update_note, delete_note, rename_note, move_note | Note CRUD operations |
| search_vault | Full-text search |
| get_frontmatter, update_frontmatter, remove_frontmatter_field, add_to_array_field, remove_from_array_field | YAML metadata |
| list_tags, add_tag, remove_tag, search_by_tag | Tag management |
| get_outlinks, get_backlinks, find_orphans, find_broken_links, get_link_graph | Link analysis |
| get_daily_note, create_daily_note, list_daily_notes, append_to_daily | Daily notes |
| list_templates, get_template, apply_template, create_from_template | Template system |
| list_bases, get_base, query_base | Obsidian Bases |
| batch_move, batch_delete, batch_update_frontmatter, batch_add_tag, batch_remove_tag, batch_read_notes | Batch operations |
| list_attachments, get_attachment_info, find_unused_attachments, get_attachments_in_note | Attachment management |
| 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,searchSafe for exploration without modifying notes.
Daily Productivity
--tools=vault,notes,search,daily,tagsQuick capture, daily notes, and tag organization.
Knowledge Analysis
--tools=vault,notes,search,links,tagsExplore connections, find orphans, analyze the knowledge graph.
Content Creation
--tools=vault,notes,search,templates,frontmatterCreate notes from templates, manage metadata.
Full Access
--tools=allAll 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 |
| Comma-separated list of tool groups |
| 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 groupsTroubleshooting
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/vaultFor Claude Code: use
/mcpto check status and errorsFor 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
.obsidianfolderCheck 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:coverageDocumentation
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
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/diegorv/another-bloated-obsidian-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server