dravix-agent 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (208) hide show
  1. package/.claude/settings.example.json +30 -0
  2. package/ARCHITECTURE.md +410 -0
  3. package/LICENSE +21 -0
  4. package/README.md +153 -0
  5. package/ROADMAP.md +117 -0
  6. package/data/vulnkb.json +666 -0
  7. package/dist/bin/aegis.d.ts +3 -0
  8. package/dist/bin/aegis.d.ts.map +1 -0
  9. package/dist/bin/aegis.js +489 -0
  10. package/dist/bin/aegis.js.map +1 -0
  11. package/dist/cache.d.ts +9 -0
  12. package/dist/cache.d.ts.map +1 -0
  13. package/dist/cache.js +146 -0
  14. package/dist/cache.js.map +1 -0
  15. package/dist/engines/ai-sinks.d.ts +52 -0
  16. package/dist/engines/ai-sinks.d.ts.map +1 -0
  17. package/dist/engines/ai-sinks.js +204 -0
  18. package/dist/engines/ai-sinks.js.map +1 -0
  19. package/dist/engines/eslint.d.ts +9 -0
  20. package/dist/engines/eslint.d.ts.map +1 -0
  21. package/dist/engines/eslint.js +245 -0
  22. package/dist/engines/eslint.js.map +1 -0
  23. package/dist/engines/joern.d.ts +3 -0
  24. package/dist/engines/joern.d.ts.map +1 -0
  25. package/dist/engines/joern.js +98 -0
  26. package/dist/engines/joern.js.map +1 -0
  27. package/dist/engines/js-sinks.d.ts +70 -0
  28. package/dist/engines/js-sinks.d.ts.map +1 -0
  29. package/dist/engines/js-sinks.js +370 -0
  30. package/dist/engines/js-sinks.js.map +1 -0
  31. package/dist/engines/llm-critic.d.ts +130 -0
  32. package/dist/engines/llm-critic.d.ts.map +1 -0
  33. package/dist/engines/llm-critic.js +551 -0
  34. package/dist/engines/llm-critic.js.map +1 -0
  35. package/dist/engines/pragma.d.ts +20 -0
  36. package/dist/engines/pragma.d.ts.map +1 -0
  37. package/dist/engines/pragma.js +83 -0
  38. package/dist/engines/pragma.js.map +1 -0
  39. package/dist/engines/property-test.d.ts +3 -0
  40. package/dist/engines/property-test.d.ts.map +1 -0
  41. package/dist/engines/property-test.js +134 -0
  42. package/dist/engines/property-test.js.map +1 -0
  43. package/dist/engines/pyright.d.ts +10 -0
  44. package/dist/engines/pyright.d.ts.map +1 -0
  45. package/dist/engines/pyright.js +143 -0
  46. package/dist/engines/pyright.js.map +1 -0
  47. package/dist/engines/pysa.d.ts +3 -0
  48. package/dist/engines/pysa.d.ts.map +1 -0
  49. package/dist/engines/pysa.js +83 -0
  50. package/dist/engines/pysa.js.map +1 -0
  51. package/dist/engines/python-sinks.d.ts +82 -0
  52. package/dist/engines/python-sinks.d.ts.map +1 -0
  53. package/dist/engines/python-sinks.js +459 -0
  54. package/dist/engines/python-sinks.js.map +1 -0
  55. package/dist/engines/registry.d.ts +26 -0
  56. package/dist/engines/registry.d.ts.map +1 -0
  57. package/dist/engines/registry.js +70 -0
  58. package/dist/engines/registry.js.map +1 -0
  59. package/dist/engines/secret-scan.d.ts +22 -0
  60. package/dist/engines/secret-scan.d.ts.map +1 -0
  61. package/dist/engines/secret-scan.js +179 -0
  62. package/dist/engines/secret-scan.js.map +1 -0
  63. package/dist/engines/semgrep.d.ts +10 -0
  64. package/dist/engines/semgrep.d.ts.map +1 -0
  65. package/dist/engines/semgrep.js +200 -0
  66. package/dist/engines/semgrep.js.map +1 -0
  67. package/dist/engines/treesitter.d.ts +18 -0
  68. package/dist/engines/treesitter.d.ts.map +1 -0
  69. package/dist/engines/treesitter.js +135 -0
  70. package/dist/engines/treesitter.js.map +1 -0
  71. package/dist/engines/tsc.d.ts +10 -0
  72. package/dist/engines/tsc.d.ts.map +1 -0
  73. package/dist/engines/tsc.js +142 -0
  74. package/dist/engines/tsc.js.map +1 -0
  75. package/dist/engines/types.d.ts +47 -0
  76. package/dist/engines/types.d.ts.map +1 -0
  77. package/dist/engines/types.js +27 -0
  78. package/dist/engines/types.js.map +1 -0
  79. package/dist/findings.d.ts +121 -0
  80. package/dist/findings.d.ts.map +1 -0
  81. package/dist/findings.js +98 -0
  82. package/dist/findings.js.map +1 -0
  83. package/dist/hooks/claude-code.d.ts +3 -0
  84. package/dist/hooks/claude-code.d.ts.map +1 -0
  85. package/dist/hooks/claude-code.js +187 -0
  86. package/dist/hooks/claude-code.js.map +1 -0
  87. package/dist/index/context.d.ts +127 -0
  88. package/dist/index/context.d.ts.map +1 -0
  89. package/dist/index/context.js +267 -0
  90. package/dist/index/context.js.map +1 -0
  91. package/dist/index/embeddings.d.ts +68 -0
  92. package/dist/index/embeddings.d.ts.map +1 -0
  93. package/dist/index/embeddings.js +570 -0
  94. package/dist/index/embeddings.js.map +1 -0
  95. package/dist/index/graph_routing.d.ts +36 -0
  96. package/dist/index/graph_routing.d.ts.map +1 -0
  97. package/dist/index/graph_routing.js +170 -0
  98. package/dist/index/graph_routing.js.map +1 -0
  99. package/dist/index/joern.d.ts +76 -0
  100. package/dist/index/joern.d.ts.map +1 -0
  101. package/dist/index/joern.js +782 -0
  102. package/dist/index/joern.js.map +1 -0
  103. package/dist/index/property-test.d.ts +88 -0
  104. package/dist/index/property-test.d.ts.map +1 -0
  105. package/dist/index/property-test.js +466 -0
  106. package/dist/index/property-test.js.map +1 -0
  107. package/dist/index/proto/scip.proto +897 -0
  108. package/dist/index/pysa.d.ts +91 -0
  109. package/dist/index/pysa.d.ts.map +1 -0
  110. package/dist/index/pysa.js +617 -0
  111. package/dist/index/pysa.js.map +1 -0
  112. package/dist/index/scip.d.ts +76 -0
  113. package/dist/index/scip.d.ts.map +1 -0
  114. package/dist/index/scip.js +541 -0
  115. package/dist/index/scip.js.map +1 -0
  116. package/dist/index/vulrag.d.ts +86 -0
  117. package/dist/index/vulrag.d.ts.map +1 -0
  118. package/dist/index/vulrag.js +242 -0
  119. package/dist/index/vulrag.js.map +1 -0
  120. package/dist/index.d.ts +9 -0
  121. package/dist/index.d.ts.map +1 -0
  122. package/dist/index.js +8 -0
  123. package/dist/index.js.map +1 -0
  124. package/dist/install/claude-code.d.ts +31 -0
  125. package/dist/install/claude-code.d.ts.map +1 -0
  126. package/dist/install/claude-code.js +447 -0
  127. package/dist/install/claude-code.js.map +1 -0
  128. package/dist/lang.d.ts +5 -0
  129. package/dist/lang.d.ts.map +1 -0
  130. package/dist/lang.js +52 -0
  131. package/dist/lang.js.map +1 -0
  132. package/dist/learning/suppressions.d.ts +70 -0
  133. package/dist/learning/suppressions.d.ts.map +1 -0
  134. package/dist/learning/suppressions.js +179 -0
  135. package/dist/learning/suppressions.js.map +1 -0
  136. package/dist/mcp/server.d.ts +2 -0
  137. package/dist/mcp/server.d.ts.map +1 -0
  138. package/dist/mcp/server.js +187 -0
  139. package/dist/mcp/server.js.map +1 -0
  140. package/dist/mcp/tools/explain.d.ts +58 -0
  141. package/dist/mcp/tools/explain.d.ts.map +1 -0
  142. package/dist/mcp/tools/explain.js +60 -0
  143. package/dist/mcp/tools/explain.js.map +1 -0
  144. package/dist/mcp/tools/precheck.d.ts +29 -0
  145. package/dist/mcp/tools/precheck.d.ts.map +1 -0
  146. package/dist/mcp/tools/precheck.js +42 -0
  147. package/dist/mcp/tools/precheck.js.map +1 -0
  148. package/dist/mcp/tools/validate.d.ts +73 -0
  149. package/dist/mcp/tools/validate.d.ts.map +1 -0
  150. package/dist/mcp/tools/validate.js +66 -0
  151. package/dist/mcp/tools/validate.js.map +1 -0
  152. package/dist/mcp/warm.d.ts +88 -0
  153. package/dist/mcp/warm.d.ts.map +1 -0
  154. package/dist/mcp/warm.js +331 -0
  155. package/dist/mcp/warm.js.map +1 -0
  156. package/dist/orchestrator.d.ts +46 -0
  157. package/dist/orchestrator.d.ts.map +1 -0
  158. package/dist/orchestrator.js +596 -0
  159. package/dist/orchestrator.js.map +1 -0
  160. package/dist/policy.d.ts +51 -0
  161. package/dist/policy.d.ts.map +1 -0
  162. package/dist/policy.js +201 -0
  163. package/dist/policy.js.map +1 -0
  164. package/dist/risk.d.ts +31 -0
  165. package/dist/risk.d.ts.map +1 -0
  166. package/dist/risk.js +92 -0
  167. package/dist/risk.js.map +1 -0
  168. package/dist/stats.d.ts +72 -0
  169. package/dist/stats.d.ts.map +1 -0
  170. package/dist/stats.js +217 -0
  171. package/dist/stats.js.map +1 -0
  172. package/dist/telemetry/collector.d.ts +10 -0
  173. package/dist/telemetry/collector.d.ts.map +1 -0
  174. package/dist/telemetry/collector.js +75 -0
  175. package/dist/telemetry/collector.js.map +1 -0
  176. package/dist/telemetry/consent.d.ts +9 -0
  177. package/dist/telemetry/consent.d.ts.map +1 -0
  178. package/dist/telemetry/consent.js +42 -0
  179. package/dist/telemetry/consent.js.map +1 -0
  180. package/dist/telemetry/installation.d.ts +2 -0
  181. package/dist/telemetry/installation.d.ts.map +1 -0
  182. package/dist/telemetry/installation.js +32 -0
  183. package/dist/telemetry/installation.js.map +1 -0
  184. package/dist/telemetry/sanitizer.d.ts +5 -0
  185. package/dist/telemetry/sanitizer.d.ts.map +1 -0
  186. package/dist/telemetry/sanitizer.js +60 -0
  187. package/dist/telemetry/sanitizer.js.map +1 -0
  188. package/dist/telemetry/types.d.ts +39 -0
  189. package/dist/telemetry/types.d.ts.map +1 -0
  190. package/dist/telemetry/types.js +4 -0
  191. package/dist/telemetry/types.js.map +1 -0
  192. package/dist/telemetry/uploader.d.ts +12 -0
  193. package/dist/telemetry/uploader.d.ts.map +1 -0
  194. package/dist/telemetry/uploader.js +92 -0
  195. package/dist/telemetry/uploader.js.map +1 -0
  196. package/dist/util/logger.d.ts +19 -0
  197. package/dist/util/logger.d.ts.map +1 -0
  198. package/dist/util/logger.js +58 -0
  199. package/dist/util/logger.js.map +1 -0
  200. package/dist/util/safe-paths.d.ts +8 -0
  201. package/dist/util/safe-paths.d.ts.map +1 -0
  202. package/dist/util/safe-paths.js +102 -0
  203. package/dist/util/safe-paths.js.map +1 -0
  204. package/dist/util/subprocess.d.ts +32 -0
  205. package/dist/util/subprocess.d.ts.map +1 -0
  206. package/dist/util/subprocess.js +137 -0
  207. package/dist/util/subprocess.js.map +1 -0
  208. package/package.json +93 -0
