Connect MCP

Connect MCP

An Obsidian plugin that runs an MCP server, enabling AI agents to read, edit, search notes, and run Dataview queries in your vault.

Category
Visit Server

README

Connect MCP

An Obsidian plugin that runs an MCP (Model Context Protocol) server, enabling AI agents like Claude to access your vault - read, edit, search notes, and run Dataview queries.

Architecture

AI Agent (Claude Code/Desktop)
    ↓ (via mcp-remote bridge)
Obsidian Plugin (Express + MCP Server on port 27124)
    ↓
Obsidian Vault

The MCP server runs directly inside the Obsidian plugin - no separate server process needed.

Prerequisites

Installation

Option A: Install via BRAT (Recommended)

  1. Install the BRAT plugin from Community Plugins
  2. Open BRAT settings and click "Add Beta Plugin"
  3. Enter: joch/obsidian-connect-mcp
  4. Enable "Connect MCP" in Community Plugins

Option B: Manual Installation

  1. Build the plugin:

    npm install
    npm run build
    
  2. Copy the plugin files to your Obsidian vault:

    mkdir -p /path/to/vault/.obsidian/plugins/connect-mcp
    cp main.js manifest.json styles.css /path/to/vault/.obsidian/plugins/connect-mcp/
    
  3. In Obsidian, go to Settings → Community plugins → Enable "Connect MCP"

  4. Configure the plugin:

    • Go to Settings → Connect MCP
    • Click "Generate" to create an API Key
    • Optionally change the port (default: 27124)
    • Click "Start Server" or enable auto-start

2. Configure Claude Code/Desktop

Add this to your Claude Code MCP settings:

{
  "mcpServers": {
    "obsidian": {
      "command": "npx",
      "args": [
        "mcp-remote",
        "http://localhost:27124/mcp",
        "--header",
        "Authorization:${AUTH}"
      ],
      "env": {
        "AUTH": "Bearer YOUR_API_KEY"
      }
    }
  }
}

Replace YOUR_API_KEY with the key generated in Obsidian settings.

Available MCP Tools

Vault Tools

Tool Description
vault_list List files and folders in the vault
vault_read Read a note's content and frontmatter
vault_create Create a new note
vault_update Replace entire file content
vault_delete Delete a note (moves to trash)
vault_search Search notes by content

Edit Tools

Tool Description
vault_edit Find and replace text using fuzzy matching
vault_edit_line Insert or replace content at a specific line
vault_patch Edit a specific section: heading, block, or frontmatter

Graph Tools

Tool Description
graph_info Get link statistics for a note
graph_links Get backlinks and forward links for a note

Dataview Tools

Tool Description
dataview_query Execute a Dataview DQL query

Active Tools

Tool Description
active_note Get the currently open note in Obsidian

Command Tools

Tool Description
command_list List available Obsidian commands (filter by plugin name)
command_execute Execute any Obsidian command by ID (Templater, MetaBind, etc.)

Note: Command tools must be enabled in plugin settings ("Allow command execution").

Templater Integration

The command_execute tool can run Templater templates as commands, enabling AI agents to trigger your automation scripts (e.g., "consume wine bottle", "complete project", "mark article as read").

Exposing Templates as Commands

By default, Templater templates are only accessible via the UI modal. To make them available as commands:

  1. Open Obsidian Settings → Templater
  2. Scroll to Template Hotkeys
  3. Click Add new template hotkey for each template you want to expose
  4. Select the template file (e.g., apps/templater/wine/consume.md)
  5. Restart Obsidian to register the new commands

Each template gets two commands:

  • templater-obsidian:path/to/template.md - Run on active file ("Insert")
  • templater-obsidian:create-path/to/template.md - Create new file from template

Example Usage

# List available wine commands
command_list with filter: "wine"

# Execute consume template on active bottle note
command_execute with commandId: "templater-obsidian:apps/templater/wine/consume.md"

Recommended Templates to Expose

Add templates that perform actions on existing notes:

  • Status changes (consume bottle, complete project, mark as read)
  • Property updates (cycle status, change priority)
  • File operations (archive, move to folder)

Templates that require user input (modals, prompts) may not work well via MCP.

MCP Resources

URI Description
obsidian://vault-info Vault name, file counts, plugin status
obsidian://dataview-reference DQL syntax quick reference

MCP Prompts

Prompts let you give AI agents context about your vault that they can discover and use automatically. Create markdown files in the prompts folder (configurable in settings) to help agents understand your vault structure, conventions, and useful queries.

