agentlint 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/LICENSE +190 -0
  3. package/README.md +246 -0
  4. package/dist/cli/index.d.ts +7 -0
  5. package/dist/cli/index.d.ts.map +1 -0
  6. package/dist/cli/index.js +351 -0
  7. package/dist/cli/index.js.map +1 -0
  8. package/dist/diff/index.d.ts +16 -0
  9. package/dist/diff/index.d.ts.map +1 -0
  10. package/dist/diff/index.js +204 -0
  11. package/dist/diff/index.js.map +1 -0
  12. package/dist/index.d.ts +21 -0
  13. package/dist/index.d.ts.map +1 -0
  14. package/dist/index.js +55 -0
  15. package/dist/index.js.map +1 -0
  16. package/dist/ir/index.d.ts +2 -0
  17. package/dist/ir/index.d.ts.map +1 -0
  18. package/dist/ir/index.js +18 -0
  19. package/dist/ir/index.js.map +1 -0
  20. package/dist/ir/types.d.ts +369 -0
  21. package/dist/ir/types.d.ts.map +1 -0
  22. package/dist/ir/types.js +12 -0
  23. package/dist/ir/types.js.map +1 -0
  24. package/dist/parsers/base.d.ts +104 -0
  25. package/dist/parsers/base.d.ts.map +1 -0
  26. package/dist/parsers/base.js +373 -0
  27. package/dist/parsers/base.js.map +1 -0
  28. package/dist/parsers/claude.d.ts +30 -0
  29. package/dist/parsers/claude.d.ts.map +1 -0
  30. package/dist/parsers/claude.js +453 -0
  31. package/dist/parsers/claude.js.map +1 -0
  32. package/dist/parsers/cursor.d.ts +24 -0
  33. package/dist/parsers/cursor.d.ts.map +1 -0
  34. package/dist/parsers/cursor.js +305 -0
  35. package/dist/parsers/cursor.js.map +1 -0
  36. package/dist/parsers/factory.d.ts +30 -0
  37. package/dist/parsers/factory.d.ts.map +1 -0
  38. package/dist/parsers/factory.js +78 -0
  39. package/dist/parsers/factory.js.map +1 -0
  40. package/dist/parsers/index.d.ts +5 -0
  41. package/dist/parsers/index.d.ts.map +1 -0
  42. package/dist/parsers/index.js +21 -0
  43. package/dist/parsers/index.js.map +1 -0
  44. package/dist/policy/index.d.ts +3 -0
  45. package/dist/policy/index.d.ts.map +1 -0
  46. package/dist/policy/index.js +19 -0
  47. package/dist/policy/index.js.map +1 -0
  48. package/dist/policy/loader.d.ts +23 -0
  49. package/dist/policy/loader.d.ts.map +1 -0
  50. package/dist/policy/loader.js +252 -0
  51. package/dist/policy/loader.js.map +1 -0
  52. package/dist/policy/types.d.ts +79 -0
  53. package/dist/policy/types.d.ts.map +1 -0
  54. package/dist/policy/types.js +99 -0
  55. package/dist/policy/types.js.map +1 -0
  56. package/dist/reports/index.d.ts +14 -0
  57. package/dist/reports/index.d.ts.map +1 -0
  58. package/dist/reports/index.js +54 -0
  59. package/dist/reports/index.js.map +1 -0
  60. package/dist/reports/json.d.ts +16 -0
  61. package/dist/reports/json.d.ts.map +1 -0
  62. package/dist/reports/json.js +126 -0
  63. package/dist/reports/json.js.map +1 -0
  64. package/dist/reports/sarif.d.ts +20 -0
  65. package/dist/reports/sarif.d.ts.map +1 -0
  66. package/dist/reports/sarif.js +169 -0
  67. package/dist/reports/sarif.js.map +1 -0
  68. package/dist/reports/text.d.ts +25 -0
  69. package/dist/reports/text.d.ts.map +1 -0
  70. package/dist/reports/text.js +283 -0
  71. package/dist/reports/text.js.map +1 -0
  72. package/dist/reports/types.d.ts +88 -0
  73. package/dist/reports/types.d.ts.map +1 -0
  74. package/dist/reports/types.js +6 -0
  75. package/dist/reports/types.js.map +1 -0
  76. package/dist/rules/base.d.ts +16 -0
  77. package/dist/rules/base.d.ts.map +1 -0
  78. package/dist/rules/base.js +48 -0
  79. package/dist/rules/base.js.map +1 -0
  80. package/dist/rules/engine.d.ts +61 -0
  81. package/dist/rules/engine.d.ts.map +1 -0
  82. package/dist/rules/engine.js +195 -0
  83. package/dist/rules/engine.js.map +1 -0
  84. package/dist/rules/execution.d.ts +33 -0
  85. package/dist/rules/execution.d.ts.map +1 -0
  86. package/dist/rules/execution.js +154 -0
  87. package/dist/rules/execution.js.map +1 -0
  88. package/dist/rules/filesystem.d.ts +36 -0
  89. package/dist/rules/filesystem.d.ts.map +1 -0
  90. package/dist/rules/filesystem.js +227 -0
  91. package/dist/rules/filesystem.js.map +1 -0
  92. package/dist/rules/hook.d.ts +25 -0
  93. package/dist/rules/hook.d.ts.map +1 -0
  94. package/dist/rules/hook.js +112 -0
  95. package/dist/rules/hook.js.map +1 -0
  96. package/dist/rules/index.d.ts +12 -0
  97. package/dist/rules/index.d.ts.map +1 -0
  98. package/dist/rules/index.js +28 -0
  99. package/dist/rules/index.js.map +1 -0
  100. package/dist/rules/instruction.d.ts +25 -0
  101. package/dist/rules/instruction.d.ts.map +1 -0
  102. package/dist/rules/instruction.js +162 -0
  103. package/dist/rules/instruction.js.map +1 -0
  104. package/dist/rules/network.d.ts +33 -0
  105. package/dist/rules/network.d.ts.map +1 -0
  106. package/dist/rules/network.js +145 -0
  107. package/dist/rules/network.js.map +1 -0
  108. package/dist/rules/observability.d.ts +25 -0
  109. package/dist/rules/observability.d.ts.map +1 -0
  110. package/dist/rules/observability.js +105 -0
  111. package/dist/rules/observability.js.map +1 -0
  112. package/dist/rules/scope.d.ts +37 -0
  113. package/dist/rules/scope.d.ts.map +1 -0
  114. package/dist/rules/scope.js +173 -0
  115. package/dist/rules/scope.js.map +1 -0
  116. package/dist/rules/secrets.d.ts +35 -0
  117. package/dist/rules/secrets.d.ts.map +1 -0
  118. package/dist/rules/secrets.js +273 -0
  119. package/dist/rules/secrets.js.map +1 -0
  120. package/dist/rules/types.d.ts +58 -0
  121. package/dist/rules/types.d.ts.map +1 -0
  122. package/dist/rules/types.js +6 -0
  123. package/dist/rules/types.js.map +1 -0
  124. package/dist/scanner.d.ts +61 -0
  125. package/dist/scanner.d.ts.map +1 -0
  126. package/dist/scanner.js +441 -0
  127. package/dist/scanner.js.map +1 -0
  128. package/dist/utils/hash.d.ts +28 -0
  129. package/dist/utils/hash.d.ts.map +1 -0
  130. package/dist/utils/hash.js +94 -0
  131. package/dist/utils/hash.js.map +1 -0
  132. package/dist/utils/index.d.ts +2 -0
  133. package/dist/utils/index.d.ts.map +1 -0
  134. package/dist/utils/index.js +18 -0
  135. package/dist/utils/index.js.map +1 -0
  136. package/package.json +76 -0
