@getrift/rift 0.1.0-beta.0 → 0.1.0-beta.10

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.
Files changed (202) hide show
  1. package/README.md +72 -48
  2. package/dist/src/auth/keychain.d.ts +9 -0
  3. package/dist/src/auth/keychain.d.ts.map +1 -1
  4. package/dist/src/auth/keychain.js +37 -0
  5. package/dist/src/auth/keychain.js.map +1 -1
  6. package/dist/src/capture/recover-quarantine.d.ts +221 -0
  7. package/dist/src/capture/recover-quarantine.d.ts.map +1 -0
  8. package/dist/src/capture/recover-quarantine.js +453 -0
  9. package/dist/src/capture/recover-quarantine.js.map +1 -0
  10. package/dist/src/cli/commands/backfill.d.ts.map +1 -1
  11. package/dist/src/cli/commands/backfill.js +5 -2
  12. package/dist/src/cli/commands/backfill.js.map +1 -1
  13. package/dist/src/cli/commands/capture-recover.d.ts +12 -0
  14. package/dist/src/cli/commands/capture-recover.d.ts.map +1 -0
  15. package/dist/src/cli/commands/capture-recover.js +120 -0
  16. package/dist/src/cli/commands/capture-recover.js.map +1 -0
  17. package/dist/src/cli/commands/capture.d.ts.map +1 -1
  18. package/dist/src/cli/commands/capture.js +10 -4
  19. package/dist/src/cli/commands/capture.js.map +1 -1
  20. package/dist/src/cli/commands/feedback.d.ts.map +1 -1
  21. package/dist/src/cli/commands/feedback.js +6 -2
  22. package/dist/src/cli/commands/feedback.js.map +1 -1
  23. package/dist/src/cli/commands/hooks-install.d.ts +19 -0
  24. package/dist/src/cli/commands/hooks-install.d.ts.map +1 -0
  25. package/dist/src/cli/commands/hooks-install.js +103 -0
  26. package/dist/src/cli/commands/hooks-install.js.map +1 -0
  27. package/dist/src/cli/commands/mcp-install.js +5 -2
  28. package/dist/src/cli/commands/mcp-install.js.map +1 -1
  29. package/dist/src/cli/commands/onboard.d.ts +24 -0
  30. package/dist/src/cli/commands/onboard.d.ts.map +1 -1
  31. package/dist/src/cli/commands/onboard.js +200 -21
  32. package/dist/src/cli/commands/onboard.js.map +1 -1
  33. package/dist/src/cli/commands/rebuild.d.ts.map +1 -1
  34. package/dist/src/cli/commands/rebuild.js +6 -3
  35. package/dist/src/cli/commands/rebuild.js.map +1 -1
  36. package/dist/src/cli/commands/review.d.ts.map +1 -1
  37. package/dist/src/cli/commands/review.js +22 -7
  38. package/dist/src/cli/commands/review.js.map +1 -1
  39. package/dist/src/cli/commands/status.d.ts.map +1 -1
  40. package/dist/src/cli/commands/status.js +48 -2
  41. package/dist/src/cli/commands/status.js.map +1 -1
  42. package/dist/src/cli/commands/token-issue.d.ts.map +1 -1
  43. package/dist/src/cli/commands/token-issue.js +9 -1
  44. package/dist/src/cli/commands/token-issue.js.map +1 -1
  45. package/dist/src/cli/commands/triage.d.ts.map +1 -1
  46. package/dist/src/cli/commands/triage.js +7 -5
  47. package/dist/src/cli/commands/triage.js.map +1 -1
  48. package/dist/src/cli/commands/update.d.ts +26 -0
  49. package/dist/src/cli/commands/update.d.ts.map +1 -0
  50. package/dist/src/cli/commands/update.js +130 -0
  51. package/dist/src/cli/commands/update.js.map +1 -0
  52. package/dist/src/cli/default-config-path.d.ts +15 -0
  53. package/dist/src/cli/default-config-path.d.ts.map +1 -0
  54. package/dist/src/cli/default-config-path.js +27 -0
  55. package/dist/src/cli/default-config-path.js.map +1 -0
  56. package/dist/src/cli/hooks-writers/claude-code-policy-script.d.ts +25 -0
  57. package/dist/src/cli/hooks-writers/claude-code-policy-script.d.ts.map +1 -0
  58. package/dist/src/cli/hooks-writers/claude-code-policy-script.js +85 -0
  59. package/dist/src/cli/hooks-writers/claude-code-policy-script.js.map +1 -0
  60. package/dist/src/cli/hooks-writers/claude-code.d.ts +12 -0
  61. package/dist/src/cli/hooks-writers/claude-code.d.ts.map +1 -0
  62. package/dist/src/cli/hooks-writers/claude-code.js +228 -0
  63. package/dist/src/cli/hooks-writers/claude-code.js.map +1 -0
  64. package/dist/src/cli/hooks-writers/errors.d.ts +16 -0
  65. package/dist/src/cli/hooks-writers/errors.d.ts.map +1 -0
  66. package/dist/src/cli/hooks-writers/errors.js +24 -0
  67. package/dist/src/cli/hooks-writers/errors.js.map +1 -0
  68. package/dist/src/cli/hooks-writers/index.d.ts +13 -0
  69. package/dist/src/cli/hooks-writers/index.d.ts.map +1 -0
  70. package/dist/src/cli/hooks-writers/index.js +26 -0
  71. package/dist/src/cli/hooks-writers/index.js.map +1 -0
  72. package/dist/src/cli/hooks-writers/types.d.ts +27 -0
  73. package/dist/src/cli/hooks-writers/types.d.ts.map +1 -0
  74. package/dist/src/cli/hooks-writers/types.js +9 -0
  75. package/dist/src/cli/hooks-writers/types.js.map +1 -0
  76. package/dist/src/cli/http-client.d.ts +56 -1
  77. package/dist/src/cli/http-client.d.ts.map +1 -1
  78. package/dist/src/cli/http-client.js +140 -4
  79. package/dist/src/cli/http-client.js.map +1 -1
  80. package/dist/src/cli/index.d.ts.map +1 -1
  81. package/dist/src/cli/index.js +27 -6
  82. package/dist/src/cli/index.js.map +1 -1
  83. package/dist/src/cli/status/friend-header.d.ts.map +1 -1
  84. package/dist/src/cli/status/friend-header.js +117 -7
  85. package/dist/src/cli/status/friend-header.js.map +1 -1
  86. package/dist/src/ingestion/inbox-core/conversation-key.d.ts +2 -0
  87. package/dist/src/ingestion/inbox-core/conversation-key.d.ts.map +1 -0
  88. package/dist/src/ingestion/inbox-core/conversation-key.js +31 -0
  89. package/dist/src/ingestion/inbox-core/conversation-key.js.map +1 -0
  90. package/dist/src/ingestion/inbox-core/extensions.d.ts +3 -0
  91. package/dist/src/ingestion/inbox-core/extensions.d.ts.map +1 -0
  92. package/dist/src/ingestion/inbox-core/extensions.js +16 -0
  93. package/dist/src/ingestion/inbox-core/extensions.js.map +1 -0
  94. package/dist/src/ingestion/inbox-core/idempotency.d.ts +2 -0
  95. package/dist/src/ingestion/inbox-core/idempotency.d.ts.map +1 -0
  96. package/dist/src/ingestion/inbox-core/idempotency.js +22 -0
  97. package/dist/src/ingestion/inbox-core/idempotency.js.map +1 -0
  98. package/dist/src/ingestion/inbox-core/index.d.ts +19 -0
  99. package/dist/src/ingestion/inbox-core/index.d.ts.map +1 -0
  100. package/dist/src/ingestion/inbox-core/index.js +19 -0
  101. package/dist/src/ingestion/inbox-core/index.js.map +1 -0
  102. package/dist/src/ingestion/inbox-core/source-detection.d.ts +2 -0
  103. package/dist/src/ingestion/inbox-core/source-detection.d.ts.map +1 -0
  104. package/dist/src/ingestion/inbox-core/source-detection.js +23 -0
  105. package/dist/src/ingestion/inbox-core/source-detection.js.map +1 -0
  106. package/dist/src/ingestion/inbox-core/source-sniffer.d.ts +11 -0
  107. package/dist/src/ingestion/inbox-core/source-sniffer.d.ts.map +1 -0
  108. package/dist/src/ingestion/inbox-core/source-sniffer.js +69 -0
  109. package/dist/src/ingestion/inbox-core/source-sniffer.js.map +1 -0
  110. package/dist/src/ingestion/inbox-core/zip-sniffer.d.ts +70 -0
  111. package/dist/src/ingestion/inbox-core/zip-sniffer.d.ts.map +1 -0
  112. package/dist/src/ingestion/inbox-core/zip-sniffer.js +161 -0
  113. package/dist/src/ingestion/inbox-core/zip-sniffer.js.map +1 -0
  114. package/dist/src/ingestion/inbox-watcher.d.ts.map +1 -1
  115. package/dist/src/ingestion/inbox-watcher.js +34 -50
  116. package/dist/src/ingestion/inbox-watcher.js.map +1 -1
  117. package/dist/src/ingestion/indexer.d.ts +7 -0
  118. package/dist/src/ingestion/indexer.d.ts.map +1 -1
  119. package/dist/src/ingestion/indexer.js +36 -2
  120. package/dist/src/ingestion/indexer.js.map +1 -1
  121. package/dist/src/ingestion/metadata-extraction.d.ts +8 -5
  122. package/dist/src/ingestion/metadata-extraction.d.ts.map +1 -1
  123. package/dist/src/ingestion/metadata-extraction.js +24 -5
  124. package/dist/src/ingestion/metadata-extraction.js.map +1 -1
  125. package/dist/src/ingestion/skip-quarantine.d.ts +10 -0
  126. package/dist/src/ingestion/skip-quarantine.d.ts.map +1 -0
  127. package/dist/src/ingestion/skip-quarantine.js +35 -0
  128. package/dist/src/ingestion/skip-quarantine.js.map +1 -0
  129. package/dist/src/jobs/handlers/compact.d.ts.map +1 -1
  130. package/dist/src/jobs/handlers/compact.js +25 -4
  131. package/dist/src/jobs/handlers/compact.js.map +1 -1
  132. package/dist/src/jobs/handlers/ingest.d.ts.map +1 -1
  133. package/dist/src/jobs/handlers/ingest.js +49 -24
  134. package/dist/src/jobs/handlers/ingest.js.map +1 -1
  135. package/dist/src/jobs/handlers/reconcile.d.ts.map +1 -1
  136. package/dist/src/jobs/handlers/reconcile.js +30 -8
  137. package/dist/src/jobs/handlers/reconcile.js.map +1 -1
  138. package/dist/src/jobs/handlers/reindex.d.ts.map +1 -1
  139. package/dist/src/jobs/handlers/reindex.js +12 -2
  140. package/dist/src/jobs/handlers/reindex.js.map +1 -1
  141. package/dist/src/jobs/handlers/save.d.ts.map +1 -1
  142. package/dist/src/jobs/handlers/save.js +9 -2
  143. package/dist/src/jobs/handlers/save.js.map +1 -1
  144. package/dist/src/jobs/queue.d.ts +11 -0
  145. package/dist/src/jobs/queue.d.ts.map +1 -1
  146. package/dist/src/jobs/queue.js +18 -0
  147. package/dist/src/jobs/queue.js.map +1 -1
  148. package/dist/src/jobs/worker-entry.d.ts.map +1 -1
  149. package/dist/src/jobs/worker-entry.js +2 -0
  150. package/dist/src/jobs/worker-entry.js.map +1 -1
  151. package/dist/src/main.js +36 -4
  152. package/dist/src/main.js.map +1 -1
  153. package/dist/src/observability/embedding-events.d.ts +52 -0
  154. package/dist/src/observability/embedding-events.d.ts.map +1 -0
  155. package/dist/src/observability/embedding-events.js +149 -0
  156. package/dist/src/observability/embedding-events.js.map +1 -0
  157. package/dist/src/observability/index-events.d.ts +70 -0
  158. package/dist/src/observability/index-events.d.ts.map +1 -0
  159. package/dist/src/observability/index-events.js +148 -0
  160. package/dist/src/observability/index-events.js.map +1 -0
  161. package/dist/src/observability/tool-usage-stats.d.ts +7 -0
  162. package/dist/src/observability/tool-usage-stats.d.ts.map +1 -1
  163. package/dist/src/observability/tool-usage-stats.js +41 -5
  164. package/dist/src/observability/tool-usage-stats.js.map +1 -1
  165. package/dist/src/observability/tool-usage.d.ts +7 -7
  166. package/dist/src/observability/tool-usage.d.ts.map +1 -1
  167. package/dist/src/observability/tool-usage.js +78 -39
  168. package/dist/src/observability/tool-usage.js.map +1 -1
  169. package/dist/src/observability/version-check.d.ts +70 -0
  170. package/dist/src/observability/version-check.d.ts.map +1 -0
  171. package/dist/src/observability/version-check.js +197 -0
  172. package/dist/src/observability/version-check.js.map +1 -0
  173. package/dist/src/providers/ollama-embed.d.ts +2 -1
  174. package/dist/src/providers/ollama-embed.d.ts.map +1 -1
  175. package/dist/src/providers/ollama-embed.js +1 -0
  176. package/dist/src/providers/ollama-embed.js.map +1 -1
  177. package/dist/src/providers/openai-metadata-extraction.d.ts +3 -3
  178. package/dist/src/providers/openai-metadata-extraction.d.ts.map +1 -1
  179. package/dist/src/providers/openai-metadata-extraction.js +18 -3
  180. package/dist/src/providers/openai-metadata-extraction.js.map +1 -1
  181. package/dist/src/providers/stub.d.ts +2 -0
  182. package/dist/src/providers/stub.d.ts.map +1 -1
  183. package/dist/src/providers/stub.js +2 -0
  184. package/dist/src/providers/stub.js.map +1 -1
  185. package/dist/src/providers/types.d.ts +11 -0
  186. package/dist/src/providers/types.d.ts.map +1 -1
  187. package/dist/src/providers/voyage.d.ts +2 -1
  188. package/dist/src/providers/voyage.d.ts.map +1 -1
  189. package/dist/src/providers/voyage.js +1 -0
  190. package/dist/src/providers/voyage.js.map +1 -1
  191. package/dist/src/server/app.d.ts.map +1 -1
  192. package/dist/src/server/app.js +67 -1
  193. package/dist/src/server/app.js.map +1 -1
  194. package/dist/src/server/routes/friend-status.d.ts +202 -3
  195. package/dist/src/server/routes/friend-status.d.ts.map +1 -1
  196. package/dist/src/server/routes/friend-status.js +290 -7
  197. package/dist/src/server/routes/friend-status.js.map +1 -1
  198. package/dist/src/storage/rebuild.d.ts +14 -1
  199. package/dist/src/storage/rebuild.d.ts.map +1 -1
  200. package/dist/src/storage/rebuild.js +160 -34
  201. package/dist/src/storage/rebuild.js.map +1 -1
  202. package/package.json +1 -1
