circle-ir-ai 2.7.1 → 2.7.2

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 (146) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/package.json +2 -2
  3. package/dist/cli/args.d.ts +0 -86
  4. package/dist/cli/args.d.ts.map +0 -1
  5. package/dist/cli/args.js +0 -653
  6. package/dist/cli/args.js.map +0 -1
  7. package/dist/cli/colors.d.ts +0 -31
  8. package/dist/cli/colors.d.ts.map +0 -1
  9. package/dist/cli/colors.js +0 -80
  10. package/dist/cli/colors.js.map +0 -1
  11. package/dist/cli/commands/analyze-skill.d.ts +0 -33
  12. package/dist/cli/commands/analyze-skill.d.ts.map +0 -1
  13. package/dist/cli/commands/analyze-skill.js +0 -217
  14. package/dist/cli/commands/analyze-skill.js.map +0 -1
  15. package/dist/cli/commands/analyze.d.ts +0 -19
  16. package/dist/cli/commands/analyze.d.ts.map +0 -1
  17. package/dist/cli/commands/analyze.js +0 -303
  18. package/dist/cli/commands/analyze.js.map +0 -1
  19. package/dist/cli/commands/benchmark-runner.d.ts +0 -42
  20. package/dist/cli/commands/benchmark-runner.d.ts.map +0 -1
  21. package/dist/cli/commands/benchmark-runner.js +0 -18
  22. package/dist/cli/commands/benchmark-runner.js.map +0 -1
  23. package/dist/cli/commands/benchmark.d.ts +0 -11
  24. package/dist/cli/commands/benchmark.d.ts.map +0 -1
  25. package/dist/cli/commands/benchmark.js +0 -90
  26. package/dist/cli/commands/benchmark.js.map +0 -1
  27. package/dist/cli/commands/cluster.d.ts +0 -12
  28. package/dist/cli/commands/cluster.d.ts.map +0 -1
  29. package/dist/cli/commands/cluster.js +0 -203
  30. package/dist/cli/commands/cluster.js.map +0 -1
  31. package/dist/cli/commands/compare.d.ts +0 -13
  32. package/dist/cli/commands/compare.d.ts.map +0 -1
  33. package/dist/cli/commands/compare.js +0 -109
  34. package/dist/cli/commands/compare.js.map +0 -1
  35. package/dist/cli/commands/dead-code.d.ts +0 -11
  36. package/dist/cli/commands/dead-code.d.ts.map +0 -1
  37. package/dist/cli/commands/dead-code.js +0 -75
  38. package/dist/cli/commands/dead-code.js.map +0 -1
  39. package/dist/cli/commands/generate-spec.d.ts +0 -11
  40. package/dist/cli/commands/generate-spec.d.ts.map +0 -1
  41. package/dist/cli/commands/generate-spec.js +0 -120
  42. package/dist/cli/commands/generate-spec.js.map +0 -1
  43. package/dist/cli/commands/health.d.ts +0 -11
  44. package/dist/cli/commands/health.d.ts.map +0 -1
  45. package/dist/cli/commands/health.js +0 -76
  46. package/dist/cli/commands/health.js.map +0 -1
  47. package/dist/cli/commands/index.d.ts +0 -30
  48. package/dist/cli/commands/index.d.ts.map +0 -1
  49. package/dist/cli/commands/index.js +0 -36
  50. package/dist/cli/commands/index.js.map +0 -1
  51. package/dist/cli/commands/metrics.d.ts +0 -12
  52. package/dist/cli/commands/metrics.d.ts.map +0 -1
  53. package/dist/cli/commands/metrics.js +0 -231
  54. package/dist/cli/commands/metrics.js.map +0 -1
  55. package/dist/cli/commands/project.d.ts +0 -21
  56. package/dist/cli/commands/project.d.ts.map +0 -1
  57. package/dist/cli/commands/project.js +0 -92
  58. package/dist/cli/commands/project.js.map +0 -1
  59. package/dist/cli/commands/quality.d.ts +0 -15
  60. package/dist/cli/commands/quality.d.ts.map +0 -1
  61. package/dist/cli/commands/quality.js +0 -86
  62. package/dist/cli/commands/quality.js.map +0 -1
  63. package/dist/cli/commands/scan.d.ts +0 -11
  64. package/dist/cli/commands/scan.d.ts.map +0 -1
  65. package/dist/cli/commands/scan.js +0 -102
  66. package/dist/cli/commands/scan.js.map +0 -1
  67. package/dist/cli/commands/secrets.d.ts +0 -11
  68. package/dist/cli/commands/secrets.d.ts.map +0 -1
  69. package/dist/cli/commands/secrets.js +0 -79
  70. package/dist/cli/commands/secrets.js.map +0 -1
  71. package/dist/cli/commands/spec-diff.d.ts +0 -12
  72. package/dist/cli/commands/spec-diff.d.ts.map +0 -1
  73. package/dist/cli/commands/spec-diff.js +0 -150
  74. package/dist/cli/commands/spec-diff.js.map +0 -1
  75. package/dist/cli/commands/swarm.d.ts +0 -21
  76. package/dist/cli/commands/swarm.d.ts.map +0 -1
  77. package/dist/cli/commands/swarm.js +0 -175
  78. package/dist/cli/commands/swarm.js.map +0 -1
  79. package/dist/cli/commands/trust.d.ts +0 -23
  80. package/dist/cli/commands/trust.d.ts.map +0 -1
  81. package/dist/cli/commands/trust.js +0 -397
  82. package/dist/cli/commands/trust.js.map +0 -1
  83. package/dist/cli/commands/understand.d.ts +0 -12
  84. package/dist/cli/commands/understand.d.ts.map +0 -1
  85. package/dist/cli/commands/understand.js +0 -188
  86. package/dist/cli/commands/understand.js.map +0 -1
  87. package/dist/cli/config.d.ts +0 -161
  88. package/dist/cli/config.d.ts.map +0 -1
  89. package/dist/cli/config.js +0 -383
  90. package/dist/cli/config.js.map +0 -1
  91. package/dist/cli/discovery.d.ts +0 -31
  92. package/dist/cli/discovery.d.ts.map +0 -1
  93. package/dist/cli/discovery.js +0 -212
  94. package/dist/cli/discovery.js.map +0 -1
  95. package/dist/cli/effective-options.d.ts +0 -42
  96. package/dist/cli/effective-options.d.ts.map +0 -1
  97. package/dist/cli/effective-options.js +0 -80
  98. package/dist/cli/effective-options.js.map +0 -1
  99. package/dist/cli/file-collection.d.ts +0 -49
  100. package/dist/cli/file-collection.d.ts.map +0 -1
  101. package/dist/cli/file-collection.js +0 -142
  102. package/dist/cli/file-collection.js.map +0 -1
  103. package/dist/cli/formatters/index.d.ts +0 -15
  104. package/dist/cli/formatters/index.d.ts.map +0 -1
  105. package/dist/cli/formatters/index.js +0 -51
  106. package/dist/cli/formatters/index.js.map +0 -1
  107. package/dist/cli/formatters/json.d.ts +0 -11
  108. package/dist/cli/formatters/json.d.ts.map +0 -1
  109. package/dist/cli/formatters/json.js +0 -12
  110. package/dist/cli/formatters/json.js.map +0 -1
  111. package/dist/cli/formatters/project-json.d.ts +0 -11
  112. package/dist/cli/formatters/project-json.d.ts.map +0 -1
  113. package/dist/cli/formatters/project-json.js +0 -12
  114. package/dist/cli/formatters/project-json.js.map +0 -1
  115. package/dist/cli/formatters/project-sarif.d.ts +0 -11
  116. package/dist/cli/formatters/project-sarif.d.ts.map +0 -1
  117. package/dist/cli/formatters/project-sarif.js +0 -127
  118. package/dist/cli/formatters/project-sarif.js.map +0 -1
  119. package/dist/cli/formatters/project-summary.d.ts +0 -11
  120. package/dist/cli/formatters/project-summary.d.ts.map +0 -1
  121. package/dist/cli/formatters/project-summary.js +0 -202
  122. package/dist/cli/formatters/project-summary.js.map +0 -1
  123. package/dist/cli/formatters/sarif-shared.d.ts +0 -101
  124. package/dist/cli/formatters/sarif-shared.d.ts.map +0 -1
  125. package/dist/cli/formatters/sarif-shared.js +0 -57
  126. package/dist/cli/formatters/sarif-shared.js.map +0 -1
  127. package/dist/cli/formatters/sarif.d.ts +0 -12
  128. package/dist/cli/formatters/sarif.d.ts.map +0 -1
  129. package/dist/cli/formatters/sarif.js +0 -92
  130. package/dist/cli/formatters/sarif.js.map +0 -1
  131. package/dist/cli/formatters/summary.d.ts +0 -11
  132. package/dist/cli/formatters/summary.d.ts.map +0 -1
  133. package/dist/cli/formatters/summary.js +0 -240
  134. package/dist/cli/formatters/summary.js.map +0 -1
  135. package/dist/cli/formatters/two-phase-summary.d.ts +0 -11
  136. package/dist/cli/formatters/two-phase-summary.d.ts.map +0 -1
  137. package/dist/cli/formatters/two-phase-summary.js +0 -188
  138. package/dist/cli/formatters/two-phase-summary.js.map +0 -1
  139. package/dist/cli/index.d.ts +0 -10
  140. package/dist/cli/index.d.ts.map +0 -1
  141. package/dist/cli/index.js +0 -72
  142. package/dist/cli/index.js.map +0 -1
  143. package/dist/cli/program.d.ts +0 -117
  144. package/dist/cli/program.d.ts.map +0 -1
  145. package/dist/cli/program.js +0 -825
  146. package/dist/cli/program.js.map +0 -1
