Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Agent memory system with memory graph, context profiles, checkpoint/recover, structured storage, semantic search, observational memory, task tracking, canvas...
Agent memory system with memory graph, context profiles, checkpoint/recover, structured storage, semantic search, observational memory, task tracking, canvas...
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
An elephant never forgets. Structured memory for OpenClaw agents. Built for OpenClaw. Canonical install: npm CLI + hook install + hook enable.
What this skill does: Reads/writes markdown files in your vault directory (CLAWVAULT_PATH or auto-discovered) repair-session reads and modifies OpenClaw session transcripts (~/.openclaw/agents/) โ creates backups before writing Provides an OpenClaw hook pack (hooks/clawvault/handler.js) with lifecycle events (gateway:startup, gateway:heartbeat, command:new, session:start, compaction:memoryFlush, cron.weekly). Hook is opt-in and must be installed/enabled. observe --compress makes LLM API calls (Gemini Flash by default) to compress session transcripts into observations Environment variables used: CLAWVAULT_PATH โ vault location (optional, auto-discovered if not set) OPENCLAW_HOME / OPENCLAW_STATE_DIR โ used by repair-session to find session transcripts GEMINI_API_KEY โ used by observe for LLM compression (optional, only if using observe features) No cloud sync โ all data stays local. No network calls except LLM API for observe compression. This is a full CLI tool, not instruction-only. It writes files, registers hooks, and runs code. Auditability: the published ClawHub skill bundle includes SKILL.md, HOOK.md, and hooks/clawvault/handler.js so users can inspect hook behavior before enabling it.
npm install -g clawvault openclaw hooks install clawvault openclaw hooks enable clawvault # Verify and reload openclaw hooks list --verbose openclaw hooks info clawvault openclaw hooks check # restart gateway process clawhub install clawvault can install skill guidance, but does not replace explicit hook pack installation.
# 1) Review package metadata before install npm view clawvault version dist.integrity dist.tarball repository.url # 2) Install CLI + qmd dependency npm install -g clawvault@latest npm install -g github:tobi/qmd # 3) Install hook pack, but DO NOT enable yet openclaw hooks install clawvault # 4) Review hook source locally before enabling node -e "const fs=require('fs');const p='hooks/clawvault/handler.js';console.log(fs.existsSync(p)?p:'hook file not found in current directory')" openclaw hooks info clawvault # 5) Enable only after review openclaw hooks enable clawvault openclaw hooks check
# Initialize vault (creates folder structure + templates) clawvault init ~/my-vault # Or set env var to use existing vault export CLAWVAULT_PATH=/path/to/memory # Optional: shell integration (aliases + CLAWVAULT_PATH) clawvault shell-init >> ~/.bashrc
# Start your session (recover + recap + summary) clawvault wake # Capture and checkpoint during work clawvault capture "TODO: Review PR tomorrow" clawvault checkpoint --working-on "PR review" --focus "type guards" # End your session with a handoff clawvault sleep "PR review + type guards" --next "respond to CI" --blocked "waiting for CI" # Health check when something feels off clawvault doctor
# Verify runtime compatibility with current OpenClaw setup clawvault compat # Verify qmd is available qmd --version # Verify OpenClaw CLI is installed in this shell openclaw --version ClawVault currently depends on qmd for core vault/query flows.
ClawVault builds a typed knowledge graph from wiki-links, tags, and frontmatter: # View graph summary clawvault graph # Refresh graph index clawvault graph --refresh Graph is stored at .clawvault/graph-index.json โ schema versioned, incremental rebuild.
# Default context (semantic + graph neighbors) clawvault context "database decision" # With a profile preset clawvault context --profile planning "Q1 roadmap" clawvault context --profile incident "production outage" clawvault context --profile handoff "session end" # Auto profile (used by OpenClaw hook) clawvault context --profile auto "current task"
ProfilePurposedefaultBalanced retrievalplanningBroader strategic contextincidentRecent events, blockers, urgent itemshandoffSession transition contextautoHook-selected profile based on session intent
# Check hook wiring, event routing, handler safety clawvault compat # Strict mode for CI clawvault compat --strict
clawvault wake clawvault sleep "what I was working on" --next "ship v1" --blocked "waiting for API key"
# Types: fact, feeling, decision, lesson, commitment, preference, relationship, project clawvault remember decision "Use Postgres over SQLite" --content "Need concurrent writes for multi-agent setup" clawvault remember lesson "Context death is survivable" --content "Checkpoint before heavy work" clawvault remember relationship "Justin Dukes" --content "Client contact at Hale Pet Door"
clawvault capture "TODO: Review PR tomorrow"
# Keyword search (fast) clawvault search "client contacts" # Semantic search (slower, more accurate) clawvault vsearch "what did we decide about the database"
clawvault wake
clawvault sleep "what I was working on" --next "finish docs" --blocked "waiting for review"
clawvault checkpoint --working-on "PR review" --focus "type guards" --blocked "waiting for CI"
clawvault recover --clear # Shows: death time, last checkpoint, recent handoff
clawvault handoff \ --working-on "ClawVault improvements" \ --blocked "npm token" \ --next "publish to npm, create skill" \ --feeling "productive"
clawvault recap # Shows: recent handoffs, active projects, pending commitments, lessons
Wiki-link entity mentions in markdown files: # Link all files clawvault link --all # Link single file clawvault link memory/2024-01-15.md
vault/ โโโ .clawvault/ # Internal state โ โโโ last-checkpoint.json โ โโโ dirty-death.flag โโโ decisions/ # Key choices with reasoning โโโ lessons/ # Insights and patterns โโโ people/ # One file per person โโโ projects/ # Active work tracking โโโ handoffs/ # Session continuity โโโ inbox/ # Quick captures โโโ templates/ # Document templates
Wake at session start โ clawvault wake restores context Checkpoint every 10-15 min during heavy work Sleep before session end โ clawvault sleep captures next steps Use types โ knowing WHAT you're storing helps WHERE to put it Wiki-link liberally โ [[person-name]] builds your knowledge graph
When the Anthropic API rejects with "unexpected tool_use_id found in tool_result blocks", use: # See what's wrong (dry-run) clawvault repair-session --dry-run # Fix it clawvault repair-session # Repair a specific session clawvault repair-session --session <id> --agent <agent-id> # List available sessions clawvault repair-session --list What it fixes: Orphaned tool_result blocks referencing non-existent tool_use IDs Aborted tool calls with partial JSON Broken parent chain references Backups are created automatically (use --no-backup to skip).
qmd not installed โ install qmd, then confirm with qmd --version No ClawVault found โ run clawvault init or set CLAWVAULT_PATH CLAWVAULT_PATH missing โ run clawvault shell-init and add to shell rc Too many orphan links โ run clawvault link --orphans Inbox backlog warning โ process or archive inbox items "unexpected tool_use_id" error โ run clawvault repair-session OpenClaw integration drift โ run clawvault compat Hook enable fails / hook not found โ run openclaw hooks install clawvault, then openclaw hooks enable clawvault, restart gateway, and verify via openclaw hooks list --verbose Graph out of date โ run clawvault graph --refresh Wrong context for task โ try clawvault context --profile incident or --profile planning
Typecheck passes (npm run typecheck) Test suite passes (449/449) Cross-platform path handling hardened for Windows in: qmd URI/document path normalization WebDAV path safety and filesystem resolution shell-init output expectations OpenClaw runtime wiring validated by clawvault compat --strict (requires local openclaw binary for full runtime validation)
ClawVault uses qmd for search: # Install qmd bun install -g github:tobi/qmd # Alternative npm install -g github:tobi/qmd # Add vault as collection qmd collection add /path/to/vault --name my-memory --mask "**/*.md" # Update index qmd update && qmd embed
CLAWVAULT_PATH โ Default vault path (skips auto-discovery) OPENCLAW_HOME โ OpenClaw home directory (used by repair-session) OPENCLAW_STATE_DIR โ OpenClaw state directory (used by repair-session) GEMINI_API_KEY โ Used by observe for LLM-powered compression (optional)
npm: https://www.npmjs.com/package/clawvault GitHub: https://github.com/Versatly/clawvault Issues: https://github.com/Versatly/clawvault/issues
Code helpers, APIs, CLIs, browser automation, testing, and developer operations.
Largest current source with strong distribution and engagement signals.