Install
openclaw skills install total-recallClawHub Security found sensitive or high-impact capabilities. Review the scan results before using.
The only memory skill that watches on its own. No database. No vectors. No manual saves. Just an LLM observer that compresses your conversations into prioritised notes, consolidates when they grow, and recovers anything missed. Five layers of redundancy, zero maintenance. ~$0.10/month. While other memory skills ask you to remember to remember, this one just pays attention.
openclaw skills install total-recallThe only memory skill that watches on its own.
No database. No vectors. No manual saves. Just an LLM observer that compresses your conversations into prioritised notes, consolidates when they grow, and recovers anything missed. Five layers of redundancy, zero maintenance. ~$0.10/month.
While other memory skills ask you to remember to remember, this one just pays attention.
Layer 1: Observer (cron, every 15-30 min)
↓ compresses recent messages → observations.md
Layer 2: Reflector (auto-triggered when observations > 8000 words)
↓ consolidates, removes superseded info → 40-60% reduction
Layer 3: Session Recovery (runs on every /new or /reset)
↓ catches any session the Observer missed
Layer 4: Reactive Watcher (inotify daemon, Linux only)
↓ triggers Observer after 40+ new JSONL writes, 5-min cooldown
Layer 5: Pre-compaction hook (memoryFlush)
↓ emergency capture before OpenClaw compacts context
observations.md with priority levels (high, medium, low)clawdhub install total-recall
Add to your .env or OpenClaw config:
OPENROUTER_API_KEY=sk-or-v1-xxxxx
bash skills/total-recall/scripts/setup.sh
This will:
memory/, logs/, backups)Add to your agent's workspace context (e.g., MEMORY.md or system prompt):
At session startup, read `memory/observations.md` for cross-session context.
Or use OpenClaw's memoryFlush.systemPrompt to inject a startup instruction.
| Platform | Observer + Reflector + Recovery | Reactive Watcher |
|---|---|---|
| Linux (Debian/Ubuntu/etc.) | Full support | With inotify-tools |
| macOS | Full support | Not available (cron-only) |
All core scripts use portable bash. stat, date, and md5 commands are handled cross-platform via _compat.sh.
All scripts read from environment variables with sensible defaults:
| Variable | Default | Description |
|---|---|---|
OPENROUTER_API_KEY | (required) | OpenRouter API key for LLM calls |
MEMORY_DIR | $OPENCLAW_WORKSPACE/memory | Where observations.md lives |
SESSIONS_DIR | ~/.openclaw/agents/main/sessions | OpenClaw session transcripts |
OBSERVER_MODEL | deepseek/deepseek-v3.2 | Primary model for compression |
OBSERVER_FALLBACK_MODEL | google/gemini-2.5-flash | Fallback if primary fails |
OBSERVER_LOOKBACK_MIN | 15 | Minutes to look back (daytime) |
OBSERVER_MORNING_LOOKBACK_MIN | 480 | Minutes to look back (before 8am) |
OBSERVER_LINE_THRESHOLD | 40 | Lines before reactive trigger (Linux) |
OBSERVER_COOLDOWN_SECS | 300 | Cooldown between reactive triggers (Linux) |
REFLECTOR_WORD_THRESHOLD | 8000 | Words before reflector runs |
OPENCLAW_WORKSPACE | ~/your-workspace | Workspace root |
Total Recall uses any OpenAI-compatible chat completion API. Switch providers by setting environment variables:
| Variable | Default | Description |
|---|---|---|
LLM_BASE_URL | https://openrouter.ai/api/v1 | API endpoint |
LLM_API_KEY | falls back to OPENROUTER_API_KEY | API key |
LLM_MODEL | deepseek/deepseek-v3.2 | Model to use |
# OpenRouter (default)
export OPENROUTER_API_KEY="your-key"
# Ollama (local)
export LLM_BASE_URL="http://localhost:11434/v1"
export LLM_API_KEY="ollama"
export LLM_MODEL="llama3.1:8b"
# Groq
export LLM_BASE_URL="https://api.groq.com/openai/v1"
export LLM_API_KEY="your-groq-key"
export LLM_MODEL="llama-3.3-70b-versatile"
memory/
observations.md # The main observation log (loaded at startup)
observation-backups/ # Reflector backups (last 10 kept)
.observer-last-run # Timestamp of last observer run
.observer-last-hash # Dedup hash of last processed messages
logs/
observer.log
reflector.log
session-recovery.log
observer-watcher.log
The setup script creates these OpenClaw cron jobs:
| Job | Schedule | Description |
|---|---|---|
memory-observer | Every 15 min | Compress recent conversation |
memory-reflector | Hourly | Consolidate if observations are large |
The reactive watcher uses inotifywait to detect session activity and trigger the observer faster than cron alone. Requires Linux with inotify-tools installed.
# Install inotify-tools (Debian/Ubuntu)
sudo apt install inotify-tools
# Check watcher status
systemctl --user status total-recall-watcher
# View logs
journalctl --user -u total-recall-watcher -f
Using DeepSeek v3.2 via OpenRouter:
observations.md/new or /resetinotifywait to monitor session directoryThe observer and reflector system prompts are in prompts/:
prompts/observer-system.txt — controls how conversations are compressedprompts/reflector-system.txt — controls how observations are consolidatedEdit these to match your agent's personality and priorities.
The Dream Cycle is an optional nightly agent that runs after hours to consolidate observations.md. It archives stale items and adds semantic hooks so nothing useful is actually lost. Context stays lean; everything remains findable.
Multi-Hook Retrieval — 4-5 alternative search phrasings per archived item. Searches using different words than the original still find the memory.
Confidence Scoring — every observation gets a confidence score (0.0-1.0) and source type (explicit, implicit, inference, weak, uncertain). High-confidence items are preserved longer; low-confidence items are archived sooner.
Memory Type System — 7 types with per-type TTLs: event (14d), fact (90d), preference (180d), goal (365d), habit (365d), rule (never), context (30d). Embedded as invisible HTML metadata comments in observations.md.
Observation Chunking — clusters of 3+ related observations are compressed into single summary entries. Source observations are archived; a chunk hook replaces them. Achieves up to 75% token reduction.
Importance Decay — per-type daily decay applied to importance scores before each archival decision. Items that decay below the archive threshold are queued for removal. Rates: event (-0.5/day), fact (-0.1/day), preference (-0.02/day), rule/habit/goal (no decay).
Pattern Promotion — scans recent dream logs for recurring themes (3+ occurrences across 3+ separate days). Writes promotion proposals to memory/dream-staging/ for human review. Use staging-review.sh to list, show, approve, or reject proposals. The context type is never promoted automatically.
Run bash skills/total-recall/scripts/setup.sh — creates Dream Cycle directories automatically.
Add the nightly cron job:
# Dream Cycle — nightly at 3am
0 3 * * * OPENCLAW_WORKSPACE=~/your-workspace bash ~/your-workspace/skills/total-recall/scripts/dream-cycle.sh preflight
Configure your cron agent using prompts/dream-cycle-prompt.md as the system prompt. Recommended models: Claude Sonnet for the Dreamer (analysis + decisions), DeepSeek v3.2 for the Observer (cheap, fast).
Start with READ_ONLY_MODE=true for the first few nights. Check memory/dream-logs/ after each run to verify what it would have archived.
Switch to READ_ONLY_MODE=false once satisfied.
| Variable | Default | Description |
|---|---|---|
DREAM_TOKEN_TARGET | 8000 | Token target for observations.md after consolidation |
READ_ONLY_MODE | false | Set true for dry-run analysis without writes |
| File | Description |
|---|---|
scripts/dream-cycle.sh | Shell helper: preflight, archive, update-observations, write-log, write-metrics, validate, rollback |
prompts/dream-cycle-prompt.md | Agent prompt for the nightly Dream Cycle run |
dream-cycle/README.md | Dream Cycle quick reference |
schemas/observation-format.md | Extended observation metadata format |
memory/
archive/
observations/ # Archived items (one .md file per night)
chunks/ # Chunked observation groups
dream-logs/ # Nightly run reports
dream-staging/ # Pattern promotion proposals awaiting human review
.dream-backups/ # Pre-run safety backups
research/
dream-cycle-metrics/
daily/ # JSON metrics per night
Observer not running?
logs/observer.log for errorsOPENROUTER_API_KEY is set and validcrontab -lObservations not being loaded at session start?
memory/observations.mdMEMORY_DIR points to the right locationReactive watcher not triggering (Linux)?
systemctl --user status total-recall-watcherinotify-tools is installed: which inotifywaitjournalctl --user -u total-recall-watcher -fDream Cycle archiving too aggressively?
READ_ONLY_MODE=true and review dream logs before going liveDREAM_TOKEN_TARGET upward to archive less per runDream Cycle not archiving enough?
DREAM_TOKEN_TARGET to trigger more aggressive consolidationThis system is inspired by how human memory works during sleep — the hippocampus (observer) captures experiences, and during sleep consolidation (reflector), important memories are strengthened while noise is discarded.
Read more: Your AI Has an Attention Problem
"Get your ass to Mars." — Well, get your agent's memory to work.