@walodayeet/hindsight-pi
v0.4.0
Published
Hindsight-backed persistent memory extension for pi
Maintainers
Readme
Hindsight-pi
Transparent long-term memory for pi powered by Hindsight.
Hindsight-pi gives pi durable, inspectable memory without hiding what is happening. It recalls relevant memories for the current turn, queues new memories safely, and lets you inspect or prune recall state when needed.
Highlights
- Fresh recall per user turn; no stale cached memory context.
- Hidden
hindsight-recallcontext is filtered so old recalls do not leak back to the model. - Durable
message_endretention queue using HindsightretainBatch. - Session-document append with stable document ids.
- Tags and observation scopes for project/user/session separation.
- One-bank + tags/scopes recommended; multiple banks supported for hard privacy boundaries.
- Friendly setup, status, doctor, config-source inspection, and explicit tools.
Install
From npm:
pi install npm:@walodayeet/hindsight-piFrom GitHub:
pi install git:github.com/walodayeet/pi-hindsightLocal dev:
npm install
pi -e ./extensions/index.tsQuick start
- Start or connect to a Hindsight server.
- Load/reload pi.
- Run:
/hindsight:setup
/hindsight:doctor
/hindsight:statusUseful server example:
http://<your-hindsight-host>:8888Recommended memory setup
For most users:
- Use one Hindsight bank.
- Separate project/global memories with tags and observation scopes.
- Use separate banks only when memories must never mix, e.g. work vs personal or different clients.
Profile presets:
/hindsight:profile broad # broad recall from configured bank
/hindsight:profile project # project-scoped recall via {project}
/hindsight:profile cwd # exact-directory scoped recall
/hindsight:profile global # global-bank style workflow
/hindsight:profile isolated # per-repo bank plus project tagsCommon commands
/hindsight:setup first-time setup
/hindsight:status runtime, queue, recall, and bank status
/hindsight:doctor connectivity and config diagnostics
/hindsight:where show config files and precedence
/hindsight:popup show exact last recalled memories
/hindsight:flush flush queued retention records
/hindsight:toggle-retain enable/disable retention for this session
/hindsight:tag <tag> add session tag
/hindsight:remove-tag <tag> remove session tag
/hindsight:parse-session inspect current session as JSON
/hindsight:parse-and-upsert-session
/hindsight:prune-recall-messages confirmAgent tools
hindsight_search— raw memory searchhindsight_context— synthesized memory contexthindsight_retain— explicit durable memory writehindsight_bank_profile— inspect active bank
Config files
Global:
~/.hindsight/config.json
~/.hindsight/config.tomlProject-local override:
<repo>/.hindsight/config.json
<repo>/.hindsight/config.tomlUse /hindsight:where to see which files are active.
Minimal config:
{
"baseUrl": "http://<your-hindsight-host>:8888",
"bankId": "my-memory-bank",
"bankStrategy": "manual",
"host": {
"pi": {
"enabled": true,
"recallMode": "hybrid",
"autoRecallTags": ["{project}"],
"autoRecallTagsMatch": "any_strict",
"observationScopes": [["{project}"]]
}
}
}Defaults that matter
- Recall query uses raw user input, not expanded skill/slash-command bodies.
- Slash commands with no user request skip recall; slash commands with args recall from the args.
- Oversized recall queries warn and skip by default.
- Auto recall is ephemeral by default (
autoRecallPersist=false). - Recall indicators are UI-only by default.
- Retention excludes Hindsight tool feedback and meta-memory inspection prompts.
#nomemand#skipopt a turn out of auto-retain.
Persisted recall caveat
Persisted recall display is for debugging. If you enable it and later uninstall the extension, old recall messages may remain in session files. Before uninstalling, run:
/hindsight:prune-recall-messages confirmOr keep the extension installed but disabled so it can continue filtering old hindsight-recall messages.
More docs
- Architecture:
docs/architecture-v3.md - Config details:
docs/config.md - Commands/tools:
docs/commands-and-tools.md - Hindsight project: github.com/vectorize-io/hindsight
Development
npm run typecheck
npm test
HINDSIGHT_BASE_URL=http://<your-hindsight-host>:8888 npm run smoke