guardrail-cli 1.0.5 → 2.0.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/README.md +483 -10
- package/dist/commands/baseline.d.ts +7 -0
- package/dist/commands/baseline.d.ts.map +1 -0
- package/dist/commands/baseline.js +79 -0
- package/dist/commands/baseline.js.map +1 -0
- package/dist/commands/cache.d.ts +13 -0
- package/dist/commands/cache.d.ts.map +1 -0
- package/dist/commands/cache.js +165 -0
- package/dist/commands/cache.js.map +1 -0
- package/dist/commands/evidence.d.ts +45 -0
- package/dist/commands/evidence.d.ts.map +1 -0
- package/dist/commands/evidence.js +197 -0
- package/dist/commands/evidence.js.map +1 -0
- package/dist/commands/index.d.ts +8 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +15 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/scan-secrets.d.ts +47 -0
- package/dist/commands/scan-secrets.d.ts.map +1 -0
- package/dist/commands/scan-secrets.js +225 -0
- package/dist/commands/scan-secrets.js.map +1 -0
- package/dist/commands/scan-vulnerabilities-enhanced.d.ts +41 -0
- package/dist/commands/scan-vulnerabilities-enhanced.d.ts.map +1 -0
- package/dist/commands/scan-vulnerabilities-enhanced.js +368 -0
- package/dist/commands/scan-vulnerabilities-enhanced.js.map +1 -0
- package/dist/commands/scan-vulnerabilities-osv.d.ts +58 -0
- package/dist/commands/scan-vulnerabilities-osv.d.ts.map +1 -0
- package/dist/commands/scan-vulnerabilities-osv.js +716 -0
- package/dist/commands/scan-vulnerabilities-osv.js.map +1 -0
- package/dist/commands/scan-vulnerabilities.d.ts +32 -0
- package/dist/commands/scan-vulnerabilities.d.ts.map +1 -0
- package/dist/commands/scan-vulnerabilities.js +283 -0
- package/dist/commands/scan-vulnerabilities.js.map +1 -0
- package/dist/commands/secrets-allowlist.d.ts +7 -0
- package/dist/commands/secrets-allowlist.d.ts.map +1 -0
- package/dist/commands/secrets-allowlist.js +85 -0
- package/dist/commands/secrets-allowlist.js.map +1 -0
- package/dist/fix/applicator.d.ts +44 -0
- package/dist/fix/applicator.d.ts.map +1 -0
- package/dist/fix/applicator.js +144 -0
- package/dist/fix/applicator.js.map +1 -0
- package/dist/fix/backup.d.ts +38 -0
- package/dist/fix/backup.d.ts.map +1 -0
- package/dist/fix/backup.js +154 -0
- package/dist/fix/backup.js.map +1 -0
- package/dist/fix/engine.d.ts +55 -0
- package/dist/fix/engine.d.ts.map +1 -0
- package/dist/fix/engine.js +285 -0
- package/dist/fix/engine.js.map +1 -0
- package/dist/fix/index.d.ts +5 -0
- package/dist/fix/index.d.ts.map +1 -0
- package/dist/fix/index.js +12 -0
- package/dist/fix/index.js.map +1 -0
- package/dist/fix/interactive.d.ts +22 -0
- package/dist/fix/interactive.d.ts.map +1 -0
- package/dist/fix/interactive.js +172 -0
- package/dist/fix/interactive.js.map +1 -0
- package/dist/formatters/index.d.ts +6 -0
- package/dist/formatters/index.d.ts.map +1 -0
- package/dist/formatters/index.js +11 -0
- package/dist/formatters/index.js.map +1 -0
- package/dist/formatters/sarif-enhanced.d.ts +78 -0
- package/dist/formatters/sarif-enhanced.d.ts.map +1 -0
- package/dist/formatters/sarif-enhanced.js +144 -0
- package/dist/formatters/sarif-enhanced.js.map +1 -0
- package/dist/formatters/sarif-v2.d.ts +121 -0
- package/dist/formatters/sarif-v2.d.ts.map +1 -0
- package/dist/formatters/sarif-v2.js +356 -0
- package/dist/formatters/sarif-v2.js.map +1 -0
- package/dist/formatters/sarif.d.ts +72 -0
- package/dist/formatters/sarif.d.ts.map +1 -0
- package/dist/formatters/sarif.js +146 -0
- package/dist/formatters/sarif.js.map +1 -0
- package/dist/index.js +3362 -1397
- package/dist/index.js.map +1 -1
- package/dist/init/ci-generator.d.ts +18 -0
- package/dist/init/ci-generator.d.ts.map +1 -0
- package/dist/init/ci-generator.js +251 -0
- package/dist/init/ci-generator.js.map +1 -0
- package/dist/init/detect-framework.d.ts +15 -0
- package/dist/init/detect-framework.d.ts.map +1 -0
- package/dist/init/detect-framework.js +299 -0
- package/dist/init/detect-framework.js.map +1 -0
- package/dist/init/hooks-installer.d.ts +22 -0
- package/dist/init/hooks-installer.d.ts.map +1 -0
- package/dist/init/hooks-installer.js +302 -0
- package/dist/init/hooks-installer.js.map +1 -0
- package/dist/init/index.d.ts +8 -0
- package/dist/init/index.d.ts.map +1 -0
- package/dist/init/index.js +22 -0
- package/dist/init/index.js.map +1 -0
- package/dist/init/templates.d.ts +401 -0
- package/dist/init/templates.d.ts.map +1 -0
- package/dist/init/templates.js +240 -0
- package/dist/init/templates.js.map +1 -0
- package/dist/reality/reality-runner.d.ts +76 -0
- package/dist/reality/reality-runner.d.ts.map +1 -0
- package/dist/reality/reality-runner.js +454 -0
- package/dist/reality/reality-runner.js.map +1 -0
- package/dist/runtime/auth-utils.d.ts +43 -0
- package/dist/runtime/auth-utils.d.ts.map +1 -0
- package/dist/runtime/auth-utils.js +126 -0
- package/dist/runtime/auth-utils.js.map +1 -0
- package/dist/runtime/client.d.ts +74 -0
- package/dist/runtime/client.d.ts.map +1 -0
- package/dist/runtime/client.js +222 -0
- package/dist/runtime/client.js.map +1 -0
- package/dist/runtime/creds.d.ts +48 -0
- package/dist/runtime/creds.d.ts.map +1 -0
- package/dist/runtime/creds.js +245 -0
- package/dist/runtime/creds.js.map +1 -0
- package/dist/runtime/exit-codes.d.ts +47 -0
- package/dist/runtime/exit-codes.d.ts.map +1 -0
- package/dist/runtime/exit-codes.js +91 -0
- package/dist/runtime/exit-codes.js.map +1 -0
- package/dist/runtime/index.d.ts +9 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +25 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/semver.d.ts +37 -0
- package/dist/runtime/semver.d.ts.map +1 -0
- package/dist/runtime/semver.js +110 -0
- package/dist/runtime/semver.js.map +1 -0
- package/dist/scanner/baseline.d.ts +52 -0
- package/dist/scanner/baseline.d.ts.map +1 -0
- package/dist/scanner/baseline.js +85 -0
- package/dist/scanner/baseline.js.map +1 -0
- package/dist/scanner/incremental.d.ts +30 -0
- package/dist/scanner/incremental.d.ts.map +1 -0
- package/dist/scanner/incremental.js +82 -0
- package/dist/scanner/incremental.js.map +1 -0
- package/dist/scanner/parallel.d.ts +43 -0
- package/dist/scanner/parallel.d.ts.map +1 -0
- package/dist/scanner/parallel.js +99 -0
- package/dist/scanner/parallel.js.map +1 -0
- package/dist/ui/frame.d.ts +68 -0
- package/dist/ui/frame.d.ts.map +1 -0
- package/dist/ui/frame.js +165 -0
- package/dist/ui/frame.js.map +1 -0
- package/dist/ui/index.d.ts +5 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +16 -0
- package/dist/ui/index.js.map +1 -0
- package/package.json +42 -9
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FixEngine = void 0;
|
|
4
|
+
const fs_1 = require("fs");
|
|
5
|
+
const path_1 = require("path");
|
|
6
|
+
class FixEngine {
|
|
7
|
+
constructor(projectPath) {
|
|
8
|
+
this.projectPath = projectPath;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Generate fix packs from scan results
|
|
12
|
+
*/
|
|
13
|
+
async generateFixPacks(scanResult) {
|
|
14
|
+
const packs = [];
|
|
15
|
+
// Group findings by category
|
|
16
|
+
const securityFindings = scanResult.findings.filter(f => f.category.toLowerCase().includes('secret') ||
|
|
17
|
+
f.category.toLowerCase().includes('vulnerability') ||
|
|
18
|
+
f.category.toLowerCase().includes('security'));
|
|
19
|
+
const qualityFindings = scanResult.findings.filter(f => f.category.toLowerCase().includes('quality') ||
|
|
20
|
+
f.category.toLowerCase().includes('code') ||
|
|
21
|
+
f.category.toLowerCase().includes('smell'));
|
|
22
|
+
const configFindings = scanResult.findings.filter(f => f.category.toLowerCase().includes('config') ||
|
|
23
|
+
f.category.toLowerCase().includes('dependency'));
|
|
24
|
+
// Generate security fix pack
|
|
25
|
+
if (securityFindings.length > 0) {
|
|
26
|
+
const securityPack = await this.createSecurityFixPack(securityFindings);
|
|
27
|
+
if (securityPack.fixes.length > 0) {
|
|
28
|
+
packs.push(securityPack);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
// Generate quality fix pack
|
|
32
|
+
if (qualityFindings.length > 0) {
|
|
33
|
+
const qualityPack = await this.createQualityFixPack(qualityFindings);
|
|
34
|
+
if (qualityPack.fixes.length > 0) {
|
|
35
|
+
packs.push(qualityPack);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
// Generate config fix pack
|
|
39
|
+
if (configFindings.length > 0) {
|
|
40
|
+
const configPack = await this.createConfigFixPack(configFindings);
|
|
41
|
+
if (configPack.fixes.length > 0) {
|
|
42
|
+
packs.push(configPack);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return packs;
|
|
46
|
+
}
|
|
47
|
+
async createSecurityFixPack(findings) {
|
|
48
|
+
const fixes = [];
|
|
49
|
+
const impactedFiles = new Set();
|
|
50
|
+
for (const finding of findings) {
|
|
51
|
+
impactedFiles.add(finding.file);
|
|
52
|
+
// Generate fix based on finding type
|
|
53
|
+
if (finding.category.toLowerCase().includes('secret')) {
|
|
54
|
+
const fix = this.generateSecretFix(finding);
|
|
55
|
+
if (fix)
|
|
56
|
+
fixes.push(fix);
|
|
57
|
+
}
|
|
58
|
+
else if (finding.category.toLowerCase().includes('vulnerability')) {
|
|
59
|
+
const fix = this.generateVulnerabilityFix(finding);
|
|
60
|
+
if (fix)
|
|
61
|
+
fixes.push(fix);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
const avgConfidence = fixes.length > 0
|
|
65
|
+
? fixes.reduce((sum, f) => sum + f.confidence, 0) / fixes.length
|
|
66
|
+
: 0;
|
|
67
|
+
return {
|
|
68
|
+
id: 'security-fixes',
|
|
69
|
+
category: 'security',
|
|
70
|
+
name: 'Security Vulnerabilities',
|
|
71
|
+
description: 'Fix hardcoded secrets and security vulnerabilities',
|
|
72
|
+
findings,
|
|
73
|
+
fixes,
|
|
74
|
+
estimatedRisk: this.calculatePackRisk(fixes),
|
|
75
|
+
impactedFiles: Array.from(impactedFiles),
|
|
76
|
+
priority: 1,
|
|
77
|
+
confidence: avgConfidence,
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
async createQualityFixPack(findings) {
|
|
81
|
+
const fixes = [];
|
|
82
|
+
const impactedFiles = new Set();
|
|
83
|
+
for (const finding of findings) {
|
|
84
|
+
impactedFiles.add(finding.file);
|
|
85
|
+
const fix = this.generateQualityFix(finding);
|
|
86
|
+
if (fix)
|
|
87
|
+
fixes.push(fix);
|
|
88
|
+
}
|
|
89
|
+
const avgConfidence = fixes.length > 0
|
|
90
|
+
? fixes.reduce((sum, f) => sum + f.confidence, 0) / fixes.length
|
|
91
|
+
: 0;
|
|
92
|
+
return {
|
|
93
|
+
id: 'quality-fixes',
|
|
94
|
+
category: 'quality',
|
|
95
|
+
name: 'Code Quality Improvements',
|
|
96
|
+
description: 'Improve code quality and best practices',
|
|
97
|
+
findings,
|
|
98
|
+
fixes,
|
|
99
|
+
estimatedRisk: this.calculatePackRisk(fixes),
|
|
100
|
+
impactedFiles: Array.from(impactedFiles),
|
|
101
|
+
priority: 2,
|
|
102
|
+
confidence: avgConfidence,
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
async createConfigFixPack(findings) {
|
|
106
|
+
const fixes = [];
|
|
107
|
+
const impactedFiles = new Set();
|
|
108
|
+
for (const finding of findings) {
|
|
109
|
+
impactedFiles.add(finding.file);
|
|
110
|
+
const fix = this.generateConfigFix(finding);
|
|
111
|
+
if (fix)
|
|
112
|
+
fixes.push(fix);
|
|
113
|
+
}
|
|
114
|
+
const avgConfidence = fixes.length > 0
|
|
115
|
+
? fixes.reduce((sum, f) => sum + f.confidence, 0) / fixes.length
|
|
116
|
+
: 0;
|
|
117
|
+
return {
|
|
118
|
+
id: 'config-fixes',
|
|
119
|
+
category: 'config',
|
|
120
|
+
name: 'Configuration Updates',
|
|
121
|
+
description: 'Update dependencies and configuration',
|
|
122
|
+
findings,
|
|
123
|
+
fixes,
|
|
124
|
+
estimatedRisk: this.calculatePackRisk(fixes),
|
|
125
|
+
impactedFiles: Array.from(impactedFiles),
|
|
126
|
+
priority: 3,
|
|
127
|
+
confidence: avgConfidence,
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
generateSecretFix(finding) {
|
|
131
|
+
try {
|
|
132
|
+
const filePath = (0, path_1.join)(this.projectPath, finding.file);
|
|
133
|
+
const content = (0, fs_1.readFileSync)(filePath, 'utf-8');
|
|
134
|
+
const lines = content.split('\n');
|
|
135
|
+
if (finding.line <= 0 || finding.line > lines.length) {
|
|
136
|
+
return null;
|
|
137
|
+
}
|
|
138
|
+
const oldCode = lines[finding.line - 1];
|
|
139
|
+
// Generate fix based on secret type
|
|
140
|
+
let newCode = oldCode;
|
|
141
|
+
let explanation = '';
|
|
142
|
+
let confidence = 0.7;
|
|
143
|
+
if (finding.title.toLowerCase().includes('api key') ||
|
|
144
|
+
finding.title.toLowerCase().includes('token')) {
|
|
145
|
+
// Replace hardcoded value with environment variable
|
|
146
|
+
const match = oldCode.match(/['"`]([a-zA-Z0-9_\-]{20,})['"`]/);
|
|
147
|
+
if (match) {
|
|
148
|
+
const secretValue = match[1];
|
|
149
|
+
const varName = this.inferEnvVarName(finding.title);
|
|
150
|
+
newCode = oldCode.replace(match[0], `process.env.${varName}`);
|
|
151
|
+
explanation = `Replace hardcoded ${finding.title} with environment variable ${varName}`;
|
|
152
|
+
confidence = 0.85;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
else if (finding.title.toLowerCase().includes('password')) {
|
|
156
|
+
const varName = 'DB_PASSWORD';
|
|
157
|
+
newCode = oldCode.replace(/password\s*[:=]\s*['"`][^'"`]+['"`]/i, `password: process.env.${varName}`);
|
|
158
|
+
explanation = `Replace hardcoded password with environment variable ${varName}`;
|
|
159
|
+
confidence = 0.8;
|
|
160
|
+
}
|
|
161
|
+
if (newCode === oldCode) {
|
|
162
|
+
// Generic fix: comment out the line
|
|
163
|
+
newCode = `// TODO: Move to environment variable\n${oldCode}`;
|
|
164
|
+
explanation = 'Comment out hardcoded secret and add TODO';
|
|
165
|
+
confidence = 0.5;
|
|
166
|
+
}
|
|
167
|
+
return {
|
|
168
|
+
findingId: finding.id,
|
|
169
|
+
file: finding.file,
|
|
170
|
+
line: finding.line,
|
|
171
|
+
oldCode,
|
|
172
|
+
newCode,
|
|
173
|
+
confidence,
|
|
174
|
+
risk: confidence > 0.7 ? 'low' : 'medium',
|
|
175
|
+
explanation,
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
catch {
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
generateVulnerabilityFix(finding) {
|
|
183
|
+
// For dependency vulnerabilities, suggest package.json updates
|
|
184
|
+
if (finding.file === 'package.json') {
|
|
185
|
+
try {
|
|
186
|
+
const filePath = (0, path_1.join)(this.projectPath, finding.file);
|
|
187
|
+
const content = (0, fs_1.readFileSync)(filePath, 'utf-8');
|
|
188
|
+
const packageJson = JSON.parse(content);
|
|
189
|
+
// Extract package name and version from recommendation
|
|
190
|
+
const match = finding.recommendation.match(/Upgrade to ([^@]+)@([^\s]+)/);
|
|
191
|
+
if (match) {
|
|
192
|
+
const [, pkgName, newVersion] = match;
|
|
193
|
+
const oldVersion = packageJson.dependencies?.[pkgName] ||
|
|
194
|
+
packageJson.devDependencies?.[pkgName];
|
|
195
|
+
if (oldVersion) {
|
|
196
|
+
return {
|
|
197
|
+
findingId: finding.id,
|
|
198
|
+
file: finding.file,
|
|
199
|
+
line: finding.line,
|
|
200
|
+
oldCode: `"${pkgName}": "${oldVersion}"`,
|
|
201
|
+
newCode: `"${pkgName}": "^${newVersion}"`,
|
|
202
|
+
confidence: 0.9,
|
|
203
|
+
risk: 'low',
|
|
204
|
+
explanation: `Upgrade ${pkgName} to ${newVersion} to fix ${finding.title}`,
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
catch {
|
|
210
|
+
return null;
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
return null;
|
|
214
|
+
}
|
|
215
|
+
generateQualityFix(finding) {
|
|
216
|
+
try {
|
|
217
|
+
const filePath = (0, path_1.join)(this.projectPath, finding.file);
|
|
218
|
+
const content = (0, fs_1.readFileSync)(filePath, 'utf-8');
|
|
219
|
+
const lines = content.split('\n');
|
|
220
|
+
if (finding.line <= 0 || finding.line > lines.length) {
|
|
221
|
+
return null;
|
|
222
|
+
}
|
|
223
|
+
const oldCode = lines[finding.line - 1];
|
|
224
|
+
let newCode = oldCode;
|
|
225
|
+
let explanation = '';
|
|
226
|
+
let confidence = 0.6;
|
|
227
|
+
// Example quality fixes
|
|
228
|
+
if (oldCode.includes('console.log')) {
|
|
229
|
+
newCode = oldCode.replace(/console\.log/g, 'logger.debug');
|
|
230
|
+
explanation = 'Replace console.log with proper logger';
|
|
231
|
+
confidence = 0.8;
|
|
232
|
+
}
|
|
233
|
+
else if (oldCode.includes('var ')) {
|
|
234
|
+
newCode = oldCode.replace(/\bvar\b/g, 'const');
|
|
235
|
+
explanation = 'Replace var with const for better scoping';
|
|
236
|
+
confidence = 0.75;
|
|
237
|
+
}
|
|
238
|
+
if (newCode === oldCode) {
|
|
239
|
+
return null;
|
|
240
|
+
}
|
|
241
|
+
return {
|
|
242
|
+
findingId: finding.id,
|
|
243
|
+
file: finding.file,
|
|
244
|
+
line: finding.line,
|
|
245
|
+
oldCode,
|
|
246
|
+
newCode,
|
|
247
|
+
confidence,
|
|
248
|
+
risk: 'low',
|
|
249
|
+
explanation,
|
|
250
|
+
};
|
|
251
|
+
}
|
|
252
|
+
catch {
|
|
253
|
+
return null;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
generateConfigFix(finding) {
|
|
257
|
+
return this.generateVulnerabilityFix(finding);
|
|
258
|
+
}
|
|
259
|
+
calculatePackRisk(fixes) {
|
|
260
|
+
if (fixes.length === 0)
|
|
261
|
+
return 'low';
|
|
262
|
+
const highRiskCount = fixes.filter(f => f.risk === 'high').length;
|
|
263
|
+
const mediumRiskCount = fixes.filter(f => f.risk === 'medium').length;
|
|
264
|
+
if (highRiskCount > fixes.length * 0.3)
|
|
265
|
+
return 'high';
|
|
266
|
+
if (mediumRiskCount > fixes.length * 0.5)
|
|
267
|
+
return 'medium';
|
|
268
|
+
return 'low';
|
|
269
|
+
}
|
|
270
|
+
inferEnvVarName(title) {
|
|
271
|
+
const normalized = title
|
|
272
|
+
.toUpperCase()
|
|
273
|
+
.replace(/[^A-Z0-9]+/g, '_')
|
|
274
|
+
.replace(/^_+|_+$/g, '');
|
|
275
|
+
if (normalized.includes('API_KEY'))
|
|
276
|
+
return 'API_KEY';
|
|
277
|
+
if (normalized.includes('TOKEN'))
|
|
278
|
+
return 'AUTH_TOKEN';
|
|
279
|
+
if (normalized.includes('SECRET'))
|
|
280
|
+
return 'SECRET_KEY';
|
|
281
|
+
return normalized || 'SECRET_VALUE';
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
exports.FixEngine = FixEngine;
|
|
285
|
+
//# sourceMappingURL=engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../../src/fix/engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { FixEngine, type Finding, type Fix, type FixPack, type ScanResult } from './engine';
|
|
2
|
+
export { BackupManager, type BackupMetadata } from './backup';
|
|
3
|
+
export { FixApplicator, type ApplyResult, type VerificationResult } from './applicator';
|
|
4
|
+
export { InteractiveSelector, type SelectionResult } from './interactive';
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/fix/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,OAAO,EAAE,KAAK,GAAG,EAAE,KAAK,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,UAAU,CAAC;AAC5F,OAAO,EAAE,aAAa,EAAE,KAAK,cAAc,EAAE,MAAM,UAAU,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,KAAK,WAAW,EAAE,KAAK,kBAAkB,EAAE,MAAM,cAAc,CAAC;AACxF,OAAO,EAAE,mBAAmB,EAAE,KAAK,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InteractiveSelector = exports.FixApplicator = exports.BackupManager = exports.FixEngine = void 0;
|
|
4
|
+
var engine_1 = require("./engine");
|
|
5
|
+
Object.defineProperty(exports, "FixEngine", { enumerable: true, get: function () { return engine_1.FixEngine; } });
|
|
6
|
+
var backup_1 = require("./backup");
|
|
7
|
+
Object.defineProperty(exports, "BackupManager", { enumerable: true, get: function () { return backup_1.BackupManager; } });
|
|
8
|
+
var applicator_1 = require("./applicator");
|
|
9
|
+
Object.defineProperty(exports, "FixApplicator", { enumerable: true, get: function () { return applicator_1.FixApplicator; } });
|
|
10
|
+
var interactive_1 = require("./interactive");
|
|
11
|
+
Object.defineProperty(exports, "InteractiveSelector", { enumerable: true, get: function () { return interactive_1.InteractiveSelector; } });
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/fix/index.ts"],"names":[],"mappings":";;;AAAA,mCAA4F;AAAnF,mGAAA,SAAS,OAAA;AAClB,mCAA8D;AAArD,uGAAA,aAAa,OAAA;AACtB,2CAAwF;AAA/E,2GAAA,aAAa,OAAA;AACtB,6CAA0E;AAAjE,kHAAA,mBAAmB,OAAA"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { FixPack } from './engine';
|
|
2
|
+
export interface SelectionResult {
|
|
3
|
+
selectedPacks: FixPack[];
|
|
4
|
+
cancelled: boolean;
|
|
5
|
+
}
|
|
6
|
+
export declare class InteractiveSelector {
|
|
7
|
+
private isTTY;
|
|
8
|
+
constructor();
|
|
9
|
+
/**
|
|
10
|
+
* Interactive checkbox selection for fix packs
|
|
11
|
+
*/
|
|
12
|
+
selectPacks(packs: FixPack[]): Promise<SelectionResult>;
|
|
13
|
+
/**
|
|
14
|
+
* Non-interactive pack selection by IDs
|
|
15
|
+
*/
|
|
16
|
+
selectPacksByIds(packs: FixPack[], packIds: string[]): FixPack[];
|
|
17
|
+
/**
|
|
18
|
+
* Confirm action with user
|
|
19
|
+
*/
|
|
20
|
+
confirm(message: string, defaultValue?: boolean): Promise<boolean>;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=interactive.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interactive.d.ts","sourceRoot":"","sources":["../../src/fix/interactive.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAEnC,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,OAAO,EAAE,CAAC;IACzB,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,KAAK,CAAU;;IAMvB;;OAEG;IACG,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC;IAkG7D;;OAEG;IACH,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,OAAO,EAAE;IAShE;;OAEG;IACG,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,UAAO,GAAG,OAAO,CAAC,OAAO,CAAC;CAuBtE"}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.InteractiveSelector = void 0;
|
|
37
|
+
const readline = __importStar(require("readline"));
|
|
38
|
+
class InteractiveSelector {
|
|
39
|
+
constructor() {
|
|
40
|
+
this.isTTY = Boolean(process.stdin.isTTY && process.stdout.isTTY);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Interactive checkbox selection for fix packs
|
|
44
|
+
*/
|
|
45
|
+
async selectPacks(packs) {
|
|
46
|
+
if (!this.isTTY) {
|
|
47
|
+
// Non-interactive: select all by default
|
|
48
|
+
return {
|
|
49
|
+
selectedPacks: packs,
|
|
50
|
+
cancelled: false,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
const selected = new Set();
|
|
54
|
+
let currentIndex = 0;
|
|
55
|
+
// Initially select all packs
|
|
56
|
+
packs.forEach((_, i) => selected.add(i));
|
|
57
|
+
return new Promise((resolve) => {
|
|
58
|
+
const rl = readline.createInterface({
|
|
59
|
+
input: process.stdin,
|
|
60
|
+
output: process.stdout,
|
|
61
|
+
});
|
|
62
|
+
const render = () => {
|
|
63
|
+
console.clear();
|
|
64
|
+
console.log('\x1b[1m\x1b[36mSelect Fix Packs to Apply\x1b[0m');
|
|
65
|
+
console.log('\x1b[2m─────────────────────────────────────────────────────────\x1b[0m');
|
|
66
|
+
console.log('');
|
|
67
|
+
packs.forEach((pack, i) => {
|
|
68
|
+
const isSelected = selected.has(i);
|
|
69
|
+
const isCurrent = i === currentIndex;
|
|
70
|
+
const checkbox = isSelected ? '\x1b[32m[✓]\x1b[0m' : '\x1b[31m[ ]\x1b[0m';
|
|
71
|
+
const cursor = isCurrent ? '\x1b[36m❯\x1b[0m' : ' ';
|
|
72
|
+
const riskColor = pack.estimatedRisk === 'high' ? '\x1b[31m' :
|
|
73
|
+
pack.estimatedRisk === 'medium' ? '\x1b[33m' : '\x1b[32m';
|
|
74
|
+
console.log(` ${cursor} ${checkbox} \x1b[1m${pack.name}\x1b[0m`);
|
|
75
|
+
console.log(` \x1b[2m${pack.description}\x1b[0m`);
|
|
76
|
+
console.log(` \x1b[2mFixes: ${pack.fixes.length} | Risk: ${riskColor}${pack.estimatedRisk}\x1b[0m | Confidence: ${(pack.confidence * 100).toFixed(0)}%`);
|
|
77
|
+
console.log('');
|
|
78
|
+
});
|
|
79
|
+
console.log('\x1b[2m─────────────────────────────────────────────────────────\x1b[0m');
|
|
80
|
+
console.log('\x1b[2mControls: ↑/↓ Navigate | Space Toggle | Enter Confirm | Q Quit\x1b[0m');
|
|
81
|
+
};
|
|
82
|
+
render();
|
|
83
|
+
// Enable raw mode for key detection
|
|
84
|
+
if (process.stdin.setRawMode) {
|
|
85
|
+
process.stdin.setRawMode(true);
|
|
86
|
+
}
|
|
87
|
+
process.stdin.on('data', (key) => {
|
|
88
|
+
const char = key.toString();
|
|
89
|
+
if (char === '\u0003' || char.toLowerCase() === 'q') {
|
|
90
|
+
// Ctrl+C or Q - quit
|
|
91
|
+
if (process.stdin.setRawMode) {
|
|
92
|
+
process.stdin.setRawMode(false);
|
|
93
|
+
}
|
|
94
|
+
rl.close();
|
|
95
|
+
resolve({
|
|
96
|
+
selectedPacks: [],
|
|
97
|
+
cancelled: true,
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
else if (char === '\r' || char === '\n') {
|
|
101
|
+
// Enter - confirm
|
|
102
|
+
if (process.stdin.setRawMode) {
|
|
103
|
+
process.stdin.setRawMode(false);
|
|
104
|
+
}
|
|
105
|
+
rl.close();
|
|
106
|
+
const selectedPacks = packs.filter((_, i) => selected.has(i));
|
|
107
|
+
resolve({
|
|
108
|
+
selectedPacks,
|
|
109
|
+
cancelled: false,
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
else if (char === ' ') {
|
|
113
|
+
// Space - toggle selection
|
|
114
|
+
if (selected.has(currentIndex)) {
|
|
115
|
+
selected.delete(currentIndex);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
selected.add(currentIndex);
|
|
119
|
+
}
|
|
120
|
+
render();
|
|
121
|
+
}
|
|
122
|
+
else if (char === '\u001b[A') {
|
|
123
|
+
// Up arrow
|
|
124
|
+
currentIndex = Math.max(0, currentIndex - 1);
|
|
125
|
+
render();
|
|
126
|
+
}
|
|
127
|
+
else if (char === '\u001b[B') {
|
|
128
|
+
// Down arrow
|
|
129
|
+
currentIndex = Math.min(packs.length - 1, currentIndex + 1);
|
|
130
|
+
render();
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Non-interactive pack selection by IDs
|
|
137
|
+
*/
|
|
138
|
+
selectPacksByIds(packs, packIds) {
|
|
139
|
+
if (packIds.length === 0) {
|
|
140
|
+
return packs;
|
|
141
|
+
}
|
|
142
|
+
const idSet = new Set(packIds);
|
|
143
|
+
return packs.filter(pack => idSet.has(pack.id));
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Confirm action with user
|
|
147
|
+
*/
|
|
148
|
+
async confirm(message, defaultValue = true) {
|
|
149
|
+
if (!this.isTTY) {
|
|
150
|
+
return defaultValue;
|
|
151
|
+
}
|
|
152
|
+
const rl = readline.createInterface({
|
|
153
|
+
input: process.stdin,
|
|
154
|
+
output: process.stdout,
|
|
155
|
+
});
|
|
156
|
+
return new Promise((resolve) => {
|
|
157
|
+
const hint = defaultValue ? '[Y/n]' : '[y/N]';
|
|
158
|
+
rl.question(`${message} ${hint}: `, (answer) => {
|
|
159
|
+
rl.close();
|
|
160
|
+
const lower = answer.toLowerCase().trim();
|
|
161
|
+
if (lower === '') {
|
|
162
|
+
resolve(defaultValue);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
resolve(lower === 'y' || lower === 'yes');
|
|
166
|
+
}
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
exports.InteractiveSelector = InteractiveSelector;
|
|
172
|
+
//# sourceMappingURL=interactive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interactive.js","sourceRoot":"","sources":["../../src/fix/interactive.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/formatters/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,OAAO,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Output Formatters
|
|
4
|
+
* Re-exports all formatter functions
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.toSarifVulnerabilities = exports.toSarif = void 0;
|
|
8
|
+
var sarif_1 = require("./sarif");
|
|
9
|
+
Object.defineProperty(exports, "toSarif", { enumerable: true, get: function () { return sarif_1.toSarif; } });
|
|
10
|
+
Object.defineProperty(exports, "toSarifVulnerabilities", { enumerable: true, get: function () { return sarif_1.toSarifVulnerabilities; } });
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/formatters/index.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,iCAA0D;AAAjD,gGAAA,OAAO,OAAA;AAAE,+GAAA,sBAAsB,OAAA"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Enhanced SARIF (Static Analysis Results Interchange Format) Output
|
|
3
|
+
* For vulnerability scanning with OSV integration
|
|
4
|
+
*
|
|
5
|
+
* Includes:
|
|
6
|
+
* - CVSS scores and vectors
|
|
7
|
+
* - Remediation paths
|
|
8
|
+
* - Direct vs transitive classification
|
|
9
|
+
* - Multiple vulnerability sources
|
|
10
|
+
*/
|
|
11
|
+
import { EnhancedVulnResult } from '../commands/scan-vulnerabilities-enhanced';
|
|
12
|
+
export interface SarifResult {
|
|
13
|
+
$schema: string;
|
|
14
|
+
version: string;
|
|
15
|
+
runs: SarifRun[];
|
|
16
|
+
}
|
|
17
|
+
export interface SarifRun {
|
|
18
|
+
tool: {
|
|
19
|
+
driver: {
|
|
20
|
+
name: string;
|
|
21
|
+
version: string;
|
|
22
|
+
informationUri: string;
|
|
23
|
+
rules: SarifRule[];
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
results: SarifFinding[];
|
|
27
|
+
invocations: SarifInvocation[];
|
|
28
|
+
}
|
|
29
|
+
export interface SarifRule {
|
|
30
|
+
id: string;
|
|
31
|
+
name: string;
|
|
32
|
+
shortDescription: {
|
|
33
|
+
text: string;
|
|
34
|
+
};
|
|
35
|
+
fullDescription?: {
|
|
36
|
+
text: string;
|
|
37
|
+
};
|
|
38
|
+
helpUri?: string;
|
|
39
|
+
defaultConfiguration: {
|
|
40
|
+
level: 'error' | 'warning' | 'note' | 'none';
|
|
41
|
+
};
|
|
42
|
+
properties?: Record<string, any>;
|
|
43
|
+
}
|
|
44
|
+
export interface SarifFinding {
|
|
45
|
+
ruleId: string;
|
|
46
|
+
level: 'error' | 'warning' | 'note' | 'none';
|
|
47
|
+
message: {
|
|
48
|
+
text: string;
|
|
49
|
+
};
|
|
50
|
+
locations: SarifLocation[];
|
|
51
|
+
fingerprints?: Record<string, string>;
|
|
52
|
+
properties?: Record<string, any>;
|
|
53
|
+
}
|
|
54
|
+
export interface SarifLocation {
|
|
55
|
+
physicalLocation: {
|
|
56
|
+
artifactLocation: {
|
|
57
|
+
uri: string;
|
|
58
|
+
uriBaseId?: string;
|
|
59
|
+
};
|
|
60
|
+
region?: {
|
|
61
|
+
startLine: number;
|
|
62
|
+
startColumn?: number;
|
|
63
|
+
endLine?: number;
|
|
64
|
+
endColumn?: number;
|
|
65
|
+
};
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
export interface SarifInvocation {
|
|
69
|
+
executionSuccessful: boolean;
|
|
70
|
+
commandLine?: string;
|
|
71
|
+
startTimeUtc?: string;
|
|
72
|
+
endTimeUtc?: string;
|
|
73
|
+
workingDirectory?: {
|
|
74
|
+
uri: string;
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
export declare function toSarifVulnerabilitiesEnhanced(results: EnhancedVulnResult): SarifResult;
|
|
78
|
+
//# sourceMappingURL=sarif-enhanced.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sarif-enhanced.d.ts","sourceRoot":"","sources":["../../src/formatters/sarif-enhanced.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAC;AAE/E,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,QAAQ,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE;QACJ,MAAM,EAAE;YACN,IAAI,EAAE,MAAM,CAAC;YACb,OAAO,EAAE,MAAM,CAAC;YAChB,cAAc,EAAE,MAAM,CAAC;YACvB,KAAK,EAAE,SAAS,EAAE,CAAC;SACpB,CAAC;KACH,CAAC;IACF,OAAO,EAAE,YAAY,EAAE,CAAC;IACxB,WAAW,EAAE,eAAe,EAAE,CAAC;CAChC;AAED,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IACnC,eAAe,CAAC,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IACnC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,oBAAoB,EAAE;QACpB,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,CAAC;KAC9C,CAAC;IACF,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAClC;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,CAAC;IAC7C,OAAO,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IAC1B,SAAS,EAAE,aAAa,EAAE,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAClC;AAED,MAAM,WAAW,aAAa;IAC5B,gBAAgB,EAAE;QAChB,gBAAgB,EAAE;YAChB,GAAG,EAAE,MAAM,CAAC;YACZ,SAAS,CAAC,EAAE,MAAM,CAAC;SACpB,CAAC;QACF,MAAM,CAAC,EAAE;YACP,SAAS,EAAE,MAAM,CAAC;YAClB,WAAW,CAAC,EAAE,MAAM,CAAC;YACrB,OAAO,CAAC,EAAE,MAAM,CAAC;YACjB,SAAS,CAAC,EAAE,MAAM,CAAC;SACpB,CAAC;KACH,CAAC;CACH;AAED,MAAM,WAAW,eAAe;IAC9B,mBAAmB,EAAE,OAAO,CAAC;IAC7B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;CACpC;AAyBD,wBAAgB,8BAA8B,CAAC,OAAO,EAAE,kBAAkB,GAAG,WAAW,CAkGvF"}
|