@nodesecure/js-x-ray 9.1.0 → 10.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 +79 -0
- package/dist/AstAnalyser.d.ts.map +1 -0
- package/dist/AstAnalyser.js +183 -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 +45 -0
- package/dist/ProbeRunner.d.ts.map +1 -0
- package/dist/ProbeRunner.js +136 -0
- package/dist/ProbeRunner.js.map +1 -0
- package/dist/SourceFile.d.ts +26 -0
- package/dist/SourceFile.d.ts.map +1 -0
- package/dist/SourceFile.js +108 -0
- package/dist/SourceFile.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/{src/index.ts → dist/index.js} +2 -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/pipelines/Runner.class.d.ts +11 -0
- package/dist/pipelines/Runner.class.d.ts.map +1 -0
- package/dist/pipelines/Runner.class.js +20 -0
- package/dist/pipelines/Runner.class.js.map +1 -0
- package/dist/pipelines/deobfuscate.d.ts +8 -0
- package/dist/pipelines/deobfuscate.d.ts.map +1 -0
- package/dist/pipelines/deobfuscate.js +33 -0
- package/dist/pipelines/deobfuscate.js.map +1 -0
- package/dist/pipelines/index.d.ts +8 -0
- package/dist/pipelines/index.d.ts.map +1 -0
- package/dist/pipelines/index.js +8 -0
- package/dist/pipelines/index.js.map +1 -0
- package/dist/probes/data-exfiltration.d.ts +19 -0
- package/dist/probes/data-exfiltration.d.ts.map +1 -0
- package/dist/probes/data-exfiltration.js +84 -0
- package/dist/probes/data-exfiltration.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 +26 -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 +92 -0
- package/dist/probes/isRequire/RequireCallExpressionWalker.js.map +1 -0
- package/dist/probes/isRequire/isRequire.d.ts +15 -0
- package/dist/probes/isRequire/isRequire.d.ts.map +1 -0
- package/dist/probes/isRequire/isRequire.js +136 -0
- package/dist/probes/isRequire/isRequire.js.map +1 -0
- package/dist/probes/isSerializeEnv.d.ts +22 -0
- package/dist/probes/isSerializeEnv.d.ts.map +1 -0
- package/dist/probes/isSerializeEnv.js +68 -0
- package/dist/probes/isSerializeEnv.js.map +1 -0
- package/dist/probes/isSyncIO.d.ts +14 -0
- package/dist/probes/isSyncIO.d.ts.map +1 -0
- package/dist/probes/isSyncIO.js +73 -0
- package/dist/probes/isSyncIO.js.map +1 -0
- package/dist/probes/isUnsafeCallee.d.ts +19 -0
- package/dist/probes/isUnsafeCallee.d.ts.map +1 -0
- package/dist/probes/isUnsafeCallee.js +58 -0
- package/dist/probes/isUnsafeCallee.js.map +1 -0
- package/dist/probes/isUnsafeCommand.d.ts +21 -0
- package/dist/probes/isUnsafeCommand.d.ts.map +1 -0
- package/dist/probes/isUnsafeCommand.js +110 -0
- package/dist/probes/isUnsafeCommand.js.map +1 -0
- package/dist/probes/isWeakCrypto.d.ts +14 -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 +12 -0
- package/dist/types/estree.d.ts.map +1 -0
- package/dist/types/estree.js +26 -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/walker/index.d.ts +9 -0
- package/dist/walker/index.d.ts.map +1 -0
- package/dist/walker/index.js +10 -0
- package/dist/walker/index.js.map +1 -0
- package/dist/walker/walker.base.d.ts +17 -0
- package/dist/walker/walker.base.d.ts.map +1 -0
- package/dist/walker/walker.base.js +45 -0
- package/dist/walker/walker.base.js.map +1 -0
- package/dist/walker/walker.sync.d.ts +15 -0
- package/dist/walker/walker.sync.d.ts.map +1 -0
- package/dist/walker/walker.sync.js +87 -0
- package/dist/walker/walker.sync.js.map +1 -0
- package/dist/warnings.d.ts +93 -0
- package/dist/warnings.d.ts.map +1 -0
- package/dist/warnings.js +96 -0
- package/dist/warnings.js.map +1 -0
- package/package.json +4 -8
- 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,17 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
export interface WalkerContext {
|
|
3
|
+
skip: () => void;
|
|
4
|
+
remove: () => void;
|
|
5
|
+
replace: (node: ESTree.Node | void) => void;
|
|
6
|
+
replaceAndSkip: (node: ESTree.Node | void) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare class WalkerBase {
|
|
9
|
+
should_skip: boolean;
|
|
10
|
+
should_remove: boolean;
|
|
11
|
+
replacement: ESTree.Node | null;
|
|
12
|
+
context: WalkerContext;
|
|
13
|
+
constructor();
|
|
14
|
+
replace(parent: ESTree.Node | null | undefined, prop: string | number | symbol | null | undefined, index: number | null | undefined, node: ESTree.Node): void;
|
|
15
|
+
remove(parent: ESTree.Node | null | undefined, prop: string | number | symbol | null | undefined, index: number | null | undefined): void;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=walker.base.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"walker.base.d.ts","sourceRoot":"","sources":["../../src/walker/walker.base.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEtC,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,KAAK,IAAI,CAAC;IAC5C,cAAc,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,KAAK,IAAI,CAAC;CACpD;AAED,qBAAa,UAAU;IACrB,WAAW,UAAS;IACpB,aAAa,UAAS;IACtB,WAAW,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,CAAQ;IACvC,OAAO,EAAE,aAAa,CAAC;;IAqBvB,OAAO,CACL,MAAM,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,GAAG,SAAS,EACtC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,SAAS,EACjD,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EAChC,IAAI,EAAE,MAAM,CAAC,IAAI;IAYnB,MAAM,CACJ,MAAM,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,GAAG,SAAS,EACtC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,SAAS,EACjD,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS;CAWnC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
export class WalkerBase {
|
|
2
|
+
should_skip = false;
|
|
3
|
+
should_remove = false;
|
|
4
|
+
replacement = null;
|
|
5
|
+
context;
|
|
6
|
+
constructor() {
|
|
7
|
+
this.context = {
|
|
8
|
+
skip: () => (this.should_skip = true),
|
|
9
|
+
remove: () => (this.should_remove = true),
|
|
10
|
+
replace: (node) => {
|
|
11
|
+
if (node !== undefined) {
|
|
12
|
+
this.replacement = node;
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
replaceAndSkip: (node) => {
|
|
16
|
+
this.should_skip = true;
|
|
17
|
+
if (node !== undefined) {
|
|
18
|
+
this.replacement = node;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
// eslint-disable-next-line max-params
|
|
24
|
+
replace(parent, prop, index, node) {
|
|
25
|
+
if (parent && prop) {
|
|
26
|
+
if (index === null) {
|
|
27
|
+
parent[prop] = node;
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
parent[prop][index] = node;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
remove(parent, prop, index) {
|
|
35
|
+
if (parent && prop) {
|
|
36
|
+
if (index !== null && index !== undefined) {
|
|
37
|
+
parent[prop].splice(index, 1);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
delete parent[prop];
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=walker.base.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"walker.base.js","sourceRoot":"","sources":["../../src/walker/walker.base.ts"],"names":[],"mappings":"AAUA,MAAM,OAAO,UAAU;IACrB,WAAW,GAAG,KAAK,CAAC;IACpB,aAAa,GAAG,KAAK,CAAC;IACtB,WAAW,GAAuB,IAAI,CAAC;IACvC,OAAO,CAAgB;IAEvB;QACE,IAAI,CAAC,OAAO,GAAG;YACb,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACrC,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YACzC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;gBAChB,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;oBACvB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBAC1B,CAAC;YACH,CAAC;YACD,cAAc,EAAE,CAAC,IAAI,EAAE,EAAE;gBACvB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBACxB,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;oBACvB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBAC1B,CAAC;YACH,CAAC;SACF,CAAC;IACJ,CAAC;IAED,sCAAsC;IACtC,OAAO,CACL,MAAsC,EACtC,IAAiD,EACjD,KAAgC,EAChC,IAAiB;QAEjB,IAAI,MAAM,IAAI,IAAI,EAAE,CAAC;YACnB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;gBACnB,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;YACtB,CAAC;iBACI,CAAC;gBACJ,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,CACJ,MAAsC,EACtC,IAAiD,EACjD,KAAgC;QAEhC,IAAI,MAAM,IAAI,IAAI,EAAE,CAAC;YACnB,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;gBAC1C,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAChC,CAAC;iBACI,CAAC;gBACJ,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC;YACtB,CAAC;QACH,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ESTree } from "meriyah";
|
|
2
|
+
import { WalkerBase, type WalkerContext } from "./walker.base.js";
|
|
3
|
+
export type SyncHandler = (this: WalkerContext, node: ESTree.Node, context: SyncWalkerVisitorContext) => void;
|
|
4
|
+
export interface SyncWalkerVisitorContext {
|
|
5
|
+
parent: ESTree.Node | null;
|
|
6
|
+
prop?: string | number;
|
|
7
|
+
index?: number | null;
|
|
8
|
+
}
|
|
9
|
+
export declare class SyncWalker extends WalkerBase {
|
|
10
|
+
enter: SyncHandler | undefined;
|
|
11
|
+
leave: SyncHandler | undefined;
|
|
12
|
+
constructor(enter?: SyncHandler, leave?: SyncHandler);
|
|
13
|
+
visit(node: ESTree.Node, options: SyncWalkerVisitorContext): ESTree.Node | null;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=walker.sync.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"walker.sync.d.ts","sourceRoot":"","sources":["../../src/walker/walker.sync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,EAAE,UAAU,EAAE,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAGlE,MAAM,MAAM,WAAW,GAAG,CACxB,IAAI,EAAE,aAAa,EACnB,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,OAAO,EAAE,wBAAwB,KAC9B,IAAI,CAAC;AAEV,MAAM,WAAW,wBAAwB;IACvC,MAAM,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC;IAC3B,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACvB;AAED,qBAAa,UAAW,SAAQ,UAAU;IACxC,KAAK,EAAE,WAAW,GAAG,SAAS,CAAC;IAC/B,KAAK,EAAE,WAAW,GAAG,SAAS,CAAC;gBAG7B,KAAK,CAAC,EAAE,WAAW,EACnB,KAAK,CAAC,EAAE,WAAW;IAOrB,KAAK,CACH,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,OAAO,EAAE,wBAAwB,GAChC,MAAM,CAAC,IAAI,GAAG,IAAI;CA4FtB"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
// Import Internal Dependencies
|
|
2
|
+
import { WalkerBase } from "./walker.base.js";
|
|
3
|
+
import { isNode } from "../types/estree.js";
|
|
4
|
+
export class SyncWalker extends WalkerBase {
|
|
5
|
+
enter;
|
|
6
|
+
leave;
|
|
7
|
+
constructor(enter, leave) {
|
|
8
|
+
super();
|
|
9
|
+
this.enter = enter;
|
|
10
|
+
this.leave = leave;
|
|
11
|
+
}
|
|
12
|
+
visit(node, options) {
|
|
13
|
+
if (!node) {
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
const { parent, prop, index } = options;
|
|
17
|
+
let returnedNode = node;
|
|
18
|
+
if (this.enter) {
|
|
19
|
+
const _should_skip = this.should_skip;
|
|
20
|
+
const _should_remove = this.should_remove;
|
|
21
|
+
const _replacement = this.replacement;
|
|
22
|
+
this.should_skip = false;
|
|
23
|
+
this.should_remove = false;
|
|
24
|
+
this.replacement = null;
|
|
25
|
+
this.enter.call(this.context, returnedNode, { parent, prop, index });
|
|
26
|
+
if (this.replacement) {
|
|
27
|
+
returnedNode = this.replacement;
|
|
28
|
+
this.replace(parent, prop, index, returnedNode);
|
|
29
|
+
}
|
|
30
|
+
if (this.should_remove) {
|
|
31
|
+
this.remove(parent, prop, index);
|
|
32
|
+
}
|
|
33
|
+
const skipped = this.should_skip;
|
|
34
|
+
const removed = this.should_remove;
|
|
35
|
+
this.should_skip = _should_skip;
|
|
36
|
+
this.should_remove = _should_remove;
|
|
37
|
+
this.replacement = _replacement;
|
|
38
|
+
if (skipped) {
|
|
39
|
+
return returnedNode;
|
|
40
|
+
}
|
|
41
|
+
if (removed) {
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
for (const key in returnedNode) {
|
|
46
|
+
if (!Object.hasOwn(returnedNode, key)) {
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
const value = returnedNode[key];
|
|
50
|
+
if (Array.isArray(value)) {
|
|
51
|
+
const nodes = value;
|
|
52
|
+
for (let i = 0; i < nodes.length; i++) {
|
|
53
|
+
const item = nodes[i];
|
|
54
|
+
const removeItem = isNode(item) && !this.visit(item, { parent: returnedNode, prop: key, index: i });
|
|
55
|
+
if (removeItem) {
|
|
56
|
+
i--;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
else if (isNode(value)) {
|
|
61
|
+
this.visit(value, { parent: returnedNode, prop: key, index: null });
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
if (this.leave) {
|
|
65
|
+
const _replacement = this.replacement;
|
|
66
|
+
const _should_remove = this.should_remove;
|
|
67
|
+
this.replacement = null;
|
|
68
|
+
this.should_remove = false;
|
|
69
|
+
this.leave.call(this.context, returnedNode, { parent, prop, index });
|
|
70
|
+
if (this.replacement) {
|
|
71
|
+
returnedNode = this.replacement;
|
|
72
|
+
this.replace(parent, prop, index, returnedNode);
|
|
73
|
+
}
|
|
74
|
+
if (this.should_remove) {
|
|
75
|
+
this.remove(parent, prop, index);
|
|
76
|
+
}
|
|
77
|
+
const removed = this.should_remove;
|
|
78
|
+
this.replacement = _replacement;
|
|
79
|
+
this.should_remove = _should_remove;
|
|
80
|
+
if (removed) {
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return returnedNode;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=walker.sync.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"walker.sync.js","sourceRoot":"","sources":["../../src/walker/walker.sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,93 @@
|
|
|
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" | "data-exfiltration" | 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
|
+
"data-exfiltration": {
|
|
81
|
+
i18n: string;
|
|
82
|
+
severity: "Warning";
|
|
83
|
+
experimental: false;
|
|
84
|
+
};
|
|
85
|
+
}>;
|
|
86
|
+
export interface GenerateWarningOptions {
|
|
87
|
+
location?: ESTree.SourceLocation | null;
|
|
88
|
+
file?: string | null;
|
|
89
|
+
value: string | null;
|
|
90
|
+
source?: string;
|
|
91
|
+
}
|
|
92
|
+
export declare function generateWarning<T extends WarningName>(kind: T, options: GenerateWarningOptions): Warning<T>;
|
|
93
|
+
//# 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,GACnB,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAsEgE,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,96 @@
|
|
|
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
|
+
"data-exfiltration": {
|
|
70
|
+
i18n: "sast_warnings.data_exfiltration",
|
|
71
|
+
severity: "Warning",
|
|
72
|
+
experimental: false
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
export function generateWarning(kind, options) {
|
|
76
|
+
const { file = null, value, source = "JS-X-Ray" } = options;
|
|
77
|
+
const location = options.location ?? rootLocation();
|
|
78
|
+
if (kind === "encoded-literal") {
|
|
79
|
+
return {
|
|
80
|
+
kind,
|
|
81
|
+
value,
|
|
82
|
+
location: [toArrayLocation(location)],
|
|
83
|
+
source,
|
|
84
|
+
...warnings[kind]
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
return {
|
|
88
|
+
kind,
|
|
89
|
+
location: toArrayLocation(location),
|
|
90
|
+
source,
|
|
91
|
+
...warnings[kind],
|
|
92
|
+
...(notNullOrUndefined(file) ? { file } : {}),
|
|
93
|
+
...(notNullOrUndefined(value) ? { value } : { value: null })
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=warnings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"warnings.js","sourceRoot":"","sources":["../src/warnings.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nodesecure/js-x-ray",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "10.0.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,11 +45,10 @@
|
|
|
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.2.0",
|
|
52
49
|
"@nodesecure/sec-literal": "^1.2.0",
|
|
53
|
-
"@nodesecure/tracer": "^
|
|
50
|
+
"@nodesecure/tracer": "^3.0.0",
|
|
54
51
|
"digraph-js": "^2.2.3",
|
|
55
|
-
"estree-walker": "^3.0.1",
|
|
56
52
|
"frequency-set": "^1.0.2",
|
|
57
53
|
"is-minified-code": "^2.0.0",
|
|
58
54
|
"meriyah": "^6.0.0",
|