guardvibe 1.5.0 → 1.6.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/build/data/rules/auth.d.ts.map +1 -1
- package/build/data/rules/auth.js +1 -0
- package/build/data/rules/auth.js.map +1 -1
- package/build/data/rules/firebase.d.ts.map +1 -1
- package/build/data/rules/firebase.js +1 -0
- package/build/data/rules/firebase.js.map +1 -1
- package/build/index.js +43 -1
- package/build/index.js.map +1 -1
- package/build/tools/check-command.d.ts +13 -0
- package/build/tools/check-command.d.ts.map +1 -0
- package/build/tools/check-command.js +227 -0
- package/build/tools/check-command.js.map +1 -0
- package/build/tools/explain-remediation.d.ts +15 -0
- package/build/tools/explain-remediation.d.ts.map +1 -0
- package/build/tools/explain-remediation.js +103 -0
- package/build/tools/explain-remediation.js.map +1 -0
- package/build/tools/fix-code.js +143 -51
- package/build/tools/fix-code.js.map +1 -1
- package/build/tools/repo-posture.d.ts +2 -0
- package/build/tools/repo-posture.d.ts.map +1 -0
- package/build/tools/repo-posture.js +178 -0
- package/build/tools/repo-posture.js.map +1 -0
- package/build/tools/review-pr.d.ts.map +1 -1
- package/build/tools/review-pr.js +50 -1
- package/build/tools/review-pr.js.map +1 -1
- package/build/tools/scan-config-change.d.ts +12 -0
- package/build/tools/scan-config-change.d.ts.map +1 -0
- package/build/tools/scan-config-change.js +88 -0
- package/build/tools/scan-config-change.js.map +1 -0
- package/package.json +1 -1
package/build/tools/fix-code.js
CHANGED
|
@@ -55,63 +55,155 @@ function generateFixSuggestions(findings, code) {
|
|
|
55
55
|
* Generate a concrete patch suggestion for the matched line.
|
|
56
56
|
* Returns a before/after replacement when possible.
|
|
57
57
|
*/
|
|
58
|
+
// guardvibe-ignore — patch templates contain intentional examples of vulnerable patterns
|
|
58
59
|
function generatePatch(finding, sourceLine) {
|
|
59
60
|
const { rule } = finding;
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
return `// Before:\n${sourceLine.trim()}\n// After:\nconst ${varName} = process.env.${envName};`;
|
|
69
|
-
}
|
|
70
|
-
break;
|
|
61
|
+
// --- Hardcoded credentials / secrets -> env var ---
|
|
62
|
+
if (["VG001", "VG062", "VG060", "VG506", "VG514", "VG517", "VG603",
|
|
63
|
+
"VG621", "VG626", "VG651", "VG665", "VG677"].includes(rule.id)) {
|
|
64
|
+
const match = /(\w+)\s*[:=]\s*['"][^'"]+['"]/.exec(sourceLine);
|
|
65
|
+
if (match) {
|
|
66
|
+
const varName = match[1];
|
|
67
|
+
const envName = varName.replace(/([a-z])([A-Z])/g, "$1_$2").toUpperCase();
|
|
68
|
+
return `// Before:\n${sourceLine.trim()}\n// After:\nconst ${varName} = process.env.${envName};`;
|
|
71
69
|
}
|
|
72
|
-
//
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
return '// Replace dangerouslySetInnerHTML with a sanitizer:\nimport DOMPurify from "dompurify";\n// Use: <div dangerouslySetInnerHTML={{ __html: DOMPurify.sanitize(content) }} />';
|
|
80
|
-
}
|
|
81
|
-
break;
|
|
82
|
-
}
|
|
83
|
-
// SQL injection -> parameterized
|
|
84
|
-
case "VG010": {
|
|
85
|
-
return "// Replace template literal interpolation with parameterized query:\n// Before: query(`SELECT * FROM users WHERE id = ${id}`)\n// After: query('SELECT * FROM users WHERE id = $1', [id])";
|
|
86
|
-
}
|
|
87
|
-
// Missing auth -> add auth check
|
|
88
|
-
case "VG002":
|
|
89
|
-
case "VG420":
|
|
90
|
-
case "VG952": {
|
|
91
|
-
return '// Add authentication check at the start:\nconst { userId } = await auth();\nif (!userId) return new Response("Unauthorized", { status: 401 });';
|
|
92
|
-
}
|
|
93
|
-
// Mass assignment -> explicit fields
|
|
94
|
-
case "VG953": {
|
|
95
|
-
return "// Replace spread with explicit field selection:\n// Before: data: { ...req.body }\n// After: const { field1, field2 } = schema.parse(req.body);\n// data: { field1, field2 }";
|
|
96
|
-
}
|
|
97
|
-
// CORS wildcard -> specific origin
|
|
98
|
-
case "VG040":
|
|
99
|
-
case "VG403": {
|
|
100
|
-
return '// Replace wildcard with specific origin:\n// Before: "Access-Control-Allow-Origin": "*"\n// After: "Access-Control-Allow-Origin": process.env.ALLOWED_ORIGIN';
|
|
101
|
-
}
|
|
102
|
-
// Error leak -> generic message
|
|
103
|
-
case "VG959": {
|
|
104
|
-
return '// Replace error details with generic message:\ncatch (error) {\n console.error("Internal error:", error);\n return Response.json({ error: "Something went wrong" }, { status: 500 });\n}';
|
|
70
|
+
return "// Move hardcoded value to environment variable:\nconst value = process.env.SECRET_NAME;";
|
|
71
|
+
}
|
|
72
|
+
// --- NEXT_PUBLIC_ secret exposure -> remove prefix ---
|
|
73
|
+
if (["VG411", "VG604", "VG627", "VG631", "VG655", "VG671", "VG676", "VG755"].includes(rule.id)) {
|
|
74
|
+
const match = /(NEXT_PUBLIC_)(\w+)/.exec(sourceLine);
|
|
75
|
+
if (match) {
|
|
76
|
+
return `// Remove NEXT_PUBLIC_ prefix:\n// Before: ${match[1]}${match[2]}\n// After: ${match[2]}\n// Access only in Server Components or API routes`;
|
|
105
77
|
}
|
|
106
|
-
//
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
78
|
+
return "// Remove NEXT_PUBLIC_ prefix. Access server-side only.";
|
|
79
|
+
}
|
|
80
|
+
// --- Client-side secret exposure -> move to server ---
|
|
81
|
+
if (["VG400", "VG600", "VG605", "VG607", "VG625", "VG630",
|
|
82
|
+
"VG670", "VG675"].includes(rule.id)) {
|
|
83
|
+
return "// Move to server-side:\nexport default async function Page() {\n const data = await fetchWithSecret(); // server-only\n return <ClientComponent data={data} />;\n}";
|
|
84
|
+
}
|
|
85
|
+
// --- Missing auth check -> add auth ---
|
|
86
|
+
if (["VG002", "VG010", "VG402", "VG420", "VG952"].includes(rule.id)) {
|
|
87
|
+
return '// Add auth check:\nconst { userId } = await auth();\nif (!userId) return new Response("Unauthorized", { status: 401 });';
|
|
88
|
+
}
|
|
89
|
+
// --- Missing input validation -> add Zod ---
|
|
90
|
+
if (["VG401", "VG406", "VG960"].includes(rule.id)) {
|
|
91
|
+
return 'import { z } from "zod";\nconst schema = z.object({ id: z.string().uuid(), name: z.string().min(1) });\nconst data = schema.parse(input);';
|
|
92
|
+
}
|
|
93
|
+
// --- SQL injection -> parameterized query ---
|
|
94
|
+
if (["VG984"].includes(rule.id)) {
|
|
95
|
+
return "// Use parameterized query:\n// Before: query(`SELECT * FROM t WHERE id = ${id}`)\n// After: query('SELECT * FROM t WHERE id = $1', [id])";
|
|
96
|
+
}
|
|
97
|
+
// --- XSS / innerHTML -> sanitize ---
|
|
98
|
+
if (["VG012", "VG042", "VG408"].includes(rule.id)) {
|
|
99
|
+
if (sourceLine.includes("innerHTML")) {
|
|
100
|
+
return `// Before:\n${sourceLine.trim()}\n// After:\n${sourceLine.trim().replace("innerHTML", "textContent")}`;
|
|
110
101
|
}
|
|
111
|
-
|
|
112
|
-
|
|
102
|
+
return 'import DOMPurify from "dompurify";\nconst clean = DOMPurify.sanitize(userContent);';
|
|
103
|
+
}
|
|
104
|
+
// --- CORS wildcard -> specific origin ---
|
|
105
|
+
if (["VG040", "VG403", "VG500", "VG510"].includes(rule.id)) {
|
|
106
|
+
return '// Replace wildcard:\n// Before: "Access-Control-Allow-Origin": "*"\n// After: "Access-Control-Allow-Origin": process.env.ALLOWED_ORIGIN';
|
|
107
|
+
}
|
|
108
|
+
// --- Webhook missing signature -> verify ---
|
|
109
|
+
if (["VG601", "VG606", "VG608", "VG650"].includes(rule.id)) {
|
|
110
|
+
return "import crypto from 'crypto';\nconst sig = request.headers.get('x-signature');\nconst expected = crypto.createHmac('sha256', process.env.WEBHOOK_SECRET!)\n .update(body).digest('hex');\nif (sig !== expected) return new Response('Unauthorized', { status: 401 });";
|
|
111
|
+
}
|
|
112
|
+
// --- Server Action returns full object -> select ---
|
|
113
|
+
if (rule.id === "VG412") {
|
|
114
|
+
return "// Use select:\nprisma.user.findUnique({\n where: { id },\n select: { id: true, name: true, email: true },\n});";
|
|
115
|
+
}
|
|
116
|
+
// --- Missing security headers ---
|
|
117
|
+
if (rule.id === "VG405") {
|
|
118
|
+
return '// next.config.ts headers():\nreturn [{ source: "/(.*)", headers: [\n { key: "X-Frame-Options", value: "DENY" },\n { key: "X-Content-Type-Options", value: "nosniff" },\n { key: "Strict-Transport-Security", value: "max-age=63072000" },\n]}];';
|
|
119
|
+
}
|
|
120
|
+
// --- Open redirect -> validate ---
|
|
121
|
+
if (["VG409", "VG660"].includes(rule.id)) {
|
|
122
|
+
return 'const ALLOWED = ["example.com"];\nconst url = new URL(target, request.url);\nif (!ALLOWED.includes(url.hostname)) redirect("/");';
|
|
123
|
+
}
|
|
124
|
+
// --- Mass assignment ---
|
|
125
|
+
if (rule.id === "VG953") {
|
|
126
|
+
return "const { field1, field2 } = schema.parse(req.body);\nawait prisma.item.update({ data: { field1, field2 } });";
|
|
127
|
+
}
|
|
128
|
+
// --- Error leak ---
|
|
129
|
+
if (rule.id === "VG959") {
|
|
130
|
+
return 'catch (error) {\n console.error("Internal:", error);\n return Response.json({ error: "Something went wrong" }, { status: 500 });\n}';
|
|
131
|
+
}
|
|
132
|
+
// --- BOLA -> ownership ---
|
|
133
|
+
if (["VG950", "VG951"].includes(rule.id)) {
|
|
134
|
+
return "// Add ownership:\n// Before: where: { id: params.id }\n// After: where: { id: params.id, userId }";
|
|
135
|
+
}
|
|
136
|
+
// --- Missing pagination ---
|
|
137
|
+
if (rule.id === "VG955") {
|
|
138
|
+
return "const items = await prisma.item.findMany({\n take: Math.min(Number(limit) || 20, 100),\n skip: Number(offset) || 0,\n});";
|
|
139
|
+
}
|
|
140
|
+
// --- Rate limiting ---
|
|
141
|
+
if (rule.id === "VG956") {
|
|
142
|
+
return 'import { Ratelimit } from "@upstash/ratelimit";\nconst rl = new Ratelimit({ redis, limiter: Ratelimit.slidingWindow(10, "60s") });\nconst { success } = await rl.limit(userId);\nif (!success) return new Response("Too many requests", { status: 429 });';
|
|
143
|
+
}
|
|
144
|
+
// --- Sensitive op without confirmation ---
|
|
145
|
+
if (rule.id === "VG958") {
|
|
146
|
+
return "export async function deleteAccount(confirmToken: string) {\n const valid = await verifyToken(confirmToken);\n if (!valid) throw new Error('Invalid confirmation');\n}";
|
|
147
|
+
}
|
|
148
|
+
// --- Supabase RLS ---
|
|
149
|
+
if (["VG440", "VG432"].includes(rule.id)) {
|
|
150
|
+
return "ALTER TABLE your_table ENABLE ROW LEVEL SECURITY;\nCREATE POLICY \"Users own data\" ON your_table\n FOR ALL USING (auth.uid() = user_id);";
|
|
151
|
+
}
|
|
152
|
+
// --- Supabase service key exposure ---
|
|
153
|
+
if (rule.id === "VG441") {
|
|
154
|
+
return "// Client: supabase = createClient(url, NEXT_PUBLIC_SUPABASE_ANON_KEY)\n// Server: supabase = createClient(url, SUPABASE_SERVICE_ROLE_KEY)";
|
|
155
|
+
}
|
|
156
|
+
// --- Stripe price client-side ---
|
|
157
|
+
if (rule.id === "VG602") {
|
|
158
|
+
return "const session = await stripe.checkout.sessions.create({\n line_items: [{ price: 'price_xxx', quantity: 1 }],\n});";
|
|
159
|
+
}
|
|
160
|
+
// --- Docker ---
|
|
161
|
+
if (rule.id === "VG515")
|
|
162
|
+
return "# Use specific capabilities:\ncap_add:\n - NET_ADMIN";
|
|
163
|
+
if (rule.id === "VG516")
|
|
164
|
+
return "# Mount only needed dirs:\nvolumes:\n - ./data:/app/data";
|
|
165
|
+
// --- Source maps ---
|
|
166
|
+
if (["VG512", "VG662"].includes(rule.id))
|
|
167
|
+
return "// next.config.ts\nproductionBrowserSourceMaps: false,";
|
|
168
|
+
// --- Wildcard image ---
|
|
169
|
+
if (rule.id === "VG507")
|
|
170
|
+
return 'images: { remotePatterns: [{ protocol: "https", hostname: "images.example.com" }] }';
|
|
171
|
+
// --- AI specific ---
|
|
172
|
+
if (rule.id === "VG874")
|
|
173
|
+
return "// Move OpenAI to API route, remove dangerouslyAllowBrowser";
|
|
174
|
+
if (rule.id === "VG875")
|
|
175
|
+
return "const result = await generateText({ model, prompt, maxTokens: 1024 });";
|
|
176
|
+
// --- React Native ---
|
|
177
|
+
if (rule.id === "VG700")
|
|
178
|
+
return 'import * as SecureStore from "expo-secure-store";\nawait SecureStore.setItemAsync("authToken", token);';
|
|
179
|
+
if (rule.id === "VG705")
|
|
180
|
+
return 'import { fetch } from "react-native-ssl-pinning";\nawait fetch(url, { sslPinning: { certs: ["cert"] } });';
|
|
181
|
+
if (rule.id === "VG707")
|
|
182
|
+
return "// Use NSExceptionDomains instead of NSAllowsArbitraryLoads";
|
|
183
|
+
if (rule.id === "VG709")
|
|
184
|
+
return 'import * as SecureStore from "expo-secure-store";\nawait SecureStore.setItemAsync("key", value);';
|
|
185
|
+
// --- CSP unsafe-inline ---
|
|
186
|
+
if (rule.id === "VG978")
|
|
187
|
+
return "// Replace 'unsafe-inline' with nonce-based CSP";
|
|
188
|
+
// --- .env not in gitignore ---
|
|
189
|
+
if (rule.id === "VG656")
|
|
190
|
+
return "# .gitignore\n.env\n.env.*\n.env.local\n!.env.example";
|
|
191
|
+
// --- Cron secret ---
|
|
192
|
+
if (rule.id === "VG503")
|
|
193
|
+
return 'const auth = request.headers.get("authorization");\nif (auth !== `Bearer ${process.env.CRON_SECRET}`) return new Response("Unauthorized", { status: 401 });';
|
|
194
|
+
// --- Cache revalidation ---
|
|
195
|
+
if (rule.id === "VG410")
|
|
196
|
+
return 'const { userId } = await auth();\nif (!userId) return new Response("Unauthorized", { status: 401 });\nrevalidateTag("posts");';
|
|
197
|
+
// --- Middleware bypass ---
|
|
198
|
+
if (rule.id === "VG404")
|
|
199
|
+
return 'export const config = { matcher: ["/dashboard/:path*", "/api/:path*"] };';
|
|
200
|
+
// --- Server data leaked to client ---
|
|
201
|
+
if (rule.id === "VG407")
|
|
202
|
+
return "// Keep sensitive data server-side:\nexport default async function Page() {\n const secret = process.env.SECRET;\n const safeData = transform(secret);\n return <Client data={safeData} />;\n}";
|
|
203
|
+
// --- Fallback: use fixCode from rule ---
|
|
204
|
+
if (rule.fixCode) {
|
|
205
|
+
return `// Secure alternative:\n${rule.fixCode}`;
|
|
113
206
|
}
|
|
114
|
-
// Fallback: no specific patch
|
|
115
207
|
return undefined;
|
|
116
208
|
}
|
|
117
209
|
function formatFixMarkdown(suggestions) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fix-code.js","sourceRoot":"","sources":["../../src/tools/fix-code.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"fix-code.js","sourceRoot":"","sources":["../../src/tools/fix-code.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-posture.d.ts","sourceRoot":"","sources":["../../src/tools/repo-posture.ts"],"names":[],"mappings":"AAwDA,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAE,UAAU,GAAG,MAAmB,GAAG,MAAM,CAyIlG"}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import { readdirSync, readFileSync, existsSync } from "fs";
|
|
2
|
+
import { join, resolve } from "path";
|
|
3
|
+
function tryRead(path) {
|
|
4
|
+
try {
|
|
5
|
+
return existsSync(path) ? readFileSync(path, "utf-8") : null;
|
|
6
|
+
}
|
|
7
|
+
catch {
|
|
8
|
+
return null;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
function countFiles(dir, depth = 0) {
|
|
12
|
+
if (depth > 5)
|
|
13
|
+
return { files: 0, dirs: 0 };
|
|
14
|
+
let files = 0, dirs = 0;
|
|
15
|
+
const skip = new Set(["node_modules", ".git", ".next", "build", "dist", "coverage"]);
|
|
16
|
+
try {
|
|
17
|
+
for (const entry of readdirSync(dir, { withFileTypes: true })) {
|
|
18
|
+
if (skip.has(entry.name))
|
|
19
|
+
continue;
|
|
20
|
+
if (entry.isDirectory()) {
|
|
21
|
+
dirs++;
|
|
22
|
+
const sub = countFiles(join(dir, entry.name), depth + 1);
|
|
23
|
+
files += sub.files;
|
|
24
|
+
dirs += sub.dirs;
|
|
25
|
+
}
|
|
26
|
+
else if (entry.isFile())
|
|
27
|
+
files++;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
catch { /* skip */ }
|
|
31
|
+
return { files, dirs };
|
|
32
|
+
}
|
|
33
|
+
function findFiles(dir, patterns, depth = 0) {
|
|
34
|
+
if (depth > 6)
|
|
35
|
+
return [];
|
|
36
|
+
const results = [];
|
|
37
|
+
const skip = new Set(["node_modules", ".git", ".next", "build", "dist", "coverage"]);
|
|
38
|
+
try {
|
|
39
|
+
for (const entry of readdirSync(dir, { withFileTypes: true })) {
|
|
40
|
+
if (skip.has(entry.name))
|
|
41
|
+
continue;
|
|
42
|
+
const full = join(dir, entry.name);
|
|
43
|
+
if (entry.isDirectory())
|
|
44
|
+
results.push(...findFiles(full, patterns, depth + 1));
|
|
45
|
+
else if (entry.isFile()) {
|
|
46
|
+
const name = entry.name.toLowerCase();
|
|
47
|
+
if (patterns.some(p => name.includes(p)))
|
|
48
|
+
results.push(full);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
catch { /* skip */ }
|
|
53
|
+
return results;
|
|
54
|
+
}
|
|
55
|
+
export function repoSecurityPosture(path, format = "markdown") {
|
|
56
|
+
const root = resolve(path);
|
|
57
|
+
const pkg = tryRead(join(root, "package.json"));
|
|
58
|
+
const deps = pkg ? Object.keys({ ...JSON.parse(pkg).dependencies, ...JSON.parse(pkg).devDependencies }) : [];
|
|
59
|
+
const has = (s) => deps.some(d => d.includes(s));
|
|
60
|
+
const { files, dirs } = countFiles(root);
|
|
61
|
+
const sensitiveAreas = [];
|
|
62
|
+
const highRiskWorkflows = [];
|
|
63
|
+
const priorityFixes = [];
|
|
64
|
+
const guardRecommendations = [];
|
|
65
|
+
// --- Auth surface ---
|
|
66
|
+
const hasAuth = has("clerk") || has("next-auth") || has("@auth/") || has("@supabase/auth") || has("firebase");
|
|
67
|
+
const authFiles = findFiles(root, ["auth", "login", "signup", "session", "middleware", "proxy"]);
|
|
68
|
+
if (authFiles.length > 0) {
|
|
69
|
+
sensitiveAreas.push({ name: "Authentication", risk: "critical", files: authFiles.slice(0, 10),
|
|
70
|
+
description: "Auth logic — any vulnerability here means full account takeover." });
|
|
71
|
+
guardRecommendations.push("Enable strict review for auth/ and middleware files.");
|
|
72
|
+
}
|
|
73
|
+
// --- Payment surface ---
|
|
74
|
+
const hasPayments = has("stripe") || has("@polar") || has("lemonsqueezy");
|
|
75
|
+
const paymentFiles = findFiles(root, ["payment", "stripe", "checkout", "billing", "subscription", "webhook"]);
|
|
76
|
+
if (paymentFiles.length > 0) {
|
|
77
|
+
sensitiveAreas.push({ name: "Payments", risk: "critical", files: paymentFiles.slice(0, 10),
|
|
78
|
+
description: "Payment flow — financial impact, PCI-DSS scope." });
|
|
79
|
+
highRiskWorkflows.push("Payment webhook endpoints must verify signatures.");
|
|
80
|
+
guardRecommendations.push("Block PRs touching payment files without review.");
|
|
81
|
+
}
|
|
82
|
+
// --- PII / user data ---
|
|
83
|
+
const hasPII = has("prisma") || has("drizzle") || has("@supabase") || has("mongoose");
|
|
84
|
+
const piiFiles = findFiles(root, ["user", "profile", "account", "patient", "customer", "personal"]);
|
|
85
|
+
if (piiFiles.length > 0) {
|
|
86
|
+
sensitiveAreas.push({ name: "PII / User Data", risk: "high", files: piiFiles.slice(0, 10),
|
|
87
|
+
description: "Contains user personal data — GDPR/CCPA scope." });
|
|
88
|
+
priorityFixes.push("Ensure all PII queries have access control (RLS or WHERE userId).");
|
|
89
|
+
}
|
|
90
|
+
// --- Admin surface ---
|
|
91
|
+
const adminFiles = findFiles(root, ["admin", "dashboard", "internal", "management"]);
|
|
92
|
+
if (adminFiles.length > 0) {
|
|
93
|
+
sensitiveAreas.push({ name: "Admin / Internal", risk: "high", files: adminFiles.slice(0, 10),
|
|
94
|
+
description: "Admin interfaces — privilege escalation target." });
|
|
95
|
+
guardRecommendations.push("Admin routes need role-based access control check.");
|
|
96
|
+
}
|
|
97
|
+
// --- API surface ---
|
|
98
|
+
const apiFiles = findFiles(root, ["route.ts", "route.js", "api"]);
|
|
99
|
+
if (apiFiles.length > 0) {
|
|
100
|
+
sensitiveAreas.push({ name: "API Surface", risk: "medium", files: apiFiles.slice(0, 10),
|
|
101
|
+
description: `${apiFiles.length} API endpoints — attack surface for injection and auth bypass.` });
|
|
102
|
+
if (apiFiles.length > 20)
|
|
103
|
+
highRiskWorkflows.push("Large API surface — consider API gateway rate limiting.");
|
|
104
|
+
}
|
|
105
|
+
// --- Infrastructure ---
|
|
106
|
+
const hasInfra = existsSync(join(root, "Dockerfile")) || existsSync(join(root, "docker-compose.yml")) ||
|
|
107
|
+
existsSync(join(root, "terraform")) || existsSync(join(root, ".github/workflows"));
|
|
108
|
+
const infraFiles = findFiles(root, ["dockerfile", "docker-compose", ".tf", "workflow", "deploy"]);
|
|
109
|
+
if (infraFiles.length > 0) {
|
|
110
|
+
sensitiveAreas.push({ name: "Infrastructure / CI/CD", risk: "high", files: infraFiles.slice(0, 10),
|
|
111
|
+
description: "Infrastructure configs — supply chain and deployment risks." });
|
|
112
|
+
highRiskWorkflows.push("CI/CD config changes should require approval.");
|
|
113
|
+
}
|
|
114
|
+
// --- Secrets ---
|
|
115
|
+
const envFiles = [".env", ".env.local", ".env.production", ".env.example"].filter(f => existsSync(join(root, f)));
|
|
116
|
+
if (envFiles.length > 0) {
|
|
117
|
+
const gitignore = tryRead(join(root, ".gitignore")) ?? "";
|
|
118
|
+
if (!/\.env/.test(gitignore)) {
|
|
119
|
+
priorityFixes.push("CRITICAL: .env files not in .gitignore — secrets at risk!");
|
|
120
|
+
}
|
|
121
|
+
sensitiveAreas.push({ name: "Secrets / Config", risk: "critical", files: envFiles.map(f => join(root, f)),
|
|
122
|
+
description: `${envFiles.length} env file(s) with potential secrets.` });
|
|
123
|
+
}
|
|
124
|
+
// --- Risk profile ---
|
|
125
|
+
const criticalAreas = sensitiveAreas.filter(a => a.risk === "critical").length;
|
|
126
|
+
const highAreas = sensitiveAreas.filter(a => a.risk === "high").length;
|
|
127
|
+
const riskProfile = criticalAreas >= 2 ? "critical" : criticalAreas >= 1 ? "high" : highAreas >= 2 ? "medium" : "low";
|
|
128
|
+
// --- Guard mode recommendation ---
|
|
129
|
+
if (riskProfile === "critical" || riskProfile === "high") {
|
|
130
|
+
guardRecommendations.push("Run GuardVibe on every PR (review_pr with fail_on=high).");
|
|
131
|
+
guardRecommendations.push("Enable pre-commit hook (guardvibe hook install).");
|
|
132
|
+
guardRecommendations.push("Run scan_secrets_history to check for leaked secrets in git history.");
|
|
133
|
+
}
|
|
134
|
+
if (hasPayments)
|
|
135
|
+
guardRecommendations.push("Run policy_check with PCI-DSS framework.");
|
|
136
|
+
if (hasPII)
|
|
137
|
+
guardRecommendations.push("Run policy_check with GDPR framework.");
|
|
138
|
+
const result = {
|
|
139
|
+
riskProfile,
|
|
140
|
+
summary: `${files} files across ${sensitiveAreas.length} sensitive areas. Risk: ${riskProfile.toUpperCase()}.`,
|
|
141
|
+
sensitiveAreas,
|
|
142
|
+
guardRecommendations,
|
|
143
|
+
highRiskWorkflows,
|
|
144
|
+
priorityFixes,
|
|
145
|
+
stats: { files, dirs, hasAuth, hasPayments, hasPII, hasInfra },
|
|
146
|
+
};
|
|
147
|
+
if (format === "json")
|
|
148
|
+
return JSON.stringify(result);
|
|
149
|
+
const lines = [
|
|
150
|
+
`# GuardVibe Repository Security Posture`,
|
|
151
|
+
``,
|
|
152
|
+
`**Risk Profile:** ${riskProfile.toUpperCase()}`,
|
|
153
|
+
`**Files:** ${files} | **Sensitive Areas:** ${sensitiveAreas.length}`,
|
|
154
|
+
``,
|
|
155
|
+
];
|
|
156
|
+
if (sensitiveAreas.length > 0) {
|
|
157
|
+
lines.push(`## Sensitive Areas`, ``);
|
|
158
|
+
for (const area of sensitiveAreas) {
|
|
159
|
+
lines.push(`### [${area.risk.toUpperCase()}] ${area.name}`, area.description, `Files: ${area.files.slice(0, 5).map(f => f.replace(root, ".")).join(", ")}`, ``);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
if (highRiskWorkflows.length > 0) {
|
|
163
|
+
lines.push(`## High-Risk Workflows`, ``);
|
|
164
|
+
highRiskWorkflows.forEach(w => lines.push(`- ${w}`));
|
|
165
|
+
lines.push(``);
|
|
166
|
+
}
|
|
167
|
+
if (priorityFixes.length > 0) {
|
|
168
|
+
lines.push(`## Priority Fixes`, ``);
|
|
169
|
+
priorityFixes.forEach(f => lines.push(`- ${f}`));
|
|
170
|
+
lines.push(``);
|
|
171
|
+
}
|
|
172
|
+
if (guardRecommendations.length > 0) {
|
|
173
|
+
lines.push(`## Guard Mode Recommendations`, ``);
|
|
174
|
+
guardRecommendations.forEach(r => lines.push(`- ${r}`));
|
|
175
|
+
}
|
|
176
|
+
return lines.join("\n");
|
|
177
|
+
}
|
|
178
|
+
//# sourceMappingURL=repo-posture.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-posture.js","sourceRoot":"","sources":["../../src/tools/repo-posture.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review-pr.d.ts","sourceRoot":"","sources":["../../src/tools/review-pr.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"review-pr.d.ts","sourceRoot":"","sources":["../../src/tools/review-pr.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AA0H3D,wBAAgB,QAAQ,CACtB,GAAG,GAAE,MAAsB,EAC3B,IAAI,GAAE,MAAe,EACrB,MAAM,GAAE,UAAU,GAAG,MAAM,GAAG,aAA0B,EACxD,QAAQ,GAAE,OAAc,EACxB,MAAM,GAAE,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAe,EAChE,KAAK,CAAC,EAAE,YAAY,EAAE,GACrB,MAAM,CAsIR"}
|
package/build/tools/review-pr.js
CHANGED
|
@@ -57,6 +57,47 @@ function detectLanguage(filePath) {
|
|
|
57
57
|
return "dockerfile";
|
|
58
58
|
return CONFIG_FILE_MAP[basename(filePath)] ?? null;
|
|
59
59
|
}
|
|
60
|
+
function assessConfidence(rule, match) {
|
|
61
|
+
// Higher confidence for specific patterns (secrets, hardcoded values)
|
|
62
|
+
if (rule.id.startsWith("VG0") || rule.id.startsWith("VG6"))
|
|
63
|
+
return 0.95; // core + secrets
|
|
64
|
+
if (rule.severity === "critical")
|
|
65
|
+
return 0.90;
|
|
66
|
+
if (rule.severity === "high")
|
|
67
|
+
return 0.80;
|
|
68
|
+
if (rule.severity === "medium")
|
|
69
|
+
return 0.70;
|
|
70
|
+
return 0.60;
|
|
71
|
+
}
|
|
72
|
+
function assessExploitability(rule) {
|
|
73
|
+
// Hardcoded secrets, SQL injection, XSS = proven exploitable
|
|
74
|
+
if (["VG001", "VG002", "VG003", "VG010", "VG042", "VG408"].includes(rule.id))
|
|
75
|
+
return "proven";
|
|
76
|
+
if (rule.severity === "critical")
|
|
77
|
+
return "likely";
|
|
78
|
+
if (rule.severity === "high")
|
|
79
|
+
return "possible";
|
|
80
|
+
return "theoretical";
|
|
81
|
+
}
|
|
82
|
+
function detectImpactArea(file, rule) {
|
|
83
|
+
if (file.includes("/api/") || file.includes("route."))
|
|
84
|
+
return "API surface";
|
|
85
|
+
if (file.includes("middleware") || file.includes("proxy."))
|
|
86
|
+
return "Auth/routing layer";
|
|
87
|
+
if (file.includes("action") || file.includes("server"))
|
|
88
|
+
return "Server action";
|
|
89
|
+
if (file.includes(".env"))
|
|
90
|
+
return "Secrets/config";
|
|
91
|
+
if (file.includes("payment") || file.includes("stripe") || file.includes("checkout"))
|
|
92
|
+
return "Payment flow";
|
|
93
|
+
if (file.includes("auth") || file.includes("login") || file.includes("session"))
|
|
94
|
+
return "Authentication";
|
|
95
|
+
if (rule.compliance?.some(c => c.includes("PCI")))
|
|
96
|
+
return "Payment/PCI scope";
|
|
97
|
+
if (rule.compliance?.some(c => c.includes("HIPAA")))
|
|
98
|
+
return "Healthcare/PHI scope";
|
|
99
|
+
return "Application code";
|
|
100
|
+
}
|
|
60
101
|
function severityToLevel(severity) {
|
|
61
102
|
if (severity === "critical" || severity === "high")
|
|
62
103
|
return "failure";
|
|
@@ -87,7 +128,12 @@ export function reviewPr(cwd = process.cwd(), base = "main", format = "markdown"
|
|
|
87
128
|
const findings = analyzeCode(content, language, undefined, file, cwd, rules);
|
|
88
129
|
for (const f of findings) {
|
|
89
130
|
const inDiff = isLineInDiff(f.line, hunks);
|
|
90
|
-
allFindings.push({
|
|
131
|
+
allFindings.push({
|
|
132
|
+
rule: f.rule, match: f.match, line: f.line, file, inDiff,
|
|
133
|
+
confidence: assessConfidence(f.rule, f.match),
|
|
134
|
+
exploitability: assessExploitability(f.rule),
|
|
135
|
+
impactArea: detectImpactArea(file, f.rule),
|
|
136
|
+
});
|
|
91
137
|
}
|
|
92
138
|
}
|
|
93
139
|
const reportFindings = diffOnly ? allFindings.filter(f => f.inDiff) : allFindings;
|
|
@@ -124,6 +170,9 @@ export function reviewPr(cwd = process.cwd(), base = "main", format = "markdown"
|
|
|
124
170
|
owasp: f.rule.owasp, file: f.file, line: f.line, match: f.match,
|
|
125
171
|
inDiff: f.inDiff, fix: f.rule.fix, fixCode: f.rule.fixCode,
|
|
126
172
|
compliance: f.rule.compliance,
|
|
173
|
+
confidence: f.confidence,
|
|
174
|
+
exploitability: f.exploitability,
|
|
175
|
+
impactArea: f.impactArea,
|
|
127
176
|
})),
|
|
128
177
|
});
|
|
129
178
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review-pr.js","sourceRoot":"","sources":["../../src/tools/review-pr.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AACzC,OAAO,EAAE,WAAW,EAAgB,MAAM,iBAAiB,CAAC;AAG5D,MAAM,aAAa,GAA2B;IAC5C,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY;IACrF,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY;IACrF,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM;IAC7C,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO;IAC/C,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW;IACnD,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;CACjC,CAAC;AAEF,MAAM,eAAe,GAA2B;IAC9C,aAAa,EAAE,eAAe;IAC9B,gBAAgB,EAAE,eAAe,EAAE,iBAAiB,EAAE,eAAe,EAAE,gBAAgB,EAAE,eAAe;IACxG,oBAAoB,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,gBAAgB;CAChF,CAAC;AAwBF,SAAS,OAAO,CAAC,IAAc,EAAE,GAAW;IAC1C,IAAI,CAAC;QACH,OAAO,YAAY,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IAC/E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,SAAS,eAAe,CAAC,GAAW,EAAE,IAAY;IAChD,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,MAAM,EAAE,aAAa,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;IAC3D,OAAO,MAAM,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;AACnD,CAAC;AAED,SAAS,YAAY,CAAC,GAAW,EAAE,IAAY,EAAE,IAAY;IAC3D,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;IAC/D,MAAM,KAAK,GAAe,EAAE,CAAC;IAC7B,MAAM,WAAW,GAAG,+CAA+C,CAAC;IACpE,IAAI,KAAK,CAAC;IACV,OAAO,CAAC,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;QACnD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACrC,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpD,KAAK,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IACrD,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,cAAc,CAAC,GAAW,EAAE,IAAY;IAC/C,IAAI,CAAC;QACH,OAAO,YAAY,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,QAAQ,IAAI,EAAE,CAAC,EAAE,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACnG,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,SAAS,YAAY,CAAC,IAAY,EAAE,KAAiB;IACnD,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,SAAS,IAAI,IAAI,GAAG,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC;AAClF,CAAC;AAED,SAAS,cAAc,CAAC,QAAgB;IACtC,MAAM,GAAG,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;IAC5C,IAAI,aAAa,CAAC,GAAG,CAAC;QAAE,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC;IAClD,IAAI,QAAQ,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,GAAG,KAAK,aAAa;QAAE,OAAO,YAAY,CAAC;IAC9F,OAAO,eAAe,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,IAAI,CAAC;AACrD,CAAC;AAED,SAAS,eAAe,CAAC,QAAgB;IACvC,IAAI,QAAQ,KAAK,UAAU,IAAI,QAAQ,KAAK,MAAM;QAAE,OAAO,SAAS,CAAC;IACrE,IAAI,QAAQ,KAAK,QAAQ;QAAE,OAAO,SAAS,CAAC;IAC5C,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,QAAQ,CACtB,MAAc,OAAO,CAAC,GAAG,EAAE,EAC3B,OAAe,MAAM,EACrB,SAA8C,UAAU,EACxD,WAAoB,IAAI,EACxB,SAA0D,MAAM,EAChE,KAAsB;IAEtB,MAAM,YAAY,GAAG,eAAe,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IAChD,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9B,IAAI,MAAM,KAAK,MAAM;YAAE,OAAO,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAChG,IAAI,MAAM,KAAK,aAAa;YAAE,OAAO,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QACxD,OAAO,kDAAkD,CAAC;IAC5D,CAAC;IAED,MAAM,WAAW,GAAgB,EAAE,CAAC;IACpC,MAAM,YAAY,GAAa,EAAE,CAAC;IAElC,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE,CAAC;QAChC,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,QAAQ;YAAE,SAAS;QAExB,MAAM,OAAO,GAAG,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAC1C,IAAI,CAAC,OAAO;YAAE,SAAS;QAEvB,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxB,MAAM,KAAK,GAAG,YAAY,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAC5C,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;QAE7E,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;YACzB,MAAM,MAAM,GAAG,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAC3C,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACjF,CAAC;IACH,CAAC;IAED,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IAElF,MAAM,QAAQ,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC,MAAM,CAAC;IACnF,MAAM,IAAI,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,MAAM,CAAC;IAC3E,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC,MAAM,CAAC;IAC/E,MAAM,KAAK,GAAG,cAAc,CAAC,MAAM,CAAC;IAEpC,MAAM,cAAc,GAA2B,EAAE,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC;IAC3F,MAAM,SAAS,GAAG,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IAC/C,MAAM,aAAa,GAA2B,EAAE,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;IACnG,MAAM,OAAO,GAAG,SAAS,IAAI,CAAC,IAAI,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC;IAE/G,qDAAqD;IACrD,IAAI,MAAM,KAAK,aAAa,EAAE,CAAC;QAC7B,MAAM,WAAW,GAAuB,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC/D,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,UAAU,EAAE,CAAC,CAAC,IAAI;YAClB,QAAQ,EAAE,CAAC,CAAC,IAAI;YAChB,gBAAgB,EAAE,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;YAClD,OAAO,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACtG,KAAK,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG;SAC1E,CAAC,CAAC,CAAC;QACJ,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IACrC,CAAC;IAED,sBAAsB;IACtB,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,IAAI,CAAC,SAAS,CAAC;YACpB,OAAO,EAAE;gBACP,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM;gBAC7B,KAAK,EAAE,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,YAAY,CAAC,MAAM;gBAC7D,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI;aAChC;YACD,QAAQ,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBACjC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ;gBAC3D,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK;gBAC/D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO;gBAC1D,UAAU,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU;aAC9B,CAAC,CAAC;SACJ,CAAC,CAAC;IACL,CAAC;IAED,2CAA2C;IAC3C,MAAM,gBAAgB,GAAG,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAE5E,MAAM,KAAK,GAAa;QACtB,iCAAiC;QACjC,EAAE;QACF,aAAa,IAAI,yBAAyB,YAAY,CAAC,MAAM,mBAAmB,YAAY,CAAC,MAAM,EAAE;QACrG,aAAa,QAAQ,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,WAAW,EAAE;QAC9D,EAAE;KACH,CAAC;IAEF,IAAI,OAAO,EAAE,CAAC;QACZ,KAAK,CAAC,IAAI,CAAC,mBAAmB,MAAM,uCAAuC,EAAE,EAAE,CAAC,CAAC;IACnF,CAAC;IAED,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;QAChB,KAAK,CAAC,IAAI,CAAC,2BAA2B,QAAQ,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,gBAAgB,CAAC,CAAC;QACpG,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,gBAAgB,CAAC,MAAM,4CAA4C,CAAC,CAAC;QAChG,CAAC;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,sBAAsB,EAAE,sBAAsB,CAAC,CAAC;IAC3D,IAAI,QAAQ,GAAG,CAAC;QAAE,KAAK,CAAC,IAAI,CAAC,gBAAgB,QAAQ,IAAI,CAAC,CAAC;IAC3D,IAAI,IAAI,GAAG,CAAC;QAAE,KAAK,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,CAAC;IAC/C,IAAI,MAAM,GAAG,CAAC;QAAE,KAAK,CAAC,IAAI,CAAC,cAAc,MAAM,IAAI,CAAC,CAAC;IACrD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,MAAM,MAAM,GAAG,IAAI,GAAG,EAAuB,CAAC;IAC9C,KAAK,MAAM,CAAC,IAAI,cAAc,EAAE,CAAC;QAC/B,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QAC1C,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjB,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,MAAM,EAAE,CAAC;QACtC,KAAK,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE,EAAE,CAAC,CAAC;QAClC,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;YACzB,MAAM,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;YAC5C,KAAK,CAAC,IAAI,CACR,QAAQ,KAAK,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,YAAY,CAAC,CAAC,IAAI,EAAE,EACjE,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAClB,CAAC;YACF,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBACnB,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;YAC3E,CAAC;YACD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC;IACH,CAAC;IAED,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,gBAAgB,CAAC,MAAM,wDAAwD,CAAC,CAAC;IAC7G,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|
|
1
|
+
{"version":3,"file":"review-pr.js","sourceRoot":"","sources":["../../src/tools/review-pr.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Config change analyzer — compares before/after config to detect security downgrades.
|
|
3
|
+
*/
|
|
4
|
+
export interface ConfigChangeFinding {
|
|
5
|
+
severity: "critical" | "high" | "medium" | "low";
|
|
6
|
+
category: string;
|
|
7
|
+
title: string;
|
|
8
|
+
description: string;
|
|
9
|
+
recommendation: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function scanConfigChange(before: string, after: string, filePath?: string, format?: "markdown" | "json"): string;
|
|
12
|
+
//# sourceMappingURL=scan-config-change.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scan-config-change.d.ts","sourceRoot":"","sources":["../../src/tools/scan-config-change.ts"],"names":[],"mappings":"AACA;;GAEG;AAEH,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;IACjD,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;CACxB;AA0DD,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,GAAE,MAAiB,EAC1D,MAAM,GAAE,UAAU,GAAG,MAAe,GACnC,MAAM,CA8CR"}
|