@getrift/rift 0.1.0-beta.2 → 0.1.0-beta.20
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 +35 -9
- package/dist/src/auth/keychain.d.ts +9 -0
- package/dist/src/auth/keychain.d.ts.map +1 -1
- package/dist/src/auth/keychain.js +37 -0
- package/dist/src/auth/keychain.js.map +1 -1
- package/dist/src/capture/auto-capture.d.ts +7 -0
- package/dist/src/capture/auto-capture.d.ts.map +1 -1
- package/dist/src/capture/auto-capture.js +82 -15
- package/dist/src/capture/auto-capture.js.map +1 -1
- package/dist/src/capture/auto-repair.d.ts +110 -0
- package/dist/src/capture/auto-repair.d.ts.map +1 -0
- package/dist/src/capture/auto-repair.js +269 -0
- package/dist/src/capture/auto-repair.js.map +1 -0
- package/dist/src/capture/codex-cli-triage-provider.d.ts.map +1 -1
- package/dist/src/capture/codex-cli-triage-provider.js +4 -3
- package/dist/src/capture/codex-cli-triage-provider.js.map +1 -1
- package/dist/src/capture/observability.d.ts +42 -0
- package/dist/src/capture/observability.d.ts.map +1 -1
- package/dist/src/capture/observability.js +45 -4
- package/dist/src/capture/observability.js.map +1 -1
- package/dist/src/capture/recover-quarantine.d.ts +260 -0
- package/dist/src/capture/recover-quarantine.d.ts.map +1 -0
- package/dist/src/capture/recover-quarantine.js +522 -0
- package/dist/src/capture/recover-quarantine.js.map +1 -0
- package/dist/src/cli/commands/backfill.d.ts.map +1 -1
- package/dist/src/cli/commands/backfill.js +5 -2
- package/dist/src/cli/commands/backfill.js.map +1 -1
- package/dist/src/cli/commands/capture-recover.d.ts +40 -0
- package/dist/src/cli/commands/capture-recover.d.ts.map +1 -0
- package/dist/src/cli/commands/capture-recover.js +184 -0
- package/dist/src/cli/commands/capture-recover.js.map +1 -0
- package/dist/src/cli/commands/capture.d.ts.map +1 -1
- package/dist/src/cli/commands/capture.js +96 -5
- package/dist/src/cli/commands/capture.js.map +1 -1
- package/dist/src/cli/commands/doctor.d.ts +6 -0
- package/dist/src/cli/commands/doctor.d.ts.map +1 -0
- package/dist/src/cli/commands/doctor.js +242 -0
- package/dist/src/cli/commands/doctor.js.map +1 -0
- package/dist/src/cli/commands/feedback.d.ts +12 -0
- package/dist/src/cli/commands/feedback.d.ts.map +1 -1
- package/dist/src/cli/commands/feedback.js +93 -4
- package/dist/src/cli/commands/feedback.js.map +1 -1
- package/dist/src/cli/commands/mcp-install.js +5 -2
- package/dist/src/cli/commands/mcp-install.js.map +1 -1
- package/dist/src/cli/commands/menubar.d.ts +30 -0
- package/dist/src/cli/commands/menubar.d.ts.map +1 -0
- package/dist/src/cli/commands/menubar.js +180 -0
- package/dist/src/cli/commands/menubar.js.map +1 -0
- package/dist/src/cli/commands/onboard.d.ts +129 -0
- package/dist/src/cli/commands/onboard.d.ts.map +1 -1
- package/dist/src/cli/commands/onboard.js +752 -171
- package/dist/src/cli/commands/onboard.js.map +1 -1
- package/dist/src/cli/commands/rebuild.d.ts.map +1 -1
- package/dist/src/cli/commands/rebuild.js +6 -3
- package/dist/src/cli/commands/rebuild.js.map +1 -1
- package/dist/src/cli/commands/reconcile.d.ts.map +1 -1
- package/dist/src/cli/commands/reconcile.js +12 -0
- package/dist/src/cli/commands/reconcile.js.map +1 -1
- package/dist/src/cli/commands/review.d.ts.map +1 -1
- package/dist/src/cli/commands/review.js +22 -7
- package/dist/src/cli/commands/review.js.map +1 -1
- package/dist/src/cli/commands/search.d.ts +2 -0
- package/dist/src/cli/commands/search.d.ts.map +1 -1
- package/dist/src/cli/commands/search.js +34 -4
- package/dist/src/cli/commands/search.js.map +1 -1
- package/dist/src/cli/commands/status.d.ts +9 -7
- package/dist/src/cli/commands/status.d.ts.map +1 -1
- package/dist/src/cli/commands/status.js +113 -12
- package/dist/src/cli/commands/status.js.map +1 -1
- package/dist/src/cli/commands/token-issue.d.ts.map +1 -1
- package/dist/src/cli/commands/token-issue.js +9 -1
- package/dist/src/cli/commands/token-issue.js.map +1 -1
- package/dist/src/cli/commands/triage.d.ts.map +1 -1
- package/dist/src/cli/commands/triage.js +7 -5
- package/dist/src/cli/commands/triage.js.map +1 -1
- package/dist/src/cli/commands/update.d.ts +80 -0
- package/dist/src/cli/commands/update.d.ts.map +1 -0
- package/dist/src/cli/commands/update.js +378 -0
- package/dist/src/cli/commands/update.js.map +1 -0
- package/dist/src/cli/default-config-path.d.ts +15 -0
- package/dist/src/cli/default-config-path.d.ts.map +1 -0
- package/dist/src/cli/default-config-path.js +27 -0
- package/dist/src/cli/default-config-path.js.map +1 -0
- package/dist/src/cli/feedback/feedback-config.d.ts +46 -0
- package/dist/src/cli/feedback/feedback-config.d.ts.map +1 -1
- package/dist/src/cli/feedback/feedback-config.js +130 -4
- package/dist/src/cli/feedback/feedback-config.js.map +1 -1
- package/dist/src/cli/feedback/feedback-history.d.ts +7 -0
- package/dist/src/cli/feedback/feedback-history.d.ts.map +1 -1
- package/dist/src/cli/feedback/feedback-history.js +39 -9
- package/dist/src/cli/feedback/feedback-history.js.map +1 -1
- package/dist/src/cli/feedback/feedback-payload.d.ts +22 -1
- package/dist/src/cli/feedback/feedback-payload.d.ts.map +1 -1
- package/dist/src/cli/feedback/feedback-payload.js.map +1 -1
- package/dist/src/cli/feedback/feedback-relay.d.ts +2 -2
- package/dist/src/cli/feedback/feedback-relay.d.ts.map +1 -1
- package/dist/src/cli/feedback/feedback-relay.js.map +1 -1
- package/dist/src/cli/feedback/invite.d.ts +17 -0
- package/dist/src/cli/feedback/invite.d.ts.map +1 -0
- package/dist/src/cli/feedback/invite.js +67 -0
- package/dist/src/cli/feedback/invite.js.map +1 -0
- package/dist/src/cli/feedback/relay-secret-store.d.ts +32 -0
- package/dist/src/cli/feedback/relay-secret-store.d.ts.map +1 -0
- package/dist/src/cli/feedback/relay-secret-store.js +137 -0
- package/dist/src/cli/feedback/relay-secret-store.js.map +1 -0
- package/dist/src/cli/http-client.d.ts +93 -1
- package/dist/src/cli/http-client.d.ts.map +1 -1
- package/dist/src/cli/http-client.js +254 -6
- package/dist/src/cli/http-client.js.map +1 -1
- package/dist/src/cli/index.d.ts.map +1 -1
- package/dist/src/cli/index.js +29 -6
- package/dist/src/cli/index.js.map +1 -1
- package/dist/src/cli/postinstall-menubar.d.ts +22 -0
- package/dist/src/cli/postinstall-menubar.d.ts.map +1 -0
- package/dist/src/cli/postinstall-menubar.js +39 -0
- package/dist/src/cli/postinstall-menubar.js.map +1 -0
- package/dist/src/cli/status/friend-header.d.ts +8 -1
- package/dist/src/cli/status/friend-header.d.ts.map +1 -1
- package/dist/src/cli/status/friend-header.js +334 -26
- package/dist/src/cli/status/friend-header.js.map +1 -1
- package/dist/src/cli/ui.d.ts +47 -0
- package/dist/src/cli/ui.d.ts.map +1 -0
- package/dist/src/cli/ui.js +166 -0
- package/dist/src/cli/ui.js.map +1 -0
- package/dist/src/config/schema.d.ts +79 -0
- package/dist/src/config/schema.d.ts.map +1 -1
- package/dist/src/config/schema.js +44 -0
- package/dist/src/config/schema.js.map +1 -1
- package/dist/src/diagnostics/codex-preflight.d.ts +33 -0
- package/dist/src/diagnostics/codex-preflight.d.ts.map +1 -0
- package/dist/src/diagnostics/codex-preflight.js +75 -0
- package/dist/src/diagnostics/codex-preflight.js.map +1 -0
- package/dist/src/diagnostics/doctor.d.ts +106 -0
- package/dist/src/diagnostics/doctor.d.ts.map +1 -0
- package/dist/src/diagnostics/doctor.js +334 -0
- package/dist/src/diagnostics/doctor.js.map +1 -0
- package/dist/src/diagnostics/notify.d.ts +90 -0
- package/dist/src/diagnostics/notify.d.ts.map +1 -0
- package/dist/src/diagnostics/notify.js +177 -0
- package/dist/src/diagnostics/notify.js.map +1 -0
- package/dist/src/diagnostics/repair-prompt.d.ts +49 -0
- package/dist/src/diagnostics/repair-prompt.d.ts.map +1 -0
- package/dist/src/diagnostics/repair-prompt.js +223 -0
- package/dist/src/diagnostics/repair-prompt.js.map +1 -0
- package/dist/src/ingestion/inbox-core/conversation-fingerprint.d.ts +2 -0
- package/dist/src/ingestion/inbox-core/conversation-fingerprint.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/conversation-fingerprint.js +27 -0
- package/dist/src/ingestion/inbox-core/conversation-fingerprint.js.map +1 -0
- package/dist/src/ingestion/inbox-core/conversation-key.d.ts +2 -0
- package/dist/src/ingestion/inbox-core/conversation-key.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/conversation-key.js +31 -0
- package/dist/src/ingestion/inbox-core/conversation-key.js.map +1 -0
- package/dist/src/ingestion/inbox-core/extensions.d.ts +3 -0
- package/dist/src/ingestion/inbox-core/extensions.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/extensions.js +16 -0
- package/dist/src/ingestion/inbox-core/extensions.js.map +1 -0
- package/dist/src/ingestion/inbox-core/idempotency.d.ts +2 -0
- package/dist/src/ingestion/inbox-core/idempotency.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/idempotency.js +22 -0
- package/dist/src/ingestion/inbox-core/idempotency.js.map +1 -0
- package/dist/src/ingestion/inbox-core/index.d.ts +20 -0
- package/dist/src/ingestion/inbox-core/index.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/index.js +20 -0
- package/dist/src/ingestion/inbox-core/index.js.map +1 -0
- package/dist/src/ingestion/inbox-core/source-detection.d.ts +2 -0
- package/dist/src/ingestion/inbox-core/source-detection.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/source-detection.js +23 -0
- package/dist/src/ingestion/inbox-core/source-detection.js.map +1 -0
- package/dist/src/ingestion/inbox-core/source-sniffer.d.ts +11 -0
- package/dist/src/ingestion/inbox-core/source-sniffer.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/source-sniffer.js +69 -0
- package/dist/src/ingestion/inbox-core/source-sniffer.js.map +1 -0
- package/dist/src/ingestion/inbox-core/zip-sniffer.d.ts +70 -0
- package/dist/src/ingestion/inbox-core/zip-sniffer.d.ts.map +1 -0
- package/dist/src/ingestion/inbox-core/zip-sniffer.js +161 -0
- package/dist/src/ingestion/inbox-core/zip-sniffer.js.map +1 -0
- package/dist/src/ingestion/inbox-watcher.d.ts.map +1 -1
- package/dist/src/ingestion/inbox-watcher.js +34 -50
- package/dist/src/ingestion/inbox-watcher.js.map +1 -1
- package/dist/src/ingestion/indexer.d.ts +7 -0
- package/dist/src/ingestion/indexer.d.ts.map +1 -1
- package/dist/src/ingestion/indexer.js +36 -2
- package/dist/src/ingestion/indexer.js.map +1 -1
- package/dist/src/ingestion/metadata-extraction.d.ts +8 -5
- package/dist/src/ingestion/metadata-extraction.d.ts.map +1 -1
- package/dist/src/ingestion/metadata-extraction.js +24 -5
- package/dist/src/ingestion/metadata-extraction.js.map +1 -1
- package/dist/src/ingestion/skip-quarantine.d.ts +10 -0
- package/dist/src/ingestion/skip-quarantine.d.ts.map +1 -0
- package/dist/src/ingestion/skip-quarantine.js +35 -0
- package/dist/src/ingestion/skip-quarantine.js.map +1 -0
- package/dist/src/jobs/handlers/compact.d.ts.map +1 -1
- package/dist/src/jobs/handlers/compact.js +30 -4
- package/dist/src/jobs/handlers/compact.js.map +1 -1
- package/dist/src/jobs/handlers/dedupe-conversations.d.ts +134 -0
- package/dist/src/jobs/handlers/dedupe-conversations.d.ts.map +1 -0
- package/dist/src/jobs/handlers/dedupe-conversations.js +371 -0
- package/dist/src/jobs/handlers/dedupe-conversations.js.map +1 -0
- package/dist/src/jobs/handlers/ingest.d.ts.map +1 -1
- package/dist/src/jobs/handlers/ingest.js +295 -41
- package/dist/src/jobs/handlers/ingest.js.map +1 -1
- package/dist/src/jobs/handlers/reconcile.d.ts +28 -0
- package/dist/src/jobs/handlers/reconcile.d.ts.map +1 -1
- package/dist/src/jobs/handlers/reconcile.js +145 -19
- package/dist/src/jobs/handlers/reconcile.js.map +1 -1
- package/dist/src/jobs/handlers/reindex.d.ts.map +1 -1
- package/dist/src/jobs/handlers/reindex.js +13 -2
- package/dist/src/jobs/handlers/reindex.js.map +1 -1
- package/dist/src/jobs/handlers/save.d.ts.map +1 -1
- package/dist/src/jobs/handlers/save.js +57 -3
- package/dist/src/jobs/handlers/save.js.map +1 -1
- package/dist/src/jobs/queue.d.ts +51 -1
- package/dist/src/jobs/queue.d.ts.map +1 -1
- package/dist/src/jobs/queue.js +466 -26
- package/dist/src/jobs/queue.js.map +1 -1
- package/dist/src/jobs/worker-entry.d.ts.map +1 -1
- package/dist/src/jobs/worker-entry.js +35 -7
- package/dist/src/jobs/worker-entry.js.map +1 -1
- package/dist/src/jobs/worker-process.d.ts +11 -0
- package/dist/src/jobs/worker-process.d.ts.map +1 -1
- package/dist/src/jobs/worker-process.js +37 -4
- package/dist/src/jobs/worker-process.js.map +1 -1
- package/dist/src/main.js +199 -46
- package/dist/src/main.js.map +1 -1
- package/dist/src/mcp/errors.d.ts.map +1 -1
- package/dist/src/mcp/errors.js +20 -1
- package/dist/src/mcp/errors.js.map +1 -1
- package/dist/src/mcp/server.d.ts.map +1 -1
- package/dist/src/mcp/server.js +43 -3
- package/dist/src/mcp/server.js.map +1 -1
- package/dist/src/mcp/tools/context-pack.d.ts.map +1 -1
- package/dist/src/mcp/tools/context-pack.js +164 -23
- package/dist/src/mcp/tools/context-pack.js.map +1 -1
- package/dist/src/mcp/tools/search.d.ts +6 -2
- package/dist/src/mcp/tools/search.d.ts.map +1 -1
- package/dist/src/mcp/tools/search.js +35 -4
- package/dist/src/mcp/tools/search.js.map +1 -1
- package/dist/src/observability/embedding-events.d.ts +52 -0
- package/dist/src/observability/embedding-events.d.ts.map +1 -0
- package/dist/src/observability/embedding-events.js +149 -0
- package/dist/src/observability/embedding-events.js.map +1 -0
- package/dist/src/observability/index-events.d.ts +70 -0
- package/dist/src/observability/index-events.d.ts.map +1 -0
- package/dist/src/observability/index-events.js +148 -0
- package/dist/src/observability/index-events.js.map +1 -0
- package/dist/src/observability/onboarding-metric.d.ts +131 -0
- package/dist/src/observability/onboarding-metric.d.ts.map +1 -0
- package/dist/src/observability/onboarding-metric.js +351 -0
- package/dist/src/observability/onboarding-metric.js.map +1 -0
- package/dist/src/observability/tool-usage-stats.d.ts +77 -4
- package/dist/src/observability/tool-usage-stats.d.ts.map +1 -1
- package/dist/src/observability/tool-usage-stats.js +112 -32
- package/dist/src/observability/tool-usage-stats.js.map +1 -1
- package/dist/src/observability/tool-usage.d.ts +100 -7
- package/dist/src/observability/tool-usage.d.ts.map +1 -1
- package/dist/src/observability/tool-usage.js +196 -33
- package/dist/src/observability/tool-usage.js.map +1 -1
- package/dist/src/observability/version-check.d.ts +71 -0
- package/dist/src/observability/version-check.d.ts.map +1 -0
- package/dist/src/observability/version-check.js +198 -0
- package/dist/src/observability/version-check.js.map +1 -0
- package/dist/src/providers/basic-metadata-extraction.d.ts +60 -0
- package/dist/src/providers/basic-metadata-extraction.d.ts.map +1 -0
- package/dist/src/providers/basic-metadata-extraction.js +114 -0
- package/dist/src/providers/basic-metadata-extraction.js.map +1 -0
- package/dist/src/providers/codex-cli-metadata-extraction.d.ts +1 -0
- package/dist/src/providers/codex-cli-metadata-extraction.d.ts.map +1 -1
- package/dist/src/providers/codex-cli-metadata-extraction.js +6 -2
- package/dist/src/providers/codex-cli-metadata-extraction.js.map +1 -1
- package/dist/src/providers/codex-cli-model.d.ts +61 -0
- package/dist/src/providers/codex-cli-model.d.ts.map +1 -0
- package/dist/src/providers/codex-cli-model.js +194 -0
- package/dist/src/providers/codex-cli-model.js.map +1 -0
- package/dist/src/providers/codex-cli-runner.d.ts +39 -0
- package/dist/src/providers/codex-cli-runner.d.ts.map +1 -1
- package/dist/src/providers/codex-cli-runner.js +234 -48
- package/dist/src/providers/codex-cli-runner.js.map +1 -1
- package/dist/src/providers/conversation-generation.d.ts.map +1 -1
- package/dist/src/providers/conversation-generation.js +43 -6
- package/dist/src/providers/conversation-generation.js.map +1 -1
- package/dist/src/providers/ollama-embed.d.ts +2 -1
- package/dist/src/providers/ollama-embed.d.ts.map +1 -1
- package/dist/src/providers/ollama-embed.js +1 -0
- package/dist/src/providers/ollama-embed.js.map +1 -1
- package/dist/src/providers/openai-metadata-extraction.d.ts +3 -3
- package/dist/src/providers/openai-metadata-extraction.d.ts.map +1 -1
- package/dist/src/providers/openai-metadata-extraction.js +18 -3
- package/dist/src/providers/openai-metadata-extraction.js.map +1 -1
- package/dist/src/providers/placeholder-embed.d.ts +56 -0
- package/dist/src/providers/placeholder-embed.d.ts.map +1 -0
- package/dist/src/providers/placeholder-embed.js +64 -0
- package/dist/src/providers/placeholder-embed.js.map +1 -0
- package/dist/src/providers/stub.d.ts +2 -0
- package/dist/src/providers/stub.d.ts.map +1 -1
- package/dist/src/providers/stub.js +2 -0
- package/dist/src/providers/stub.js.map +1 -1
- package/dist/src/providers/types.d.ts +11 -0
- package/dist/src/providers/types.d.ts.map +1 -1
- package/dist/src/providers/voyage.d.ts +2 -1
- package/dist/src/providers/voyage.d.ts.map +1 -1
- package/dist/src/providers/voyage.js +1 -0
- package/dist/src/providers/voyage.js.map +1 -1
- package/dist/src/retrieval/compact.d.ts +116 -2
- package/dist/src/retrieval/compact.d.ts.map +1 -1
- package/dist/src/retrieval/compact.js +158 -5
- package/dist/src/retrieval/compact.js.map +1 -1
- package/dist/src/retrieval/context-pack.d.ts +114 -0
- package/dist/src/retrieval/context-pack.d.ts.map +1 -1
- package/dist/src/retrieval/context-pack.js +292 -8
- package/dist/src/retrieval/context-pack.js.map +1 -1
- package/dist/src/retrieval/current-truth.d.ts +360 -0
- package/dist/src/retrieval/current-truth.d.ts.map +1 -0
- package/dist/src/retrieval/current-truth.js +766 -0
- package/dist/src/retrieval/current-truth.js.map +1 -0
- package/dist/src/retrieval/git-state.d.ts +53 -0
- package/dist/src/retrieval/git-state.d.ts.map +1 -0
- package/dist/src/retrieval/git-state.js +174 -0
- package/dist/src/retrieval/git-state.js.map +1 -0
- package/dist/src/retrieval/lexical.d.ts.map +1 -1
- package/dist/src/retrieval/lexical.js +19 -3
- package/dist/src/retrieval/lexical.js.map +1 -1
- package/dist/src/retrieval/locator-boost.d.ts +37 -0
- package/dist/src/retrieval/locator-boost.d.ts.map +1 -0
- package/dist/src/retrieval/locator-boost.js +129 -0
- package/dist/src/retrieval/locator-boost.js.map +1 -0
- package/dist/src/retrieval/report-demotion.d.ts +46 -0
- package/dist/src/retrieval/report-demotion.d.ts.map +1 -0
- package/dist/src/retrieval/report-demotion.js +169 -0
- package/dist/src/retrieval/report-demotion.js.map +1 -0
- package/dist/src/retrieval/vector.d.ts.map +1 -1
- package/dist/src/retrieval/vector.js +11 -2
- package/dist/src/retrieval/vector.js.map +1 -1
- package/dist/src/server/app.d.ts.map +1 -1
- package/dist/src/server/app.js +92 -11
- package/dist/src/server/app.js.map +1 -1
- package/dist/src/server/routes/compact.d.ts.map +1 -1
- package/dist/src/server/routes/compact.js +4 -1
- package/dist/src/server/routes/compact.js.map +1 -1
- package/dist/src/server/routes/context.d.ts +1 -1
- package/dist/src/server/routes/context.d.ts.map +1 -1
- package/dist/src/server/routes/context.js +2 -1
- package/dist/src/server/routes/context.js.map +1 -1
- package/dist/src/server/routes/conversations-search.d.ts.map +1 -1
- package/dist/src/server/routes/conversations-search.js +28 -3
- package/dist/src/server/routes/conversations-search.js.map +1 -1
- package/dist/src/server/routes/enqueue.d.ts +11 -0
- package/dist/src/server/routes/enqueue.d.ts.map +1 -0
- package/dist/src/server/routes/enqueue.js +17 -0
- package/dist/src/server/routes/enqueue.js.map +1 -0
- package/dist/src/server/routes/friend-status.d.ts +339 -3
- package/dist/src/server/routes/friend-status.d.ts.map +1 -1
- package/dist/src/server/routes/friend-status.js +447 -13
- package/dist/src/server/routes/friend-status.js.map +1 -1
- package/dist/src/server/routes/ingest.d.ts.map +1 -1
- package/dist/src/server/routes/ingest.js +5 -2
- package/dist/src/server/routes/ingest.js.map +1 -1
- package/dist/src/server/routes/mcp-usage.d.ts +5 -4
- package/dist/src/server/routes/mcp-usage.d.ts.map +1 -1
- package/dist/src/server/routes/mcp-usage.js.map +1 -1
- package/dist/src/server/routes/reconcile.d.ts.map +1 -1
- package/dist/src/server/routes/reconcile.js +20 -1
- package/dist/src/server/routes/reconcile.js.map +1 -1
- package/dist/src/server/routes/reindex.d.ts.map +1 -1
- package/dist/src/server/routes/reindex.js +4 -1
- package/dist/src/server/routes/reindex.js.map +1 -1
- package/dist/src/server/routes/save.d.ts.map +1 -1
- package/dist/src/server/routes/save.js +4 -1
- package/dist/src/server/routes/save.js.map +1 -1
- package/dist/src/server/routes/search.d.ts +1 -1
- package/dist/src/server/routes/search.d.ts.map +1 -1
- package/dist/src/server/routes/search.js +253 -29
- package/dist/src/server/routes/search.js.map +1 -1
- package/dist/src/server/routes/triage.d.ts.map +1 -1
- package/dist/src/server/routes/triage.js +4 -1
- package/dist/src/server/routes/triage.js.map +1 -1
- package/dist/src/storage/rebuild.d.ts +35 -1
- package/dist/src/storage/rebuild.d.ts.map +1 -1
- package/dist/src/storage/rebuild.js +288 -64
- package/dist/src/storage/rebuild.js.map +1 -1
- package/dist/src/storage/tables.d.ts +29 -0
- package/dist/src/storage/tables.d.ts.map +1 -1
- package/dist/src/storage/tables.js +32 -1
- package/dist/src/storage/tables.js.map +1 -1
- package/operator/swiftbar/render-menu.py +524 -0
- package/operator/swiftbar/rift.10s.sh +176 -0
- package/package.json +9 -3
|
@@ -3,14 +3,86 @@
|
|
|
3
3
|
*
|
|
4
4
|
* No filesystem reads, no parsing — callers pass an already-decoded
|
|
5
5
|
* `ToolUsageEntry[]` (typically via `readToolUsageEntriesTolerant`).
|
|
6
|
-
* Buckets calls into today/week/month/all-time
|
|
7
|
-
*
|
|
8
|
-
*
|
|
6
|
+
* Buckets calls into today/week/month/all-time. The headline retrieval
|
|
7
|
+
* metric is `context_tokens_delivered_estimate` — the measured size of
|
|
8
|
+
* the text channel actually returned on context hits, divided by 4 for
|
|
9
|
+
* a rough tokens estimate.
|
|
9
10
|
*/
|
|
10
11
|
import type { ToolUsageEntry } from "./tool-usage.js";
|
|
11
12
|
export interface UsageWindow {
|
|
12
13
|
calls: number;
|
|
13
|
-
|
|
14
|
+
/**
|
|
15
|
+
* Successful retrieval calls that returned at least one item and were not
|
|
16
|
+
* marked `degraded`. Captures rift_search, rift_conversations_search, and
|
|
17
|
+
* rift_context_pack — the tools whose job is to surface relevant context.
|
|
18
|
+
* Non-retrieval calls (rift_save, rift_status) are excluded.
|
|
19
|
+
*/
|
|
20
|
+
context_hits: number;
|
|
21
|
+
/**
|
|
22
|
+
* Subset of `context_hits` whose rows included `response_text_bytes`, meaning
|
|
23
|
+
* they actually contributed to `context_tokens_delivered_estimate`. Legacy
|
|
24
|
+
* rows written before byte measurement still count as context hits, but not
|
|
25
|
+
* as measured hits. SwiftBar renders this as "3/115 hits measured" so equal
|
|
26
|
+
* token totals across wider windows are understandable instead of suspicious.
|
|
27
|
+
*/
|
|
28
|
+
context_tokens_measured_hits: number;
|
|
29
|
+
/**
|
|
30
|
+
* Cheap tokens estimate (`ceil(bytes / 4)`) over the MCP text channel of
|
|
31
|
+
* every call that counts toward `context_hits`. Measured from the response
|
|
32
|
+
* we actually returned — not a per-tool flat constant. Empty results,
|
|
33
|
+
* degraded retrievals, failures, and non-retrieval tools contribute 0.
|
|
34
|
+
* Legacy log rows written before response size was recorded contribute 0
|
|
35
|
+
* (no fabricated number) and naturally age out as fresh rows accumulate.
|
|
36
|
+
*/
|
|
37
|
+
context_tokens_delivered_estimate: number;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Precise-lookup health: aggregates over rift_search calls whose
|
|
41
|
+
* `search_mode` was recorded as `"exact_id"`. Surfaces the leading
|
|
42
|
+
* indicators that the strict direct-lookup gate on `/search` is or
|
|
43
|
+
* isn't earning agent trust — high success ratio + rare typed failures
|
|
44
|
+
* is healthy; rising `typed_failures` (`id_not_found`/`ambiguous_id`)
|
|
45
|
+
* or large `max_content_tokens_estimate` paired with low success is
|
|
46
|
+
* the shape of a flow where an agent may stop trusting Rift for precise
|
|
47
|
+
* lookup. Trust risk is named precisely:
|
|
48
|
+
* we cannot tell from Rift alone that the agent went on to read JSONL
|
|
49
|
+
* from disk, only that the lookup it asked for here failed.
|
|
50
|
+
*/
|
|
51
|
+
export interface PreciseLookupStats {
|
|
52
|
+
/** Total rift_search calls with search_mode = exact_id (success or not). */
|
|
53
|
+
total: number;
|
|
54
|
+
/** Subset of `total` where success = true. */
|
|
55
|
+
successes: number;
|
|
56
|
+
/**
|
|
57
|
+
* Failures bucketed by the typed `error` field parsed from the response
|
|
58
|
+
* body (e.g. `id_not_found`, `ambiguous_id`). Transport / untyped
|
|
59
|
+
* failures do not appear here — they only count toward `total - successes`.
|
|
60
|
+
*/
|
|
61
|
+
typed_failures: Record<string, number>;
|
|
62
|
+
/**
|
|
63
|
+
* Detail-level split among exact-id calls. `summary` is impossible by
|
|
64
|
+
* definition (exact-id requires middle|full), so only `middle` and
|
|
65
|
+
* `full` appear. Useful for seeing whether agents prefer the bounded
|
|
66
|
+
* middle path or still default to full-body expansion.
|
|
67
|
+
*/
|
|
68
|
+
by_detail: {
|
|
69
|
+
middle: number;
|
|
70
|
+
full: number;
|
|
71
|
+
};
|
|
72
|
+
/**
|
|
73
|
+
* Count of successful exact-id calls that returned at least one hit
|
|
74
|
+
* with `content_truncated === true` — a leading indicator that the
|
|
75
|
+
* agent received a bounded excerpt and may decide to escalate to
|
|
76
|
+
* `detail=full`. Bounded to successful calls because truncation only
|
|
77
|
+
* makes sense for returned content.
|
|
78
|
+
*/
|
|
79
|
+
truncated_count: number;
|
|
80
|
+
/**
|
|
81
|
+
* Maximum `content_tokens_estimate` observed across all exact-id
|
|
82
|
+
* calls (successful or not, when the field was present). Captures the
|
|
83
|
+
* worst-case "this row would blow context if expanded" signal.
|
|
84
|
+
*/
|
|
85
|
+
max_content_tokens_estimate: number;
|
|
14
86
|
}
|
|
15
87
|
export interface UsageSummary {
|
|
16
88
|
today: UsageWindow;
|
|
@@ -18,6 +90,7 @@ export interface UsageSummary {
|
|
|
18
90
|
month: UsageWindow;
|
|
19
91
|
all_time: UsageWindow;
|
|
20
92
|
by_tool: Record<string, number>;
|
|
93
|
+
precise_lookup: PreciseLookupStats;
|
|
21
94
|
}
|
|
22
95
|
export declare function aggregateUsage(entries: ToolUsageEntry[], now?: Date): UsageSummary;
|
|
23
96
|
//# sourceMappingURL=tool-usage-stats.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tool-usage-stats.d.ts","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"tool-usage-stats.d.ts","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAsBtD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd;;;;;OAKG;IACH,YAAY,EAAE,MAAM,CAAC;IACrB;;;;;;OAMG;IACH,4BAA4B,EAAE,MAAM,CAAC;IACrC;;;;;;;OAOG;IACH,iCAAiC,EAAE,MAAM,CAAC;CAC3C;AAED;;;;;;;;;;;GAWG;AACH,MAAM,WAAW,kBAAkB;IACjC,4EAA4E;IAC5E,KAAK,EAAE,MAAM,CAAC;IACd,8CAA8C;IAC9C,SAAS,EAAE,MAAM,CAAC;IAClB;;;;OAIG;IACH,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACvC;;;;;OAKG;IACH,SAAS,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IAC5C;;;;;;OAMG;IACH,eAAe,EAAE,MAAM,CAAC;IACxB;;;;OAIG;IACH,2BAA2B,EAAE,MAAM,CAAC;CACrC;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,WAAW,CAAC;IACnB,IAAI,EAAE,WAAW,CAAC;IAClB,KAAK,EAAE,WAAW,CAAC;IACnB,QAAQ,EAAE,WAAW,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,cAAc,EAAE,kBAAkB,CAAC;CACpC;AA8ED,wBAAgB,cAAc,CAC5B,OAAO,EAAE,cAAc,EAAE,EACzB,GAAG,GAAE,IAAiB,GACrB,YAAY,CA2Fd"}
|
|
@@ -1,24 +1,7 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tokens-saved estimates per MCP tool call. The numbers are the
|
|
3
|
-
* approximate tokens an agent would have to spend stuffing equivalent
|
|
4
|
-
* context into a system prompt or doing the same query without the
|
|
5
|
-
* compact, bucketed retrieval the MCP server provides.
|
|
6
|
-
*
|
|
7
|
-
* Unknown tools fall back to `DEFAULT_TOKENS_SAVED` so future tools
|
|
8
|
-
* report a non-zero baseline.
|
|
9
|
-
*/
|
|
10
|
-
const TOKENS_SAVED_PER_TOOL = {
|
|
11
|
-
rift_context_pack: 12_000,
|
|
12
|
-
rift_conversations_search: 8_000,
|
|
13
|
-
rift_search: 6_000,
|
|
14
|
-
rift_save: 2_000,
|
|
15
|
-
rift_status: 1_000,
|
|
16
|
-
};
|
|
17
|
-
const DEFAULT_TOKENS_SAVED = 1_000;
|
|
18
1
|
/**
|
|
19
2
|
* Map legacy tool names from JSONL rows written before the rename onto
|
|
20
|
-
* their canonical `rift_*` equivalents so SwiftBar
|
|
21
|
-
*
|
|
3
|
+
* their canonical `rift_*` equivalents so SwiftBar counters stay
|
|
4
|
+
* continuous on a machine that upgrades. Hidden migration only —
|
|
22
5
|
* never surfaces in user-visible output.
|
|
23
6
|
*/
|
|
24
7
|
const LEGACY_TOOL_RENAMES = {
|
|
@@ -33,49 +16,146 @@ function canonicalToolName(tool) {
|
|
|
33
16
|
}
|
|
34
17
|
const DAY_MS = 24 * 60 * 60 * 1000;
|
|
35
18
|
function emptyWindow() {
|
|
36
|
-
return {
|
|
19
|
+
return {
|
|
20
|
+
calls: 0,
|
|
21
|
+
context_hits: 0,
|
|
22
|
+
context_tokens_measured_hits: 0,
|
|
23
|
+
context_tokens_delivered_estimate: 0,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Cheap tokens estimate from a UTF-8 byte count. `bytes / 4` is the standard
|
|
28
|
+
* back-of-envelope for English text — good enough for a glanceable menu-bar
|
|
29
|
+
* counter without pulling a real tokenizer into the daemon.
|
|
30
|
+
*/
|
|
31
|
+
function tokensFromBytes(bytes) {
|
|
32
|
+
return bytes > 0 ? Math.ceil(bytes / 4) : 0;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Local-time start-of-day. The menu-bar "today" counter is a glanceable
|
|
36
|
+
* Mac-local metric, so the boundary follows the machine's wall clock — not
|
|
37
|
+
* UTC, which would reset mid-evening in Asia/early-morning in Europe.
|
|
38
|
+
*/
|
|
39
|
+
function startOfLocalDay(date) {
|
|
40
|
+
return new Date(date.getFullYear(), date.getMonth(), date.getDate()).getTime();
|
|
37
41
|
}
|
|
38
|
-
|
|
39
|
-
|
|
42
|
+
/**
|
|
43
|
+
* Local-time start of the following day. Built via the local-time Date
|
|
44
|
+
* constructor (not `startOfLocalDay + DAY_MS`) so DST-fallback days, which
|
|
45
|
+
* have 25 hours, still capture their final hour as "today".
|
|
46
|
+
*/
|
|
47
|
+
function startOfNextLocalDay(date) {
|
|
48
|
+
return new Date(date.getFullYear(), date.getMonth(), date.getDate() + 1).getTime();
|
|
40
49
|
}
|
|
41
|
-
|
|
42
|
-
|
|
50
|
+
/**
|
|
51
|
+
* Local-time start of the current calendar month. The menu labels this window
|
|
52
|
+
* "This month", and a friend reads that as "since the 1st" — not a rolling
|
|
53
|
+
* 30-day trailing window. Anchoring on the calendar boundary keeps the label
|
|
54
|
+
* honest (on June 4 it means June 1→now, never May 5→now).
|
|
55
|
+
*/
|
|
56
|
+
function startOfLocalMonth(date) {
|
|
57
|
+
return new Date(date.getFullYear(), date.getMonth(), 1).getTime();
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Tools whose `result_count` counts toward `context_hits`. Belt-and-suspenders
|
|
61
|
+
* with the logger's own whitelist in [extractRetrievalSignal] — if a future
|
|
62
|
+
* code path ever writes `result_count` for a non-retrieval tool, this gate
|
|
63
|
+
* still keeps it out of the metric.
|
|
64
|
+
*/
|
|
65
|
+
const RETRIEVAL_TOOLS_FOR_HITS = new Set([
|
|
66
|
+
"rift_search",
|
|
67
|
+
"rift_conversations_search",
|
|
68
|
+
"rift_context_pack",
|
|
69
|
+
]);
|
|
70
|
+
function isContextHit(tool, entry) {
|
|
71
|
+
return (RETRIEVAL_TOOLS_FOR_HITS.has(tool) &&
|
|
72
|
+
entry.success === true &&
|
|
73
|
+
entry.degraded !== true &&
|
|
74
|
+
typeof entry.result_count === "number" &&
|
|
75
|
+
entry.result_count > 0);
|
|
43
76
|
}
|
|
44
77
|
export function aggregateUsage(entries, now = new Date()) {
|
|
45
|
-
const todayStartMs =
|
|
78
|
+
const todayStartMs = startOfLocalDay(now);
|
|
79
|
+
const todayEndMs = startOfNextLocalDay(now);
|
|
46
80
|
const nowMs = now.getTime();
|
|
81
|
+
// `week` stays a rolling 7-day window — it is an internal metric, never
|
|
82
|
+
// surfaced in the menu, so it carries no calendar-label honesty obligation.
|
|
83
|
+
// `month` is a calendar-month boundary because the menu labels it "This
|
|
84
|
+
// month" (see startOfLocalMonth).
|
|
47
85
|
const weekStartMs = nowMs - 7 * DAY_MS;
|
|
48
|
-
const monthStartMs =
|
|
86
|
+
const monthStartMs = startOfLocalMonth(now);
|
|
49
87
|
const summary = {
|
|
50
88
|
today: emptyWindow(),
|
|
51
89
|
week: emptyWindow(),
|
|
52
90
|
month: emptyWindow(),
|
|
53
91
|
all_time: emptyWindow(),
|
|
54
92
|
by_tool: {},
|
|
93
|
+
precise_lookup: {
|
|
94
|
+
total: 0,
|
|
95
|
+
successes: 0,
|
|
96
|
+
typed_failures: {},
|
|
97
|
+
by_detail: { middle: 0, full: 0 },
|
|
98
|
+
truncated_count: 0,
|
|
99
|
+
max_content_tokens_estimate: 0,
|
|
100
|
+
},
|
|
55
101
|
};
|
|
56
|
-
const todayEndMs = todayStartMs + DAY_MS;
|
|
57
102
|
for (const entry of entries) {
|
|
58
103
|
const ts = Date.parse(entry.timestamp);
|
|
59
104
|
if (Number.isNaN(ts))
|
|
60
105
|
continue;
|
|
61
106
|
const tool = canonicalToolName(entry.tool);
|
|
62
|
-
const
|
|
107
|
+
const hit = isContextHit(tool, entry) ? 1 : 0;
|
|
108
|
+
// Only count delivered tokens on context hits — empty/degraded/non-retrieval
|
|
109
|
+
// calls all contribute 0. `response_text_bytes` is absent on legacy rows
|
|
110
|
+
// written before the field existed; those naturally contribute 0 too.
|
|
111
|
+
const delivered = hit && typeof entry.response_text_bytes === "number"
|
|
112
|
+
? tokensFromBytes(entry.response_text_bytes)
|
|
113
|
+
: 0;
|
|
114
|
+
const measuredHit = hit && typeof entry.response_text_bytes === "number" ? 1 : 0;
|
|
63
115
|
summary.all_time.calls += 1;
|
|
64
|
-
summary.all_time.
|
|
116
|
+
summary.all_time.context_tokens_delivered_estimate += delivered;
|
|
117
|
+
summary.all_time.context_tokens_measured_hits += measuredHit;
|
|
118
|
+
summary.all_time.context_hits += hit;
|
|
65
119
|
summary.by_tool[tool] = (summary.by_tool[tool] ?? 0) + 1;
|
|
120
|
+
if (tool === "rift_search" && entry.search_mode === "exact_id") {
|
|
121
|
+
const pl = summary.precise_lookup;
|
|
122
|
+
pl.total += 1;
|
|
123
|
+
if (entry.success === true)
|
|
124
|
+
pl.successes += 1;
|
|
125
|
+
else if (typeof entry.typed_error === "string") {
|
|
126
|
+
pl.typed_failures[entry.typed_error] =
|
|
127
|
+
(pl.typed_failures[entry.typed_error] ?? 0) + 1;
|
|
128
|
+
}
|
|
129
|
+
if (entry.detail === "middle")
|
|
130
|
+
pl.by_detail.middle += 1;
|
|
131
|
+
else if (entry.detail === "full")
|
|
132
|
+
pl.by_detail.full += 1;
|
|
133
|
+
if (entry.has_truncated_content === true)
|
|
134
|
+
pl.truncated_count += 1;
|
|
135
|
+
if (typeof entry.max_content_tokens_estimate === "number" &&
|
|
136
|
+
entry.max_content_tokens_estimate > pl.max_content_tokens_estimate) {
|
|
137
|
+
pl.max_content_tokens_estimate = entry.max_content_tokens_estimate;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
66
140
|
if (ts > nowMs)
|
|
67
141
|
continue;
|
|
68
142
|
if (ts >= monthStartMs) {
|
|
69
143
|
summary.month.calls += 1;
|
|
70
|
-
summary.month.
|
|
144
|
+
summary.month.context_tokens_delivered_estimate += delivered;
|
|
145
|
+
summary.month.context_tokens_measured_hits += measuredHit;
|
|
146
|
+
summary.month.context_hits += hit;
|
|
71
147
|
}
|
|
72
148
|
if (ts >= weekStartMs) {
|
|
73
149
|
summary.week.calls += 1;
|
|
74
|
-
summary.week.
|
|
150
|
+
summary.week.context_tokens_delivered_estimate += delivered;
|
|
151
|
+
summary.week.context_tokens_measured_hits += measuredHit;
|
|
152
|
+
summary.week.context_hits += hit;
|
|
75
153
|
}
|
|
76
154
|
if (ts >= todayStartMs && ts < todayEndMs) {
|
|
77
155
|
summary.today.calls += 1;
|
|
78
|
-
summary.today.
|
|
156
|
+
summary.today.context_tokens_delivered_estimate += delivered;
|
|
157
|
+
summary.today.context_tokens_measured_hits += measuredHit;
|
|
158
|
+
summary.today.context_hits += hit;
|
|
79
159
|
}
|
|
80
160
|
}
|
|
81
161
|
return summary;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tool-usage-stats.js","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"tool-usage-stats.js","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
export type SearchMode = "exact_id" | "ranked";
|
|
2
|
+
export type DetailLevel = "summary" | "middle" | "full";
|
|
1
3
|
export interface ToolUsageEntry {
|
|
2
4
|
timestamp: string;
|
|
3
5
|
type: "mcp_tool_call";
|
|
@@ -8,15 +10,64 @@ export interface ToolUsageEntry {
|
|
|
8
10
|
result_count?: number;
|
|
9
11
|
degraded?: boolean;
|
|
10
12
|
error?: string;
|
|
13
|
+
/**
|
|
14
|
+
* rift_search only: "exact_id" when `args.id` is present AND
|
|
15
|
+
* `detail` is "middle" or "full" (the strict direct-lookup gate on
|
|
16
|
+
* `/search`); "ranked" otherwise. Recorded as a leading indicator for
|
|
17
|
+
* precise-lookup trust: a healthy exact-ID flow has a high success
|
|
18
|
+
* ratio and rare typed failures; failures are trust-loss risk signals
|
|
19
|
+
* that may push an agent to seek evidence outside Rift.
|
|
20
|
+
* Trust risk is named precisely — we cannot tell from Rift alone that
|
|
21
|
+
* the agent went on to read JSONL from disk, only that the precise
|
|
22
|
+
* lookup it asked for here failed.
|
|
23
|
+
*/
|
|
24
|
+
search_mode?: SearchMode;
|
|
25
|
+
/** rift_search only: the detail level argued by the caller. */
|
|
26
|
+
detail?: DetailLevel;
|
|
27
|
+
/** rift_search only: whether the caller supplied an `id`. */
|
|
28
|
+
id_present?: boolean;
|
|
29
|
+
/** rift_search only: whether the caller supplied a `tier`. */
|
|
30
|
+
tier_present?: boolean;
|
|
31
|
+
/** rift_search only: whether the caller supplied a `source_table`. */
|
|
32
|
+
source_table_present?: boolean;
|
|
33
|
+
/**
|
|
34
|
+
* rift_search only: the typed error code parsed from the response
|
|
35
|
+
* body when the call failed with a structured error (e.g.
|
|
36
|
+
* `id_not_found`, `ambiguous_id`). Absent for generic transport
|
|
37
|
+
* failures or untyped 4xx/5xx.
|
|
38
|
+
*/
|
|
39
|
+
typed_error?: string;
|
|
40
|
+
/**
|
|
41
|
+
* rift_search only: true when any returned hit carries
|
|
42
|
+
* `content_truncated === true`. Signals that the agent received a
|
|
43
|
+
* bounded middle-detail excerpt rather than the full row body — a
|
|
44
|
+
* useful leading indicator that the agent may decide to escalate to
|
|
45
|
+
* `detail=full` next.
|
|
46
|
+
*/
|
|
47
|
+
has_truncated_content?: boolean;
|
|
48
|
+
/**
|
|
49
|
+
* rift_search only: the maximum `content_tokens_estimate` observed
|
|
50
|
+
* across returned hits. Cheap to compute (the size advisory is
|
|
51
|
+
* already on each hit) and lets us see whether agents are routinely
|
|
52
|
+
* being shown rows that would blow context if expanded.
|
|
53
|
+
*/
|
|
54
|
+
max_content_tokens_estimate?: number;
|
|
55
|
+
/**
|
|
56
|
+
* Total UTF-8 byte length of `content[].text` on the MCP response we
|
|
57
|
+
* hand back to the caller. The text channel is the user/model-visible
|
|
58
|
+
* answer; we count it (rather than `structuredContent`, which often
|
|
59
|
+
* duplicates the same data) so the resulting tokens-delivered estimate
|
|
60
|
+
* isn't double-counted. Recorded on every successful call so it can
|
|
61
|
+
* survive retrieval-tool / non-retrieval-tool reclassifications later.
|
|
62
|
+
*/
|
|
63
|
+
response_text_bytes?: number;
|
|
11
64
|
}
|
|
12
65
|
export declare function sanitizeArgs(raw: Record<string, unknown>): Record<string, unknown>;
|
|
13
66
|
/**
|
|
14
|
-
* Try to extract result_count from
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
* and fall back to JSON-parsing the text channel for backwards compatibility
|
|
19
|
-
* with tools that still return JSON there.
|
|
67
|
+
* Try to extract `result_count` from a retrieval-tool response. For search
|
|
68
|
+
* tools this is `results.length`; for `rift_context_pack` it is the sum of
|
|
69
|
+
* all four bucket sizes (decisions + constraints + examples + rules).
|
|
70
|
+
* Returns `undefined` for non-retrieval tools.
|
|
20
71
|
*/
|
|
21
72
|
export declare function extractResultCount(tool: string, mcpResult: {
|
|
22
73
|
content: Array<{
|
|
@@ -26,7 +77,9 @@ export declare function extractResultCount(tool: string, mcpResult: {
|
|
|
26
77
|
structuredContent?: Record<string, unknown>;
|
|
27
78
|
}): number | undefined;
|
|
28
79
|
/**
|
|
29
|
-
* Try to extract degraded flag from
|
|
80
|
+
* Try to extract the `degraded` flag from a retrieval-tool response.
|
|
81
|
+
* Returns `undefined` for non-retrieval tools and for retrieval tools whose
|
|
82
|
+
* response did not carry the flag.
|
|
30
83
|
*/
|
|
31
84
|
export declare function extractDegraded(tool: string, mcpResult: {
|
|
32
85
|
content: Array<{
|
|
@@ -35,6 +88,46 @@ export declare function extractDegraded(tool: string, mcpResult: {
|
|
|
35
88
|
}>;
|
|
36
89
|
structuredContent?: Record<string, unknown>;
|
|
37
90
|
}): boolean | undefined;
|
|
91
|
+
/**
|
|
92
|
+
* Derive search-mode metadata from the raw rift_search args. Mirrors the
|
|
93
|
+
* direct-lookup gate on `/search`: `id` + (`middle` | `full`) → exact_id;
|
|
94
|
+
* anything else is ranked retrieval, even if `id` is present alongside
|
|
95
|
+
* `detail="summary"` (which doesn't trigger the strict path).
|
|
96
|
+
*/
|
|
97
|
+
export declare function deriveSearchModeMeta(args: Record<string, unknown>): {
|
|
98
|
+
search_mode: SearchMode;
|
|
99
|
+
detail: DetailLevel;
|
|
100
|
+
id_present: boolean;
|
|
101
|
+
tier_present: boolean;
|
|
102
|
+
source_table_present: boolean;
|
|
103
|
+
};
|
|
104
|
+
/**
|
|
105
|
+
* Derive result-side metadata for a successful rift_search call:
|
|
106
|
+
* - has_truncated_content: any returned hit with content_truncated=true
|
|
107
|
+
* - max_content_tokens_estimate: max content_tokens_estimate across hits
|
|
108
|
+
*
|
|
109
|
+
* Reads from `structuredContent.results` (the canonical compact DTO).
|
|
110
|
+
* Returns `{}` when the result shape is unknown — never throws.
|
|
111
|
+
*/
|
|
112
|
+
export declare function extractSearchResultMeta(mcpResult: {
|
|
113
|
+
content: Array<{
|
|
114
|
+
type: string;
|
|
115
|
+
text: string;
|
|
116
|
+
}>;
|
|
117
|
+
structuredContent?: Record<string, unknown>;
|
|
118
|
+
}): {
|
|
119
|
+
has_truncated_content?: boolean;
|
|
120
|
+
max_content_tokens_estimate?: number;
|
|
121
|
+
};
|
|
122
|
+
/**
|
|
123
|
+
* Try to parse the typed error code (`id_not_found`, `ambiguous_id`, …)
|
|
124
|
+
* out of a failure response's text channel. `formatError` formats typed
|
|
125
|
+
* 404/409 bodies as `"<Prefix>: { "error": "id_not_found", … }"`, so we
|
|
126
|
+
* locate the first `{`, JSON.parse to end, and return the `error` field
|
|
127
|
+
* when it's a string. Returns `undefined` for transport-only failures
|
|
128
|
+
* (no body), untyped responses, or unparseable text.
|
|
129
|
+
*/
|
|
130
|
+
export declare function parseTypedError(text: string | undefined): string | undefined;
|
|
38
131
|
export declare class ToolUsageLogger {
|
|
39
132
|
private readonly logPath;
|
|
40
133
|
constructor(dataDir: string);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tool-usage.d.ts","sourceRoot":"","sources":["../../../src/observability/tool-usage.ts"],"names":[],"mappings":"AAwBA,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,eAAe,CAAC;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,OAAO,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"tool-usage.d.ts","sourceRoot":"","sources":["../../../src/observability/tool-usage.ts"],"names":[],"mappings":"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"}
|