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.
- package/CHANGELOG.md +32 -0
- package/LICENSE +190 -0
- package/README.md +246 -0
- package/dist/cli/index.d.ts +7 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +351 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/diff/index.d.ts +16 -0
- package/dist/diff/index.d.ts.map +1 -0
- package/dist/diff/index.js +204 -0
- package/dist/diff/index.js.map +1 -0
- package/dist/index.d.ts +21 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +55 -0
- package/dist/index.js.map +1 -0
- package/dist/ir/index.d.ts +2 -0
- package/dist/ir/index.d.ts.map +1 -0
- package/dist/ir/index.js +18 -0
- package/dist/ir/index.js.map +1 -0
- package/dist/ir/types.d.ts +369 -0
- package/dist/ir/types.d.ts.map +1 -0
- package/dist/ir/types.js +12 -0
- package/dist/ir/types.js.map +1 -0
- package/dist/parsers/base.d.ts +104 -0
- package/dist/parsers/base.d.ts.map +1 -0
- package/dist/parsers/base.js +373 -0
- package/dist/parsers/base.js.map +1 -0
- package/dist/parsers/claude.d.ts +30 -0
- package/dist/parsers/claude.d.ts.map +1 -0
- package/dist/parsers/claude.js +453 -0
- package/dist/parsers/claude.js.map +1 -0
- package/dist/parsers/cursor.d.ts +24 -0
- package/dist/parsers/cursor.d.ts.map +1 -0
- package/dist/parsers/cursor.js +305 -0
- package/dist/parsers/cursor.js.map +1 -0
- package/dist/parsers/factory.d.ts +30 -0
- package/dist/parsers/factory.d.ts.map +1 -0
- package/dist/parsers/factory.js +78 -0
- package/dist/parsers/factory.js.map +1 -0
- package/dist/parsers/index.d.ts +5 -0
- package/dist/parsers/index.d.ts.map +1 -0
- package/dist/parsers/index.js +21 -0
- package/dist/parsers/index.js.map +1 -0
- package/dist/policy/index.d.ts +3 -0
- package/dist/policy/index.d.ts.map +1 -0
- package/dist/policy/index.js +19 -0
- package/dist/policy/index.js.map +1 -0
- package/dist/policy/loader.d.ts +23 -0
- package/dist/policy/loader.d.ts.map +1 -0
- package/dist/policy/loader.js +252 -0
- package/dist/policy/loader.js.map +1 -0
- package/dist/policy/types.d.ts +79 -0
- package/dist/policy/types.d.ts.map +1 -0
- package/dist/policy/types.js +99 -0
- package/dist/policy/types.js.map +1 -0
- package/dist/reports/index.d.ts +14 -0
- package/dist/reports/index.d.ts.map +1 -0
- package/dist/reports/index.js +54 -0
- package/dist/reports/index.js.map +1 -0
- package/dist/reports/json.d.ts +16 -0
- package/dist/reports/json.d.ts.map +1 -0
- package/dist/reports/json.js +126 -0
- package/dist/reports/json.js.map +1 -0
- package/dist/reports/sarif.d.ts +20 -0
- package/dist/reports/sarif.d.ts.map +1 -0
- package/dist/reports/sarif.js +169 -0
- package/dist/reports/sarif.js.map +1 -0
- package/dist/reports/text.d.ts +25 -0
- package/dist/reports/text.d.ts.map +1 -0
- package/dist/reports/text.js +283 -0
- package/dist/reports/text.js.map +1 -0
- package/dist/reports/types.d.ts +88 -0
- package/dist/reports/types.d.ts.map +1 -0
- package/dist/reports/types.js +6 -0
- package/dist/reports/types.js.map +1 -0
- package/dist/rules/base.d.ts +16 -0
- package/dist/rules/base.d.ts.map +1 -0
- package/dist/rules/base.js +48 -0
- package/dist/rules/base.js.map +1 -0
- package/dist/rules/engine.d.ts +61 -0
- package/dist/rules/engine.d.ts.map +1 -0
- package/dist/rules/engine.js +195 -0
- package/dist/rules/engine.js.map +1 -0
- package/dist/rules/execution.d.ts +33 -0
- package/dist/rules/execution.d.ts.map +1 -0
- package/dist/rules/execution.js +154 -0
- package/dist/rules/execution.js.map +1 -0
- package/dist/rules/filesystem.d.ts +36 -0
- package/dist/rules/filesystem.d.ts.map +1 -0
- package/dist/rules/filesystem.js +227 -0
- package/dist/rules/filesystem.js.map +1 -0
- package/dist/rules/hook.d.ts +25 -0
- package/dist/rules/hook.d.ts.map +1 -0
- package/dist/rules/hook.js +112 -0
- package/dist/rules/hook.js.map +1 -0
- package/dist/rules/index.d.ts +12 -0
- package/dist/rules/index.d.ts.map +1 -0
- package/dist/rules/index.js +28 -0
- package/dist/rules/index.js.map +1 -0
- package/dist/rules/instruction.d.ts +25 -0
- package/dist/rules/instruction.d.ts.map +1 -0
- package/dist/rules/instruction.js +162 -0
- package/dist/rules/instruction.js.map +1 -0
- package/dist/rules/network.d.ts +33 -0
- package/dist/rules/network.d.ts.map +1 -0
- package/dist/rules/network.js +145 -0
- package/dist/rules/network.js.map +1 -0
- package/dist/rules/observability.d.ts +25 -0
- package/dist/rules/observability.d.ts.map +1 -0
- package/dist/rules/observability.js +105 -0
- package/dist/rules/observability.js.map +1 -0
- package/dist/rules/scope.d.ts +37 -0
- package/dist/rules/scope.d.ts.map +1 -0
- package/dist/rules/scope.js +173 -0
- package/dist/rules/scope.js.map +1 -0
- package/dist/rules/secrets.d.ts +35 -0
- package/dist/rules/secrets.d.ts.map +1 -0
- package/dist/rules/secrets.js +273 -0
- package/dist/rules/secrets.js.map +1 -0
- package/dist/rules/types.d.ts +58 -0
- package/dist/rules/types.d.ts.map +1 -0
- package/dist/rules/types.js +6 -0
- package/dist/rules/types.js.map +1 -0
- package/dist/scanner.d.ts +61 -0
- package/dist/scanner.d.ts.map +1 -0
- package/dist/scanner.js +441 -0
- package/dist/scanner.js.map +1 -0
- package/dist/utils/hash.d.ts +28 -0
- package/dist/utils/hash.d.ts.map +1 -0
- package/dist/utils/hash.js +94 -0
- package/dist/utils/hash.js.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +18 -0
- package/dist/utils/index.js.map +1 -0
- 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
|