Install
openclaw skills install obsidian-curatorManage Obsidian vaults via LiveSync CouchDB — capture notes, AI-enrich and file them, manage tasks, audit and tidy vault structure. Use when working with Obsidian vaults through CouchDB/LiveSync (not local filesystem). Requires CouchDB with Obsidian LiveSync plugin. AI features (process, file) need an AI provider configured; capture, audit, tidy, and tasks work rule-based without any API key.
openclaw skills install obsidian-curatorManage Obsidian vaults through the CouchDB database that powers Obsidian LiveSync. Capture, process, file, audit, tidy, and manage tasks — all via CLI or Node.js API.
Prerequisites: CouchDB with LiveSync configured, E2EE disabled.
preinstall, install, or postinstall scripts — npm install only copies filesnano (CouchDB client) and date-fns (date parsing)~/.obsidian-curator/config.json — never transmitted except to your own CouchDBRun the interactive wizard — it tests the CouchDB connection live:
obsidian-curator init
Configures: CouchDB connection, vault structure preset (PARA/Zettelkasten/Johnny Decimal/Flat/Custom), AI provider (OpenAI/Anthropic/Ollama/None), task projects.
Config location: ~/.obsidian-curator/config.json
obsidian-curator capture "Quick thought about project X"
obsidian-curator capture "Meeting notes from standup" --source meeting
Enrich inbox notes with tags, summary, and suggested folder:
obsidian-curator process
obsidian-curator process --limit 5 --dry-run
obsidian-curator process --force # re-process already-processed notes
Route processed notes to canonical vault folders:
obsidian-curator file
obsidian-curator file --dry-run --min-confidence 0.8
Check vault structure against configured canonical folders:
obsidian-curator audit
Find duplicates, structure violations, dead notes. With AI, ambiguous cases are triaged automatically:
obsidian-curator tidy --dry-run
obsidian-curator tidy --checks dupes,stubs
obsidian-curator tasks # list open tasks
obsidian-curator tasks --project Work --priority high
obsidian-curator task "call dentist next Tuesday" # create task (parses dates, priority, project)
obsidian-curator done "dentist" # mark done by partial title match
obsidian-curator config show
obsidian-curator config set ai.provider ollama
obsidian-curator config set vault.host 192.168.1.100
const { VaultClient, Curator, createAIAdapter, loadConfig } = require('obsidian-curator');
const config = loadConfig();
const vault = new VaultClient(config.vault);
await vault.ping();
const ai = createAIAdapter(config);
const curator = new Curator({ vault, ai, config });
await curator.capture('Quick thought');
await curator.process({ limit: 5 });
await curator.file({ dryRun: true });
await curator.audit();
await curator.tidy({ checks: ['dupes', 'stubs'], dryRun: true });
const tasks = await curator.tasks({ status: 'open', project: 'Work' });
await curator.createTask('call Alice next Friday');
await curator.taskBrief(); // markdown summary
| Provider | Cost | Privacy | Setup |
|---|---|---|---|
none | Free | Local | Default — rule-based features only |
ollama | Free | Local | config set ai.provider ollama + model name |
openai | Pay-per-use | Cloud | config set ai.provider openai + API key |
anthropic | Pay-per-use | Cloud | config set ai.provider anthropic + API key |
| Custom/OpenRouter | Varies | Varies | Use openai provider with custom baseUrl |