@@ -1,240 +0,0 @@
1
- /**
2
- * Summary Formatter
3
- *
4
- * Outputs a human-readable summary of the analysis.
5
- */
6
- import { globalPatternCache } from '../../analysis/pattern-discovery.js';
7
- import { colors } from '../colors.js';
8
- /**
9
- * Format result as human-readable summary.
10
- */
11
- export function formatSummary(result, filePath) {
12
- const lines = [];
13
- // Header
14
- lines.push('');
15
- lines.push(colors.cyan('═'.repeat(60)));
16
- lines.push(colors.bold(' Circle-IR Analysis Report'));
17
- lines.push(colors.cyan('═'.repeat(60)));
18
- lines.push('');
19
- // File info
20
- lines.push(`File: ${filePath}`);
21
- lines.push(`Language: ${result.meta.language}`);
22
- lines.push(`Lines of Code: ${result.meta.loc}`);
23
- lines.push('');
24
- // Types summary
25
- lines.push('─'.repeat(60));
26
- lines.push('Types');
27
- lines.push('─'.repeat(60));
28
- lines.push(` Classes: ${result.types.filter(t => t.kind === 'class').length}`);
29
- lines.push(` Interfaces: ${result.types.filter(t => t.kind === 'interface').length}`);
30
- lines.push(` Enums: ${result.types.filter(t => t.kind === 'enum').length}`);
31
- lines.push(` Methods: ${result.types.reduce((sum, t) => sum + t.methods.length, 0)}`);
32
- lines.push('');
33
- // Pattern Discovery Stats (if enabled)
34
- const patternStats = globalPatternCache.getStats();
35
- if (patternStats.sources > 0 || patternStats.sinks > 0) {
36
- lines.push('─'.repeat(60));
37
- lines.push('Pattern Discovery');
38
- lines.push('─'.repeat(60));
39
- lines.push(` Discovered Sources: ${patternStats.sources}`);
40
- lines.push(` Discovered Sinks: ${patternStats.sinks}`);
41
- if (patternStats.verified > 0) {
42
- lines.push(` LLM Verified: ${patternStats.verified}`);
43
- }
44
- if (patternStats.needsVerification > 0) {
45
- lines.push(` Needs Verification: ${patternStats.needsVerification}`);
46
- }
47
- lines.push('');
48
- }
49
- // Taint sources
50
- lines.push('─'.repeat(60));
51
- lines.push('Taint Sources');
52
- lines.push('─'.repeat(60));
53
- if (result.taint.sources.length === 0) {
54
- lines.push(' No taint sources detected');
55
- }
56
- else {
57
- for (const source of result.taint.sources) {
58
- lines.push(formatSource(source));
59
- }
60
- }
61
- lines.push('');
62
- // Taint sinks
63
- lines.push('─'.repeat(60));
64
- lines.push('Taint Sinks');
65
- lines.push('─'.repeat(60));
66
- if (result.taint.sinks.length === 0) {
67
- lines.push(' No taint sinks detected');
68
- }
69
- else {
70
- for (const sink of result.taint.sinks) {
71
- lines.push(formatSink(sink));
72
- }
73
- }
74
- lines.push('');
75
- // Sanitizers
76
- if (result.taint.sanitizers && result.taint.sanitizers.length > 0) {
77
- lines.push('─'.repeat(60));
78
- lines.push('Sanitizers');
79
- lines.push('─'.repeat(60));
80
- for (const sanitizer of result.taint.sanitizers) {
81
- lines.push(` Line ${sanitizer.line}: ${sanitizer.method}`);
82
- }
83
- lines.push('');
84
- }
85
- // Verified taint flows
86
- if (result.taint.flows && result.taint.flows.length > 0) {
87
- lines.push('─'.repeat(60));
88
- lines.push('Verified Taint Flows (via Dataflow Analysis)');
89
- lines.push('─'.repeat(60));
90
- for (const flow of result.taint.flows.slice(0, 5)) {
91
- const confidence = Math.round(flow.confidence * 100);
92
- lines.push(` [${confidence}%] Line ${flow.source_line} → Line ${flow.sink_line}`);
93
- lines.push(` Source: ${flow.source_type}`);
94
- lines.push(` Sink: ${flow.sink_type}`);
95
- if (flow.path.length > 2) {
96
- lines.push(` Path: ${flow.path.map(s => s.variable).join(' → ')}`);
97
- }
98
- }
99
- if (result.taint.flows.length > 5) {
100
- lines.push(` ... and ${result.taint.flows.length - 5} more flow(s)`);
101
- }
102
- lines.push('');
103
- }
104
- // Inter-procedural taint analysis
105
- if (result.taint.interprocedural && result.taint.interprocedural.tainted_methods.length > 0) {
106
- lines.push('─'.repeat(60));
107
- lines.push('Inter-procedural Taint Flow');
108
- lines.push('─'.repeat(60));
109
- lines.push(` Tainted methods: ${result.taint.interprocedural.tainted_methods.length}`);
110
- if (result.taint.interprocedural.taint_bridges.length > 0) {
111
- lines.push(` Taint bridges: ${result.taint.interprocedural.taint_bridges.join(', ')}`);
112
- }
113
- if (result.taint.interprocedural.method_flows.length > 0) {
114
- lines.push(' Method call flows:');
115
- for (const flow of result.taint.interprocedural.method_flows.slice(0, 5)) {
116
- const arrow = flow.returns_taint ? '⇄' : '→';
117
- lines.push(` ${flow.caller}() ${arrow} ${flow.callee}() at line ${flow.call_line}`);
118
- }
119
- if (result.taint.interprocedural.method_flows.length > 5) {
120
- lines.push(` ... and ${result.taint.interprocedural.method_flows.length - 5} more`);
121
- }
122
- }
123
- lines.push('');
124
- }
125
- // Potential vulnerabilities
126
- lines.push('─'.repeat(60));
127
- lines.push(colors.bold('Potential Vulnerabilities'));
128
- lines.push('─'.repeat(60));
129
- const vulnCount = countVulnerabilities(result);
130
- if (vulnCount === 0) {
131
- lines.push(colors.success(' ✓ No potential vulnerabilities detected'));
132
- }
133
- else {
134
- lines.push(colors.warning(` ⚠ Found ${vulnCount} potential vulnerability path(s)`));
135
- lines.push('');
136
- // Group by sink type
137
- const sinksByType = groupBy(result.taint.sinks, 'type');
138
- for (const [type, sinks] of Object.entries(sinksByType)) {
139
- const cwe = sinks[0]?.cwe || 'Unknown';
140
- lines.push(colors.red(` [${cwe}] ${formatVulnType(type)}: ${sinks.length} sink(s)`));
141
- for (const sink of sinks) {
142
- lines.push(colors.gray(` - Line ${sink.line}: ${sink.location}`));
143
- }
144
- }
145
- }
146
- lines.push('');
147
- // Unresolved items
148
- if (result.unresolved.length > 0) {
149
- lines.push('─'.repeat(60));
150
- lines.push('Items Requiring Review');
151
- lines.push('─'.repeat(60));
152
- for (const item of result.unresolved.slice(0, 5)) {
153
- lines.push(` [${item.type}] Line ${item.context.line}: ${item.reason}`);
154
- }
155
- if (result.unresolved.length > 5) {
156
- lines.push(` ... and ${result.unresolved.length - 5} more`);
157
- }
158
- lines.push('');
159
- }
160
- // Summary
161
- lines.push(colors.cyan('═'.repeat(60)));
162
- const summaryColor = vulnCount > 0 ? colors.warning : colors.success;
163
- lines.push(summaryColor(`Summary: ${result.taint.sources.length} sources, ${result.taint.sinks.length} sinks, ${vulnCount} potential vulns`));
164
- lines.push(colors.cyan('═'.repeat(60)));
165
- lines.push('');
166
- return lines.join('\n');
167
- }
168
- /**
169
- * Format a taint source for display.
170
- */
171
- function formatSource(source) {
172
- const severity = formatSeverity(source.severity);
173
- return ` ${severity} Line ${source.line}: [${source.type}] ${source.location}`;
174
- }
175
- /**
176
- * Format a taint sink for display.
177
- */
178
- function formatSink(sink) {
179
- return ` [${sink.cwe}] Line ${sink.line}: [${sink.type}] ${sink.location}`;
180
- }
181
- /**
182
- * Format severity with indicator and color.
183
- */
184
- function formatSeverity(severity) {
185
- switch (severity) {
186
- case 'critical':
187
- return colors.critical('[!!!]');
188
- case 'high':
189
- return colors.high('[!! ]');
190
- case 'medium':
191
- return colors.medium('[! ]');
192
- case 'low':
193
- return colors.low('[ ]');
194
- default:
195
- return colors.gray('[ ]');
196
- }
197
- }
198
- /**
199
- * Format vulnerability type for display.
200
- */
201
- function formatVulnType(type) {
202
- const names = {
203
- sql_injection: 'SQL Injection',
204
- command_injection: 'Command Injection',
205
- xss: 'Cross-Site Scripting (XSS)',
206
- path_traversal: 'Path Traversal',
207
- xxe: 'XML External Entity (XXE)',
208
- deserialization: 'Unsafe Deserialization',
209
- ldap_injection: 'LDAP Injection',
210
- xpath_injection: 'XPath Injection',
211
- ssrf: 'Server-Side Request Forgery (SSRF)',
212
- code_injection: 'Code Injection',
213
- regex_injection: 'Regular Expression Injection (ReDoS)',
214
- };
215
- return names[type] || type;
216
- }
217
- /**
218
- * Count potential vulnerabilities (sources that could reach sinks).
219
- */
220
- function countVulnerabilities(result) {
221
- // Simple heuristic: if we have both sources and sinks, count the sinks
222
- if (result.taint.sources.length > 0 && result.taint.sinks.length > 0) {
223
- return result.taint.sinks.length;
224
- }
225
- return 0;
226
- }
227
- /**
228
- * Group array by key.
229
- */
230
- function groupBy(array, key) {
231
- return array.reduce((result, item) => {
232
- const k = String(item[key]);
233
- if (!result[k]) {
234
- result[k] = [];
235
- }
236
- result[k].push(item);
237
- return result;
238
- }, {});
239
- }
240
- //# sourceMappingURL=summary.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"summary.js","sourceRoot":"","sources":["../../../src/cli/formatters/summary.ts"],"names":[],"mappings":"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"}
@@ -1,11 +0,0 @@
1
- /**
2
- * Two-Phase Project Summary Formatter
3
- *
4
- * Outputs a human-readable summary of two-phase LLM-enhanced project analysis.
5
- */
6
- import type { TwoPhaseProjectAnalysis } from '../../project/index.js';
7
- /**
8
- * Format two-phase project analysis as human-readable summary.
9
- */
10
- export declare function formatTwoPhaseProjectSummary(result: TwoPhaseProjectAnalysis): string;
11
- //# sourceMappingURL=two-phase-summary.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"two-phase-summary.d.ts","sourceRoot":"","sources":["../../../src/cli/formatters/two-phase-summary.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,uBAAuB,EAAsB,MAAM,wBAAwB,CAAC;AAG1F;;GAEG;AACH,wBAAgB,4BAA4B,CAAC,MAAM,EAAE,uBAAuB,GAAG,MAAM,CA6JpF"}
@@ -1,188 +0,0 @@
1
- /**
2
- * Two-Phase Project Summary Formatter
3
- *
4
- * Outputs a human-readable summary of two-phase LLM-enhanced project analysis.
5
- */
6
- import { colors } from '../colors.js';
7
- /**
8
- * Format two-phase project analysis as human-readable summary.
9
- */
10
- export function formatTwoPhaseProjectSummary(result) {
11
- const lines = [];
12
- // Header
13
- lines.push('');
14
- lines.push(colors.cyan('═'.repeat(70)));
15
- lines.push(colors.bold(' Circle-IR Two-Phase Project Analysis Report'));
16
- lines.push(colors.cyan('═'.repeat(70)));
17
- lines.push('');
18
- // Project info
19
- lines.push(`Project: ${result.meta.name}`);
20
- lines.push(`Root: ${result.meta.root}`);
21
- lines.push(`Language: ${result.meta.language}`);
22
- if (result.meta.framework) {
23
- lines.push(`Framework: ${result.meta.framework}${result.meta.framework_version ? ` ${result.meta.framework_version}` : ''}`);
24
- }
25
- lines.push(`Total Files: ${result.meta.total_files}`);
26
- lines.push(`Total Lines: ${result.meta.total_loc}`);
27
- lines.push(`Analyzed: ${result.meta.analyzed_at}`);
28
- lines.push('');
29
- // Timing
30
- lines.push('─'.repeat(70));
31
- lines.push('Analysis Timing');
32
- lines.push('─'.repeat(70));
33
- lines.push(` Phase 1 (per-file): ${(result.timing.phase1TotalMs / 1000).toFixed(1)}s`);
34
- lines.push(` Phase 2 (cross-file): ${(result.timing.phase2TotalMs / 1000).toFixed(1)}s`);
35
- lines.push(` Total: ${(result.timing.totalMs / 1000).toFixed(1)}s`);
36
- lines.push('');
37
- // LLM Enrichment summary
38
- lines.push('─'.repeat(70));
39
- lines.push('LLM Enrichment (Phase 1)');
40
- lines.push('─'.repeat(70));
41
- const enrichedFiles = result.enrichedFiles.filter(f => f.enrichment);
42
- const totalAdditionalSources = enrichedFiles.reduce((sum, f) => sum + (f.enrichment?.additionalSources?.length || 0), 0);
43
- const totalAdditionalSinks = enrichedFiles.reduce((sum, f) => sum + (f.enrichment?.additionalSinks?.length || 0), 0);
44
- lines.push(` Files with LLM enrichment: ${enrichedFiles.length}`);
45
- lines.push(` LLM-discovered sources: ${totalAdditionalSources}`);
46
- lines.push(` LLM-discovered sinks: ${totalAdditionalSinks}`);
47
- // File roles
48
- const roleGroups = {};
49
- for (const f of enrichedFiles) {
50
- const role = f.enrichment?.role?.role || 'unknown';
51
- if (!roleGroups[role])
52
- roleGroups[role] = [];
53
- roleGroups[role].push(f.file);
54
- }
55
- const rolesSorted = Object.entries(roleGroups).sort((a, b) => b[1].length - a[1].length);
56
- if (rolesSorted.length > 0) {
57
- lines.push(' File roles:');
58
- for (const [role, files] of rolesSorted.slice(0, 5)) {
59
- lines.push(` ${role}: ${files.length} file(s)`);
60
- }
61
- }
62
- lines.push('');
63
- // Cross-File Taint Flows (Phase 2)
64
- lines.push('─'.repeat(70));
65
- lines.push(colors.bold('Cross-File Taint Flows (Phase 2)'));
66
- lines.push('─'.repeat(70));
67
- if (result.crossFileFlows.length === 0) {
68
- lines.push(colors.success(' No cross-file taint flows detected'));
69
- }
70
- else {
71
- lines.push(colors.warning(` Found ${result.crossFileFlows.length} cross-file flow(s)`));
72
- lines.push('');
73
- for (const flow of result.crossFileFlows.slice(0, 10)) {
74
- lines.push(formatCrossFileFlow(flow));
75
- lines.push('');
76
- }
77
- if (result.crossFileFlows.length > 10) {
78
- lines.push(` ... and ${result.crossFileFlows.length - 10} more flow(s)`);
79
- }
80
- }
81
- lines.push('');
82
- // Standard taint paths
83
- if (result.taint_paths.length > 0) {
84
- lines.push('─'.repeat(70));
85
- lines.push('Static Taint Paths');
86
- lines.push('─'.repeat(70));
87
- lines.push(` Total paths: ${result.taint_paths.length}`);
88
- for (const path of result.taint_paths.slice(0, 5)) {
89
- const sanitized = path.sanitizers_in_path.length > 0 ? ' [SANITIZED]' : '';
90
- const confidence = Math.round(path.confidence * 100);
91
- lines.push(` [${path.sink.cwe}] ${path.source.file}:${path.source.line} → ${path.sink.file}:${path.sink.line}${sanitized} (${confidence}%)`);
92
- }
93
- if (result.taint_paths.length > 5) {
94
- lines.push(` ... and ${result.taint_paths.length - 5} more path(s)`);
95
- }
96
- lines.push('');
97
- }
98
- // Security Findings
99
- lines.push('─'.repeat(70));
100
- lines.push('Security Findings');
101
- lines.push('─'.repeat(70));
102
- if (result.findings.length === 0) {
103
- lines.push(colors.success(' No security findings'));
104
- }
105
- else {
106
- // Group by severity
107
- const bySeverity = groupBy(result.findings, f => f.severity);
108
- const critical = bySeverity['critical'] || [];
109
- const high = bySeverity['high'] || [];
110
- const medium = bySeverity['medium'] || [];
111
- const low = bySeverity['low'] || [];
112
- if (critical.length > 0)
113
- lines.push(colors.critical(` Critical: ${critical.length}`));
114
- if (high.length > 0)
115
- lines.push(colors.high(` High: ${high.length}`));
116
- if (medium.length > 0)
117
- lines.push(colors.medium(` Medium: ${medium.length}`));
118
- if (low.length > 0)
119
- lines.push(colors.low(` Low: ${low.length}`));
120
- lines.push('');
121
- // Show top findings
122
- for (const finding of result.findings.slice(0, 10)) {
123
- const severity = formatSeverity(finding.severity);
124
- const exploitable = finding.exploitable ? colors.critical(' [EXPLOITABLE]') : '';
125
- lines.push(` ${severity} [${finding.cwe}] ${finding.type}${exploitable}`);
126
- lines.push(` Source: ${finding.source.file}:${finding.source.line}`);
127
- lines.push(` Sink: ${finding.sink.file}:${finding.sink.line}`);
128
- lines.push(` ${finding.explanation}`);
129
- lines.push('');
130
- }
131
- if (result.findings.length > 10) {
132
- lines.push(` ... and ${result.findings.length - 10} more finding(s)`);
133
- }
134
- }
135
- lines.push('');
136
- // Summary
137
- lines.push(colors.cyan('═'.repeat(70)));
138
- const vulnCount = result.findings.length + result.crossFileFlows.length;
139
- const summaryColor = vulnCount > 0 ? colors.warning : colors.success;
140
- lines.push(summaryColor(`Summary: ${result.meta.total_files} files, ${result.crossFileFlows.length} cross-file flows, ${result.findings.length} findings`));
141
- lines.push(colors.cyan('═'.repeat(70)));
142
- lines.push('');
143
- return lines.join('\n');
144
- }
145
- /**
146
- * Format a cross-file taint flow.
147
- */
148
- function formatCrossFileFlow(flow) {
149
- const confidencePercent = Math.round(flow.confidence * 100);
150
- const lines = [];
151
- lines.push(colors.warning(` [${confidencePercent}%] Cross-File Flow [${flow.sink.cwe}]`));
152
- lines.push(` Source: ${flow.source.file}:${flow.source.line}`);
153
- lines.push(` ${flow.source.code || flow.source.type}`);
154
- lines.push(` Sink: ${flow.sink.file}:${flow.sink.line}`);
155
- lines.push(` ${flow.sink.code || flow.sink.type}`);
156
- return lines.join('\n');
157
- }
158
- /**
159
- * Format severity with indicator and color.
160
- */
161
- function formatSeverity(severity) {
162
- switch (severity) {
163
- case 'critical':
164
- return colors.critical('[!!!!]');
165
- case 'high':
166
- return colors.high('[!!! ]');
167
- case 'medium':
168
- return colors.medium('[!! ]');
169
- case 'low':
170
- return colors.low('[! ]');
171
- default:
172
- return colors.gray('[ ]');
173
- }
174
- }
175
- /**
176
- * Group array by key function.
177
- */
178
- function groupBy(array, keyFn) {
179
- return array.reduce((result, item) => {
180
- const key = keyFn(item);
181
- if (!result[key]) {
182
- result[key] = [];
183
- }
184
- result[key].push(item);
185
- return result;
186
- }, {});
187
- }
188
- //# sourceMappingURL=two-phase-summary.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"two-phase-summary.js","sourceRoot":"","sources":["../../../src/cli/formatters/two-phase-summary.ts"],"names":[],"mappings":"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"}
@@ -1,10 +0,0 @@
1
- #!/usr/bin/env node
2
- /**
3
- * Circle-IR CLI entry point.
4
- *
5
- * Built on Commander — each subcommand carries its own help, options, and
6
- * examples. The legacy `parseArgs` switch parser in `args.ts` is preserved for
7
- * downstream wrappers (cognium-ai) that still call it directly.
8
- */
9
- export {};
10
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":";AACA;;;;;;GAMG"}
package/dist/cli/index.js DELETED
@@ -1,72 +0,0 @@
1
- #!/usr/bin/env node
2
- /**
3
- * Circle-IR CLI entry point.
4
- *
5
- * Built on Commander — each subcommand carries its own help, options, and
6
- * examples. The legacy `parseArgs` switch parser in `args.ts` is preserved for
7
- * downstream wrappers (cognium-ai) that still call it directly.
8
- */
9
- import { configureLogger, logger } from '../utils/logger.js';
10
- import { buildProgram } from './program.js';
11
- import { executeAnalyze } from './commands/analyze.js';
12
- import { executeBenchmark } from './commands/benchmark.js';
13
- import { executeScan } from './commands/scan.js';
14
- import { executeHealth } from './commands/health.js';
15
- import { executeSecrets } from './commands/secrets.js';
16
- import { executeDeadCode } from './commands/dead-code.js';
17
- import { executeGenerateSpec } from './commands/generate-spec.js';
18
- import { executeAnalyzeSkill } from './commands/analyze-skill.js';
19
- import { executeMetrics } from './commands/metrics.js';
20
- import { executeTrust } from './commands/trust.js';
21
- import { executeCompare } from './commands/compare.js';
22
- import { executeQuality } from './commands/quality.js';
23
- import { executeUnderstand } from './commands/understand.js';
24
- import { executeSpecDiff } from './commands/spec-diff.js';
25
- import { executeCluster } from './commands/cluster.js';
26
- function configureFromArgs(args) {
27
- if (args.logLevel) {
28
- configureLogger({ level: args.logLevel });
29
- }
30
- else if (args.quiet) {
31
- configureLogger({ level: 'silent' });
32
- }
33
- logger.debug('CLI started', { command: args.command });
34
- }
35
- const program = buildProgram({
36
- analyze: async (args) => { configureFromArgs(args); return executeAnalyze(args); },
37
- scan: async (args) => { configureFromArgs(args); return executeScan(args); },
38
- health: async (args) => { configureFromArgs(args); return executeHealth(args); },
39
- secrets: async (args) => { configureFromArgs(args); return executeSecrets(args); },
40
- deadCode: async (args) => { configureFromArgs(args); return executeDeadCode(args); },
41
- generateSpec: async (args) => { configureFromArgs(args); return executeGenerateSpec(args); },
42
- analyzeSkill: async (skillPath, args) => {
43
- configureFromArgs(args);
44
- let skillFormat = 'text';
45
- if (args.format === 'json')
46
- skillFormat = 'json';
47
- else if (args.format === 'markdown')
48
- skillFormat = 'markdown';
49
- await executeAnalyzeSkill(skillPath, {
50
- format: skillFormat,
51
- output: args.output || undefined,
52
- crossArtifact: args.crossArtifact !== false,
53
- verification: args.verification !== false,
54
- minConfidence: args.minConfidence,
55
- minSeverity: args.minSeverity,
56
- verbose: !args.quiet,
57
- });
58
- },
59
- metrics: async (args) => { configureFromArgs(args); return executeMetrics(args); },
60
- trust: async (args) => { configureFromArgs(args); return executeTrust(args); },
61
- compare: async (args) => { configureFromArgs(args); return executeCompare(args); },
62
- quality: async (args) => { configureFromArgs(args); return executeQuality(args); },
63
- understand: async (args) => { configureFromArgs(args); return executeUnderstand(args); },
64
- specDiff: async (args) => { configureFromArgs(args); return executeSpecDiff(args); },
65
- cluster: async (args) => { configureFromArgs(args); return executeCluster(args); },
66
- benchmark: async (args) => { configureFromArgs(args); return executeBenchmark(args); },
67
- });
68
- program.parseAsync(process.argv).catch((error) => {
69
- console.error('Fatal error:', error instanceof Error ? error.message : error);
70
- process.exit(1);
71
- });
72
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}