package/dist/stats.js ADDED
@@ -0,0 +1,217 @@
1
+ /**
2
+ * Audit-log stats for ``aegis stats``.
3
+ *
4
+ * The orchestrator already appends one JSON line per gate decision to
5
+ * ``<project_root>/.aegis/audit.jsonl`` (see ``appendAudit`` in
6
+ * src/orchestrator.ts). This module reads that log, optionally filters
7
+ * by time window, and computes the operational metrics the user needs
8
+ * to answer "is the gate actually useful on my project?".
9
+ *
10
+ * Metrics produced:
11
+ * total_runs — how many ``runGate()`` invocations
12
+ * verdict_distribution — allow / warn / block counts + pct
13
+ * latency — p50 / p95 / p99 / max (ms)
14
+ * truncated_rate — fraction of runs that hit the orchestrator timeout
15
+ * findings_per_run — avg / max
16
+ * top_engines — which engine is doing the heavy lifting
17
+ * top_rules — most-fired rule_ids
18
+ * top_files — files with the most blocks (often = where the work is)
19
+ *
20
+ * Output is JSON by default (machine-readable) with optional ``--human``
21
+ * pretty-print. The CLI in src/bin/aegis.ts wires the flag.
22
+ *
23
+ * Time window: ``--since 7d`` accepts ``Nd`` / ``Nh`` / ``Nm`` / ISO-8601
24
+ * date. Default is "all-time".
25
+ */
26
+ import { existsSync, readFileSync } from "node:fs";
27
+ import { join } from "node:path";
28
+ import { getLogger } from "./util/logger.js";
29
+ const log = getLogger("aegis.stats");
30
+ // ── Audit log loader ──────────────────────────────────────────────────────
31
+ export function auditPath(projectRoot) {
32
+ return join(projectRoot, ".aegis", "audit.jsonl");
33
+ }
34
+ /** Read all audit rows. Skips malformed lines silently. Never throws. */
35
+ export function loadAuditRows(projectRoot) {
36
+ const p = auditPath(projectRoot);
37
+ if (!existsSync(p))
38
+ return [];
39
+ let raw;
40
+ try {
41
+ raw = readFileSync(p, "utf8");
42
+ }
43
+ catch (err) {
44
+ log.warn("stats: audit read failed", { path: p, err: String(err) });
45
+ return [];
46
+ }
47
+ const out = [];
48
+ for (const line of raw.split(/\r?\n/)) {
49
+ const trimmed = line.trim();
50
+ if (!trimmed)
51
+ continue;
52
+ try {
53
+ const obj = JSON.parse(trimmed);
54
+ if (typeof obj.ts === "string" &&
55
+ typeof obj.file === "string" &&
56
+ typeof obj.action === "string" &&
57
+ (obj.action === "allow" || obj.action === "warn" || obj.action === "block") &&
58
+ typeof obj.duration_ms === "number") {
59
+ out.push(obj);
60
+ }
61
+ }
62
+ catch {
63
+ // skip
64
+ }
65
+ }
66
+ return out;
67
+ }
68
+ // ── --since parser ────────────────────────────────────────────────────────
69
+ /** Parse a `--since` value: ``N{d|h|m}`` (relative) or an ISO 8601
70
+ * timestamp (absolute). Returns the epoch ms cutoff, or null when the
71
+ * value is unparseable (caller treats null as "all-time"). */
72
+ export function parseSince(since) {
73
+ if (!since)
74
+ return null;
75
+ const trimmed = since.trim();
76
+ const rel = trimmed.match(/^(\d+)\s*([dhm])$/i);
77
+ if (rel) {
78
+ const n = Number(rel[1]);
79
+ const unit = rel[2].toLowerCase();
80
+ const ms = unit === "d" ? 86_400_000 : unit === "h" ? 3_600_000 : 60_000;
81
+ return Date.now() - n * ms;
82
+ }
83
+ const t = Date.parse(trimmed);
84
+ if (Number.isFinite(t))
85
+ return t;
86
+ return null;
87
+ }
88
+ export function computeStats(rows, opts) {
89
+ const sinceMs = opts?.sinceMs ?? null;
90
+ const topN = opts?.topN ?? 10;
91
+ // Filter by since.
92
+ const filtered = sinceMs === null
93
+ ? rows
94
+ : rows.filter((r) => {
95
+ const t = Date.parse(r.ts);
96
+ return Number.isFinite(t) && t >= sinceMs;
97
+ });
98
+ const total = filtered.length;
99
+ const counts = { allow: 0, warn: 0, block: 0 };
100
+ const latencies = [];
101
+ const engines = new Map();
102
+ const rules = new Map();
103
+ const fileStats = new Map();
104
+ let truncated = 0;
105
+ let findingsTotal = 0;
106
+ let findingsMax = 0;
107
+ for (const r of filtered) {
108
+ counts[r.action]++;
109
+ if (Number.isFinite(r.duration_ms))
110
+ latencies.push(r.duration_ms);
111
+ if (r.truncated)
112
+ truncated++;
113
+ const nf = r.n_findings ?? 0;
114
+ findingsTotal += nf;
115
+ if (nf > findingsMax)
116
+ findingsMax = nf;
117
+ if (r.driving?.engine) {
118
+ engines.set(r.driving.engine, (engines.get(r.driving.engine) ?? 0) + 1);
119
+ }
120
+ if (r.driving?.rule_id) {
121
+ rules.set(r.driving.rule_id, (rules.get(r.driving.rule_id) ?? 0) + 1);
122
+ }
123
+ const fs = fileStats.get(r.file) ?? { blocks: 0, runs: 0 };
124
+ fs.runs++;
125
+ if (r.action === "block")
126
+ fs.blocks++;
127
+ fileStats.set(r.file, fs);
128
+ }
129
+ const sortedLatencies = [...latencies].sort((a, b) => a - b);
130
+ const pct = (p) => {
131
+ if (sortedLatencies.length === 0)
132
+ return 0;
133
+ const idx = Math.min(sortedLatencies.length - 1, Math.floor((sortedLatencies.length - 1) * p));
134
+ return sortedLatencies[idx];
135
+ };
136
+ const mean = (xs) => (xs.length ? xs.reduce((a, b) => a + b, 0) / xs.length : 0);
137
+ const verdictDist = {
138
+ allow: { count: counts.allow, pct: total ? counts.allow / total : 0 },
139
+ warn: { count: counts.warn, pct: total ? counts.warn / total : 0 },
140
+ block: { count: counts.block, pct: total ? counts.block / total : 0 },
141
+ };
142
+ return {
143
+ source: "audit.jsonl",
144
+ total_runs: total,
145
+ since: sinceMs ? new Date(sinceMs).toISOString() : null,
146
+ until: total ? filtered[filtered.length - 1].ts : null,
147
+ verdict_distribution: verdictDist,
148
+ latency_ms: {
149
+ p50: Math.round(pct(0.5)),
150
+ p95: Math.round(pct(0.95)),
151
+ p99: Math.round(pct(0.99)),
152
+ max: sortedLatencies.length ? sortedLatencies[sortedLatencies.length - 1] : 0,
153
+ mean: Math.round(mean(latencies)),
154
+ },
155
+ truncated_count: truncated,
156
+ truncated_pct: total ? truncated / total : 0,
157
+ findings_per_run: {
158
+ mean: total ? Math.round((findingsTotal / total) * 10) / 10 : 0,
159
+ max: findingsMax,
160
+ },
161
+ top_engines: topMap(engines, topN).map(([k, v]) => ({ engine: k, count: v })),
162
+ top_rules: topMap(rules, topN).map(([k, v]) => ({ rule_id: k, count: v })),
163
+ top_files: [...fileStats.entries()]
164
+ .sort((a, b) => b[1].blocks - a[1].blocks || b[1].runs - a[1].runs)
165
+ .slice(0, topN)
166
+ .map(([file, s]) => ({ file, blocks: s.blocks, runs: s.runs })),
167
+ };
168
+ }
169
+ function topMap(m, n) {
170
+ return [...m.entries()].sort((a, b) => b[1] - a[1]).slice(0, n);
171
+ }
172
+ // ── Human-readable formatter ─────────────────────────────────────────────
173
+ export function formatHuman(s) {
174
+ const lines = [];
175
+ lines.push("Aegis-v2 stats");
176
+ lines.push("==============");
177
+ lines.push(`Source: ${s.source}`);
178
+ lines.push(`Window: ${s.since ?? "all-time"} → ${s.until ?? "(none)"}`);
179
+ lines.push(`Total runs: ${s.total_runs}`);
180
+ lines.push("");
181
+ lines.push("Verdict distribution:");
182
+ for (const v of ["allow", "warn", "block"]) {
183
+ const d = s.verdict_distribution[v];
184
+ lines.push(` ${v.padEnd(6)} ${String(d.count).padStart(6)} (${(d.pct * 100).toFixed(1)}%)`);
185
+ }
186
+ lines.push("");
187
+ lines.push("Latency (ms):");
188
+ lines.push(` p50 ${s.latency_ms.p50}`);
189
+ lines.push(` p95 ${s.latency_ms.p95}`);
190
+ lines.push(` p99 ${s.latency_ms.p99}`);
191
+ lines.push(` max ${s.latency_ms.max}`);
192
+ lines.push(` mean ${s.latency_ms.mean}`);
193
+ lines.push("");
194
+ lines.push(`Truncated (timeout): ${s.truncated_count} (${(s.truncated_pct * 100).toFixed(1)}%)`);
195
+ lines.push(`Findings per run: mean=${s.findings_per_run.mean}, max=${s.findings_per_run.max}`);
196
+ lines.push("");
197
+ if (s.top_engines.length) {
198
+ lines.push("Top driving engines:");
199
+ for (const e of s.top_engines)
200
+ lines.push(` ${e.engine.padEnd(20)} ${e.count}`);
201
+ lines.push("");
202
+ }
203
+ if (s.top_rules.length) {
204
+ lines.push("Top driving rules:");
205
+ for (const r of s.top_rules)
206
+ lines.push(` ${r.rule_id.padEnd(40)} ${r.count}`);
207
+ lines.push("");
208
+ }
209
+ if (s.top_files.length) {
210
+ lines.push("Top files (by blocks):");
211
+ for (const f of s.top_files) {
212
+ lines.push(` ${String(f.blocks).padStart(4)} blocks / ${String(f.runs).padStart(4)} runs ${f.file}`);
213
+ }
214
+ }
215
+ return lines.join("\n");
216
+ }
217
+ //# sourceMappingURL=stats.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stats.js","sourceRoot":"","sources":["../src/stats.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import type { UploadedFeedback } from "./types.js";
2
+ import type { GateReport } from "../orchestrator.js";
3
+ export declare function enqueueReport(content: string, report: GateReport): void;
4
+ export declare function enqueueFeedback(fb: UploadedFeedback): void;
5
+ export declare function flush(): Promise<void>;
6
+ export declare function stats(): {
7
+ buffered_findings: number;
8
+ buffered_feedback: number;
9
+ };
10
+ //# sourceMappingURL=collector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collector.d.ts","sourceRoot":"","sources":["../../src/telemetry/collector.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,gBAAgB,EAAmB,MAAM,YAAY,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAWrD,wBAAgB,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,GAAG,IAAI,CA0BvE;AAED,wBAAgB,eAAe,CAAC,EAAE,EAAE,gBAAgB,GAAG,IAAI,CAI1D;AAgBD,wBAAsB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAQ3C;AAED,wBAAgB,KAAK,IAAI;IAAE,iBAAiB,EAAE,MAAM,CAAC;IAAC,iBAAiB,EAAE,MAAM,CAAA;CAAE,CAEhF"}
@@ -0,0 +1,75 @@
1
+ // In-process buffer for findings + feedback. Flushes when:
2
+ // - buffer size reaches FLUSH_AT_FINDINGS
3
+ // - last-flush > FLUSH_INTERVAL_MS ago
4
+ // - explicit flush() (called on shutdown)
5
+ import { isTelemetryEnabled } from "./consent.js";
6
+ import { hashPath, redactSecrets, snippetAround, classifyFileKind } from "./sanitizer.js";
7
+ const FLUSH_AT_FINDINGS = Number(process.env.AEGIS_TELEMETRY_FLUSH_AT ?? "25");
8
+ const FLUSH_INTERVAL_MS = Number(process.env.AEGIS_TELEMETRY_FLUSH_MS ?? "60000");
9
+ const _findings = [];
10
+ const _feedback = [];
11
+ const _durations = [];
12
+ let _lastFlush = Date.now();
13
+ let _flushScheduled = false;
14
+ export function enqueueReport(content, report) {
15
+ if (!isTelemetryEnabled())
16
+ return;
17
+ const file_hash = hashPath(report.filePath);
18
+ const file_kind = classifyFileKind(report.filePath);
19
+ for (const f of report.findings) {
20
+ const finding = {
21
+ id: f.id,
22
+ engine: f.engine,
23
+ rule_id: f.rule_id,
24
+ severity: f.severity,
25
+ confidence: f.confidence,
26
+ lang: report.lang,
27
+ verdict: report.decision.action,
28
+ file_hash,
29
+ snippet: snippetAround(content, f.line ?? 1, 30),
30
+ message: redactSecrets(f.message),
31
+ file_kind,
32
+ stage: f.engine === "llm-critic" ? 2 : 1,
33
+ ...(f.cwe !== undefined ? { cwe: f.cwe } : {}),
34
+ ...(f.line !== undefined ? { line: 31 } : {}),
35
+ ...(f.remediation !== undefined ? { remediation: redactSecrets(f.remediation) } : {}),
36
+ };
37
+ _findings.push(finding);
38
+ }
39
+ _durations.push(report.durationMs);
40
+ _maybeFlush();
41
+ }
42
+ export function enqueueFeedback(fb) {
43
+ if (!isTelemetryEnabled())
44
+ return;
45
+ _feedback.push(fb);
46
+ _maybeFlush();
47
+ }
48
+ function _maybeFlush() {
49
+ if (_findings.length >= FLUSH_AT_FINDINGS) {
50
+ void flush();
51
+ return;
52
+ }
53
+ if (_flushScheduled)
54
+ return;
55
+ const due = Math.max(0, FLUSH_INTERVAL_MS - (Date.now() - _lastFlush));
56
+ _flushScheduled = true;
57
+ setTimeout(() => {
58
+ _flushScheduled = false;
59
+ void flush();
60
+ }, due).unref();
61
+ }
62
+ export async function flush() {
63
+ if (_findings.length === 0 && _feedback.length === 0)
64
+ return;
65
+ const { uploadBatch } = await import("./uploader.js");
66
+ const drained_findings = _findings.splice(0);
67
+ const drained_feedback = _feedback.splice(0);
68
+ const drained_durations = _durations.splice(0);
69
+ _lastFlush = Date.now();
70
+ await uploadBatch(drained_findings, drained_feedback, drained_durations);
71
+ }
72
+ export function stats() {
73
+ return { buffered_findings: _findings.length, buffered_feedback: _feedback.length };
74
+ }
75
+ //# sourceMappingURL=collector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collector.js","sourceRoot":"","sources":["../../src/telemetry/collector.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ export interface ConsentState {
2
+ enabled: boolean | null;
3
+ consented_at?: string;
4
+ source?: "first_run_prompt" | "cli" | "env_var";
5
+ }
6
+ export declare function readConsent(): ConsentState;
7
+ export declare function writeConsent(enabled: boolean, source?: ConsentState["source"]): void;
8
+ export declare function isTelemetryEnabled(): boolean;
9
+ //# sourceMappingURL=consent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consent.d.ts","sourceRoot":"","sources":["../../src/telemetry/consent.ts"],"names":[],"mappings":"AASA,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,MAAM,CAAC,EAAE,kBAAkB,GAAG,KAAK,GAAG,SAAS,CAAC;CACjD;AAED,wBAAgB,WAAW,IAAI,YAAY,CAe1C;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,GAAE,YAAY,CAAC,QAAQ,CAAS,GAAG,IAAI,CAQ3F;AAED,wBAAgB,kBAAkB,IAAI,OAAO,CAM5C"}
@@ -0,0 +1,42 @@
1
+ // Telemetry on/off state, persisted to ~/.aegis/telemetry.json.
2
+ // Default: not-yet-decided (null). First-run prompt sets it.
3
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
4
+ import { homedir } from "node:os";
5
+ import { resolve } from "node:path";
6
+ const AEGIS_HOME = process.env.AEGIS_HOME ?? resolve(homedir(), ".aegis");
7
+ const CONSENT_FILE = resolve(AEGIS_HOME, "telemetry.json");
8
+ export function readConsent() {
9
+ // Env override wins (CI / corporate disable).
10
+ const env = process.env.AEGIS_TELEMETRY;
11
+ if (env === "off" || env === "false" || env === "0") {
12
+ return { enabled: false, source: "env_var" };
13
+ }
14
+ if (env === "on" || env === "true" || env === "1") {
15
+ return { enabled: true, source: "env_var" };
16
+ }
17
+ if (!existsSync(CONSENT_FILE))
18
+ return { enabled: null };
19
+ try {
20
+ return JSON.parse(readFileSync(CONSENT_FILE, "utf8"));
21
+ }
22
+ catch {
23
+ return { enabled: null };
24
+ }
25
+ }
26
+ export function writeConsent(enabled, source = "cli") {
27
+ mkdirSync(AEGIS_HOME, { recursive: true });
28
+ const state = {
29
+ enabled,
30
+ consented_at: new Date().toISOString(),
31
+ source,
32
+ };
33
+ writeFileSync(CONSENT_FILE, JSON.stringify(state, null, 2), "utf8");
34
+ }
35
+ export function isTelemetryEnabled() {
36
+ const s = readConsent();
37
+ // Default ON when never asked AND not explicitly disabled — per product
38
+ // decision; the first-run prompt in the hook flips this to a recorded ON
39
+ // (with source=first_run_prompt) on the first invocation.
40
+ return s.enabled !== false;
41
+ }
42
+ //# sourceMappingURL=consent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consent.js","sourceRoot":"","sources":["../../src/telemetry/consent.ts"],"names":[],"mappings":"AAAA,gEAAgE;AAChE,6DAA6D;AAC7D,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,OAAO,CAAC,OAAO,EAAE,EAAE,QAAQ,CAAC,CAAC;AAC1E,MAAM,YAAY,GAAG,OAAO,CAAC,UAAU,EAAE,gBAAgB,CAAC,CAAC;AAQ3D,MAAM,UAAU,WAAW;IACzB,8CAA8C;IAC9C,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC;IACxC,IAAI,GAAG,KAAK,KAAK,IAAI,GAAG,KAAK,OAAO,IAAI,GAAG,KAAK,GAAG,EAAE,CAAC;QACpD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;IAC/C,CAAC;IACD,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,MAAM,IAAI,GAAG,KAAK,GAAG,EAAE,CAAC;QAClD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;IAC9C,CAAC;IACD,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC;QAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IACxD,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,YAAY,EAAE,MAAM,CAAC,CAAiB,CAAC;IACxE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,OAAgB,EAAE,SAAiC,KAAK;IACnF,SAAS,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3C,MAAM,KAAK,GAAiB;QAC1B,OAAO;QACP,YAAY,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACtC,MAAM;KACP,CAAC;IACF,aAAa,CAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;AACtE,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,MAAM,CAAC,GAAG,WAAW,EAAE,CAAC;IACxB,wEAAwE;IACxE,yEAAyE;IACzE,0DAA0D;IAC1D,OAAO,CAAC,CAAC,OAAO,KAAK,KAAK,CAAC;AAC7B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function getInstallationId(): string;
2
+ //# sourceMappingURL=installation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"installation.d.ts","sourceRoot":"","sources":["../../src/telemetry/installation.ts"],"names":[],"mappings":"AAeA,wBAAgB,iBAAiB,IAAI,MAAM,CAU1C"}
@@ -0,0 +1,32 @@
1
+ // Generate + persist a per-installation UUID. Anonymous by default.
2
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
3
+ import { homedir } from "node:os";
4
+ import { resolve } from "node:path";
5
+ import { randomUUID } from "node:crypto";
6
+ const AEGIS_HOME = process.env.AEGIS_HOME ?? resolve(homedir(), ".aegis");
7
+ const INSTALLATION_FILE = resolve(AEGIS_HOME, "installation.json");
8
+ export function getInstallationId() {
9
+ if (existsSync(INSTALLATION_FILE)) {
10
+ try {
11
+ const s = JSON.parse(readFileSync(INSTALLATION_FILE, "utf8"));
12
+ if (s.id && /^[0-9a-f-]{36}$/i.test(s.id))
13
+ return s.id;
14
+ }
15
+ catch {
16
+ // fall through to regenerate
17
+ }
18
+ }
19
+ return _create();
20
+ }
21
+ function _create() {
22
+ const id = randomUUID();
23
+ try {
24
+ mkdirSync(AEGIS_HOME, { recursive: true });
25
+ writeFileSync(INSTALLATION_FILE, JSON.stringify({ id, created_at: new Date().toISOString() }, null, 2), "utf8");
26
+ }
27
+ catch {
28
+ // best-effort; in-memory id still returned
29
+ }
30
+ return id;
31
+ }
32
+ //# sourceMappingURL=installation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"installation.js","sourceRoot":"","sources":["../../src/telemetry/installation.ts"],"names":[],"mappings":"AAAA,oEAAoE;AACpE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,OAAO,CAAC,OAAO,EAAE,EAAE,QAAQ,CAAC,CAAC;AAC1E,MAAM,iBAAiB,GAAG,OAAO,CAAC,UAAU,EAAE,mBAAmB,CAAC,CAAC;AAQnE,MAAM,UAAU,iBAAiB;IAC/B,IAAI,UAAU,CAAC,iBAAiB,CAAC,EAAE,CAAC;QAClC,IAAI,CAAC;YACH,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAsB,CAAC;YACnF,IAAI,CAAC,CAAC,EAAE,IAAI,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;gBAAE,OAAO,CAAC,CAAC,EAAE,CAAC;QACzD,CAAC;QAAC,MAAM,CAAC;YACP,6BAA6B;QAC/B,CAAC;IACH,CAAC;IACD,OAAO,OAAO,EAAE,CAAC;AACnB,CAAC;AAED,SAAS,OAAO;IACd,MAAM,EAAE,GAAG,UAAU,EAAE,CAAC;IACxB,IAAI,CAAC;QACH,SAAS,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC3C,aAAa,CACX,iBAAiB,EACjB,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,EACrE,MAAM,CACP,CAAC;IACJ,CAAC;IAAC,MAAM,CAAC;QACP,2CAA2C;IAC7C,CAAC;IACD,OAAO,EAAE,CAAC;AACZ,CAAC"}
@@ -0,0 +1,5 @@
1
+ export declare function redactSecrets(text: string): string;
2
+ export declare function hashPath(absPath: string): string;
3
+ export declare function snippetAround(content: string, targetLine: number, window?: number): string;
4
+ export declare function classifyFileKind(absPath: string): string;
5
+ //# sourceMappingURL=sanitizer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sanitizer.d.ts","sourceRoot":"","sources":["../../src/telemetry/sanitizer.ts"],"names":[],"mappings":"AAwBA,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAUlD;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAEhD;AAED,wBAAgB,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,SAAK,GAAG,MAAM,CAKtF;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CASxD"}
@@ -0,0 +1,60 @@
1
+ // Strip secrets + PII before uploading to the flywheel API.
2
+ // Conservative — when in doubt, redact. The server-side sanitizer ALSO
3
+ // scans and will REJECT a batch with unredacted secrets.
4
+ import { createHash } from "node:crypto";
5
+ const SECRET_PATTERNS = [
6
+ /\bghp_[A-Za-z0-9]{36,255}\b/g,
7
+ /\bgho_[A-Za-z0-9]{36,255}\b/g,
8
+ /\bghu_[A-Za-z0-9]{36,255}\b/g,
9
+ /\bAKIA[A-Z0-9]{16}\b/g,
10
+ /\bsk-(?:proj-|ant-|live-)?[A-Za-z0-9_-]{30,}\b/g,
11
+ /\bsk-ant-(?:api03-)?[A-Za-z0-9_-]{30,}\b/g,
12
+ /\bAIza[A-Za-z0-9_-]{30,}\b/g,
13
+ /\bxox[abprs]-[A-Za-z0-9-]{10,}\b/g,
14
+ /\bsk_(?:live|test)_[A-Za-z0-9]{24,}\b/g,
15
+ /\bSK[a-f0-9]{32}\b/g,
16
+ /-----BEGIN (?:RSA |EC |DSA |OPENSSH |PGP )?PRIVATE KEY-----[\s\S]*?-----END/g,
17
+ /\beyJ[A-Za-z0-9_-]{10,}\.[A-Za-z0-9_-]{10,}\.[A-Za-z0-9_-]{10,}\b/g,
18
+ ];
19
+ const EMAIL = /\b[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}\b/g;
20
+ const PHONE = /\b\+?\d{1,3}[-.\s]?\(?\d{2,4}\)?[-.\s]?\d{3,4}[-.\s]?\d{4}\b/g;
21
+ const IPV4 = /\b(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\b/g;
22
+ export function redactSecrets(text) {
23
+ let out = text;
24
+ for (const re of SECRET_PATTERNS)
25
+ out = out.replace(re, "<REDACTED_SECRET>");
26
+ out = out.replace(EMAIL, "<email>");
27
+ out = out.replace(PHONE, "<phone>");
28
+ out = out.replace(IPV4, (ip) => {
29
+ if (/^(?:10|127|192\.168|172\.(?:1[6-9]|2\d|3[01]))\./.test(ip))
30
+ return "<private_ip>";
31
+ return ip;
32
+ });
33
+ return out;
34
+ }
35
+ export function hashPath(absPath) {
36
+ return createHash("sha256").update(absPath).digest("hex").slice(0, 16);
37
+ }
38
+ export function snippetAround(content, targetLine, window = 30) {
39
+ const lines = content.split(/\r?\n/);
40
+ const start = Math.max(0, targetLine - 1 - window);
41
+ const end = Math.min(lines.length, targetLine + window);
42
+ return redactSecrets(lines.slice(start, end).join("\n"));
43
+ }
44
+ export function classifyFileKind(absPath) {
45
+ const p = absPath.replace(/\\/g, "/").toLowerCase();
46
+ if (/\/tests?\/|\/__tests__\/|\.test\.|\.spec\./.test(p))
47
+ return "test";
48
+ if (/\/routes?\/|\/handlers?\/|\/controllers?\/|\/views?\//.test(p))
49
+ return "route";
50
+ if (/\/models?\/|\/entities?\/|\/schemas?\//.test(p))
51
+ return "model";
52
+ if (/\/(?:settings|config|configs)\.|\.config\.|\.env/.test(p))
53
+ return "config";
54
+ if (/\/migrations?\/|\.sql$/.test(p))
55
+ return "migration";
56
+ if (/\/utils?\/|\/helpers?\/|\/lib\//.test(p))
57
+ return "util";
58
+ return "generic";
59
+ }
60
+ //# sourceMappingURL=sanitizer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sanitizer.js","sourceRoot":"","sources":["../../src/telemetry/sanitizer.ts"],"names":[],"mappings":"AAAA,4DAA4D;AAC5D,uEAAuE;AACvE,yDAAyD;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,MAAM,eAAe,GAAa;IAChC,8BAA8B;IAC9B,8BAA8B;IAC9B,8BAA8B;IAC9B,uBAAuB;IACvB,iDAAiD;IACjD,2CAA2C;IAC3C,6BAA6B;IAC7B,mCAAmC;IACnC,wCAAwC;IACxC,qBAAqB;IACrB,8EAA8E;IAC9E,oEAAoE;CACrE,CAAC;AAEF,MAAM,KAAK,GAAG,qDAAqD,CAAC;AACpE,MAAM,KAAK,GAAG,+DAA+D,CAAC;AAC9E,MAAM,IAAI,GAAG,8EAA8E,CAAC;AAE5F,MAAM,UAAU,aAAa,CAAC,IAAY;IACxC,IAAI,GAAG,GAAG,IAAI,CAAC;IACf,KAAK,MAAM,EAAE,IAAI,eAAe;QAAE,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,mBAAmB,CAAC,CAAC;IAC7E,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACpC,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACpC,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,EAAE;QAC7B,IAAI,kDAAkD,CAAC,IAAI,CAAC,EAAE,CAAC;YAAE,OAAO,cAAc,CAAC;QACvF,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;IACH,OAAO,GAAG,CAAC;AACb,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,OAAe;IACtC,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AACzE,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,OAAe,EAAE,UAAkB,EAAE,MAAM,GAAG,EAAE;IAC5E,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IACrC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;IACnD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,UAAU,GAAG,MAAM,CAAC,CAAC;IACxD,OAAO,aAAa,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,OAAe;IAC9C,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;IACpD,IAAI,4CAA4C,CAAC,IAAI,CAAC,CAAC,CAAC;QAAE,OAAO,MAAM,CAAC;IACxE,IAAI,uDAAuD,CAAC,IAAI,CAAC,CAAC,CAAC;QAAE,OAAO,OAAO,CAAC;IACpF,IAAI,wCAAwC,CAAC,IAAI,CAAC,CAAC,CAAC;QAAE,OAAO,OAAO,CAAC;IACrE,IAAI,kDAAkD,CAAC,IAAI,CAAC,CAAC,CAAC;QAAE,OAAO,QAAQ,CAAC;IAChF,IAAI,wBAAwB,CAAC,IAAI,CAAC,CAAC,CAAC;QAAE,OAAO,WAAW,CAAC;IACzD,IAAI,iCAAiC,CAAC,IAAI,CAAC,CAAC,CAAC;QAAE,OAAO,MAAM,CAAC;IAC7D,OAAO,SAAS,CAAC;AACnB,CAAC"}
@@ -0,0 +1,39 @@
1
+ export declare const SCHEMA_VERSION = "1.0.0";
2
+ export interface UploadedFinding {
3
+ id: string;
4
+ engine: string;
5
+ rule_id: string;
6
+ cwe?: string;
7
+ severity: "info" | "low" | "medium" | "high" | "critical";
8
+ confidence: number;
9
+ lang: string;
10
+ verdict: "allow" | "warn" | "block";
11
+ file_hash: string;
12
+ line?: number;
13
+ snippet: string;
14
+ message: string;
15
+ remediation?: string;
16
+ file_kind?: string;
17
+ stage?: 1 | 2;
18
+ }
19
+ export interface UploadedFeedback {
20
+ finding_id: string;
21
+ signal: "agree" | "dismiss" | "fixed" | "false_positive";
22
+ reason?: string;
23
+ }
24
+ export interface UploadBatch {
25
+ schema_version: string;
26
+ installation_id: string;
27
+ client_version: string;
28
+ platform: string;
29
+ sent_at: number;
30
+ findings: UploadedFinding[];
31
+ feedback?: UploadedFeedback[];
32
+ stats?: {
33
+ durations_ms: number[];
34
+ lang_counts: Record<string, number>;
35
+ engine_counts: Record<string, number>;
36
+ verdict_counts: Record<string, number>;
37
+ };
38
+ }
39
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/telemetry/types.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,cAAc,UAAU,CAAC;AAEtC,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;IAC1D,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;IACpC,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;CACf;AAED,MAAM,WAAW,gBAAgB;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,OAAO,GAAG,SAAS,GAAG,OAAO,GAAG,gBAAgB,CAAC;IACzD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,WAAW;IAC1B,cAAc,EAAE,MAAM,CAAC;IACvB,eAAe,EAAE,MAAM,CAAC;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,eAAe,EAAE,CAAC;IAC5B,QAAQ,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC9B,KAAK,CAAC,EAAE;QACN,YAAY,EAAE,MAAM,EAAE,CAAC;QACvB,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACpC,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACtC,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACxC,CAAC;CACH"}
@@ -0,0 +1,4 @@
1
+ // Mirror of aegis-cloud/src/types.ts — keep in sync, bump SCHEMA_VERSION on
2
+ // any breaking change.
3
+ export const SCHEMA_VERSION = "1.0.0";
4
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/telemetry/types.ts"],"names":[],"mappings":"AAAA,4EAA4E;AAC5E,uBAAuB;AAEvB,MAAM,CAAC,MAAM,cAAc,GAAG,OAAO,CAAC"}
@@ -0,0 +1,12 @@
1
+ import type { UploadedFeedback, UploadedFinding } from "./types.js";
2
+ export declare function uploadBatch(findings: UploadedFinding[], feedback: UploadedFeedback[], durations: number[]): Promise<{
3
+ ok: boolean;
4
+ reason?: string;
5
+ }>;
6
+ export declare function postOptOut(reason?: string): Promise<{
7
+ ok: boolean;
8
+ }>;
9
+ export declare function deleteAllData(): Promise<{
10
+ ok: boolean;
11
+ }>;
12
+ //# sourceMappingURL=uploader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"uploader.d.ts","sourceRoot":"","sources":["../../src/telemetry/uploader.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAe,gBAAgB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAMjF,wBAAsB,WAAW,CAC/B,QAAQ,EAAE,eAAe,EAAE,EAC3B,QAAQ,EAAE,gBAAgB,EAAE,EAC5B,SAAS,EAAE,MAAM,EAAE,GAClB,OAAO,CAAC;IAAE,EAAE,EAAE,OAAO,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CA6C3C;AAYD,wBAAsB,UAAU,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAAE,EAAE,EAAE,OAAO,CAAA;CAAE,CAAC,CAW1E;AAED,wBAAsB,aAAa,IAAI,OAAO,CAAC;IAAE,EAAE,EAAE,OAAO,CAAA;CAAE,CAAC,CAU9D"}