obsidian-writer-mcp
MCP server that writes to Obsidian vaults via the obsidian-writer HTTP service. Supports managing inbox entries, lists, notes, and tasks.
README
obsidian-writer-mcp
MCP server for writing to Obsidian through the obsidian-writer HTTP service.
This project was originally created for personal use in my homelab. I later decided to publish it in case it is useful to other people building similar local-first Obsidian automation.
Related project: obsidian-writer, the HTTP service this MCP server calls to write into Obsidian vaults.
Configuration
The server reads environment variables from the process and from .env files. Existing process variables take precedence over .env values.
Load order:
.envnext toobsidian_writer_mcp.py.envin the current working directory
Create a local .env from the example:
cp .env.example .env
Variables:
OBSIDIAN_WRITER_BASE_URL: base URL for the HTTP writer. Default:http://obsidian-writer:3000.OBSIDIAN_DEFAULT_VAULT: default vault used when a tool does not receivevault. Default:default.
Example:
OBSIDIAN_WRITER_BASE_URL=http://obsidian-writer:3000
OBSIDIAN_DEFAULT_VAULT=my-vault
The .env file is ignored by Git; publish .env.example and keep local values private.
Hermes registration
If this repository is mounted inside the Hermes container at /srv/apps/obsidian-writer-mcp, register it without hardcoded vault values; the MCP will read .env itself:
docker exec -it hermes hermes -p <profile> mcp remove obsidian-writer || true
docker exec -it hermes hermes -p <profile> mcp add obsidian-writer \
--command sh \
--args -lc 'exec uv run --with fastmcp --with httpx python /srv/apps/obsidian-writer-mcp/obsidian_writer_mcp.py'
docker exec -it hermes hermes -p <profile> mcp test obsidian-writer
If your obsidian-writer service is not reachable as http://obsidian-writer:3000 from inside Hermes, change OBSIDIAN_WRITER_BASE_URL in .env.
Tools
Inbox
obsidian_append_inbox: append one line to today's inbox file in the configured default vault.obsidian_read_inbox: read inbox items for a specific day. Thedateargument is optional; when omitted,obsidian-writeruses today's date.
Lists
obsidian_list_lists: list existing Obsidian checklist files.obsidian_list_add: add unchecked items to a named list.obsidian_list_remove: remove items from a named list.obsidian_list_update: update/rename items in a named list.
Notes
obsidian_list_notes: list existing notes.obsidian_read_note: read a note by slug.obsidian_create_note: create a new standalone Markdown note.obsidian_append_note: append Markdown content to an existing note.obsidian_create_or_append_note: create a note or append to an existing compatible note.
Tasks
Task creation keeps its existing tool name: obsidian_create_task.
Task listing is available as obsidian_list_tasks and reads structured tasks through GET /tasks.
Creation sends structured JSON to POST /tasks; it does not format Obsidian Tasks Markdown itself. The canonical formatter is the obsidian-writer service.
Supported creation fields include:
vaulttitlecontent(legacy fallback fortitle)status:todo,done,cancelleddue,scheduled,start,done,cancelled: dates asYYYY-MM-DDpriority:highest,high,medium,low,lowest,nonerecurrencetagssourcedue_text(legacy; ignored whendueis provided)depends_on(accepted by the MCP for compatibility, but not sent yet)
Dependencies are reserved for phase 2 if/when obsidian-writer supports them.
Listing supports:
status:todo(default),done,cancelled, oralllimit: optional positive integervault: optional vault override
Examples
Read today's inbox:
obsidian_read_inbox()
Read a specific inbox day:
obsidian_read_inbox(date="2026-06-24")
Create a task using the configured default vault:
obsidian_create_task(
title="Pay electricity bill",
due="2026-06-25",
priority="high",
tags=["home", "bills"],
source="assistant",
)
List pending tasks:
obsidian_list_tasks(status="todo", limit=20)
Create or append a note:
obsidian_create_or_append_note(
title="Project ideas",
content="- Try a simpler publishing flow",
)
Local development
Run the server over stdio:
uv run --with fastmcp --with httpx python obsidian_writer_mcp.py
The process will wait for MCP stdio messages; that is expected.
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.