secure-scan 1.2.3 → 1.2.5
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/README.md +85 -317
- package/aur/.SRCINFO +11 -0
- package/aur/PKGBUILD +28 -0
- package/debian/changelog +10 -0
- package/debian/compat +1 -0
- package/debian/control +16 -0
- package/debian/rules +17 -0
- package/dist/cli/index.js +109 -9
- package/dist/cli/index.js.map +1 -1
- package/docs/V1.2.1-IA_Performances.md +2 -2
- package/package.json +2 -2
- package/secure-scan.config.json +2 -16
- package/src/cli/index.ts +117 -9
- package/dist/core/engine/index.d.ts +0 -5
- package/dist/core/engine/index.d.ts.map +0 -1
- package/dist/core/engine/index.js +0 -21
- package/dist/core/engine/index.js.map +0 -1
- package/dist/core/engine/ruleEngine.d.ts +0 -46
- package/dist/core/engine/ruleEngine.d.ts.map +0 -1
- package/dist/core/engine/ruleEngine.js +0 -173
- package/dist/core/engine/ruleEngine.js.map +0 -1
- package/dist/core/index.d.ts +0 -8
- package/dist/core/index.d.ts.map +0 -1
- package/dist/core/index.js +0 -24
- package/dist/core/index.js.map +0 -1
- package/dist/core/scanner/fileScanner.d.ts +0 -31
- package/dist/core/scanner/fileScanner.d.ts.map +0 -1
- package/dist/core/scanner/fileScanner.js +0 -199
- package/dist/core/scanner/fileScanner.js.map +0 -1
- package/dist/core/scanner/index.d.ts +0 -5
- package/dist/core/scanner/index.d.ts.map +0 -1
- package/dist/core/scanner/index.js +0 -21
- package/dist/core/scanner/index.js.map +0 -1
- package/dist/core/scoring/index.d.ts +0 -5
- package/dist/core/scoring/index.d.ts.map +0 -1
- package/dist/core/scoring/index.js +0 -21
- package/dist/core/scoring/index.js.map +0 -1
- package/dist/core/scoring/riskScoring.d.ts +0 -49
- package/dist/core/scoring/riskScoring.d.ts.map +0 -1
- package/dist/core/scoring/riskScoring.js +0 -180
- package/dist/core/scoring/riskScoring.js.map +0 -1
- package/dist/core/securityScanner.d.ts +0 -47
- package/dist/core/securityScanner.d.ts.map +0 -1
- package/dist/core/securityScanner.js +0 -298
- package/dist/core/securityScanner.js.map +0 -1
- package/reporte-test.html +0 -5036
- package/src/analyzers/javascript/PROMPT_JS_ANALYZER.md +0 -267
- package/src/rules/malware/INFO.md +0 -287
package/dist/cli/index.js
CHANGED
|
@@ -201,18 +201,118 @@ program
|
|
|
201
201
|
return;
|
|
202
202
|
}
|
|
203
203
|
const defaultConfig = {
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
204
|
+
"$schema": "https://raw.githubusercontent.com/Sobdev/secure-scan/main/schema.json",
|
|
205
|
+
version: "1.0.0",
|
|
206
|
+
scan: {
|
|
207
|
+
languages: [
|
|
208
|
+
"javascript",
|
|
209
|
+
"typescript",
|
|
210
|
+
"python",
|
|
211
|
+
"php",
|
|
212
|
+
"java",
|
|
213
|
+
"c",
|
|
214
|
+
"cpp",
|
|
215
|
+
"csharp",
|
|
216
|
+
"dockerfile",
|
|
217
|
+
"yaml",
|
|
218
|
+
"terraform"
|
|
219
|
+
],
|
|
220
|
+
exclude: [
|
|
221
|
+
"node_modules",
|
|
222
|
+
"dist",
|
|
223
|
+
"vendor",
|
|
224
|
+
".git"
|
|
225
|
+
],
|
|
226
|
+
include: [],
|
|
227
|
+
maxFileSize: 1048576,
|
|
228
|
+
maxFiles: 10000,
|
|
229
|
+
followSymlinks: false
|
|
230
|
+
},
|
|
231
|
+
rules: {
|
|
232
|
+
enabled: true,
|
|
233
|
+
categories: {
|
|
234
|
+
vulnerability: true,
|
|
235
|
+
malware: true
|
|
236
|
+
},
|
|
237
|
+
severity: {
|
|
238
|
+
critical: true,
|
|
239
|
+
high: true,
|
|
240
|
+
medium: true,
|
|
241
|
+
low: true,
|
|
242
|
+
info: false
|
|
243
|
+
},
|
|
244
|
+
customRulesPath: null,
|
|
245
|
+
disabledRules: []
|
|
246
|
+
},
|
|
208
247
|
ai: {
|
|
209
248
|
enabled: false,
|
|
210
|
-
provider:
|
|
211
|
-
model:
|
|
249
|
+
provider: "local",
|
|
250
|
+
model: "codellama:7b-instruct",
|
|
251
|
+
apiKey: null,
|
|
252
|
+
endpoint: "http://localhost:11434/api/generate",
|
|
253
|
+
enhanceFindings: true,
|
|
254
|
+
generateSummary: true,
|
|
255
|
+
maxTokens: 4096,
|
|
256
|
+
temperature: 0.1,
|
|
257
|
+
performance: {
|
|
258
|
+
parallelRequests: 2,
|
|
259
|
+
numGpuLayers: -1,
|
|
260
|
+
numThreads: 8,
|
|
261
|
+
contextSize: 4096,
|
|
262
|
+
batchSize: 512,
|
|
263
|
+
enableCache: true,
|
|
264
|
+
useMmap: true,
|
|
265
|
+
useMlock: false,
|
|
266
|
+
timeout: 120000
|
|
267
|
+
}
|
|
212
268
|
},
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
269
|
+
output: {
|
|
270
|
+
format: "html",
|
|
271
|
+
path: "./secure-scan-report",
|
|
272
|
+
filename: "security-report",
|
|
273
|
+
includeSource: true,
|
|
274
|
+
groupBy: "severity",
|
|
275
|
+
sortBy: "severity"
|
|
276
|
+
},
|
|
277
|
+
scoring: {
|
|
278
|
+
enabled: true,
|
|
279
|
+
weights: {
|
|
280
|
+
critical: 100,
|
|
281
|
+
high: 50,
|
|
282
|
+
medium: 20,
|
|
283
|
+
low: 5,
|
|
284
|
+
info: 1
|
|
285
|
+
},
|
|
286
|
+
categoryMultipliers: {
|
|
287
|
+
vulnerability: 1.0,
|
|
288
|
+
malware: 1.5
|
|
289
|
+
},
|
|
290
|
+
thresholds: {
|
|
291
|
+
fail: 70,
|
|
292
|
+
warn: 40
|
|
293
|
+
}
|
|
294
|
+
},
|
|
295
|
+
performance: {
|
|
296
|
+
parallelism: 4,
|
|
297
|
+
timeout: 300000,
|
|
298
|
+
cacheEnabled: true,
|
|
299
|
+
cachePath: ".secure-scan-cache"
|
|
300
|
+
},
|
|
301
|
+
integrations: {
|
|
302
|
+
git: {
|
|
303
|
+
enabled: true,
|
|
304
|
+
scanOnlyChanged: false,
|
|
305
|
+
baseBranch: "main"
|
|
306
|
+
},
|
|
307
|
+
sarif: {
|
|
308
|
+
enabled: false,
|
|
309
|
+
path: "./results.sarif"
|
|
310
|
+
}
|
|
311
|
+
},
|
|
312
|
+
logging: {
|
|
313
|
+
level: "info",
|
|
314
|
+
file: null,
|
|
315
|
+
colors: true
|
|
216
316
|
}
|
|
217
317
|
};
|
|
218
318
|
fs.writeFileSync(configPath, JSON.stringify(defaultConfig, null, 2));
|
package/dist/cli/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":";;AACA;;;GAGG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,yCAAoC;AACpC,kDAA0B;AAC1B,8CAAsB;AACtB,2CAA6B;AAC7B,uCAAyB;AAEzB,uEAAoE;AACpE,oCAAmE;AACnE,4CAA8C;AAE9C,0BAA0B;AAC1B,MAAM,WAAW,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC;AAElD,qBAAqB;AACrB,MAAM,OAAO,GAAG,IAAI,mBAAO,EAAE,CAAC;AAE9B,OAAO;KACJ,IAAI,CAAC,aAAa,CAAC;KACnB,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC;KAC5B,WAAW,CAAC,eAAK,CAAC,IAAI,CAAC,gEAAgE,CAAC,CAAC,CAAC;AAE7F;;GAEG;AACH,OAAO;KACJ,OAAO,CAAC,aAAa,CAAC;KACtB,WAAW,CAAC,sEAAsE,CAAC;KACnF,MAAM,CAAC,qBAAqB,EAAE,2CAA2C,CAAC;KAC1E,MAAM,CAAC,yBAAyB,EAAE,uCAAuC,CAAC;KAC1E,MAAM,CAAC,0BAA0B,EAAE,uCAAuC,CAAC;KAC3E,MAAM,CAAC,wBAAwB,EAAE,iEAAiE,EAAE,MAAM,CAAC;KAC3G,MAAM,CAAC,MAAM,EAAE,2BAA2B,CAAC;KAC3C,MAAM,CAAC,iBAAiB,EAAE,0EAA0E,CAAC;KACrG,MAAM,CAAC,0BAA0B,EAAE,kEAAkE,EAAE,MAAM,CAAC;KAC9G,MAAM,CAAC,oBAAoB,EAAE,6FAA6F,CAAC;KAC3H,MAAM,CAAC,qBAAqB,EAAE,+EAA+E,CAAC;KAC9G,MAAM,CAAC,eAAe,EAAE,0BAA0B,CAAC;KACnD,MAAM,CAAC,QAAQ,EAAE,wCAAwC,CAAC;KAC1D,MAAM,CAAC,yBAAyB,EAAE,gDAAgD,EAAE,SAAS,CAAC;KAC9F,MAAM,CAAC,mBAAmB,EAAE,gDAAgD,EAAE,IAAI,CAAC;KACnF,MAAM,CAAC,KAAK,EAAE,WAAmB,EAAE,OAAY,EAAE,EAAE;IAClD,IAAI,CAAC;QACH,wBAAwB;QACxB,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC/C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;YACjC,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,+BAA+B,YAAY,EAAE,CAAC,CAAC,CAAC;YACxE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,gBAAgB;QAChB,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,IAAA,oBAAW,EAAC,OAAO,CAAC,CAAC;QACvB,CAAC;QAED,kBAAkB;QAClB,IAAI,SAA0C,CAAC;QAC/C,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;QACtF,CAAC;QAED,yBAAyB;QACzB,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAE/F,iBAAiB;QACjB,MAAM,WAAW,GAA6B;YAC5C,MAAM,EAAE,gBAAQ,CAAC,IAAI;YACrB,KAAK,EAAE,gBAAQ,CAAC,GAAG;YACnB,QAAQ,EAAE,gBAAQ,CAAC,MAAM;YACzB,MAAM,EAAE,gBAAQ,CAAC,IAAI;YACrB,UAAU,EAAE,gBAAQ,CAAC,QAAQ;SAC9B,CAAC;QACF,MAAM,WAAW,GAAG,WAAW,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,IAAI,gBAAQ,CAAC,IAAI,CAAC;QAEpF,wBAAwB;QACxB,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QAEvD,eAAe;QACf,yCAAyC;QACzC,MAAM,oBAAoB,GAAG,qCAAqC,CAAC;QACnE,MAAM,iBAAiB,GAAG,uBAAuB,CAAC;QAElD,MAAM,MAAM,GAAe;YACzB,WAAW,EAAE,YAAY;YACzB,UAAU,EAAE,OAAO,CAAC,MAAM;YAC1B,SAAS;YACT,OAAO;YACP,WAAW;YACX,KAAK,EAAE,OAAO,CAAC,EAAE;YACjB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,WAAW,EAAE,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC;YAC1C,QAAQ,EAAE,UAAU;YACpB,QAAQ,EAAE,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;gBACrB,QAAQ,EAAE,OAAO,CAAC,UAAU;gBAC5B,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc;gBACpD,KAAK,EAAE,OAAO,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,SAAS,CAAC;gBAC1F,QAAQ,EAAE,OAAO,CAAC,UAAU,IAAI,CAAC,OAAO,CAAC,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC;aACpG,CAAC,CAAC,CAAC,SAAS;SACd,CAAC;QAEF,WAAW;QACX,MAAM,OAAO,GAAG,IAAA,aAAG,EAAC,uCAAuC,CAAC,CAAC,KAAK,EAAE,CAAC;QAErE,MAAM,OAAO,GAAG,IAAI,iCAAe,CAAC,MAAM,CAAC,CAAC;QAE5C,OAAO,CAAC,IAAI,GAAG,wBAAwB,CAAC;QACxC,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;QAEpC,OAAO,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC;QAExC,iBAAiB;QACjB,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,CAAC;aAAM,CAAC;YACN,gBAAgB;YAChB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAChB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACxC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC;YACvD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACxC,OAAO,CAAC,GAAG,CAAC,8BAA8B,eAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YACnF,OAAO,CAAC,GAAG,CAAC,2BAA2B,eAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YAChF,OAAO,CAAC,GAAG,CAAC,oBAAoB,eAAK,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YACxE,OAAO,CAAC,GAAG,CAAC,oBAAoB,eAAK,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;YACjG,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEhB,qBAAqB;YACrB,MAAM,EAAE,kBAAkB,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC;YAC5C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC,CAAC;YACtD,OAAO,CAAC,GAAG,CAAC,MAAM,eAAK,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,kBAAkB,CAAC,QAAQ,IAAI,CAAC,EAAE,CAAC,CAAC;YACxF,OAAO,CAAC,GAAG,CAAC,MAAM,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,kBAAkB,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC;YACzE,OAAO,CAAC,GAAG,CAAC,MAAM,eAAK,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,kBAAkB,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,CAAC;YAC/E,OAAO,CAAC,GAAG,CAAC,MAAM,eAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,kBAAkB,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;YAC1E,OAAO,CAAC,GAAG,CAAC,MAAM,eAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,kBAAkB,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC;YAC1E,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEhB,aAAa;YACb,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,CAAC,eAAK,CAAC,GAAG,CAAC,CAAC;gBACrC,MAAM,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,CAAC,eAAK,CAAC,MAAM,CAAC,CAAC,CAAC,eAAK,CAAC,KAAK,CAAC;YACrE,OAAO,CAAC,GAAG,CAAC,+BAA+B,SAAS,CAAC,MAAM,CAAC,SAAS,GAAG,MAAM,CAAC,KAAK,MAAM,CAAC,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;YAEvH,sDAAsD;YACtD,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;gBACnB,IAAI,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;gBAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;gBACnD,+CAA+C;gBAC/C,IAAI,GAAG,KAAK,EAAE,EAAE,CAAC;oBACf,UAAU,GAAG,GAAG,UAAU,OAAO,CAAC;gBACpC,CAAC;gBACD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAChB,OAAO,CAAC,GAAG,CAAC,8BAA8B,eAAK,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YACtE,CAAC;YAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACxC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEhB,4CAA4C;YAC5C,IAAI,kBAAkB,CAAC,QAAQ,GAAG,CAAC,EAAE,CAAC;gBACpC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;iBAAM,IAAI,kBAAkB,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC;gBACvC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;QACH,CAAC;IAEH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,0BAA0B,KAAK,EAAE,CAAC,CAAC,CAAC;QAC5D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC;AAEL;;GAEG;AACH,OAAO;KACJ,OAAO,CAAC,MAAM,CAAC;KACf,WAAW,CAAC,kEAAkE,CAAC;KAC/E,MAAM,CAAC,GAAG,EAAE;IACX,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,yBAAyB,CAAC,CAAC;IAEvE,IAAI,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC9B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,mEAAmE,CAAC,CAAC,CAAC;QAC/F,OAAO;IACT,CAAC;IAED,MAAM,aAAa,GAAG;QACpB,OAAO,EAAE,CAAC,cAAc,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC;QACnD,SAAS,EAAE,CAAC,YAAY,EAAE,YAAY,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,CAAC;QACtF,WAAW,EAAE,KAAK;QAClB,QAAQ,EAAE,IAAI;QACd,EAAE,EAAE;YACF,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,QAAQ;YAClB,KAAK,EAAE,OAAO;SACf;QACD,KAAK,EAAE;YACL,QAAQ,EAAE,EAAE;YACZ,MAAM,EAAE,EAAE;SACX;KACF,CAAC;IAEF,EAAE,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IACrE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC,CAAC;AACvE,CAAC,CAAC,CAAC;AAEL;;GAEG;AACH,OAAO;KACJ,OAAO,CAAC,OAAO,CAAC;KAChB,WAAW,CAAC,kDAAkD,CAAC;KAC/D,MAAM,CAAC,uBAAuB,EAAE,sBAAsB,CAAC;KACvD,MAAM,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;IAC7B,MAAM,EAAE,WAAW,EAAE,GAAG,wDAAa,UAAU,GAAC,CAAC;IACjD,IAAI,KAAK,GAAG,WAAW,EAAE,CAAC;IAE1B,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;QACrB,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC,CAAC;IAClE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAExC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,aAAa,GAAG;YACpB,QAAQ,EAAE,eAAK,CAAC,GAAG;YACnB,IAAI,EAAE,eAAK,CAAC,GAAG;YACf,MAAM,EAAE,eAAK,CAAC,MAAM;YACpB,GAAG,EAAE,eAAK,CAAC,KAAK;YAChB,IAAI,EAAE,eAAK,CAAC,IAAI;SACjB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,eAAK,CAAC,KAAK,CAAC;QAEhC,OAAO,CAAC,GAAG,CAAC,GAAG,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,aAAa,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;QAC3F,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAC9B,OAAO,CAAC,GAAG,CAAC,KAAK,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;QAC1D,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACxC,OAAO,CAAC,GAAG,CAAC,UAAU,KAAK,CAAC,MAAM,WAAW,CAAC,CAAC;AACjD,CAAC,CAAC,CAAC;AAEL;;GAEG;AACH,OAAO;KACJ,OAAO,CAAC,SAAS,CAAC;KAClB,WAAW,CAAC,gCAAgC,CAAC;KAC7C,MAAM,CAAC,GAAG,EAAE;IACX,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,qBAAqB,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;IACpE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,wDAAwD,CAAC,CAAC,CAAC;AACpF,CAAC,CAAC,CAAC;AAEL,sBAAsB;AACtB,OAAO,CAAC,KAAK,EAAE,CAAC;AAEhB,kCAAkC;AAClC,IAAI,OAAO,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;IAC9B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC;;;;;;;;;;;;;GAatB,CAAC,CAAC,CAAC;AACN,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,7 +10,7 @@ La versión **V1.2.1-IA_Performances** introduce mejoras significativas en el re
|
|
|
10
10
|
|
|
11
11
|
Windows puede detectar como malware el módulo de `categories` y puede eliminar algunos archivos relacionados. Esto es un falso positivo debido a las reglas de detección avanzadas incluidas en esta actualización.
|
|
12
12
|
|
|
13
|
-

