{"skill":{"slug":"wip-memory-crystal","displayName":"Memory Crystal Private","summary":"Search and manage the shared memory crystal. Use when user says \"do you remember\", \"search memory\", \"remember this\", \"forget that\", \"memory status\", \"what do...","tags":{"latest":"0.7.35"},"stats":{"comments":0,"downloads":387,"installsAllTime":0,"installsCurrent":0,"stars":0,"versions":8},"createdAt":1773780642826,"updatedAt":1777358614056},"latestVersion":{"version":"0.7.35","createdAt":1776527771831,"changelog":"# Memory Crystal v0.7.35\n\nOne-line release: **`crystal status` and every other CLI verb now actually run on global installs under modern Node**. Before this release, a silent packaging mistake made every `crystal <verb>` command throw `ERR_MODULE_NOT_FOUND` at startup on Node 25.6+, which is the first Node version to enforce strict ESM resolution against an unresolvable bare import. Ingestion continued to work the whole time because the Claude Code Stop hook takes a different code path.\n\n## What was wrong\n\n`package.json` declared its dream-weaver-protocol dependency with a `file:` relative path intended for local dev (`file:../dream-weaver-protocol-private`). When users ran `npm install -g @wipcomputer/memory-crystal`, npm tried to resolve that path relative to the global install root, could not find the sibling directory, and left the module unresolvable. Older Node resolvers tolerated the resulting empty state; Node 25 does not. Any entrypoint that imports `dream-weaver.ts` — which is every interactive CLI — threw on startup.\n\n## What changed\n\nAdded `tsup.config.ts` with `noExternal: ['dream-weaver-protocol']`. Tsup now bundles dream-weaver's source code into each memory-crystal dist entrypoint at build time, so the published tarball is self-contained and needs no runtime resolution of that dep. The CLI verbs work on any Node from 18 to 25+.\n\n## What did not change\n\n- Ingestion: the Claude Code Stop hook path was never broken. Continuous capture kept going at normal rate.\n- Search: the MCP server entrypoint was never broken. Agents that use `crystal_search` through MCP were unaffected.\n- Data: zero chunks were lost. Today's DB count is 92,696 and growing.\n\n## Related bugs filed in this release\n\n- `ai/product/bugs/2026-04-18--cc-mini--crystal-status-cli-broken-node-25.md` — this bug in full, with root cause, discovery narrative, and follow-up work\n- `ai/product/bugs/2026-04-18--cc-mini--lesa-capture-gap-2026-04-17.md` — a separate concern: during the Opus 4.7 rollout incident on Apr 17, Lēsa's gateway failed repeatedly on an unknown model ID and emitted no successful agent_end events, so ingestion for that day dropped to ~46 chunks vs ~300 baseline. Propose backfill + structural prevention in that bug.\n\n## Install\n\n```bash\nnpm install -g @wipcomputer/memory-crystal@latest\ncrystal status\n```\n\nIf that reports your chunk count and agent list cleanly, you're on the fix.\n\nCloses wipcomputer/memory-crystal#68.","license":"MIT-0"},"metadata":null,"owner":{"handle":"parkertoddbrooks","userId":"s17620xzyc7kfan8m36at57m6n83h8he","displayName":"Parker Todd Brooks","image":"https://avatars.githubusercontent.com/u/585456?v=4"},"moderation":{"isSuspicious":true,"isMalwareBlocked":false,"verdict":"suspicious","reasonCodes":["suspicious.dangerous_exec","suspicious.env_credential_access","suspicious.llm_suspicious","suspicious.potential_exfiltration","suspicious.prompt_injection_instructions","suspicious.vt_suspicious"],"summary":"Detected: suspicious.dangerous_exec, suspicious.env_credential_access, suspicious.llm_suspicious (+3 more)","engineVersion":"v2.4.2","updatedAt":1777358614056}}