Obsidian MCP Server
Enables users to search, list, and read notes in an Obsidian vault via a CLI or HTTP API, integrating with Obsidian for note management.
README
Typescript MCP Server with Obsidian Integration
A command-line interface for interacting with your Obsidian vault.
Prerequisites
- Node.js 14.x or later
- npm or yarn
- An Obsidian vault
Setup
- Clone the repository
- Install dependencies:
npm install - Create a
.envfile in the project root with your Obsidian vault path:OBSIDIAN_VAULT_PATH=/path/to/your/obsidian/vault
Development
Starting and Stopping Services
Start All Services
To start the backend, frontend, and health data server simultaneously:
# From the project root directory
npm run dev
This will start:
- Backend server (default: http://localhost:3000)
- Frontend development server (default: http://localhost:5173)
- Health data server (default: http://localhost:8000)
Stop All Services
To stop all running services:
# From the project root directory
npm run stop
Manual Service Management
Backend Server
# Start backend server
cd server
npm run dev
Frontend Development Server
-
Navigate to the client directory:
cd client -
Install dependencies (if not already installed):
npm install -
Start the development server:
npm run dev
The application will be available at http://localhost:5173 by default.
Apple Health Data Server
The application includes a server to serve Apple Health data. Follow these steps to set it up:
- Ensure you have Python 3.8+ installed
- Install the required Python packages:
pip install -r requirements.txt - Start the server:
python server/main.py
The server will start on http://localhost:8000 by default.
API Endpoints
GET /- List all files and directories in the appleHealthData directoryGET /file/{path}- Get file contents or list directory contentsGET /docs- Interactive API documentation (Swagger UI)GET /redoc- Alternative API documentation (ReDoc)
For more details, see APPLE_HEALTH_SERVER.md.
Available Scripts
This project includes several npm scripts to help with development and testing:
Start the Server Application
npm start
Starts the application using ts-node. The server will be available at http://localhost:3000 by default (or the port specified in your environment variables).
Development Mode with Auto-Reload
npm run dev
Starts the application in development mode using nodemon, which automatically restarts the server when you make changes to any TypeScript file in the src directory.
Build the Project
npm run build
Compiles TypeScript files to JavaScript in the dist directory.
Run Tests
npm test
Runs the test suite (currently no tests are configured).
Run CLI Tool
# Run the CLI tool directly
npm run cli [command]
# Examples:
npm run cli list
npm run cli search "query"
npm run cli read "path/to/note.md"
Environment Variables
The application uses the following environment variables:
OBSIDIAN_VAULT_PATH: Path to your Obsidian vault (required)PORT: Port number for the server (default: 3000)
Create a .env file in the project root to set these variables:
OBSIDIAN_VAULT_PATH=/path/to/your/obsidian/vault
PORT=3000
Project Structure
src/- Source codetools/- MCP tool implementationsobsidian.ts- Obsidian vault integration
index.ts- Main application entry pointrouter.ts- API route definitionstypes.ts- TypeScript type definitions
dist/- Compiled JavaScript (created when runningnpm run build)test-obsidian.ts- Test script for Obsidian toolsrc/cli.ts- Command-line interface
CLI Usage
Getting Started
After setting up your environment, you can use the CLI tool to interact with your Obsidian vault. The tool provides three main commands: search, list, and read.
Search for Notes
Search for notes containing specific text:
# Basic search
npm run cli search "search query"
# Limit the number of results (default: 5)
npm run cli search "search query" -- --limit 10
# Example: Search for notes about "project management"
npm run cli search "project management"
Example output:
Searching for "project management" (max 5 results)...
1. Project Management Best Practices
Path: 01_Projects/Project Management Best Practices.md
Modified: 5/25/2025, 2:30:45 PM
Size: 12 KB
Project management is the practice of...
2. Team Meeting Notes
Path: 02_Meetings/Team Meeting Notes.md
Modified: 5/26/2025, 10:15:22 AM
Size: 8 KB
Discussed project management tools and...
List Notes in a Directory
List all notes in a specific directory:
# List notes in the root directory
npm run cli list
# List notes in a specific directory
npm run cli list "00_Slipbox"
# Limit the number of results (default: 10)
npm run cli list "00_Slipbox" -- --limit 5
# Example: List all notes in the "Projects" directory
npm run cli list "01_Projects"
Example output:
Listing notes in "01_Projects" (max 10 results)...
Directory: 01_Projects
Total files: 15
1. Project Alpha
Path: 01_Projects/Project Alpha.md
Modified: 5/20/2025, 3:45:12 PM
Size: 5 KB
2. Project Beta
Path: 01_Projects/Project Beta.md
Modified: 5/22/2025, 9:15:33 AM
Size: 3 KB
Read a Specific Note
View the content of a specific note:
# Read a note by its path relative to your vault root
npm run cli read "00_Slipbox/MyNote.md"
# Example: Read a note from a subdirectory
npm run cli read "01_Projects/Project Alpha/Meeting Notes.md"
Example output:
Reading note: 00_Slipbox/MyNote.md
My Note Title
Path: 00_Slipbox/MyNote.md
Modified: 5/26/2025, 11:00:00 AM
Size: 2 KB
--- CONTENT ---
# My Note
This is the content of my note...
- List item 1
- List item 2
- List item 3
--- END OF CONTENT ---
Global Installation (Optional)
For easier access, you can install the CLI globally:
# From the project directory
npm link
# Now you can use it from anywhere
obsidian-cli list
obsidian-cli search "query"
obsidian-cli read "path/to/note.md"
API Endpoints
If you prefer to use the HTTP API directly:
Search for notes
curl -X POST http://localhost:3000/api/tools/obsidian/search \
-H "Content-Type: application/json" \
-d '{"query": "project", "limit": 5}'
List notes in a directory
curl -X POST http://localhost:3000/api/tools/obsidian/list \
-H "Content-Type: application/json" \
-d '{"directory": "00_Slipbox", "limit": 10}'
Read a specific note
curl -X POST http://localhost:3000/api/tools/obsidian/read \
-H "Content-Type: application/json" \
-d '{"filePath": "00_Slipbox/SomeNote.md"}'
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.