@@ -0,0 +1,149 @@
1
+ /**
2
+ * Embedding-events lane — append-only JSONL.
3
+ *
4
+ * One row per call to an embedding provider on an *ingest* code path
5
+ * (watcher / scheduled-scan / reconcile / ingest-job / compact / backfill).
6
+ * Search-time embedding calls (search routes, hybrid retrieval) are
7
+ * deliberately NOT logged here — otherwise a user search would refresh
8
+ * `voyage.last_embed_at` and mask an ingestion outage.
9
+ *
10
+ * Provider-agnostic on purpose: `provider` and `model` are payload
11
+ * fields, not the file name, so a future Ollama/local-embedding swap
12
+ * shares the same lane and the same `/status/friend` consumer.
13
+ *
14
+ * Failure mode: writes are best-effort and never throw — embedding must
15
+ * not be observably blocked by telemetry. Reads are tolerant of bad
16
+ * lines so one corrupt row doesn't blank the status dashboard.
17
+ */
18
+ import fs from "node:fs";
19
+ import path from "node:path";
20
+ export const EMBEDDING_PIPELINES = [
21
+ "watcher",
22
+ "scheduled_scan",
23
+ "reconcile",
24
+ "ingest_job",
25
+ "compact",
26
+ "backfill",
27
+ "capture",
28
+ "reindex",
29
+ ];
30
+ const MAX_ERROR_MESSAGE_LEN = 512;
31
+ export function eventsFilePath(dataDir) {
32
+ return path.join(dataDir, "observability", "embedding-events.jsonl");
33
+ }
34
+ /**
35
+ * Append a single event to the lane. Never throws — telemetry must not
36
+ * break embedding. On filesystem error, writes a single stderr line so
37
+ * the failure is at least visible to operators tailing logs.
38
+ */
39
+ export function appendEmbeddingEvent(dataDir, event) {
40
+ const filePath = eventsFilePath(dataDir);
41
+ try {
42
+ fs.mkdirSync(path.dirname(filePath), { recursive: true });
43
+ fs.appendFileSync(filePath, JSON.stringify(event) + "\n");
44
+ }
45
+ catch (err) {
46
+ process.stderr.write(`[embedding-events] write failed: ${err instanceof Error ? err.message : String(err)}\n`);
47
+ }
48
+ }
49
+ /**
50
+ * Run an embedding call and record one event. Re-throws errors so the
51
+ * caller's existing failure-handling path is unchanged; logging is a
52
+ * pure side effect.
53
+ *
54
+ * Use this at every ingest call site. Do NOT use it for search-time
55
+ * embedding — keeping search out of the lane is what makes
56
+ * `last_embed_at` meaningful.
57
+ */
58
+ export async function recordEmbed(dataDir, provider, ctx, fn) {
59
+ const start = Date.now();
60
+ try {
61
+ const result = await fn();
62
+ appendEmbeddingEvent(dataDir, {
63
+ ts: new Date().toISOString(),
64
+ provider: provider.name,
65
+ model: provider.model,
66
+ pipeline: ctx.pipeline,
67
+ operation: ctx.operation,
68
+ outcome: "success",
69
+ input_count: ctx.input_count,
70
+ ms: Date.now() - start,
71
+ });
72
+ return result;
73
+ }
74
+ catch (err) {
75
+ const message = err instanceof Error ? err.message : String(err);
76
+ appendEmbeddingEvent(dataDir, {
77
+ ts: new Date().toISOString(),
78
+ provider: provider.name,
79
+ model: provider.model,
80
+ pipeline: ctx.pipeline,
81
+ operation: ctx.operation,
82
+ outcome: "error",
83
+ input_count: ctx.input_count,
84
+ ms: Date.now() - start,
85
+ error_class: classifyError(err),
86
+ error_message: message.slice(0, MAX_ERROR_MESSAGE_LEN),
87
+ });
88
+ throw err;
89
+ }
90
+ }
91
+ /**
92
+ * Best-effort classification for the `error_class` field.
93
+ * Voyage / Ollama errors carry `Voyage API <code>: ...` /
94
+ * `Ollama embed API <code>: ...` shapes — extract the status code so
95
+ * status views can group by class without parsing free-text.
96
+ */
97
+ function classifyError(err) {
98
+ const msg = err instanceof Error ? err.message : String(err);
99
+ const httpMatch = msg.match(/\b(\d{3})\b/);
100
+ if (httpMatch && msg.toLowerCase().includes("api")) {
101
+ return `provider_${httpMatch[1]}`;
102
+ }
103
+ if (err instanceof TypeError)
104
+ return "network";
105
+ return "unknown";
106
+ }
107
+ /**
108
+ * Tolerant reader. One bad JSON line is skipped; the rest are returned.
109
+ * Returns [] if the file is missing.
110
+ */
111
+ export function readEmbeddingEvents(dataDir) {
112
+ let raw;
113
+ try {
114
+ raw = fs.readFileSync(eventsFilePath(dataDir), "utf-8");
115
+ }
116
+ catch {
117
+ return [];
118
+ }
119
+ const out = [];
120
+ for (const line of raw.split("\n")) {
121
+ if (!line)
122
+ continue;
123
+ let parsed;
124
+ try {
125
+ parsed = JSON.parse(line);
126
+ }
127
+ catch {
128
+ continue;
129
+ }
130
+ if (!isEmbeddingEvent(parsed))
131
+ continue;
132
+ out.push(parsed);
133
+ }
134
+ return out;
135
+ }
136
+ function isEmbeddingEvent(value) {
137
+ if (value === null || typeof value !== "object")
138
+ return false;
139
+ const v = value;
140
+ return (typeof v["ts"] === "string" &&
141
+ typeof v["provider"] === "string" &&
142
+ typeof v["model"] === "string" &&
143
+ typeof v["pipeline"] === "string" &&
144
+ typeof v["operation"] === "string" &&
145
+ (v["outcome"] === "success" || v["outcome"] === "error") &&
146
+ typeof v["input_count"] === "number" &&
147
+ typeof v["ms"] === "number");
148
+ }
149
+ //# sourceMappingURL=embedding-events.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"embedding-events.js","sourceRoot":"","sources":["../../../src/observability/embedding-events.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,70 @@
1
+ import type { EmbeddingPipeline } from "./embedding-events.js";
2
+ export type IndexOutcome = "success" | "error";
3
+ export interface IndexEvent {
4
+ ts: string;
5
+ /**
6
+ * Target LanceDB table. Free-form string (not `TableName`) so shadow
7
+ * writes can record their target without coupling to the live table
8
+ * name set.
9
+ */
10
+ table: string;
11
+ pipeline: EmbeddingPipeline;
12
+ /**
13
+ * Free-form caller label (e.g. "structured_doc_upsert",
14
+ * "conversation_upsert", "digest_upsert"). Helps debug "which write
15
+ * path"; does not gate any status logic today.
16
+ */
17
+ operation: string;
18
+ outcome: IndexOutcome;
19
+ /** Number of rows in this `table.add(...)` call (or rollback batch). */
20
+ row_count: number;
21
+ ms: number;
22
+ /**
23
+ * Lifecycle phase.
24
+ * - "live" (default when omitted) — the row is now searchable.
25
+ * Direct writes are always "live"; shadow rebuilds emit a single
26
+ * "live" event per table after `commitAllSwaps` succeeds.
27
+ * - "shadow" — the row was written to a pre-commit shadow table. If
28
+ * the subsequent swap fails the row is NOT searchable, so
29
+ * `computeIndexHealth` does NOT credit `last_update_at` from
30
+ * shadow successes. Shadow errors still surface as `last_error_at`
31
+ * because they represent real LanceDB write failures regardless of
32
+ * the eventual swap outcome.
33
+ */
34
+ phase?: "live" | "shadow";
35
+ /** Compact error class. Present when outcome === "error". */
36
+ error_class?: string;
37
+ /** Truncated error message (≤ 512 chars). Present when outcome === "error". */
38
+ error_message?: string;
39
+ }
40
+ export interface IndexWriteContext {
41
+ table: string;
42
+ pipeline: EmbeddingPipeline;
43
+ operation: string;
44
+ row_count: number;
45
+ /** Defaults to "live". Set "shadow" for pre-commit shadow-table writes. */
46
+ phase?: "live" | "shadow";
47
+ }
48
+ export declare function indexEventsFilePath(dataDir: string): string;
49
+ /**
50
+ * Append a single event to the lane. Never throws — telemetry must not
51
+ * break indexing. On filesystem error, writes a single stderr line so
52
+ * the failure is at least visible to operators tailing logs.
53
+ */
54
+ export declare function appendIndexEvent(dataDir: string, event: IndexEvent): void;
55
+ /**
56
+ * Run a LanceDB write and record one event. Re-throws errors so the
57
+ * caller's existing failure-handling path is unchanged; logging is a
58
+ * pure side effect.
59
+ *
60
+ * Use this only at write boundaries (`table.add(...)`). Do NOT use it
61
+ * for reads, queries, or deletes — keeping the lane write-only is what
62
+ * makes `last_update_at` meaningful.
63
+ */
64
+ export declare function recordIndexWrite<T>(dataDir: string, ctx: IndexWriteContext, fn: () => Promise<T>): Promise<T>;
65
+ /**
66
+ * Tolerant reader. One bad JSON line is skipped; the rest are returned.
67
+ * Returns [] if the file is missing.
68
+ */
69
+ export declare function readIndexEvents(dataDir: string): IndexEvent[];
70
+ //# sourceMappingURL=index-events.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-events.d.ts","sourceRoot":"","sources":["../../../src/observability/index-events.ts"],"names":[],"mappings":"AAmBA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,OAAO,CAAC;AAE/C,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX;;;;OAIG;IACH,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,iBAAiB,CAAC;IAC5B;;;;OAIG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,YAAY,CAAC;IACtB,wEAAwE;IACxE,SAAS,EAAE,MAAM,CAAC;IAClB,EAAE,EAAE,MAAM,CAAC;IACX;;;;;;;;;;;OAWG;IACH,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;IAC1B,6DAA6D;IAC7D,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,+EAA+E;IAC/E,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAID,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,iBAAiB,CAAC;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,2EAA2E;IAC3E,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;CAC3B;AAED,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAE3D;AAED;;;;GAIG;AACH,wBAAgB,gBAAgB,CAC9B,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,UAAU,GAChB,IAAI,CAUN;AAED;;;;;;;;GAQG;AACH,wBAAsB,gBAAgB,CAAC,CAAC,EACtC,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,iBAAiB,EACtB,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACnB,OAAO,CAAC,CAAC,CAAC,CAgCZ;AAmBD;;;GAGG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU,EAAE,CAoB7D"}
@@ -0,0 +1,148 @@
1
+ /**
2
+ * Index-events lane — append-only JSONL.
3
+ *
4
+ * One row per write boundary against LanceDB (`table.add(...)`). This
5
+ * complements `embedding-events.jsonl`: the embedding lane proves the
6
+ * vector was produced, this lane proves the row was actually persisted
7
+ * to LanceDB and is searchable. Without it, `/status/friend` cannot
8
+ * distinguish "embedded but not indexed yet" from "fully searchable".
9
+ *
10
+ * Provider-agnostic and table-agnostic: `table` and `pipeline` are
11
+ * payload fields. Reads / search queries are deliberately NOT wrapped —
12
+ * they're not write events and would muddy `index.last_update_at`.
13
+ *
14
+ * Failure mode: writes are best-effort and never throw — observability
15
+ * must not break indexing. The reader is tolerant of bad lines so one
16
+ * corrupt row doesn't blank the status dashboard.
17
+ */
18
+ import fs from "node:fs";
19
+ import path from "node:path";
20
+ const MAX_ERROR_MESSAGE_LEN = 512;
21
+ export function indexEventsFilePath(dataDir) {
22
+ return path.join(dataDir, "observability", "index-events.jsonl");
23
+ }
24
+ /**
25
+ * Append a single event to the lane. Never throws — telemetry must not
26
+ * break indexing. On filesystem error, writes a single stderr line so
27
+ * the failure is at least visible to operators tailing logs.
28
+ */
29
+ export function appendIndexEvent(dataDir, event) {
30
+ const filePath = indexEventsFilePath(dataDir);
31
+ try {
32
+ fs.mkdirSync(path.dirname(filePath), { recursive: true });
33
+ fs.appendFileSync(filePath, JSON.stringify(event) + "\n");
34
+ }
35
+ catch (err) {
36
+ process.stderr.write(`[index-events] write failed: ${err instanceof Error ? err.message : String(err)}\n`);
37
+ }
38
+ }
39
+ /**
40
+ * Run a LanceDB write and record one event. Re-throws errors so the
41
+ * caller's existing failure-handling path is unchanged; logging is a
42
+ * pure side effect.
43
+ *
44
+ * Use this only at write boundaries (`table.add(...)`). Do NOT use it
45
+ * for reads, queries, or deletes — keeping the lane write-only is what
46
+ * makes `last_update_at` meaningful.
47
+ */
48
+ export async function recordIndexWrite(dataDir, ctx, fn) {
49
+ const start = Date.now();
50
+ const phase = ctx.phase ?? "live";
51
+ try {
52
+ const result = await fn();
53
+ appendIndexEvent(dataDir, {
54
+ ts: new Date().toISOString(),
55
+ table: ctx.table,
56
+ pipeline: ctx.pipeline,
57
+ operation: ctx.operation,
58
+ outcome: "success",
59
+ row_count: ctx.row_count,
60
+ ms: Date.now() - start,
61
+ phase,
62
+ });
63
+ return result;
64
+ }
65
+ catch (err) {
66
+ const message = err instanceof Error ? err.message : String(err);
67
+ appendIndexEvent(dataDir, {
68
+ ts: new Date().toISOString(),
69
+ table: ctx.table,
70
+ pipeline: ctx.pipeline,
71
+ operation: ctx.operation,
72
+ outcome: "error",
73
+ row_count: ctx.row_count,
74
+ ms: Date.now() - start,
75
+ phase,
76
+ error_class: classifyError(err),
77
+ error_message: message.slice(0, MAX_ERROR_MESSAGE_LEN),
78
+ });
79
+ throw err;
80
+ }
81
+ }
82
+ /**
83
+ * Best-effort classification for the `error_class` field. LanceDB
84
+ * surfaces schema mismatches, IO errors, and lock contention with
85
+ * different shapes — pick a coarse class so dashboards can group.
86
+ */
87
+ function classifyError(err) {
88
+ const msg = err instanceof Error ? err.message : String(err);
89
+ const lower = msg.toLowerCase();
90
+ if (lower.includes("schema"))
91
+ return "schema_mismatch";
92
+ if (lower.includes("lock") || lower.includes("conflict"))
93
+ return "lock_conflict";
94
+ if (lower.includes("enoent") || lower.includes("eacces") || lower.includes("eio")) {
95
+ return "io";
96
+ }
97
+ if (err instanceof TypeError)
98
+ return "type";
99
+ return "unknown";
100
+ }
101
+ /**
102
+ * Tolerant reader. One bad JSON line is skipped; the rest are returned.
103
+ * Returns [] if the file is missing.
104
+ */
105
+ export function readIndexEvents(dataDir) {
106
+ let raw;
107
+ try {
108
+ raw = fs.readFileSync(indexEventsFilePath(dataDir), "utf-8");
109
+ }
110
+ catch {
111
+ return [];
112
+ }
113
+ const out = [];
114
+ for (const line of raw.split("\n")) {
115
+ if (!line)
116
+ continue;
117
+ let parsed;
118
+ try {
119
+ parsed = JSON.parse(line);
120
+ }
121
+ catch {
122
+ continue;
123
+ }
124
+ if (!isIndexEvent(parsed))
125
+ continue;
126
+ out.push(parsed);
127
+ }
128
+ return out;
129
+ }
130
+ function isIndexEvent(value) {
131
+ if (value === null || typeof value !== "object")
132
+ return false;
133
+ const v = value;
134
+ if (!(typeof v["ts"] === "string" &&
135
+ typeof v["table"] === "string" &&
136
+ typeof v["pipeline"] === "string" &&
137
+ typeof v["operation"] === "string" &&
138
+ (v["outcome"] === "success" || v["outcome"] === "error") &&
139
+ typeof v["row_count"] === "number" &&
140
+ typeof v["ms"] === "number")) {
141
+ return false;
142
+ }
143
+ const phase = v["phase"];
144
+ if (phase !== undefined && phase !== "live" && phase !== "shadow")
145
+ return false;
146
+ return true;
147
+ }
148
+ //# sourceMappingURL=index-events.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-events.js","sourceRoot":"","sources":["../../../src/observability/index-events.ts"],"names":[],"mappings":"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"}
@@ -10,6 +10,13 @@
10
10
  import type { ToolUsageEntry } from "./tool-usage.js";