Why Use Prompts?

When an AI agent connects to your vault, it has no idea how you've organized things. Prompts solve this by providing:

  • Vault structure - Describe your folder hierarchy and what goes where
  • Dataview queries - Pre-built DQL queries for common searches in your vault
  • Naming conventions - Explain your file naming patterns and metadata fields
  • Workflows - Document how you use tags, links, or specific note types

Prompt Format

---
description: Brief description the agent sees when listing prompts
---

# My Vault Guide

## Folder Structure
- `projects/` - Active project notes with status frontmatter
- `archive/` - Completed projects
- `daily/` - Daily notes in YYYY-MM-DD format

## Useful Queries

Find incomplete tasks:
\`\`\`dataview
TASK FROM "projects" WHERE !completed
\`\`\`

Recent notes:
\`\`\`dataview
LIST FROM "" WHERE file.mtime > date(today) - dur(7 days) SORT file.mtime DESC
\`\`\`

## Conventions
- Projects use `status` field: active, waiting, done
- People notes are in `people/` with `birthday` and `company` fields

The filename (without .md) becomes the prompt name that agents can request.

Security Features

API Key Authentication

All requests require a valid API key in the Authorization header.

Read-Only Mode

Enable in settings to block all write operations (create, update, delete).

.mcpignore File

Create a .mcpignore file in your vault root to block access to sensitive paths:

# Block private folders
private/
journal/

# Block specific files
secrets.md

Uses gitignore-style patterns.

Example DQL Queries

-- List notes with a tag
LIST FROM #project

-- Table of tasks
TABLE file.name, due, status FROM "Tasks" WHERE !completed

-- Notes modified today
LIST FROM "" WHERE file.mday = date(today)

-- Count notes by folder
TABLE length(rows) as Count FROM "" GROUP BY file.folder

Remote Access (Cloud Agents)

To securely expose your MCP server to AI agents running in the cloud, use Cloudflare Tunnel. This provides HTTPS encryption without opening ports on your firewall.

Setup Cloudflare Tunnel

  1. Install cloudflared:

    # macOS
    brew install cloudflared
    
    # Windows
    winget install Cloudflare.cloudflared
    
    # Linux (Debian/Ubuntu)
    curl -L https://pkg.cloudflare.com/cloudflare-main.gpg | sudo tee /usr/share/keyrings/cloudflare-archive-keyring.gpg
    echo "deb [signed-by=/usr/share/keyrings/cloudflare-archive-keyring.gpg] https://pkg.cloudflare.com/cloudflared $(lsb_release -cs) main" | sudo tee /etc/apt/sources.list.d/cloudflared.list
    sudo apt update && sudo apt install cloudflared
    
  2. Create a quick tunnel (no Cloudflare account needed):

    cloudflared tunnel --url http://localhost:27124
    

    This outputs a URL like https://random-words.trycloudflare.com

  3. Update your Claude Code MCP settings to use the tunnel URL:

    {
      "mcpServers": {
        "obsidian": {
          "command": "npx",
          "args": [
            "mcp-remote",
            "https://random-words.trycloudflare.com/mcp",
            "--header",
            "Authorization:${AUTH}"
          ],
          "env": {
            "AUTH": "Bearer YOUR_API_KEY"
          }
        }
      }
    }
    

Persistent Tunnel (Optional)

For a stable URL, create a named tunnel with a Cloudflare account:

  1. Login to Cloudflare:

    cloudflared tunnel login
    
  2. Create a named tunnel:

    cloudflared tunnel create obsidian-mcp
    
  3. Configure the tunnel (create ~/.cloudflared/config.yml):

    tunnel: obsidian-mcp
    credentials-file: ~/.cloudflared/<tunnel-id>.json
    
    ingress:
      - hostname: obsidian-mcp.yourdomain.com
        service: http://localhost:27124
      - service: http_status:404
    
  4. Add DNS record:

    cloudflared tunnel route dns obsidian-mcp obsidian-mcp.yourdomain.com
    
  5. Run the tunnel:

    cloudflared tunnel run obsidian-mcp
    

Verifying the Setup

# Health check (no auth required)
curl http://localhost:27124/health

# MCP info
curl http://localhost:27124/mcp

# Via tunnel (if using remote access)
curl https://your-tunnel-url.trycloudflare.com/health

Development

npm run dev  # Watch mode

License

MIT

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