obsidian-writer-mcp
Provides tools for interacting with Obsidian vaults, including creating and appending notes, managing lists, handling tasks (create, list), and sending content to an inbox, via the obsidian-writer HTTP service.
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., "@obsidian-writer-mcpcreate a task for dentist appointment tomorrow high priority"
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.
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 .envVariables:
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-vaultThe .env file is ignored by Git; publish .env.example and keep local values private.
Related MCP server: Obsidian MCP Tool Server
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-writerIf 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.
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
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.pyThe process will wait for MCP stdio messages; that is expected.
This server cannot be installed
Maintenance
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/ariedotme/obsidian-writer-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server