jfl 0.2.2 → 0.2.4

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 (153) hide show
  1. package/README.md +399 -423
  2. package/clawdbot-plugin/clawdbot.plugin.json +12 -1
  3. package/clawdbot-plugin/index.js +5 -5
  4. package/clawdbot-plugin/index.ts +5 -5
  5. package/dist/commands/context-hub.d.ts +4 -0
  6. package/dist/commands/context-hub.d.ts.map +1 -1
  7. package/dist/commands/context-hub.js +704 -83
  8. package/dist/commands/context-hub.js.map +1 -1
  9. package/dist/commands/digest.d.ts +6 -0
  10. package/dist/commands/digest.d.ts.map +1 -0
  11. package/dist/commands/digest.js +81 -0
  12. package/dist/commands/digest.js.map +1 -0
  13. package/dist/commands/flows.d.ts +7 -0
  14. package/dist/commands/flows.d.ts.map +1 -0
  15. package/dist/commands/flows.js +264 -0
  16. package/dist/commands/flows.js.map +1 -0
  17. package/dist/commands/hooks.d.ts +11 -0
  18. package/dist/commands/hooks.d.ts.map +1 -0
  19. package/dist/commands/hooks.js +303 -0
  20. package/dist/commands/hooks.js.map +1 -0
  21. package/dist/commands/improve.d.ts +11 -0
  22. package/dist/commands/improve.d.ts.map +1 -0
  23. package/dist/commands/improve.js +77 -0
  24. package/dist/commands/improve.js.map +1 -0
  25. package/dist/commands/init.d.ts.map +1 -1
  26. package/dist/commands/init.js +42 -11
  27. package/dist/commands/init.js.map +1 -1
  28. package/dist/commands/peter.d.ts +15 -0
  29. package/dist/commands/peter.d.ts.map +1 -0
  30. package/dist/commands/peter.js +198 -0
  31. package/dist/commands/peter.js.map +1 -0
  32. package/dist/commands/ralph.d.ts +3 -1
  33. package/dist/commands/ralph.d.ts.map +1 -1
  34. package/dist/commands/ralph.js +40 -5
  35. package/dist/commands/ralph.js.map +1 -1
  36. package/dist/commands/scope.d.ts +7 -0
  37. package/dist/commands/scope.d.ts.map +1 -0
  38. package/dist/commands/scope.js +227 -0
  39. package/dist/commands/scope.js.map +1 -0
  40. package/dist/commands/service-validate.js +7 -1
  41. package/dist/commands/service-validate.js.map +1 -1
  42. package/dist/commands/session.d.ts +2 -1
  43. package/dist/commands/session.d.ts.map +1 -1
  44. package/dist/commands/session.js +519 -49
  45. package/dist/commands/session.js.map +1 -1
  46. package/dist/commands/update.d.ts.map +1 -1
  47. package/dist/commands/update.js +25 -6
  48. package/dist/commands/update.js.map +1 -1
  49. package/dist/dashboard/components.d.ts +7 -0
  50. package/dist/dashboard/components.d.ts.map +1 -0
  51. package/dist/dashboard/components.js +163 -0
  52. package/dist/dashboard/components.js.map +1 -0
  53. package/dist/dashboard/index.d.ts +12 -0
  54. package/dist/dashboard/index.d.ts.map +1 -0
  55. package/dist/dashboard/index.js +132 -0
  56. package/dist/dashboard/index.js.map +1 -0
  57. package/dist/dashboard/pages.d.ts +7 -0
  58. package/dist/dashboard/pages.d.ts.map +1 -0
  59. package/dist/dashboard/pages.js +742 -0
  60. package/dist/dashboard/pages.js.map +1 -0
  61. package/dist/dashboard/styles.d.ts +7 -0
  62. package/dist/dashboard/styles.d.ts.map +1 -0
  63. package/dist/dashboard/styles.js +497 -0
  64. package/dist/dashboard/styles.js.map +1 -0
  65. package/dist/index.js +196 -8
  66. package/dist/index.js.map +1 -1
  67. package/dist/lib/flow-engine.d.ts +34 -0
  68. package/dist/lib/flow-engine.d.ts.map +1 -0
  69. package/dist/lib/flow-engine.js +321 -0
  70. package/dist/lib/flow-engine.js.map +1 -0
  71. package/dist/lib/hook-transformer.d.ts +11 -0
  72. package/dist/lib/hook-transformer.d.ts.map +1 -0
  73. package/dist/lib/hook-transformer.js +74 -0
  74. package/dist/lib/hook-transformer.js.map +1 -0
  75. package/dist/lib/map-event-bus.d.ts +50 -0
  76. package/dist/lib/map-event-bus.d.ts.map +1 -0
  77. package/dist/lib/map-event-bus.js +366 -0
  78. package/dist/lib/map-event-bus.js.map +1 -0
  79. package/dist/lib/memory-indexer.d.ts.map +1 -1
  80. package/dist/lib/memory-indexer.js +26 -2
  81. package/dist/lib/memory-indexer.js.map +1 -1
  82. package/dist/lib/model-pricing.d.ts +11 -0
  83. package/dist/lib/model-pricing.d.ts.map +1 -0
  84. package/dist/lib/model-pricing.js +27 -0
  85. package/dist/lib/model-pricing.js.map +1 -0
  86. package/dist/lib/peter-parker-bridge.d.ts +34 -0
  87. package/dist/lib/peter-parker-bridge.d.ts.map +1 -0
  88. package/dist/lib/peter-parker-bridge.js +145 -0
  89. package/dist/lib/peter-parker-bridge.js.map +1 -0
  90. package/dist/lib/peter-parker-config.d.ts +13 -0
  91. package/dist/lib/peter-parker-config.d.ts.map +1 -0
  92. package/dist/lib/peter-parker-config.js +86 -0
  93. package/dist/lib/peter-parker-config.js.map +1 -0
  94. package/dist/lib/service-gtm.d.ts +7 -0
  95. package/dist/lib/service-gtm.d.ts.map +1 -1
  96. package/dist/lib/service-gtm.js.map +1 -1
  97. package/dist/lib/service-utils.d.ts.map +1 -1
  98. package/dist/lib/service-utils.js +33 -17
  99. package/dist/lib/service-utils.js.map +1 -1
  100. package/dist/lib/stratus-client.d.ts +1 -0
  101. package/dist/lib/stratus-client.d.ts.map +1 -1
  102. package/dist/lib/stratus-client.js +33 -2
  103. package/dist/lib/stratus-client.js.map +1 -1
  104. package/dist/lib/stratus-rollout-test.d.ts +10 -0
  105. package/dist/lib/stratus-rollout-test.d.ts.map +1 -0
  106. package/dist/lib/stratus-rollout-test.js +412 -0
  107. package/dist/lib/stratus-rollout-test.js.map +1 -0
  108. package/dist/lib/telemetry-digest.d.ts +10 -0
  109. package/dist/lib/telemetry-digest.d.ts.map +1 -0
  110. package/dist/lib/telemetry-digest.js +359 -0
  111. package/dist/lib/telemetry-digest.js.map +1 -0
  112. package/dist/lib/telemetry.d.ts +35 -0
  113. package/dist/lib/telemetry.d.ts.map +1 -0
  114. package/dist/lib/telemetry.js +320 -0
  115. package/dist/lib/telemetry.js.map +1 -0
  116. package/dist/lib/training-tuples.d.ts +33 -0
  117. package/dist/lib/training-tuples.d.ts.map +1 -0
  118. package/dist/lib/training-tuples.js +273 -0
  119. package/dist/lib/training-tuples.js.map +1 -0
  120. package/dist/mcp/context-hub-mcp.js +139 -22
  121. package/dist/mcp/context-hub-mcp.js.map +1 -1
  122. package/dist/types/flows.d.ts +62 -0
  123. package/dist/types/flows.d.ts.map +1 -0
  124. package/dist/types/flows.js +10 -0
  125. package/dist/types/flows.js.map +1 -0
  126. package/dist/types/map.d.ts +42 -0
  127. package/dist/types/map.d.ts.map +1 -0
  128. package/dist/types/map.js +39 -0
  129. package/dist/types/map.js.map +1 -0
  130. package/dist/types/telemetry-digest.d.ts +73 -0
  131. package/dist/types/telemetry-digest.d.ts.map +1 -0
  132. package/dist/types/telemetry-digest.js +5 -0
  133. package/dist/types/telemetry-digest.js.map +1 -0
  134. package/dist/types/telemetry.d.ts +69 -0
  135. package/dist/types/telemetry.d.ts.map +1 -0
  136. package/dist/types/telemetry.js +5 -0
  137. package/dist/types/telemetry.js.map +1 -0
  138. package/dist/ui/event-dashboard.d.ts +12 -0
  139. package/dist/ui/event-dashboard.d.ts.map +1 -0
  140. package/dist/ui/event-dashboard.js +342 -0
  141. package/dist/ui/event-dashboard.js.map +1 -0
  142. package/dist/utils/jfl-paths.d.ts +1 -0
  143. package/dist/utils/jfl-paths.d.ts.map +1 -1
  144. package/dist/utils/jfl-paths.js +1 -0
  145. package/dist/utils/jfl-paths.js.map +1 -1
  146. package/dist/utils/settings-validator.d.ts +3 -2
  147. package/dist/utils/settings-validator.d.ts.map +1 -1
  148. package/dist/utils/settings-validator.js +25 -6
  149. package/dist/utils/settings-validator.js.map +1 -1
  150. package/package.json +3 -2
  151. package/scripts/session/session-end.sh +10 -0
  152. package/scripts/session/session-init.sh +16 -0
  153. package/scripts/test-map-eventbus.sh +357 -0
