@nodesecure/js-x-ray 9.1.0 → 9.2.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 +64 -0
- package/dist/AstAnalyser.d.ts.map +1 -0
- package/dist/AstAnalyser.js +165 -0
- package/dist/AstAnalyser.js.map +1 -0
- package/dist/Deobfuscator.d.ts +36 -0
- package/dist/Deobfuscator.d.ts.map +1 -0
- package/dist/Deobfuscator.js +154 -0
- package/dist/Deobfuscator.js.map +1 -0
- package/dist/EntryFilesAnalyser.d.ts +20 -0
- package/dist/EntryFilesAnalyser.d.ts.map +1 -0
- package/dist/EntryFilesAnalyser.js +121 -0
- package/dist/EntryFilesAnalyser.js.map +1 -0
- package/dist/JsSourceParser.d.ts +18 -0
- package/dist/JsSourceParser.d.ts.map +1 -0
- package/dist/JsSourceParser.js +38 -0
- package/dist/JsSourceParser.js.map +1 -0
- package/dist/NodeCounter.d.ts +24 -0
- package/dist/NodeCounter.d.ts.map +1 -0
- package/dist/NodeCounter.js +62 -0
- package/dist/NodeCounter.js.map +1 -0
- package/dist/ProbeRunner.d.ts +40 -0
- package/dist/ProbeRunner.d.ts.map +1 -0
- package/dist/ProbeRunner.js +106 -0
- package/dist/ProbeRunner.js.map +1 -0
- package/dist/SourceFile.d.ts +43 -0
- package/dist/SourceFile.d.ts.map +1 -0
- package/dist/SourceFile.js +137 -0
- package/dist/SourceFile.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -0
- package/{src/index.ts → dist/index.js} +1 -0
- package/dist/index.js.map +1 -0
- package/dist/obfuscators/freejsobfuscator.d.ts +3 -0
- package/dist/obfuscators/freejsobfuscator.d.ts.map +1 -0
- package/dist/obfuscators/freejsobfuscator.js +10 -0
- package/dist/obfuscators/freejsobfuscator.js.map +1 -0
- package/dist/obfuscators/jjencode.d.ts +3 -0
- package/dist/obfuscators/jjencode.d.ts.map +1 -0
- package/dist/obfuscators/jjencode.js +24 -0
- package/dist/obfuscators/jjencode.js.map +1 -0
- package/dist/obfuscators/jsfuck.d.ts +3 -0
- package/dist/obfuscators/jsfuck.d.ts.map +1 -0
- package/dist/obfuscators/jsfuck.js +13 -0
- package/dist/obfuscators/jsfuck.js.map +1 -0
- package/dist/obfuscators/obfuscator-io.d.ts +3 -0
- package/dist/obfuscators/obfuscator-io.d.ts.map +1 -0
- package/dist/obfuscators/obfuscator-io.js +15 -0
- package/dist/obfuscators/obfuscator-io.js.map +1 -0
- package/dist/obfuscators/trojan-source.d.ts +2 -0
- package/dist/obfuscators/trojan-source.d.ts.map +1 -0
- package/dist/obfuscators/trojan-source.js +27 -0
- package/dist/obfuscators/trojan-source.js.map +1 -0
- package/dist/probes/isArrayExpression.d.ts +21 -0
- package/dist/probes/isArrayExpression.d.ts.map +1 -0
- package/dist/probes/isArrayExpression.js +27 -0
- package/dist/probes/isArrayExpression.js.map +1 -0
- package/dist/probes/isBinaryExpression.d.ts +21 -0
- package/dist/probes/isBinaryExpression.d.ts.map +1 -0
- package/dist/probes/isBinaryExpression.js +54 -0
- package/dist/probes/isBinaryExpression.js.map +1 -0
- package/dist/probes/isESMExport.d.ts +24 -0
- package/dist/probes/isESMExport.d.ts.map +1 -0
- package/dist/probes/isESMExport.js +30 -0
- package/dist/probes/isESMExport.js.map +1 -0
- package/dist/probes/isFetch.d.ts +14 -0
- package/dist/probes/isFetch.d.ts.map +1 -0
- package/dist/probes/isFetch.js +18 -0
- package/dist/probes/isFetch.js.map +1 -0
- package/dist/probes/isImportDeclaration.d.ts +26 -0
- package/dist/probes/isImportDeclaration.d.ts.map +1 -0
- package/dist/probes/isImportDeclaration.js +38 -0
- package/dist/probes/isImportDeclaration.js.map +1 -0
- package/dist/probes/isLiteral.d.ts +21 -0
- package/dist/probes/isLiteral.d.ts.map +1 -0
- package/dist/probes/isLiteral.js +66 -0
- package/dist/probes/isLiteral.js.map +1 -0
- package/dist/probes/isLiteralRegex.d.ts +20 -0
- package/dist/probes/isLiteralRegex.d.ts.map +1 -0
- package/dist/probes/isLiteralRegex.js +30 -0
- package/dist/probes/isLiteralRegex.js.map +1 -0
- package/dist/probes/isRegexObject.d.ts +22 -0
- package/dist/probes/isRegexObject.d.ts.map +1 -0
- package/dist/probes/isRegexObject.js +50 -0
- package/dist/probes/isRegexObject.js.map +1 -0
- package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts +15 -0
- package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts.map +1 -0
- package/dist/probes/isRequire/RequireCallExpressionWalker.js +95 -0
- package/dist/probes/isRequire/RequireCallExpressionWalker.js.map +1 -0
- package/dist/probes/isRequire/isRequire.d.ts +20 -0
- package/dist/probes/isRequire/isRequire.d.ts.map +1 -0
- package/dist/probes/isRequire/isRequire.js +138 -0
- package/dist/probes/isRequire/isRequire.js.map +1 -0
- package/dist/probes/isSerializeEnv.d.ts +24 -0
- package/dist/probes/isSerializeEnv.d.ts.map +1 -0
- package/dist/probes/isSerializeEnv.js +66 -0
- package/dist/probes/isSerializeEnv.js.map +1 -0
- package/dist/probes/isSyncIO.d.ts +16 -0
- package/dist/probes/isSyncIO.d.ts.map +1 -0
- package/dist/probes/isSyncIO.js +74 -0
- package/dist/probes/isSyncIO.js.map +1 -0
- package/dist/probes/isUnsafeCallee.d.ts +22 -0
- package/dist/probes/isUnsafeCallee.d.ts.map +1 -0
- package/dist/probes/isUnsafeCallee.js +60 -0
- package/dist/probes/isUnsafeCallee.js.map +1 -0
- package/dist/probes/isUnsafeCommand.d.ts +24 -0
- package/dist/probes/isUnsafeCommand.d.ts.map +1 -0
- package/dist/probes/isUnsafeCommand.js +100 -0
- package/dist/probes/isUnsafeCommand.js.map +1 -0
- package/dist/probes/isWeakCrypto.d.ts +16 -0
- package/dist/probes/isWeakCrypto.d.ts.map +1 -0
- package/dist/probes/isWeakCrypto.js +46 -0
- package/dist/probes/isWeakCrypto.js.map +1 -0
- package/dist/types/estree.d.ts +11 -0
- package/dist/types/estree.d.ts.map +1 -0
- package/dist/types/estree.js +15 -0
- package/dist/types/estree.js.map +1 -0
- package/dist/utils/extractNode.d.ts +5 -0
- package/dist/utils/extractNode.d.ts.map +1 -0
- package/dist/utils/extractNode.js +13 -0
- package/dist/utils/extractNode.js.map +1 -0
- package/dist/utils/index.d.ts +5 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/{src/utils/index.ts → dist/utils/index.js} +1 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/isOneLineExpressionExport.d.ts +3 -0
- package/dist/utils/isOneLineExpressionExport.d.ts.map +1 -0
- package/dist/utils/isOneLineExpressionExport.js +49 -0
- package/dist/utils/isOneLineExpressionExport.js.map +1 -0
- package/dist/utils/notNullOrUndefined.d.ts +2 -0
- package/dist/utils/notNullOrUndefined.d.ts.map +1 -0
- package/dist/utils/notNullOrUndefined.js +4 -0
- package/dist/utils/notNullOrUndefined.js.map +1 -0
- package/dist/utils/toArrayLocation.d.ts +5 -0
- package/dist/utils/toArrayLocation.d.ts.map +1 -0
- package/dist/utils/toArrayLocation.js +14 -0
- package/dist/utils/toArrayLocation.js.map +1 -0
- package/dist/warnings.d.ts +88 -0
- package/dist/warnings.d.ts.map +1 -0
- package/dist/warnings.js +91 -0
- package/dist/warnings.js.map +1 -0
- package/package.json +3 -6
- package/src/AstAnalyser.ts +0 -283
- package/src/Deobfuscator.ts +0 -228
- package/src/EntryFilesAnalyser.ts +0 -206
- package/src/JsSourceParser.ts +0 -77
- package/src/NodeCounter.ts +0 -90
- package/src/ProbeRunner.ts +0 -167
- package/src/SourceFile.ts +0 -226
- package/src/obfuscators/freejsobfuscator.ts +0 -17
- package/src/obfuscators/jjencode.ts +0 -39
- package/src/obfuscators/jsfuck.ts +0 -19
- package/src/obfuscators/obfuscator-io.ts +0 -25
- package/src/obfuscators/trojan-source.ts +0 -30
- package/src/probes/isArrayExpression.ts +0 -41
- package/src/probes/isBinaryExpression.ts +0 -74
- package/src/probes/isESMExport.ts +0 -50
- package/src/probes/isFetch.ts +0 -28
- package/src/probes/isImportDeclaration.ts +0 -58
- package/src/probes/isLiteral.ts +0 -91
- package/src/probes/isLiteralRegex.ts +0 -42
- package/src/probes/isRegexObject.ts +0 -71
- package/src/probes/isRequire/RequireCallExpressionWalker.ts +0 -142
- package/src/probes/isRequire/isRequire.ts +0 -195
- package/src/probes/isSerializeEnv.ts +0 -65
- package/src/probes/isSyncIO.ts +0 -96
- package/src/probes/isUnsafeCallee.ts +0 -89
- package/src/probes/isUnsafeCommand.ts +0 -133
- package/src/probes/isWeakCrypto.ts +0 -69
- package/src/types/estree.ts +0 -35
- package/src/utils/extractNode.ts +0 -22
- package/src/utils/isOneLineExpressionExport.ts +0 -70
- package/src/utils/notNullOrUndefined.ts +0 -5
- package/src/utils/toArrayLocation.ts +0 -22
- package/src/warnings.ts +0 -146
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { SourceFile } from "../SourceFile.js";
|
|
3
|
+
import { generateWarning } from "../warnings.js";
|
|
4
|
+
import { ProbeSignals } from "../ProbeRunner.js";
|
|
5
|
+
import { isLiteral } from "../types/estree.js";
|
|
6
|
+
// CONSTANTS
|
|
7
|
+
const kUnsafeCommands = ["csrutil"];
|
|
8
|
+
function isUnsafeCommand(command) {
|
|
9
|
+
return kUnsafeCommands.some((unsafeCommand) => command.includes(unsafeCommand));
|
|
10
|
+
}
|
|
11
|
+
function isSpawnOrExec(name) {
|
|
12
|
+
return name === "spawn" ||
|
|
13
|
+
name === "exec" ||
|
|
14
|
+
name === "spawnSync" ||
|
|
15
|
+
name === "execSync";
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* @description Detect spawn or exec unsafe commands
|
|
19
|
+
* @example
|
|
20
|
+
* child_process.spawn("csrutil", ["status"]);
|
|
21
|
+
*
|
|
22
|
+
* require("child_process").spawn("csrutil", ["disable"]);
|
|
23
|
+
*
|
|
24
|
+
* const { exec } = require("child_process");
|
|
25
|
+
* exec("csrutil status");
|
|
26
|
+
*/
|
|
27
|
+
function validateNode(node) {
|
|
28
|
+
if (node.type !== "CallExpression" || node.arguments.length === 0) {
|
|
29
|
+
return [false];
|
|
30
|
+
}
|
|
31
|
+
// const { spawn } = require("child_process");
|
|
32
|
+
// spawn("...", ["..."]);
|
|
33
|
+
// or
|
|
34
|
+
// const { exec } = require("child_process");
|
|
35
|
+
// exec(...);
|
|
36
|
+
if (node.type === "CallExpression" &&
|
|
37
|
+
node.callee.type === "Identifier" &&
|
|
38
|
+
isSpawnOrExec(node.callee.name)) {
|
|
39
|
+
return [true, node.callee.name];
|
|
40
|
+
}
|
|
41
|
+
// child_process.spawn(...) or require("child_process").spawn(...)
|
|
42
|
+
// child_process.exec(...) or require("child_process").exec(...)
|
|
43
|
+
if (node.callee.type === "MemberExpression" &&
|
|
44
|
+
node.callee.property.type === "Identifier" &&
|
|
45
|
+
isSpawnOrExec(node.callee.property.name)) {
|
|
46
|
+
// child_process.spawn(...)
|
|
47
|
+
// child_process.exec(...)
|
|
48
|
+
if (node.callee.object.type === "Identifier" &&
|
|
49
|
+
node.callee.object.name === "child_process") {
|
|
50
|
+
return [true, node.callee.property.name];
|
|
51
|
+
}
|
|
52
|
+
// require("child_process").spawn(...)
|
|
53
|
+
// require("child_process").exec(...)
|
|
54
|
+
if (node.callee.object.type === "CallExpression" &&
|
|
55
|
+
node.callee.object.callee.type === "Identifier" &&
|
|
56
|
+
node.callee.object.callee.name === "require" &&
|
|
57
|
+
node.callee.object.arguments.length === 1 &&
|
|
58
|
+
node.callee.object.arguments[0].type === "Literal" &&
|
|
59
|
+
node.callee.object.arguments[0].value === "child_process") {
|
|
60
|
+
return [true, node.callee.property.name];
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return [false];
|
|
64
|
+
}
|
|
65
|
+
function main(node, options) {
|
|
66
|
+
const { sourceFile, data: methodName } = options;
|
|
67
|
+
const commandArg = node.arguments[0];
|
|
68
|
+
if (!isLiteral(commandArg)) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
let command = commandArg.value;
|
|
72
|
+
if (isUnsafeCommand(command)) {
|
|
73
|
+
// Spawned command arguments are filled into an Array
|
|
74
|
+
// as second arguments. This is why we should add them
|
|
75
|
+
// manually to the command string.
|
|
76
|
+
if (methodName === "spawn" || methodName === "spawnSync") {
|
|
77
|
+
const arrExpr = node.arguments.at(1);
|
|
78
|
+
if (arrExpr && arrExpr.type === "ArrayExpression") {
|
|
79
|
+
arrExpr.elements
|
|
80
|
+
.filter((element) => isLiteral(element))
|
|
81
|
+
.forEach((element) => {
|
|
82
|
+
command += ` ${element.value}`;
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
const warning = generateWarning("unsafe-command", {
|
|
87
|
+
value: command,
|
|
88
|
+
location: node.loc
|
|
89
|
+
});
|
|
90
|
+
sourceFile.warnings.push(warning);
|
|
91
|
+
return ProbeSignals.Skip;
|
|
92
|
+
}
|
|
93
|
+
return null;
|
|
94
|
+
}
|
|
95
|
+
export default {
|
|
96
|
+
name: "isUnsafeCommand",
|
|
97
|
+
validateNode,
|
|
98
|
+
main
|
|
99
|
+
};
|
|
100
|
+
//# sourceMappingURL=isUnsafeCommand.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isUnsafeCommand.js","sourceRoot":"","sources":["../../src/probes/isUnsafeCommand.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
import { SourceFile } from "../SourceFile.js";
|
|
3
|
+
declare function validateNode(node: ESTree.Node, sourceFile: SourceFile): [boolean, any?];
|
|
4
|
+
declare function initialize(sourceFile: SourceFile): void;
|
|
5
|
+
declare function main(node: ESTree.CallExpression, { sourceFile }: {
|
|
6
|
+
sourceFile: SourceFile;
|
|
7
|
+
}): void;
|
|
8
|
+
declare const _default: {
|
|
9
|
+
name: string;
|
|
10
|
+
validateNode: typeof validateNode;
|
|
11
|
+
main: typeof main;
|
|
12
|
+
initialize: typeof initialize;
|
|
13
|
+
breakOnMatch: boolean;
|
|
14
|
+
};
|
|
15
|
+
export default _default;
|
|
16
|
+
//# sourceMappingURL=isWeakCrypto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isWeakCrypto.d.ts","sourceRoot":"","sources":["../../src/probes/isWeakCrypto.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAe9C,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,UAAU,EAAE,UAAU,GACrB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAajB;AAED,iBAAS,UAAU,CACjB,UAAU,EAAE,UAAU,QAMvB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,MAAM,CAAC,cAAc,EAC3B,EAAE,UAAU,EAAE,EAAE;IAAE,UAAU,EAAE,UAAU,CAAC;CAAE,QAW5C;;;;;;;;AAED,wBAME"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
// Import Third-party Dependencies
|
|
2
|
+
import { getCallExpressionIdentifier } from "@nodesecure/estree-ast-utils";
|
|
3
|
+
// Import Internal Dependencies
|
|
4
|
+
import { SourceFile } from "../SourceFile.js";
|
|
5
|
+
import { generateWarning } from "../warnings.js";
|
|
6
|
+
import { isLiteral } from "../types/estree.js";
|
|
7
|
+
// CONSTANTS
|
|
8
|
+
const kWeakAlgorithms = new Set([
|
|
9
|
+
"md5",
|
|
10
|
+
"sha1",
|
|
11
|
+
"ripemd160",
|
|
12
|
+
"md4",
|
|
13
|
+
"md2"
|
|
14
|
+
]);
|
|
15
|
+
function validateNode(node, sourceFile) {
|
|
16
|
+
const { tracer } = sourceFile;
|
|
17
|
+
const id = getCallExpressionIdentifier(node);
|
|
18
|
+
if (id === null || !tracer.importedModules.has("crypto")) {
|
|
19
|
+
return [false];
|
|
20
|
+
}
|
|
21
|
+
const data = tracer.getDataFromIdentifier(id);
|
|
22
|
+
return [
|
|
23
|
+
data !== null && data.identifierOrMemberExpr === "crypto.createHash"
|
|
24
|
+
];
|
|
25
|
+
}
|
|
26
|
+
function initialize(sourceFile) {
|
|
27
|
+
sourceFile.tracer.trace("crypto.createHash", {
|
|
28
|
+
followConsecutiveAssignment: true,
|
|
29
|
+
moduleName: "crypto"
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
function main(node, { sourceFile }) {
|
|
33
|
+
const arg = node.arguments.at(0);
|
|
34
|
+
if (isLiteral(arg) && kWeakAlgorithms.has(arg.value)) {
|
|
35
|
+
const warning = generateWarning("weak-crypto", { value: arg.value, location: node.loc });
|
|
36
|
+
sourceFile.warnings.push(warning);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
export default {
|
|
40
|
+
name: "isWeakCrypto",
|
|
41
|
+
validateNode,
|
|
42
|
+
main,
|
|
43
|
+
initialize,
|
|
44
|
+
breakOnMatch: false
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=isWeakCrypto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isWeakCrypto.js","sourceRoot":"","sources":["../../src/probes/isWeakCrypto.ts"],"names":[],"mappings":"AAAA,kCAAkC;AAClC,OAAO,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;AAG3E,+BAA+B;AAC/B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EACL,SAAS,EACV,MAAM,oBAAoB,CAAC;AAE5B,YAAY;AACZ,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC;IAC9B,KAAK;IACL,MAAM;IACN,WAAW;IACX,KAAK;IACL,KAAK;CACN,CAAC,CAAC;AAEH,SAAS,YAAY,CACnB,IAAiB,EACjB,UAAsB;IAEtB,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC;IAE9B,MAAM,EAAE,GAAG,2BAA2B,CAAC,IAAI,CAAC,CAAC;IAC7C,IAAI,EAAE,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;QACzD,OAAO,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC;IAE9C,OAAO;QACL,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,sBAAsB,KAAK,mBAAmB;KACrE,CAAC;AACJ,CAAC;AAED,SAAS,UAAU,CACjB,UAAsB;IAEtB,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE;QAC3C,2BAA2B,EAAE,IAAI;QACjC,UAAU,EAAE,QAAQ;KACrB,CAAC,CAAC;AACL,CAAC;AAED,SAAS,IAAI,CACX,IAA2B,EAC3B,EAAE,UAAU,EAA+B;IAE3C,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAEjC,IAAI,SAAS,CAAC,GAAG,CAAC,IAAI,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;QACrD,MAAM,OAAO,GAAG,eAAe,CAC7B,aAAa,EACb,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,CACzC,CAAC;QACF,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC;AACH,CAAC;AAED,eAAe;IACb,IAAI,EAAE,cAAc;IACpB,YAAY;IACZ,IAAI;IACJ,UAAU;IACV,YAAY,EAAE,KAAK;CACpB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
export type Literal<T> = ESTree.Literal & {
|
|
3
|
+
value: T;
|
|
4
|
+
};
|
|
5
|
+
export type RegExpLiteral<T> = ESTree.RegExpLiteral & {
|
|
6
|
+
value: T;
|
|
7
|
+
};
|
|
8
|
+
export declare function isNode(value: any): value is ESTree.Node;
|
|
9
|
+
export declare function isLiteral(node: any): node is Literal<string>;
|
|
10
|
+
export declare function isCallExpression(node: any): node is ESTree.CallExpression;
|
|
11
|
+
//# sourceMappingURL=estree.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estree.d.ts","sourceRoot":"","sources":["../../src/types/estree.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEtC,MAAM,MAAM,OAAO,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,GAAG;IACxC,KAAK,EAAE,CAAC,CAAC;CACV,CAAC;AAEF,MAAM,MAAM,aAAa,CAAC,CAAC,IAAI,MAAM,CAAC,aAAa,GAAG;IACpD,KAAK,EAAE,CAAC,CAAC;CACV,CAAC;AAEF,wBAAgB,MAAM,CACpB,KAAK,EAAE,GAAG,GACT,KAAK,IAAI,MAAM,CAAC,IAAI,CAOtB;AAED,wBAAgB,SAAS,CACvB,IAAI,EAAE,GAAG,GACR,IAAI,IAAI,OAAO,CAAC,MAAM,CAAC,CAIzB;AAED,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,GAAG,GACR,IAAI,IAAI,MAAM,CAAC,cAAc,CAE/B"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export function isNode(value) {
|
|
2
|
+
return (value !== null &&
|
|
3
|
+
typeof value === "object" &&
|
|
4
|
+
"type" in value &&
|
|
5
|
+
typeof value.type === "string");
|
|
6
|
+
}
|
|
7
|
+
export function isLiteral(node) {
|
|
8
|
+
return isNode(node) &&
|
|
9
|
+
node.type === "Literal" &&
|
|
10
|
+
typeof node.value === "string";
|
|
11
|
+
}
|
|
12
|
+
export function isCallExpression(node) {
|
|
13
|
+
return isNode(node) && node.type === "CallExpression";
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=estree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estree.js","sourceRoot":"","sources":["../../src/types/estree.ts"],"names":[],"mappings":"AAWA,MAAM,UAAU,MAAM,CACpB,KAAU;IAEV,OAAO,CACL,KAAK,KAAK,IAAI;QACd,OAAO,KAAK,KAAK,QAAQ;QACzB,MAAM,IAAI,KAAK;QACf,OAAO,KAAK,CAAC,IAAI,KAAK,QAAQ,CAC/B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,SAAS,CACvB,IAAS;IAET,OAAO,MAAM,CAAC,IAAI,CAAC;QACjB,IAAI,CAAC,IAAI,KAAK,SAAS;QACvB,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,IAAS;IAET,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,CAAC;AACxD,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
export type NodeExtractorCallback<T> = (node: T) => void;
|
|
3
|
+
export type NodeOrNull = ESTree.Node | null;
|
|
4
|
+
export declare function extractNode<T extends ESTree.Node>(expectedType: T["type"]): (callback: NodeExtractorCallback<T>, nodes: NodeOrNull | NodeOrNull[]) => void;
|
|
5
|
+
//# sourceMappingURL=extractNode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractNode.d.ts","sourceRoot":"","sources":["../../src/utils/extractNode.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAKtC,MAAM,MAAM,qBAAqB,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC;AACzD,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC;AAE5C,wBAAgB,WAAW,CAAC,CAAC,SAAS,MAAM,CAAC,IAAI,EAC/C,YAAY,EAAE,CAAC,CAAC,MAAM,CAAC,IAEf,UAAU,qBAAqB,CAAC,CAAC,CAAC,EAAE,OAAO,UAAU,GAAG,UAAU,EAAE,UAS7E"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { isNode } from "../types/estree.js";
|
|
3
|
+
export function extractNode(expectedType) {
|
|
4
|
+
return (callback, nodes) => {
|
|
5
|
+
const finalNodes = Array.isArray(nodes) ? nodes : [nodes];
|
|
6
|
+
for (const node of finalNodes) {
|
|
7
|
+
if (isNode(node) && node.type === expectedType) {
|
|
8
|
+
callback(node);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=extractNode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractNode.js","sourceRoot":"","sources":["../../src/utils/extractNode.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAK5C,MAAM,UAAU,WAAW,CACzB,YAAuB;IAEvB,OAAO,CAAC,QAAkC,EAAE,KAAgC,EAAE,EAAE;QAC9E,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAE1D,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;YAC9B,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;gBAC/C,QAAQ,CAAC,IAAS,CAAC,CAAC;YACtB,CAAC;QACH,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC"}
|
|
@@ -0,0 +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;AAKtC,wBAAgB,yBAAyB,CACvC,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAC3B,OAAO,CAoBT"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { getCallExpressionIdentifier } from "@nodesecure/estree-ast-utils";
|
|
2
|
+
export function isOneLineExpressionExport(body) {
|
|
3
|
+
if (body.length === 0 || body.length > 1) {
|
|
4
|
+
return false;
|
|
5
|
+
}
|
|
6
|
+
const [firstNode] = body;
|
|
7
|
+
if (firstNode.type !== "ExpressionStatement") {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
switch (firstNode.expression.type) {
|
|
11
|
+
// module.exports = require('...');
|
|
12
|
+
case "AssignmentExpression":
|
|
13
|
+
return exportAssignmentHasRequireLeave(firstNode.expression.right);
|
|
14
|
+
// require('...');
|
|
15
|
+
case "CallExpression":
|
|
16
|
+
return exportAssignmentHasRequireLeave(firstNode.expression);
|
|
17
|
+
default:
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function exportAssignmentHasRequireLeave(expr) {
|
|
22
|
+
if (expr.type === "LogicalExpression") {
|
|
23
|
+
return atLeastOneBranchHasRequireLeave(expr.left, expr.right);
|
|
24
|
+
}
|
|
25
|
+
if (expr.type === "ConditionalExpression") {
|
|
26
|
+
return atLeastOneBranchHasRequireLeave(expr.consequent, expr.alternate);
|
|
27
|
+
}
|
|
28
|
+
if (expr.type === "CallExpression") {
|
|
29
|
+
return getCallExpressionIdentifier(expr) === "require";
|
|
30
|
+
}
|
|
31
|
+
if (expr.type === "MemberExpression") {
|
|
32
|
+
let rootMember = expr.object;
|
|
33
|
+
while (rootMember.type === "MemberExpression") {
|
|
34
|
+
rootMember = rootMember.object;
|
|
35
|
+
}
|
|
36
|
+
if (rootMember.type !== "CallExpression") {
|
|
37
|
+
return false;
|
|
38
|
+
}
|
|
39
|
+
return getCallExpressionIdentifier(rootMember) === "require";
|
|
40
|
+
}
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
function atLeastOneBranchHasRequireLeave(left, right) {
|
|
44
|
+
return [
|
|
45
|
+
exportAssignmentHasRequireLeave(left),
|
|
46
|
+
exportAssignmentHasRequireLeave(right)
|
|
47
|
+
].some((hasRequire) => hasRequire);
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=isOneLineExpressionExport.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isOneLineExpressionExport.js","sourceRoot":"","sources":["../../src/utils/isOneLineExpressionExport.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,2BAA2B,EAC5B,MAAM,8BAA8B,CAAC;AAEtC,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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notNullOrUndefined.d.ts","sourceRoot":"","sources":["../../src/utils/notNullOrUndefined.ts"],"names":[],"mappings":"AAAA,wBAAgB,kBAAkB,CAAC,CAAC,GAAG,GAAG,EACxC,KAAK,EAAE,CAAC,GACP,KAAK,IAAI,WAAW,CAAC,CAAC,CAAC,CAEzB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notNullOrUndefined.js","sourceRoot":"","sources":["../../src/utils/notNullOrUndefined.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,kBAAkB,CAChC,KAAQ;IAER,OAAO,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,KAAK,CAAC,CAAC;AAC5C,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
export type SourceArrayLocation = [[number, number], [number, number]];
|
|
3
|
+
export declare function rootLocation(): ESTree.SourceLocation;
|
|
4
|
+
export declare function toArrayLocation(location?: ESTree.SourceLocation): SourceArrayLocation;
|
|
5
|
+
//# sourceMappingURL=toArrayLocation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toArrayLocation.d.ts","sourceRoot":"","sources":["../../src/utils/toArrayLocation.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEtC,MAAM,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;AAEvE,wBAAgB,YAAY,IAAI,MAAM,CAAC,cAAc,CAKpD;AAED,wBAAgB,eAAe,CAC7B,QAAQ,GAAE,MAAM,CAAC,cAA+B,GAC/C,mBAAmB,CAOrB"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export function rootLocation() {
|
|
2
|
+
return {
|
|
3
|
+
start: { line: 0, column: 0 },
|
|
4
|
+
end: { line: 0, column: 0 }
|
|
5
|
+
};
|
|
6
|
+
}
|
|
7
|
+
export function toArrayLocation(location = rootLocation()) {
|
|
8
|
+
const { start, end = start } = location;
|
|
9
|
+
return [
|
|
10
|
+
[start.line || 0, start.column || 0],
|
|
11
|
+
[end.line || 0, end.column || 0]
|
|
12
|
+
];
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=toArrayLocation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toArrayLocation.js","sourceRoot":"","sources":["../../src/utils/toArrayLocation.ts"],"names":[],"mappings":"AAKA,MAAM,UAAU,YAAY;IAC1B,OAAO;QACL,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE;QAC7B,GAAG,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE;KAC5B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAC7B,WAAkC,YAAY,EAAE;IAEhD,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,KAAK,EAAE,GAAG,QAAQ,CAAC;IAExC,OAAO;QACL,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,EAAE,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC;QACpC,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,EAAE,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC;KACjC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
import { type SourceArrayLocation } from "./utils/toArrayLocation.js";
|
|
3
|
+
export type OptionalWarningName = "synchronous-io";
|
|
4
|
+
export type WarningName = "parsing-error" | "encoded-literal" | "unsafe-regex" | "unsafe-stmt" | "short-identifiers" | "suspicious-literal" | "suspicious-file" | "obfuscated-code" | "weak-crypto" | "shady-link" | "unsafe-command" | "unsafe-import" | "serialize-environment" | OptionalWarningName;
|
|
5
|
+
export interface Warning<T = WarningName> {
|
|
6
|
+
kind: T | (string & {});
|
|
7
|
+
file?: string;
|
|
8
|
+
value: string | null;
|
|
9
|
+
source: string;
|
|
10
|
+
location: null | SourceArrayLocation | SourceArrayLocation[];
|
|
11
|
+
i18n: string;
|
|
12
|
+
severity: "Information" | "Warning" | "Critical";
|
|
13
|
+
experimental?: boolean;
|
|
14
|
+
}
|
|
15
|
+
export declare const warnings: Readonly<{
|
|
16
|
+
"parsing-error": {
|
|
17
|
+
i18n: string;
|
|
18
|
+
severity: "Information";
|
|
19
|
+
};
|
|
20
|
+
"unsafe-import": {
|
|
21
|
+
i18n: string;
|
|
22
|
+
severity: "Warning";
|
|
23
|
+
};
|
|
24
|
+
"unsafe-regex": {
|
|
25
|
+
i18n: string;
|
|
26
|
+
severity: "Warning";
|
|
27
|
+
};
|
|
28
|
+
"unsafe-stmt": {
|
|
29
|
+
code: string;
|
|
30
|
+
i18n: string;
|
|
31
|
+
severity: "Warning";
|
|
32
|
+
};
|
|
33
|
+
"encoded-literal": {
|
|
34
|
+
i18n: string;
|
|
35
|
+
severity: "Information";
|
|
36
|
+
};
|
|
37
|
+
"short-identifiers": {
|
|
38
|
+
i18n: string;
|
|
39
|
+
severity: "Warning";
|
|
40
|
+
};
|
|
41
|
+
"suspicious-literal": {
|
|
42
|
+
i18n: string;
|
|
43
|
+
severity: "Warning";
|
|
44
|
+
};
|
|
45
|
+
"suspicious-file": {
|
|
46
|
+
i18n: string;
|
|
47
|
+
severity: "Critical";
|
|
48
|
+
experimental: false;
|
|
49
|
+
};
|
|
50
|
+
"obfuscated-code": {
|
|
51
|
+
i18n: string;
|
|
52
|
+
severity: "Critical";
|
|
53
|
+
experimental: true;
|
|
54
|
+
};
|
|
55
|
+
"weak-crypto": {
|
|
56
|
+
i18n: string;
|
|
57
|
+
severity: "Information";
|
|
58
|
+
experimental: false;
|
|
59
|
+
};
|
|
60
|
+
"shady-link": {
|
|
61
|
+
i18n: string;
|
|
62
|
+
severity: "Warning";
|
|
63
|
+
experimental: false;
|
|
64
|
+
};
|
|
65
|
+
"unsafe-command": {
|
|
66
|
+
i18n: string;
|
|
67
|
+
severity: "Warning";
|
|
68
|
+
experimental: true;
|
|
69
|
+
};
|
|
70
|
+
"synchronous-io": {
|
|
71
|
+
i18n: string;
|
|
72
|
+
severity: "Warning";
|
|
73
|
+
experimental: true;
|
|
74
|
+
};
|
|
75
|
+
"serialize-environment": {
|
|
76
|
+
i18n: string;
|
|
77
|
+
severity: "Warning";
|
|
78
|
+
experimental: false;
|
|
79
|
+
};
|
|
80
|
+
}>;
|
|
81
|
+
export interface GenerateWarningOptions {
|
|
82
|
+
location?: ESTree.SourceLocation | null;
|
|
83
|
+
file?: string | null;
|
|
84
|
+
value: string | null;
|
|
85
|
+
source?: string;
|
|
86
|
+
}
|
|
87
|
+
export declare function generateWarning<T extends WarningName>(kind: T, options: GenerateWarningOptions): Warning<T>;
|
|
88
|
+
//# sourceMappingURL=warnings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"warnings.d.ts","sourceRoot":"","sources":["../src/warnings.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,EAGL,KAAK,mBAAmB,EACzB,MAAM,4BAA4B,CAAC;AAGpC,MAAM,MAAM,mBAAmB,GAC3B,gBAAgB,CAAC;AAErB,MAAM,MAAM,WAAW,GACnB,eAAe,GACf,iBAAiB,GACjB,cAAc,GACd,aAAa,GACb,mBAAmB,GACnB,oBAAoB,GACpB,iBAAiB,GACjB,iBAAiB,GACjB,aAAa,GACb,YAAY,GACZ,gBAAgB,GAChB,eAAe,GACf,uBAAuB,GACvB,mBAAmB,CAAC;AAExB,MAAM,WAAW,OAAO,CAAC,CAAC,GAAG,WAAW;IACtC,IAAI,EAAE,CAAC,GAAG,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;IACxB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,IAAI,GAAG,mBAAmB,GAAG,mBAAmB,EAAE,CAAC;IAC7D,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,aAAa,GAAG,SAAS,GAAG,UAAU,CAAC;IACjD,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiEgE,CAAC;AAEtF,MAAM,WAAW,sBAAsB;IACrC,QAAQ,CAAC,EAAE,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC;IACxC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,eAAe,CAAC,CAAC,SAAS,WAAW,EACnD,IAAI,EAAE,CAAC,EACP,OAAO,EAAE,sBAAsB,GAC9B,OAAO,CAAC,CAAC,CAAC,CA0BZ"}
|
package/dist/warnings.js
ADDED
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { toArrayLocation, rootLocation } from "./utils/toArrayLocation.js";
|
|
3
|
+
import { notNullOrUndefined } from "./utils/notNullOrUndefined.js";
|
|
4
|
+
export const warnings = Object.freeze({
|
|
5
|
+
"parsing-error": {
|
|
6
|
+
i18n: "sast_warnings.parsing_error",
|
|
7
|
+
severity: "Information"
|
|
8
|
+
},
|
|
9
|
+
"unsafe-import": {
|
|
10
|
+
i18n: "sast_warnings.unsafe_import",
|
|
11
|
+
severity: "Warning"
|
|
12
|
+
},
|
|
13
|
+
"unsafe-regex": {
|
|
14
|
+
i18n: "sast_warnings.unsafe_regex",
|
|
15
|
+
severity: "Warning"
|
|
16
|
+
},
|
|
17
|
+
"unsafe-stmt": {
|
|
18
|
+
code: "unsafe-stmt",
|
|
19
|
+
i18n: "sast_warnings.unsafe_stmt",
|
|
20
|
+
severity: "Warning"
|
|
21
|
+
},
|
|
22
|
+
"encoded-literal": {
|
|
23
|
+
i18n: "sast_warnings.encoded_literal",
|
|
24
|
+
severity: "Information"
|
|
25
|
+
},
|
|
26
|
+
"short-identifiers": {
|
|
27
|
+
i18n: "sast_warnings.short_identifiers",
|
|
28
|
+
severity: "Warning"
|
|
29
|
+
},
|
|
30
|
+
"suspicious-literal": {
|
|
31
|
+
i18n: "sast_warnings.suspicious_literal",
|
|
32
|
+
severity: "Warning"
|
|
33
|
+
},
|
|
34
|
+
"suspicious-file": {
|
|
35
|
+
i18n: "sast_warnings.suspicious_file",
|
|
36
|
+
severity: "Critical",
|
|
37
|
+
experimental: false
|
|
38
|
+
},
|
|
39
|
+
"obfuscated-code": {
|
|
40
|
+
i18n: "sast_warnings.obfuscated_code",
|
|
41
|
+
severity: "Critical",
|
|
42
|
+
experimental: true
|
|
43
|
+
},
|
|
44
|
+
"weak-crypto": {
|
|
45
|
+
i18n: "sast_warnings.weak_crypto",
|
|
46
|
+
severity: "Information",
|
|
47
|
+
experimental: false
|
|
48
|
+
},
|
|
49
|
+
"shady-link": {
|
|
50
|
+
i18n: "sast_warnings.shady_link",
|
|
51
|
+
severity: "Warning",
|
|
52
|
+
experimental: false
|
|
53
|
+
},
|
|
54
|
+
"unsafe-command": {
|
|
55
|
+
i18n: "sast_warnings.unsafe-command",
|
|
56
|
+
severity: "Warning",
|
|
57
|
+
experimental: true
|
|
58
|
+
},
|
|
59
|
+
"synchronous-io": {
|
|
60
|
+
i18n: "sast_warnings.synchronous-io",
|
|
61
|
+
severity: "Warning",
|
|
62
|
+
experimental: true
|
|
63
|
+
},
|
|
64
|
+
"serialize-environment": {
|
|
65
|
+
i18n: "sast_warnings.serialize-environment",
|
|
66
|
+
severity: "Warning",
|
|
67
|
+
experimental: false
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
export function generateWarning(kind, options) {
|
|
71
|
+
const { file = null, value, source = "JS-X-Ray" } = options;
|
|
72
|
+
const location = options.location ?? rootLocation();
|
|
73
|
+
if (kind === "encoded-literal") {
|
|
74
|
+
return {
|
|
75
|
+
kind,
|
|
76
|
+
value,
|
|
77
|
+
location: [toArrayLocation(location)],
|
|
78
|
+
source,
|
|
79
|
+
...warnings[kind]
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
return {
|
|
83
|
+
kind,
|
|
84
|
+
location: toArrayLocation(location),
|
|
85
|
+
source,
|
|
86
|
+
...warnings[kind],
|
|
87
|
+
...(notNullOrUndefined(file) ? { file } : {}),
|
|
88
|
+
...(notNullOrUndefined(value) ? { value } : { value: null })
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=warnings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"warnings.js","sourceRoot":"","sources":["../src/warnings.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EACL,eAAe,EACf,YAAY,EAEb,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAgCnE,MAAM,CAAC,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC;IACpC,eAAe,EAAE;QACf,IAAI,EAAE,6BAA6B;QACnC,QAAQ,EAAE,aAAa;KACxB;IACD,eAAe,EAAE;QACf,IAAI,EAAE,6BAA6B;QACnC,QAAQ,EAAE,SAAS;KACpB;IACD,cAAc,EAAE;QACd,IAAI,EAAE,4BAA4B;QAClC,QAAQ,EAAE,SAAS;KACpB;IACD,aAAa,EAAE;QACb,IAAI,EAAE,aAAa;QACnB,IAAI,EAAE,2BAA2B;QACjC,QAAQ,EAAE,SAAS;KACpB;IACD,iBAAiB,EAAE;QACjB,IAAI,EAAE,+BAA+B;QACrC,QAAQ,EAAE,aAAa;KACxB;IACD,mBAAmB,EAAE;QACnB,IAAI,EAAE,iCAAiC;QACvC,QAAQ,EAAE,SAAS;KACpB;IACD,oBAAoB,EAAE;QACpB,IAAI,EAAE,kCAAkC;QACxC,QAAQ,EAAE,SAAS;KACpB;IACD,iBAAiB,EAAE;QACjB,IAAI,EAAE,+BAA+B;QACrC,QAAQ,EAAE,UAAU;QACpB,YAAY,EAAE,KAAK;KACpB;IACD,iBAAiB,EAAE;QACjB,IAAI,EAAE,+BAA+B;QACrC,QAAQ,EAAE,UAAU;QACpB,YAAY,EAAE,IAAI;KACnB;IACD,aAAa,EAAE;QACb,IAAI,EAAE,2BAA2B;QACjC,QAAQ,EAAE,aAAa;QACvB,YAAY,EAAE,KAAK;KACpB;IACD,YAAY,EAAE;QACZ,IAAI,EAAE,0BAA0B;QAChC,QAAQ,EAAE,SAAS;QACnB,YAAY,EAAE,KAAK;KACpB;IACD,gBAAgB,EAAE;QAChB,IAAI,EAAE,8BAA8B;QACpC,QAAQ,EAAE,SAAS;QACnB,YAAY,EAAE,IAAI;KACnB;IACD,gBAAgB,EAAE;QAChB,IAAI,EAAE,8BAA8B;QACpC,QAAQ,EAAE,SAAS;QACnB,YAAY,EAAE,IAAI;KACnB;IACD,uBAAuB,EAAE;QACvB,IAAI,EAAE,qCAAqC;QAC3C,QAAQ,EAAE,SAAS;QACnB,YAAY,EAAE,KAAK;KACpB;CACF,CAAoF,CAAC;AAStF,MAAM,UAAU,eAAe,CAC7B,IAAO,EACP,OAA+B;IAE/B,MAAM,EACJ,IAAI,GAAG,IAAI,EACX,KAAK,EACL,MAAM,GAAG,UAAU,EACpB,GAAG,OAAO,CAAC;IACZ,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,YAAY,EAAE,CAAC;IAEpD,IAAI,IAAI,KAAK,iBAAiB,EAAE,CAAC;QAC/B,OAAO;YACL,IAAI;YACJ,KAAK;YACL,QAAQ,EAAE,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;YACrC,MAAM;YACN,GAAG,QAAQ,CAAC,IAAI,CAAC;SAClB,CAAC;IACJ,CAAC;IAED,OAAO;QACL,IAAI;QACJ,QAAQ,EAAE,eAAe,CAAC,QAAQ,CAAC;QACnC,MAAM;QACN,GAAG,QAAQ,CAAC,IAAI,CAAC;QACjB,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7C,GAAG,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;KAC7D,CAAC;AACJ,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nodesecure/js-x-ray",
|
|
3
|
-
"version": "9.
|
|
3
|
+
"version": "9.2.0",
|
|
4
4
|
"description": "JavaScript AST XRay analysis",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
@@ -36,10 +36,7 @@
|
|
|
36
36
|
"security"
|
|
37
37
|
],
|
|
38
38
|
"files": [
|
|
39
|
-
"
|
|
40
|
-
"types",
|
|
41
|
-
"index.js",
|
|
42
|
-
"index.d.ts"
|
|
39
|
+
"dist"
|
|
43
40
|
],
|
|
44
41
|
"author": "GENTILHOMME Thomas <gentilhomme.thomas@gmail.com>",
|
|
45
42
|
"license": "MIT",
|
|
@@ -48,7 +45,7 @@
|
|
|
48
45
|
},
|
|
49
46
|
"homepage": "https://github.com/NodeSecure/js-x-ray#readme",
|
|
50
47
|
"dependencies": {
|
|
51
|
-
"@nodesecure/estree-ast-utils": "^4.
|
|
48
|
+
"@nodesecure/estree-ast-utils": "^4.1.0",
|
|
52
49
|
"@nodesecure/sec-literal": "^1.2.0",
|
|
53
50
|
"@nodesecure/tracer": "^2.0.0",
|
|
54
51
|
"digraph-js": "^2.2.3",
|