@nodesecure/js-x-ray 11.5.0 → 12.0.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/dist/AstAnalyser.d.ts +2 -2
- package/dist/AstAnalyser.d.ts.map +1 -1
- package/dist/AstAnalyser.js +23 -14
- package/dist/AstAnalyser.js.map +1 -1
- package/dist/CollectableSet.d.ts +11 -6
- package/dist/CollectableSet.d.ts.map +1 -1
- package/dist/CollectableSet.js +1 -1
- package/dist/CollectableSet.js.map +1 -1
- package/dist/CollectableSetRegistry.d.ts +1 -1
- package/dist/CollectableSetRegistry.d.ts.map +1 -1
- package/dist/CollectableSetRegistry.js +0 -2
- package/dist/CollectableSetRegistry.js.map +1 -1
- package/dist/Deobfuscator.d.ts.map +1 -1
- package/dist/Deobfuscator.js +8 -7
- package/dist/Deobfuscator.js.map +1 -1
- package/dist/EntryFilesAnalyser.d.ts +1 -1
- package/dist/EntryFilesAnalyser.d.ts.map +1 -1
- package/dist/EntryFilesAnalyser.js +2 -2
- package/dist/EntryFilesAnalyser.js.map +1 -1
- package/dist/NodeCounter.js +1 -1
- package/dist/ProbeRunner.d.ts.map +1 -1
- package/dist/ProbeRunner.js +12 -4
- package/dist/ProbeRunner.js.map +1 -1
- package/dist/SourceFile.d.ts +3 -3
- package/dist/SourceFile.d.ts.map +1 -1
- package/dist/SourceFile.js +14 -8
- package/dist/SourceFile.js.map +1 -1
- package/dist/VariableTracer.d.ts +100 -0
- package/dist/VariableTracer.d.ts.map +1 -0
- package/dist/VariableTracer.js +463 -0
- package/dist/VariableTracer.js.map +1 -0
- package/dist/contants.d.ts +1 -0
- package/dist/contants.d.ts.map +1 -1
- package/dist/contants.js +1 -0
- package/dist/contants.js.map +1 -1
- package/dist/estree/functions/arrayExpression.d.ts +15 -0
- package/dist/estree/functions/arrayExpression.d.ts.map +1 -0
- package/dist/estree/functions/arrayExpression.js +69 -0
- package/dist/estree/functions/arrayExpression.js.map +1 -0
- package/dist/estree/functions/concatBinaryExpression.d.ts +15 -0
- package/dist/estree/functions/concatBinaryExpression.d.ts.map +1 -0
- package/dist/estree/functions/concatBinaryExpression.js +46 -0
- package/dist/estree/functions/concatBinaryExpression.js.map +1 -0
- package/dist/estree/functions/extractLogicalExpression.d.ts +6 -0
- package/dist/estree/functions/extractLogicalExpression.d.ts.map +1 -0
- package/dist/estree/functions/extractLogicalExpression.js +18 -0
- package/dist/estree/functions/extractLogicalExpression.js.map +1 -0
- package/dist/estree/functions/getCallExpressionArguments.d.ts +4 -0
- package/dist/estree/functions/getCallExpressionArguments.d.ts.map +1 -0
- package/dist/estree/functions/getCallExpressionArguments.js +52 -0
- package/dist/estree/functions/getCallExpressionArguments.js.map +1 -0
- package/dist/estree/functions/getCallExpressionIdentifier.d.ts +15 -0
- package/dist/estree/functions/getCallExpressionIdentifier.d.ts.map +1 -0
- package/dist/estree/functions/getCallExpressionIdentifier.js +24 -0
- package/dist/estree/functions/getCallExpressionIdentifier.js.map +1 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.d.ts +7 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.d.ts.map +1 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.js +63 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.js.map +1 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.d.ts +13 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.d.ts.map +1 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.js +123 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.js.map +1 -0
- package/dist/estree/functions/toLiteral.d.ts +3 -0
- package/dist/estree/functions/toLiteral.d.ts.map +1 -0
- package/dist/estree/functions/toLiteral.js +4 -0
- package/dist/estree/functions/toLiteral.js.map +1 -0
- package/dist/estree/index.d.ts +11 -0
- package/dist/estree/index.d.ts.map +1 -0
- package/dist/estree/index.js +11 -0
- package/dist/estree/index.js.map +1 -0
- package/dist/estree/literal.d.ts +4 -0
- package/dist/estree/literal.d.ts.map +1 -0
- package/dist/estree/literal.js +7 -0
- package/dist/estree/literal.js.map +1 -0
- package/dist/{types/estree.d.ts → estree/types.d.ts} +5 -1
- package/dist/estree/types.d.ts.map +1 -0
- package/dist/{types/estree.js → estree/types.js} +4 -1
- package/dist/estree/types.js.map +1 -0
- package/dist/i18n/arabic.d.ts +29 -0
- package/dist/i18n/arabic.d.ts.map +1 -0
- package/dist/i18n/arabic.js +28 -0
- package/dist/i18n/arabic.js.map +1 -0
- package/dist/i18n/english.d.ts +1 -0
- package/dist/i18n/english.js +2 -1
- package/dist/i18n/english.js.map +1 -1
- package/dist/i18n/french.d.ts +1 -0
- package/dist/i18n/french.js +2 -1
- package/dist/i18n/french.js.map +1 -1
- package/dist/i18n/turkish.d.ts +29 -0
- package/dist/i18n/turkish.d.ts.map +1 -0
- package/dist/i18n/turkish.js +28 -0
- package/dist/i18n/turkish.js.map +1 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/obfuscators/freejsobfuscator.d.ts +5 -0
- package/dist/obfuscators/freejsobfuscator.d.ts.map +1 -1
- package/dist/obfuscators/freejsobfuscator.js +1 -3
- package/dist/obfuscators/freejsobfuscator.js.map +1 -1
- package/dist/{JsSourceParser.d.ts → parsers/JsSourceParser.d.ts} +8 -0
- package/dist/parsers/JsSourceParser.d.ts.map +1 -0
- package/dist/{JsSourceParser.js → parsers/JsSourceParser.js} +9 -2
- package/dist/parsers/JsSourceParser.js.map +1 -0
- package/dist/parsers/TsSourceParser.d.ts +7 -0
- package/dist/parsers/TsSourceParser.d.ts.map +1 -0
- package/dist/parsers/TsSourceParser.js +25 -0
- package/dist/parsers/TsSourceParser.js.map +1 -0
- package/dist/pipelines/deobfuscate.d.ts.map +1 -1
- package/dist/pipelines/deobfuscate.js +1 -2
- package/dist/pipelines/deobfuscate.js.map +1 -1
- package/dist/probes/data-exfiltration.d.ts.map +1 -1
- package/dist/probes/data-exfiltration.js +3 -3
- package/dist/probes/data-exfiltration.js.map +1 -1
- package/dist/probes/isESMExport.d.ts +1 -1
- package/dist/probes/isFetch.d.ts.map +1 -1
- package/dist/probes/isFetch.js +2 -2
- package/dist/probes/isFetch.js.map +1 -1
- package/dist/probes/isImportDeclaration.d.ts +1 -1
- package/dist/probes/isLiteral.d.ts +1 -1
- package/dist/probes/isLiteral.d.ts.map +1 -1
- package/dist/probes/isLiteral.js +1 -3
- package/dist/probes/isLiteral.js.map +1 -1
- package/dist/probes/isMonkeyPatch.js +2 -1
- package/dist/probes/isMonkeyPatch.js.map +1 -1
- package/dist/probes/isPrototypePollution.d.ts +18 -0
- package/dist/probes/isPrototypePollution.d.ts.map +1 -0
- package/dist/probes/isPrototypePollution.js +31 -0
- package/dist/probes/isPrototypePollution.js.map +1 -0
- package/dist/probes/isRandom.d.ts +15 -0
- package/dist/probes/isRandom.d.ts.map +1 -0
- package/dist/probes/isRandom.js +29 -0
- package/dist/probes/isRandom.js.map +1 -0
- package/dist/probes/isRequire/InlinedRequire.d.ts.map +1 -1
- package/dist/probes/isRequire/InlinedRequire.js +1 -2
- package/dist/probes/isRequire/InlinedRequire.js.map +1 -1
- package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts +1 -1
- package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts.map +1 -1
- package/dist/probes/isRequire/RequireCallExpressionWalker.js +3 -5
- package/dist/probes/isRequire/RequireCallExpressionWalker.js.map +1 -1
- package/dist/probes/isRequire/isRequire.d.ts.map +1 -1
- package/dist/probes/isRequire/isRequire.js +3 -3
- package/dist/probes/isRequire/isRequire.js.map +1 -1
- package/dist/probes/isSerializeEnv.d.ts.map +1 -1
- package/dist/probes/isSerializeEnv.js +2 -2
- package/dist/probes/isSerializeEnv.js.map +1 -1
- package/dist/probes/isUnsafeCallee.d.ts +4 -3
- package/dist/probes/isUnsafeCallee.d.ts.map +1 -1
- package/dist/probes/isUnsafeCallee.js +12 -12
- package/dist/probes/isUnsafeCallee.js.map +1 -1
- package/dist/probes/isUnsafeCommand.js +3 -2
- package/dist/probes/isUnsafeCommand.js.map +1 -1
- package/dist/probes/isWeakCrypto.js +1 -1
- package/dist/probes/sql-injection.js +2 -1
- package/dist/probes/sql-injection.js.map +1 -1
- package/dist/utils/extractNode.js +1 -1
- package/dist/utils/getSubMemberExpressionSegments.d.ts +2 -0
- package/dist/utils/getSubMemberExpressionSegments.d.ts.map +1 -0
- package/dist/utils/getSubMemberExpressionSegments.js +9 -0
- package/dist/utils/getSubMemberExpressionSegments.js.map +1 -0
- package/dist/utils/hex.d.ts +14 -0
- package/dist/utils/hex.d.ts.map +1 -0
- package/dist/utils/hex.js +44 -0
- package/dist/utils/hex.js.map +1 -0
- package/dist/utils/index.d.ts +9 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +9 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/isEvilIdentifier.d.ts +3 -0
- package/dist/utils/isEvilIdentifier.d.ts.map +1 -0
- package/dist/utils/isEvilIdentifier.js +11 -0
- package/dist/utils/isEvilIdentifier.js.map +1 -0
- package/dist/utils/isOneLineExpressionExport.d.ts.map +1 -1
- package/dist/utils/isOneLineExpressionExport.js +2 -1
- package/dist/utils/isOneLineExpressionExport.js.map +1 -1
- package/dist/utils/isStringBase64.d.ts +8 -0
- package/dist/utils/isStringBase64.d.ts.map +1 -0
- package/dist/utils/isStringBase64.js +18 -0
- package/dist/utils/isStringBase64.js.map +1 -0
- package/dist/utils/isSvg.d.ts +7 -0
- package/dist/utils/isSvg.d.ts.map +1 -0
- package/dist/utils/isSvg.js +26 -0
- package/dist/utils/isSvg.js.map +1 -0
- package/dist/utils/makePrefixRemover.d.ts +2 -0
- package/dist/utils/makePrefixRemover.d.ts.map +1 -0
- package/dist/utils/makePrefixRemover.js +13 -0
- package/dist/utils/makePrefixRemover.js.map +1 -0
- package/dist/utils/patterns.d.ts +24 -0
- package/dist/utils/patterns.d.ts.map +1 -0
- package/dist/utils/patterns.js +77 -0
- package/dist/utils/patterns.js.map +1 -0
- package/dist/utils/stringSuspicionScore.d.ts +12 -0
- package/dist/utils/stringSuspicionScore.d.ts.map +1 -0
- package/dist/utils/stringSuspicionScore.js +53 -0
- package/dist/utils/stringSuspicionScore.js.map +1 -0
- package/dist/utils/stripNodePrefix.d.ts +2 -0
- package/dist/utils/stripNodePrefix.d.ts.map +1 -0
- package/dist/utils/stripNodePrefix.js +11 -0
- package/dist/utils/stripNodePrefix.js.map +1 -0
- package/dist/walker/walker.sync.js +1 -1
- package/dist/warnings.d.ts +12 -2
- package/dist/warnings.d.ts.map +1 -1
- package/dist/warnings.js +10 -0
- package/dist/warnings.js.map +1 -1
- package/package.json +4 -6
- package/dist/JsSourceParser.d.ts.map +0 -1
- package/dist/JsSourceParser.js.map +0 -1
- package/dist/types/estree.d.ts.map +0 -1
- package/dist/types/estree.js.map +0 -1
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { getMemberExpressionIdentifier } from "../estree/index.js";
|
|
3
|
+
import { SourceFile } from "../SourceFile.js";
|
|
4
|
+
import { generateWarning } from "../warnings.js";
|
|
5
|
+
function validateNode(node) {
|
|
6
|
+
if (node.type === "Literal" && node.value === "__proto__") {
|
|
7
|
+
return [true, "literal"];
|
|
8
|
+
}
|
|
9
|
+
if (node.type === "MemberExpression") {
|
|
10
|
+
const parts = [...getMemberExpressionIdentifier(node)];
|
|
11
|
+
if (parts.at(-1) === "__proto__") {
|
|
12
|
+
return [true, parts.join(".")];
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return [false];
|
|
16
|
+
}
|
|
17
|
+
function main(node, options) {
|
|
18
|
+
const { sourceFile, data, signals } = options;
|
|
19
|
+
sourceFile.warnings.push(generateWarning("prototype-pollution", {
|
|
20
|
+
value: data === "literal" ? "__proto__" : data,
|
|
21
|
+
location: node.loc ?? null
|
|
22
|
+
}));
|
|
23
|
+
return data === "literal" ? undefined : signals.Skip;
|
|
24
|
+
}
|
|
25
|
+
export default {
|
|
26
|
+
name: "isPrototypePollution",
|
|
27
|
+
validateNode,
|
|
28
|
+
main,
|
|
29
|
+
breakOnMatch: false
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=isPrototypePollution.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isPrototypePollution.js","sourceRoot":"","sources":["../../src/probes/isPrototypePollution.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,6BAA6B,EAAE,MAAM,oBAAoB,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD,SAAS,YAAY,CACnB,IAAiB;IAEjB,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;QAC1D,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC3B,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;QACrC,MAAM,KAAK,GAAG,CAAC,GAAG,6BAA6B,CAAC,IAAI,CAAC,CAAC,CAAC;QAEvD,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,WAAW,EAAE,CAAC;YACjC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,CAAC;AACjB,CAAC;AAED,SAAS,IAAI,CACX,IAA8C,EAC9C,OAIC;IAED,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAE9C,UAAU,CAAC,QAAQ,CAAC,IAAI,CACtB,eAAe,CAAC,qBAAqB,EAAE;QACrC,KAAK,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAK;QAC/C,QAAQ,EAAE,IAAI,CAAC,GAAG,IAAI,IAAI;KAC3B,CAAC,CACH,CAAC;IAEF,OAAO,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;AACvD,CAAC;AAED,eAAe;IACb,IAAI,EAAE,sBAAsB;IAC5B,YAAY;IACZ,IAAI;IACJ,YAAY,EAAE,KAAK;CACpB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
import type { ProbeContext } from "../ProbeRunner.ts";
|
|
3
|
+
declare function validateNode(_node: ESTree.Node, ctx: ProbeContext): [boolean, any?];
|
|
4
|
+
declare function initialize(ctx: ProbeContext): void;
|
|
5
|
+
declare function main(node: ESTree.MemberExpression, ctx: ProbeContext): void;
|
|
6
|
+
declare const _default: {
|
|
7
|
+
name: string;
|
|
8
|
+
validateNode: typeof validateNode;
|
|
9
|
+
main: typeof main;
|
|
10
|
+
initialize: typeof initialize;
|
|
11
|
+
breakOnMatch: boolean;
|
|
12
|
+
context: {};
|
|
13
|
+
};
|
|
14
|
+
export default _default;
|
|
15
|
+
//# sourceMappingURL=isRandom.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isRandom.d.ts","sourceRoot":"","sources":["../../src/probes/isRandom.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAItD,iBAAS,YAAY,CACnB,KAAK,EAAE,MAAM,CAAC,IAAI,EAClB,GAAG,EAAE,YAAY,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAIjB;AAED,iBAAS,UAAU,CACjB,GAAG,EAAE,YAAY,QAOlB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,MAAM,CAAC,gBAAgB,EAC7B,GAAG,EAAE,YAAY,QAQlB;;;;;;;;;AAED,wBAOE"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { generateWarning } from "../warnings.js";
|
|
2
|
+
import { CALL_EXPRESSION_DATA } from "../contants.js";
|
|
3
|
+
function validateNode(_node, ctx) {
|
|
4
|
+
return [
|
|
5
|
+
ctx.context[CALL_EXPRESSION_DATA]?.name === "Math.random"
|
|
6
|
+
];
|
|
7
|
+
}
|
|
8
|
+
function initialize(ctx) {
|
|
9
|
+
const { tracer } = ctx.sourceFile;
|
|
10
|
+
tracer.trace("Math.random", {
|
|
11
|
+
followConsecutiveAssignment: true
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
function main(node, ctx) {
|
|
15
|
+
const { sourceFile } = ctx;
|
|
16
|
+
sourceFile.warnings.push(generateWarning("insecure-random", {
|
|
17
|
+
value: null,
|
|
18
|
+
location: node.loc
|
|
19
|
+
}));
|
|
20
|
+
}
|
|
21
|
+
export default {
|
|
22
|
+
name: "isRandom",
|
|
23
|
+
validateNode,
|
|
24
|
+
main,
|
|
25
|
+
initialize,
|
|
26
|
+
breakOnMatch: false,
|
|
27
|
+
context: {}
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=isRandom.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isRandom.js","sourceRoot":"","sources":["../../src/probes/isRandom.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAEtD,SAAS,YAAY,CACnB,KAAkB,EAClB,GAAiB;IAEjB,OAAO;QACL,GAAG,CAAC,OAAQ,CAAC,oBAAoB,CAAC,EAAE,IAAI,KAAK,aAAa;KAC3D,CAAC;AACJ,CAAC;AAED,SAAS,UAAU,CACjB,GAAiB;IAEjB,MAAM,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,UAAU,CAAC;IAElC,MAAM,CAAC,KAAK,CAAC,aAAa,EAAE;QAC1B,2BAA2B,EAAE,IAAI;KAClC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,IAAI,CACX,IAA6B,EAC7B,GAAiB;IAEjB,MAAM,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC;IAE3B,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,iBAAiB,EAAE;QAC1D,KAAK,EAAE,IAAI;QACX,QAAQ,EAAE,IAAI,CAAC,GAAG;KACnB,CAAC,CAAC,CAAC;AACN,CAAC;AAED,eAAe;IACb,IAAI,EAAE,UAAU;IAChB,YAAY;IACZ,IAAI;IACJ,UAAU;IACV,YAAY,EAAE,KAAK;IACnB,OAAO,EAAE,EAAE;CACZ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InlinedRequire.d.ts","sourceRoot":"","sources":["../../../src/probes/isRequire/InlinedRequire.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"InlinedRequire.d.ts","sourceRoot":"","sources":["../../../src/probes/isRequire/InlinedRequire.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAQtC,MAAM,WAAW,WAAW;IAC1B;;OAEG;IACH,iBAAiB,EAAE,MAAM,CAAC;IAC1B;;;OAGG;IACH,kBAAkB,EAAE,MAAM,CAAC,mBAAmB,CAAC;IAC/C;;;;OAIG;IACH,iBAAiB,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC;CACvC;AAED,qBAAa,cAAc;;IACzB,MAAM,CAAC,UAAU,CACf,IAAI,EAAE,MAAM,CAAC,IAAI,GAChB,IAAI,IAAI,MAAM,CAAC,cAAc;IAWhC,MAAM,CAAC,KAAK,CACV,gBAAgB,EAAE,MAAM,CAAC,IAAI,GAC5B,WAAW,GAAG,IAAI;CA6HtB"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
// Import Third-party Dependencies
|
|
2
|
-
import { getCallExpressionIdentifier } from "@nodesecure/estree-ast-utils";
|
|
3
1
|
// Import Internal Dependencies
|
|
2
|
+
import { getCallExpressionIdentifier } from "../../estree/index.js";
|
|
4
3
|
import { VirtualVariableIdentifier } from "../../VirtualVariableIdentifier.js";
|
|
5
4
|
export class InlinedRequire {
|
|
6
5
|
static assertNode(node) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InlinedRequire.js","sourceRoot":"","sources":["../../../src/probes/isRequire/InlinedRequire.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"InlinedRequire.js","sourceRoot":"","sources":["../../../src/probes/isRequire/InlinedRequire.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EACL,2BAA2B,EAC5B,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,yBAAyB,EAAE,MAAM,oCAAoC,CAAC;AAoB/E,MAAM,OAAO,cAAc;IACzB,MAAM,CAAC,UAAU,CACf,IAAiB;QAEjB,IACE,IAAI,CAAC,IAAI,KAAK,gBAAgB;YAC9B,2BAA2B,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,eAAe,CAAC,EACzD,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,CAAC,KAAK,CACV,gBAA6B;QAE7B,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,gBAAgB,CAAC,EAAE,CAAC;YACjD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,WAAW,GAAG,cAAc,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;QACtE,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,iBAAiB,GAAG,yBAAyB,CAAC,QAAQ,CAC1D,SAAS,EACT,gBAAgB,CAAC,GAAG,CACrB,CAAC;QAEF,OAAO;YACL,iBAAiB;YACjB,kBAAkB,EAAE;gBAClB,IAAI,EAAE,qBAAqB;gBAC3B,IAAI,EAAE,OAAO;gBACb,YAAY,EAAE;oBACZ;wBACE,IAAI,EAAE,oBAAoB;wBAC1B,EAAE,EAAE;4BACF,IAAI,EAAE,YAAY;4BAClB,IAAI,EAAE,iBAAiB;yBACxB;wBACD,IAAI,EAAE,WAAW;qBAClB;iBACF;aACF;YACD,iBAAiB,EAAE,cAAc,CAAC,6BAA6B,CAC7D,gBAAgB,EAChB,WAAW,EACX,iBAAiB,CAClB;SACF,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,gBAAgB,CACrB,IAAqD;QAErD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,KAAK,kBAAkB;YAC7C,CAAC,CAAC,IAAI,CAAC,MAAM;YACb,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;QAEhB,IACE,MAAM,CAAC,IAAI,KAAK,gBAAgB;YAChC,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,YAAY;YACnC,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,EAChC,CAAC;YACD,OAAO,MAAM,CAAC;QAChB,CAAC;QAED,IACE,MAAM,CAAC,IAAI,KAAK,kBAAkB;YAClC,MAAM,CAAC,IAAI,KAAK,gBAAgB,EAChC,CAAC;YACD,OAAO,cAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACjD,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,6BAA6B,CAClC,IAA2B,EAC3B,WAAkC,EAClC,iBAAyB;QAEzB,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,SAAS,GAAsB;YACnC,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE,iBAAiB;SACxB,CAAC;QAEF,OAAO,cAAc,CAAC,gBAAgB,CACpC,IAAI,EACJ,WAAW,EACX,SAAS,CACV,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,gBAAgB,CACrB,IAAiB,EACjB,MAA6B,EAC7B,WAA8B;QAE9B,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;YACpB,OAAO,WAAW,CAAC;QACrB,CAAC;QAED,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;YACnC,MAAM,MAAM,GAAG,cAAc,CAAC,gBAAgB,CAC5C,IAAI,CAAC,MAAM,EACX,MAAM,EACN,WAAW,CACS,CAAC;YAEvB,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAC7B,CAAC,GAAG,EAAE,EAAE,CAAC,cAAc,CAAC,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,WAAW,CAAC,CAC5C,CAAC;YAEzB,OAAO;gBACL,GAAG,IAAI;gBACP,MAAM;gBACN,SAAS,EAAE,IAAI;aAChB,CAAC;QACJ,CAAC;QAED,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YACrC,OAAO;gBACL,GAAG,IAAI;gBACP,MAAM,EAAE,cAAc,CAAC,gBAAgB,CACrC,IAAI,CAAC,MAAM,EACX,MAAM,EACN,WAAW,CACS;aACvB,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RequireCallExpressionWalker.d.ts","sourceRoot":"","sources":["../../../src/probes/isRequire/RequireCallExpressionWalker.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"RequireCallExpressionWalker.d.ts","sourceRoot":"","sources":["../../../src/probes/isRequire/RequireCallExpressionWalker.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAStC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAO9D,qBAAa,2BAA2B;;IACtC,MAAM,EAAE,cAAc,CAAC;IACvB,YAAY,cAAqB;IACjC,cAAc,UAAQ;gBAGpB,MAAM,EAAE,cAAc;IAKxB,KAAK;IAKL,IAAI,CACF,YAAY,EAAE,MAAM,CAAC,cAAc;;;;CAsGtC"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
// Import Node.js Dependencies
|
|
2
2
|
import path from "node:path";
|
|
3
|
-
// Import Third-party Dependencies
|
|
4
|
-
import { arrayExpressionToString, getCallExpressionArguments, getMemberExpressionIdentifier } from "@nodesecure/estree-ast-utils";
|
|
5
|
-
import { Hex } from "@nodesecure/sec-literal";
|
|
6
|
-
import { VariableTracer } from "@nodesecure/tracer";
|
|
7
3
|
// Import Internal Dependencies
|
|
8
|
-
import {
|
|
4
|
+
import { Hex } from "../../utils/index.js";
|
|
5
|
+
import { arrayExpressionToString, getCallExpressionArguments, getMemberExpressionIdentifier } from "../../estree/index.js";
|
|
6
|
+
import { isCallExpression, isLiteral } from "../../estree/types.js";
|
|
9
7
|
import { walkEnter } from "../../walker/index.js";
|
|
10
8
|
export class RequireCallExpressionWalker {
|
|
11
9
|
tracer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RequireCallExpressionWalker.js","sourceRoot":"","sources":["../../../src/probes/isRequire/RequireCallExpressionWalker.ts"],"names":[],"mappings":"AAAA,8BAA8B;AAC9B,OAAO,IAAI,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"RequireCallExpressionWalker.js","sourceRoot":"","sources":["../../../src/probes/isRequire/RequireCallExpressionWalker.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isRequire.d.ts","sourceRoot":"","sources":["../../../src/probes/isRequire/isRequire.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"isRequire.d.ts","sourceRoot":"","sources":["../../../src/probes/isRequire/isRequire.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAStC,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAK3E,iBAAS,mBAAmB,CAC1B,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,GAAG,EAAE,YAAY,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAiBjB;AA2BD,iBAAS,QAAQ,CACf,GAAG,EAAE,YAAY,QAGlB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,MAAM,CAAC,cAAc,EAC3B,GAAG,EAAE,gBAAgB,sBA8GtB;;;;;;;;;AAED,wBAUE"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/* eslint-disable consistent-return */
|
|
2
|
-
// Import
|
|
3
|
-
import { arrayExpressionToString, concatBinaryExpression, getCallExpressionArguments, getCallExpressionIdentifier } from "
|
|
4
|
-
import { isLiteral } from "../../types
|
|
2
|
+
// Import Internal Dependencies
|
|
3
|
+
import { arrayExpressionToString, concatBinaryExpression, getCallExpressionArguments, getCallExpressionIdentifier } from "../../estree/index.js";
|
|
4
|
+
import { isLiteral } from "../../estree/types.js";
|
|
5
5
|
import { generateWarning } from "../../warnings.js";
|
|
6
6
|
import { RequireCallExpressionWalker } from "./RequireCallExpressionWalker.js";
|
|
7
7
|
function validateNodeRequire(node, ctx) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isRequire.js","sourceRoot":"","sources":["../../../src/probes/isRequire/isRequire.ts"],"names":[],"mappings":"AAAA,sCAAsC;
|
|
1
|
+
{"version":3,"file":"isRequire.js","sourceRoot":"","sources":["../../../src/probes/isRequire/isRequire.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isSerializeEnv.d.ts","sourceRoot":"","sources":["../../src/probes/isSerializeEnv.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"isSerializeEnv.d.ts","sourceRoot":"","sources":["../../src/probes/isSerializeEnv.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAMtC,OAAO,KAAK,EACV,YAAY,EACZ,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAI3B;;;;;;;GAOG;AACH,iBAAS,qBAAqB,CAC5B,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,GAAG,EAAE,YAAY,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CA4BjB;AA0BD,iBAAS,cAAc,CACrB,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,GAAG,EAAE,gBAAgB,UAWtB;AAED,iBAAS,iBAAiB,CACxB,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,GAAG,EAAE,gBAAgB,iBAgBtB;AAED,iBAAS,UAAU,CACjB,GAAG,EAAE,YAAY,QAWlB;;;;;;;;;;;;AAED,wBAUE"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
// Import
|
|
2
|
-
import { getMemberExpressionIdentifier } from "
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { getMemberExpressionIdentifier } from "../estree/index.js";
|
|
3
3
|
import { CALL_EXPRESSION_DATA } from "../contants.js";
|
|
4
4
|
import { generateWarning } from "../warnings.js";
|
|
5
5
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isSerializeEnv.js","sourceRoot":"","sources":["../../src/probes/isSerializeEnv.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"isSerializeEnv.js","sourceRoot":"","sources":["../../src/probes/isSerializeEnv.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,19 +1,20 @@
|
|
|
1
1
|
import type { ESTree } from "meriyah";
|
|
2
|
-
import type { ProbeMainContext } from "../ProbeRunner.ts";
|
|
2
|
+
import type { ProbeContext, ProbeMainContext } from "../ProbeRunner.ts";
|
|
3
3
|
/**
|
|
4
4
|
* @description Detect unsafe statement
|
|
5
5
|
* @example
|
|
6
6
|
* eval("this");
|
|
7
7
|
* Function("return this")();
|
|
8
8
|
*/
|
|
9
|
-
declare function validateNode(node: ESTree.Node): [boolean, any?];
|
|
9
|
+
declare function validateNode(node: ESTree.Node, ctx: ProbeContext): [boolean, any?];
|
|
10
10
|
declare function main(node: ESTree.CallExpression, ctx: ProbeMainContext): symbol;
|
|
11
|
-
export declare function isUnsafeCallee(node: ESTree.CallExpression | ESTree.Node): [boolean, "eval" | "Function" | null];
|
|
11
|
+
export declare function isUnsafeCallee(node: ESTree.CallExpression | ESTree.Node, ctx: ProbeContext): [boolean, "eval" | "Function" | null];
|
|
12
12
|
declare const _default: {
|
|
13
13
|
name: string;
|
|
14
14
|
validateNode: typeof validateNode;
|
|
15
15
|
main: typeof main;
|
|
16
16
|
breakOnMatch: boolean;
|
|
17
|
+
context: {};
|
|
17
18
|
};
|
|
18
19
|
export default _default;
|
|
19
20
|
//# sourceMappingURL=isUnsafeCallee.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isUnsafeCallee.d.ts","sourceRoot":"","sources":["../../src/probes/isUnsafeCallee.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"isUnsafeCallee.d.ts","sourceRoot":"","sources":["../../src/probes/isUnsafeCallee.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAKxE;;;;;GAKG;AACH,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,GAAG,EAAE,YAAY,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAEjB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,MAAM,CAAC,cAAc,EAC3B,GAAG,EAAE,gBAAgB,UAsBtB;AAmBD,wBAAgB,cAAc,CAC5B,IAAI,EAAE,MAAM,CAAC,cAAc,GAAG,MAAM,CAAC,IAAI,EACzC,GAAG,EAAE,YAAY,GAChB,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,CAAC,CAcvC;;;;;;;;AAED,wBAME"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
1
|
+
import { getCallExpressionIdentifier } from "../estree/index.js";
|
|
2
|
+
import { CALL_EXPRESSION_IDENTIFIER } from "../contants.js";
|
|
3
3
|
import { generateWarning } from "../warnings.js";
|
|
4
4
|
/**
|
|
5
5
|
* @description Detect unsafe statement
|
|
@@ -7,8 +7,8 @@ import { generateWarning } from "../warnings.js";
|
|
|
7
7
|
* eval("this");
|
|
8
8
|
* Function("return this")();
|
|
9
9
|
*/
|
|
10
|
-
function validateNode(node) {
|
|
11
|
-
return isUnsafeCallee(node);
|
|
10
|
+
function validateNode(node, ctx) {
|
|
11
|
+
return isUnsafeCallee(node, ctx);
|
|
12
12
|
}
|
|
13
13
|
function main(node, ctx) {
|
|
14
14
|
const { sourceFile, data: calleeName, signals } = ctx;
|
|
@@ -27,24 +27,23 @@ function main(node, ctx) {
|
|
|
27
27
|
sourceFile.warnings.push(warning);
|
|
28
28
|
return signals.Skip;
|
|
29
29
|
}
|
|
30
|
+
function isFunctionCallee(node, identifier) {
|
|
31
|
+
return identifier === "Function" && node.callee.type === "CallExpression";
|
|
32
|
+
}
|
|
30
33
|
function isEvalCallee(node) {
|
|
31
34
|
const identifier = getCallExpressionIdentifier(node, {
|
|
32
|
-
resolveCallExpression:
|
|
35
|
+
resolveCallExpression: true
|
|
33
36
|
});
|
|
34
37
|
return identifier === "eval";
|
|
35
38
|
}
|
|
36
|
-
function
|
|
37
|
-
const identifier = getCallExpressionIdentifier(node);
|
|
38
|
-
return identifier === "Function" && node.callee.type === "CallExpression";
|
|
39
|
-
}
|
|
40
|
-
export function isUnsafeCallee(node) {
|
|
39
|
+
export function isUnsafeCallee(node, ctx) {
|
|
41
40
|
if (node.type !== "CallExpression") {
|
|
42
41
|
return [false, null];
|
|
43
42
|
}
|
|
44
43
|
if (isEvalCallee(node)) {
|
|
45
44
|
return [true, "eval"];
|
|
46
45
|
}
|
|
47
|
-
if (isFunctionCallee(node)) {
|
|
46
|
+
if (isFunctionCallee(node, ctx.context?.[CALL_EXPRESSION_IDENTIFIER])) {
|
|
48
47
|
return [true, "Function"];
|
|
49
48
|
}
|
|
50
49
|
return [false, null];
|
|
@@ -53,6 +52,7 @@ export default {
|
|
|
53
52
|
name: "isUnsafeCallee",
|
|
54
53
|
validateNode,
|
|
55
54
|
main,
|
|
56
|
-
breakOnMatch: false
|
|
55
|
+
breakOnMatch: false,
|
|
56
|
+
context: {}
|
|
57
57
|
};
|
|
58
58
|
//# sourceMappingURL=isUnsafeCallee.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isUnsafeCallee.js","sourceRoot":"","sources":["../../src/probes/isUnsafeCallee.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"isUnsafeCallee.js","sourceRoot":"","sources":["../../src/probes/isUnsafeCallee.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,2BAA2B,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,0BAA0B,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD;;;;;GAKG;AACH,SAAS,YAAY,CACnB,IAAiB,EACjB,GAAiB;IAEjB,OAAO,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;AACnC,CAAC;AAED,SAAS,IAAI,CACX,IAA2B,EAC3B,GAAqB;IAErB,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,GAAG,CAAC;IAEtD,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,OAAO,OAAO,CAAC,IAAI,CAAC;IACtB,CAAC;IACD,IACE,UAAU,KAAK,UAAU;QACzB,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,aAAa,EAChD,CAAC;QACD,OAAO,OAAO,CAAC,IAAI,CAAC;IACtB,CAAC;IAED,MAAM,OAAO,GAAG,eAAe,CAAC,aAAa,EAAE;QAC7C,KAAK,EAAE,UAAU;QACjB,QAAQ,EAAE,IAAI,CAAC,GAAG;KACnB,CAAC,CAAC;IACH,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAElC,OAAO,OAAO,CAAC,IAAI,CAAC;AACtB,CAAC;AAED,SAAS,gBAAgB,CACvB,IAA2B,EAC3B,UAAqC;IAErC,OAAO,UAAU,KAAK,UAAU,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC;AAC5E,CAAC;AAED,SAAS,YAAY,CACnB,IAA2B;IAE3B,MAAM,UAAU,GAAG,2BAA2B,CAAC,IAAI,EAAE;QACnD,qBAAqB,EAAE,IAAI;KAC5B,CAAC,CAAC;IAEH,OAAO,UAAU,KAAK,MAAM,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,IAAyC,EACzC,GAAiB;IAEjB,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;QACnC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACvB,CAAC;IAED,IAAI,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC;QACvB,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,gBAAgB,CAAC,IAAI,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,0BAA0B,CAAC,CAAC,EAAE,CAAC;QACtE,OAAO,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;AACvB,CAAC;AAED,eAAe;IACb,IAAI,EAAE,gBAAgB;IACtB,YAAY;IACZ,IAAI;IACJ,YAAY,EAAE,KAAK;IACnB,OAAO,EAAE,EAAE;CACZ,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { toLiteral } from "../estree/index.js";
|
|
2
3
|
import { CALL_EXPRESSION_DATA } from "../contants.js";
|
|
3
|
-
import { isLiteral, isTemplateLiteral } from "../types
|
|
4
|
+
import { isLiteral, isTemplateLiteral } from "../estree/types.js";
|
|
4
5
|
import { generateWarning } from "../warnings.js";
|
|
5
6
|
// CONSTANTS
|
|
6
7
|
const kUnsafeCommands = ["csrutil", "uname", "ping", "curl"];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isUnsafeCommand.js","sourceRoot":"","sources":["../../src/probes/isUnsafeCommand.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"isUnsafeCommand.js","sourceRoot":"","sources":["../../src/probes/isUnsafeCommand.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { toLiteral } from "../estree/index.js";
|
|
2
3
|
import { generateWarning } from "../warnings.js";
|
|
3
4
|
// CONSTANTS
|
|
4
5
|
const kSqlInjectionRegex = /(select\s+.*\s+from|insert\s+into|delete\s+from|update\s+.*\s+set)/i;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sql-injection.js","sourceRoot":"","sources":["../../src/probes/sql-injection.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"sql-injection.js","sourceRoot":"","sources":["../../src/probes/sql-injection.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAE/C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD,YAAY;AACZ,MAAM,kBAAkB,GAAG,qEAAqE,CAAC;AAEjG,SAAS,YAAY,CACnB,IAAiB,EACjB,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,EAAgB;IAExC,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;QACnC,OAAO,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;IAED,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACrC,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;YACrB,KAAK,YAAY,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;oBACjD,MAAM;gBACR,CAAC;gBAED,MAAM,iBAAiB,GAAG,MAAM,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;gBAEtE,IAAI,iBAAkB,CAAC,IAAI,KAAK,iBAAiB;oBAC/C,CAAC,kBAAkB,CAAC,IAAI,CAAC,iBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;oBACrD,MAAM;gBACR,CAAC;gBAED,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;YACpE,CAAC;YAED,KAAK,iBAAiB,CAAC,CAAC,CAAC;gBACvB,IAAI,OAAO,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBACrC,MAAM;gBACR,CAAC;gBACD,MAAM,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC;gBACnC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;oBACtC,MAAM;gBACR,CAAC;gBAED,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,CAAC;AACjB,CAAC;AAED,SAAS,IAAI,CACX,IAA4B,EAC5B,GAAqB;IAErB,GAAG,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAC1B,eAAe,CAAC,eAAe,EAAE;QAC/B,KAAK,EAAE,GAAG,CAAC,IAAI;QACf,QAAQ,EAAE,IAAI,CAAC,GAAG;KACnB,CAAC,CACH,CAAC;AACJ,CAAC;AAED,eAAe;IACb,IAAI,EAAE,eAAe;IACrB,YAAY;IACZ,IAAI;IACJ,YAAY,EAAE,KAAK;CACpB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getSubMemberExpressionSegments.d.ts","sourceRoot":"","sources":["../../src/utils/getSubMemberExpressionSegments.ts"],"names":[],"mappings":"AAAA,wBAAiB,8BAA8B,CAC7C,wBAAwB,EAAE,MAAM,GAC/B,gBAAgB,CAAC,MAAM,CAAC,CAQ1B"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export function* getSubMemberExpressionSegments(memberExpressionFullpath) {
|
|
2
|
+
const identifiers = memberExpressionFullpath.split(".");
|
|
3
|
+
const segments = [];
|
|
4
|
+
for (let i = 0; i < identifiers.length - 1; i++) {
|
|
5
|
+
segments.push(identifiers[i]);
|
|
6
|
+
yield segments.join(".");
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=getSubMemberExpressionSegments.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getSubMemberExpressionSegments.js","sourceRoot":"","sources":["../../src/utils/getSubMemberExpressionSegments.ts"],"names":[],"mappings":"AAAA,MAAM,SAAS,CAAC,CAAC,8BAA8B,CAC7C,wBAAgC;IAEhC,MAAM,WAAW,GAAG,wBAAwB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACxD,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAChD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
export declare const CONSTANTS: Readonly<{
|
|
3
|
+
SAFE_HEXA_VALUES: string[];
|
|
4
|
+
UNSAFE_HEXA_VALUES: string[];
|
|
5
|
+
}>;
|
|
6
|
+
/**
|
|
7
|
+
* @description detect if the given string is an Hexadecimal value
|
|
8
|
+
*/
|
|
9
|
+
export declare function isHex(anyValue: ESTree.Literal | string): boolean;
|
|
10
|
+
/**
|
|
11
|
+
* @description detect if the given string is a safe Hexadecimal value
|
|
12
|
+
*/
|
|
13
|
+
export declare function isSafe(anyValue: ESTree.Literal | string): boolean;
|
|
14
|
+
//# sourceMappingURL=hex.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hex.d.ts","sourceRoot":"","sources":["../../src/utils/hex.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAoBtC,eAAO,MAAM,SAAS;;;EAGpB,CAAC;AAEH;;GAEG;AACH,wBAAgB,KAAK,CACnB,QAAQ,EAAE,MAAM,CAAC,OAAO,GAAG,MAAM,GAChC,OAAO,CAIT;AAED;;GAEG;AACH,wBAAgB,MAAM,CACpB,QAAQ,EAAE,MAAM,CAAC,OAAO,GAAG,MAAM,GAChC,OAAO,CAkBT"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { toValue, toRaw } from "../estree/index.js";
|
|
3
|
+
import { stringCharDiversity } from "./stringSuspicionScore.js";
|
|
4
|
+
// CONSTANTS
|
|
5
|
+
const kUnsafeHexValues = new Set([
|
|
6
|
+
"require",
|
|
7
|
+
"length"
|
|
8
|
+
].map((value) => Buffer.from(value).toString("hex")));
|
|
9
|
+
const kSafeHexValues = new Set([
|
|
10
|
+
"0123456789",
|
|
11
|
+
"123456789",
|
|
12
|
+
"abcdef",
|
|
13
|
+
"abc123456789",
|
|
14
|
+
"0123456789abcdef",
|
|
15
|
+
"abcdef0123456789abcdef"
|
|
16
|
+
]);
|
|
17
|
+
export const CONSTANTS = Object.freeze({
|
|
18
|
+
SAFE_HEXA_VALUES: [...kSafeHexValues],
|
|
19
|
+
UNSAFE_HEXA_VALUES: [...kUnsafeHexValues]
|
|
20
|
+
});
|
|
21
|
+
/**
|
|
22
|
+
* @description detect if the given string is an Hexadecimal value
|
|
23
|
+
*/
|
|
24
|
+
export function isHex(anyValue) {
|
|
25
|
+
const value = toValue(anyValue);
|
|
26
|
+
return typeof value === "string" && /^[0-9A-Fa-f]{4,}$/g.test(value);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* @description detect if the given string is a safe Hexadecimal value
|
|
30
|
+
*/
|
|
31
|
+
export function isSafe(anyValue) {
|
|
32
|
+
const rawValue = toRaw(anyValue);
|
|
33
|
+
if (typeof rawValue === "undefined" || kUnsafeHexValues.has(rawValue)) {
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
const charCount = stringCharDiversity(rawValue);
|
|
37
|
+
if (/^([0-9]+|[a-z]+|[A-Z]+)$/g.test(rawValue)
|
|
38
|
+
|| rawValue.length <= 5
|
|
39
|
+
|| charCount <= 2) {
|
|
40
|
+
return true;
|
|
41
|
+
}
|
|
42
|
+
return [...kSafeHexValues].some((value) => rawValue.toLowerCase().startsWith(value));
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=hex.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hex.js","sourceRoot":"","sources":["../../src/utils/hex.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAEhE,YAAY;AACZ,MAAM,gBAAgB,GAAG,IAAI,GAAG,CAAC;IAC/B,SAAS;IACT,QAAQ;CACT,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACtD,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC;IAC7B,YAAY;IACZ,WAAW;IACX,QAAQ;IACR,cAAc;IACd,kBAAkB;IAClB,wBAAwB;CACzB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC;IACrC,gBAAgB,EAAE,CAAC,GAAG,cAAc,CAAC;IACrC,kBAAkB,EAAE,CAAC,GAAG,gBAAgB,CAAC;CAC1C,CAAC,CAAC;AAEH;;GAEG;AACH,MAAM,UAAU,KAAK,CACnB,QAAiC;IAEjC,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IAEhC,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACvE,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,MAAM,CACpB,QAAiC;IAEjC,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;IACjC,IAAI,OAAO,QAAQ,KAAK,WAAW,IAAI,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;QACtE,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,SAAS,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IAChD,IACE,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC;WACvC,QAAQ,CAAC,MAAM,IAAI,CAAC;WACpB,SAAS,IAAI,CAAC,EACjB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CAAC,GAAG,cAAc,CAAC,CAAC,IAAI,CAC7B,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CACpD,CAAC;AACJ,CAAC"}
|
package/dist/utils/index.d.ts
CHANGED
|
@@ -3,4 +3,13 @@ export * from "./isMinifiedCode.ts";
|
|
|
3
3
|
export * from "./isOneLineExpressionExport.ts";
|
|
4
4
|
export * from "./notNullOrUndefined.ts";
|
|
5
5
|
export * from "./toArrayLocation.ts";
|
|
6
|
+
export * from "./isEvilIdentifier.ts";
|
|
7
|
+
export * from "./stripNodePrefix.ts";
|
|
8
|
+
export * from "./getSubMemberExpressionSegments.ts";
|
|
9
|
+
export * from "./makePrefixRemover.ts";
|
|
10
|
+
export * from "./stringSuspicionScore.ts";
|
|
11
|
+
export * from "./isSvg.ts";
|
|
12
|
+
export * from "./isStringBase64.ts";
|
|
13
|
+
export * from "./patterns.ts";
|
|
14
|
+
export * as Hex from "./hex.ts";
|
|
6
15
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,uBAAuB,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qCAAqC,CAAC;AACpD,cAAc,wBAAwB,CAAC;AACvC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,YAAY,CAAC;AAC3B,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,OAAO,KAAK,GAAG,MAAM,UAAU,CAAC"}
|
package/dist/utils/index.js
CHANGED
|
@@ -3,4 +3,13 @@ export * from "./isMinifiedCode.js";
|
|
|
3
3
|
export * from "./isOneLineExpressionExport.js";
|
|
4
4
|
export * from "./notNullOrUndefined.js";
|
|
5
5
|
export * from "./toArrayLocation.js";
|
|
6
|
+
export * from "./isEvilIdentifier.js";
|
|
7
|
+
export * from "./stripNodePrefix.js";
|
|
8
|
+
export * from "./getSubMemberExpressionSegments.js";
|
|
9
|
+
export * from "./makePrefixRemover.js";
|
|
10
|
+
export * from "./stringSuspicionScore.js";
|
|
11
|
+
export * from "./isSvg.js";
|
|
12
|
+
export * from "./isStringBase64.js";
|
|
13
|
+
export * from "./patterns.js";
|
|
14
|
+
export * as Hex from "./hex.js";
|
|
6
15
|
//# sourceMappingURL=index.js.map
|
package/dist/utils/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,uBAAuB,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qCAAqC,CAAC;AACpD,cAAc,wBAAwB,CAAC;AACvC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,YAAY,CAAC;AAC3B,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,OAAO,KAAK,GAAG,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isEvilIdentifier.d.ts","sourceRoot":"","sources":["../../src/utils/isEvilIdentifier.ts"],"names":[],"mappings":"AAAA,wBAAgB,oBAAoB,CAClC,UAAU,EAAE,MAAM,GACjB,OAAO,CAET;AAED,wBAAgB,iBAAiB,CAC/B,UAAU,EAAE,MAAM,GACjB,OAAO,CAET"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export function isEvilIdentifierPath(identifier) {
|
|
2
|
+
return isFunctionPrototype(identifier);
|
|
3
|
+
}
|
|
4
|
+
export function isNeutralCallable(identifier) {
|
|
5
|
+
return identifier === "Function.prototype.call";
|
|
6
|
+
}
|
|
7
|
+
function isFunctionPrototype(identifier) {
|
|
8
|
+
return identifier.startsWith("Function.prototype")
|
|
9
|
+
&& /call|apply|bind/i.test(identifier);
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=isEvilIdentifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isEvilIdentifier.js","sourceRoot":"","sources":["../../src/utils/isEvilIdentifier.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,oBAAoB,CAClC,UAAkB;IAElB,OAAO,mBAAmB,CAAC,UAAU,CAAC,CAAC;AACzC,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,UAAkB;IAElB,OAAO,UAAU,KAAK,yBAAyB,CAAC;AAClD,CAAC;AAED,SAAS,mBAAmB,CAC1B,UAAkB;IAElB,OAAO,UAAU,CAAC,UAAU,CAAC,oBAAoB,CAAC;WAC7C,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AAC3C,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isOneLineExpressionExport.d.ts","sourceRoot":"","sources":["../../src/utils/isOneLineExpressionExport.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"isOneLineExpressionExport.d.ts","sourceRoot":"","sources":["../../src/utils/isOneLineExpressionExport.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAOtC,wBAAgB,yBAAyB,CACvC,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAC3B,OAAO,CAoBT"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { getCallExpressionIdentifier } from "../estree/index.js";
|
|
2
3
|
export function isOneLineExpressionExport(body) {
|
|
3
4
|
if (body.length === 0 || body.length > 1) {
|
|
4
5
|
return false;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isOneLineExpressionExport.js","sourceRoot":"","sources":["../../src/utils/isOneLineExpressionExport.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"isOneLineExpressionExport.js","sourceRoot":"","sources":["../../src/utils/isOneLineExpressionExport.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EACL,2BAA2B,EAC5B,MAAM,oBAAoB,CAAC;AAE5B,MAAM,UAAU,yBAAyB,CACvC,IAA4B;IAE5B,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACzC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;IACzB,IAAI,SAAS,CAAC,IAAI,KAAK,qBAAqB,EAAE,CAAC;QAC7C,OAAO,KAAK,CAAC;IACf,CAAC;IAED,QAAQ,SAAS,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QAClC,mCAAmC;QACnC,KAAK,sBAAsB;YACzB,OAAO,+BAA+B,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACrE,kBAAkB;QAClB,KAAK,gBAAgB;YACnB,OAAO,+BAA+B,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC/D;YACE,OAAO,KAAK,CAAC;IACjB,CAAC;AACH,CAAC;AAED,SAAS,+BAA+B,CACtC,IAAuB;IAEvB,IAAI,IAAI,CAAC,IAAI,KAAK,mBAAmB,EAAE,CAAC;QACtC,OAAO,+BAA+B,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAChE,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,KAAK,uBAAuB,EAAE,CAAC;QAC1C,OAAO,+BAA+B,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1E,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;QACnC,OAAO,2BAA2B,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC;IACzD,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;QACrC,IAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;QAC7B,OAAO,UAAU,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YAC9C,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC;QACjC,CAAC;QAED,IAAI,UAAU,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;YACzC,OAAO,KAAK,CAAC;QACf,CAAC;QAED,OAAO,2BAA2B,CAAC,UAAU,CAAC,KAAK,SAAS,CAAC;IAC/D,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,+BAA+B,CACtC,IAAuB,EACvB,KAAwB;IAExB,OAAO;QACL,+BAA+B,CAAC,IAAI,CAAC;QACrC,+BAA+B,CAAC,KAAK,CAAC;KACvC,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,CAAC;AACrC,CAAC"}
|