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.
- package/.claude/settings.example.json +30 -0
- package/ARCHITECTURE.md +410 -0
- package/LICENSE +21 -0
- package/README.md +153 -0
- package/ROADMAP.md +117 -0
- package/data/vulnkb.json +666 -0
- package/dist/bin/aegis.d.ts +3 -0
- package/dist/bin/aegis.d.ts.map +1 -0
- package/dist/bin/aegis.js +489 -0
- package/dist/bin/aegis.js.map +1 -0
- package/dist/cache.d.ts +9 -0
- package/dist/cache.d.ts.map +1 -0
- package/dist/cache.js +146 -0
- package/dist/cache.js.map +1 -0
- package/dist/engines/ai-sinks.d.ts +52 -0
- package/dist/engines/ai-sinks.d.ts.map +1 -0
- package/dist/engines/ai-sinks.js +204 -0
- package/dist/engines/ai-sinks.js.map +1 -0
- package/dist/engines/eslint.d.ts +9 -0
- package/dist/engines/eslint.d.ts.map +1 -0
- package/dist/engines/eslint.js +245 -0
- package/dist/engines/eslint.js.map +1 -0
- package/dist/engines/joern.d.ts +3 -0
- package/dist/engines/joern.d.ts.map +1 -0
- package/dist/engines/joern.js +98 -0
- package/dist/engines/joern.js.map +1 -0
- package/dist/engines/js-sinks.d.ts +70 -0
- package/dist/engines/js-sinks.d.ts.map +1 -0
- package/dist/engines/js-sinks.js +370 -0
- package/dist/engines/js-sinks.js.map +1 -0
- package/dist/engines/llm-critic.d.ts +130 -0
- package/dist/engines/llm-critic.d.ts.map +1 -0
- package/dist/engines/llm-critic.js +551 -0
- package/dist/engines/llm-critic.js.map +1 -0
- package/dist/engines/pragma.d.ts +20 -0
- package/dist/engines/pragma.d.ts.map +1 -0
- package/dist/engines/pragma.js +83 -0
- package/dist/engines/pragma.js.map +1 -0
- package/dist/engines/property-test.d.ts +3 -0
- package/dist/engines/property-test.d.ts.map +1 -0
- package/dist/engines/property-test.js +134 -0
- package/dist/engines/property-test.js.map +1 -0
- package/dist/engines/pyright.d.ts +10 -0
- package/dist/engines/pyright.d.ts.map +1 -0
- package/dist/engines/pyright.js +143 -0
- package/dist/engines/pyright.js.map +1 -0
- package/dist/engines/pysa.d.ts +3 -0
- package/dist/engines/pysa.d.ts.map +1 -0
- package/dist/engines/pysa.js +83 -0
- package/dist/engines/pysa.js.map +1 -0
- package/dist/engines/python-sinks.d.ts +82 -0
- package/dist/engines/python-sinks.d.ts.map +1 -0
- package/dist/engines/python-sinks.js +459 -0
- package/dist/engines/python-sinks.js.map +1 -0
- package/dist/engines/registry.d.ts +26 -0
- package/dist/engines/registry.d.ts.map +1 -0
- package/dist/engines/registry.js +70 -0
- package/dist/engines/registry.js.map +1 -0
- package/dist/engines/secret-scan.d.ts +22 -0
- package/dist/engines/secret-scan.d.ts.map +1 -0
- package/dist/engines/secret-scan.js +179 -0
- package/dist/engines/secret-scan.js.map +1 -0
- package/dist/engines/semgrep.d.ts +10 -0
- package/dist/engines/semgrep.d.ts.map +1 -0
- package/dist/engines/semgrep.js +200 -0
- package/dist/engines/semgrep.js.map +1 -0
- package/dist/engines/treesitter.d.ts +18 -0
- package/dist/engines/treesitter.d.ts.map +1 -0
- package/dist/engines/treesitter.js +135 -0
- package/dist/engines/treesitter.js.map +1 -0
- package/dist/engines/tsc.d.ts +10 -0
- package/dist/engines/tsc.d.ts.map +1 -0
- package/dist/engines/tsc.js +142 -0
- package/dist/engines/tsc.js.map +1 -0
- package/dist/engines/types.d.ts +47 -0
- package/dist/engines/types.d.ts.map +1 -0
- package/dist/engines/types.js +27 -0
- package/dist/engines/types.js.map +1 -0
- package/dist/findings.d.ts +121 -0
- package/dist/findings.d.ts.map +1 -0
- package/dist/findings.js +98 -0
- package/dist/findings.js.map +1 -0
- package/dist/hooks/claude-code.d.ts +3 -0
- package/dist/hooks/claude-code.d.ts.map +1 -0
- package/dist/hooks/claude-code.js +187 -0
- package/dist/hooks/claude-code.js.map +1 -0
- package/dist/index/context.d.ts +127 -0
- package/dist/index/context.d.ts.map +1 -0
- package/dist/index/context.js +267 -0
- package/dist/index/context.js.map +1 -0
- package/dist/index/embeddings.d.ts +68 -0
- package/dist/index/embeddings.d.ts.map +1 -0
- package/dist/index/embeddings.js +570 -0
- package/dist/index/embeddings.js.map +1 -0
- package/dist/index/graph_routing.d.ts +36 -0
- package/dist/index/graph_routing.d.ts.map +1 -0
- package/dist/index/graph_routing.js +170 -0
- package/dist/index/graph_routing.js.map +1 -0
- package/dist/index/joern.d.ts +76 -0
- package/dist/index/joern.d.ts.map +1 -0
- package/dist/index/joern.js +782 -0
- package/dist/index/joern.js.map +1 -0
- package/dist/index/property-test.d.ts +88 -0
- package/dist/index/property-test.d.ts.map +1 -0
- package/dist/index/property-test.js +466 -0
- package/dist/index/property-test.js.map +1 -0
- package/dist/index/proto/scip.proto +897 -0
- package/dist/index/pysa.d.ts +91 -0
- package/dist/index/pysa.d.ts.map +1 -0
- package/dist/index/pysa.js +617 -0
- package/dist/index/pysa.js.map +1 -0
- package/dist/index/scip.d.ts +76 -0
- package/dist/index/scip.d.ts.map +1 -0
- package/dist/index/scip.js +541 -0
- package/dist/index/scip.js.map +1 -0
- package/dist/index/vulrag.d.ts +86 -0
- package/dist/index/vulrag.d.ts.map +1 -0
- package/dist/index/vulrag.js +242 -0
- package/dist/index/vulrag.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/install/claude-code.d.ts +31 -0
- package/dist/install/claude-code.d.ts.map +1 -0
- package/dist/install/claude-code.js +447 -0
- package/dist/install/claude-code.js.map +1 -0
- package/dist/lang.d.ts +5 -0
- package/dist/lang.d.ts.map +1 -0
- package/dist/lang.js +52 -0
- package/dist/lang.js.map +1 -0
- package/dist/learning/suppressions.d.ts +70 -0
- package/dist/learning/suppressions.d.ts.map +1 -0
- package/dist/learning/suppressions.js +179 -0
- package/dist/learning/suppressions.js.map +1 -0
- package/dist/mcp/server.d.ts +2 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +187 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/explain.d.ts +58 -0
- package/dist/mcp/tools/explain.d.ts.map +1 -0
- package/dist/mcp/tools/explain.js +60 -0
- package/dist/mcp/tools/explain.js.map +1 -0
- package/dist/mcp/tools/precheck.d.ts +29 -0
- package/dist/mcp/tools/precheck.d.ts.map +1 -0
- package/dist/mcp/tools/precheck.js +42 -0
- package/dist/mcp/tools/precheck.js.map +1 -0
- package/dist/mcp/tools/validate.d.ts +73 -0
- package/dist/mcp/tools/validate.d.ts.map +1 -0
- package/dist/mcp/tools/validate.js +66 -0
- package/dist/mcp/tools/validate.js.map +1 -0
- package/dist/mcp/warm.d.ts +88 -0
- package/dist/mcp/warm.d.ts.map +1 -0
- package/dist/mcp/warm.js +331 -0
- package/dist/mcp/warm.js.map +1 -0
- package/dist/orchestrator.d.ts +46 -0
- package/dist/orchestrator.d.ts.map +1 -0
- package/dist/orchestrator.js +596 -0
- package/dist/orchestrator.js.map +1 -0
- package/dist/policy.d.ts +51 -0
- package/dist/policy.d.ts.map +1 -0
- package/dist/policy.js +201 -0
- package/dist/policy.js.map +1 -0
- package/dist/risk.d.ts +31 -0
- package/dist/risk.d.ts.map +1 -0
- package/dist/risk.js +92 -0
- package/dist/risk.js.map +1 -0
- package/dist/stats.d.ts +72 -0
- package/dist/stats.d.ts.map +1 -0
- package/dist/stats.js +217 -0
- package/dist/stats.js.map +1 -0
- package/dist/telemetry/collector.d.ts +10 -0
- package/dist/telemetry/collector.d.ts.map +1 -0
- package/dist/telemetry/collector.js +75 -0
- package/dist/telemetry/collector.js.map +1 -0
- package/dist/telemetry/consent.d.ts +9 -0
- package/dist/telemetry/consent.d.ts.map +1 -0
- package/dist/telemetry/consent.js +42 -0
- package/dist/telemetry/consent.js.map +1 -0
- package/dist/telemetry/installation.d.ts +2 -0
- package/dist/telemetry/installation.d.ts.map +1 -0
- package/dist/telemetry/installation.js +32 -0
- package/dist/telemetry/installation.js.map +1 -0
- package/dist/telemetry/sanitizer.d.ts +5 -0
- package/dist/telemetry/sanitizer.d.ts.map +1 -0
- package/dist/telemetry/sanitizer.js +60 -0
- package/dist/telemetry/sanitizer.js.map +1 -0
- package/dist/telemetry/types.d.ts +39 -0
- package/dist/telemetry/types.d.ts.map +1 -0
- package/dist/telemetry/types.js +4 -0
- package/dist/telemetry/types.js.map +1 -0
- package/dist/telemetry/uploader.d.ts +12 -0
- package/dist/telemetry/uploader.d.ts.map +1 -0
- package/dist/telemetry/uploader.js +92 -0
- package/dist/telemetry/uploader.js.map +1 -0
- package/dist/util/logger.d.ts +19 -0
- package/dist/util/logger.d.ts.map +1 -0
- package/dist/util/logger.js +58 -0
- package/dist/util/logger.js.map +1 -0
- package/dist/util/safe-paths.d.ts +8 -0
- package/dist/util/safe-paths.d.ts.map +1 -0
- package/dist/util/safe-paths.js +102 -0
- package/dist/util/safe-paths.js.map +1 -0
- package/dist/util/subprocess.d.ts +32 -0
- package/dist/util/subprocess.d.ts.map +1 -0
- package/dist/util/subprocess.js +137 -0
- package/dist/util/subprocess.js.map +1 -0
- 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":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,MAAM,GAAG,GAAG,SAAS,CAAC,aAAa,CAAC,CAAC;AA0CrC,6EAA6E;AAE7E,MAAM,UAAU,SAAS,CAAC,WAAmB;IAC3C,OAAO,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;AACpD,CAAC;AAED,yEAAyE;AACzE,MAAM,UAAU,aAAa,CAAC,WAAmB;IAC/C,MAAM,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;IACjC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAAE,OAAO,EAAE,CAAC;IAC9B,IAAI,GAAW,CAAC;IAChB,IAAI,CAAC;QACH,GAAG,GAAG,YAAY,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IAChC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,GAAG,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACpE,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,MAAM,GAAG,GAAe,EAAE,CAAC;IAC3B,KAAK,MAAM,IAAI,IAAI,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,OAAO;YAAE,SAAS;QACvB,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAA4B,CAAC;YAC3D,IACE,OAAO,GAAG,CAAC,EAAE,KAAK,QAAQ;gBAC1B,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;gBAC5B,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ;gBAC9B,CAAC,GAAG,CAAC,MAAM,KAAK,OAAO,IAAI,GAAG,CAAC,MAAM,KAAK,MAAM,IAAI,GAAG,CAAC,MAAM,KAAK,OAAO,CAAC;gBAC3E,OAAO,GAAG,CAAC,WAAW,KAAK,QAAQ,EACnC,CAAC;gBACD,GAAG,CAAC,IAAI,CAAC,GAA0B,CAAC,CAAC;YACvC,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,OAAO;QACT,CAAC;IACH,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAED,6EAA6E;AAE7E;;8DAE8D;AAC9D,MAAM,UAAU,UAAU,CAAC,KAAgC;IACzD,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IACxB,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;IAC7B,MAAM,GAAG,GAAG,OAAO,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;IAChD,IAAI,GAAG,EAAE,CAAC;QACR,MAAM,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,IAAI,GAAG,GAAG,CAAC,CAAC,CAAE,CAAC,WAAW,EAAE,CAAC;QACnC,MAAM,EAAE,GAAG,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC;QACzE,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,CAAC;IAC7B,CAAC;IACD,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAC9B,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;QAAE,OAAO,CAAC,CAAC;IACjC,OAAO,IAAI,CAAC;AACd,CAAC;AASD,MAAM,UAAU,YAAY,CAAC,IAAgB,EAAE,IAAkB;IAC/D,MAAM,OAAO,GAAG,IAAI,EAAE,OAAO,IAAI,IAAI,CAAC;IACtC,MAAM,IAAI,GAAG,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;IAE9B,mBAAmB;IACnB,MAAM,QAAQ,GAAG,OAAO,KAAK,IAAI;QAC/B,CAAC,CAAC,IAAI;QACN,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;YAChB,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC3B,OAAO,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC;QAC5C,CAAC,CAAC,CAAC;IAEP,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC;IAC9B,MAAM,MAAM,GAA4B,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;IACxE,MAAM,SAAS,GAAa,EAAE,CAAC;IAC/B,MAAM,OAAO,GAAG,IAAI,GAAG,EAAkB,CAAC;IAC1C,MAAM,KAAK,GAAG,IAAI,GAAG,EAAkB,CAAC;IACxC,MAAM,SAAS,GAAG,IAAI,GAAG,EAA4C,CAAC;IACtE,IAAI,SAAS,GAAG,CAAC,CAAC;IAClB,IAAI,aAAa,GAAG,CAAC,CAAC;IACtB,IAAI,WAAW,GAAG,CAAC,CAAC;IAEpB,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;QACzB,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;QACnB,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC;YAAE,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;QAClE,IAAI,CAAC,CAAC,SAAS;YAAE,SAAS,EAAE,CAAC;QAC7B,MAAM,EAAE,GAAG,CAAC,CAAC,UAAU,IAAI,CAAC,CAAC;QAC7B,aAAa,IAAI,EAAE,CAAC;QACpB,IAAI,EAAE,GAAG,WAAW;YAAE,WAAW,GAAG,EAAE,CAAC;QAEvC,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC;YACtB,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC1E,CAAC;QACD,IAAI,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YACvB,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACxE,CAAC;QACD,MAAM,EAAE,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;QAC3D,EAAE,CAAC,IAAI,EAAE,CAAC;QACV,IAAI,CAAC,CAAC,MAAM,KAAK,OAAO;YAAE,EAAE,CAAC,MAAM,EAAE,CAAC;QACtC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,MAAM,eAAe,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC7D,MAAM,GAAG,GAAG,CAAC,CAAS,EAAU,EAAE;QAChC,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,CAAC,CAAC;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAClB,eAAe,CAAC,MAAM,GAAG,CAAC,EAC1B,IAAI,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAC7C,CAAC;QACF,OAAO,eAAe,CAAC,GAAG,CAAE,CAAC;IAC/B,CAAC,CAAC;IACF,MAAM,IAAI,GAAG,CAAC,EAAY,EAAU,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEnG,MAAM,WAAW,GAAoD;QACnE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;QACrE,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;QAClE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;KACtE,CAAC;IAEF,OAAO;QACL,MAAM,EAAE,aAAa;QACrB,UAAU,EAAE,KAAK;QACjB,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI;QACvD,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAE,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI;QACvD,oBAAoB,EAAE,WAAW;QACjC,UAAU,EAAE;YACV,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACzB,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC1B,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC1B,GAAG,EAAE,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAE,CAAC,CAAC,CAAC,CAAC;YAC9E,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAClC;QACD,eAAe,EAAE,SAAS;QAC1B,aAAa,EAAE,KAAK,CAAC,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5C,gBAAgB,EAAE;YAChB,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,aAAa,GAAG,KAAK,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;YAC/D,GAAG,EAAE,WAAW;SACjB;QACD,WAAW,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QAC7E,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QAC1E,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC,OAAO,EAAE,CAAC;aAChC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;aAClE,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC;aACd,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;KAClE,CAAC;AACJ,CAAC;AAED,SAAS,MAAM,CAAC,CAAsB,EAAE,CAAS;IAC/C,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAClE,CAAC;AAED,4EAA4E;AAE5E,MAAM,UAAU,WAAW,CAAC,CAAc;IACxC,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC7B,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC7B,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;IAClC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,KAAK,IAAI,UAAU,MAAM,CAAC,CAAC,KAAK,IAAI,QAAQ,EAAE,CAAC,CAAC;IACxE,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC;IAC1C,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;IACpC,KAAK,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAU,EAAE,CAAC;QACpD,MAAM,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC;QACpC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACjG,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC5B,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;IACzC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;IACzC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;IACzC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;IACzC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1C,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,eAAe,KAAK,CAAC,CAAC,CAAC,aAAa,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACjG,KAAK,CAAC,IAAI,CACR,0BAA0B,CAAC,CAAC,gBAAgB,CAAC,IAAI,SAAS,CAAC,CAAC,gBAAgB,CAAC,GAAG,EAAE,CACnF,CAAC;IACF,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,IAAI,CAAC,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QACzB,KAAK,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACnC,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC,WAAW;YAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QACjF,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACjB,CAAC;IACD,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;QACvB,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACjC,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS;YAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAChF,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACjB,CAAC;IACD,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;QACvB,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;QACrC,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,CAAC;YAC5B,KAAK,CAAC,IAAI,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QACzG,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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"}
|