@usememra/pi-extension
Persistent memory for pi coding agent. Hybrid cloud + local backend (Memra).
Package details
Install @usememra/pi-extension from npm and Pi will load the resources declared by the package manifest.
$ pi install npm:@usememra/pi-extension- Package
@usememra/pi-extension- Version
0.3.2- Published
- Apr 21, 2026
- Downloads
- 331/mo · 9/wk
- Author
- vonsensey
- License
- MIT
- Types
- extension
- Size
- 47.7 KB
- Dependencies
- 0 dependencies · 3 peers
Pi manifest JSON
{
"extensions": [
"./src/index.ts"
]
}Security note
Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.
README
@usememra/pi-extension
Persistent memory for pi — the coding agent. Works with any LLM pi supports (Anthropic, OpenAI, Google, and more). Pick cloud (Memra) or local (memra-local) — same tools, same API, your choice.
Your agent forgets everything between sessions. Memra is the memory layer that fixes that.
Install
From a local repo checkout
pi install ./pi-extension
From npm (recommended for end users)
pi install npm:@usememra/pi-extension
Reload with /reload.
Setup
On first session start the extension auto-detects:
MEMRA_API_KEYin env → cloud mode.- A running memra-local on
http://127.0.0.1:8765→ local mode. - Otherwise it asks you.
Cloud defaults to https://usememra.com/api and automatically talks to the public API at /v1/... and /health.
Config lives at ~/.memra/pi-extension.json (mode 0600). Nothing else is written.
Environment Variables
| Variable | Description |
|---|---|
MEMRA_API_KEY |
Cloud API key (memra_live_...) |
MEMRA_PROJECT_ID |
Cloud project ID / namespace (default: default) |
MEMRA_TENANT_ID |
Cloud tenant ID / namespace root (default: pi-agent) |
Commands
| Command | Action |
|---|---|
/memra |
Interactive hub |
/memra status |
Active backend + health |
/memra switch |
Pick cloud or local |
/memra namespace <name> |
Set project/namespace |
/memra tenant <id> |
Set cloud tenant ID |
/memra setkey |
Set cloud API key |
/memra autorecall |
Toggle auto-recall on new turns |
/memra signup |
Open signup page |
/memra reset |
Wipe extension config |
A footer badge (☁ cloud · <project> or ⌂ local · <namespace>) shows the active backend at all times.
Auto-Recall
When auto-recall is enabled (default), the extension automatically searches your memory store before each agent turn and injects relevant memories into the LLM context. This means your agent remembers across sessions without you having to ask.
Toggle with /memra autorecall.
Tools (LLM-facing)
Every tool mirrors the Memra API surface:
| Tool | Description |
|---|---|
memra_recall |
Semantic recall by natural-language query (primary read verb) |
memra_remember |
Store a fact, decision, preference, or context (primary write verb) |
memra_get |
Fetch a single memory by ID |
memra_list |
List memories, optionally filtered by type |
memra_delete |
Delete a memory permanently |
memra_supersede |
Replace an outdated memory (preserves audit trail) |
memra_history |
View the supersession chain for a memory |
memra_health |
Check backend reachability |
memra_search |
Deprecated alias of memra_recall (still callable) |
memra_add |
Deprecated alias of memra_remember (still callable) |
The LLM picks tools automatically based on your conversation. The extension routes every call to the active backend (cloud or local).
Security
- API key read from
MEMRA_API_KEY→~/.memra/pi-extension.json→ interactive prompt. Never logged. - Local mode is bound to loopback (
127.0.0.1/localhost) only. - Cloud mode refuses non-HTTPS URLs.
- Namespace / project / tenant inputs are validated before saving.
- Writes confined to
~/.memra/pi-extension.json.
Cloud vs Local
| Cloud | Local | |
|---|---|---|
| Storage | Managed (EU, Hetzner Helsinki) | Your machine |
| Sync | Multi-device | None (use cloud for sync) |
| Offline | No | Yes |
| Setup | API key | pip install memra-local && memra-local serve |
| Price | Free tier + paid plans | Free, BUSL-1.1 (memra-local) |
Get a cloud key: usememra.com/install
Recommended config for Memra Cloud
For shared persistent memory across pi sessions, set:
export MEMRA_API_KEY="memra_live_..."
export MEMRA_PROJECT_ID="memra-brain"
export MEMRA_TENANT_ID="pi-agent"
Then run pi and /reload.
License
MIT. Use it anywhere. The Memra backend (usememra.com) and memra-local server have their own licenses.