@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
|
@@ -1,7 +1,43 @@
|
|
|
1
1
|
import { getBuildInfo } from "../build-info.js";
|
|
2
|
-
import { readAutoCaptureRunSummary, } from "../../capture/observability.js";
|
|
2
|
+
import { autoCaptureRunFailed, readAutoCaptureRunSummary, } from "../../capture/observability.js";
|
|
3
|
+
import { classifyParkedOversizedSessions } from "../../capture/auto-repair.js";
|
|
3
4
|
import { loadFeedbackConfig } from "../../cli/feedback/feedback-config.js";
|
|
5
|
+
import { classifyCodexPreflightError, extractCodexModelFromError, summarizeCodexPreflightClass, } from "../../diagnostics/codex-preflight.js";
|
|
4
6
|
import { sanitizeProjectLabel } from "../../runtime/legacy-name-guard.js";
|
|
7
|
+
import { readEmbeddingEvents, } from "../../observability/embedding-events.js";
|
|
8
|
+
import { readIndexEvents, } from "../../observability/index-events.js";
|
|
9
|
+
import { compareBetaVersions, readVersionCheck, } from "../../observability/version-check.js";
|
|
10
|
+
import { computeOnboardingState, isUsefulStateReached, readOnboardingMetric, stampUsefulStateIfReady, } from "../../observability/onboarding-metric.js";
|
|
11
|
+
import { getCapabilityCounts } from "../../observability/rift-context.js";
|
|
12
|
+
const VOYAGE_ERROR_LOOKBACK_MS = 24 * 60 * 60 * 1000;
|
|
13
|
+
const INDEX_ERROR_LOOKBACK_MS = 24 * 60 * 60 * 1000;
|
|
14
|
+
const INBOX_ERROR_LOOKBACK_MS = 24 * 60 * 60 * 1000;
|
|
15
|
+
const INBOX_IDEMPOTENCY_PREFIX = "inbox:";
|
|
16
|
+
/**
|
|
17
|
+
* Build the codex block, classifying the last preflight failure into a
|
|
18
|
+
* leak-free, honest diagnosis. On success (or no run) the failure fields are
|
|
19
|
+
* null.
|
|
20
|
+
*/
|
|
21
|
+
function codexBlock(last) {
|
|
22
|
+
if (!last || last.preflight_ok) {
|
|
23
|
+
return {
|
|
24
|
+
last_preflight_at: last?.timestamp ?? null,
|
|
25
|
+
last_preflight_ok: last ? last.preflight_ok : null,
|
|
26
|
+
last_preflight_error_class: null,
|
|
27
|
+
last_preflight_model: null,
|
|
28
|
+
last_preflight_error_summary: null,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
const errorClass = classifyCodexPreflightError(last.preflight_error);
|
|
32
|
+
const model = extractCodexModelFromError(last.preflight_error);
|
|
33
|
+
return {
|
|
34
|
+
last_preflight_at: last.timestamp,
|
|
35
|
+
last_preflight_ok: false,
|
|
36
|
+
last_preflight_error_class: errorClass,
|
|
37
|
+
last_preflight_model: model,
|
|
38
|
+
last_preflight_error_summary: summarizeCodexPreflightClass(errorClass, model),
|
|
39
|
+
};
|
|
40
|
+
}
|
|
5
41
|
export function buildFriendStatusPayload(deps) {
|
|
6
42
|
const build = getBuildInfo();
|
|
7
43
|
const voyageKey = process.env["VOYAGE_API_KEY"];
|
|
@@ -11,9 +47,10 @@ export function buildFriendStatusPayload(deps) {
|
|
|
11
47
|
summary = readAutoCaptureRunSummary(dataDir, deps.config.capture.sources);
|
|
12
48
|
}
|
|
13
49
|
catch {
|
|
14
|
-
summary = { last_run: null, last_success_by_source: {} };
|
|
50
|
+
summary = { last_run: null, last_daemon_run: null, last_success_by_source: {} };
|
|
15
51
|
}
|
|
16
52
|
const last = summary.last_run;
|
|
53
|
+
const lastDaemon = summary.last_daemon_run;
|
|
17
54
|
let captureTotals = { saved: 0, review: 0, quarantined: 0 };
|
|
18
55
|
if (last) {
|
|
19
56
|
for (const counts of Object.values(last.counts_by_source)) {
|
|
@@ -24,18 +61,29 @@ export function buildFriendStatusPayload(deps) {
|
|
|
24
61
|
captureTotals.quarantined += counts.quarantined ?? 0;
|
|
25
62
|
}
|
|
26
63
|
}
|
|
27
|
-
let
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
lastEmbedAt = success.timestamp;
|
|
31
|
-
}
|
|
64
|
+
let parkedClassification = { parked: 0, repairing: 0, failed: 0 };
|
|
65
|
+
try {
|
|
66
|
+
parkedClassification = classifyParkedOversizedSessions({ dataDir });
|
|
32
67
|
}
|
|
68
|
+
catch {
|
|
69
|
+
parkedClassification = { parked: 0, repairing: 0, failed: 0 };
|
|
70
|
+
}
|
|
71
|
+
const voyageHealth = computeVoyageHealth(dataDir, Date.now());
|
|
72
|
+
const indexHealth = computeIndexHealth(dataDir, Date.now());
|
|
73
|
+
const inboxHealth = computeInboxHealth(deps.jobQueue, Date.now());
|
|
74
|
+
// `enabled` covers both opt-in shapes (contact email and/or operator
|
|
75
|
+
// relay), so a relay is "on" only when an endpoint URL also exists —
|
|
76
|
+
// otherwise an email-only opt-in would falsely read as a Clem-side relay.
|
|
33
77
|
let relayEnabled = false;
|
|
78
|
+
let contactOptedIn = false;
|
|
34
79
|
try {
|
|
35
|
-
|
|
80
|
+
const fb = loadFeedbackConfig(dataDir);
|
|
81
|
+
relayEnabled = fb.enabled === true && typeof fb.url === "string" && fb.url.length > 0;
|
|
82
|
+
contactOptedIn = fb.enabled === true && typeof fb.email === "string" && fb.email.length > 0;
|
|
36
83
|
}
|
|
37
84
|
catch {
|
|
38
85
|
relayEnabled = false;
|
|
86
|
+
contactOptedIn = false;
|
|
39
87
|
}
|
|
40
88
|
return {
|
|
41
89
|
build,
|
|
@@ -43,28 +91,414 @@ export function buildFriendStatusPayload(deps) {
|
|
|
43
91
|
uptime_seconds: Math.floor((Date.now() - deps.startTime) / 1000),
|
|
44
92
|
port: deps.config.server.port,
|
|
45
93
|
voyage_key_present: typeof voyageKey === "string" && voyageKey.length > 0,
|
|
94
|
+
capture_enabled: deps.config.capture.enabled === true,
|
|
95
|
+
data_dir: dataDir,
|
|
46
96
|
},
|
|
47
97
|
voyage: {
|
|
48
98
|
project_label: sanitizeProjectLabel(deps.config.voyage?.project_label),
|
|
49
|
-
last_embed_at:
|
|
99
|
+
last_embed_at: voyageHealth.last_embed_at,
|
|
100
|
+
last_error_at: voyageHealth.last_error_at,
|
|
101
|
+
last_error_reason: voyageHealth.last_error_reason,
|
|
50
102
|
},
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
103
|
+
index: {
|
|
104
|
+
last_update_at: indexHealth.last_update_at,
|
|
105
|
+
last_error_at: indexHealth.last_error_at,
|
|
106
|
+
last_error_reason: indexHealth.last_error_reason,
|
|
54
107
|
},
|
|
108
|
+
inbox: inboxHealth,
|
|
109
|
+
codex: codexBlock(last),
|
|
55
110
|
capture: {
|
|
56
111
|
last_run_at: last?.timestamp ?? null,
|
|
57
112
|
last_run_ok: last ? last.run_ok : null,
|
|
113
|
+
last_run_trigger: last ? (last.trigger ?? "daemon") : null,
|
|
58
114
|
last_saved: captureTotals.saved,
|
|
59
115
|
last_review: captureTotals.review,
|
|
60
116
|
last_errors: last?.errors.length ?? 0,
|
|
61
117
|
last_quarantined: captureTotals.quarantined,
|
|
118
|
+
oversized_parked: parkedClassification.parked,
|
|
119
|
+
oversized_repairing: parkedClassification.repairing,
|
|
120
|
+
oversized_repair_failed: parkedClassification.failed,
|
|
121
|
+
next_run_at: computeNextCaptureRunAt({
|
|
122
|
+
captureEnabled: deps.config.capture.enabled,
|
|
123
|
+
intervalSeconds: deps.config.capture.interval_seconds,
|
|
124
|
+
startTime: deps.startTime,
|
|
125
|
+
now: Date.now(),
|
|
126
|
+
}),
|
|
127
|
+
last_daemon_run_at: lastDaemon?.timestamp ?? null,
|
|
128
|
+
last_daemon_failed: lastDaemon ? autoCaptureRunFailed(lastDaemon) : null,
|
|
62
129
|
},
|
|
63
|
-
feedback: { relay_enabled: relayEnabled },
|
|
130
|
+
feedback: { relay_enabled: relayEnabled, contact_opted_in: contactOptedIn },
|
|
131
|
+
update: computeUpdateProjection(dataDir, build.version),
|
|
132
|
+
onboarding: projectOnboardingState(dataDir),
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Read the persisted metric and return its projection. Pure read — start
|
|
137
|
+
* stamping happens in the async `stampOnboardingStartIfReady` helper so
|
|
138
|
+
* the sync builder (and its test surface) stay sync. The route awaits
|
|
139
|
+
* the stamper before calling `buildFriendStatusPayload`, so a freshly
|
|
140
|
+
* stamped start is visible in the same response.
|
|
141
|
+
*
|
|
142
|
+
* Exported for tests.
|
|
143
|
+
*/
|
|
144
|
+
export function projectOnboardingState(dataDir) {
|
|
145
|
+
const metric = readOnboardingMetric(dataDir);
|
|
146
|
+
const projection = computeOnboardingState(metric);
|
|
147
|
+
if (projection.state === "hidden") {
|
|
148
|
+
return {
|
|
149
|
+
state: "hidden",
|
|
150
|
+
install_id: metric.install_id,
|
|
151
|
+
useful_state_reached_at: null,
|
|
152
|
+
first_useful_recall_at: null,
|
|
153
|
+
first_useful_recall_tool: null,
|
|
154
|
+
duration_seconds: null,
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
if (projection.state === "pending") {
|
|
158
|
+
return {
|
|
159
|
+
state: "pending",
|
|
160
|
+
install_id: metric.install_id,
|
|
161
|
+
useful_state_reached_at: projection.useful_state_reached_at,
|
|
162
|
+
first_useful_recall_at: null,
|
|
163
|
+
first_useful_recall_tool: null,
|
|
164
|
+
duration_seconds: null,
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
return {
|
|
168
|
+
state: "completed",
|
|
169
|
+
install_id: metric.install_id,
|
|
170
|
+
useful_state_reached_at: projection.useful_state_reached_at,
|
|
171
|
+
first_useful_recall_at: projection.first_useful_recall_at,
|
|
172
|
+
first_useful_recall_tool: projection.first_useful_recall_tool,
|
|
173
|
+
duration_seconds: projection.duration_seconds,
|
|
64
174
|
};
|
|
65
175
|
}
|
|
176
|
+
/**
|
|
177
|
+
* Async readiness evaluation + write-once start stamping. Pulled out of
|
|
178
|
+
* `buildFriendStatusPayload` so the sync builder stays sync; the route
|
|
179
|
+
* awaits this before assembling the payload, so a stamp written here
|
|
180
|
+
* is visible in the same response.
|
|
181
|
+
*
|
|
182
|
+
* Readiness signals for v1:
|
|
183
|
+
* - daemon healthy: trivially true (this code is running inside the
|
|
184
|
+
* daemon process that is serving the request).
|
|
185
|
+
* - Voyage key valid: VOYAGE_API_KEY env present AND at least one
|
|
186
|
+
* successful Voyage embedding has been recorded on the ingest lane
|
|
187
|
+
* (a real round-trip with this key, not just "env var is set").
|
|
188
|
+
* - indexed count >= 1: `getCapabilityCounts()` reports at least one
|
|
189
|
+
* conversations_hot/cold or structured_docs row. Digest count is
|
|
190
|
+
* intentionally excluded — the bar is "conversations + structured
|
|
191
|
+
* docs" per the v1 spec.
|
|
192
|
+
*
|
|
193
|
+
* Never throws. A capability-counts failure (LanceDB not initialised,
|
|
194
|
+
* IO error) is treated as "not ready" rather than a 500, so a partial
|
|
195
|
+
* daemon never surfaces a misleading start timestamp.
|
|
196
|
+
*
|
|
197
|
+
* Exported for tests.
|
|
198
|
+
*/
|
|
199
|
+
export async function stampOnboardingStartIfReady(dataDir, opts = {}) {
|
|
200
|
+
const voyageKey = process.env["VOYAGE_API_KEY"];
|
|
201
|
+
const voyageKeyPresent = typeof voyageKey === "string" && voyageKey.length > 0;
|
|
202
|
+
const voyageHealth = opts.voyageHealth ?? computeVoyageHealth(dataDir, opts.now ?? Date.now());
|
|
203
|
+
const voyageKeyValid = voyageKeyPresent && voyageHealth.last_embed_at !== null;
|
|
204
|
+
// No-key installs are a first-class useful state: keyword (lexical) search is
|
|
205
|
+
// fully on without a Voyage key. We treat "no key present" as intentional
|
|
206
|
+
// lexical mode. A key that's present but not yet round-tripped (valid=false)
|
|
207
|
+
// is a setup-in-progress, NOT lexical mode — so it counts as neither and
|
|
208
|
+
// does not stamp useful, preserving the "env present but never embedded →
|
|
209
|
+
// not useful" contract.
|
|
210
|
+
const lexicalModeAvailable = !voyageKeyPresent;
|
|
211
|
+
let indexedCount = 0;
|
|
212
|
+
try {
|
|
213
|
+
const counts = await getCapabilityCounts();
|
|
214
|
+
indexedCount =
|
|
215
|
+
counts.structured_docs +
|
|
216
|
+
counts.conversations_hot +
|
|
217
|
+
counts.conversations_cold;
|
|
218
|
+
}
|
|
219
|
+
catch {
|
|
220
|
+
indexedCount = 0;
|
|
221
|
+
}
|
|
222
|
+
const ready = isUsefulStateReached({
|
|
223
|
+
daemonHealthy: true,
|
|
224
|
+
voyageKeyValid,
|
|
225
|
+
lexicalModeAvailable,
|
|
226
|
+
indexedCount,
|
|
227
|
+
});
|
|
228
|
+
stampUsefulStateIfReady(dataDir, {
|
|
229
|
+
ready,
|
|
230
|
+
now: new Date(opts.now ?? Date.now()).toISOString(),
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* Project the version-check snapshot to the three fields the renderer
|
|
235
|
+
* needs. A missing snapshot, a failed probe, or an up-to-date install
|
|
236
|
+
* all return `available: false` — the renderer prints nothing in those
|
|
237
|
+
* cases, so an unreachable npm registry can never make Rift look broken.
|
|
238
|
+
*
|
|
239
|
+
* Exported for tests.
|
|
240
|
+
*/
|
|
241
|
+
export function computeUpdateProjection(dataDir, installedVersion) {
|
|
242
|
+
const snapshot = readVersionCheck(dataDir);
|
|
243
|
+
if (!snapshot || snapshot.latest_beta === null) {
|
|
244
|
+
return {
|
|
245
|
+
available: false,
|
|
246
|
+
installed: installedVersion,
|
|
247
|
+
latest_beta: snapshot?.latest_beta ?? null,
|
|
248
|
+
checked_at: snapshot?.checked_at ?? null,
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
// Use the installedVersion from the live build, not the snapshot, so a
|
|
252
|
+
// post-update daemon restart immediately reports `available: false`
|
|
253
|
+
// even before the next probe writes a fresh snapshot.
|
|
254
|
+
const available = compareBetaVersions(installedVersion, snapshot.latest_beta) < 0;
|
|
255
|
+
return {
|
|
256
|
+
available,
|
|
257
|
+
installed: installedVersion,
|
|
258
|
+
latest_beta: snapshot.latest_beta,
|
|
259
|
+
checked_at: snapshot.checked_at,
|
|
260
|
+
};
|
|
261
|
+
}
|
|
262
|
+
/**
|
|
263
|
+
* Compute the next auto-capture tick.
|
|
264
|
+
*
|
|
265
|
+
* The daemon registers `setInterval(runCapture, intervalMs)` at startup
|
|
266
|
+
* (`src/main.ts`), so ticks land at `startTime + N * intervalMs` for
|
|
267
|
+
* N ≥ 1 (N = 0 is the eager startup call). We deliberately anchor to
|
|
268
|
+
* `startTime` rather than `last_run_at` because:
|
|
269
|
+
* - `setInterval` does, so this matches what will actually fire.
|
|
270
|
+
* - `last_run_at` lags by hundreds of ms (save-job wait), and could
|
|
271
|
+
* be stale from a prior daemon process for the first interval after
|
|
272
|
+
* a restart.
|
|
273
|
+
*
|
|
274
|
+
* Returns null when auto-capture is disabled in config.
|
|
275
|
+
*
|
|
276
|
+
* Exported for tests.
|
|
277
|
+
*/
|
|
278
|
+
export function computeNextCaptureRunAt(opts) {
|
|
279
|
+
if (!opts.captureEnabled)
|
|
280
|
+
return null;
|
|
281
|
+
if (opts.intervalSeconds <= 0)
|
|
282
|
+
return null;
|
|
283
|
+
const intervalMs = opts.intervalSeconds * 1000;
|
|
284
|
+
const elapsed = Math.max(0, opts.now - opts.startTime);
|
|
285
|
+
const ticksElapsed = Math.floor(elapsed / intervalMs);
|
|
286
|
+
return new Date(opts.startTime + (ticksElapsed + 1) * intervalMs).toISOString();
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Reduce the embedding-events lane to the three voyage health fields the
|
|
290
|
+
* friend-status route needs.
|
|
291
|
+
*
|
|
292
|
+
* Exported for tests so we can verify the pipeline-filter and 24h-window
|
|
293
|
+
* logic without booting Fastify or stubbing the route layer.
|
|
294
|
+
*/
|
|
295
|
+
export function computeVoyageHealth(dataDir, now) {
|
|
296
|
+
let events;
|
|
297
|
+
try {
|
|
298
|
+
events = readEmbeddingEvents(dataDir);
|
|
299
|
+
}
|
|
300
|
+
catch {
|
|
301
|
+
events = [];
|
|
302
|
+
}
|
|
303
|
+
let lastSuccessTs = null;
|
|
304
|
+
let lastErrorTs = null;
|
|
305
|
+
let lastErrorReason = null;
|
|
306
|
+
const errorCutoff = now - VOYAGE_ERROR_LOOKBACK_MS;
|
|
307
|
+
for (const event of events) {
|
|
308
|
+
// The `voyage.*` projection must reflect Voyage health only. The lane
|
|
309
|
+
// itself is provider-agnostic so a future Ollama-only install reuses
|
|
310
|
+
// the same writer, but on a mixed cloud+local install an Ollama
|
|
311
|
+
// success would otherwise refresh `voyage.last_embed_at` and mask a
|
|
312
|
+
// Voyage outage. Filter at projection time, not write time.
|
|
313
|
+
if (event.provider !== "voyage")
|
|
314
|
+
continue;
|
|
315
|
+
if (event.outcome === "success") {
|
|
316
|
+
if (!lastSuccessTs || event.ts > lastSuccessTs) {
|
|
317
|
+
lastSuccessTs = event.ts;
|
|
318
|
+
}
|
|
319
|
+
continue;
|
|
320
|
+
}
|
|
321
|
+
// outcome === "error"
|
|
322
|
+
const eventTime = Date.parse(event.ts);
|
|
323
|
+
if (Number.isNaN(eventTime) || eventTime < errorCutoff)
|
|
324
|
+
continue;
|
|
325
|
+
if (!lastErrorTs || event.ts > lastErrorTs) {
|
|
326
|
+
lastErrorTs = event.ts;
|
|
327
|
+
lastErrorReason = event.error_class ?? "unknown";
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
return {
|
|
331
|
+
last_embed_at: lastSuccessTs,
|
|
332
|
+
last_error_at: lastErrorTs,
|
|
333
|
+
last_error_reason: lastErrorReason,
|
|
334
|
+
};
|
|
335
|
+
}
|
|
336
|
+
/**
|
|
337
|
+
* Reduce the index-events lane to the three index health fields the
|
|
338
|
+
* friend-status route needs. Provider-agnostic and table-agnostic: an
|
|
339
|
+
* embed can succeed but the subsequent `table.add(...)` can fail, and
|
|
340
|
+
* `index.*` is what makes that visible. No 24h filter on `last_update_at`
|
|
341
|
+
* (a daemon that has not indexed in 7 days should still surface the
|
|
342
|
+
* stale timestamp); errors are filtered to the 24h window so old
|
|
343
|
+
* resolved incidents don't sit on the dashboard forever.
|
|
344
|
+
*/
|
|
345
|
+
export function computeIndexHealth(dataDir, now) {
|
|
346
|
+
let events;
|
|
347
|
+
try {
|
|
348
|
+
events = readIndexEvents(dataDir);
|
|
349
|
+
}
|
|
350
|
+
catch {
|
|
351
|
+
events = [];
|
|
352
|
+
}
|
|
353
|
+
let lastSuccessTs = null;
|
|
354
|
+
let lastErrorTs = null;
|
|
355
|
+
let lastErrorReason = null;
|
|
356
|
+
const errorCutoff = now - INDEX_ERROR_LOOKBACK_MS;
|
|
357
|
+
for (const event of events) {
|
|
358
|
+
if (event.outcome === "success") {
|
|
359
|
+
// Shadow-phase successes do NOT credit `last_update_at`: a row
|
|
360
|
+
// written to a shadow table is "prepared", not "searchable",
|
|
361
|
+
// until `commitAllSwaps` runs. If the swap rolls back, those
|
|
362
|
+
// rows stay invisible — so claiming a fresh index from them
|
|
363
|
+
// would lie. The post-commit "live" event is what credits the
|
|
364
|
+
// real update timestamp.
|
|
365
|
+
const phase = event.phase ?? "live";
|
|
366
|
+
if (phase !== "live")
|
|
367
|
+
continue;
|
|
368
|
+
if (!lastSuccessTs || event.ts > lastSuccessTs) {
|
|
369
|
+
lastSuccessTs = event.ts;
|
|
370
|
+
}
|
|
371
|
+
continue;
|
|
372
|
+
}
|
|
373
|
+
// Errors at any phase (including shadow) count toward
|
|
374
|
+
// `last_error_at` — a per-row LanceDB write failure during shadow
|
|
375
|
+
// population is a real failure regardless of the eventual swap.
|
|
376
|
+
const eventTime = Date.parse(event.ts);
|
|
377
|
+
if (Number.isNaN(eventTime) || eventTime < errorCutoff)
|
|
378
|
+
continue;
|
|
379
|
+
if (!lastErrorTs || event.ts > lastErrorTs) {
|
|
380
|
+
lastErrorTs = event.ts;
|
|
381
|
+
lastErrorReason = event.error_class ?? "unknown";
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
return {
|
|
385
|
+
last_update_at: lastSuccessTs,
|
|
386
|
+
last_error_at: lastErrorTs,
|
|
387
|
+
last_error_reason: lastErrorReason,
|
|
388
|
+
};
|
|
389
|
+
}
|
|
390
|
+
/**
|
|
391
|
+
* Reduce the inbox-keyed job set to the four fields the friend-status
|
|
392
|
+
* route needs. Pure over the queue's snapshot (no I/O), so tests can
|
|
393
|
+
* pass an in-memory `JobQueue` without booting Fastify.
|
|
394
|
+
*
|
|
395
|
+
* When the queue isn't wired up (deps.jobQueue undefined), this
|
|
396
|
+
* returns the empty / idle shape — the renderer treats it the same
|
|
397
|
+
* as "nothing dropped yet."
|
|
398
|
+
*
|
|
399
|
+
* Exported for tests.
|
|
400
|
+
*/
|
|
401
|
+
export function computeInboxHealth(queue, now) {
|
|
402
|
+
if (!queue) {
|
|
403
|
+
return {
|
|
404
|
+
last_import_at: null,
|
|
405
|
+
last_error_at: null,
|
|
406
|
+
last_error_reason: null,
|
|
407
|
+
pending: 0,
|
|
408
|
+
};
|
|
409
|
+
}
|
|
410
|
+
const jobs = queue.listByIdempotencyPrefix(INBOX_IDEMPOTENCY_PREFIX);
|
|
411
|
+
let lastImportTs = null;
|
|
412
|
+
let lastErrorTs = null;
|
|
413
|
+
let lastErrorReason = null;
|
|
414
|
+
let pending = 0;
|
|
415
|
+
const errorCutoff = now - INBOX_ERROR_LOOKBACK_MS;
|
|
416
|
+
for (const job of jobs) {
|
|
417
|
+
// Skip superseded jobs — the queue chains a retry by setting
|
|
418
|
+
// `retried_by` on the failed/completed parent and creating a fresh
|
|
419
|
+
// job with the same idempotency key. Counting both would let a
|
|
420
|
+
// long-resolved failure keep the "Inbox import errors" hint live
|
|
421
|
+
// for 24h after the retry already succeeded; the leaf is the only
|
|
422
|
+
// entry that reflects current state. (Same invariant the queue
|
|
423
|
+
// itself enforces in `findByIdempotencyKey`.)
|
|
424
|
+
if (job.retried_by !== undefined)
|
|
425
|
+
continue;
|
|
426
|
+
if (job.status === "queued" || job.status === "running") {
|
|
427
|
+
pending++;
|
|
428
|
+
continue;
|
|
429
|
+
}
|
|
430
|
+
if (job.status === "completed") {
|
|
431
|
+
if (!lastImportTs || job.updated_at > lastImportTs) {
|
|
432
|
+
lastImportTs = job.updated_at;
|
|
433
|
+
}
|
|
434
|
+
continue;
|
|
435
|
+
}
|
|
436
|
+
if (job.status === "failed") {
|
|
437
|
+
const eventTime = Date.parse(job.updated_at);
|
|
438
|
+
if (Number.isNaN(eventTime) || eventTime < errorCutoff)
|
|
439
|
+
continue;
|
|
440
|
+
if (!lastErrorTs || job.updated_at > lastErrorTs) {
|
|
441
|
+
lastErrorTs = job.updated_at;
|
|
442
|
+
lastErrorReason = classifyJobError(job);
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
// cancelled / interrupted: ignore — neither a successful import
|
|
446
|
+
// nor a real error the user can act on. A retry will be either
|
|
447
|
+
// queued (counted as pending) or completed/failed (counted above).
|
|
448
|
+
}
|
|
449
|
+
return {
|
|
450
|
+
last_import_at: lastImportTs,
|
|
451
|
+
last_error_at: lastErrorTs,
|
|
452
|
+
last_error_reason: lastErrorReason,
|
|
453
|
+
pending,
|
|
454
|
+
};
|
|
455
|
+
}
|
|
456
|
+
/**
|
|
457
|
+
* Best-effort short label for a failed inbox job's error. The queue
|
|
458
|
+
* stores the raw error message (`job.error`); we collapse it into a
|
|
459
|
+
* compact class keyword by substring match against the parser errors
|
|
460
|
+
* we know about, then fall back to a truncated form of the original
|
|
461
|
+
* message. Lower-cased for stability under capitalization drift.
|
|
462
|
+
*
|
|
463
|
+
* Exported for tests.
|
|
464
|
+
*/
|
|
465
|
+
export function classifyJobError(job) {
|
|
466
|
+
const raw = (job.error ?? "").trim();
|
|
467
|
+
if (!raw)
|
|
468
|
+
return "unknown";
|
|
469
|
+
const lower = raw.toLowerCase();
|
|
470
|
+
if (lower.includes("zip slip") || lower.includes("path traversal")) {
|
|
471
|
+
return "unsafe_archive";
|
|
472
|
+
}
|
|
473
|
+
if (lower.includes("too large") || lower.includes("max size")) {
|
|
474
|
+
return "size_limit";
|
|
475
|
+
}
|
|
476
|
+
if (lower.includes("unsupported source"))
|
|
477
|
+
return "unsupported_source";
|
|
478
|
+
if (lower.includes("no conversations"))
|
|
479
|
+
return "empty_export";
|
|
480
|
+
if (lower.includes("invalid json") || lower.includes("unexpected token")) {
|
|
481
|
+
return "invalid_json";
|
|
482
|
+
}
|
|
483
|
+
// ADM-ZIP throws strings like "ADM-ZIP: Invalid or unsupported zip
|
|
484
|
+
// format" when adm-zip can't open the archive at all (corrupt header,
|
|
485
|
+
// truncated CD). Distinct from `unsafe_archive` (security-blocked) —
|
|
486
|
+
// this is "the ZIP itself is broken before we can even look inside."
|
|
487
|
+
if (lower.includes("adm-zip") || lower.includes("invalid or unsupported zip")) {
|
|
488
|
+
return "invalid_archive";
|
|
489
|
+
}
|
|
490
|
+
if (lower.includes("parser"))
|
|
491
|
+
return "parser_error";
|
|
492
|
+
// Fallback: first ≤40 chars of the raw message, single-lined.
|
|
493
|
+
const snippet = raw.replace(/\s+/g, " ").slice(0, 40);
|
|
494
|
+
return snippet || "unknown";
|
|
495
|
+
}
|
|
66
496
|
export function registerFriendStatusRoute(server, deps) {
|
|
67
497
|
server.get("/status/friend", async (_request, reply) => {
|
|
498
|
+
// Stamp `useful_state_reached_at` lazily on read. The metric file
|
|
499
|
+
// lives in the shared data dir, so the MCP-side end stamper sees
|
|
500
|
+
// the same value on the next retrieval.
|
|
501
|
+
await stampOnboardingStartIfReady(deps.config.data_paths.data_dir);
|
|
68
502
|
return reply.send(buildFriendStatusPayload(deps));
|
|
69
503
|
});
|
|
70
504
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"friend-status.js","sourceRoot":"","sources":["../../../../src/server/routes/friend-status.ts"],"names":[],"mappings":"AAoBA,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EACL,yBAAyB,GAE1B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AA2D1E,MAAM,UAAU,wBAAwB,CACtC,IAAsB;IAEtB,MAAM,KAAK,GAAG,YAAY,EAAE,CAAC;IAC7B,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;IAChD,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;IAEhD,IAAI,OAAO,CAAC;IACZ,IAAI,CAAC;QACH,OAAO,GAAG,yBAAyB,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAC5E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,sBAAsB,EAAE,EAAE,EAAE,CAAC;IAC3D,CAAC;IACD,MAAM,IAAI,GAAgC,OAAO,CAAC,QAAQ,CAAC;IAE3D,IAAI,aAAa,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC;IAC5D,IAAI,IAAI,EAAE,CAAC;QACT,KAAK,MAAM,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC;YAC1D,IAAI,CAAC,MAAM;gBAAE,SAAS;YACtB,aAAa,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC;YACpC,aAAa,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC;YACtC,aAAa,CAAC,WAAW,IAAI,MAAM,CAAC,WAAW,IAAI,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED,IAAI,WAAW,GAAkB,IAAI,CAAC;IACtC,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,sBAAsB,CAAC,EAAE,CAAC;QACpE,IAAI,OAAO,IAAI,CAAC,CAAC,WAAW,IAAI,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,EAAE,CAAC;YACjE,WAAW,GAAG,OAAO,CAAC,SAAS,CAAC;QAClC,CAAC;IACH,CAAC;IAED,IAAI,YAAY,GAAG,KAAK,CAAC;IACzB,IAAI,CAAC;QACH,YAAY,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC;IAC9D,CAAC;IAAC,MAAM,CAAC;QACP,YAAY,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,OAAO;QACL,KAAK;QACL,MAAM,EAAE;YACN,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;YAChE,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI;YAC7B,kBAAkB,EAChB,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC;SACxD;QACD,MAAM,EAAE;YACN,aAAa,EAAE,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC;YACtE,aAAa,EAAE,WAAW;SAC3B;QACD,KAAK,EAAE;YACL,iBAAiB,EAAE,IAAI,EAAE,SAAS,IAAI,IAAI;YAC1C,iBAAiB,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI;SACnD;QACD,OAAO,EAAE;YACP,WAAW,EAAE,IAAI,EAAE,SAAS,IAAI,IAAI;YACpC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI;YACtC,UAAU,EAAE,aAAa,CAAC,KAAK;YAC/B,WAAW,EAAE,aAAa,CAAC,MAAM;YACjC,WAAW,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,IAAI,CAAC;YACrC,gBAAgB,EAAE,aAAa,CAAC,WAAW;SAC5C;QACD,QAAQ,EAAE,EAAE,aAAa,EAAE,YAAY,EAAE;KAC1C,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,yBAAyB,CACvC,MAAuB,EACvB,IAAsB;IAEtB,MAAM,CAAC,GAAG,CAAC,gBAAgB,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE;QACrD,OAAO,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
1
|
+
{"version":3,"file":"friend-status.js","sourceRoot":"","sources":["../../../../src/server/routes/friend-status.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ingest.d.ts","sourceRoot":"","sources":["../../../../src/server/routes/ingest.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,eAAe,EAAgC,MAAM,SAAS,CAAC;AAC7E,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"ingest.d.ts","sourceRoot":"","sources":["../../../../src/server/routes/ingest.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,eAAe,EAAgC,MAAM,SAAS,CAAC;AAC7E,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAIpD,OAAO,EACL,cAAc,EAEf,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EAOL,KAAK,wBAAwB,EAC9B,MAAM,uCAAuC,CAAC;AAO/C,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,CAAC,OAAO,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC;IACxC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,8EAA8E;IAC9E,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,4BAA4B,CAAC,EAAE,wBAAwB,CAAC;CACzD;AAED,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,eAAe,EACvB,KAAK,EAAE,QAAQ,EACf,mBAAmB,EAAE,MAAM,EAC3B,kBAAkB,EAAE,OAAO,EAC3B,OAAO,EAAE,MAAM,GACd,IAAI,CA+IN"}
|
|
@@ -15,6 +15,7 @@
|
|
|
15
15
|
import { z } from "zod";
|
|
16
16
|
import { toJobStatusView } from "../../jobs/types.js";
|
|
17
17
|
import { consumeMultipartUpload } from "../middleware/multipart.js";
|
|
18
|
+
import { enqueueJob } from "./enqueue.js";
|
|
18
19
|
import { INGEST_SOURCES, isSourceSupported, } from "../../ingestion/parsers/types.js";
|
|
19
20
|
import { SOURCE_EXTENSIONS } from "../../ingestion/staging.js";
|
|
20
21
|
import { HISTORICAL_BACKFILL_CAPABILITY_HEADER, HISTORICAL_BACKFILL_OVERRIDE_HEADER, INTERNAL_HISTORICAL_INGEST_CODEX_ROUTE, CODEX_CLI_OVERRIDE_PROVIDER, hasHistoricalBackfillCapability, isHistoricalIngestIdempotencyKey, } from "../../providers/operator-overrides.js";
|
|
@@ -27,7 +28,7 @@ export function registerIngestRoute(server, queue, multipartLimitBytes, extracto
|
|
|
27
28
|
if (!extractorAvailable) {
|
|
28
29
|
return reply.code(501).send({
|
|
29
30
|
error: "not_configured",
|
|
30
|
-
message: "POST /ingest
|
|
31
|
+
message: "POST /ingest is unavailable: no metadata extractor configured",
|
|
31
32
|
});
|
|
32
33
|
}
|
|
33
34
|
// --- Consume multipart upload (file + fields) ---
|
|
@@ -113,7 +114,9 @@ export function registerIngestRoute(server, queue, multipartLimitBytes, extracto
|
|
|
113
114
|
if (parsed.data.idempotency_key !== undefined) {
|
|
114
115
|
opts.idempotency_key = parsed.data.idempotency_key;
|
|
115
116
|
}
|
|
116
|
-
const result = await queue
|
|
117
|
+
const result = await enqueueJob(reply, queue, "ingest", opts);
|
|
118
|
+
if (!result)
|
|
119
|
+
return;
|
|
117
120
|
if ("conflict" in result) {
|
|
118
121
|
return reply.code(409).send({ error: "conflict" });
|
|
119
122
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ingest.js","sourceRoot":"","sources":["../../../../src/server/routes/ingest.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AACH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EACL,cAAc,EACd,iBAAiB,GAClB,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EACL,qCAAqC,EACrC,mCAAmC,EACnC,sCAAsC,EACtC,2BAA2B,EAC3B,+BAA+B,EAC/B,gCAAgC,GAEjC,MAAM,uCAAuC,CAAC;AAE/C,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IAClC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;IAC9B,eAAe,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACvC,CAAC,CAAC;AAYH,MAAM,UAAU,mBAAmB,CACjC,MAAuB,EACvB,KAAe,EACf,mBAA2B,EAC3B,kBAA2B,EAC3B,OAAe;IAEf,MAAM,YAAY,GAAG,KAAK,EACxB,OAAuB,EACvB,KAAmB,EACnB,0BAAqD,EACrD,2BAA2B,GAAG,KAAK,EACnC,EAAE;QACF,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;gBAC1B,KAAK,EAAE,gBAAgB;gBACvB,OAAO,EAAE
|
|
1
|
+
{"version":3,"file":"ingest.js","sourceRoot":"","sources":["../../../../src/server/routes/ingest.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,10 +2,11 @@
|
|
|
2
2
|
* GET /stats/mcp-usage — unauthenticated MCP tool-call telemetry.
|
|
3
3
|
*
|
|
4
4
|
* SwiftBar pulls this on each tick. Returns per-window call counts +
|
|
5
|
-
*
|
|
6
|
-
*
|
|
7
|
-
*
|
|
8
|
-
*
|
|
5
|
+
* `context_tokens_delivered_estimate` (≈ ceil(returned-text bytes / 4)
|
|
6
|
+
* over measured context-hit calls) plus `context_tokens_measured_hits`,
|
|
7
|
+
* the numerator for "N/M hits measured" coverage. Mirrors the auth
|
|
8
|
+
* posture of `/health` and `/version` (no token required) — the response
|
|
9
|
+
* carries only call counts and tool names, never user content.
|
|
9
10
|
*/
|
|
10
11
|
import type { FastifyInstance } from "fastify";
|
|
11
12
|
import type { ObservabilityDeps } from "../../observability/coverage.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-usage.d.ts","sourceRoot":"","sources":["../../../../src/server/routes/mcp-usage.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"mcp-usage.d.ts","sourceRoot":"","sources":["../../../../src/server/routes/mcp-usage.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAM/C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AAEzE,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,eAAe,EACvB,IAAI,EAAE,iBAAiB,GACtB,IAAI,CAYN"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-usage.js","sourceRoot":"","sources":["../../../../src/server/routes/mcp-usage.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"mcp-usage.js","sourceRoot":"","sources":["../../../../src/server/routes/mcp-usage.ts"],"names":[],"mappings":"AAWA,OAAO,EACL,eAAe,EACf,4BAA4B,GAC7B,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,yCAAyC,CAAC;AAGzE,MAAM,UAAU,qBAAqB,CACnC,MAAuB,EACvB,IAAuB;IAEvB,MAAM,CAAC,GAAG,CAAC,kBAAkB,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE;QACvD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACpE,MAAM,OAAO,GAAG,4BAA4B,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC9D,MAAM,OAAO,GAAG,cAAc,CAAC,OAAO,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;YACpD,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC7B,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,EAAE,wBAAwB,CAAC,CAAC;YACpD,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,uBAAuB,EAAE,CAAC,CAAC;QAClE,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reconcile.d.ts","sourceRoot":"","sources":["../../../../src/server/routes/reconcile.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"reconcile.d.ts","sourceRoot":"","sources":["../../../../src/server/routes/reconcile.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAoBpD,wBAAgB,sBAAsB,CACpC,MAAM,EAAE,eAAe,EACvB,KAAK,EAAE,QAAQ,GACd,IAAI,CAyCN"}
|