@clauderecallhq/cli 0.64.0 → 0.64.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,10 +1,6 @@
1
1
  <div align="center">
2
2
 
3
- <picture>
4
- <source media="(prefers-color-scheme: dark)" srcset="https://clauderecall.com/wordmark-dark.svg">
5
- <source media="(prefers-color-scheme: light)" srcset="https://clauderecall.com/wordmark-light.svg">
6
- <img src="https://clauderecall.com/wordmark-dark.svg" alt="Claude Recall" width="400">
7
- </picture>
3
+ <img src="https://clauderecall.com/wordmark-light.svg" alt="Claude Recall" width="400">
8
4
 
9
5
  <br />
10
6
  <br />
@@ -15,17 +11,14 @@ Claude Recall indexes every Claude Code session you've ever run, surfaces what m
15
11
 
16
12
  <br />
17
13
 
18
- <img src="https://clauderecall.com/hero/brand-morph.gif" alt="Claude Recall memory tree morphing into the wordmark" width="700">
14
+ <img src="https://clauderecall.com/hero/brand-morph.gif" alt="Claude Recall, memory tree morphing into the wordmark" width="700">
19
15
 
20
16
  <br />
21
17
  <br />
22
18
 
23
- [![npm](https://img.shields.io/npm/v/@clauderecallhq/cli?style=flat-square&color=f97316&label=npm)](https://www.npmjs.com/package/@clauderecallhq/cli)
24
- [![Node](https://img.shields.io/badge/node-%E2%89%A522-43853d?style=flat-square&logo=node.js&logoColor=white)](https://nodejs.org)
25
- [![TypeScript](https://img.shields.io/badge/typescript-strict-3178c6?style=flat-square&logo=typescript&logoColor=white)](https://www.typescriptlang.org/)
26
- [![Local-first](https://img.shields.io/badge/local--first-127.0.0.1%20only-0b0c0f?style=flat-square)](#privacy--security)
27
- [![License](https://img.shields.io/badge/license-proprietary-1a1a2e?style=flat-square)](#license)
28
- [![Site](https://img.shields.io/badge/clauderecall.com-f97316?style=flat-square&logo=data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9IndoaXRlIiBzdHJva2Utd2lkdGg9IjIiPjxjaXJjbGUgY3g9IjEyIiBjeT0iMTIiIHI9IjEwIi8+PGxpbmUgeDE9IjIiIHkxPSIxMiIgeDI9IjIyIiB5Mj0iMTIiLz48cGF0aCBkPSJNMTIgMmExNS4zIDE1LjMgMCAwIDEgNCAxMCAxNS4zIDE1LjMgMCAwIDEtNCA4IDEwIi8+PC9zdmc+)](https://clauderecall.com)
19
+ [![npm](https://img.shields.io/npm/v/@clauderecallhq/cli?style=flat-square&color=f97316&labelColor=f97316&label=npm)](https://www.npmjs.com/package/@clauderecallhq/cli)
20
+ [![Downloads](https://img.shields.io/npm/dm/@clauderecallhq/cli?style=flat-square&color=f97316&labelColor=f97316&label=downloads)](https://www.npmjs.com/package/@clauderecallhq/cli)
21
+ [![License](https://img.shields.io/badge/license-proprietary-f97316?style=flat-square)](#license)
29
22
 
30
23
  <br />
31
24
 
@@ -102,11 +95,8 @@ Claude picks up where you left off instead of asking you to explain it again.
102
95
 
103
96
  ## Features
104
97
 
105
- <table>
106
- <tr>
107
- <td width="50%" valign="top">
98
+ ### Context Re-injection (the moat)
108
99
 
109
- ### Context Re-injection &nbsp;<sub>← the moat</sub>
110
100
  Pipe any past session straight into a new Claude Code conversation as condensed markdown. Claude picks up where you left off instead of asking you to re-explain it. **Nothing else in this category has it.**
111
101
 
112
102
  ```bash
@@ -115,10 +105,8 @@ recall context <id> --prelude "continue this" | claude
115
105
  recall context <id> --since 2h | claude
116
106
  ```
117
107
 
118
- </td>
119
- <td width="50%" valign="top">
108
+ ### Threads
120
109
 
121
- ### Threads &nbsp;<sub>NEW · v0.15a</sub>
122
110
  Group related sessions into a DAG you can see, rename, and walk. Drag-to-reparent in the graph view. Right-click rename. Bulk-generate coherent titles across an entire thread with one click.
123
111
 
124
112
  ```bash
@@ -127,12 +115,8 @@ recall thread create "auth-refactor"
127
115
  recall thread add <thread> <session>
128
116
  ```
129
117
 
130
- </td>
131
- </tr>
132
- <tr>
133
- <td width="50%" valign="top">
134
-
135
118
  ### Full-Text Search
119
+
136
120
  FTS5 BM25 ranking across every message, every session, in milliseconds. Highlighted snippets, inline `#tag` filters, project + date scoping.
137
121
 
138
122
  ```bash
@@ -140,26 +124,20 @@ recall search "zod schema"
140
124
  recall search "auth #auth-fix" -p Pest-Control
141
125
  ```
142
126
 
143
- </td>
144
- <td width="50%" valign="top">
127
+ ### On-Device Vector Search (Pro)
145
128
 
146
- ### On-Device Vector Search &nbsp;<sub>Pro</sub>
147
129
  Local **768-dimension embeddings** via `bge-base-en-v1.5` ONNX. Three-lane RRF fusion (BM25 + summary + vectors) finds sessions by *meaning*, not keywords. Your code never leaves your laptop.
148
130
 
149
131
  The embedder model (~110MB) auto-downloads on `npm install`. Skip with `RECALL_SKIP_MODEL_DOWNLOAD=1`.
150
132
 
151
- > **Anonymous install ping (opt-in, off by default).** On first run we ask once whether you want to send a single anonymous message per month so we can count real installs vs bots. No PII, no fingerprint, no cross-month linkage. Full payload at [clauderecall.com/telemetry](https://clauderecall.com/telemetry). Toggle any time with `recall telemetry on` / `off` / `view`.
133
+ **Anonymous install ping (opt-in, off by default).** On first run we ask once whether you want to send a single anonymous message per month so we can count real installs vs bots. No PII, no fingerprint, no cross-month linkage. Full payload at [clauderecall.com/telemetry](https://clauderecall.com/telemetry). Toggle any time with `recall telemetry on` / `off` / `view`.
152
134
 
153
135
  ```bash
154
136
  recall similar <session-id>
155
137
  ```
156
138
 
157
- </td>
158
- </tr>
159
- <tr>
160
- <td width="50%" valign="top">
161
-
162
139
  ### Cost Analytics
140
+
163
141
  Per-session and per-project token + dollar totals. Daily sparkline. Top-10 heaviest sessions. Know exactly where your Anthropic bill is going.
164
142
 
165
143
  ```bash
@@ -167,10 +145,8 @@ recall stats <id>
167
145
  recall stats --project Tools --days 7
168
146
  ```
169
147
 
170
- </td>
171
- <td width="50%" valign="top">
172
-
173
148
  ### Git Correlation
149
+
174
150
  Every session links to commits authored in its working directory during its time window. Reverse-map any commit back to the session that produced it.
175
151
 
176
152
  ```bash
@@ -178,65 +154,43 @@ recall correlate
178
154
  recall blame <sha>
179
155
  ```
180
156
 
181
- </td>
182
- </tr>
183
- <tr>
184
- <td width="50%" valign="top">
185
-
186
157
  ### Auto-Tagging
158
+
187
159
  Let Claude label your sessions automatically. Two modes: **MCP mode** (zero-setup, runs through your existing Claude Code subscription at no extra cost) or **BYOK** (paste your own Anthropic API key). Off by default, fully opt-in.
188
160
 
189
- </td>
190
- <td width="50%" valign="top">
161
+ ### MCP Server (35 tools)
191
162
 
192
- ### MCP Server &nbsp;<sub>33 tools</sub>
193
- Expose Recall to Claude Desktop, Claude Code, or any MCP client as native tools. **14 read tools always on**, **19 write tools** opt-in with rate limiting and append-only audit logging.
163
+ Expose Recall to Claude Desktop, Claude Code, or any MCP client as native tools. **13 read tools always on**, **22 write tools** opt-in with rate limiting and append-only audit logging.
194
164
 
195
165
  ```bash
196
166
  recall mcp
197
167
  recall mcp --allow-writes
198
168
  ```
199
169
 
200
- </td>
201
- </tr>
202
- <tr>
203
- <td width="50%" valign="top">
170
+ ### Collections, Tags and Notes
204
171
 
205
- ### Collections, Tags & Notes
206
- Hand-curated hierarchical collections that cut across projects. Flat tags. Markdown notes per session. Aliases. Pins. Cross-session diff. Every write is reversible -- three-layer durability with plain-text mirrors on disk.
207
-
208
- </td>
209
- <td width="50%" valign="top">
172
+ Hand-curated hierarchical collections that cut across projects. Flat tags. Markdown notes per session. Aliases. Pins. Cross-session diff. Every write is reversible: three-layer durability with plain-text mirrors on disk.
210
173
 
211
174
  ### Web UI
175
+
212
176
  Dark-mode three-pane layout. **Virtualized transcript** (10,000-message sessions open instantly). `Cmd+K` command palette. Cross-session diff. First-60-seconds onboarding tour. Export to markdown, HTML, or print-ready PDF.
213
177
 
214
- </td>
215
- </tr>
216
- <tr>
217
- <td width="50%" valign="top">
178
+ ### Rediscovery ("For you")
218
179
 
219
- ### Rediscovery &nbsp;<sub>"For you"</sub>
220
180
  Three rotating cards in the left pane surface forgotten sessions worth revisiting: a 60+-day-old session that overlaps with what you've been working on, your top-cost session this week, and the session that authored your current `HEAD`.
221
181
 
222
182
  ```bash
223
183
  recall digest
224
184
  ```
225
185
 
226
- </td>
227
- <td width="50%" valign="top">
228
-
229
186
  ### IDE Extension
230
- **VS Code · Cursor · Windsurf · VS Code Insiders.** Tag terminal tabs from inside your editor -- terminal names sync to Recall so sessions get meaningful aliases with zero CLI ceremony, live as you rename tabs.
187
+
188
+ **VS Code, Cursor, Windsurf, VS Code Insiders.** Tag terminal tabs from inside your editor; terminal names sync to Recall so sessions get meaningful aliases with zero CLI ceremony, live as you rename tabs.
231
189
 
232
190
  ```bash
233
191
  recall install-extension
234
192
  ```
235
193
 
236
- </td>
237
- </tr>
238
- </table>
239
-
240
194
  <br />
241
195
 
242
196
  <details>
@@ -244,13 +198,13 @@ recall install-extension
244
198
 
245
199
  <br />
246
200
 
247
- - **Secrets redaction** -- API keys, auth tokens, passwords, private-key blobs are detected by pattern and replaced with placeholders **before** text lands in the searchable index or any export. Original JSONLs untouched.
248
- - **Memory health scores** -- every session gets a freshness score; surfaces stale data so you know when to re-run a backfill.
249
- - **MCP audit log** -- every write tool call lands in `mcp_audit_events` with status (ok / error / rate_limited). Pure local, no telemetry.
250
- - **First-60-seconds onboarding** -- 3-step modal demos the moat (`recall context <id> | claude`) the moment you open the web UI.
251
- - **Cmd+K command palette** -- jump to any session, action, or setting in one keystroke.
252
- - **Multi-select sessions** -- `Cmd+Click` toggle, `Shift+Click` range, right-click to copy IDs.
253
- - **Three-layer durability** -- every write goes to SQLite + an append-only history column + a plain-text mirror on disk. Source JSONLs at `~/.claude/projects/` are strictly read-only.
201
+ - **Secrets redaction.** API keys, auth tokens, passwords, private-key blobs are detected by pattern and replaced with placeholders **before** text lands in the searchable index or any export. Original JSONLs untouched.
202
+ - **Memory health scores.** Every session gets a freshness score; surfaces stale data so you know when to re-run a backfill.
203
+ - **MCP audit log.** Every write tool call lands in `mcp_audit_events` with status (ok / error / rate_limited). Pure local, no telemetry.
204
+ - **First-60-seconds onboarding.** 3-step modal demos the moat (`recall context <id> | claude`) the moment you open the web UI.
205
+ - **Cmd+K command palette.** Jump to any session, action, or setting in one keystroke.
206
+ - **Multi-select sessions.** `Cmd+Click` toggle, `Shift+Click` range, right-click to copy IDs.
207
+ - **Three-layer durability.** Every write goes to SQLite + an append-only history column + a plain-text mirror on disk. Source JSONLs at `~/.claude/projects/` are strictly read-only.
254
208
 
255
209
  #### Keyboard Shortcuts
256
210
 
@@ -304,7 +258,7 @@ recall tui # full terminal UI: arrow-key browse, live search, pre
304
258
 
305
259
  `recall` (no args) prints a branded splash with version / daemon / sessions / license status and drops into a slash-aware prompt; type `/` to browse 60+ commands grouped by purpose (Setup, Browse, Pipe to Claude, Threads, Inference, Analytics, Daemon, Diagnostics, Integrations, Sharing, Feedback, Pro).
306
260
 
307
- `recall tui` mounts an Ink-based terminal app modeled on `lazygit` and `k9s`. Arrow keys to navigate, `/` to filter, `enter` to view the full transcript, `o` to open the selected session in the browser, `q` to quit.
261
+ `recall tui` mounts a full-screen terminal app modeled on `lazygit` and `k9s`. Arrow keys to navigate, `/` to filter, `enter` to view the full transcript, `o` to open the selected session in the browser, `q` to quit.
308
262
 
309
263
  ### Explore
310
264
 
@@ -331,13 +285,13 @@ recall context abc12345 --since 2h | claude
331
285
 
332
286
  ### How Claude Recall integrates with Claude Code
333
287
 
334
- Don't think of Claude Recall as a *separate* tool you context-switch to. It's **Claude Code's memory layer** you reach it from inside any session through four surfaces, in increasing power:
288
+ Don't think of Claude Recall as a *separate* tool you context-switch to. It's **Claude Code's memory layer**: you reach it from inside any session through four surfaces, in increasing power:
335
289
 
336
- **1. Bash tool always available, zero setup.**
290
+ **1. Bash tool: always available, zero setup.**
337
291
 
338
- Inside any Claude Code conversation, just say *"run `recall search auth bug`"* (or any other recall command). The Bash tool executes it; output lands in the conversation. Works the moment you `npm install -g @clauderecallhq/cli` no config.
292
+ Inside any Claude Code conversation, just say *"run `recall search auth bug`"* (or any other recall command). The Bash tool executes it; output lands in the conversation. Works the moment you `npm install -g @clauderecallhq/cli`. No config.
339
293
 
340
- **2. Slash commands (skills) one-tap workflows.**
294
+ **2. Slash commands (skills): one-tap workflows.**
341
295
 
342
296
  When Claude Recall is installed as a Claude Code plugin, typing `/` in Claude Code surfaces ready-made workflows:
343
297
 
@@ -352,11 +306,11 @@ When Claude Recall is installed as a Claude Code plugin, typing `/` in Claude Co
352
306
  | `/claude-recall:thread-scan` | Auto-detect threads across historical sessions |
353
307
  | `/claude-recall:setup` | Verify installation and MCP connection |
354
308
 
355
- **3. MCP server the model calls Recall directly.**
309
+ **3. MCP server: the model calls Recall directly.**
356
310
 
357
- The most powerful surface. With `recall mcp` registered as an MCP server in Claude Code, the model itself decides when to call Recall mid-conversation. Ask *"have I solved this auth bug before?"* and Claude calls `search` autonomously, gets results, and uses them. Ask *"pull yesterday's context"* and it calls `context_for_session`. No commands, no slash menu pure intent.
311
+ The most powerful surface. With `recall mcp` registered as an MCP server in Claude Code, the model itself decides when to call Recall mid-conversation. Ask *"have I solved this auth bug before?"* and Claude calls `search` autonomously, gets results, and uses them. Ask *"pull yesterday's context"* and it calls `context_for_session`. No commands, no slash menu, pure intent.
358
312
 
359
- **4. Piping into a fresh `claude` start tomorrow with yesterday's context.**
313
+ **4. Piping into a fresh `claude`: start tomorrow with yesterday's context.**
360
314
 
361
315
  The cross-session continuation pattern, run from your shell:
362
316
 
@@ -382,33 +336,34 @@ Point any MCP client at Recall and the model calls it as native tools:
382
336
  ```
383
337
 
384
338
  <details>
385
- <summary><strong>Available MCP tools (33 total)</strong></summary>
339
+ <summary><strong>Available MCP tools (35 total)</strong></summary>
386
340
 
387
341
  <br />
388
342
 
389
- **Read tools (14 -- always available):**
343
+ **Read tools (13, always available):**
390
344
 
391
345
  | Tool | Purpose |
392
346
  |---|---|
393
347
  | `list_projects` | Every indexed project with session/message counts |
394
348
  | `list_sessions` | Recent sessions; filters: project, tag, date range |
395
349
  | `list_tags` | Tag cloud with counts, most popular first |
396
- | `list_sessions_to_tag` | Surface untagged sessions for review |
397
- | `apply_tags` | Add tags to a session (merge-mode) |
398
350
  | `search` | Full-text search with `#tag` support; BM25 + optional vector fusion |
399
351
  | `find_similar_sessions` | Semantic similarity via vector embeddings (Pro) |
400
352
  | `semantic_status` | Health snapshot: model, worker, queue depth (Pro) |
401
353
  | `get_session` | Full transcript (accepts 8+ char id prefix) |
402
354
  | `context_for_session` | Condensed markdown export, ready to inject |
403
355
  | `recall_neighborhood` | Bundle parents/children/citations/similar as one budget-bounded markdown blob |
356
+ | `doctor` | Read-only health snapshot: db size, WAL, FTS5 fragmentation, integrity check |
404
357
  | `thread_list` | All threads, newest first; can exclude archived |
405
358
  | `thread_get` | Full thread detail with every session edge |
406
359
  | `thread_for_session` | Non-archived threads referencing a session |
407
360
 
408
- **Write tools (19 -- opt-in via `--allow-writes`):**
361
+ **Write tools (22, opt-in via `--allow-writes`):**
409
362
 
410
363
  | Tool | Purpose |
411
364
  |---|---|
365
+ | `list_sessions_to_tag` | Surface untagged sessions for review (auto-tag flow) |
366
+ | `apply_tags` | Add tags to a session (merge-mode, never deletes) |
412
367
  | `add_tag` / `remove_tag` | Tag management; removals logged in append-only log |
413
368
  | `set_alias` | Human-friendly session name; previous alias archived |
414
369
  | `append_note` | Add markdown to session note; separated by `---` |
@@ -424,8 +379,9 @@ Point any MCP client at Recall and the model calls it as native tools:
424
379
  | `thread_archive` | Soft-delete thread; hidden by default |
425
380
  | `thread_merge` | Move all edges from source to dest, delete source |
426
381
  | `thread_split` | Peel sessions into new thread |
427
- | `sync_active_sessions` | Capture currently-active terminals in a repo into a thread (Captain Code Pattern) |
382
+ | `sync_active_sessions` | Capture every Claude Code terminal currently open in a repo into one thread, so parallel sessions stay organized |
428
383
  | `generate_thread_titles` | Generate coherent titles for sessions in thread DAG |
384
+ | `optimize` | WAL checkpoint, FTS5 segment merge, planner stats refresh; optional VACUUM |
429
385
 
430
386
  All writes are rate-limited (default 60/min), zod-validated, and audited to `~/.recall/audit/`.
431
387
 
@@ -439,14 +395,14 @@ All writes are rate-limited (default 60/min), zod-validated, and audited to `~/.
439
395
 
440
396
  ## How It Works
441
397
 
442
- ```
443
- ~/.claude/projects/**/*.jsonl <-- Claude Code's session files (read-only to Recall)
398
+ ```text
399
+ ~/.claude/projects/**/*.jsonl <-- Claude Code session files (read-only to Recall)
444
400
  |
445
401
  v chokidar file watcher
446
402
  ~/.recall/db.sqlite <-- indexed database (FTS5 + sqlite-vec 768d)
447
403
  |
448
404
  +-- background embedding worker (idle-aware, transactional)
449
- +-- git correlator (read-only `git log` scoped to session cwd)
405
+ +-- git correlator (read-only 'git log' scoped to session cwd)
450
406
  +-- semantic / auto-tag scanner (opt-in, off by default)
451
407
  |
452
408
  +-----+-----+
@@ -454,7 +410,7 @@ All writes are rate-limited (default 60/min), zod-validated, and audited to `~/.
454
410
  CLI HTTP server (Hono, 127.0.0.1 only)
455
411
  | |
456
412
  recall ... Web UI (React + Tailwind SPA, Vite-bundled)
457
- MCP server (stdio, 33 tools, opt-in writes)
413
+ MCP server (stdio, 35 tools, opt-in writes)
458
414
  ```
459
415
 
460
416
  ### Data stays local
@@ -481,17 +437,19 @@ Claude Recall is **local-first by design**, not as an afterthought.
481
437
 
482
438
  - **The daemon binds to `127.0.0.1` only.** Never `0.0.0.0`, never a public interface.
483
439
  - **No telemetry. No analytics. No background phone-home.** The daemon, file watcher, indexer, and web UI never make outbound network calls. Your session content never leaves your machine.
484
- - **The only outbound calls are user-initiated**, never automatic, and never transmit your session data:
485
-
486
- | Command | Endpoint | What it sends | What it gets |
487
- |---|---|---|---|
488
- | `recall activate <key>` | `clauderecall.com` | The license key only | A signed JWT for offline validation |
489
- | `recall semantic install` | `huggingface.co` | Nothing about you | The `bge-base-en-v1.5` ONNX model file |
490
-
491
- Both are optional and not required for core indexing, search, or context re-injection. Skip them and Recall is fully air-gapped.
440
+ - **The only outbound calls are user-initiated**, never automatic, and never transmit your session data.
492
441
  - **No cloud. No account.** Your data lives at `~/.recall/` and nowhere else.
493
442
  - **Source sessions are never modified.** Claude Code's JSONL files at `~/.claude/projects/` are strictly read-only to Recall.
494
- - **Never-delete-data invariant.** Every write enforces three independent durability layers: SQLite with history columns, plain-text mirror on disk, and source JSONLs untouched. Renaming, clearing, or removing anything is always additive -- the prior value is archived, never destroyed.
443
+ - **Never-delete-data invariant.** Every write enforces three independent durability layers: SQLite with history columns, plain-text mirror on disk, and source JSONLs untouched. Renaming, clearing, or removing anything is always additive; the prior value is archived, never destroyed.
444
+
445
+ The two user-initiated outbound calls:
446
+
447
+ | Command | Endpoint | What it sends | What it gets |
448
+ |---|---|---|---|
449
+ | `recall activate <key>` | `clauderecall.com` | The license key only | A signed JWT for offline validation |
450
+ | `recall semantic install` | `huggingface.co` | Nothing about you | The `bge-base-en-v1.5` ONNX model file |
451
+
452
+ Both are optional and not required for core indexing, search, or context re-injection. Skip them and Recall is fully air-gapped.
495
453
 
496
454
  <br />
497
455
 
@@ -564,7 +522,7 @@ recall semantic reindex # re-embed everything
564
522
  recall semantic auto-extract on # daemon nibbles un-extracted sessions through Claude (Pro)
565
523
  recall similar <id> # cosine kNN over session chunks
566
524
 
567
- # Threads (v0.15a)
525
+ # Threads
568
526
  recall thread list # all threads, newest first
569
527
  recall thread create <name> # new thread
570
528
  recall thread add <t> <s> # attach session to thread
@@ -638,7 +596,7 @@ Claude Recall is a Node.js CLI with a few native dependencies (`better-sqlite3`,
638
596
 
639
597
  **Node:** 22 LTS or 24 LTS. Node 20 and earlier are unsupported (declared in `engines.node`).
640
598
 
641
- **Semantic search is optional.** The on-device embedder is the only feature that loads the native ONNX runtime. The model auto-downloads (~110MB) on `npm install`; skip with `RECALL_SKIP_MODEL_DOWNLOAD=1` and install later via `recall semantic install`. Core CLI features search, list, context, daemon, MCP work on every supported platform regardless of whether the embedder is installed. If the embedder fails to load on your platform, you get a clear error pointing here, and the rest of Claude Recall keeps working.
599
+ **Semantic search is optional.** The on-device embedder is the only feature that loads the native ONNX runtime. The model auto-downloads (~110MB) on `npm install`; skip with `RECALL_SKIP_MODEL_DOWNLOAD=1` and install later via `recall semantic install`. Core CLI features (search, list, context, daemon, MCP) work on every supported platform regardless of whether the embedder is installed. If the embedder fails to load on your platform, you get a clear error pointing here, and the rest of Claude Recall keeps working.
642
600
 
643
601
  <br />
644
602
 
@@ -656,9 +614,9 @@ Claude Recall ships on every surface a developer already works in.
656
614
  | **VS Code Marketplace** | [`clauderecallhq.clauderecall-vscode`](https://marketplace.visualstudio.com/items?itemName=clauderecallhq.clauderecall-vscode) | Search "Claude Recall" in Extensions |
657
615
  | **MCP Registry** | [`com.clauderecall/recall`](https://registry.modelcontextprotocol.io/v0/servers?search=clauderecall) | Auto-discovered by MCP clients |
658
616
  | **Claude Code Plugin Hub** | `claude-recall` | `/plugin install claude-recall` in Claude Code |
659
- | **Website** | [clauderecall.com](https://clauderecall.com) | -- |
617
+ | **Website** | [clauderecall.com](https://clauderecall.com) | |
660
618
 
661
- The npm package ships **the CLI and the MCP server**. The VS Code extension is a thin companion that talks to the local daemon over `127.0.0.1`. The MCP Registry and Claude Code Plugin Hub both point back to the npm package -- one source of truth, one update pipeline.
619
+ The npm package ships **the CLI and the MCP server**. The VS Code extension is a thin companion that talks to the local daemon over `127.0.0.1`. The MCP Registry and Claude Code Plugin Hub both point back to the npm package: one source of truth, one update pipeline.
662
620
 
663
621
  <br />
664
622
 
@@ -670,14 +628,9 @@ The npm package ships **the CLI and the MCP server**. The VS Code extension is a
670
628
 
671
629
  One tier is free forever. One tier is a **one-time** purchase that works offline for life, even if we disappear. One tier is a conversation.
672
630
 
673
- <table>
674
- <tr>
675
- <td width="33%" valign="top">
676
-
677
631
  ### Free
678
632
 
679
- **$0**
680
- Forever. No signup. No credit card.
633
+ **$0.** Forever. No signup. No credit card.
681
634
 
682
635
  - Full indexing of every `~/.claude/projects/` JSON-L
683
636
  - CLI: `list`, `show`, `projects`, `status`
@@ -688,14 +641,9 @@ Forever. No signup. No credit card.
688
641
  npm install -g @clauderecallhq/cli
689
642
  ```
690
643
 
691
- </td>
692
- <td width="33%" valign="top">
644
+ ### Pro (daily driver)
693
645
 
694
- ### Pro &nbsp;<sub>← daily driver</sub>
695
-
696
- **$29.69 one-time** through May 2026 (Founder pricing)
697
- **$49.69 one-time** from June 2026 (standard)
698
- Pay once. Offline forever. Lifetime updates. Dead-man clause included. Never a subscription.
646
+ **$29.69 one-time** through May 2026 (Founder pricing). **$49.69 one-time** from June 2026 (standard). Pay once. Offline forever. Lifetime updates. Dead-man clause included. Never a subscription.
699
647
 
700
648
  - Full-text search (FTS5 BM25)
701
649
  - On-device semantic vector search (768d, RRF fusion)
@@ -709,15 +657,11 @@ Pay once. Offline forever. Lifetime updates. Dead-man clause included. Never a s
709
657
  - Secrets redaction (client-side scrub of keys, tokens, passwords pre-index)
710
658
  - **Every future personal-use feature.** One price, lifetime updates.
711
659
 
712
- [**Buy Pro for $29.69 (Founder pricing through May) →**](https://clauderecall.com/pricing)
713
-
714
- </td>
715
- <td width="33%" valign="top">
660
+ [**Buy Pro for $29.69 (Founder pricing through May)**](https://clauderecall.com/pricing)
716
661
 
717
662
  ### Enterprise
718
663
 
719
- **Contact us**
720
- Built for 50+ developer organizations.
664
+ **Contact us.** Built for 50+ developer organizations.
721
665
 
722
666
  - Shared session library with end-to-end encrypted team sync
723
667
  - Team-wide tag conventions
@@ -728,10 +672,6 @@ Built for 50+ developer organizations.
728
672
 
729
673
  [hello@clauderecall.com](mailto:hello@clauderecall.com)
730
674
 
731
- </td>
732
- </tr>
733
- </table>
734
-
735
675
  <br />
736
676
 
737
677
  ### How it compares to what you already pay
@@ -750,7 +690,7 @@ Built for 50+ developer organizations.
750
690
 
751
691
  ### The dead-man clause
752
692
 
753
- Your Pro license validates against our server exactly once, at activation. After that, Recall works **offline forever**. If `clauderecall.com` ever disappears, every existing license stays valid -- we'll publish the validation secret if we ever shut down, so you're never stranded.
693
+ Your Pro license validates against our server exactly once, at activation. After that, Recall works **offline forever**. If `clauderecall.com` ever disappears, every existing license stays valid; we'll publish the validation secret if we ever shut down, so you're never stranded.
754
694
 
755
695
  Full pricing FAQ: **[clauderecall.com/pricing](https://clauderecall.com/pricing)**
756
696
 
@@ -777,7 +717,7 @@ Full pricing FAQ: **[clauderecall.com/pricing](https://clauderecall.com/pricing)
777
717
  - [x] First-60-seconds onboarding
778
718
  - [x] Rediscovery surface ("For you" cards)
779
719
  - [x] **On-device vector search** (768d ONNX embeddings, RRF fusion)
780
- - [x] **Threads** -- DAG view, drag-to-reparent, bulk title generation
720
+ - [x] **Threads.** DAG view, drag-to-reparent, bulk title generation
781
721
  - [x] **Pro license + dead-man clause** (offline-validatable JWT)
782
722
  - [x] Memory health scores
783
723
  - [x] Claude Code plugin manifest
@@ -791,19 +731,26 @@ Full pricing FAQ: **[clauderecall.com/pricing](https://clauderecall.com/pricing)
791
731
 
792
732
  <br />
793
733
 
734
+ ## License
735
+
736
+ Proprietary. Free tier is free forever for personal use. Pro is a one-time purchase with offline-validatable JWT and a dead-man clause: if `clauderecall.com` ever shuts down, every existing license stays valid and the validation secret will be published so you're never stranded. Full terms at [clauderecall.com/terms](https://clauderecall.com/terms).
737
+
738
+ <br />
739
+
740
+ ---
741
+
742
+ <br />
743
+
794
744
  <div align="center">
795
745
 
796
- <picture>
797
- <source media="(prefers-color-scheme: dark)" srcset="https://clauderecall.com/mark-scrollback-dark.svg">
798
- <img src="https://clauderecall.com/mark-scrollback-dark.svg" alt="Claude Recall" width="48">
799
- </picture>
746
+ <img src="https://clauderecall.com/mark-scrollback-dark.svg" alt="Claude Recall" width="48">
800
747
 
801
748
  <br />
802
749
  <br />
803
750
 
804
- **Claude Recall** -- the memory layer for the agent you're steering.
751
+ **Claude Recall.** The memory layer for the agent you're steering.
805
752
 
806
- [Website](https://clauderecall.com) &nbsp;&middot;&nbsp; [Install](https://www.npmjs.com/package/@clauderecallhq/cli) &nbsp;&middot;&nbsp; [Issues](https://gitlab.com/clauderecallhq/clauderecallhq/-/issues)
753
+ [Website](https://clauderecall.com) · [Install](https://www.npmjs.com/package/@clauderecallhq/cli) · [Issues](https://gitlab.com/clauderecallhq/clauderecallhq/-/issues)
807
754
 
808
755
  <br />
809
756