@clauderecallhq/cli 0.0.1 → 0.12.0
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/LICENSE +33 -0
- package/README.md +543 -3
- package/README.public.md +523 -0
- package/dist/cli.js +362 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/activate.js +69 -0
- package/dist/commands/activate.js.map +1 -0
- package/dist/commands/audit-secrets.js +103 -0
- package/dist/commands/audit-secrets.js.map +1 -0
- package/dist/commands/blame.js +35 -0
- package/dist/commands/blame.js.map +1 -0
- package/dist/commands/config-verification.js +18 -0
- package/dist/commands/config-verification.js.map +1 -0
- package/dist/commands/context.js +144 -0
- package/dist/commands/context.js.map +1 -0
- package/dist/commands/correlate.js +70 -0
- package/dist/commands/correlate.js.map +1 -0
- package/dist/commands/digest.js +78 -0
- package/dist/commands/digest.js.map +1 -0
- package/dist/commands/health.js +62 -0
- package/dist/commands/health.js.map +1 -0
- package/dist/commands/index.js +247 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/install-extension.js +138 -0
- package/dist/commands/install-extension.js.map +1 -0
- package/dist/commands/installs.js +128 -0
- package/dist/commands/installs.js.map +1 -0
- package/dist/commands/license.js +39 -0
- package/dist/commands/license.js.map +1 -0
- package/dist/commands/list.js +47 -0
- package/dist/commands/list.js.map +1 -0
- package/dist/commands/mcp.js +29 -0
- package/dist/commands/mcp.js.map +1 -0
- package/dist/commands/open.js +28 -0
- package/dist/commands/open.js.map +1 -0
- package/dist/commands/paste.js +154 -0
- package/dist/commands/paste.js.map +1 -0
- package/dist/commands/projects.js +36 -0
- package/dist/commands/projects.js.map +1 -0
- package/dist/commands/search.js +67 -0
- package/dist/commands/search.js.map +1 -0
- package/dist/commands/semantic.js +173 -0
- package/dist/commands/semantic.js.map +1 -0
- package/dist/commands/show.js +121 -0
- package/dist/commands/show.js.map +1 -0
- package/dist/commands/start.js +47 -0
- package/dist/commands/start.js.map +1 -0
- package/dist/commands/stats.js +133 -0
- package/dist/commands/stats.js.map +1 -0
- package/dist/commands/status.js +45 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/stop.js +29 -0
- package/dist/commands/stop.js.map +1 -0
- package/dist/commands/thread.js +396 -0
- package/dist/commands/thread.js.map +1 -0
- package/dist/context/formatter.js +103 -0
- package/dist/context/formatter.js.map +1 -0
- package/dist/daemon/auto-tag-config.js +103 -0
- package/dist/daemon/auto-tag-config.js.map +1 -0
- package/dist/daemon/auto-tag-config.test.js +72 -0
- package/dist/daemon/auto-tag-config.test.js.map +1 -0
- package/dist/daemon/auto-title-config.js +70 -0
- package/dist/daemon/auto-title-config.js.map +1 -0
- package/dist/daemon/bulk-title-jobs.js +170 -0
- package/dist/daemon/bulk-title-jobs.js.map +1 -0
- package/dist/daemon/correlator.js +320 -0
- package/dist/daemon/correlator.js.map +1 -0
- package/dist/daemon/discover.js +316 -0
- package/dist/daemon/discover.js.map +1 -0
- package/dist/daemon/editor-detection.js +186 -0
- package/dist/daemon/editor-detection.js.map +1 -0
- package/dist/daemon/entrypoint.js +55 -0
- package/dist/daemon/entrypoint.js.map +1 -0
- package/dist/daemon/git-correlator.js +256 -0
- package/dist/daemon/git-correlator.js.map +1 -0
- package/dist/daemon/mcp-installer.js +108 -0
- package/dist/daemon/mcp-installer.js.map +1 -0
- package/dist/daemon/onboarding-state.js +140 -0
- package/dist/daemon/onboarding-state.js.map +1 -0
- package/dist/daemon/pidfile.js +57 -0
- package/dist/daemon/pidfile.js.map +1 -0
- package/dist/daemon/ports.js +48 -0
- package/dist/daemon/ports.js.map +1 -0
- package/dist/daemon/scanProgressRegistry.js +62 -0
- package/dist/daemon/scanProgressRegistry.js.map +1 -0
- package/dist/daemon/server.js +2010 -0
- package/dist/daemon/server.js.map +1 -0
- package/dist/daemon/tag-scanner/anthropic-client.js +40 -0
- package/dist/daemon/tag-scanner/anthropic-client.js.map +1 -0
- package/dist/daemon/tag-scanner/autopilot.js +131 -0
- package/dist/daemon/tag-scanner/autopilot.js.map +1 -0
- package/dist/daemon/tag-scanner/claude-cli-driver.js +250 -0
- package/dist/daemon/tag-scanner/claude-cli-driver.js.map +1 -0
- package/dist/daemon/tag-scanner/orchestrator.js +88 -0
- package/dist/daemon/tag-scanner/orchestrator.js.map +1 -0
- package/dist/daemon/tag-scanner/prompt.js +46 -0
- package/dist/daemon/tag-scanner/prompt.js.map +1 -0
- package/dist/daemon/tag-scanner/prompt.test.js +48 -0
- package/dist/daemon/tag-scanner/prompt.test.js.map +1 -0
- package/dist/daemon/tag-scanner/scan-state.js +49 -0
- package/dist/daemon/tag-scanner/scan-state.js.map +1 -0
- package/dist/daemon/tag-scanner/session-fetcher.js +82 -0
- package/dist/daemon/tag-scanner/session-fetcher.js.map +1 -0
- package/dist/daemon/tag-scanner/session-fetcher.test.js +34 -0
- package/dist/daemon/tag-scanner/session-fetcher.test.js.map +1 -0
- package/dist/daemon/tag-scanner/validator.js +50 -0
- package/dist/daemon/tag-scanner/validator.js.map +1 -0
- package/dist/daemon/tag-scanner/validator.test.js +41 -0
- package/dist/daemon/tag-scanner/validator.test.js.map +1 -0
- package/dist/daemon/terminal-registry.js +443 -0
- package/dist/daemon/terminal-registry.js.map +1 -0
- package/dist/daemon/ui.js +64 -0
- package/dist/daemon/ui.js.map +1 -0
- package/dist/daemon/watcher.js +256 -0
- package/dist/daemon/watcher.js.map +1 -0
- package/dist/db/client.js +22 -0
- package/dist/db/client.js.map +1 -0
- package/dist/db/schema.js +496 -0
- package/dist/db/schema.js.map +1 -0
- package/dist/license/api-base.js +13 -0
- package/dist/license/api-base.js.map +1 -0
- package/dist/license/manager.js +43 -0
- package/dist/license/manager.js.map +1 -0
- package/dist/license/public-key.js +19 -0
- package/dist/license/public-key.js.map +1 -0
- package/dist/license/storage.js +27 -0
- package/dist/license/storage.js.map +1 -0
- package/dist/license/verify.js +23 -0
- package/dist/license/verify.js.map +1 -0
- package/dist/mcp/audit.js +126 -0
- package/dist/mcp/audit.js.map +1 -0
- package/dist/mcp/prompts.js +180 -0
- package/dist/mcp/prompts.js.map +1 -0
- package/dist/mcp/server.js +502 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/thread-tools.js +363 -0
- package/dist/mcp/thread-tools.js.map +1 -0
- package/dist/mcp/write-tools.js +239 -0
- package/dist/mcp/write-tools.js.map +1 -0
- package/dist/parser/jsonl.js +150 -0
- package/dist/parser/jsonl.js.map +1 -0
- package/dist/semantic/chunker.js +47 -0
- package/dist/semantic/chunker.js.map +1 -0
- package/dist/semantic/config.js +74 -0
- package/dist/semantic/config.js.map +1 -0
- package/dist/semantic/embedder.js +54 -0
- package/dist/semantic/embedder.js.map +1 -0
- package/dist/semantic/fusion.js +38 -0
- package/dist/semantic/fusion.js.map +1 -0
- package/dist/semantic/model-download.js +69 -0
- package/dist/semantic/model-download.js.map +1 -0
- package/dist/semantic/pipeline.js +375 -0
- package/dist/semantic/pipeline.js.map +1 -0
- package/dist/semantic/query.js +42 -0
- package/dist/semantic/query.js.map +1 -0
- package/dist/semantic/worker.js +78 -0
- package/dist/semantic/worker.js.map +1 -0
- package/dist/stats/backfill.js +151 -0
- package/dist/stats/backfill.js.map +1 -0
- package/dist/stats/health.js +102 -0
- package/dist/stats/health.js.map +1 -0
- package/dist/stats/query.js +385 -0
- package/dist/stats/query.js.map +1 -0
- package/dist/utils/aliases.js +107 -0
- package/dist/utils/aliases.js.map +1 -0
- package/dist/utils/autoCollections.js +635 -0
- package/dist/utils/autoCollections.js.map +1 -0
- package/dist/utils/autoTitle.js +348 -0
- package/dist/utils/autoTitle.js.map +1 -0
- package/dist/utils/collections.js +446 -0
- package/dist/utils/collections.js.map +1 -0
- package/dist/utils/format.js +46 -0
- package/dist/utils/format.js.map +1 -0
- package/dist/utils/notes.js +270 -0
- package/dist/utils/notes.js.map +1 -0
- package/dist/utils/paths.js +50 -0
- package/dist/utils/paths.js.map +1 -0
- package/dist/utils/pricing.js +257 -0
- package/dist/utils/pricing.js.map +1 -0
- package/dist/utils/secret-scanner.js +166 -0
- package/dist/utils/secret-scanner.js.map +1 -0
- package/dist/utils/sessionLabel.js +64 -0
- package/dist/utils/sessionLabel.js.map +1 -0
- package/dist/utils/tags.js +97 -0
- package/dist/utils/tags.js.map +1 -0
- package/dist/utils/thread-context.js +129 -0
- package/dist/utils/thread-context.js.map +1 -0
- package/dist/utils/threadFilter.js +18 -0
- package/dist/utils/threadFilter.js.map +1 -0
- package/dist/utils/threads-titler.js +298 -0
- package/dist/utils/threads-titler.js.map +1 -0
- package/dist/utils/threads.js +383 -0
- package/dist/utils/threads.js.map +1 -0
- package/dist/utils/usage.js +76 -0
- package/dist/utils/usage.js.map +1 -0
- package/dist/verification/compute.js +88 -0
- package/dist/verification/compute.js.map +1 -0
- package/dist/verification/config.js +34 -0
- package/dist/verification/config.js.map +1 -0
- package/dist/web/assets/index-CIr6J4Fw.js +1201 -0
- package/dist/web/assets/index-Ctc8g9Jw.css +1 -0
- package/dist/web/assets/inter-cyrillic-400-normal-HOLc17fK.woff +0 -0
- package/dist/web/assets/inter-cyrillic-400-normal-obahsSVq.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-500-normal-BasfLYem.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-500-normal-CxZf_p3X.woff +0 -0
- package/dist/web/assets/inter-cyrillic-600-normal-4D_pXhcN.woff +0 -0
- package/dist/web/assets/inter-cyrillic-600-normal-CWCymEST.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-700-normal-CjBOestx.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-700-normal-DrXBdSj3.woff +0 -0
- package/dist/web/assets/inter-cyrillic-ext-400-normal-BQZuk6qB.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-ext-400-normal-DQukG94-.woff +0 -0
- package/dist/web/assets/inter-cyrillic-ext-500-normal-B0yAr1jD.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-ext-500-normal-BmqWE9Dz.woff +0 -0
- package/dist/web/assets/inter-cyrillic-ext-600-normal-Bcila6Z-.woff +0 -0
- package/dist/web/assets/inter-cyrillic-ext-600-normal-Dfes3d0z.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-ext-700-normal-BjwYoWNd.woff2 +0 -0
- package/dist/web/assets/inter-cyrillic-ext-700-normal-LO58E6JB.woff +0 -0
- package/dist/web/assets/inter-greek-400-normal-B4URO6DV.woff2 +0 -0
- package/dist/web/assets/inter-greek-400-normal-q2sYcFCs.woff +0 -0
- package/dist/web/assets/inter-greek-500-normal-BIZE56-Y.woff2 +0 -0
- package/dist/web/assets/inter-greek-500-normal-Xzm54t5V.woff +0 -0
- package/dist/web/assets/inter-greek-600-normal-BZpKdvQh.woff +0 -0
- package/dist/web/assets/inter-greek-600-normal-plRanbMR.woff2 +0 -0
- package/dist/web/assets/inter-greek-700-normal-BUv2fZ6O.woff +0 -0
- package/dist/web/assets/inter-greek-700-normal-C3JjAnD8.woff2 +0 -0
- package/dist/web/assets/inter-greek-ext-400-normal-DGGRlc-M.woff2 +0 -0
- package/dist/web/assets/inter-greek-ext-400-normal-KugGGMne.woff +0 -0
- package/dist/web/assets/inter-greek-ext-500-normal-2j5mBUwD.woff +0 -0
- package/dist/web/assets/inter-greek-ext-500-normal-C4iEst2y.woff2 +0 -0
- package/dist/web/assets/inter-greek-ext-600-normal-B8X0CLgF.woff +0 -0
- package/dist/web/assets/inter-greek-ext-600-normal-DRtmH8MT.woff2 +0 -0
- package/dist/web/assets/inter-greek-ext-700-normal-BoQ6DsYi.woff +0 -0
- package/dist/web/assets/inter-greek-ext-700-normal-qfdV9bQt.woff2 +0 -0
- package/dist/web/assets/inter-latin-400-normal-C38fXH4l.woff2 +0 -0
- package/dist/web/assets/inter-latin-400-normal-CyCys3Eg.woff +0 -0
- package/dist/web/assets/inter-latin-500-normal-BL9OpVg8.woff +0 -0
- package/dist/web/assets/inter-latin-500-normal-Cerq10X2.woff2 +0 -0
- package/dist/web/assets/inter-latin-600-normal-CiBQ2DWP.woff +0 -0
- package/dist/web/assets/inter-latin-600-normal-LgqL8muc.woff2 +0 -0
- package/dist/web/assets/inter-latin-700-normal-BLAVimhd.woff +0 -0
- package/dist/web/assets/inter-latin-700-normal-Yt3aPRUw.woff2 +0 -0
- package/dist/web/assets/inter-latin-ext-400-normal-77YHD8bZ.woff +0 -0
- package/dist/web/assets/inter-latin-ext-400-normal-C1nco2VV.woff2 +0 -0
- package/dist/web/assets/inter-latin-ext-500-normal-BxGbmqWO.woff +0 -0
- package/dist/web/assets/inter-latin-ext-500-normal-CV4jyFjo.woff2 +0 -0
- package/dist/web/assets/inter-latin-ext-600-normal-CIVaiw4L.woff +0 -0
- package/dist/web/assets/inter-latin-ext-600-normal-D2bJ5OIk.woff2 +0 -0
- package/dist/web/assets/inter-latin-ext-700-normal-Ca8adRJv.woff2 +0 -0
- package/dist/web/assets/inter-latin-ext-700-normal-TidjK2hL.woff +0 -0
- package/dist/web/assets/inter-vietnamese-400-normal-Bbgyi5SW.woff +0 -0
- package/dist/web/assets/inter-vietnamese-400-normal-DMkecbls.woff2 +0 -0
- package/dist/web/assets/inter-vietnamese-500-normal-DOriooB6.woff2 +0 -0
- package/dist/web/assets/inter-vietnamese-500-normal-mJboJaSs.woff +0 -0
- package/dist/web/assets/inter-vietnamese-600-normal-BuLX-rYi.woff +0 -0
- package/dist/web/assets/inter-vietnamese-600-normal-Cc8MFFhd.woff2 +0 -0
- package/dist/web/assets/inter-vietnamese-700-normal-BZaoP0fm.woff +0 -0
- package/dist/web/assets/inter-vietnamese-700-normal-DlLaEgI2.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-cyrillic-400-normal-BEIGL1Tu.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-cyrillic-400-normal-ugxPyKxw.woff +0 -0
- package/dist/web/assets/jetbrains-mono-cyrillic-500-normal-DJqRU3vO.woff +0 -0
- package/dist/web/assets/jetbrains-mono-cyrillic-500-normal-DmUKJPL_.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-greek-400-normal-B9oWc5Lo.woff +0 -0
- package/dist/web/assets/jetbrains-mono-greek-400-normal-C190GLew.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-greek-500-normal-D7SFKleX.woff +0 -0
- package/dist/web/assets/jetbrains-mono-greek-500-normal-JpySY46c.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-latin-400-normal-6-qcROiO.woff +0 -0
- package/dist/web/assets/jetbrains-mono-latin-400-normal-V6pRDFza.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-latin-500-normal-BWZEU5yA.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-latin-500-normal-CJOVTJB7.woff +0 -0
- package/dist/web/assets/jetbrains-mono-latin-ext-400-normal-Bc8Ftmh3.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-latin-ext-400-normal-fXTG6kC5.woff +0 -0
- package/dist/web/assets/jetbrains-mono-latin-ext-500-normal-Cut-4mMH.woff2 +0 -0
- package/dist/web/assets/jetbrains-mono-latin-ext-500-normal-ckzbgY84.woff +0 -0
- package/dist/web/assets/jetbrains-mono-vietnamese-400-normal-CqNFfHCs.woff +0 -0
- package/dist/web/assets/jetbrains-mono-vietnamese-500-normal-DNRqzVM1.woff +0 -0
- package/dist/web/favicon.svg +9 -0
- package/dist/web/index.html +15 -0
- package/package.json +80 -9
- package/bin/cli.js +0 -12
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import Table from 'cli-table3';
|
|
2
|
+
import { getDb } from '../db/client.js';
|
|
3
|
+
import { c, timeAgo, truncate } from '../utils/format.js';
|
|
4
|
+
export function runProjects() {
|
|
5
|
+
const db = getDb();
|
|
6
|
+
const rows = db
|
|
7
|
+
.prepare(`SELECT p.name,
|
|
8
|
+
p.decoded_path,
|
|
9
|
+
COUNT(s.id) AS session_count,
|
|
10
|
+
COALESCE(SUM(s.message_count), 0) AS message_count,
|
|
11
|
+
MAX(s.started_at) AS latest
|
|
12
|
+
FROM projects p
|
|
13
|
+
LEFT JOIN sessions s ON s.project_id = p.id
|
|
14
|
+
GROUP BY p.id
|
|
15
|
+
ORDER BY MAX(COALESCE(s.started_at, '')) DESC`)
|
|
16
|
+
.all();
|
|
17
|
+
if (rows.length === 0) {
|
|
18
|
+
console.log(c.dim('no projects indexed yet.'));
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const table = new Table({
|
|
22
|
+
head: [c.bold('project'), c.bold('sessions'), c.bold('msgs'), c.bold('latest'), c.bold('path')],
|
|
23
|
+
style: { head: [], border: ['grey'] },
|
|
24
|
+
});
|
|
25
|
+
for (const r of rows) {
|
|
26
|
+
table.push([
|
|
27
|
+
c.project(truncate(r.name, 30)),
|
|
28
|
+
String(r.session_count),
|
|
29
|
+
String(r.message_count),
|
|
30
|
+
c.dim(timeAgo(r.latest)),
|
|
31
|
+
c.dim(truncate(r.decoded_path, 50)),
|
|
32
|
+
]);
|
|
33
|
+
}
|
|
34
|
+
console.log(table.toString());
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=projects.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projects.js","sourceRoot":"","sources":["../../src/commands/projects.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,YAAY,CAAC;AAC/B,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAU1D,MAAM,UAAU,WAAW;IACzB,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IACnB,MAAM,IAAI,GAAG,EAAE;SACZ,OAAO,CACN;;;;;;;;qDAQ+C,CAChD;SACA,GAAG,EAAkB,CAAC;IAEzB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC,CAAC;QAC/C,OAAO;IACT,CAAC;IAED,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC;QACtB,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/F,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE;KACtC,CAAC,CAAC;IACH,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;QACrB,KAAK,CAAC,IAAI,CAAC;YACT,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC;YACvB,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC;YACvB,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACxB,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;SACpC,CAAC,CAAC;IACL,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;AAChC,CAAC"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { getDb } from '../db/client.js';
|
|
2
|
+
import { c, highlight, shortId, timeAgo, truncate } from '../utils/format.js';
|
|
3
|
+
import { requireProOrExit } from '../license/manager.js';
|
|
4
|
+
function sanitizeFtsQuery(query) {
|
|
5
|
+
// Wrap each term in quotes for safety; join with AND semantics.
|
|
6
|
+
const terms = query
|
|
7
|
+
.split(/\s+/)
|
|
8
|
+
.filter(Boolean)
|
|
9
|
+
.map((t) => t.replace(/"/g, ''))
|
|
10
|
+
.filter((t) => t.length > 0);
|
|
11
|
+
if (terms.length === 0)
|
|
12
|
+
return '';
|
|
13
|
+
return terms.map((t) => `"${t}"`).join(' ');
|
|
14
|
+
}
|
|
15
|
+
export async function runSearch(query, options) {
|
|
16
|
+
await requireProOrExit('Full-text search');
|
|
17
|
+
const db = getDb();
|
|
18
|
+
const ftsQuery = sanitizeFtsQuery(query);
|
|
19
|
+
if (!ftsQuery) {
|
|
20
|
+
console.log(c.dim('empty query'));
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const limit = Math.max(1, Math.min(200, parseInt(options.limit ?? '20', 10) || 20));
|
|
24
|
+
const params = { q: ftsQuery, limit };
|
|
25
|
+
let projectFilter = '';
|
|
26
|
+
if (options.project) {
|
|
27
|
+
projectFilter = ' AND (p.name LIKE @proj OR p.decoded_path LIKE @proj) ';
|
|
28
|
+
params.proj = `%${options.project}%`;
|
|
29
|
+
}
|
|
30
|
+
const rows = db
|
|
31
|
+
.prepare(`SELECT m.session_id AS session_id,
|
|
32
|
+
p.name AS project_name,
|
|
33
|
+
s.started_at AS started_at,
|
|
34
|
+
snippet(messages_fts, 0, '<<', '>>', '…', 16) AS snippet,
|
|
35
|
+
m.role AS role,
|
|
36
|
+
m.timestamp AS timestamp
|
|
37
|
+
FROM messages_fts
|
|
38
|
+
JOIN messages m ON m.rowid = messages_fts.rowid
|
|
39
|
+
JOIN sessions s ON s.id = m.session_id
|
|
40
|
+
JOIN projects p ON p.id = s.project_id
|
|
41
|
+
WHERE messages_fts MATCH @q
|
|
42
|
+
${projectFilter}
|
|
43
|
+
ORDER BY bm25(messages_fts)
|
|
44
|
+
LIMIT @limit`)
|
|
45
|
+
.all(params);
|
|
46
|
+
if (rows.length === 0) {
|
|
47
|
+
console.log(c.dim(`no matches for "${query}"`));
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
console.log(c.dim(`${rows.length} match${rows.length === 1 ? '' : 'es'} for "${query}"`));
|
|
51
|
+
console.log('');
|
|
52
|
+
for (const hit of rows) {
|
|
53
|
+
const snippet = hit.snippet
|
|
54
|
+
.replace(/<<([\s\S]*?)>>/g, (_, s) => highlight(s, s).replace(/\n/g, ' '))
|
|
55
|
+
.replace(/\n/g, ' ');
|
|
56
|
+
const roleTag = hit.role === 'user'
|
|
57
|
+
? c.user('user')
|
|
58
|
+
: hit.role === 'assistant'
|
|
59
|
+
? c.assistant('asst')
|
|
60
|
+
: c.dim('----');
|
|
61
|
+
console.log(`${c.accent(shortId(hit.session_id))} ${c.project(truncate(hit.project_name, 20))} ${c.dim(timeAgo(hit.started_at))} ${roleTag}`);
|
|
62
|
+
console.log(` ${truncate(snippet, 200)}`);
|
|
63
|
+
console.log('');
|
|
64
|
+
}
|
|
65
|
+
console.log(c.dim('`recall show <id>` to read any session.'));
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=search.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.js","sourceRoot":"","sources":["../../src/commands/search.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAgBzD,SAAS,gBAAgB,CAAC,KAAa;IACrC,gEAAgE;IAChE,MAAM,KAAK,GAAG,KAAK;SAChB,KAAK,CAAC,KAAK,CAAC;SACZ,MAAM,CAAC,OAAO,CAAC;SACf,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;SAC/B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC/B,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAClC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,KAAa,EAAE,OAAsB;IACnE,MAAM,gBAAgB,CAAC,kBAAkB,CAAC,CAAC;IAC3C,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IACnB,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACzC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC;QAClC,OAAO;IACT,CAAC;IACD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAEpF,MAAM,MAAM,GAA4B,EAAE,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC/D,IAAI,aAAa,GAAG,EAAE,CAAC;IACvB,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QACpB,aAAa,GAAG,wDAAwD,CAAC;QACzE,MAAM,CAAC,IAAI,GAAG,IAAI,OAAO,CAAC,OAAO,GAAG,CAAC;IACvC,CAAC;IAED,MAAM,IAAI,GAAG,EAAE;SACZ,OAAO,CACN;;;;;;;;;;;WAWK,aAAa;;oBAEJ,CACf;SACA,GAAG,CAAC,MAAM,CAAU,CAAC;IAExB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,mBAAmB,KAAK,GAAG,CAAC,CAAC,CAAC;QAChD,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,SAAS,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,SAAS,KAAK,GAAG,CAAC,CAAC,CAAC;IAC1F,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO;aACxB,OAAO,CAAC,iBAAiB,EAAE,CAAC,CAAC,EAAE,CAAS,EAAE,EAAE,CAC3C,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CACpC;aACA,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QACvB,MAAM,OAAO,GACX,GAAG,CAAC,IAAI,KAAK,MAAM;YACjB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;YAChB,CAAC,CAAC,GAAG,CAAC,IAAI,KAAK,WAAW;gBACxB,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC;gBACrB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACtB,OAAO,CAAC,GAAG,CACT,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,OAAO,EAAE,CACpI,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,KAAK,QAAQ,CAAC,OAAO,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;QAC3C,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,yCAAyC,CAAC,CAAC,CAAC;AAChE,CAAC"}
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import { readSemanticConfig, writeSemanticConfig } from '../semantic/config.js';
|
|
2
|
+
import { backfill, getSemanticStatus } from '../semantic/pipeline.js';
|
|
3
|
+
import { isClaudeCliAvailable } from '../daemon/tag-scanner/claude-cli-driver.js';
|
|
4
|
+
import { isModelInstalled, downloadModel, uninstallModel } from '../semantic/model-download.js';
|
|
5
|
+
import { loadEmbedder, getEmbedderStatus, embed } from '../semantic/embedder.js';
|
|
6
|
+
import { getWorkerStatus } from '../semantic/worker.js';
|
|
7
|
+
import { chunkSession } from '../semantic/chunker.js';
|
|
8
|
+
import { getDb } from '../db/client.js';
|
|
9
|
+
import { requireProOrExit } from '../license/manager.js';
|
|
10
|
+
export async function runSemantic(action, opts) {
|
|
11
|
+
const cmd = (action ?? 'status').toLowerCase();
|
|
12
|
+
if (cmd === 'on' || cmd === 'enable') {
|
|
13
|
+
if (!isClaudeCliAvailable()) {
|
|
14
|
+
console.error('claude CLI not found on PATH. Install Claude Code first, then re-run.');
|
|
15
|
+
process.exitCode = 1;
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const patch = { enabled: true };
|
|
19
|
+
if (opts.rate)
|
|
20
|
+
patch.ratePerMinute = Number(opts.rate);
|
|
21
|
+
if (opts.model)
|
|
22
|
+
patch.model = opts.model;
|
|
23
|
+
const cfg = writeSemanticConfig(patch);
|
|
24
|
+
console.log('Semantic search: ENABLED');
|
|
25
|
+
console.log(` Rate: ${cfg.ratePerMinute}/min`);
|
|
26
|
+
if (cfg.model)
|
|
27
|
+
console.log(` Model: ${cfg.model}`);
|
|
28
|
+
console.log('');
|
|
29
|
+
console.log('Disclosure: enabling semantic search sends condensed session');
|
|
30
|
+
console.log('summaries to Claude via your local `claude` CLI using your existing');
|
|
31
|
+
console.log('plan. New sessions are summarized on close. Run `recall semantic backfill`');
|
|
32
|
+
console.log('to summarize the existing archive.');
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
if (cmd === 'off' || cmd === 'disable') {
|
|
36
|
+
writeSemanticConfig({ enabled: false });
|
|
37
|
+
console.log('Semantic search: DISABLED');
|
|
38
|
+
console.log('Existing summaries are kept in the database; the pipeline will not run.');
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
if (cmd === 'pause') {
|
|
42
|
+
writeSemanticConfig({ backfillPaused: true });
|
|
43
|
+
console.log('Backfill paused. Resume with `recall semantic resume`.');
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
if (cmd === 'resume') {
|
|
47
|
+
writeSemanticConfig({ backfillPaused: false });
|
|
48
|
+
console.log('Backfill resumed.');
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
if (cmd === 'backfill') {
|
|
52
|
+
const cfg = readSemanticConfig();
|
|
53
|
+
if (!cfg.enabled) {
|
|
54
|
+
console.error('Semantic search is disabled. Run `recall semantic on` first.');
|
|
55
|
+
process.exitCode = 1;
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
if (cfg.backfillPaused) {
|
|
59
|
+
writeSemanticConfig({ backfillPaused: false });
|
|
60
|
+
}
|
|
61
|
+
const limit = opts.limit ? Math.max(1, Number(opts.limit)) : 1000;
|
|
62
|
+
const force = !!opts.force;
|
|
63
|
+
console.log(`Backfilling up to ${limit} sessions${force ? ' (force)' : ''}…`);
|
|
64
|
+
const start = Date.now();
|
|
65
|
+
let lastPrinted = 0;
|
|
66
|
+
const result = await backfill({
|
|
67
|
+
limit,
|
|
68
|
+
force,
|
|
69
|
+
onProgress: (snap) => {
|
|
70
|
+
if (snap.processed === lastPrinted)
|
|
71
|
+
return;
|
|
72
|
+
lastPrinted = snap.processed;
|
|
73
|
+
const pct = snap.total > 0 ? ` (${Math.round((snap.processed / snap.total) * 100)}%)` : '';
|
|
74
|
+
process.stdout.write(`\r ${snap.processed}/${snap.total}${pct} ok=${snap.ok} failed=${snap.failed} `);
|
|
75
|
+
},
|
|
76
|
+
});
|
|
77
|
+
process.stdout.write('\n');
|
|
78
|
+
const elapsed = ((Date.now() - start) / 1000).toFixed(1);
|
|
79
|
+
console.log(`Done in ${elapsed}s — processed=${result.processed} ok=${result.ok} failed=${result.failed}`);
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
// v0.7 — vector model management
|
|
83
|
+
if (cmd === 'install') {
|
|
84
|
+
await requireProOrExit('Vector semantic search');
|
|
85
|
+
if (isModelInstalled()) {
|
|
86
|
+
console.log('Model already installed.');
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
console.log('Downloading bge-base-en-v1.5 (~110MB)...');
|
|
90
|
+
await downloadModel((file, downloaded, total) => {
|
|
91
|
+
const pct = total > 0 ? Math.round((downloaded / total) * 100) : 0;
|
|
92
|
+
process.stdout.write(`\r ${file}: ${pct}% `);
|
|
93
|
+
});
|
|
94
|
+
process.stdout.write('\n');
|
|
95
|
+
console.log('Model installed. Loading embedder...');
|
|
96
|
+
await loadEmbedder();
|
|
97
|
+
console.log('Done. Vector search is now active.');
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
if (cmd === 'uninstall') {
|
|
101
|
+
uninstallModel();
|
|
102
|
+
console.log('Model removed. Vector search will fall back to keyword search.');
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
if (cmd === 'reindex') {
|
|
106
|
+
await requireProOrExit('Vector reindex');
|
|
107
|
+
if (!getEmbedderStatus().loaded) {
|
|
108
|
+
if (!isModelInstalled()) {
|
|
109
|
+
console.error('Model not installed. Run `recall semantic install` first.');
|
|
110
|
+
process.exitCode = 1;
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
await loadEmbedder();
|
|
114
|
+
}
|
|
115
|
+
const db = getDb();
|
|
116
|
+
const sessions = db.prepare("SELECT id FROM sessions WHERE message_count >= 3").all();
|
|
117
|
+
console.log(`Reindexing ${sessions.length} sessions...`);
|
|
118
|
+
let processed = 0;
|
|
119
|
+
for (const { id } of sessions) {
|
|
120
|
+
const chunks = chunkSession(id);
|
|
121
|
+
if (chunks.length === 0) {
|
|
122
|
+
processed++;
|
|
123
|
+
continue;
|
|
124
|
+
}
|
|
125
|
+
const texts = chunks.map((c) => c.text);
|
|
126
|
+
const embeddings = await embed(texts);
|
|
127
|
+
db.prepare('DELETE FROM vec_chunks WHERE rowid IN (SELECT rowid FROM chunk_meta WHERE session_id = ?)').run(id);
|
|
128
|
+
db.prepare('DELETE FROM chunk_meta WHERE session_id = ?').run(id);
|
|
129
|
+
const insertMeta = db.prepare(`INSERT INTO chunk_meta(session_id, message_uuids, text, embedding_model_id, embedding_dim, stale, generated_at)
|
|
130
|
+
VALUES (?, ?, ?, 'bge-base-en-v1.5', 768, 0, datetime('now'))`);
|
|
131
|
+
const insertVec = db.prepare('INSERT INTO vec_chunks(rowid, embedding) VALUES (?, ?)');
|
|
132
|
+
for (let i = 0; i < chunks.length; i++) {
|
|
133
|
+
const info = insertMeta.run(id, JSON.stringify(chunks[i].messageUuids), chunks[i].text);
|
|
134
|
+
const buf = Buffer.from(embeddings[i].buffer, embeddings[i].byteOffset, embeddings[i].byteLength);
|
|
135
|
+
insertVec.run(info.lastInsertRowid, buf);
|
|
136
|
+
}
|
|
137
|
+
processed++;
|
|
138
|
+
if (processed % 10 === 0) {
|
|
139
|
+
process.stdout.write(`\r ${processed}/${sessions.length} `);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
process.stdout.write('\n');
|
|
143
|
+
console.log(`Reindexed ${processed} sessions.`);
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
// default: status
|
|
147
|
+
const status = getSemanticStatus();
|
|
148
|
+
console.log(`Semantic search: ${status.enabled ? 'ENABLED' : 'disabled'}`);
|
|
149
|
+
console.log(` claude CLI: ${status.claudeCliAvailable ? 'available' : 'NOT FOUND'}`);
|
|
150
|
+
console.log(` Rate: ${status.ratePerMinute}/min`);
|
|
151
|
+
console.log(` Model: ${status.model ?? 'claude default'}`);
|
|
152
|
+
console.log(` Sessions: ${status.processedSessions}/${status.totalSessions} summarized`);
|
|
153
|
+
console.log(` Pending: ${status.pendingSessions}`);
|
|
154
|
+
if (status.lastProcessedSessionId) {
|
|
155
|
+
console.log(` Cursor: ${status.lastProcessedSessionId}`);
|
|
156
|
+
}
|
|
157
|
+
if (status.backfillPaused) {
|
|
158
|
+
console.log(' Backfill: PAUSED (run `recall semantic resume`)');
|
|
159
|
+
}
|
|
160
|
+
// v0.7 vector tier status
|
|
161
|
+
const vectorInstalled = isModelInstalled();
|
|
162
|
+
const embedderStatus = getEmbedderStatus();
|
|
163
|
+
const workerStatus = getWorkerStatus();
|
|
164
|
+
console.log('');
|
|
165
|
+
console.log('Vector tier (Pro):');
|
|
166
|
+
console.log(` Model: ${vectorInstalled ? 'installed' : 'not installed'}`);
|
|
167
|
+
console.log(` Embedder: ${embedderStatus.loaded ? 'loaded' : 'not loaded'} (${embedderStatus.modelId}, ${embedderStatus.dim}d)`);
|
|
168
|
+
console.log(` Worker: ${workerStatus.running ? 'running' : 'stopped'} (queue: ${workerStatus.queueDepth})`);
|
|
169
|
+
if (process.env.RECALL_RRF_K) {
|
|
170
|
+
console.log(` RRF k: ${process.env.RECALL_RRF_K}`);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
//# sourceMappingURL=semantic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"semantic.js","sourceRoot":"","sources":["../../src/commands/semantic.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { spawn } from 'node:child_process';
|
|
2
|
+
import { getDb } from '../db/client.js';
|
|
3
|
+
import { c, timeAgo } from '../utils/format.js';
|
|
4
|
+
import { isVerificationEnabled } from '../verification/config.js';
|
|
5
|
+
import { getOrCompute } from '../verification/compute.js';
|
|
6
|
+
function resolveSessionId(db, prefix) {
|
|
7
|
+
if (prefix.length >= 32) {
|
|
8
|
+
const full = db.prepare('SELECT id FROM sessions WHERE id = ?').get(prefix);
|
|
9
|
+
return full?.id ?? null;
|
|
10
|
+
}
|
|
11
|
+
const matches = db
|
|
12
|
+
.prepare('SELECT id FROM sessions WHERE id LIKE ? LIMIT 2')
|
|
13
|
+
.all(prefix + '%');
|
|
14
|
+
if (matches.length === 1)
|
|
15
|
+
return matches[0].id;
|
|
16
|
+
if (matches.length === 0)
|
|
17
|
+
return null;
|
|
18
|
+
console.error(c.err(`ambiguous id prefix "${prefix}". be more specific.`));
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
function renderSession(sessionId, options) {
|
|
22
|
+
const db = getDb();
|
|
23
|
+
const session = db
|
|
24
|
+
.prepare(`SELECT s.id, p.name AS project_name, p.decoded_path,
|
|
25
|
+
s.started_at, s.ended_at, s.message_count,
|
|
26
|
+
s.git_branch, s.version, s.cwd
|
|
27
|
+
FROM sessions s
|
|
28
|
+
JOIN projects p ON p.id = s.project_id
|
|
29
|
+
WHERE s.id = ?`)
|
|
30
|
+
.get(sessionId);
|
|
31
|
+
if (!session)
|
|
32
|
+
return null;
|
|
33
|
+
const lines = [];
|
|
34
|
+
const hr = c.dim('─'.repeat(78));
|
|
35
|
+
lines.push('');
|
|
36
|
+
lines.push(c.bold(c.project(session.project_name)) + c.dim(` ${session.decoded_path}`));
|
|
37
|
+
lines.push(c.dim(`session ${session.id} · ${session.message_count} msgs · ${timeAgo(session.started_at)}` +
|
|
38
|
+
(session.git_branch ? ` · branch: ${session.git_branch}` : '')));
|
|
39
|
+
if (isVerificationEnabled()) {
|
|
40
|
+
const v = getOrCompute(sessionId);
|
|
41
|
+
if (v.status === 'verified')
|
|
42
|
+
lines.push(c.ok('✓ verified'));
|
|
43
|
+
else if (v.status === 'unverified')
|
|
44
|
+
lines.push(c.warn('⚠ unverified'));
|
|
45
|
+
}
|
|
46
|
+
lines.push(hr);
|
|
47
|
+
const limit = options.limit ? Math.max(1, parseInt(options.limit, 10) || 9999) : 9999;
|
|
48
|
+
const messages = db
|
|
49
|
+
.prepare(`SELECT uuid, type, role, timestamp, is_sidechain, content_text, tool_names, raw_json
|
|
50
|
+
FROM messages
|
|
51
|
+
WHERE session_id = ?
|
|
52
|
+
ORDER BY COALESCE(timestamp, ''), rowid
|
|
53
|
+
LIMIT ?`)
|
|
54
|
+
.all(sessionId, limit);
|
|
55
|
+
for (const m of messages) {
|
|
56
|
+
if (options.raw) {
|
|
57
|
+
lines.push(m.raw_json);
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
const isSub = m.is_sidechain === 1 ? c.dim(' [subagent]') : '';
|
|
61
|
+
const header = m.role === 'user'
|
|
62
|
+
? c.user('▸ user')
|
|
63
|
+
: m.role === 'assistant'
|
|
64
|
+
? c.assistant('▸ assistant')
|
|
65
|
+
: c.dim(`▸ ${m.type}`);
|
|
66
|
+
lines.push(`${header}${isSub} ${c.dim(m.timestamp ?? '')}`);
|
|
67
|
+
if (m.tool_names && m.tool_names.length > 0) {
|
|
68
|
+
lines.push(c.tool(` tools: ${m.tool_names}`));
|
|
69
|
+
}
|
|
70
|
+
if (m.content_text && m.content_text.trim()) {
|
|
71
|
+
const indented = m.content_text.trim().split('\n').map((l) => ' ' + l).join('\n');
|
|
72
|
+
lines.push(indented);
|
|
73
|
+
}
|
|
74
|
+
lines.push('');
|
|
75
|
+
}
|
|
76
|
+
lines.push(hr);
|
|
77
|
+
lines.push(c.dim(`end of session ${session.id}`));
|
|
78
|
+
return lines.join('\n');
|
|
79
|
+
}
|
|
80
|
+
function shouldPage(output, usePager) {
|
|
81
|
+
if (!usePager)
|
|
82
|
+
return false;
|
|
83
|
+
if (!process.stdout.isTTY)
|
|
84
|
+
return false;
|
|
85
|
+
const rows = process.stdout.rows || 24;
|
|
86
|
+
const lineCount = output.split('\n').length;
|
|
87
|
+
return lineCount > rows;
|
|
88
|
+
}
|
|
89
|
+
function pipeToLess(output) {
|
|
90
|
+
const less = spawn('less', ['-R', '-F', '-X'], { stdio: ['pipe', 'inherit', 'inherit'] });
|
|
91
|
+
less.stdin.on('error', () => {
|
|
92
|
+
/* pager exited early (e.g. user hit q) */
|
|
93
|
+
});
|
|
94
|
+
less.stdin.write(output);
|
|
95
|
+
less.stdin.end();
|
|
96
|
+
less.on('exit', () => process.exit(0));
|
|
97
|
+
}
|
|
98
|
+
export function runShow(idPrefix, options) {
|
|
99
|
+
const db = getDb();
|
|
100
|
+
const sessionId = resolveSessionId(db, idPrefix);
|
|
101
|
+
if (!sessionId) {
|
|
102
|
+
if (idPrefix.length >= 32)
|
|
103
|
+
console.error(c.err(`session not found: ${idPrefix}`));
|
|
104
|
+
process.exitCode = 1;
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
const output = renderSession(sessionId, options);
|
|
108
|
+
if (output === null) {
|
|
109
|
+
console.error(c.err(`session metadata missing for ${sessionId}`));
|
|
110
|
+
process.exitCode = 1;
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
const usePager = options.pager !== false;
|
|
114
|
+
if (shouldPage(output, usePager)) {
|
|
115
|
+
pipeToLess(output);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
console.log(output);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
//# sourceMappingURL=show.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show.js","sourceRoot":"","sources":["../../src/commands/show.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { spawn } from 'node:child_process';
|
|
2
|
+
import { openSync } from 'node:fs';
|
|
3
|
+
import { fileURLToPath } from 'node:url';
|
|
4
|
+
import { dirname, join } from 'node:path';
|
|
5
|
+
import { getRunningDaemon } from '../daemon/pidfile.js';
|
|
6
|
+
import { LOG_FILE } from '../daemon/pidfile.js';
|
|
7
|
+
import { ensureRecallHome } from '../utils/paths.js';
|
|
8
|
+
import { c } from '../utils/format.js';
|
|
9
|
+
function resolveDaemonScript() {
|
|
10
|
+
// cli.js and daemon/entrypoint.js ship in the same dist tree.
|
|
11
|
+
const here = dirname(fileURLToPath(import.meta.url));
|
|
12
|
+
// `here` is either src/commands (dev via tsx) or dist/commands (prod).
|
|
13
|
+
// Both resolve cleanly via `../daemon/entrypoint.(js|ts)`.
|
|
14
|
+
// The compiled output uses .js — tsx at dev-time resolves .ts transparently.
|
|
15
|
+
return join(here, '..', 'daemon', 'entrypoint.js');
|
|
16
|
+
}
|
|
17
|
+
export async function runStart() {
|
|
18
|
+
const existing = getRunningDaemon();
|
|
19
|
+
if (existing) {
|
|
20
|
+
console.log(`${c.ok('already running')} pid ${existing.pid} · http://127.0.0.1:${existing.port}`);
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
ensureRecallHome();
|
|
24
|
+
const logFd = openSync(LOG_FILE, 'a');
|
|
25
|
+
const script = resolveDaemonScript();
|
|
26
|
+
const child = spawn(process.execPath, [script], {
|
|
27
|
+
detached: true,
|
|
28
|
+
stdio: ['ignore', logFd, logFd],
|
|
29
|
+
env: { ...process.env },
|
|
30
|
+
});
|
|
31
|
+
child.unref();
|
|
32
|
+
// Poll briefly for the pid/port file so we can confirm to the user.
|
|
33
|
+
const start = Date.now();
|
|
34
|
+
while (Date.now() - start < 5000) {
|
|
35
|
+
await new Promise((r) => setTimeout(r, 150));
|
|
36
|
+
const info = getRunningDaemon();
|
|
37
|
+
if (info) {
|
|
38
|
+
console.log(`${c.ok('daemon started')} pid ${info.pid} · http://127.0.0.1:${info.port}`);
|
|
39
|
+
console.log(c.dim(`logs: ${LOG_FILE}`));
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
console.error(c.err('daemon did not come up within 5s — check the log file'));
|
|
44
|
+
console.error(c.dim(` ${LOG_FILE}`));
|
|
45
|
+
process.exitCode = 1;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=start.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"start.js","sourceRoot":"","sources":["../../src/commands/start.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,CAAC,EAAE,MAAM,oBAAoB,CAAC;AAEvC,SAAS,mBAAmB;IAC1B,8DAA8D;IAC9D,MAAM,IAAI,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IACrD,uEAAuE;IACvE,2DAA2D;IAC3D,6EAA6E;IAC7E,OAAO,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,eAAe,CAAC,CAAC;AACrD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,QAAQ;IAC5B,MAAM,QAAQ,GAAG,gBAAgB,EAAE,CAAC;IACpC,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,CAAC,GAAG,CACT,GAAG,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC,SAAS,QAAQ,CAAC,GAAG,yBAAyB,QAAQ,CAAC,IAAI,EAAE,CACxF,CAAC;QACF,OAAO;IACT,CAAC;IAED,gBAAgB,EAAE,CAAC;IACnB,MAAM,KAAK,GAAG,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IACtC,MAAM,MAAM,GAAG,mBAAmB,EAAE,CAAC;IAErC,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,EAAE;QAC9C,QAAQ,EAAE,IAAI;QACd,KAAK,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,CAAC;QAC/B,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE;KACxB,CAAC,CAAC;IACH,KAAK,CAAC,KAAK,EAAE,CAAC;IAEd,oEAAoE;IACpE,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,IAAI,EAAE,CAAC;QACjC,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QAC7C,MAAM,IAAI,GAAG,gBAAgB,EAAE,CAAC;QAChC,IAAI,IAAI,EAAE,CAAC;YACT,OAAO,CAAC,GAAG,CACT,GAAG,CAAC,CAAC,EAAE,CAAC,gBAAgB,CAAC,SAAS,IAAI,CAAC,GAAG,yBAAyB,IAAI,CAAC,IAAI,EAAE,CAC/E,CAAC;YACF,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,SAAS,QAAQ,EAAE,CAAC,CAAC,CAAC;YACxC,OAAO;QACT,CAAC;IACH,CAAC;IACD,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,uDAAuD,CAAC,CAAC,CAAC;IAC9E,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,QAAQ,EAAE,CAAC,CAAC,CAAC;IACtC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;AACvB,CAAC"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { getDb } from '../db/client.js';
|
|
2
|
+
import { c } from '../utils/format.js';
|
|
3
|
+
const formatNumber = (n) => n.toLocaleString();
|
|
4
|
+
import { formatDollars, formatTokens } from '../utils/pricing.js';
|
|
5
|
+
import { getOverviewStats, getProjectStats, getSessionStats, } from '../stats/query.js';
|
|
6
|
+
import { runBackfill } from '../stats/backfill.js';
|
|
7
|
+
function resolveSessionId(input) {
|
|
8
|
+
const db = getDb();
|
|
9
|
+
const row = db
|
|
10
|
+
.prepare('SELECT id FROM sessions WHERE id = ? OR id LIKE ? LIMIT 1')
|
|
11
|
+
.get(input, `${input}%`);
|
|
12
|
+
return row?.id ?? null;
|
|
13
|
+
}
|
|
14
|
+
export async function runStats(idArg, options) {
|
|
15
|
+
if (options.backfill) {
|
|
16
|
+
const limit = options.limit ? Math.max(1, Number(options.limit)) : undefined;
|
|
17
|
+
console.log(c.dim('backfilling per-message usage from raw_json…'));
|
|
18
|
+
const progress = runBackfill({ limit });
|
|
19
|
+
console.log(`${c.ok('backfill done')}: scanned ${c.bold(String(progress.scanned))}, inserted ${c.bold(String(progress.inserted))}, rolled-up ${c.bold(String(progress.sessionsTouched))} sessions`);
|
|
20
|
+
if (!idArg && !options.project)
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
if (idArg) {
|
|
24
|
+
const sid = resolveSessionId(idArg);
|
|
25
|
+
if (!sid) {
|
|
26
|
+
console.error(c.err(`no session matches '${idArg}'`));
|
|
27
|
+
process.exit(1);
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
const s = getSessionStats(sid);
|
|
31
|
+
if (!s) {
|
|
32
|
+
console.error(c.err('session has no usage data yet — try --backfill'));
|
|
33
|
+
process.exit(1);
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
if (options.json) {
|
|
37
|
+
console.log(JSON.stringify(s, null, 2));
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
console.log('');
|
|
41
|
+
console.log(c.bold('session cost'));
|
|
42
|
+
console.log(c.dim('────────────'));
|
|
43
|
+
console.log(` id ${c.dim(s.sessionId)}`);
|
|
44
|
+
console.log(` project ${c.accent(s.project ?? '—')}`);
|
|
45
|
+
console.log(` started ${c.dim(s.startedAt ?? 'n/a')}`);
|
|
46
|
+
console.log(` messages ${c.accent(formatNumber(s.messageCount))}`);
|
|
47
|
+
console.log(` model ${c.accent(s.primaryModelLabel)} ${c.dim(s.primaryModel ?? '')}`);
|
|
48
|
+
console.log('');
|
|
49
|
+
console.log(` input ${formatNumber(s.inputTokens).padStart(12)}`);
|
|
50
|
+
console.log(` output ${formatNumber(s.outputTokens).padStart(12)}`);
|
|
51
|
+
console.log(` cache write ${formatNumber(s.cacheCreateTokens).padStart(12)}`);
|
|
52
|
+
console.log(` cache read ${formatNumber(s.cacheReadTokens).padStart(12)}`);
|
|
53
|
+
console.log(` ──────────────────────────────`);
|
|
54
|
+
console.log(` total tokens ${c.bold(formatNumber(s.totalTokens).padStart(12))}`);
|
|
55
|
+
console.log(` estimated cost ${c.accent(formatDollars(s.cost.cents).padStart(12))}`);
|
|
56
|
+
if (s.byModel.length > 1) {
|
|
57
|
+
console.log('');
|
|
58
|
+
console.log(c.dim(' by model:'));
|
|
59
|
+
for (const m of s.byModel) {
|
|
60
|
+
console.log(` ${m.modelLabel.padEnd(14)} ${formatTokens(m.inputTokens + m.outputTokens + m.cacheCreateTokens + m.cacheReadTokens).padStart(10)} ${c.accent(formatDollars(m.cost.cents).padStart(10))}`);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
console.log('');
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
if (options.project) {
|
|
67
|
+
const p = getProjectStats(options.project);
|
|
68
|
+
if (!p) {
|
|
69
|
+
console.error(c.err(`project '${options.project}' not found`));
|
|
70
|
+
process.exit(1);
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
if (options.json) {
|
|
74
|
+
console.log(JSON.stringify(p, null, 2));
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
console.log('');
|
|
78
|
+
console.log(c.bold(`project · ${p.project}`));
|
|
79
|
+
console.log(c.dim('────────────────────────────'));
|
|
80
|
+
console.log(` sessions ${c.accent(formatNumber(p.sessionCount))}`);
|
|
81
|
+
console.log(` total tokens ${c.accent(formatTokens(p.totalTokens).padStart(12))}`);
|
|
82
|
+
console.log(` estimated cost ${c.accent(formatDollars(p.cost.cents).padStart(12))}`);
|
|
83
|
+
if (p.byModel.length > 0) {
|
|
84
|
+
console.log('');
|
|
85
|
+
console.log(c.dim(' by model:'));
|
|
86
|
+
for (const m of p.byModel) {
|
|
87
|
+
console.log(` ${m.modelLabel.padEnd(14)} ${formatTokens(m.inputTokens + m.outputTokens + m.cacheCreateTokens + m.cacheReadTokens).padStart(10)} ${c.accent(formatDollars(m.cost.cents).padStart(10))}`);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
if (p.topSessions.length > 0) {
|
|
91
|
+
console.log('');
|
|
92
|
+
console.log(c.dim(' top sessions:'));
|
|
93
|
+
for (const s of p.topSessions) {
|
|
94
|
+
const label = s.alias ?? s.sessionId.slice(0, 8);
|
|
95
|
+
console.log(` ${label.padEnd(22)} ${formatTokens(s.totalTokens).padStart(10)} ${c.accent(formatDollars(s.cost.cents).padStart(10))}`);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
console.log('');
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
const range = options.days === '7' ? '7d' : options.days === '30' ? '30d' : 'all';
|
|
102
|
+
const o = getOverviewStats(range);
|
|
103
|
+
if (options.json) {
|
|
104
|
+
console.log(JSON.stringify(o, null, 2));
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
console.log('');
|
|
108
|
+
console.log(c.bold(`overview · ${range}`));
|
|
109
|
+
console.log(c.dim('──────────────────────────────'));
|
|
110
|
+
console.log(` sessions ${c.accent(formatNumber(o.totalSessions))} ${c.dim(`(${o.sessionsWithUsage} w/ usage)`)}`);
|
|
111
|
+
console.log(` total tokens ${c.accent(formatTokens(o.totalTokens).padStart(12))}`);
|
|
112
|
+
console.log(` estimated cost ${c.accent(formatDollars(o.cost.cents).padStart(12))}`);
|
|
113
|
+
if (o.backfill.pending > 0) {
|
|
114
|
+
console.log(c.dim(` (${formatNumber(o.backfill.pending)} assistant messages pending — run \`recall stats --backfill\`)`));
|
|
115
|
+
}
|
|
116
|
+
if (o.byModel.length > 0) {
|
|
117
|
+
console.log('');
|
|
118
|
+
console.log(c.dim(' by model:'));
|
|
119
|
+
for (const m of o.byModel) {
|
|
120
|
+
console.log(` ${m.modelLabel.padEnd(14)} ${formatTokens(m.inputTokens + m.outputTokens + m.cacheCreateTokens + m.cacheReadTokens).padStart(10)} ${c.accent(formatDollars(m.cost.cents).padStart(10))}`);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (o.topSessions.length > 0) {
|
|
124
|
+
console.log('');
|
|
125
|
+
console.log(c.dim(' top sessions:'));
|
|
126
|
+
for (const s of o.topSessions) {
|
|
127
|
+
const label = s.alias ?? s.sessionId.slice(0, 8);
|
|
128
|
+
console.log(` ${label.padEnd(22)} ${(s.project ?? '').slice(0, 20).padEnd(22)} ${formatTokens(s.totalTokens).padStart(10)} ${c.accent(formatDollars(s.cost.cents).padStart(10))}`);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
console.log('');
|
|
132
|
+
}
|
|
133
|
+
//# sourceMappingURL=stats.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stats.js","sourceRoot":"","sources":["../../src/commands/stats.ts"],"names":[],"mappings":"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"}
|