9 releases (5 breaking)
| 0.6.0 | Apr 12, 2026 |
|---|---|
| 0.5.0 | Mar 24, 2026 |
| 0.4.0 | Mar 22, 2026 |
| 0.3.0 | Mar 21, 2026 |
| 0.1.0 | Feb 18, 2026 |
#2673 in Command line utilities
195KB
4.5K
SLoC
outline-mcp
Tree-structured knowledge base as an MCP server.
LLM sessions are ephemeral. outline-mcp gives them a persistent, editable knowledge tree — sections and content nodes that can be browsed (toc), annotated with properties, and evolved across sessions. Nodes with inject=true are automatically included in session context.
Quick Start
cargo install --path .
Claude Code (~/.claude.json)
{
"mcpServers": {
"outline": {
"command": "outline-mcp",
"args": ["/path/to/your-book.json"]
}
}
}
If the path argument is omitted, defaults to outline-book.json in the current directory.
Workflow
shelf → select_book → toc → node_create / node_update / node_move
node_batch_move / node_batch_update / node_query
checklist / import / init / gen_routing
snapshot_create / snapshot_list / snapshot_restore
node_history / dump
init— Create a new empty booknode_create— Add sections and content nodes (with optionalproperties)toc— View the table of contents with numbered IDs (e.g.1,2-3). Supportsfilterby propertiesselect_book— Select a book. Nodes withinject=trueproperty have their body auto-appended (draft nodes excluded)checklist— Export a section (or the whole book) as a Markdown checklist with checkboxesnode_update— Edit title, body, type, placeholder, properties, or status (active/draft) of a nodenode_move— Relocate or delete nodes (with descendants)node_batch_move— Move or delete multiple nodes in a single atomic call (requires UUID or UUID-prefix IDs)node_batch_update— Update title/body/type/properties/status on multiple nodes atomicallynode_query— Search nodes by property values, status (active/draft), or type (section/content); optionally include body in resultsimport— Import a book from a previously exported JSON filegen_routing— Generate a Markdown routing table from nodes withroutingproperty across all bookssnapshot_create/snapshot_list/snapshot_restore— Full book versioning (create, list, restore)node_history— View per-node change log with before/after diffsdump— Export full book as JSON file
Node IDs
toc assigns human-friendly numbered IDs:
1. Coding Standards
1-1. Naming Conventions
1-2. Error Handling
2. Testing
2-1. Unit Tests
2-2. Integration Tests
These IDs (1, 1-2, 2-1, etc.) work in most tools. Full UUIDs and title substring matching are also supported as fallbacks.
Note:
node_batch_moveandnode_batch_updaterequire UUID or UUID-prefix IDs. Hierarchical toc IDs are intentionally rejected to prevent positional drift when the tree is modified mid-batch.
Node Properties
Nodes can have key-value properties for metadata:
node_create title="My Rule" properties={"inject": "true", "scope": "rust"}
inject=true— Node body is automatically included inselect_bookoutput (context injection)routing=<scene>— Marks the node forgen_routingoutput. Use|to assign multiple scenes (e.g.routing="testing|TDD")routing_ref=<text>— Overrides the default§ID Titlereference in the routing table (e.g.routing_ref="select_book で全体参照")- Properties with value
"true"appear as tags intoc:1. My Rule [inject] tocsupports filtering:filter={"inject": "true"}shows only matching nodes- Properties are preserved in JSON export/import
Architecture
src/
├── domain/ # Core model (TemplateBook, TemplateNode, NodeId)
│ ├── model/ # Aggregate root + value objects
│ ├── error.rs # Domain errors
│ └── repository.rs # BookRepository trait
├── application/ # Use cases
│ ├── service.rs # BookService (CRUD)
│ └── eject.rs # EjectService (Markdown/JSON export & import)
├── infra/ # Persistence
│ └── json_store.rs # JSON file repository (atomic write)
└── interface/ # Transport
└── mcp.rs # MCP server (rmcp, stdio)
Export Formats
Markdown (default)
# My Runbook
## Design
- [ ] Define requirements
> requirements list: ___
- [ ] API design
REST endpoints
JSON
Tree-structured format that can be re-imported:
{
"title": "My Runbook",
"max_depth": 4,
"nodes": [
{
"title": "Design",
"node_type": "section",
"children": [...]
}
]
}
License
Licensed under either of
at your option.
Dependencies
~10–15MB
~192K SLoC