@@ -0,0 +1,359 @@
1
+ /**
2
+ * @purpose Analyze telemetry events into cost breakdowns, stats, and improvement suggestions
3
+ */
4
+ import { readFileSync, existsSync } from 'fs';
5
+ import { JFL_FILES } from '../utils/jfl-paths.js';
6
+ export function loadLocalEvents() {
7
+ const path = JFL_FILES.telemetryQueue;
8
+ if (!existsSync(path))
9
+ return [];
10
+ try {
11
+ const content = readFileSync(path, 'utf-8').trim();
12
+ if (!content)
13
+ return [];
14
+ return content.split('\n').map(line => {
15
+ try {
16
+ return JSON.parse(line);
17
+ }
18
+ catch {
19
+ return null;
20
+ }
21
+ }).filter(Boolean);
22
+ }
23
+ catch {
24
+ return [];
25
+ }
26
+ }
27
+ export function analyzeEvents(events, periodHours) {
28
+ const cutoff = new Date(Date.now() - periodHours * 60 * 60 * 1000).toISOString();
29
+ const filtered = events.filter(e => e.ts >= cutoff);
30
+ const costMap = new Map();
31
+ const cmdMap = new Map();
32
+ const errorsByType = {};
33
+ let totalErrors = 0;
34
+ const hub = { starts: 0, crashes: 0, mcpCalls: 0, totalMcpLatency: 0 };
35
+ const memory = { indexRuns: 0, entriesIndexed: 0, errors: 0, totalDuration: 0 };
36
+ const sessions = { started: 0, ended: 0, crashed: 0, totalDuration: 0, durationCount: 0 };
37
+ const hooks = { received: 0, byEvent: {}, byTool: {}, fileEdits: {} };
38
+ const flows = { triggered: 0, completed: 0, failed: 0, byFlow: {} };
39
+ for (const e of filtered) {
40
+ if (e.event === 'stratus:api_call' || e.event === 'peter:agent_cost') {
41
+ const model = e.model_name || e.stratus_model || 'unknown';
42
+ const existing = costMap.get(model) || {
43
+ model,
44
+ calls: 0,
45
+ promptTokens: 0,
46
+ completionTokens: 0,
47
+ totalTokens: 0,
48
+ estimatedCostUsd: 0,
49
+ avgLatencyMs: 0,
50
+ };
51
+ existing.calls++;
52
+ existing.promptTokens += e.prompt_tokens || 0;
53
+ existing.completionTokens += e.completion_tokens || 0;
54
+ existing.totalTokens += e.total_tokens || 0;
55
+ existing.estimatedCostUsd += e.estimated_cost_usd || 0;
56
+ existing.avgLatencyMs = ((existing.avgLatencyMs * (existing.calls - 1)) + (e.duration_ms || 0)) / existing.calls;
57
+ costMap.set(model, existing);
58
+ }
59
+ if (e.category === 'command' && e.command) {
60
+ const cmd = e.command;
61
+ const existing = cmdMap.get(cmd) || { count: 0, totalDuration: 0, successes: 0 };
62
+ existing.count++;
63
+ existing.totalDuration += e.duration_ms || 0;
64
+ if (e.success !== false)
65
+ existing.successes++;
66
+ cmdMap.set(cmd, existing);
67
+ }
68
+ if (e.category === 'error') {
69
+ totalErrors++;
70
+ const t = e.error_type || 'unknown';
71
+ errorsByType[t] = (errorsByType[t] || 0) + 1;
72
+ }
73
+ if (e.event === 'context_hub:started')
74
+ hub.starts++;
75
+ if (e.event === 'error:hub_crash')
76
+ hub.crashes++;
77
+ if (e.event === 'context_hub:mcp_call') {
78
+ hub.mcpCalls++;
79
+ hub.totalMcpLatency += e.mcp_duration_ms || 0;
80
+ }
81
+ if (e.event === 'performance:memory_index') {
82
+ memory.indexRuns++;
83
+ memory.entriesIndexed += e.memory_entries_indexed || 0;
84
+ memory.errors += e.entries_errors || 0;
85
+ memory.totalDuration += e.memory_index_duration_ms || 0;
86
+ }
87
+ if (e.category === 'session') {
88
+ if (e.session_event === 'start')
89
+ sessions.started++;
90
+ if (e.session_event === 'end') {
91
+ sessions.ended++;
92
+ if (e.session_duration_s) {
93
+ sessions.totalDuration += e.session_duration_s;
94
+ sessions.durationCount++;
95
+ }
96
+ }
97
+ if (e.session_event === 'crash')
98
+ sessions.crashed++;
99
+ }
100
+ if (e.category === 'hooks' && e.event === 'hook:received') {
101
+ hooks.received++;
102
+ const hookEvent = e.hook_event_name || 'unknown';
103
+ hooks.byEvent[hookEvent] = (hooks.byEvent[hookEvent] || 0) + 1;
104
+ const toolName = e.tool_name;
105
+ if (toolName) {
106
+ hooks.byTool[toolName] = (hooks.byTool[toolName] || 0) + 1;
107
+ }
108
+ const filePaths = e.file_paths;
109
+ if (filePaths && Array.isArray(filePaths)) {
110
+ for (const fp of filePaths) {
111
+ if (typeof fp === 'string') {
112
+ hooks.fileEdits[fp] = (hooks.fileEdits[fp] || 0) + 1;
113
+ }
114
+ }
115
+ }
116
+ }
117
+ if (e.event === 'flow:triggered' || e.event === 'flow:completed') {
118
+ if (e.event === 'flow:triggered')
119
+ flows.triggered++;
120
+ if (e.event === 'flow:completed') {
121
+ flows.completed++;
122
+ if (e.actions_failed > 0)
123
+ flows.failed++;
124
+ }
125
+ const flowName = e.flow_name || 'unknown';
126
+ flows.byFlow[flowName] = (flows.byFlow[flowName] || 0) + 1;
127
+ }
128
+ }
129
+ const costs = Array.from(costMap.values()).sort((a, b) => b.estimatedCostUsd - a.estimatedCostUsd);
130
+ const totalCostUsd = costs.reduce((sum, c) => sum + c.estimatedCostUsd, 0);
131
+ const commands = Array.from(cmdMap.entries())
132
+ .map(([command, stats]) => ({
133
+ command,
134
+ count: stats.count,
135
+ avgDurationMs: stats.count > 0 ? Math.round(stats.totalDuration / stats.count) : 0,
136
+ successRate: stats.count > 0 ? stats.successes / stats.count : 1,
137
+ }))
138
+ .sort((a, b) => b.count - a.count);
139
+ return {
140
+ periodHours,
141
+ generatedAt: new Date().toISOString(),
142
+ totalEvents: filtered.length,
143
+ costs,
144
+ totalCostUsd,
145
+ commands,
146
+ errors: { total: totalErrors, byType: errorsByType },
147
+ hubHealth: {
148
+ starts: hub.starts,
149
+ crashes: hub.crashes,
150
+ mcpCalls: hub.mcpCalls,
151
+ avgMcpLatencyMs: hub.mcpCalls > 0 ? Math.round(hub.totalMcpLatency / hub.mcpCalls) : 0,
152
+ },
153
+ memoryHealth: {
154
+ indexRuns: memory.indexRuns,
155
+ entriesIndexed: memory.entriesIndexed,
156
+ errors: memory.errors,
157
+ avgDurationMs: memory.indexRuns > 0 ? Math.round(memory.totalDuration / memory.indexRuns) : 0,
158
+ },
159
+ sessions: {
160
+ started: sessions.started,
161
+ ended: sessions.ended,
162
+ crashed: sessions.crashed,
163
+ avgDurationS: sessions.durationCount > 0 ? Math.round(sessions.totalDuration / sessions.durationCount) : 0,
164
+ },
165
+ hooks: {
166
+ received: hooks.received,
167
+ byEvent: hooks.byEvent,
168
+ byTool: hooks.byTool,
169
+ fileHotspots: Object.entries(hooks.fileEdits)
170
+ .map(([file, edits]) => ({ file, edits }))
171
+ .sort((a, b) => b.edits - a.edits)
172
+ .slice(0, 10),
173
+ },
174
+ flows: {
175
+ triggered: flows.triggered,
176
+ completed: flows.completed,
177
+ failed: flows.failed,
178
+ byFlow: flows.byFlow,
179
+ },
180
+ };
181
+ }
182
+ export function generateSuggestions(digest) {
183
+ const suggestions = [];
184
+ if (digest.hubHealth.avgMcpLatencyMs > 500) {
185
+ suggestions.push({
186
+ type: 'perf',
187
+ severity: 'medium',
188
+ title: 'High MCP latency detected',
189
+ description: `Average MCP call latency is ${digest.hubHealth.avgMcpLatencyMs}ms (threshold: 500ms).`,
190
+ suggestedFix: 'Restart Context Hub (`jfl hub restart`). Check for large journal files or slow disk I/O.',
191
+ });
192
+ }
193
+ if (digest.totalEvents > 10) {
194
+ const errorRate = digest.errors.total / digest.totalEvents;
195
+ if (errorRate > 0.1) {
196
+ suggestions.push({
197
+ type: 'reliability',
198
+ severity: 'high',
199
+ title: 'Error rate exceeds 10%',
200
+ description: `${digest.errors.total} errors out of ${digest.totalEvents} events (${(errorRate * 100).toFixed(1)}%).`,
201
+ suggestedFix: `Top error types: ${Object.entries(digest.errors.byType).sort((a, b) => b[1] - a[1]).slice(0, 3).map(([t, c]) => `${t} (${c})`).join(', ')}. Investigate and fix the most common errors.`,
202
+ });
203
+ }
204
+ }
205
+ if (digest.totalCostUsd > 0 && digest.costs.length > 0) {
206
+ const topModel = digest.costs[0];
207
+ const topModelShare = topModel.estimatedCostUsd / digest.totalCostUsd;
208
+ if (topModelShare > 0.8 && digest.costs.length > 1) {
209
+ suggestions.push({
210
+ type: 'cost',
211
+ severity: 'medium',
212
+ title: `${topModel.model} accounts for ${(topModelShare * 100).toFixed(0)}% of cost`,
213
+ description: `$${topModel.estimatedCostUsd.toFixed(4)} of $${digest.totalCostUsd.toFixed(4)} total from ${topModel.calls} calls.`,
214
+ suggestedFix: 'Consider routing lower-stakes operations (scout, tester) to a cheaper model tier.',
215
+ });
216
+ }
217
+ }
218
+ const totalSessions = digest.sessions.started || 1;
219
+ const crashRate = digest.sessions.crashed / totalSessions;
220
+ if (crashRate > 0.05 && digest.sessions.started > 5) {
221
+ suggestions.push({
222
+ type: 'reliability',
223
+ severity: 'high',
224
+ title: 'Session crash rate exceeds 5%',
225
+ description: `${digest.sessions.crashed} crashes out of ${digest.sessions.started} sessions (${(crashRate * 100).toFixed(1)}%).`,
226
+ suggestedFix: 'Check session logs for common crash patterns. Ensure auto-commit is running.',
227
+ });
228
+ }
229
+ if (digest.memoryHealth.errors > 0) {
230
+ suggestions.push({
231
+ type: 'reliability',
232
+ severity: 'medium',
233
+ title: 'Memory indexing errors detected',
234
+ description: `${digest.memoryHealth.errors} indexing errors across ${digest.memoryHealth.indexRuns} runs.`,
235
+ suggestedFix: 'Run `jfl memory status` and `jfl-doctor.sh --fix` to repair the index.',
236
+ });
237
+ }
238
+ if (digest.hubHealth.crashes > 2) {
239
+ suggestions.push({
240
+ type: 'reliability',
241
+ severity: 'high',
242
+ title: 'Context Hub crashing frequently',
243
+ description: `${digest.hubHealth.crashes} hub crashes in the last ${digest.periodHours}h.`,
244
+ suggestedFix: 'Check hub logs, ensure port 7890 is not conflicting, and restart with `jfl hub start`.',
245
+ });
246
+ }
247
+ if (digest.hooks && digest.hooks.received > 50) {
248
+ const topTools = Object.entries(digest.hooks.byTool)
249
+ .sort((a, b) => b[1] - a[1])
250
+ .slice(0, 3);
251
+ if (topTools.length > 0) {
252
+ const toolList = topTools.map(([t, c]) => `${t} (${c})`).join(', ');
253
+ suggestions.push({
254
+ type: 'usage',
255
+ severity: 'low',
256
+ title: 'Tool usage breakdown available',
257
+ description: `${digest.hooks.received} hook events captured. Top tools: ${toolList}.`,
258
+ suggestedFix: 'Review tool usage patterns. High Edit/Write ratios may indicate files needing refactoring.',
259
+ });
260
+ }
261
+ }
262
+ if (digest.hooks?.fileHotspots?.length > 0) {
263
+ const hotspot = digest.hooks.fileHotspots[0];
264
+ if (hotspot.edits > 10) {
265
+ suggestions.push({
266
+ type: 'usage',
267
+ severity: 'medium',
268
+ title: `File hotspot: ${hotspot.file}`,
269
+ description: `${hotspot.file} edited ${hotspot.edits} times — consider refactoring.`,
270
+ suggestedFix: 'Files edited frequently across sessions may benefit from decomposition or clearer interfaces.',
271
+ });
272
+ }
273
+ }
274
+ if (digest.flows && digest.flows.triggered > 0 && digest.flows.failed > 0) {
275
+ const failRate = digest.flows.failed / digest.flows.triggered;
276
+ if (failRate > 0.2) {
277
+ suggestions.push({
278
+ type: 'reliability',
279
+ severity: 'medium',
280
+ title: 'Flow failure rate exceeds 20%',
281
+ description: `${digest.flows.failed} of ${digest.flows.triggered} flow triggers had action failures.`,
282
+ suggestedFix: 'Check flow definitions in .jfl/flows.yaml. Run `jfl flows test <name>` to debug.',
283
+ });
284
+ }
285
+ }
286
+ return suggestions;
287
+ }
288
+ export function formatDigest(digest, format) {
289
+ if (format === 'json')
290
+ return JSON.stringify(digest, null, 2);
291
+ const lines = [];
292
+ lines.push(`\n Telemetry Digest (last ${digest.periodHours}h)`);
293
+ lines.push(` Generated: ${digest.generatedAt.replace('T', ' ').slice(0, 19)}`);
294
+ lines.push(` Total events: ${digest.totalEvents}\n`);
295
+ if (digest.costs.length > 0) {
296
+ lines.push(' Model Costs');
297
+ lines.push(' ' + '-'.repeat(72));
298
+ lines.push(' ' + 'Model'.padEnd(35) + 'Calls'.padEnd(8) + 'Tokens'.padEnd(12) + 'Cost');
299
+ lines.push(' ' + '-'.repeat(72));
300
+ for (const c of digest.costs) {
301
+ lines.push(' ' +
302
+ c.model.padEnd(35) +
303
+ String(c.calls).padEnd(8) +
304
+ String(c.totalTokens).padEnd(12) +
305
+ `$${c.estimatedCostUsd.toFixed(4)}`);
306
+ }
307
+ lines.push(' ' + '-'.repeat(72));
308
+ lines.push(' ' + 'Total'.padEnd(55) + `$${digest.totalCostUsd.toFixed(4)}`);
309
+ lines.push('');
310
+ }
311
+ if (digest.commands.length > 0) {
312
+ lines.push(' Top Commands');
313
+ lines.push(' ' + '-'.repeat(56));
314
+ lines.push(' ' + 'Command'.padEnd(20) + 'Count'.padEnd(8) + 'Avg ms'.padEnd(12) + 'Success');
315
+ lines.push(' ' + '-'.repeat(56));
316
+ for (const c of digest.commands.slice(0, 10)) {
317
+ lines.push(' ' +
318
+ c.command.padEnd(20) +
319
+ String(c.count).padEnd(8) +
320
+ String(c.avgDurationMs).padEnd(12) +
321
+ `${(c.successRate * 100).toFixed(0)}%`);
322
+ }
323
+ lines.push('');
324
+ }
325
+ if (digest.hooks && digest.hooks.received > 0) {
326
+ lines.push(' Hook Events');
327
+ lines.push(' ' + '-'.repeat(56));
328
+ lines.push(` Total received: ${digest.hooks.received}`);
329
+ const topTools = Object.entries(digest.hooks.byTool).sort((a, b) => b[1] - a[1]).slice(0, 5);
330
+ if (topTools.length > 0) {
331
+ lines.push(' Top tools: ' + topTools.map(([t, c]) => `${t} (${c})`).join(', '));
332
+ }
333
+ if (digest.hooks.fileHotspots?.length > 0) {
334
+ lines.push(' File hotspots:');
335
+ for (const h of digest.hooks.fileHotspots.slice(0, 5)) {
336
+ lines.push(` ${h.file} — ${h.edits} edits`);
337
+ }
338
+ }
339
+ lines.push('');
340
+ }
341
+ if (digest.flows && digest.flows.triggered > 0) {
342
+ lines.push(' Flows');
343
+ lines.push(' ' + '-'.repeat(56));
344
+ lines.push(` Triggered: ${digest.flows.triggered}, Completed: ${digest.flows.completed}, Failed: ${digest.flows.failed}`);
345
+ const topFlows = Object.entries(digest.flows.byFlow).sort((a, b) => b[1] - a[1]).slice(0, 5);
346
+ if (topFlows.length > 0) {
347
+ lines.push(' Top flows: ' + topFlows.map(([f, c]) => `${f} (${c})`).join(', '));
348
+ }
349
+ lines.push('');
350
+ }
351
+ lines.push(' Health');
352
+ lines.push(` Sessions: ${digest.sessions.started} started, ${digest.sessions.ended} ended, ${digest.sessions.crashed} crashed`);
353
+ lines.push(` Hub: ${digest.hubHealth.starts} starts, ${digest.hubHealth.crashes} crashes, ${digest.hubHealth.mcpCalls} MCP calls (avg ${digest.hubHealth.avgMcpLatencyMs}ms)`);
354
+ lines.push(` Memory: ${digest.memoryHealth.indexRuns} index runs, ${digest.memoryHealth.entriesIndexed} indexed, ${digest.memoryHealth.errors} errors`);
355
+ lines.push(` Errors: ${digest.errors.total} total`);
356
+ lines.push('');
357
+ return lines.join('\n');
358
+ }
359
+ //# sourceMappingURL=telemetry-digest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"telemetry-digest.js","sourceRoot":"","sources":["../../src/lib/telemetry-digest.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ /**
2
+ * @purpose Lightweight telemetry client with batched HTTP flush, spillover queue, and opt-out consent
3
+ */
4
+ import type { TelemetryEvent } from '../types/telemetry.js';
5
+ declare class TelemetryClient {
6
+ private queue;
7
+ private timer;
8
+ private initialized;
9
+ private disabled;
10
+ private sessionId;
11
+ private installId;
12
+ private flushing;
13
+ private exitHandlerRegistered;
14
+ track(partial: Partial<TelemetryEvent> & Pick<TelemetryEvent, 'category' | 'event'>): void;
15
+ private init;
16
+ private showConsentNotice;
17
+ private getConfig;
18
+ private saveConfig;
19
+ flush(): Promise<void>;
20
+ private flushSync;
21
+ private get spilloverPath();
22
+ private spillToDisk;
23
+ private loadSpillover;
24
+ isEnabled(): boolean;
25
+ getInstallId(): string;
26
+ getSessionId(): string;
27
+ getQueueSize(): number;
28
+ getSpilloverEvents(): TelemetryEvent[];
29
+ disable(): void;
30
+ enable(): void;
31
+ resetInstallId(): void;
32
+ }
33
+ export declare const telemetry: TelemetryClient;
34
+ export {};
35
+ //# sourceMappingURL=telemetry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"telemetry.d.ts","sourceRoot":"","sources":["../../src/lib/telemetry.ts"],"names":[],"mappings":"AAAA;;GAEG;AAMH,OAAO,KAAK,EAAE,cAAc,EAAmB,MAAM,uBAAuB,CAAA;AAsB5E,cAAM,eAAe;IACnB,OAAO,CAAC,KAAK,CAAuB;IACpC,OAAO,CAAC,KAAK,CAA8C;IAC3D,OAAO,CAAC,WAAW,CAAQ;IAC3B,OAAO,CAAC,QAAQ,CAAQ;IACxB,OAAO,CAAC,SAAS,CAAa;IAC9B,OAAO,CAAC,SAAS,CAAa;IAC9B,OAAO,CAAC,QAAQ,CAAQ;IACxB,OAAO,CAAC,qBAAqB,CAAQ;IAErC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,UAAU,GAAG,OAAO,CAAC,GAAG,IAAI;IA0B1F,OAAO,CAAC,IAAI;IA+DZ,OAAO,CAAC,iBAAiB;IAazB,OAAO,CAAC,SAAS;IAajB,OAAO,CAAC,UAAU;IAsBZ,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IA4C5B,OAAO,CAAC,SAAS;IAQjB,OAAO,KAAK,aAAa,GAExB;IAED,OAAO,CAAC,WAAW;IAanB,OAAO,CAAC,aAAa;IAyBrB,SAAS,IAAI,OAAO;IAKpB,YAAY,IAAI,MAAM;IAKtB,YAAY,IAAI,MAAM;IAKtB,YAAY,IAAI,MAAM;IAItB,kBAAkB,IAAI,cAAc,EAAE;IAatC,OAAO,IAAI,IAAI;IAWf,MAAM,IAAI,IAAI;IAYd,cAAc,IAAI,IAAI;CAMvB;AAGD,eAAO,MAAM,SAAS,iBAAwB,CAAA"}