@@ -0,0 +1,252 @@
1
+ "use strict";
2
+ /**
3
+ * Policy configuration loader
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.loadPolicy = loadPolicy;
40
+ exports.validatePolicy = validatePolicy;
41
+ exports.generateDefaultConfig = generateDefaultConfig;
42
+ const fs = __importStar(require("fs"));
43
+ const path = __importStar(require("path"));
44
+ const YAML = __importStar(require("yaml"));
45
+ const types_1 = require("./types");
46
+ const CONFIG_FILE_NAMES = [
47
+ 'agentlint.yaml',
48
+ 'agentlint.yml',
49
+ '.agentlint.yaml',
50
+ '.agentlint.yml',
51
+ '.agentlint/agentlint.yaml',
52
+ '.agentlint/agentlint.yml',
53
+ ];
54
+ /**
55
+ * Load policy configuration from file or defaults
56
+ */
57
+ function loadPolicy(configPath, workingDir) {
58
+ const errors = [];
59
+ const warnings = [];
60
+ const cwd = workingDir || process.cwd();
61
+ // If explicit config path provided
62
+ if (configPath) {
63
+ const absolutePath = path.isAbsolute(configPath) ? configPath : path.join(cwd, configPath);
64
+ if (!fs.existsSync(absolutePath)) {
65
+ errors.push(`Configuration file not found: ${absolutePath}`);
66
+ return { config: types_1.DEFAULT_POLICY, path: null, errors, warnings };
67
+ }
68
+ try {
69
+ const content = fs.readFileSync(absolutePath, 'utf-8');
70
+ const parsed = YAML.parse(content);
71
+ const config = mergeWithDefaults(parsed, warnings);
72
+ return { config, path: absolutePath, errors, warnings };
73
+ }
74
+ catch (e) {
75
+ const msg = e instanceof Error ? e.message : String(e);
76
+ errors.push(`Failed to parse configuration file: ${msg}`);
77
+ return { config: types_1.DEFAULT_POLICY, path: null, errors, warnings };
78
+ }
79
+ }
80
+ // Search for config file
81
+ for (const fileName of CONFIG_FILE_NAMES) {
82
+ const filePath = path.join(cwd, fileName);
83
+ if (fs.existsSync(filePath)) {
84
+ try {
85
+ const content = fs.readFileSync(filePath, 'utf-8');
86
+ const parsed = YAML.parse(content);
87
+ const config = mergeWithDefaults(parsed, warnings);
88
+ return { config, path: filePath, errors, warnings };
89
+ }
90
+ catch (e) {
91
+ const msg = e instanceof Error ? e.message : String(e);
92
+ errors.push(`Failed to parse configuration file ${filePath}: ${msg}`);
93
+ return { config: types_1.DEFAULT_POLICY, path: null, errors, warnings };
94
+ }
95
+ }
96
+ }
97
+ // No config file found, use defaults
98
+ return { config: types_1.DEFAULT_POLICY, path: null, errors, warnings };
99
+ }
100
+ /**
101
+ * Merge user configuration with defaults
102
+ */
103
+ function mergeWithDefaults(userConfig, warnings) {
104
+ const config = JSON.parse(JSON.stringify(types_1.DEFAULT_POLICY));
105
+ if (!userConfig) {
106
+ return config;
107
+ }
108
+ // Validate version
109
+ if (userConfig.version !== undefined && userConfig.version !== 1) {
110
+ warnings.push(`Unknown policy version: ${userConfig.version}. Using defaults for unknown fields.`);
111
+ }
112
+ // Merge scan section
113
+ if (userConfig.scan) {
114
+ Object.assign(config.scan, userConfig.scan);
115
+ }
116
+ // Merge policy section
117
+ if (userConfig.policy) {
118
+ Object.assign(config.policy, userConfig.policy);
119
+ if (userConfig.policy.tags) {
120
+ Object.assign(config.policy.tags, userConfig.policy.tags);
121
+ }
122
+ }
123
+ // Merge rules section
124
+ if (userConfig.rules) {
125
+ if (userConfig.rules.enable) {
126
+ config.rules.enable = userConfig.rules.enable;
127
+ }
128
+ if (userConfig.rules.disable) {
129
+ config.rules.disable = userConfig.rules.disable;
130
+ }
131
+ if (userConfig.rules.severity_overrides) {
132
+ Object.assign(config.rules.severity_overrides, userConfig.rules.severity_overrides);
133
+ }
134
+ if (userConfig.rules.group_overrides) {
135
+ Object.assign(config.rules.group_overrides, userConfig.rules.group_overrides);
136
+ }
137
+ if (userConfig.rules.confidence_overrides) {
138
+ Object.assign(config.rules.confidence_overrides, userConfig.rules.confidence_overrides);
139
+ }
140
+ }
141
+ // Merge capabilities section
142
+ if (userConfig.capabilities) {
143
+ Object.assign(config.capabilities, userConfig.capabilities);
144
+ }
145
+ // Merge diff section
146
+ if (userConfig.diff) {
147
+ Object.assign(config.diff, userConfig.diff);
148
+ if (userConfig.diff.compare) {
149
+ Object.assign(config.diff.compare, userConfig.diff.compare);
150
+ }
151
+ }
152
+ // Merge baseline section
153
+ if (userConfig.baseline) {
154
+ Object.assign(config.baseline, userConfig.baseline);
155
+ }
156
+ // Merge output section
157
+ if (userConfig.output) {
158
+ Object.assign(config.output, userConfig.output);
159
+ }
160
+ // Merge meta section
161
+ if (userConfig.meta) {
162
+ Object.assign(config.meta, userConfig.meta);
163
+ }
164
+ return config;
165
+ }
166
+ /**
167
+ * Validate policy configuration
168
+ */
169
+ function validatePolicy(config) {
170
+ const errors = [];
171
+ // Validate severity values
172
+ const validSeverities = ['low', 'medium', 'high', 'none'];
173
+ if (!validSeverities.includes(config.policy.fail_on)) {
174
+ errors.push(`Invalid fail_on value: ${config.policy.fail_on}`);
175
+ }
176
+ if (!validSeverities.includes(config.policy.warn_on)) {
177
+ errors.push(`Invalid warn_on value: ${config.policy.warn_on}`);
178
+ }
179
+ // Validate confidence thresholds
180
+ if (config.policy.min_finding_confidence < 0 || config.policy.min_finding_confidence > 1) {
181
+ errors.push(`min_finding_confidence must be between 0 and 1`);
182
+ }
183
+ if (config.scan.min_parse_confidence < 0 || config.scan.min_parse_confidence > 1) {
184
+ errors.push(`min_parse_confidence must be between 0 and 1`);
185
+ }
186
+ // Validate tool mode
187
+ const validToolModes = ['auto', 'claude', 'cursor'];
188
+ if (!validToolModes.includes(config.scan.tool_mode)) {
189
+ errors.push(`Invalid tool_mode: ${config.scan.tool_mode}`);
190
+ }
191
+ // Validate output format
192
+ const validFormats = ['text', 'json', 'sarif'];
193
+ if (!validFormats.includes(config.output.format)) {
194
+ errors.push(`Invalid output format: ${config.output.format}`);
195
+ }
196
+ return errors;
197
+ }
198
+ /**
199
+ * Generate default configuration file content
200
+ */
201
+ function generateDefaultConfig() {
202
+ return `# AgentLint Configuration
203
+ # https://github.com/agentlint/agentlint
204
+
205
+ version: 1
206
+
207
+ scan:
208
+ include:
209
+ - ".claude/**"
210
+ - ".cursorrules"
211
+ - "CLAUDE.md"
212
+ - "AGENTS.md"
213
+ exclude:
214
+ - "**/.git/**"
215
+ - "**/node_modules/**"
216
+ tool_mode: auto
217
+ max_files: 2000
218
+
219
+ policy:
220
+ fail_on: high
221
+ warn_on: medium
222
+ min_finding_confidence: 0.6
223
+ strict: false
224
+
225
+ rules:
226
+ disable: []
227
+ # severity_overrides:
228
+ # FS-001: high
229
+
230
+ capabilities:
231
+ fail_on_new_dynamic_shell: true
232
+ fail_on_sensitive_path_write: true
233
+ sensitive_paths:
234
+ - ".github/workflows/**"
235
+ - ".git/**"
236
+ - ".env"
237
+
238
+ diff:
239
+ enabled: true
240
+ fail_on:
241
+ - capability_expansion
242
+ - shell_dynamic_introduced
243
+ - context_change_to_hook
244
+
245
+ output:
246
+ format: text
247
+ color: auto
248
+ include_recommendations: true
249
+ include_permission_manifest: true
250
+ `;
251
+ }
252
+ //# sourceMappingURL=loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/policy/loader.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,79 @@
1
+ /**
2
+ * Policy configuration types
3
+ */
4
+ import { Severity } from '../ir/types';
5
+ export interface PolicyConfig {
6
+ version: number;
7
+ scan: {
8
+ root?: string;
9
+ include: string[];
10
+ exclude: string[];
11
+ tool_mode: 'auto' | 'claude' | 'cursor';
12
+ max_files: number;
13
+ timeout: string;
14
+ min_parse_confidence: number;
15
+ };
16
+ policy: {
17
+ ci_mode: boolean;
18
+ fail_on: Severity | 'none';
19
+ warn_on: Severity | 'none';
20
+ min_finding_confidence: number;
21
+ treat_parse_failed_as: 'pass' | 'warn' | 'fail';
22
+ no_supported_files_as: 'pass' | 'warn' | 'fail';
23
+ strict: boolean;
24
+ tags: {
25
+ fail_if_any: string[];
26
+ warn_if_any: string[];
27
+ ignore_if_any: string[];
28
+ };
29
+ };
30
+ rules: {
31
+ enable: string[];
32
+ disable: string[];
33
+ severity_overrides: Record<string, Severity>;
34
+ group_overrides: Record<string, Severity>;
35
+ confidence_overrides: Record<string, number>;
36
+ };
37
+ capabilities: {
38
+ fail_on_expansion: boolean;
39
+ fail_on_new_dynamic_shell: boolean;
40
+ fail_on_new_network_outbound: boolean;
41
+ fail_on_sensitive_path_write: boolean;
42
+ sensitive_paths: string[];
43
+ allowed_write_scopes: string[];
44
+ disallowed_write_scopes: string[];
45
+ allowed_network_domains: string[];
46
+ disallowed_network_domains: string[];
47
+ };
48
+ diff: {
49
+ enabled: boolean;
50
+ fail_on: string[];
51
+ warn_on: string[];
52
+ compare: {
53
+ normalize_globs: boolean;
54
+ normalize_domains: boolean;
55
+ normalize_commands: boolean;
56
+ };
57
+ };
58
+ baseline: {
59
+ enabled: boolean;
60
+ file: string;
61
+ mode: 'suppress_known' | 'require_no_new';
62
+ fingerprint: 'stable' | 'location' | 'content';
63
+ expires_days: number;
64
+ };
65
+ output: {
66
+ format: 'text' | 'json' | 'sarif';
67
+ color: 'auto' | 'always' | 'never';
68
+ include_recommendations: boolean;
69
+ include_permission_manifest: boolean;
70
+ include_ir: boolean;
71
+ };
72
+ meta: {
73
+ policy_name: string;
74
+ owner: string;
75
+ last_reviewed: string;
76
+ };
77
+ }
78
+ export declare const DEFAULT_POLICY: PolicyConfig;
79
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/policy/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,99 @@
1
+ "use strict";
2
+ /**
3
+ * Policy configuration types
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.DEFAULT_POLICY = void 0;
7
+ exports.DEFAULT_POLICY = {
8
+ version: 1,
9
+ scan: {
10
+ root: '.',
11
+ include: [
12
+ '.claude/**',
13
+ '.cursorrules',
14
+ 'CLAUDE.md',
15
+ 'AGENTS.md',
16
+ ],
17
+ exclude: [
18
+ '**/.git/**',
19
+ '**/node_modules/**',
20
+ ],
21
+ tool_mode: 'auto',
22
+ max_files: 2000,
23
+ timeout: '10s',
24
+ min_parse_confidence: 0.5,
25
+ },
26
+ policy: {
27
+ ci_mode: false,
28
+ fail_on: 'high',
29
+ warn_on: 'medium',
30
+ min_finding_confidence: 0.6,
31
+ treat_parse_failed_as: 'warn',
32
+ no_supported_files_as: 'pass',
33
+ strict: false,
34
+ tags: {
35
+ fail_if_any: [],
36
+ warn_if_any: [],
37
+ ignore_if_any: [],
38
+ },
39
+ },
40
+ rules: {
41
+ enable: [],
42
+ disable: [],
43
+ severity_overrides: {},
44
+ group_overrides: {},
45
+ confidence_overrides: {},
46
+ },
47
+ capabilities: {
48
+ fail_on_expansion: true,
49
+ fail_on_new_dynamic_shell: true,
50
+ fail_on_new_network_outbound: false,
51
+ fail_on_sensitive_path_write: true,
52
+ sensitive_paths: [
53
+ '.github/workflows/**',
54
+ '.git/**',
55
+ '.env',
56
+ '~/.ssh/**',
57
+ ],
58
+ allowed_write_scopes: [],
59
+ disallowed_write_scopes: [],
60
+ allowed_network_domains: [],
61
+ disallowed_network_domains: [],
62
+ },
63
+ diff: {
64
+ enabled: true,
65
+ fail_on: [
66
+ 'capability_expansion',
67
+ 'context_change_to_hook',
68
+ 'write_scope_widening_to_all',
69
+ ],
70
+ warn_on: [
71
+ 'new_medium_findings',
72
+ ],
73
+ compare: {
74
+ normalize_globs: true,
75
+ normalize_domains: true,
76
+ normalize_commands: true,
77
+ },
78
+ },
79
+ baseline: {
80
+ enabled: false,
81
+ file: '.agentlint/baseline.json',
82
+ mode: 'suppress_known',
83
+ fingerprint: 'stable',
84
+ expires_days: 30,
85
+ },
86
+ output: {
87
+ format: 'text',
88
+ color: 'auto',
89
+ include_recommendations: true,
90
+ include_permission_manifest: true,
91
+ include_ir: false,
92
+ },
93
+ meta: {
94
+ policy_name: 'default',
95
+ owner: '',
96
+ last_reviewed: '',
97
+ },
98
+ };
99
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/policy/types.ts"],"names":[],"mappings":";AAAA;;GAEG;;;AAsFU,QAAA,cAAc,GAAiB;IAC1C,OAAO,EAAE,CAAC;IAEV,IAAI,EAAE;QACJ,IAAI,EAAE,GAAG;QACT,OAAO,EAAE;YACP,YAAY;YACZ,cAAc;YACd,WAAW;YACX,WAAW;SACZ;QACD,OAAO,EAAE;YACP,YAAY;YACZ,oBAAoB;SACrB;QACD,SAAS,EAAE,MAAM;QACjB,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,KAAK;QACd,oBAAoB,EAAE,GAAG;KAC1B;IAED,MAAM,EAAE;QACN,OAAO,EAAE,KAAK;QACd,OAAO,EAAE,MAAM;QACf,OAAO,EAAE,QAAQ;QACjB,sBAAsB,EAAE,GAAG;QAC3B,qBAAqB,EAAE,MAAM;QAC7B,qBAAqB,EAAE,MAAM;QAC7B,MAAM,EAAE,KAAK;QACb,IAAI,EAAE;YACJ,WAAW,EAAE,EAAE;YACf,WAAW,EAAE,EAAE;YACf,aAAa,EAAE,EAAE;SAClB;KACF;IAED,KAAK,EAAE;QACL,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,EAAE;QACX,kBAAkB,EAAE,EAAE;QACtB,eAAe,EAAE,EAAE;QACnB,oBAAoB,EAAE,EAAE;KACzB;IAED,YAAY,EAAE;QACZ,iBAAiB,EAAE,IAAI;QACvB,yBAAyB,EAAE,IAAI;QAC/B,4BAA4B,EAAE,KAAK;QACnC,4BAA4B,EAAE,IAAI;QAClC,eAAe,EAAE;YACf,sBAAsB;YACtB,SAAS;YACT,MAAM;YACN,WAAW;SACZ;QACD,oBAAoB,EAAE,EAAE;QACxB,uBAAuB,EAAE,EAAE;QAC3B,uBAAuB,EAAE,EAAE;QAC3B,0BAA0B,EAAE,EAAE;KAC/B;IAED,IAAI,EAAE;QACJ,OAAO,EAAE,IAAI;QACb,OAAO,EAAE;YACP,sBAAsB;YACtB,wBAAwB;YACxB,6BAA6B;SAC9B;QACD,OAAO,EAAE;YACP,qBAAqB;SACtB;QACD,OAAO,EAAE;YACP,eAAe,EAAE,IAAI;YACrB,iBAAiB,EAAE,IAAI;YACvB,kBAAkB,EAAE,IAAI;SACzB;KACF;IAED,QAAQ,EAAE;QACR,OAAO,EAAE,KAAK;QACd,IAAI,EAAE,0BAA0B;QAChC,IAAI,EAAE,gBAAgB;QACtB,WAAW,EAAE,QAAQ;QACrB,YAAY,EAAE,EAAE;KACjB;IAED,MAAM,EAAE;QACN,MAAM,EAAE,MAAM;QACd,KAAK,EAAE,MAAM;QACb,uBAAuB,EAAE,IAAI;QAC7B,2BAA2B,EAAE,IAAI;QACjC,UAAU,EAAE,KAAK;KAClB;IAED,IAAI,EAAE;QACJ,WAAW,EAAE,SAAS;QACtB,KAAK,EAAE,EAAE;QACT,aAAa,EAAE,EAAE;KAClB;CACF,CAAC"}
@@ -0,0 +1,14 @@
1
+ export * from './types';
2
+ export * from './text';
3
+ export * from './json';
4
+ export * from './sarif';
5
+ import { ReportData, ReportOptions } from './types';
6
+ /**
7
+ * Generate a report in the specified format
8
+ */
9
+ export declare function generateReport(data: ReportData, options: ReportOptions): string;
10
+ /**
11
+ * Generate a diff report in the specified format
12
+ */
13
+ export declare function generateDiffReport(data: ReportData, options: ReportOptions): string;
14
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/reports/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AAExB,OAAO,EAAE,UAAU,EAAE,aAAa,EAAgB,MAAM,SAAS,CAAC;AAKlE;;GAEG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,aAAa,GAAG,MAAM,CAU/E;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,aAAa,GAAG,MAAM,CAUnF"}
@@ -0,0 +1,54 @@
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.generateReport = generateReport;
18
+ exports.generateDiffReport = generateDiffReport;
19
+ __exportStar(require("./types"), exports);
20
+ __exportStar(require("./text"), exports);
21
+ __exportStar(require("./json"), exports);
22
+ __exportStar(require("./sarif"), exports);
23
+ const text_1 = require("./text");
24
+ const json_1 = require("./json");
25
+ const sarif_1 = require("./sarif");
26
+ /**
27
+ * Generate a report in the specified format
28
+ */
29
+ function generateReport(data, options) {
30
+ switch (options.format) {
31
+ case 'json':
32
+ return new json_1.JsonReportGenerator(options).generate(data);
33
+ case 'sarif':
34
+ return new sarif_1.SarifReportGenerator(options).generate(data);
35
+ case 'text':
36
+ default:
37
+ return new text_1.TextReportGenerator(options).generate(data);
38
+ }
39
+ }
40
+ /**
41
+ * Generate a diff report in the specified format
42
+ */
43
+ function generateDiffReport(data, options) {
44
+ switch (options.format) {
45
+ case 'json':
46
+ return (0, json_1.generateDiffJsonReport)(data);
47
+ case 'sarif':
48
+ return (0, sarif_1.generateDiffSarifReport)(data);
49
+ case 'text':
50
+ default:
51
+ return (0, text_1.generateDiffTextReport)(data, options);
52
+ }
53
+ }
54
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/reports/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAaA,wCAUC;AAKD,gDAUC;AAtCD,0CAAwB;AACxB,yCAAuB;AACvB,yCAAuB;AACvB,0CAAwB;AAGxB,iCAAqE;AACrE,iCAAqE;AACrE,mCAAwE;AAExE;;GAEG;AACH,SAAgB,cAAc,CAAC,IAAgB,EAAE,OAAsB;IACrE,QAAQ,OAAO,CAAC,MAAM,EAAE,CAAC;QACvB,KAAK,MAAM;YACT,OAAO,IAAI,0BAAmB,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACzD,KAAK,OAAO;YACV,OAAO,IAAI,4BAAoB,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC1D,KAAK,MAAM,CAAC;QACZ;YACE,OAAO,IAAI,0BAAmB,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC3D,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAgB,kBAAkB,CAAC,IAAgB,EAAE,OAAsB;IACzE,QAAQ,OAAO,CAAC,MAAM,EAAE,CAAC;QACvB,KAAK,MAAM;YACT,OAAO,IAAA,6BAAsB,EAAC,IAAI,CAAC,CAAC;QACtC,KAAK,OAAO;YACV,OAAO,IAAA,+BAAuB,EAAC,IAAI,CAAC,CAAC;QACvC,KAAK,MAAM,CAAC;QACZ;YACE,OAAO,IAAA,6BAAsB,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACjD,CAAC;AACH,CAAC"}
@@ -0,0 +1,16 @@
1
+ /**
2
+ * JSON Report Generator
3
+ * Machine-readable output for CI/CD and dashboards
4
+ */
5
+ import { ReportData, ReportOptions } from './types';
6
+ export declare class JsonReportGenerator {
7
+ private options;
8
+ constructor(options: ReportOptions);
9
+ generate(data: ReportData): string;
10
+ private buildReport;
11
+ }
12
+ /**
13
+ * Generate JSON diff report
14
+ */
15
+ export declare function generateDiffJsonReport(data: ReportData): string;
16
+ //# sourceMappingURL=json.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"json.d.ts","sourceRoot":"","sources":["../../src/reports/json.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAOpD,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,OAAO,CAAgB;gBAEnB,OAAO,EAAE,aAAa;IAIlC,QAAQ,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM;IAKlC,OAAO,CAAC,WAAW;CA4CpB;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CA0B/D"}
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ /**
3
+ * JSON Report Generator
4
+ * Machine-readable output for CI/CD and dashboards
5
+ */
6
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ var desc = Object.getOwnPropertyDescriptor(m, k);
9
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
10
+ desc = { enumerable: true, get: function() { return m[k]; } };
11
+ }
12
+ Object.defineProperty(o, k2, desc);
13
+ }) : (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ o[k2] = m[k];
16
+ }));
17
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
18
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
19
+ }) : function(o, v) {
20
+ o["default"] = v;
21
+ });
22
+ var __importStar = (this && this.__importStar) || (function () {
23
+ var ownKeys = function(o) {
24
+ ownKeys = Object.getOwnPropertyNames || function (o) {
25
+ var ar = [];
26
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
27
+ return ar;
28
+ };
29
+ return ownKeys(o);
30
+ };
31
+ return function (mod) {
32
+ if (mod && mod.__esModule) return mod;
33
+ var result = {};
34
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
35
+ __setModuleDefault(result, mod);
36
+ return result;
37
+ };
38
+ })();
39
+ Object.defineProperty(exports, "__esModule", { value: true });
40
+ exports.JsonReportGenerator = void 0;
41
+ exports.generateDiffJsonReport = generateDiffJsonReport;
42
+ const types_1 = require("../ir/types");
43
+ const os = __importStar(require("os"));
44
+ // Package version (would normally come from package.json)
45
+ const TOOL_VERSION = '0.1.0';
46
+ class JsonReportGenerator {
47
+ options;
48
+ constructor(options) {
49
+ this.options = options;
50
+ }
51
+ generate(data) {
52
+ const report = this.buildReport(data);
53
+ return JSON.stringify(report, null, 2);
54
+ }
55
+ buildReport(data) {
56
+ const report = {
57
+ report_version: types_1.REPORT_VERSION,
58
+ schema_version: types_1.IR_SCHEMA_VERSION,
59
+ generated_at: new Date().toISOString(),
60
+ tool: {
61
+ name: 'agentlint',
62
+ version: TOOL_VERSION,
63
+ build: {
64
+ os: os.platform(),
65
+ arch: os.arch(),
66
+ },
67
+ },
68
+ inputs: data.report.inputs,
69
+ policy: data.report.policy,
70
+ summary: data.report.summary,
71
+ documents: data.documents,
72
+ capability_summary: data.capabilitySummary,
73
+ recommended_permissions: data.recommendedPermissions,
74
+ findings: data.findings,
75
+ diff: data.diff || null,
76
+ errors: data.report.errors || [],
77
+ annotations: data.report.annotations || {},
78
+ };
79
+ // Remove IR data if not requested
80
+ if (!this.options.includeIR) {
81
+ // The documents array already contains summaries, not full IR
82
+ }
83
+ // Remove recommendations if not requested
84
+ if (!this.options.includeRecommendations) {
85
+ for (const finding of report.findings) {
86
+ finding.recommendation = '';
87
+ }
88
+ }
89
+ // Remove permission manifest if not requested
90
+ if (!this.options.includePermissionManifest) {
91
+ delete report.recommended_permissions;
92
+ }
93
+ return report;
94
+ }
95
+ }
96
+ exports.JsonReportGenerator = JsonReportGenerator;
97
+ /**
98
+ * Generate JSON diff report
99
+ */
100
+ function generateDiffJsonReport(data) {
101
+ const report = {
102
+ report_version: types_1.REPORT_VERSION,
103
+ schema_version: types_1.IR_SCHEMA_VERSION,
104
+ generated_at: new Date().toISOString(),
105
+ tool: {
106
+ name: 'agentlint',
107
+ version: TOOL_VERSION,
108
+ build: {
109
+ os: os.platform(),
110
+ arch: os.arch(),
111
+ },
112
+ },
113
+ diff: data.diff,
114
+ summary: {
115
+ status: data.diff?.summary.status || 'pass',
116
+ exit_code: data.diff?.summary.exit_code || 0,
117
+ capability_expansion: data.diff?.summary.capability_expansion || false,
118
+ new_high_findings: data.diff?.summary.new_high_findings || 0,
119
+ changes_count: data.diff?.changes.length || 0,
120
+ new_findings_count: data.diff?.new_findings.length || 0,
121
+ resolved_findings_count: data.diff?.resolved_findings.length || 0,
122
+ },
123
+ };
124
+ return JSON.stringify(report, null, 2);
125
+ }
126
+ //# sourceMappingURL=json.js.map