|
|
14
14
|
|
|
15
15
|
---
|
|
16
16
|
|
|
@@ -113,4 +113,4 @@ Se añadieron 81 reglas distribuidas en 7 categorías:
|
|
|
113
113
|
|
|
114
114
|
## Conclusión
|
|
115
115
|
|
|
116
|
-
La versión **V1.2.1-IA_Performances** establece un nuevo estándar para herramientas SAST con capacidades avanzadas de detección, arquitectura modular y soporte para IA. Esta actualización asegura que Secure-Scan sea una solución confiable, escalable y lista para producción.
|
|
116
|
+
La versión **V1.2.1-IA_Performances** establece un nuevo estándar para herramientas SAST con capacidades avanzadas de detección, arquitectura modular y soporte para IA. Esta actualización asegura que Secure-Scan sea una solución confiable, escalable y lista para producción.
|
package/package.json
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "secure-scan",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.5",
|
|
4
4
|
"description": "Herramienta SAST (Análisis Estático de Seguridad) para detectar vulnerabilidades y código malicioso.",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"bin": {
|
|
7
|
-
"secure
|
|
7
|
+
"secure": "./dist/cli/index.js"
|
|
8
8
|
},
|
|
9
9
|
"repository": {
|
|
10
10
|
"type": "git",
|
package/secure-scan.config.json
CHANGED
|
@@ -16,22 +16,8 @@
|
|
|
16
16
|
"yaml",
|
|
17
17
|
"terraform"
|
|
18
18
|
],
|
|
19
|
-
"exclude": [
|
|
20
|
-
|
|
21
|
-
"**/vendor/**",
|
|
22
|
-
"**/venv/**",
|
|
23
|
-
"**/.venv/**",
|
|
24
|
-
"**/dist/**",
|
|
25
|
-
"**/build/**",
|
|
26
|
-
"**/target/**",
|
|
27
|
-
"**/.git/**",
|
|
28
|
-
"**/coverage/**",
|
|
29
|
-
"**/__pycache__/**",
|
|
30
|
-
"**/*.min.js",
|
|
31
|
-
"**/*.min.css",
|
|
32
|
-
"**/package-lock.json",
|
|
33
|
-
"**/yarn.lock",
|
|
34
|
-
"**/composer.lock"
|
|
19
|
+
"exclude": [ "aqui se agregan las exclusiones de archivos o carpetas"
|
|
20
|
+
|
|
35
21
|
],
|
|
36
22
|
"include": [],
|
|
37
23
|
"maxFileSize": 1048576,
|
package/src/cli/index.ts
CHANGED
|
@@ -187,18 +187,126 @@ program
|
|
|
187
187
|
}
|
|
188
188
|
|
|
189
189
|
const defaultConfig = {
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
190
|
+
"$schema": "https://raw.githubusercontent.com/Sobdev/secure-scan/main/schema.json",
|
|
191
|
+
version: "1.0.0",
|
|
192
|
+
|
|
193
|
+
scan: {
|
|
194
|
+
languages: [
|
|
195
|
+
"javascript",
|
|
196
|
+
"typescript",
|
|
197
|
+
"python",
|
|
198
|
+
"php",
|
|
199
|
+
"java",
|
|
200
|
+
"c",
|
|
201
|
+
"cpp",
|
|
202
|
+
"csharp",
|
|
203
|
+
"dockerfile",
|
|
204
|
+
"yaml",
|
|
205
|
+
"terraform"
|
|
206
|
+
],
|
|
207
|
+
exclude: [
|
|
208
|
+
"node_modules",
|
|
209
|
+
"dist",
|
|
210
|
+
"vendor",
|
|
211
|
+
".git"
|
|
212
|
+
],
|
|
213
|
+
include: [],
|
|
214
|
+
maxFileSize: 1048576,
|
|
215
|
+
maxFiles: 10000,
|
|
216
|
+
followSymlinks: false
|
|
217
|
+
},
|
|
218
|
+
|
|
219
|
+
rules: {
|
|
220
|
+
enabled: true,
|
|
221
|
+
categories: {
|
|
222
|
+
vulnerability: true,
|
|
223
|
+
malware: true
|
|
224
|
+
},
|
|
225
|
+
severity: {
|
|
226
|
+
critical: true,
|
|
227
|
+
high: true,
|
|
228
|
+
medium: true,
|
|
229
|
+
low: true,
|
|
230
|
+
info: false
|
|
231
|
+
},
|
|
232
|
+
customRulesPath: null,
|
|
233
|
+
disabledRules: []
|
|
234
|
+
},
|
|
235
|
+
|
|
194
236
|
ai: {
|
|
195
237
|
enabled: false,
|
|
196
|
-
provider:
|
|
197
|
-
model:
|
|
238
|
+
provider: "local",
|
|
239
|
+
model: "codellama:7b-instruct",
|
|
240
|
+
apiKey: null,
|
|
241
|
+
endpoint: "http://localhost:11434/api/generate",
|
|
242
|
+
enhanceFindings: true,
|
|
243
|
+
generateSummary: true,
|
|
244
|
+
maxTokens: 4096,
|
|
245
|
+
temperature: 0.1,
|
|
246
|
+
performance: {
|
|
247
|
+
parallelRequests: 2,
|
|
248
|
+
numGpuLayers: -1,
|
|
249
|
+
numThreads: 8,
|
|
250
|
+
contextSize: 4096,
|
|
251
|
+
batchSize: 512,
|
|
252
|
+
enableCache: true,
|
|
253
|
+
useMmap: true,
|
|
254
|
+
useMlock: false,
|
|
255
|
+
timeout: 120000
|
|
256
|
+
}
|
|
198
257
|
},
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
258
|
+
|
|
259
|
+
output: {
|
|
260
|
+
format: "html",
|
|
261
|
+
path: "./secure-scan-report",
|
|
262
|
+
filename: "security-report",
|
|
263
|
+
includeSource: true,
|
|
264
|
+
groupBy: "severity",
|
|
265
|
+
sortBy: "severity"
|
|
266
|
+
},
|
|
267
|
+
|
|
268
|
+
scoring: {
|
|
269
|
+
enabled: true,
|
|
270
|
+
weights: {
|
|
271
|
+
critical: 100,
|
|
272
|
+
high: 50,
|
|
273
|
+
medium: 20,
|
|
274
|
+
low: 5,
|
|
275
|
+
info: 1
|
|
276
|
+
},
|
|
277
|
+
categoryMultipliers: {
|
|
278
|
+
vulnerability: 1.0,
|
|
279
|
+
malware: 1.5
|
|
280
|
+
},
|
|
281
|
+
thresholds: {
|
|
282
|
+
fail: 70,
|
|
283
|
+
warn: 40
|
|
284
|
+
}
|
|
285
|
+
},
|
|
286
|
+
|
|
287
|
+
performance: {
|
|
288
|
+
parallelism: 4,
|
|
289
|
+
timeout: 300000,
|
|
290
|
+
cacheEnabled: true,
|
|
291
|
+
cachePath: ".secure-scan-cache"
|
|
292
|
+
},
|
|
293
|
+
|
|
294
|
+
integrations: {
|
|
295
|
+
git: {
|
|
296
|
+
enabled: true,
|
|
297
|
+
scanOnlyChanged: false,
|
|
298
|
+
baseBranch: "main"
|
|
299
|
+
},
|
|
300
|
+
sarif: {
|
|
301
|
+
enabled: false,
|
|
302
|
+
path: "./results.sarif"
|
|
303
|
+
}
|
|
304
|
+
},
|
|
305
|
+
|
|
306
|
+
logging: {
|
|
307
|
+
level: "info",
|
|
308
|
+
file: null,
|
|
309
|
+
colors: true
|
|
202
310
|
}
|
|
203
311
|
};
|
|
204
312
|
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/engine/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,cAAc,CAAC"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Engine Module Exports
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
17
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
18
|
-
};
|
|
19
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
-
__exportStar(require("./ruleEngine"), exports);
|
|
21
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/engine/index.ts"],"names":[],"mappings":";AAAA;;GAEG;;;;;;;;;;;;;;;;AAEH,+CAA6B"}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Rule Engine
|
|
3
|
-
* Core engine for running security rules against code
|
|
4
|
-
*/
|
|
5
|
-
import { Rule, Finding, ScannedFile } from '../../types';
|
|
6
|
-
/**
|
|
7
|
-
* Rule Engine Class
|
|
8
|
-
*/
|
|
9
|
-
export declare class RuleEngine {
|
|
10
|
-
private rules;
|
|
11
|
-
constructor();
|
|
12
|
-
/**
|
|
13
|
-
* Load rules for analysis
|
|
14
|
-
*/
|
|
15
|
-
loadRules(rules: Rule[]): void;
|
|
16
|
-
/**
|
|
17
|
-
* Get rules for a specific language
|
|
18
|
-
*/
|
|
19
|
-
getRulesForLanguage(language: string): Rule[];
|
|
20
|
-
/**
|
|
21
|
-
* Run rules against a file
|
|
22
|
-
*/
|
|
23
|
-
analyzeFile(file: ScannedFile, rules?: Rule[]): Promise<Finding[]>;
|
|
24
|
-
/**
|
|
25
|
-
* Run a single rule against a file
|
|
26
|
-
*/
|
|
27
|
-
private runRule;
|
|
28
|
-
/**
|
|
29
|
-
* Match regex pattern against content
|
|
30
|
-
*/
|
|
31
|
-
private matchRegex;
|
|
32
|
-
/**
|
|
33
|
-
* Create a finding from a rule match
|
|
34
|
-
*/
|
|
35
|
-
private createFinding;
|
|
36
|
-
/**
|
|
37
|
-
* Deduplicate findings
|
|
38
|
-
*/
|
|
39
|
-
deduplicateFindings(findings: Finding[]): Finding[];
|
|
40
|
-
/**
|
|
41
|
-
* Sort findings by severity
|
|
42
|
-
*/
|
|
43
|
-
sortBySeverity(findings: Finding[]): Finding[];
|
|
44
|
-
}
|
|
45
|
-
export default RuleEngine;
|
|
46
|
-
//# sourceMappingURL=ruleEngine.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ruleEngine.d.ts","sourceRoot":"","sources":["../../../src/core/engine/ruleEngine.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EACL,IAAI,EACJ,OAAO,EACP,WAAW,EAMZ,MAAM,aAAa,CAAC;AAgBrB;;GAEG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,KAAK,CAAS;;IAMtB;;OAEG;IACH,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI;IAK9B;;OAEG;IACH,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,EAAE;IAO7C;;OAEG;IACG,WAAW,CAAC,IAAI,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAgBxE;;OAEG;YACW,OAAO;IAiBrB;;OAEG;IACH,OAAO,CAAC,UAAU;IAuClB;;OAEG;IACH,OAAO,CAAC,aAAa;IAyCrB;;OAEG;IACH,mBAAmB,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE;IAgBnD;;OAEG;IACH,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE;CAa/C;AAED,eAAe,UAAU,CAAC"}
|
|
@@ -1,173 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Rule Engine
|
|
4
|
-
* Core engine for running security rules against code
|
|
5
|
-
*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.RuleEngine = void 0;
|
|
8
|
-
const types_1 = require("../../types");
|
|
9
|
-
const utils_1 = require("../../utils");
|
|
10
|
-
const standards_1 = require("../../rules/standards");
|
|
11
|
-
const logger_1 = require("../../utils/logger");
|
|
12
|
-
/**
|
|
13
|
-
* Rule Engine Class
|
|
14
|
-
*/
|
|
15
|
-
class RuleEngine {
|
|
16
|
-
rules;
|
|
17
|
-
constructor() {
|
|
18
|
-
this.rules = [];
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Load rules for analysis
|
|
22
|
-
*/
|
|
23
|
-
loadRules(rules) {
|
|
24
|
-
this.rules = rules.filter(r => r.enabled);
|
|
25
|
-
logger_1.logger.info(`📋 Loaded ${this.rules.length} active rules`);
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* Get rules for a specific language
|
|
29
|
-
*/
|
|
30
|
-
getRulesForLanguage(language) {
|
|
31
|
-
return this.rules.filter(rule => rule.languages.includes(language) ||
|
|
32
|
-
rule.languages.includes('*'));
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Run rules against a file
|
|
36
|
-
*/
|
|
37
|
-
async analyzeFile(file, rules) {
|
|
38
|
-
const findings = [];
|
|
39
|
-
const applicableRules = rules || this.getRulesForLanguage(file.language || '');
|
|
40
|
-
for (const rule of applicableRules) {
|
|
41
|
-
try {
|
|
42
|
-
const ruleFindings = await this.runRule(rule, file);
|
|
43
|
-
findings.push(...ruleFindings);
|
|
44
|
-
}
|
|
45
|
-
catch (error) {
|
|
46
|
-
logger_1.logger.debug(`Error running rule ${rule.id}: ${error}`);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
return findings;
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Run a single rule against a file
|
|
53
|
-
*/
|
|
54
|
-
async runRule(rule, file) {
|
|
55
|
-
const findings = [];
|
|
56
|
-
for (const pattern of rule.patterns) {
|
|
57
|
-
if (pattern.type === 'regex') {
|
|
58
|
-
const matches = this.matchRegex(file.content, pattern.pattern, pattern.flags);
|
|
59
|
-
for (const match of matches) {
|
|
60
|
-
const finding = this.createFinding(rule, file, match);
|
|
61
|
-
findings.push(finding);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
return findings;
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Match regex pattern against content
|
|
69
|
-
*/
|
|
70
|
-
matchRegex(content, pattern, flags = 'gim') {
|
|
71
|
-
const matches = [];
|
|
72
|
-
const lines = content.split('\n');
|
|
73
|
-
try {
|
|
74
|
-
const regex = new RegExp(pattern, flags);
|
|
75
|
-
let lineOffset = 0;
|
|
76
|
-
for (let lineNum = 0; lineNum < lines.length; lineNum++) {
|
|
77
|
-
const line = lines[lineNum];
|
|
78
|
-
let match;
|
|
79
|
-
// Reset regex for each line
|
|
80
|
-
const lineRegex = new RegExp(pattern, flags.replace('g', '') + 'g');
|
|
81
|
-
while ((match = lineRegex.exec(line)) !== null) {
|
|
82
|
-
matches.push({
|
|
83
|
-
matched: true,
|
|
84
|
-
line: lineNum + 1, // 1-indexed
|
|
85
|
-
column: match.index + 1,
|
|
86
|
-
matchedText: match[0],
|
|
87
|
-
groups: match.groups
|
|
88
|
-
});
|
|
89
|
-
// Prevent infinite loop on zero-width matches
|
|
90
|
-
if (match[0].length === 0) {
|
|
91
|
-
lineRegex.lastIndex++;
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
lineOffset += line.length + 1;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
catch (error) {
|
|
98
|
-
logger_1.logger.debug(`Invalid regex pattern: ${pattern}`);
|
|
99
|
-
}
|
|
100
|
-
return matches;
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* Create a finding from a rule match
|
|
104
|
-
*/
|
|
105
|
-
createFinding(rule, file, match) {
|
|
106
|
-
const context = (0, utils_1.extractCodeContext)(file.content, match.line, 3);
|
|
107
|
-
const location = {
|
|
108
|
-
file: file.relativePath,
|
|
109
|
-
startLine: match.line,
|
|
110
|
-
endLine: match.line,
|
|
111
|
-
startColumn: match.column,
|
|
112
|
-
endColumn: match.column + match.matchedText.length
|
|
113
|
-
};
|
|
114
|
-
const snippet = {
|
|
115
|
-
code: context.code,
|
|
116
|
-
contextBefore: context.contextBefore,
|
|
117
|
-
contextAfter: context.contextAfter,
|
|
118
|
-
highlight: {
|
|
119
|
-
start: match.column - 1,
|
|
120
|
-
end: match.column - 1 + match.matchedText.length
|
|
121
|
-
}
|
|
122
|
-
};
|
|
123
|
-
return {
|
|
124
|
-
id: (0, utils_1.generateId)(),
|
|
125
|
-
title: rule.name,
|
|
126
|
-
description: rule.description,
|
|
127
|
-
severity: rule.severity,
|
|
128
|
-
threatType: rule.threatType,
|
|
129
|
-
category: rule.category,
|
|
130
|
-
location,
|
|
131
|
-
snippet,
|
|
132
|
-
standards: rule.standards.length > 0
|
|
133
|
-
? rule.standards
|
|
134
|
-
: (0, standards_1.getStandardsForThreat)(rule.threatType),
|
|
135
|
-
remediation: rule.remediation,
|
|
136
|
-
confidence: 85, // Default confidence for regex matches
|
|
137
|
-
analyzer: 'rule-engine',
|
|
138
|
-
timestamp: new Date(),
|
|
139
|
-
tags: rule.tags
|
|
140
|
-
};
|
|
141
|
-
}
|
|
142
|
-
/**
|
|
143
|
-
* Deduplicate findings
|
|
144
|
-
*/
|
|
145
|
-
deduplicateFindings(findings) {
|
|
146
|
-
const seen = new Set();
|
|
147
|
-
const unique = [];
|
|
148
|
-
for (const finding of findings) {
|
|
149
|
-
const key = `${finding.location.file}:${finding.location.startLine}:${finding.threatType}`;
|
|
150
|
-
if (!seen.has(key)) {
|
|
151
|
-
seen.add(key);
|
|
152
|
-
unique.push(finding);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
return unique;
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* Sort findings by severity
|
|
159
|
-
*/
|
|
160
|
-
sortBySeverity(findings) {
|
|
161
|
-
const severityOrder = {
|
|
162
|
-
[types_1.Severity.CRITICAL]: 0,
|
|
163
|
-
[types_1.Severity.HIGH]: 1,
|
|
164
|
-
[types_1.Severity.MEDIUM]: 2,
|
|
165
|
-
[types_1.Severity.LOW]: 3,
|
|
166
|
-
[types_1.Severity.INFO]: 4
|
|
167
|
-
};
|
|
168
|
-
return [...findings].sort((a, b) => severityOrder[a.severity] - severityOrder[b.severity]);
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
exports.RuleEngine = RuleEngine;
|
|
172
|
-
exports.default = RuleEngine;
|
|
173
|
-
//# sourceMappingURL=ruleEngine.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ruleEngine.js","sourceRoot":"","sources":["../../../src/core/engine/ruleEngine.ts"],"names":[],"mappings":"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"}
|
package/dist/core/index.d.ts
DELETED
package/dist/core/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,cAAc,mBAAmB,CAAC"}
|