postquant 0.4.2 → 0.7.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/README.md +45 -27
- package/dist/commands/analyze.d.ts.map +1 -1
- package/dist/commands/analyze.js +18 -23
- package/dist/commands/analyze.js.map +1 -1
- package/dist/index.js +4 -2
- package/dist/index.js.map +1 -1
- package/dist/output/cbom.d.ts.map +1 -1
- package/dist/output/cbom.js +1 -13
- package/dist/output/cbom.js.map +1 -1
- package/dist/output/json-code.d.ts.map +1 -1
- package/dist/output/json-code.js +2 -13
- package/dist/output/json-code.js.map +1 -1
- package/dist/output/json.d.ts.map +1 -1
- package/dist/output/json.js +2 -13
- package/dist/output/json.js.map +1 -1
- package/dist/output/sarif.d.ts.map +1 -1
- package/dist/output/sarif.js +1 -13
- package/dist/output/sarif.js.map +1 -1
- package/dist/output/terminal-code.d.ts.map +1 -1
- package/dist/output/terminal-code.js +6 -13
- package/dist/output/terminal-code.js.map +1 -1
- package/dist/output/terminal.d.ts.map +1 -1
- package/dist/output/terminal.js +6 -13
- package/dist/output/terminal.js.map +1 -1
- package/dist/scanner/code/ast/analyzer.d.ts +8 -0
- package/dist/scanner/code/ast/analyzer.d.ts.map +1 -0
- package/dist/scanner/code/ast/analyzer.js +117 -0
- package/dist/scanner/code/ast/analyzer.js.map +1 -0
- package/dist/scanner/code/ast/import-resolver.d.ts +13 -0
- package/dist/scanner/code/ast/import-resolver.d.ts.map +1 -0
- package/dist/scanner/code/ast/import-resolver.js +198 -0
- package/dist/scanner/code/ast/import-resolver.js.map +1 -0
- package/dist/scanner/code/ast/merge.d.ts +11 -0
- package/dist/scanner/code/ast/merge.d.ts.map +1 -0
- package/dist/scanner/code/ast/merge.js +50 -0
- package/dist/scanner/code/ast/merge.js.map +1 -0
- package/dist/scanner/code/ast/parser.d.ts +9 -0
- package/dist/scanner/code/ast/parser.d.ts.map +1 -0
- package/dist/scanner/code/ast/parser.js +58 -0
- package/dist/scanner/code/ast/parser.js.map +1 -0
- package/dist/scanner/code/ast/patterns/index.d.ts +5 -0
- package/dist/scanner/code/ast/patterns/index.d.ts.map +1 -0
- package/dist/scanner/code/ast/patterns/index.js +13 -0
- package/dist/scanner/code/ast/patterns/index.js.map +1 -0
- package/dist/scanner/code/ast/patterns/javascript.d.ts +3 -0
- package/dist/scanner/code/ast/patterns/javascript.d.ts.map +1 -0
- package/dist/scanner/code/ast/patterns/javascript.js +113 -0
- package/dist/scanner/code/ast/patterns/javascript.js.map +1 -0
- package/dist/scanner/code/ast/patterns/python.d.ts +3 -0
- package/dist/scanner/code/ast/patterns/python.d.ts.map +1 -0
- package/dist/scanner/code/ast/patterns/python.js +165 -0
- package/dist/scanner/code/ast/patterns/python.js.map +1 -0
- package/dist/scanner/code/ast/patterns/types.d.ts +23 -0
- package/dist/scanner/code/ast/patterns/types.d.ts.map +1 -0
- package/dist/scanner/code/ast/patterns/types.js +2 -0
- package/dist/scanner/code/ast/patterns/types.js.map +1 -0
- package/dist/scanner/code/ast/scope-detector.d.ts +8 -0
- package/dist/scanner/code/ast/scope-detector.d.ts.map +1 -0
- package/dist/scanner/code/ast/scope-detector.js +116 -0
- package/dist/scanner/code/ast/scope-detector.js.map +1 -0
- package/dist/scanner/code/ast/variable-resolver.d.ts +11 -0
- package/dist/scanner/code/ast/variable-resolver.d.ts.map +1 -0
- package/dist/scanner/code/ast/variable-resolver.js +115 -0
- package/dist/scanner/code/ast/variable-resolver.js.map +1 -0
- package/dist/scanner/code/discovery.d.ts +2 -0
- package/dist/scanner/code/discovery.d.ts.map +1 -1
- package/dist/scanner/code/discovery.js +8 -1
- package/dist/scanner/code/discovery.js.map +1 -1
- package/dist/scanner/code/grader.d.ts.map +1 -1
- package/dist/scanner/code/grader.js +2 -0
- package/dist/scanner/code/grader.js.map +1 -1
- package/dist/scanner/code/matcher.js +14 -4
- package/dist/scanner/code/matcher.js.map +1 -1
- package/dist/scanner/code/patterns/c.d.ts +3 -0
- package/dist/scanner/code/patterns/c.d.ts.map +1 -0
- package/dist/scanner/code/patterns/c.js +359 -0
- package/dist/scanner/code/patterns/c.js.map +1 -0
- package/dist/scanner/code/patterns/go.d.ts.map +1 -1
- package/dist/scanner/code/patterns/go.js +54 -0
- package/dist/scanner/code/patterns/go.js.map +1 -1
- package/dist/scanner/code/patterns/index.d.ts +3 -1
- package/dist/scanner/code/patterns/index.d.ts.map +1 -1
- package/dist/scanner/code/patterns/index.js +5 -1
- package/dist/scanner/code/patterns/index.js.map +1 -1
- package/dist/scanner/code/patterns/java.d.ts.map +1 -1
- package/dist/scanner/code/patterns/java.js +46 -0
- package/dist/scanner/code/patterns/java.js.map +1 -1
- package/dist/scanner/code/patterns/javascript.d.ts.map +1 -1
- package/dist/scanner/code/patterns/javascript.js +58 -0
- package/dist/scanner/code/patterns/javascript.js.map +1 -1
- package/dist/scanner/code/patterns/python.d.ts.map +1 -1
- package/dist/scanner/code/patterns/python.js +59 -0
- package/dist/scanner/code/patterns/python.js.map +1 -1
- package/dist/scanner/code/patterns/rust.d.ts +3 -0
- package/dist/scanner/code/patterns/rust.d.ts.map +1 -0
- package/dist/scanner/code/patterns/rust.js +246 -0
- package/dist/scanner/code/patterns/rust.js.map +1 -0
- package/dist/scanner/code/risk-assessor.d.ts.map +1 -1
- package/dist/scanner/code/risk-assessor.js +37 -0
- package/dist/scanner/code/risk-assessor.js.map +1 -1
- package/dist/scanner/grader.d.ts.map +1 -1
- package/dist/scanner/grader.js +2 -0
- package/dist/scanner/grader.js.map +1 -1
- package/dist/types/index.d.ts +22 -4
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/utils/version.d.ts +2 -0
- package/dist/utils/version.d.ts.map +1 -0
- package/dist/utils/version.js +19 -0
- package/dist/utils/version.js.map +1 -0
- package/grammars/tree-sitter-python.wasm +0 -0
- package/grammars/tree-sitter-typescript.wasm +0 -0
- package/package.json +4 -2
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { readdir, readFile } from 'node:fs/promises';
|
|
2
2
|
import { join, extname, basename } from 'node:path';
|
|
3
3
|
/** Extension → Language mapping. TypeScript maps to 'javascript'. */
|
|
4
|
-
const EXTENSION_MAP = {
|
|
4
|
+
export const EXTENSION_MAP = {
|
|
5
5
|
'.py': 'python',
|
|
6
6
|
'.pyw': 'python',
|
|
7
7
|
'.pyi': 'python',
|
|
@@ -15,6 +15,13 @@ const EXTENSION_MAP = {
|
|
|
15
15
|
'.tsx': 'javascript',
|
|
16
16
|
'.go': 'go',
|
|
17
17
|
'.java': 'java',
|
|
18
|
+
'.c': 'c',
|
|
19
|
+
'.h': 'c',
|
|
20
|
+
'.cpp': 'c',
|
|
21
|
+
'.hpp': 'c',
|
|
22
|
+
'.cc': 'c',
|
|
23
|
+
'.cxx': 'c',
|
|
24
|
+
'.rs': 'rust',
|
|
18
25
|
};
|
|
19
26
|
/** Directories and patterns always ignored regardless of config. */
|
|
20
27
|
const DEFAULT_IGNORE_DIRS = new Set([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"discovery.js","sourceRoot":"","sources":["../../../src/scanner/code/discovery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAGpD,qEAAqE;AACrE,MAAM,aAAa,GAA6B;
|
|
1
|
+
{"version":3,"file":"discovery.js","sourceRoot":"","sources":["../../../src/scanner/code/discovery.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"grader.d.ts","sourceRoot":"","sources":["../../../src/scanner/code/grader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EACd,gBAAgB,EAKhB,SAAS,EAEV,MAAM,sBAAsB,CAAC;AA6B9B;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,cAAc,GAAG,gBAAgB,
|
|
1
|
+
{"version":3,"file":"grader.d.ts","sourceRoot":"","sources":["../../../src/scanner/code/grader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EACd,gBAAgB,EAKhB,SAAS,EAEV,MAAM,sBAAsB,CAAC;AA6B9B;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,cAAc,GAAG,gBAAgB,CAuFpE;AAoCD;;;GAGG;AACH,wBAAgB,sBAAsB,CACpC,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,SAAS,GACnB,OAAO,CAET"}
|
|
@@ -99,6 +99,7 @@ export function gradeCodeScan(scan) {
|
|
|
99
99
|
}
|
|
100
100
|
}
|
|
101
101
|
const displayGrade = (baseGrade + modifier);
|
|
102
|
+
const pqcDetected = findings.some((f) => f.category === 'pqc-algorithm');
|
|
102
103
|
// Collect unique migration notes
|
|
103
104
|
const migrationSet = new Set();
|
|
104
105
|
for (const f of findings) {
|
|
@@ -112,6 +113,7 @@ export function gradeCodeScan(scan) {
|
|
|
112
113
|
grade: displayGrade,
|
|
113
114
|
baseGrade,
|
|
114
115
|
modifier,
|
|
116
|
+
pqcDetected,
|
|
115
117
|
findings,
|
|
116
118
|
migrationNotes: [...migrationSet],
|
|
117
119
|
summary: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"grader.js","sourceRoot":"","sources":["../../../src/scanner/code/grader.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"grader.js","sourceRoot":"","sources":["../../../src/scanner/code/grader.ts"],"names":[],"mappings":"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"}
|
|
@@ -52,7 +52,7 @@ export function matchFileContent(content, language, fileName) {
|
|
|
52
52
|
continue;
|
|
53
53
|
}
|
|
54
54
|
// Detect start of block comments
|
|
55
|
-
if ((language === 'javascript' || language === 'go' || language === 'java') &&
|
|
55
|
+
if ((language === 'javascript' || language === 'go' || language === 'java' || language === 'c' || language === 'rust') &&
|
|
56
56
|
trimmed.startsWith('/*')) {
|
|
57
57
|
if (!trimmed.includes('*/')) {
|
|
58
58
|
inBlockComment = true;
|
|
@@ -79,11 +79,11 @@ export function matchFileContent(content, language, fileName) {
|
|
|
79
79
|
// Skip single-line comments
|
|
80
80
|
if (language === 'python' && trimmed.startsWith('#'))
|
|
81
81
|
continue;
|
|
82
|
-
if ((language === 'javascript' || language === 'go' || language === 'java') &&
|
|
82
|
+
if ((language === 'javascript' || language === 'go' || language === 'java' || language === 'c' || language === 'rust') &&
|
|
83
83
|
trimmed.startsWith('//'))
|
|
84
84
|
continue;
|
|
85
85
|
// Skip Java block comment single-line: /** ... */
|
|
86
|
-
if ((language === 'javascript' || language === 'go' || language === 'java') &&
|
|
86
|
+
if ((language === 'javascript' || language === 'go' || language === 'java' || language === 'c' || language === 'rust') &&
|
|
87
87
|
trimmed.startsWith('/*') &&
|
|
88
88
|
trimmed.includes('*/'))
|
|
89
89
|
continue;
|
|
@@ -146,7 +146,7 @@ function stripInlineComment(line, language) {
|
|
|
146
146
|
// Simple heuristic: find # not inside quotes
|
|
147
147
|
return stripAfterChar(line, '#');
|
|
148
148
|
}
|
|
149
|
-
if (language === 'javascript' || language === 'go' || language === 'java') {
|
|
149
|
+
if (language === 'javascript' || language === 'go' || language === 'java' || language === 'c' || language === 'rust') {
|
|
150
150
|
return stripAfterStr(line, '//');
|
|
151
151
|
}
|
|
152
152
|
return line;
|
|
@@ -204,6 +204,16 @@ function isPureStringLiteral(line, language) {
|
|
|
204
204
|
if (/^\w+\s*:?=\s*".*"\s*$/.test(line))
|
|
205
205
|
return true;
|
|
206
206
|
}
|
|
207
|
+
if (language === 'c') {
|
|
208
|
+
// Lines like: const char *msg = "RSA_generate_key_ex is deprecated";
|
|
209
|
+
if (/^(?:const\s+)?(?:char|unsigned\s+char)\s*\*?\s*\w+\s*=\s*".*"\s*;\s*$/.test(line))
|
|
210
|
+
return true;
|
|
211
|
+
}
|
|
212
|
+
if (language === 'rust') {
|
|
213
|
+
// Lines like: let msg = "Rsa::generate is deprecated";
|
|
214
|
+
if (/^let\s+(?:mut\s+)?\w+\s*(?::\s*&?str\s*)?=\s*".*"\s*;\s*$/.test(line))
|
|
215
|
+
return true;
|
|
216
|
+
}
|
|
207
217
|
return false;
|
|
208
218
|
}
|
|
209
219
|
//# sourceMappingURL=matcher.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"matcher.js","sourceRoot":"","sources":["../../../src/scanner/code/matcher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAC9B,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAElC,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAalD;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,SAAS,CAC7B,QAAgB,EAChB,QAAkB;IAElB,MAAM,OAAO,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC9D,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC7C,MAAM,QAAQ,GAAG,gBAAgB,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IACnE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC;AAC/B,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,gBAAgB,CAC9B,OAAe,EACf,QAAkB,EAClB,QAAgB;IAEhB,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;IACvC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAE7D,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAElC,wDAAwD;IACxD,MAAM,UAAU,GAAG,IAAI,GAAG,EAAU,CAAC;IACrC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC,OAAO,CAAC,cAAc;gBAAE,SAAS;YACtC,IAAI,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;gBACvD,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,wDAAwD;IACxD,MAAM,QAAQ,GAAkB,EAAE,CAAC;IACnC,IAAI,cAAc,GAAG,KAAK,CAAC;IAC3B,IAAI,iBAAiB,GAA0B,IAAI,CAAC;IAEpD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,OAAO,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;QAE/B,iCAAiC;QACjC,IAAI,cAAc,EAAE,CAAC;YACnB,IACE,iBAAiB,KAAK,GAAG;gBACzB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EACtB,CAAC;gBACD,cAAc,GAAG,KAAK,CAAC;gBACvB,iBAAiB,GAAG,IAAI,CAAC;YAC3B,CAAC;iBAAM,IACL,iBAAiB,KAAK,QAAQ;gBAC9B,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EACpD,CAAC;gBACD,cAAc,GAAG,KAAK,CAAC;gBACvB,iBAAiB,GAAG,IAAI,CAAC;YAC3B,CAAC;YACD,SAAS;QACX,CAAC;QAED,iCAAiC;QACjC,IACE,CAAC,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,KAAK,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"matcher.js","sourceRoot":"","sources":["../../../src/scanner/code/matcher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAC9B,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAElC,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAalD;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,SAAS,CAC7B,QAAgB,EAChB,QAAkB;IAElB,MAAM,OAAO,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC9D,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC7C,MAAM,QAAQ,GAAG,gBAAgB,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IACnE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC;AAC/B,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,gBAAgB,CAC9B,OAAe,EACf,QAAkB,EAClB,QAAgB;IAEhB,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;IACvC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAE7D,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAElC,wDAAwD;IACxD,MAAM,UAAU,GAAG,IAAI,GAAG,EAAU,CAAC;IACrC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC,OAAO,CAAC,cAAc;gBAAE,SAAS;YACtC,IAAI,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;gBACvD,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,wDAAwD;IACxD,MAAM,QAAQ,GAAkB,EAAE,CAAC;IACnC,IAAI,cAAc,GAAG,KAAK,CAAC;IAC3B,IAAI,iBAAiB,GAA0B,IAAI,CAAC;IAEpD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,OAAO,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;QAE/B,iCAAiC;QACjC,IAAI,cAAc,EAAE,CAAC;YACnB,IACE,iBAAiB,KAAK,GAAG;gBACzB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EACtB,CAAC;gBACD,cAAc,GAAG,KAAK,CAAC;gBACvB,iBAAiB,GAAG,IAAI,CAAC;YAC3B,CAAC;iBAAM,IACL,iBAAiB,KAAK,QAAQ;gBAC9B,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EACpD,CAAC;gBACD,cAAc,GAAG,KAAK,CAAC;gBACvB,iBAAiB,GAAG,IAAI,CAAC;YAC3B,CAAC;YACD,SAAS;QACX,CAAC;QAED,iCAAiC;QACjC,IACE,CAAC,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,MAAM,CAAC;YAClH,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,EACxB,CAAC;YACD,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC5B,cAAc,GAAG,IAAI,CAAC;gBACtB,iBAAiB,GAAG,GAAG,CAAC;YAC1B,CAAC;YACD,SAAS;QACX,CAAC;QAED,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;YAC1B,IAAI,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC3D,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;gBACnC,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAC9B,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC1B,2EAA2E;oBAC3E,SAAS;gBACX,CAAC;qBAAM,CAAC;oBACN,6BAA6B;oBAC7B,cAAc,GAAG,IAAI,CAAC;oBACtB,iBAAiB,GAAG,QAAQ,CAAC;oBAC7B,SAAS;gBACX,CAAC;YACH,CAAC;QACH,CAAC;QAED,4BAA4B;QAC5B,IAAI,QAAQ,KAAK,QAAQ,IAAI,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC;YAAE,SAAS;QAC/D,IACE,CAAC,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,MAAM,CAAC;YAClH,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC;YACxB,SAAS;QAEX,kDAAkD;QAClD,IACE,CAAC,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,MAAM,CAAC;YAClH,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC;YACxB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;YACtB,SAAS;QAEX,qCAAqC;QACrC,MAAM,QAAQ,GAAG,kBAAkB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAEvD,uDAAuD;QACvD,IAAI,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC;YAAE,SAAS;QAEtD,+BAA+B;QAC/B,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,IAAI,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;gBACzD,MAAM,UAAU,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,YAAY;gBAEtC,uBAAuB;gBACvB,IAAI,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;gBACpC,IAAI,OAAO,CAAC,cAAc,IAAI,OAAO,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAChE,UAAU,GAAG,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC;gBAC9D,CAAC;gBAED,wCAAwC;gBACxC,IAAI,OAA2B,CAAC;gBAChC,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;gBACxB,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;oBAC7B,MAAM,KAAK,GAAG,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACtD,IAAI,KAAK,EAAE,CAAC;wBACV,yCAAyC;wBACzC,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;wBAC5D,IAAI,OAAO,EAAE,CAAC;4BACZ,OAAO,GAAG,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;4BAChC,IAAI,OAAO,CAAC,WAAW,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;gCAC3C,IAAI,GAAG,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;4BACtC,CAAC;wBACH,CAAC;oBACH,CAAC;gBACH,CAAC;gBAED,QAAQ,CAAC,IAAI,CAAC;oBACZ,SAAS,EAAE,OAAO,CAAC,EAAE;oBACrB,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,UAAU;oBAChB,WAAW,EAAE,OAAO;oBACpB,QAAQ;oBACR,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,SAAS,EAAE,OAAO,CAAC,SAAS;oBAC5B,OAAO;oBACP,IAAI;oBACJ,MAAM,EAAE,OAAO,CAAC,WAAW;oBAC3B,SAAS,EAAE,OAAO,CAAC,SAAS;oBAC5B,UAAU;iBACX,CAAC,CAAC;gBAEH,iEAAiE;gBACjE,MAAM;YACR,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,SAAS,kBAAkB,CAAC,IAAY,EAAE,QAAkB;IAC1D,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;QAC1B,6CAA6C;QAC7C,OAAO,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC;IACD,IAAI,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;QACrH,OAAO,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAS,cAAc,CAAC,IAAY,EAAE,IAAY;IAChD,IAAI,QAAQ,GAAG,KAAK,CAAC;IACrB,IAAI,QAAQ,GAAG,KAAK,CAAC;IACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACrC,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ;YAAE,QAAQ,GAAG,CAAC,QAAQ,CAAC;aAC5C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ;YAAE,QAAQ,GAAG,CAAC,QAAQ,CAAC;aACjD,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC9C,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QACjC,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAS,aAAa,CAAC,IAAY,EAAE,GAAW;IAC9C,IAAI,QAAQ,GAAG,KAAK,CAAC;IACrB,IAAI,QAAQ,GAAG,KAAK,CAAC;IACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACrC,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ;YAAE,QAAQ,GAAG,CAAC,QAAQ,CAAC;aAC5C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ;YAAE,QAAQ,GAAG,CAAC,QAAQ,CAAC;aACjD,IACH,CAAC,QAAQ;YACT,CAAC,QAAQ;YACT,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,EACrC,CAAC;YACD,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QACjC,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;GAEG;AACH,SAAS,mBAAmB,CAAC,IAAY,EAAE,QAAkB;IAC3D,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;QAC1B,6DAA6D;QAC7D,IAAI,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;QACxD,IAAI,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;IACvD,CAAC;IACD,IAAI,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;QACrD,yCAAyC;QACzC,IAAI,6DAA6D,CAAC,IAAI,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;IAC5F,CAAC;IACD,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;QACtB,qDAAqD;QACrD,IAAI,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;IACtD,CAAC;IACD,IAAI,QAAQ,KAAK,GAAG,EAAE,CAAC;QACrB,qEAAqE;QACrE,IAAI,uEAAuE,CAAC,IAAI,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;IACtG,CAAC;IACD,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;QACxB,uDAAuD;QACvD,IAAI,2DAA2D,CAAC,IAAI,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;IAC1F,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"c.d.ts","sourceRoot":"","sources":["../../../../src/scanner/code/patterns/c.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAa,MAAM,yBAAyB,CAAC;AAExE,eAAO,MAAM,SAAS,EAAE,aAAa,EAqWpC,CAAC"}
|
|
@@ -0,0 +1,359 @@
|
|
|
1
|
+
export const cPatterns = [
|
|
2
|
+
// === OpenSSL ===
|
|
3
|
+
{
|
|
4
|
+
id: 'c-rsa-keygen',
|
|
5
|
+
language: 'c',
|
|
6
|
+
category: 'asymmetric-encryption',
|
|
7
|
+
algorithm: 'RSA',
|
|
8
|
+
risk: 'critical',
|
|
9
|
+
confidence: 'medium',
|
|
10
|
+
importPatterns: [/openssl\/rsa\.h/, /openssl\/evp\.h/],
|
|
11
|
+
callPatterns: [
|
|
12
|
+
/RSA_generate_key_ex\s*\(/,
|
|
13
|
+
/RSA_generate_key\s*\(/,
|
|
14
|
+
/EVP_PKEY_keygen\s*\(/,
|
|
15
|
+
/EVP_PKEY_CTX_new_id\s*\(\s*EVP_PKEY_RSA/,
|
|
16
|
+
],
|
|
17
|
+
description: "RSA key generation is vulnerable to quantum attacks via Shor's algorithm",
|
|
18
|
+
migration: 'Migrate to ML-KEM (FIPS 203) for encryption or ML-DSA (FIPS 204) for signatures',
|
|
19
|
+
nistRef: 'FIPS 203/204',
|
|
20
|
+
cweId: 'CWE-327',
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
id: 'c-rsa-sign',
|
|
24
|
+
language: 'c',
|
|
25
|
+
category: 'digital-signature',
|
|
26
|
+
algorithm: 'RSA',
|
|
27
|
+
risk: 'critical',
|
|
28
|
+
confidence: 'medium',
|
|
29
|
+
callPatterns: [
|
|
30
|
+
/RSA_sign\s*\(/,
|
|
31
|
+
/RSA_verify\s*\(/,
|
|
32
|
+
/EVP_DigestSignInit\s*\(/,
|
|
33
|
+
/EVP_DigestVerifyInit\s*\(/,
|
|
34
|
+
/EVP_SignFinal\s*\(/,
|
|
35
|
+
/EVP_VerifyFinal\s*\(/,
|
|
36
|
+
],
|
|
37
|
+
description: "RSA digital signatures are vulnerable to quantum attacks via Shor's algorithm",
|
|
38
|
+
migration: 'Migrate to ML-DSA (FIPS 204) for digital signatures',
|
|
39
|
+
nistRef: 'FIPS 204',
|
|
40
|
+
cweId: 'CWE-327',
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
id: 'c-rsa-encrypt',
|
|
44
|
+
language: 'c',
|
|
45
|
+
category: 'asymmetric-encryption',
|
|
46
|
+
algorithm: 'RSA',
|
|
47
|
+
risk: 'critical',
|
|
48
|
+
confidence: 'medium',
|
|
49
|
+
callPatterns: [
|
|
50
|
+
/RSA_public_encrypt\s*\(/,
|
|
51
|
+
/RSA_private_decrypt\s*\(/,
|
|
52
|
+
/EVP_PKEY_encrypt\s*\(/,
|
|
53
|
+
/EVP_PKEY_decrypt\s*\(/,
|
|
54
|
+
],
|
|
55
|
+
description: "RSA encryption is vulnerable to quantum attacks via Shor's algorithm",
|
|
56
|
+
migration: 'Migrate to ML-KEM (FIPS 203) for key encapsulation',
|
|
57
|
+
nistRef: 'FIPS 203',
|
|
58
|
+
cweId: 'CWE-327',
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
id: 'c-ec-keygen',
|
|
62
|
+
language: 'c',
|
|
63
|
+
category: 'asymmetric-encryption',
|
|
64
|
+
algorithm: 'ECDSA',
|
|
65
|
+
risk: 'critical',
|
|
66
|
+
confidence: 'medium',
|
|
67
|
+
importPatterns: [/openssl\/ec\.h/, /openssl\/ecdsa\.h/],
|
|
68
|
+
callPatterns: [
|
|
69
|
+
/EC_KEY_generate_key\s*\(/,
|
|
70
|
+
/EC_KEY_new_by_curve_name\s*\(/,
|
|
71
|
+
/ECDSA_sign\s*\(/,
|
|
72
|
+
/ECDSA_do_sign\s*\(/,
|
|
73
|
+
/ECDH_compute_key\s*\(/,
|
|
74
|
+
/EVP_PKEY_CTX_new_id\s*\(\s*EVP_PKEY_EC/,
|
|
75
|
+
],
|
|
76
|
+
description: "EC key generation and operations are vulnerable to quantum attacks via Shor's algorithm",
|
|
77
|
+
migration: 'Migrate to ML-DSA (FIPS 204) for signatures or ML-KEM (FIPS 203) for key exchange',
|
|
78
|
+
nistRef: 'FIPS 203/204',
|
|
79
|
+
cweId: 'CWE-327',
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
id: 'c-dh-keygen',
|
|
83
|
+
language: 'c',
|
|
84
|
+
category: 'key-exchange',
|
|
85
|
+
algorithm: 'DH',
|
|
86
|
+
risk: 'critical',
|
|
87
|
+
confidence: 'medium',
|
|
88
|
+
importPatterns: [/openssl\/dh\.h/],
|
|
89
|
+
callPatterns: [
|
|
90
|
+
/DH_generate_key\s*\(/,
|
|
91
|
+
/DH_generate_parameters_ex\s*\(/,
|
|
92
|
+
/DH_compute_key\s*\(/,
|
|
93
|
+
/EVP_PKEY_CTX_new_id\s*\(\s*EVP_PKEY_DH/,
|
|
94
|
+
],
|
|
95
|
+
description: "Diffie-Hellman key exchange is vulnerable to quantum attacks via Shor's algorithm",
|
|
96
|
+
migration: 'Migrate to ML-KEM (FIPS 203) for key encapsulation',
|
|
97
|
+
nistRef: 'FIPS 203',
|
|
98
|
+
cweId: 'CWE-327',
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
id: 'c-dsa-keygen',
|
|
102
|
+
language: 'c',
|
|
103
|
+
category: 'digital-signature',
|
|
104
|
+
algorithm: 'DSA',
|
|
105
|
+
risk: 'critical',
|
|
106
|
+
confidence: 'medium',
|
|
107
|
+
importPatterns: [/openssl\/dsa\.h/],
|
|
108
|
+
callPatterns: [
|
|
109
|
+
/DSA_generate_key\s*\(/,
|
|
110
|
+
/DSA_generate_parameters_ex\s*\(/,
|
|
111
|
+
/DSA_sign\s*\(/,
|
|
112
|
+
/EVP_PKEY_CTX_new_id\s*\(\s*EVP_PKEY_DSA/,
|
|
113
|
+
],
|
|
114
|
+
description: "DSA is vulnerable to quantum attacks via Shor's algorithm",
|
|
115
|
+
migration: 'Migrate to ML-DSA (FIPS 204) for digital signatures',
|
|
116
|
+
nistRef: 'FIPS 204',
|
|
117
|
+
cweId: 'CWE-327',
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
id: 'c-md5',
|
|
121
|
+
language: 'c',
|
|
122
|
+
category: 'weak-hash',
|
|
123
|
+
algorithm: 'MD5',
|
|
124
|
+
risk: 'critical',
|
|
125
|
+
confidence: 'medium',
|
|
126
|
+
importPatterns: [/openssl\/md5\.h/],
|
|
127
|
+
callPatterns: [
|
|
128
|
+
/MD5_Init\s*\(/,
|
|
129
|
+
/MD5_Update\s*\(/,
|
|
130
|
+
/MD5_Final\s*\(/,
|
|
131
|
+
/MD5\s*\([^)]/,
|
|
132
|
+
/EVP_md5\s*\(\)/,
|
|
133
|
+
],
|
|
134
|
+
description: 'MD5 is cryptographically broken and unsuitable for any security use',
|
|
135
|
+
migration: 'Migrate to SHA-256 or SHA-3 for hashing',
|
|
136
|
+
cweId: 'CWE-328',
|
|
137
|
+
},
|
|
138
|
+
{
|
|
139
|
+
id: 'c-sha1',
|
|
140
|
+
language: 'c',
|
|
141
|
+
category: 'weak-hash',
|
|
142
|
+
algorithm: 'SHA-1',
|
|
143
|
+
risk: 'critical',
|
|
144
|
+
confidence: 'medium',
|
|
145
|
+
importPatterns: [/openssl\/sha\.h/],
|
|
146
|
+
callPatterns: [
|
|
147
|
+
/SHA1_Init\s*\(/,
|
|
148
|
+
/SHA1_Update\s*\(/,
|
|
149
|
+
/SHA1_Final\s*\(/,
|
|
150
|
+
/SHA1\s*\([^)]/,
|
|
151
|
+
/EVP_sha1\s*\(\)/,
|
|
152
|
+
],
|
|
153
|
+
description: 'SHA-1 is cryptographically broken with practical collision attacks',
|
|
154
|
+
migration: 'Migrate to SHA-256 or SHA-3 for hashing',
|
|
155
|
+
cweId: 'CWE-328',
|
|
156
|
+
},
|
|
157
|
+
{
|
|
158
|
+
id: 'c-sha256',
|
|
159
|
+
language: 'c',
|
|
160
|
+
category: 'safe-hash',
|
|
161
|
+
algorithm: 'SHA-256',
|
|
162
|
+
risk: 'safe',
|
|
163
|
+
confidence: 'medium',
|
|
164
|
+
callPatterns: [
|
|
165
|
+
/SHA256_Init\s*\(/,
|
|
166
|
+
/SHA256\s*\([^)]/,
|
|
167
|
+
/SHA384\s*\([^)]/,
|
|
168
|
+
/SHA512\s*\([^)]/,
|
|
169
|
+
/EVP_sha256\s*\(\)/,
|
|
170
|
+
/EVP_sha384\s*\(\)/,
|
|
171
|
+
/EVP_sha512\s*\(\)/,
|
|
172
|
+
],
|
|
173
|
+
description: 'SHA-256/384/512 are quantum-resistant hash functions',
|
|
174
|
+
migration: 'No migration needed — already quantum-safe',
|
|
175
|
+
},
|
|
176
|
+
{
|
|
177
|
+
id: 'c-aes',
|
|
178
|
+
language: 'c',
|
|
179
|
+
category: 'weak-symmetric',
|
|
180
|
+
algorithm: 'AES',
|
|
181
|
+
risk: 'moderate',
|
|
182
|
+
confidence: 'medium',
|
|
183
|
+
callPatterns: [
|
|
184
|
+
/EVP_aes_\d+_\w+\s*\(\)/,
|
|
185
|
+
/AES_set_encrypt_key\s*\(/,
|
|
186
|
+
/AES_set_decrypt_key\s*\(/,
|
|
187
|
+
/AES_encrypt\s*\(/,
|
|
188
|
+
/AES_cbc_encrypt\s*\(/,
|
|
189
|
+
],
|
|
190
|
+
keySizeExtractor: /EVP_aes_(\d+)/,
|
|
191
|
+
keySizeRisk: (size) => (size >= 256 ? 'safe' : 'moderate'),
|
|
192
|
+
description: "AES-128 provides reduced security against quantum attacks (Grover's algorithm)",
|
|
193
|
+
migration: 'Use AES-256 for quantum-resistant symmetric encryption',
|
|
194
|
+
},
|
|
195
|
+
// === libsodium ===
|
|
196
|
+
{
|
|
197
|
+
id: 'c-libsodium-box',
|
|
198
|
+
language: 'c',
|
|
199
|
+
category: 'key-exchange',
|
|
200
|
+
algorithm: 'Curve25519',
|
|
201
|
+
risk: 'critical',
|
|
202
|
+
confidence: 'medium',
|
|
203
|
+
importPatterns: [/sodium\.h/],
|
|
204
|
+
callPatterns: [
|
|
205
|
+
/crypto_box_keypair\s*\(/,
|
|
206
|
+
/crypto_box_easy\s*\(/,
|
|
207
|
+
/crypto_box_open_easy\s*\(/,
|
|
208
|
+
/crypto_box_seal\s*\(/,
|
|
209
|
+
/crypto_box_seal_open\s*\(/,
|
|
210
|
+
/crypto_scalarmult\s*\(/,
|
|
211
|
+
/crypto_scalarmult_base\s*\(/,
|
|
212
|
+
/crypto_kx_keypair\s*\(/,
|
|
213
|
+
/crypto_kx_client_session_keys\s*\(/,
|
|
214
|
+
/crypto_kx_server_session_keys\s*\(/,
|
|
215
|
+
],
|
|
216
|
+
description: "libsodium box/kx uses Curve25519, vulnerable to quantum attacks via Shor's algorithm",
|
|
217
|
+
migration: 'Migrate to ML-KEM (FIPS 203) for key exchange',
|
|
218
|
+
nistRef: 'FIPS 203',
|
|
219
|
+
cweId: 'CWE-327',
|
|
220
|
+
},
|
|
221
|
+
{
|
|
222
|
+
id: 'c-libsodium-sign',
|
|
223
|
+
language: 'c',
|
|
224
|
+
category: 'digital-signature',
|
|
225
|
+
algorithm: 'Ed25519',
|
|
226
|
+
risk: 'critical',
|
|
227
|
+
confidence: 'medium',
|
|
228
|
+
importPatterns: [/sodium\.h/],
|
|
229
|
+
callPatterns: [
|
|
230
|
+
/crypto_sign_keypair\s*\(/,
|
|
231
|
+
/crypto_sign\s*\(/,
|
|
232
|
+
/crypto_sign_open\s*\(/,
|
|
233
|
+
/crypto_sign_detached\s*\(/,
|
|
234
|
+
/crypto_sign_verify_detached\s*\(/,
|
|
235
|
+
/crypto_sign_ed25519_sk_to_curve25519\s*\(/,
|
|
236
|
+
],
|
|
237
|
+
description: "libsodium sign uses Ed25519, vulnerable to quantum attacks via Shor's algorithm",
|
|
238
|
+
migration: 'Migrate to ML-DSA (FIPS 204) for digital signatures',
|
|
239
|
+
nistRef: 'FIPS 204',
|
|
240
|
+
cweId: 'CWE-327',
|
|
241
|
+
},
|
|
242
|
+
{
|
|
243
|
+
id: 'c-libsodium-aead',
|
|
244
|
+
language: 'c',
|
|
245
|
+
category: 'safe-symmetric',
|
|
246
|
+
algorithm: 'ChaCha20-Poly1305',
|
|
247
|
+
risk: 'safe',
|
|
248
|
+
confidence: 'medium',
|
|
249
|
+
importPatterns: [/sodium\.h/],
|
|
250
|
+
callPatterns: [
|
|
251
|
+
/crypto_aead_chacha20poly1305_ietf_encrypt\s*\(/,
|
|
252
|
+
/crypto_aead_xchacha20poly1305_ietf_encrypt\s*\(/,
|
|
253
|
+
/crypto_aead_chacha20poly1305_ietf_decrypt\s*\(/,
|
|
254
|
+
/crypto_aead_xchacha20poly1305_ietf_decrypt\s*\(/,
|
|
255
|
+
/crypto_secretbox_easy\s*\(/,
|
|
256
|
+
/crypto_secretbox_open_easy\s*\(/,
|
|
257
|
+
],
|
|
258
|
+
description: 'libsodium AEAD/secretbox uses quantum-resistant symmetric encryption',
|
|
259
|
+
migration: 'No migration needed — already quantum-safe',
|
|
260
|
+
},
|
|
261
|
+
// === wolfSSL ===
|
|
262
|
+
{
|
|
263
|
+
id: 'c-wolfssl-rsa',
|
|
264
|
+
language: 'c',
|
|
265
|
+
category: 'asymmetric-encryption',
|
|
266
|
+
algorithm: 'RSA',
|
|
267
|
+
risk: 'critical',
|
|
268
|
+
confidence: 'medium',
|
|
269
|
+
importPatterns: [/wolfssl\/wolfcrypt\/rsa\.h/],
|
|
270
|
+
callPatterns: [
|
|
271
|
+
/wc_RsaKeyGen\s*\(/,
|
|
272
|
+
/wc_MakeRsaKey\s*\(/,
|
|
273
|
+
/wc_RsaPublicEncrypt\s*\(/,
|
|
274
|
+
/wc_RsaPrivateDecrypt\s*\(/,
|
|
275
|
+
/wc_RsaSSL_Sign\s*\(/,
|
|
276
|
+
/wc_RsaSSL_Verify\s*\(/,
|
|
277
|
+
],
|
|
278
|
+
description: "wolfSSL RSA operations are vulnerable to quantum attacks via Shor's algorithm",
|
|
279
|
+
migration: 'Migrate to ML-KEM (FIPS 203) for encryption or ML-DSA (FIPS 204) for signatures',
|
|
280
|
+
nistRef: 'FIPS 203/204',
|
|
281
|
+
cweId: 'CWE-327',
|
|
282
|
+
},
|
|
283
|
+
// === mbedTLS ===
|
|
284
|
+
{
|
|
285
|
+
id: 'c-mbedtls-rsa',
|
|
286
|
+
language: 'c',
|
|
287
|
+
category: 'asymmetric-encryption',
|
|
288
|
+
algorithm: 'RSA',
|
|
289
|
+
risk: 'critical',
|
|
290
|
+
confidence: 'medium',
|
|
291
|
+
importPatterns: [/mbedtls\/rsa\.h/],
|
|
292
|
+
callPatterns: [
|
|
293
|
+
/mbedtls_rsa_gen_key\s*\(/,
|
|
294
|
+
/mbedtls_rsa_pkcs1_encrypt\s*\(/,
|
|
295
|
+
/mbedtls_rsa_pkcs1_decrypt\s*\(/,
|
|
296
|
+
/mbedtls_rsa_pkcs1_sign\s*\(/,
|
|
297
|
+
/mbedtls_rsa_pkcs1_verify\s*\(/,
|
|
298
|
+
],
|
|
299
|
+
description: "mbedTLS RSA operations are vulnerable to quantum attacks via Shor's algorithm",
|
|
300
|
+
migration: 'Migrate to ML-KEM (FIPS 203) for encryption or ML-DSA (FIPS 204) for signatures',
|
|
301
|
+
nistRef: 'FIPS 203/204',
|
|
302
|
+
cweId: 'CWE-327',
|
|
303
|
+
},
|
|
304
|
+
{
|
|
305
|
+
id: 'c-mbedtls-ec',
|
|
306
|
+
language: 'c',
|
|
307
|
+
category: 'digital-signature',
|
|
308
|
+
algorithm: 'ECDSA',
|
|
309
|
+
risk: 'critical',
|
|
310
|
+
confidence: 'medium',
|
|
311
|
+
importPatterns: [/mbedtls\/ecdsa\.h/, /mbedtls\/ecp\.h/],
|
|
312
|
+
callPatterns: [
|
|
313
|
+
/mbedtls_ecdsa_genkey\s*\(/,
|
|
314
|
+
/mbedtls_ecdsa_write_signature\s*\(/,
|
|
315
|
+
/mbedtls_ecdsa_read_signature\s*\(/,
|
|
316
|
+
/mbedtls_ecdh_gen_public\s*\(/,
|
|
317
|
+
/mbedtls_ecdh_compute_shared\s*\(/,
|
|
318
|
+
],
|
|
319
|
+
description: "mbedTLS EC operations are vulnerable to quantum attacks via Shor's algorithm",
|
|
320
|
+
migration: 'Migrate to ML-DSA (FIPS 204) for signatures or ML-KEM (FIPS 203) for key exchange',
|
|
321
|
+
nistRef: 'FIPS 203/204',
|
|
322
|
+
cweId: 'CWE-327',
|
|
323
|
+
},
|
|
324
|
+
// === PQC (liboqs) ===
|
|
325
|
+
{
|
|
326
|
+
id: 'c-pqc-oqs-kem',
|
|
327
|
+
language: 'c',
|
|
328
|
+
category: 'pqc-algorithm',
|
|
329
|
+
algorithm: 'ML-KEM',
|
|
330
|
+
risk: 'safe',
|
|
331
|
+
confidence: 'high',
|
|
332
|
+
importPatterns: [/#include\s+[<"]oqs\/oqs\.h[>"]/],
|
|
333
|
+
callPatterns: [
|
|
334
|
+
/OQS_KEM_new\s*\(/,
|
|
335
|
+
/OQS_KEM_keypair\s*\(/,
|
|
336
|
+
/OQS_KEM_encaps\s*\(/,
|
|
337
|
+
/OQS_KEM_decaps\s*\(/,
|
|
338
|
+
],
|
|
339
|
+
description: 'liboqs ML-KEM (FIPS 203) key encapsulation',
|
|
340
|
+
migration: 'Already using PQC — verify parameter choices match NIST recommendations',
|
|
341
|
+
},
|
|
342
|
+
{
|
|
343
|
+
id: 'c-pqc-oqs-sig',
|
|
344
|
+
language: 'c',
|
|
345
|
+
category: 'pqc-algorithm',
|
|
346
|
+
algorithm: 'ML-DSA',
|
|
347
|
+
risk: 'safe',
|
|
348
|
+
confidence: 'high',
|
|
349
|
+
importPatterns: [/#include\s+[<"]oqs\/oqs\.h[>"]/],
|
|
350
|
+
callPatterns: [
|
|
351
|
+
/OQS_SIG_new\s*\(/,
|
|
352
|
+
/OQS_SIG_sign\s*\(/,
|
|
353
|
+
/OQS_SIG_verify\s*\(/,
|
|
354
|
+
],
|
|
355
|
+
description: 'liboqs ML-DSA (FIPS 204) digital signature',
|
|
356
|
+
migration: 'Already using PQC — verify parameter choices match NIST recommendations',
|
|
357
|
+
},
|
|
358
|
+
];
|
|
359
|
+
//# sourceMappingURL=c.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"c.js","sourceRoot":"","sources":["../../../../src/scanner/code/patterns/c.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"go.d.ts","sourceRoot":"","sources":["../../../../src/scanner/code/patterns/go.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAE7D,eAAO,MAAM,UAAU,EAAE,aAAa,
|
|
1
|
+
{"version":3,"file":"go.d.ts","sourceRoot":"","sources":["../../../../src/scanner/code/patterns/go.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAE7D,eAAO,MAAM,UAAU,EAAE,aAAa,EAsRrC,CAAC"}
|
|
@@ -222,5 +222,59 @@ export const goPatterns = [
|
|
|
222
222
|
description: "AES with 128-bit keys provides reduced security against quantum attacks (Grover's algorithm)",
|
|
223
223
|
migration: 'Use AES-256 (32-byte key) for quantum-resistant symmetric encryption',
|
|
224
224
|
},
|
|
225
|
+
{
|
|
226
|
+
id: 'go-pqc-circl-kem',
|
|
227
|
+
language: 'go',
|
|
228
|
+
category: 'pqc-algorithm',
|
|
229
|
+
algorithm: 'ML-KEM',
|
|
230
|
+
risk: 'safe',
|
|
231
|
+
confidence: 'high',
|
|
232
|
+
importPatterns: [
|
|
233
|
+
/circl\/kem\/mlkem/,
|
|
234
|
+
/circl\/kem\/kyber/,
|
|
235
|
+
],
|
|
236
|
+
callPatterns: [
|
|
237
|
+
/mlkem\.\w+/,
|
|
238
|
+
/kyber\.\w+/,
|
|
239
|
+
],
|
|
240
|
+
description: 'Cloudflare circl ML-KEM (FIPS 203) implementation',
|
|
241
|
+
migration: 'Already using PQC — verify parameter choices match NIST recommendations',
|
|
242
|
+
},
|
|
243
|
+
{
|
|
244
|
+
id: 'go-pqc-circl-sig',
|
|
245
|
+
language: 'go',
|
|
246
|
+
category: 'pqc-algorithm',
|
|
247
|
+
algorithm: 'ML-DSA',
|
|
248
|
+
risk: 'safe',
|
|
249
|
+
confidence: 'high',
|
|
250
|
+
importPatterns: [
|
|
251
|
+
/circl\/sign\/mldsa/,
|
|
252
|
+
/circl\/sign\/dilithium/,
|
|
253
|
+
],
|
|
254
|
+
callPatterns: [
|
|
255
|
+
/mldsa\.\w+/,
|
|
256
|
+
/dilithium\.\w+/,
|
|
257
|
+
],
|
|
258
|
+
description: 'Cloudflare circl ML-DSA (FIPS 204) implementation',
|
|
259
|
+
migration: 'Already using PQC — verify parameter choices match NIST recommendations',
|
|
260
|
+
},
|
|
261
|
+
{
|
|
262
|
+
id: 'go-pqc-stdlib',
|
|
263
|
+
language: 'go',
|
|
264
|
+
category: 'pqc-algorithm',
|
|
265
|
+
algorithm: 'ML-KEM',
|
|
266
|
+
risk: 'safe',
|
|
267
|
+
confidence: 'high',
|
|
268
|
+
importPatterns: [
|
|
269
|
+
/crypto\/mlkem/,
|
|
270
|
+
/crypto\/mldsa/,
|
|
271
|
+
],
|
|
272
|
+
callPatterns: [
|
|
273
|
+
/mlkem\./,
|
|
274
|
+
/mldsa\./,
|
|
275
|
+
],
|
|
276
|
+
description: 'Go stdlib PQC support (Go 1.24+)',
|
|
277
|
+
migration: 'Already using PQC — verify parameter choices match NIST recommendations',
|
|
278
|
+
},
|
|
225
279
|
];
|
|
226
280
|
//# sourceMappingURL=go.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"go.js","sourceRoot":"","sources":["../../../../src/scanner/code/patterns/go.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"go.js","sourceRoot":"","sources":["../../../../src/scanner/code/patterns/go.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,UAAU,GAAoB;IACzC;QACE,EAAE,EAAE,eAAe;QACnB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,uBAAuB;QACjC,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE,CAAC,eAAe,CAAC;QACjC,YAAY,EAAE,CAAC,uBAAuB,CAAC;QACvC,gBAAgB,EAAE,qCAAqC;QACvD,WAAW,EAAE,0EAA0E;QACvF,SAAS,EAAE,iFAAiF;QAC5F,OAAO,EAAE,cAAc;QACvB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,aAAa;QACjB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,mBAAmB;QAC7B,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,YAAY,EAAE;YACZ,wBAAwB;YACxB,mBAAmB;SACpB;QACD,WAAW,EAAE,+EAA+E;QAC5F,SAAS,EAAE,qDAAqD;QAChE,OAAO,EAAE,UAAU;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,gBAAgB;QACpB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,uBAAuB;QACjC,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,YAAY,EAAE;YACZ,uBAAuB;YACvB,2BAA2B;YAC3B,uBAAuB;YACvB,2BAA2B;SAC5B;QACD,WAAW,EAAE,sEAAsE;QACnF,SAAS,EAAE,oDAAoD;QAC/D,OAAO,EAAE,UAAU;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,iBAAiB;QACrB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,uBAAuB;QACjC,SAAS,EAAE,OAAO;QAClB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE,CAAC,iBAAiB,CAAC;QACnC,YAAY,EAAE,CAAC,yBAAyB,CAAC;QACzC,eAAe,EAAE,CAAC,uCAAuC,CAAC;QAC1D,WAAW,EAAE,4EAA4E;QACzF,SAAS,EAAE,qDAAqD;QAChE,OAAO,EAAE,UAAU;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,eAAe;QACnB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,mBAAmB;QAC7B,SAAS,EAAE,OAAO;QAClB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,YAAY,EAAE;YACZ,kBAAkB;YAClB,sBAAsB;YACtB,oBAAoB;YACpB,wBAAwB;SACzB;QACD,WAAW,EAAE,kFAAkF;QAC/F,SAAS,EAAE,qDAAqD;QAChE,OAAO,EAAE,UAAU;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,YAAY;QAChB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,mBAAmB;QAC7B,SAAS,EAAE,SAAS;QACpB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE;YACd,mBAAmB;YACnB,mCAAmC;SACpC;QACD,YAAY,EAAE;YACZ,2BAA2B;YAC3B,oBAAoB;SACrB;QACD,WAAW,EAAE,2EAA2E;QACxF,SAAS,EAAE,qDAAqD;QAChE,OAAO,EAAE,UAAU;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,eAAe;QACnB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,mBAAmB;QAC7B,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE,CAAC,eAAe,CAAC;QACjC,YAAY,EAAE;YACZ,uBAAuB;YACvB,8BAA8B;SAC/B;QACD,WAAW,EAAE,2DAA2D;QACxE,SAAS,EAAE,qDAAqD;QAChE,OAAO,EAAE,UAAU;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,eAAe;QACnB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,cAAc;QACxB,SAAS,EAAE,QAAQ;QACnB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE,CAAC,sCAAsC,CAAC;QACxD,YAAY,EAAE;YACZ,yBAAyB;YACzB,6BAA6B;SAC9B;QACD,WAAW,EAAE,+EAA+E;QAC5F,SAAS,EAAE,oDAAoD;QAC/D,OAAO,EAAE,UAAU;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,aAAa;QACjB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,cAAc;QACxB,SAAS,EAAE,UAAU;QACrB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE;YACd,qCAAqC;YACrC,sCAAsC;SACvC;QACD,YAAY,EAAE;YACZ,uBAAuB;YACvB,gBAAgB;YAChB,gBAAgB;YAChB,wBAAwB;SACzB;QACD,WAAW,EAAE,sEAAsE;QACnF,SAAS,EAAE,oFAAoF;QAC/F,OAAO,EAAE,cAAc;QACvB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,WAAW;QACrB,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE,CAAC,eAAe,CAAC;QACjC,YAAY,EAAE;YACZ,eAAe;YACf,eAAe;SAChB;QACD,WAAW,EAAE,qEAAqE;QAClF,SAAS,EAAE,yCAAyC;QACpD,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,SAAS;QACb,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,WAAW;QACrB,SAAS,EAAE,OAAO;QAClB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE,CAAC,gBAAgB,CAAC;QAClC,YAAY,EAAE;YACZ,gBAAgB;YAChB,gBAAgB;SACjB;QACD,WAAW,EAAE,oEAAoE;QACjF,SAAS,EAAE,yCAAyC;QACpD,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,WAAW;QACf,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,WAAW;QACrB,SAAS,EAAE,SAAS;QACpB,IAAI,EAAE,MAAM;QACZ,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE;YACd,kBAAkB;YAClB,kBAAkB;SACnB;QACD,YAAY,EAAE;YACZ,kBAAkB;YAClB,qBAAqB;YACrB,kBAAkB;YAClB,qBAAqB;YACrB,qBAAqB;SACtB;QACD,WAAW,EAAE,sDAAsD;QACnE,SAAS,EAAE,4CAA4C;KACxD;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,gBAAgB;QAC1B,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,UAAU;QAChB,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,CAAC,eAAe,CAAC;QACjC,YAAY,EAAE,CAAC,qBAAqB,CAAC;QACrC,WAAW,EAAE,8FAA8F;QAC3G,SAAS,EAAE,sEAAsE;KAClF;IACD;QACE,EAAE,EAAE,kBAAkB;QACtB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,eAAe;QACzB,SAAS,EAAE,QAAQ;QACnB,IAAI,EAAE,MAAM;QACZ,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE;YACd,mBAAmB;YACnB,mBAAmB;SACpB;QACD,YAAY,EAAE;YACZ,YAAY;YACZ,YAAY;SACb;QACD,WAAW,EAAE,mDAAmD;QAChE,SAAS,EAAE,yEAAyE;KACrF;IACD;QACE,EAAE,EAAE,kBAAkB;QACtB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,eAAe;QACzB,SAAS,EAAE,QAAQ;QACnB,IAAI,EAAE,MAAM;QACZ,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE;YACd,oBAAoB;YACpB,wBAAwB;SACzB;QACD,YAAY,EAAE;YACZ,YAAY;YACZ,gBAAgB;SACjB;QACD,WAAW,EAAE,mDAAmD;QAChE,SAAS,EAAE,yEAAyE;KACrF;IACD;QACE,EAAE,EAAE,eAAe;QACnB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,eAAe;QACzB,SAAS,EAAE,QAAQ;QACnB,IAAI,EAAE,MAAM;QACZ,UAAU,EAAE,MAAM;QAClB,cAAc,EAAE;YACd,eAAe;YACf,eAAe;SAChB;QACD,YAAY,EAAE;YACZ,SAAS;YACT,SAAS;SACV;QACD,WAAW,EAAE,kCAAkC;QAC/C,SAAS,EAAE,yEAAyE;KACrF;CACF,CAAC"}
|