11
11
  export interface UsageWindow {
12
12
  calls: number;
13
+ /**
14
+ * Successful retrieval calls that returned at least one item and were not
15
+ * marked `degraded`. Captures rift_search, rift_conversations_search, and
16
+ * rift_context_pack — the tools whose job is to surface relevant context.
17
+ * Non-retrieval calls (rift_save, rift_status) are excluded.
18
+ */
19
+ context_hits: number;
13
20
  tokens_saved: number;
14
21
  }
15
22
  export interface UsageSummary {
@@ -1 +1 @@
1
- {"version":3,"file":"tool-usage-stats.d.ts","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAyCtD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,CAAC;CACtB;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;CACjC;AAkBD,wBAAgB,cAAc,CAC5B,OAAO,EAAE,cAAc,EAAE,EACzB,GAAG,GAAE,IAAiB,GACrB,YAAY,CA4Cd"}
1
+ {"version":3,"file":"tool-usage-stats.d.ts","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAyCtD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd;;;;;OAKG;IACH,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;CACtB;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;CACjC;AA0DD,wBAAgB,cAAc,CAC5B,OAAO,EAAE,cAAc,EAAE,EACzB,GAAG,GAAE,IAAiB,GACrB,YAAY,CAgDd"}
@@ -33,16 +33,48 @@ function canonicalToolName(tool) {
33
33
  }
34
34
  const DAY_MS = 24 * 60 * 60 * 1000;
35
35
  function emptyWindow() {
36
- return { calls: 0, tokens_saved: 0 };
36
+ return { calls: 0, context_hits: 0, tokens_saved: 0 };
37
37
  }
38
38
  function tokensSavedFor(tool) {
39
39
  return TOKENS_SAVED_PER_TOOL[tool] ?? DEFAULT_TOKENS_SAVED;
40
40
  }
41
- function startOfUtcDay(date) {
42
- return Date.UTC(date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate());
41
+ /**
42
+ * Local-time start-of-day. The menu-bar "today" counter is a glanceable
43
+ * Mac-local metric, so the boundary follows the machine's wall clock — not
44
+ * UTC, which would reset mid-evening in Asia/early-morning in Europe.
45
+ */
46
+ function startOfLocalDay(date) {
47
+ return new Date(date.getFullYear(), date.getMonth(), date.getDate()).getTime();
48
+ }
49
+ /**
50
+ * Local-time start of the following day. Built via the local-time Date
51
+ * constructor (not `startOfLocalDay + DAY_MS`) so DST-fallback days, which
52
+ * have 25 hours, still capture their final hour as "today".
53
+ */
54
+ function startOfNextLocalDay(date) {
55
+ return new Date(date.getFullYear(), date.getMonth(), date.getDate() + 1).getTime();
56
+ }
57
+ /**
58
+ * Tools whose `result_count` counts toward `context_hits`. Belt-and-suspenders
59
+ * with the logger's own whitelist in [extractRetrievalSignal] — if a future
60
+ * code path ever writes `result_count` for a non-retrieval tool, this gate
61
+ * still keeps it out of the metric.
62
+ */
63
+ const RETRIEVAL_TOOLS_FOR_HITS = new Set([
64
+ "rift_search",
65
+ "rift_conversations_search",
66
+ "rift_context_pack",
67
+ ]);
68
+ function isContextHit(tool, entry) {
69
+ return (RETRIEVAL_TOOLS_FOR_HITS.has(tool) &&
70
+ entry.success === true &&
71
+ entry.degraded !== true &&
72
+ typeof entry.result_count === "number" &&
73
+ entry.result_count > 0);
43
74
  }
44
75
  export function aggregateUsage(entries, now = new Date()) {
45
- const todayStartMs = startOfUtcDay(now);
76
+ const todayStartMs = startOfLocalDay(now);
77
+ const todayEndMs = startOfNextLocalDay(now);
46
78
  const nowMs = now.getTime();
47
79
  const weekStartMs = nowMs - 7 * DAY_MS;
48
80
  const monthStartMs = nowMs - 30 * DAY_MS;
@@ -53,29 +85,33 @@ export function aggregateUsage(entries, now = new Date()) {
53
85
  all_time: emptyWindow(),
54
86
  by_tool: {},
55
87
  };
56
- const todayEndMs = todayStartMs + DAY_MS;
57
88
  for (const entry of entries) {
58
89
  const ts = Date.parse(entry.timestamp);
59
90
  if (Number.isNaN(ts))
60
91
  continue;
61
92
  const tool = canonicalToolName(entry.tool);
62
93
  const tokens = entry.success ? tokensSavedFor(tool) : 0;
94
+ const hit = isContextHit(tool, entry) ? 1 : 0;
63
95
  summary.all_time.calls += 1;
64
96
  summary.all_time.tokens_saved += tokens;
97
+ summary.all_time.context_hits += hit;
65
98
  summary.by_tool[tool] = (summary.by_tool[tool] ?? 0) + 1;
66
99
  if (ts > nowMs)
67
100
  continue;
68
101
  if (ts >= monthStartMs) {
69
102
  summary.month.calls += 1;
70
103
  summary.month.tokens_saved += tokens;
104
+ summary.month.context_hits += hit;
71
105
  }
72
106
  if (ts >= weekStartMs) {
73
107
  summary.week.calls += 1;
74
108
  summary.week.tokens_saved += tokens;
109
+ summary.week.context_hits += hit;
75
110
  }
76
111
  if (ts >= todayStartMs && ts < todayEndMs) {
77
112
  summary.today.calls += 1;
78
113
  summary.today.tokens_saved += tokens;
114
+ summary.today.context_hits += hit;
79
115
  }
80
116
  }
81
117
  return summary;
@@ -1 +1 @@
1
- {"version":3,"file":"tool-usage-stats.js","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"AAWA;;;;;;;;GAQG;AACH,MAAM,qBAAqB,GAA2B;IACpD,iBAAiB,EAAE,MAAM;IACzB,yBAAyB,EAAE,KAAK;IAChC,WAAW,EAAE,KAAK;IAClB,SAAS,EAAE,KAAK;IAChB,WAAW,EAAE,KAAK;CACnB,CAAC;AAEF,MAAM,oBAAoB,GAAG,KAAK,CAAC;AAEnC;;;;;GAKG;AACH,MAAM,mBAAmB,GAA2B;IAClD,SAAS,EAAE,WAAW;IACtB,WAAW,EAAE,aAAa;IAC1B,yBAAyB,EAAE,2BAA2B;IACtD,iBAAiB,EAAE,mBAAmB;IACtC,WAAW,EAAE,aAAa;CAC3B,CAAC;AAEF,SAAS,iBAAiB,CAAC,IAAY;IACrC,OAAO,mBAAmB,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC;AAC3C,CAAC;AAED,MAAM,MAAM,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;AAenC,SAAS,WAAW;IAClB,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC;AACvC,CAAC;AAED,SAAS,cAAc,CAAC,IAAY;IAClC,OAAO,qBAAqB,CAAC,IAAI,CAAC,IAAI,oBAAoB,CAAC;AAC7D,CAAC;AAED,SAAS,aAAa,CAAC,IAAU;IAC/B,OAAO,IAAI,CAAC,GAAG,CACb,IAAI,CAAC,cAAc,EAAE,EACrB,IAAI,CAAC,WAAW,EAAE,EAClB,IAAI,CAAC,UAAU,EAAE,CAClB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,OAAyB,EACzB,MAAY,IAAI,IAAI,EAAE;IAEtB,MAAM,YAAY,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IACxC,MAAM,KAAK,GAAG,GAAG,CAAC,OAAO,EAAE,CAAC;IAC5B,MAAM,WAAW,GAAG,KAAK,GAAG,CAAC,GAAG,MAAM,CAAC;IACvC,MAAM,YAAY,GAAG,KAAK,GAAG,EAAE,GAAG,MAAM,CAAC;IAEzC,MAAM,OAAO,GAAiB;QAC5B,KAAK,EAAE,WAAW,EAAE;QACpB,IAAI,EAAE,WAAW,EAAE;QACnB,KAAK,EAAE,WAAW,EAAE;QACpB,QAAQ,EAAE,WAAW,EAAE;QACvB,OAAO,EAAE,EAAE;KACZ,CAAC;IAEF,MAAM,UAAU,GAAG,YAAY,GAAG,MAAM,CAAC;IAEzC,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QACvC,IAAI,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;YAAE,SAAS;QAE/B,MAAM,IAAI,GAAG,iBAAiB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC3C,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAExD,OAAO,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC;QAC5B,OAAO,CAAC,QAAQ,CAAC,YAAY,IAAI,MAAM,CAAC;QACxC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAEzD,IAAI,EAAE,GAAG,KAAK;YAAE,SAAS;QAEzB,IAAI,EAAE,IAAI,YAAY,EAAE,CAAC;YACvB,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,CAAC;YACzB,OAAO,CAAC,KAAK,CAAC,YAAY,IAAI,MAAM,CAAC;QACvC,CAAC;QACD,IAAI,EAAE,IAAI,WAAW,EAAE,CAAC;YACtB,OAAO,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC;YACxB,OAAO,CAAC,IAAI,CAAC,YAAY,IAAI,MAAM,CAAC;QACtC,CAAC;QACD,IAAI,EAAE,IAAI,YAAY,IAAI,EAAE,GAAG,UAAU,EAAE,CAAC;YAC1C,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,CAAC;YACzB,OAAO,CAAC,KAAK,CAAC,YAAY,IAAI,MAAM,CAAC;QACvC,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
1
+ {"version":3,"file":"tool-usage-stats.js","sourceRoot":"","sources":["../../../src/observability/tool-usage-stats.ts"],"names":[],"mappings":"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"}
@@ -11,12 +11,10 @@ export interface ToolUsageEntry {
11
11
  }
12
12
  export declare function sanitizeArgs(raw: Record<string, unknown>): Record<string, unknown>;
13
13
  /**
14
- * Try to extract result_count from search-tool responses.
15
- *
16
- * Slice 1: search tools now emit markdown on the text channel and put the
17
- * compact DTO in `structuredContent`. We read from structuredContent first
18
- * and fall back to JSON-parsing the text channel for backwards compatibility
19
- * with tools that still return JSON there.
14
+ * Try to extract `result_count` from a retrieval-tool response. For search
15
+ * tools this is `results.length`; for `rift_context_pack` it is the sum of
16
+ * all four bucket sizes (decisions + constraints + examples + rules).
17
+ * Returns `undefined` for non-retrieval tools.
20
18
  */
21
19
  export declare function extractResultCount(tool: string, mcpResult: {
22
20
  content: Array<{
@@ -26,7 +24,9 @@ export declare function extractResultCount(tool: string, mcpResult: {
26
24
  structuredContent?: Record<string, unknown>;
27
25
  }): number | undefined;
28
26
  /**
29
- * Try to extract degraded flag from search-tool responses.
27
+ * Try to extract the `degraded` flag from a retrieval-tool response.
28
+ * Returns `undefined` for non-retrieval tools and for retrieval tools whose
29
+ * response did not carry the flag.
30
30
  */
31
31
  export declare function extractDegraded(tool: string, mcpResult: {
32
32
  content: Array<{
@@ -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;CAChB;AAID,wBAAgB,YAAY,CAC1B,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC3B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAkBzB;AAID;;;;;;;GAOG;AACH,wBAAgB,kBAAkB,CAChC,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE;IACT,OAAO,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC/C,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC7C,GACA,MAAM,GAAG,SAAS,CAapB;AAED;;GAEG;AACH,wBAAgB,eAAe,CAC7B,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE;IACT,OAAO,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC/C,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC7C,GACA,OAAO,GAAG,SAAS,CAarB;AAID,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;gBAErB,OAAO,EAAE,MAAM;IAK3B,2CAA2C;IAC3C,GAAG,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IAWhC;;;OAGG;IACH,IAAI,CACF,CAAC,SAAS;QACR,OAAO,EAAE,KAAK,CAAC;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KAC7C,EAED,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACxB,OAAO,CAAC,CAAC,CAAC;IAwCb,sCAAsC;IACtC,OAAO,IAAI,cAAc,EAAE;IAa3B,IAAI,QAAQ,IAAI,MAAM,CAErB;CACF;AAED;;;;;;;GAOG;AACH,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,MAAM,GACf,cAAc,EAAE,CA4BlB"}
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;CAChB;AAID,wBAAgB,YAAY,CAC1B,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC3B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAkBzB;AA8ED;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAChC,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE;IACT,OAAO,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC/C,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC7C,GACA,MAAM,GAAG,SAAS,CAEpB;AAED;;;;GAIG;AACH,wBAAgB,eAAe,CAC7B,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE;IACT,OAAO,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC/C,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC7C,GACA,OAAO,GAAG,SAAS,CAErB;AAID,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;gBAErB,OAAO,EAAE,MAAM;IAK3B,2CAA2C;IAC3C,GAAG,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IAWhC;;;OAGG;IACH,IAAI,CACF,CAAC,SAAS;QACR,OAAO,EAAE,KAAK,CAAC;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KAC7C,EAED,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACxB,OAAO,CAAC,CAAC,CAAC;IAwCb,sCAAsC;IACtC,OAAO,IAAI,cAAc,EAAE;IAa3B,IAAI,QAAQ,IAAI,MAAM,CAErB;CACF;AAED;;;;;;;GAOG;AACH,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,MAAM,GACf,cAAc,EAAE,CA4BlB"}