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.
Files changed (144) hide show
  1. package/README.md +483 -10
  2. package/dist/commands/baseline.d.ts +7 -0
  3. package/dist/commands/baseline.d.ts.map +1 -0
  4. package/dist/commands/baseline.js +79 -0
  5. package/dist/commands/baseline.js.map +1 -0
  6. package/dist/commands/cache.d.ts +13 -0
  7. package/dist/commands/cache.d.ts.map +1 -0
  8. package/dist/commands/cache.js +165 -0
  9. package/dist/commands/cache.js.map +1 -0
  10. package/dist/commands/evidence.d.ts +45 -0
  11. package/dist/commands/evidence.d.ts.map +1 -0
  12. package/dist/commands/evidence.js +197 -0
  13. package/dist/commands/evidence.js.map +1 -0
  14. package/dist/commands/index.d.ts +8 -0
  15. package/dist/commands/index.d.ts.map +1 -0
  16. package/dist/commands/index.js +15 -0
  17. package/dist/commands/index.js.map +1 -0
  18. package/dist/commands/scan-secrets.d.ts +47 -0
  19. package/dist/commands/scan-secrets.d.ts.map +1 -0
  20. package/dist/commands/scan-secrets.js +225 -0
  21. package/dist/commands/scan-secrets.js.map +1 -0
  22. package/dist/commands/scan-vulnerabilities-enhanced.d.ts +41 -0
  23. package/dist/commands/scan-vulnerabilities-enhanced.d.ts.map +1 -0
  24. package/dist/commands/scan-vulnerabilities-enhanced.js +368 -0
  25. package/dist/commands/scan-vulnerabilities-enhanced.js.map +1 -0
  26. package/dist/commands/scan-vulnerabilities-osv.d.ts +58 -0
  27. package/dist/commands/scan-vulnerabilities-osv.d.ts.map +1 -0
  28. package/dist/commands/scan-vulnerabilities-osv.js +716 -0
  29. package/dist/commands/scan-vulnerabilities-osv.js.map +1 -0
  30. package/dist/commands/scan-vulnerabilities.d.ts +32 -0
  31. package/dist/commands/scan-vulnerabilities.d.ts.map +1 -0
  32. package/dist/commands/scan-vulnerabilities.js +283 -0
  33. package/dist/commands/scan-vulnerabilities.js.map +1 -0
  34. package/dist/commands/secrets-allowlist.d.ts +7 -0
  35. package/dist/commands/secrets-allowlist.d.ts.map +1 -0
  36. package/dist/commands/secrets-allowlist.js +85 -0
  37. package/dist/commands/secrets-allowlist.js.map +1 -0
  38. package/dist/fix/applicator.d.ts +44 -0
  39. package/dist/fix/applicator.d.ts.map +1 -0
  40. package/dist/fix/applicator.js +144 -0
  41. package/dist/fix/applicator.js.map +1 -0
  42. package/dist/fix/backup.d.ts +38 -0
  43. package/dist/fix/backup.d.ts.map +1 -0
  44. package/dist/fix/backup.js +154 -0
  45. package/dist/fix/backup.js.map +1 -0
  46. package/dist/fix/engine.d.ts +55 -0
  47. package/dist/fix/engine.d.ts.map +1 -0
  48. package/dist/fix/engine.js +285 -0
  49. package/dist/fix/engine.js.map +1 -0
  50. package/dist/fix/index.d.ts +5 -0
  51. package/dist/fix/index.d.ts.map +1 -0
  52. package/dist/fix/index.js +12 -0
  53. package/dist/fix/index.js.map +1 -0
  54. package/dist/fix/interactive.d.ts +22 -0
  55. package/dist/fix/interactive.d.ts.map +1 -0
  56. package/dist/fix/interactive.js +172 -0
  57. package/dist/fix/interactive.js.map +1 -0
  58. package/dist/formatters/index.d.ts +6 -0
  59. package/dist/formatters/index.d.ts.map +1 -0
  60. package/dist/formatters/index.js +11 -0
  61. package/dist/formatters/index.js.map +1 -0
  62. package/dist/formatters/sarif-enhanced.d.ts +78 -0
  63. package/dist/formatters/sarif-enhanced.d.ts.map +1 -0
  64. package/dist/formatters/sarif-enhanced.js +144 -0
  65. package/dist/formatters/sarif-enhanced.js.map +1 -0
  66. package/dist/formatters/sarif-v2.d.ts +121 -0
  67. package/dist/formatters/sarif-v2.d.ts.map +1 -0
  68. package/dist/formatters/sarif-v2.js +356 -0
  69. package/dist/formatters/sarif-v2.js.map +1 -0
  70. package/dist/formatters/sarif.d.ts +72 -0
  71. package/dist/formatters/sarif.d.ts.map +1 -0
  72. package/dist/formatters/sarif.js +146 -0
  73. package/dist/formatters/sarif.js.map +1 -0
  74. package/dist/index.js +3362 -1397
  75. package/dist/index.js.map +1 -1
  76. package/dist/init/ci-generator.d.ts +18 -0
  77. package/dist/init/ci-generator.d.ts.map +1 -0
  78. package/dist/init/ci-generator.js +251 -0
  79. package/dist/init/ci-generator.js.map +1 -0
  80. package/dist/init/detect-framework.d.ts +15 -0
  81. package/dist/init/detect-framework.d.ts.map +1 -0
  82. package/dist/init/detect-framework.js +299 -0
  83. package/dist/init/detect-framework.js.map +1 -0
  84. package/dist/init/hooks-installer.d.ts +22 -0
  85. package/dist/init/hooks-installer.d.ts.map +1 -0
  86. package/dist/init/hooks-installer.js +302 -0
  87. package/dist/init/hooks-installer.js.map +1 -0
  88. package/dist/init/index.d.ts +8 -0
  89. package/dist/init/index.d.ts.map +1 -0
  90. package/dist/init/index.js +22 -0
  91. package/dist/init/index.js.map +1 -0
  92. package/dist/init/templates.d.ts +401 -0
  93. package/dist/init/templates.d.ts.map +1 -0
  94. package/dist/init/templates.js +240 -0
  95. package/dist/init/templates.js.map +1 -0
  96. package/dist/reality/reality-runner.d.ts +76 -0
  97. package/dist/reality/reality-runner.d.ts.map +1 -0
  98. package/dist/reality/reality-runner.js +454 -0
  99. package/dist/reality/reality-runner.js.map +1 -0
  100. package/dist/runtime/auth-utils.d.ts +43 -0
  101. package/dist/runtime/auth-utils.d.ts.map +1 -0
  102. package/dist/runtime/auth-utils.js +126 -0
  103. package/dist/runtime/auth-utils.js.map +1 -0
  104. package/dist/runtime/client.d.ts +74 -0
  105. package/dist/runtime/client.d.ts.map +1 -0
  106. package/dist/runtime/client.js +222 -0
  107. package/dist/runtime/client.js.map +1 -0
  108. package/dist/runtime/creds.d.ts +48 -0
  109. package/dist/runtime/creds.d.ts.map +1 -0
  110. package/dist/runtime/creds.js +245 -0
  111. package/dist/runtime/creds.js.map +1 -0
  112. package/dist/runtime/exit-codes.d.ts +47 -0
  113. package/dist/runtime/exit-codes.d.ts.map +1 -0
  114. package/dist/runtime/exit-codes.js +91 -0
  115. package/dist/runtime/exit-codes.js.map +1 -0
  116. package/dist/runtime/index.d.ts +9 -0
  117. package/dist/runtime/index.d.ts.map +1 -0
  118. package/dist/runtime/index.js +25 -0
  119. package/dist/runtime/index.js.map +1 -0
  120. package/dist/runtime/semver.d.ts +37 -0
  121. package/dist/runtime/semver.d.ts.map +1 -0
  122. package/dist/runtime/semver.js +110 -0
  123. package/dist/runtime/semver.js.map +1 -0
  124. package/dist/scanner/baseline.d.ts +52 -0
  125. package/dist/scanner/baseline.d.ts.map +1 -0
  126. package/dist/scanner/baseline.js +85 -0
  127. package/dist/scanner/baseline.js.map +1 -0
  128. package/dist/scanner/incremental.d.ts +30 -0
  129. package/dist/scanner/incremental.d.ts.map +1 -0
  130. package/dist/scanner/incremental.js +82 -0
  131. package/dist/scanner/incremental.js.map +1 -0
  132. package/dist/scanner/parallel.d.ts +43 -0
  133. package/dist/scanner/parallel.d.ts.map +1 -0
  134. package/dist/scanner/parallel.js +99 -0
  135. package/dist/scanner/parallel.js.map +1 -0
  136. package/dist/ui/frame.d.ts +68 -0
  137. package/dist/ui/frame.d.ts.map +1 -0
  138. package/dist/ui/frame.js +165 -0
  139. package/dist/ui/frame.js.map +1 -0
  140. package/dist/ui/index.d.ts +5 -0
  141. package/dist/ui/index.d.ts.map +1 -0
  142. package/dist/ui/index.js +16 -0
  143. package/dist/ui/index.js.map +1 -0
  144. 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,6 @@
1
+ /**
2
+ * Output Formatters
3
+ * Re-exports all formatter functions
4
+ */
5
+ export { toSarif, toSarifVulnerabilities } from './sarif';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}