The initial split copied SKILL.md verbatim from its pre-split location where it still referenced paths in cli_utils. Update all 10 stale references to point at mempalace-toolkit instead — canonical path, clone URL, bind-mount path, container-recreate recovery command, and See also links.
9.2 KiB
name, description
| name | description |
|---|---|
| opencode-mempalace-bridge | Set up the producer side of MemPalace — feed opencode session history and project docs into the palace via the wrappers in the mempalace-toolkit repo. Use when provisioning a new machine, when the user asks how palace feeding works, when opencode sessions aren't showing up in searches, or when a project needs docs-only mining. Pairs with the `mempalace` skill (consumer side). |
Opencode ↔ MemPalace Bridge (producer side)
Overview
The mempalace skill covers using the palace (search, diary, KG). This skill covers feeding it — specifically, how to wire opencode session history and project docs into the palace on a new machine or after a container recreate.
Authoritative source: /workspace/mempalace-toolkit/ARCHITECTURE.md (also at the root of the mempalace-toolkit repo on gitea). When in doubt, read that file — it's the canonical spec. This skill is the short-form checklist.
Core idea: two thin wrappers in mempalace-toolkit/bin/ close gaps in the stock mempalace CLI:
| Gap | Wrapper |
|---|---|
mempalace mine floods the palace with source code we don't want |
mempalace-docs |
mempalace mine --mode convos can't read opencode's SQLite DB |
mempalace-session |
Both follow the same stage-to-cache-then-mine idiom — they curate input into ~/.cache/…/<wing>/, then delegate to mempalace mine.
When to Load This Skill
- User asks "how does the palace get fed?" or mentions setting up mempalace on a new machine.
- Opencode conversations are missing from palace searches (
wing_conversationsis empty or stale). - A project needs to be mined but you want docs only, no source code.
- User asks about
mempalace-docsormempalace-session. - After a container recreate on a devbox — the wrappers need reinstall.
- Planning to retire either wrapper once upstream PRs merge (see §6 of ARCHITECTURE.md).
Setup Recipe (new machine)
Prerequisites: opencode installed with an active DB at ~/.local/share/opencode/opencode.db, mempalace CLI v3.3.3+, Python 3 (stdlib sqlite3 only — no extra deps).
# 1. Clone mempalace-toolkit (holds the two wrappers in bin/)
git clone ssh://git@gitea.jordbo.se:2222/joakimp/mempalace-toolkit.git ~/mempalace-toolkit
cd ~/mempalace-toolkit
# 2. Install — symlinks bin/* into ~/.local/bin, adds loader to rc file
./install.sh
# 3. Verify ~/.local/bin is on PATH
which mempalace-session mempalace-docs
# 4. Initialize palace (one-time, platform-wide)
mempalace init --yes
# 5. Mine opencode session history into wing_conversations
mempalace-session --dry-run # preview: which sessions qualify?
mempalace-session # do it (~20 min per 60 sessions)
# 6. Mine project docs per project (docs only — no source code)
mempalace-docs /workspace/my_project --dry-run
mempalace-docs /workspace/my_project
# 7. If a long-lived MCP session is open, reconnect it
# (from inside the MCP client): mempalace_reconnect
Containerized (devbox) specifics
Named Docker volumes preserve state across container recreate:
devbox-palace→~/.mempalace/palacedevbox-data→~/.local/share/opencode
Bind mount /workspace/mempalace-toolkit from the host — code survives recreate, syncs via gitea.
After container recreate: ~/.local/bin is ephemeral. Just re-run ./install.sh (idempotent) — everything else already persists.
Key Operational Rules
Always dry-run first on a cold system
mempalace-session --dry-run # shows qualifying sessions
mempalace-docs <dir> --dry-run # shows files that would be mined
A docs-heavy repo should produce ~5–10 drawers per file. >15 drawers/file on average = code leaked in; investigate.
Dedup is free — re-running is safe
mempalace-docs: dedup keyed onsource_filepath +mtime. Unchanged files skipped.mempalace-session: dedup keyed onsource_filepath alone (no mtime check for convos). Staging filenames are deterministic per session (<slug>_<id>.jsonl), so re-runs skip already-filed sessions.
Second run immediately after first → 0 new drawers, only the post-mine repair step runs (~5 min on 5k drawers).
Incremental catch-up
mempalace-session --since 2026-04-20 # only recent sessions
mempalace-session --session ses_abc123 # one specific session
Force re-mine
rm -rf ~/.cache/mempalace-session/<wing>/ # nukes staging dir
mempalace-session # stages + mines fresh
Staging is ephemeral by design; the palace is the source of truth.
Failure Modes & Fixes
| Symptom | Cause | Fix |
|---|---|---|
mempalace-session: command not found |
~/.local/bin wiped (container recreate) |
cd ~/mempalace-toolkit && ./install.sh --yes |
| Sessions missing from palace | Fewer messages than --min-messages (default 3) |
Lower threshold or --session <id> explicitly |
| "Error finding id" on search after mining | Stale HNSW index | mempalace repair --yes + mempalace_reconnect |
| Drawers doubled for a project | Someone ran raw mempalace mine alongside wrapper, or renamed wing mid-flight |
Inspect embedding_metadata in chroma.sqlite3, purge duplicates by source prefix, then mempalace repair |
| Post-mine ChromaDB search returns stale results in MCP | MCP server caches old index | Call mempalace_reconnect from MCP |
| Opencode DB not at default path | Non-standard XDG_DATA_HOME or opencode config |
export OPENCODE_DB=/custom/path/opencode.db or --db |
What to File Under Which Wing
| Content type | Wing (convention) | Room | Tool |
|---|---|---|---|
| Opencode session transcripts | wing_conversations |
auto (keyword) | mempalace-session |
| Project docs (md, yaml, Dockerfile) | wing_<project-name> |
auto | mempalace-docs |
| Per-agent session diaries | wing_<agent-name> |
diary |
mempalace_diary_write (from the consumer-side mempalace skill) |
| Ad-hoc verbatim facts | any | any | mempalace_add_drawer |
Cost Profile (reference)
From a 10-day opencode corpus (140 sessions / 1491 msgs / 4656 parts):
- Dry run: seconds.
- Full mine: ~21 min wall / ~38 min user CPU → 2378 drawers from 62 qualifying sessions.
- Dedup re-run: mine instant, repair ~5 min.
Budget ~20 minutes per 60-session batch. Scales roughly linearly with message count.
Anti-Patterns
- Don't run
mempalace minedirectly on a project. Usemempalace-docs— otherwise source code floods the palace. - Don't try to point
mempalace mine --mode convosatopencode.dbdirectly. The convos miner reads files (txt/md/json/jsonl) only — no SQLite support. Usemempalace-sessionto export first. - Don't delete staging dirs unnecessarily. They're dedup anchors; deleting means a forced re-mine of everything in that wing.
- Don't forget
mempalace_reconnectafter a mine from inside a live MCP session — otherwise search hits the stale index. - Don't mine with
--min-messages 0or1— 78 out of 140 sessions in reference corpus were throwaway/exit'd sessions that would flood the palace with noise. Default 3 is sensible.
Upstream Roadmap (when to retire these wrappers)
- MemPalace PR #1213 merges →
mempalace-docsbecomes redundant (exclude patterns inmempalace.yaml). Retire to thin shim or delete. - Opencode session-stopping hooks merge (PR #16598 et al.) AND
hooks_cli.pygainsopencodeharness → live auto-save works;mempalace-sessionbecomes a manual-only backfill tool (cron / historic import). - SQLite mode lands in
mempalace mine --mode convos→mempalace-sessionloses its reason to exist entirely.
Check ARCHITECTURE.md §6 in mempalace-toolkit/ for current upstream status before doing any retirement work.
See Also
<mempalace-toolkit>/ARCHITECTURE.md— canonical spec (diagrams, implementation notes, full troubleshooting).<mempalace-toolkit>/README.md— per-tool usage reference.~/.agents/skills/mempalace/SKILL.md— consumer-side skill (search, diary, KG) — pair this skill with that one.