@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.
Files changed (202) hide show
  1. package/dist/AstAnalyser.d.ts +79 -0
  2. package/dist/AstAnalyser.d.ts.map +1 -0
  3. package/dist/AstAnalyser.js +183 -0
  4. package/dist/AstAnalyser.js.map +1 -0
  5. package/dist/Deobfuscator.d.ts +36 -0
  6. package/dist/Deobfuscator.d.ts.map +1 -0
  7. package/dist/Deobfuscator.js +154 -0
  8. package/dist/Deobfuscator.js.map +1 -0
  9. package/dist/EntryFilesAnalyser.d.ts +20 -0
  10. package/dist/EntryFilesAnalyser.d.ts.map +1 -0
  11. package/dist/EntryFilesAnalyser.js +121 -0
  12. package/dist/EntryFilesAnalyser.js.map +1 -0
  13. package/dist/JsSourceParser.d.ts +18 -0
  14. package/dist/JsSourceParser.d.ts.map +1 -0
  15. package/dist/JsSourceParser.js +38 -0
  16. package/dist/JsSourceParser.js.map +1 -0
  17. package/dist/NodeCounter.d.ts +24 -0
  18. package/dist/NodeCounter.d.ts.map +1 -0
  19. package/dist/NodeCounter.js +62 -0
  20. package/dist/NodeCounter.js.map +1 -0
  21. package/dist/ProbeRunner.d.ts +45 -0
  22. package/dist/ProbeRunner.d.ts.map +1 -0
  23. package/dist/ProbeRunner.js +136 -0
  24. package/dist/ProbeRunner.js.map +1 -0
  25. package/dist/SourceFile.d.ts +26 -0
  26. package/dist/SourceFile.d.ts.map +1 -0
  27. package/dist/SourceFile.js +108 -0
  28. package/dist/SourceFile.js.map +1 -0
  29. package/dist/index.d.ts +7 -0
  30. package/dist/index.d.ts.map +1 -0
  31. package/{src/index.ts → dist/index.js} +2 -0
  32. package/dist/index.js.map +1 -0
  33. package/dist/obfuscators/freejsobfuscator.d.ts +3 -0
  34. package/dist/obfuscators/freejsobfuscator.d.ts.map +1 -0
  35. package/dist/obfuscators/freejsobfuscator.js +10 -0
  36. package/dist/obfuscators/freejsobfuscator.js.map +1 -0
  37. package/dist/obfuscators/jjencode.d.ts +3 -0
  38. package/dist/obfuscators/jjencode.d.ts.map +1 -0
  39. package/dist/obfuscators/jjencode.js +24 -0
  40. package/dist/obfuscators/jjencode.js.map +1 -0
  41. package/dist/obfuscators/jsfuck.d.ts +3 -0
  42. package/dist/obfuscators/jsfuck.d.ts.map +1 -0
  43. package/dist/obfuscators/jsfuck.js +13 -0
  44. package/dist/obfuscators/jsfuck.js.map +1 -0
  45. package/dist/obfuscators/obfuscator-io.d.ts +3 -0
  46. package/dist/obfuscators/obfuscator-io.d.ts.map +1 -0
  47. package/dist/obfuscators/obfuscator-io.js +15 -0
  48. package/dist/obfuscators/obfuscator-io.js.map +1 -0
  49. package/dist/obfuscators/trojan-source.d.ts +2 -0
  50. package/dist/obfuscators/trojan-source.d.ts.map +1 -0
  51. package/dist/obfuscators/trojan-source.js +27 -0
  52. package/dist/obfuscators/trojan-source.js.map +1 -0
  53. package/dist/pipelines/Runner.class.d.ts +11 -0
  54. package/dist/pipelines/Runner.class.d.ts.map +1 -0
  55. package/dist/pipelines/Runner.class.js +20 -0
  56. package/dist/pipelines/Runner.class.js.map +1 -0
  57. package/dist/pipelines/deobfuscate.d.ts +8 -0
  58. package/dist/pipelines/deobfuscate.d.ts.map +1 -0
  59. package/dist/pipelines/deobfuscate.js +33 -0
  60. package/dist/pipelines/deobfuscate.js.map +1 -0
  61. package/dist/pipelines/index.d.ts +8 -0
  62. package/dist/pipelines/index.d.ts.map +1 -0
  63. package/dist/pipelines/index.js +8 -0
  64. package/dist/pipelines/index.js.map +1 -0
  65. package/dist/probes/data-exfiltration.d.ts +19 -0
  66. package/dist/probes/data-exfiltration.d.ts.map +1 -0
  67. package/dist/probes/data-exfiltration.js +84 -0
  68. package/dist/probes/data-exfiltration.js.map +1 -0
  69. package/dist/probes/isArrayExpression.d.ts +21 -0
  70. package/dist/probes/isArrayExpression.d.ts.map +1 -0
  71. package/dist/probes/isArrayExpression.js +27 -0
  72. package/dist/probes/isArrayExpression.js.map +1 -0
  73. package/dist/probes/isBinaryExpression.d.ts +21 -0
  74. package/dist/probes/isBinaryExpression.d.ts.map +1 -0
  75. package/dist/probes/isBinaryExpression.js +54 -0
  76. package/dist/probes/isBinaryExpression.js.map +1 -0
  77. package/dist/probes/isESMExport.d.ts +24 -0
  78. package/dist/probes/isESMExport.d.ts.map +1 -0
  79. package/dist/probes/isESMExport.js +30 -0
  80. package/dist/probes/isESMExport.js.map +1 -0
  81. package/dist/probes/isFetch.d.ts +14 -0
  82. package/dist/probes/isFetch.d.ts.map +1 -0
  83. package/dist/probes/isFetch.js +26 -0
  84. package/dist/probes/isFetch.js.map +1 -0
  85. package/dist/probes/isImportDeclaration.d.ts +26 -0
  86. package/dist/probes/isImportDeclaration.d.ts.map +1 -0
  87. package/dist/probes/isImportDeclaration.js +38 -0
  88. package/dist/probes/isImportDeclaration.js.map +1 -0
  89. package/dist/probes/isLiteral.d.ts +21 -0
  90. package/dist/probes/isLiteral.d.ts.map +1 -0
  91. package/dist/probes/isLiteral.js +66 -0
  92. package/dist/probes/isLiteral.js.map +1 -0
  93. package/dist/probes/isLiteralRegex.d.ts +20 -0
  94. package/dist/probes/isLiteralRegex.d.ts.map +1 -0
  95. package/dist/probes/isLiteralRegex.js +30 -0
  96. package/dist/probes/isLiteralRegex.js.map +1 -0
  97. package/dist/probes/isRegexObject.d.ts +22 -0
  98. package/dist/probes/isRegexObject.d.ts.map +1 -0
  99. package/dist/probes/isRegexObject.js +50 -0
  100. package/dist/probes/isRegexObject.js.map +1 -0
  101. package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts +15 -0
  102. package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts.map +1 -0
  103. package/dist/probes/isRequire/RequireCallExpressionWalker.js +92 -0
  104. package/dist/probes/isRequire/RequireCallExpressionWalker.js.map +1 -0
  105. package/dist/probes/isRequire/isRequire.d.ts +15 -0
  106. package/dist/probes/isRequire/isRequire.d.ts.map +1 -0
  107. package/dist/probes/isRequire/isRequire.js +136 -0
  108. package/dist/probes/isRequire/isRequire.js.map +1 -0
  109. package/dist/probes/isSerializeEnv.d.ts +22 -0
  110. package/dist/probes/isSerializeEnv.d.ts.map +1 -0
  111. package/dist/probes/isSerializeEnv.js +68 -0
  112. package/dist/probes/isSerializeEnv.js.map +1 -0
  113. package/dist/probes/isSyncIO.d.ts +14 -0
  114. package/dist/probes/isSyncIO.d.ts.map +1 -0
  115. package/dist/probes/isSyncIO.js +73 -0
  116. package/dist/probes/isSyncIO.js.map +1 -0
  117. package/dist/probes/isUnsafeCallee.d.ts +19 -0
  118. package/dist/probes/isUnsafeCallee.d.ts.map +1 -0
  119. package/dist/probes/isUnsafeCallee.js +58 -0
  120. package/dist/probes/isUnsafeCallee.js.map +1 -0
  121. package/dist/probes/isUnsafeCommand.d.ts +21 -0
  122. package/dist/probes/isUnsafeCommand.d.ts.map +1 -0
  123. package/dist/probes/isUnsafeCommand.js +110 -0
  124. package/dist/probes/isUnsafeCommand.js.map +1 -0
  125. package/dist/probes/isWeakCrypto.d.ts +14 -0
  126. package/dist/probes/isWeakCrypto.d.ts.map +1 -0
  127. package/dist/probes/isWeakCrypto.js +46 -0
  128. package/dist/probes/isWeakCrypto.js.map +1 -0
  129. package/dist/types/estree.d.ts +12 -0
  130. package/dist/types/estree.d.ts.map +1 -0
  131. package/dist/types/estree.js +26 -0
  132. package/dist/types/estree.js.map +1 -0
  133. package/dist/utils/extractNode.d.ts +5 -0
  134. package/dist/utils/extractNode.d.ts.map +1 -0
  135. package/dist/utils/extractNode.js +13 -0
  136. package/dist/utils/extractNode.js.map +1 -0
  137. package/dist/utils/index.d.ts +5 -0
  138. package/dist/utils/index.d.ts.map +1 -0
  139. package/{src/utils/index.ts → dist/utils/index.js} +1 -0
  140. package/dist/utils/index.js.map +1 -0
  141. package/dist/utils/isOneLineExpressionExport.d.ts +3 -0
  142. package/dist/utils/isOneLineExpressionExport.d.ts.map +1 -0
  143. package/dist/utils/isOneLineExpressionExport.js +49 -0
  144. package/dist/utils/isOneLineExpressionExport.js.map +1 -0
  145. package/dist/utils/notNullOrUndefined.d.ts +2 -0
  146. package/dist/utils/notNullOrUndefined.d.ts.map +1 -0
  147. package/dist/utils/notNullOrUndefined.js +4 -0
  148. package/dist/utils/notNullOrUndefined.js.map +1 -0
  149. package/dist/utils/toArrayLocation.d.ts +5 -0
  150. package/dist/utils/toArrayLocation.d.ts.map +1 -0
  151. package/dist/utils/toArrayLocation.js +14 -0
  152. package/dist/utils/toArrayLocation.js.map +1 -0
  153. package/dist/walker/index.d.ts +9 -0
  154. package/dist/walker/index.d.ts.map +1 -0
  155. package/dist/walker/index.js +10 -0
  156. package/dist/walker/index.js.map +1 -0
  157. package/dist/walker/walker.base.d.ts +17 -0
  158. package/dist/walker/walker.base.d.ts.map +1 -0
  159. package/dist/walker/walker.base.js +45 -0
  160. package/dist/walker/walker.base.js.map +1 -0
  161. package/dist/walker/walker.sync.d.ts +15 -0
  162. package/dist/walker/walker.sync.d.ts.map +1 -0
  163. package/dist/walker/walker.sync.js +87 -0
  164. package/dist/walker/walker.sync.js.map +1 -0
  165. package/dist/warnings.d.ts +93 -0
  166. package/dist/warnings.d.ts.map +1 -0
  167. package/dist/warnings.js +96 -0
  168. package/dist/warnings.js.map +1 -0
  169. package/package.json +4 -8
  170. package/src/AstAnalyser.ts +0 -283
  171. package/src/Deobfuscator.ts +0 -228
  172. package/src/EntryFilesAnalyser.ts +0 -206
  173. package/src/JsSourceParser.ts +0 -77
  174. package/src/NodeCounter.ts +0 -90
  175. package/src/ProbeRunner.ts +0 -167
  176. package/src/SourceFile.ts +0 -226
  177. package/src/obfuscators/freejsobfuscator.ts +0 -17
  178. package/src/obfuscators/jjencode.ts +0 -39
  179. package/src/obfuscators/jsfuck.ts +0 -19
  180. package/src/obfuscators/obfuscator-io.ts +0 -25
  181. package/src/obfuscators/trojan-source.ts +0 -30
  182. package/src/probes/isArrayExpression.ts +0 -41
  183. package/src/probes/isBinaryExpression.ts +0 -74
  184. package/src/probes/isESMExport.ts +0 -50
  185. package/src/probes/isFetch.ts +0 -28
  186. package/src/probes/isImportDeclaration.ts +0 -58
  187. package/src/probes/isLiteral.ts +0 -91
  188. package/src/probes/isLiteralRegex.ts +0 -42
  189. package/src/probes/isRegexObject.ts +0 -71
  190. package/src/probes/isRequire/RequireCallExpressionWalker.ts +0 -142
  191. package/src/probes/isRequire/isRequire.ts +0 -195
  192. package/src/probes/isSerializeEnv.ts +0 -65
  193. package/src/probes/isSyncIO.ts +0 -96
  194. package/src/probes/isUnsafeCallee.ts +0 -89
  195. package/src/probes/isUnsafeCommand.ts +0 -133
  196. package/src/probes/isWeakCrypto.ts +0 -69
  197. package/src/types/estree.ts +0 -35
  198. package/src/utils/extractNode.ts +0 -22
  199. package/src/utils/isOneLineExpressionExport.ts +0 -70
  200. package/src/utils/notNullOrUndefined.ts +0 -5
  201. package/src/utils/toArrayLocation.ts +0 -22
  202. package/src/warnings.ts +0 -146
@@ -0,0 +1,2 @@
1
+ export declare function verify(sourceString: string): boolean;
2
+ //# sourceMappingURL=trojan-source.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trojan-source.d.ts","sourceRoot":"","sources":["../../src/obfuscators/trojan-source.ts"],"names":[],"mappings":"AAmBA,wBAAgB,MAAM,CACpB,YAAY,EAAE,MAAM,GACnB,OAAO,CAQT"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Dangerous Unicode control characters that can be used by hackers
3
+ * to perform trojan source.
4
+ */
5
+ const kUnsafeUnicodeControlCharacters = [
6
+ "\u202A",
7
+ "\u202B",
8
+ "\u202D",
9
+ "\u202E",
10
+ "\u202C",
11
+ "\u2066",
12
+ "\u2067",
13
+ "\u2068",
14
+ "\u2069",
15
+ "\u200E",
16
+ "\u200F",
17
+ "\u061C"
18
+ ];
19
+ export function verify(sourceString) {
20
+ for (const unsafeCharacter of kUnsafeUnicodeControlCharacters) {
21
+ if (sourceString.includes(unsafeCharacter)) {
22
+ return true;
23
+ }
24
+ }
25
+ return false;
26
+ }
27
+ //# sourceMappingURL=trojan-source.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trojan-source.js","sourceRoot":"","sources":["../../src/obfuscators/trojan-source.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,+BAA+B,GAAG;IACtC,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;CACT,CAAC;AAEF,MAAM,UAAU,MAAM,CACpB,YAAoB;IAEpB,KAAK,MAAM,eAAe,IAAI,+BAA+B,EAAE,CAAC;QAC9D,IAAI,YAAY,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;YAC3C,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type { ESTree } from "meriyah";
2
+ export interface Pipeline {
3
+ name: string;
4
+ walk(body: ESTree.Program["body"]): ESTree.Program["body"];
5
+ }
6
+ export declare class PipelineRunner {
7
+ #private;
8
+ constructor(pipelines: Pipeline[]);
9
+ reduce(initialBody: ESTree.Program["body"]): ESTree.Program["body"];
10
+ }
11
+ //# sourceMappingURL=Runner.class.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Runner.class.d.ts","sourceRoot":"","sources":["../../src/pipelines/Runner.class.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEtC,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAC;IAEb,IAAI,CACF,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAC3B,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;CAC3B;AAED,qBAAa,cAAc;;gBAIvB,SAAS,EAAE,QAAQ,EAAE;IAKvB,MAAM,CACJ,WAAW,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAClC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;CAM1B"}
@@ -0,0 +1,20 @@
1
+ export class PipelineRunner {
2
+ #pipelines;
3
+ constructor(pipelines) {
4
+ this.#pipelines = removeDuplicatedPipelines(pipelines);
5
+ }
6
+ reduce(initialBody) {
7
+ return this.#pipelines.reduce((body, pipeline) => pipeline.walk(body), initialBody);
8
+ }
9
+ }
10
+ function removeDuplicatedPipelines(pipelines) {
11
+ const seen = new Set();
12
+ return pipelines.filter((pipeline) => {
13
+ if (seen.has(pipeline.name)) {
14
+ return false;
15
+ }
16
+ seen.add(pipeline.name);
17
+ return true;
18
+ });
19
+ }
20
+ //# sourceMappingURL=Runner.class.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Runner.class.js","sourceRoot":"","sources":["../../src/pipelines/Runner.class.ts"],"names":[],"mappings":"AAWA,MAAM,OAAO,cAAc;IACzB,UAAU,CAAa;IAEvB,YACE,SAAqB;QAErB,IAAI,CAAC,UAAU,GAAG,yBAAyB,CAAC,SAAS,CAAC,CAAC;IACzD,CAAC;IAED,MAAM,CACJ,WAAmC;QAEnC,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAC3B,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EACvC,WAAW,CACZ,CAAC;IACJ,CAAC;CACF;AAED,SAAS,yBAAyB,CAChC,SAAqB;IAErB,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAE/B,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE;QACnC,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC5B,OAAO,KAAK,CAAC;QACf,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAExB,OAAO,IAAI,CAAC;IACd,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { ESTree } from "meriyah";
2
+ import type { Pipeline } from "./Runner.class.js";
3
+ export declare class Deobfuscate implements Pipeline {
4
+ #private;
5
+ name: string;
6
+ walk(body: ESTree.Program["body"]): ESTree.Program["body"];
7
+ }
8
+ //# sourceMappingURL=deobfuscate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deobfuscate.d.ts","sourceRoot":"","sources":["../../src/pipelines/deobfuscate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAMtC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,qBAAa,WAAY,YAAW,QAAQ;;IAC1C,IAAI,SAAiB;IAiBrB,IAAI,CACF,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAC3B,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;CAgB1B"}
@@ -0,0 +1,33 @@
1
+ import { match } from "ts-pattern";
2
+ import { joinArrayExpression } from "@nodesecure/estree-ast-utils";
3
+ // Import Internal Dependencies
4
+ import { walkEnter } from "../walker/index.js";
5
+ export class Deobfuscate {
6
+ name = "deobfuscate";
7
+ #withCallExpression(node) {
8
+ const value = joinArrayExpression(node);
9
+ if (value !== null) {
10
+ return {
11
+ type: "Literal",
12
+ value,
13
+ raw: value
14
+ };
15
+ }
16
+ return void 0;
17
+ }
18
+ walk(body) {
19
+ const self = this;
20
+ walkEnter(body, function walk(node) {
21
+ if (Array.isArray(node)) {
22
+ return;
23
+ }
24
+ match(node)
25
+ .with({ type: "CallExpression" }, (node) => {
26
+ this.replaceAndSkip(self.#withCallExpression(node));
27
+ })
28
+ .otherwise(() => void 0);
29
+ });
30
+ return body;
31
+ }
32
+ }
33
+ //# sourceMappingURL=deobfuscate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deobfuscate.js","sourceRoot":"","sources":["../../src/pipelines/deobfuscate.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAEnE,+BAA+B;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAG/C,MAAM,OAAO,WAAW;IACtB,IAAI,GAAG,aAAa,CAAC;IAErB,mBAAmB,CACjB,IAA2B;QAE3B,MAAM,KAAK,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO;gBACL,IAAI,EAAE,SAAS;gBACf,KAAK;gBACL,GAAG,EAAE,KAAK;aACX,CAAC;QACJ,CAAC;QAED,OAAO,KAAK,CAAC,CAAC;IAChB,CAAC;IAED,IAAI,CACF,IAA4B;QAE5B,MAAM,IAAI,GAAG,IAAI,CAAC;QAClB,SAAS,CAAC,IAAI,EAAE,SAAS,IAAI,CAAC,IAAI;YAChC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;gBACxB,OAAO;YACT,CAAC;YAED,KAAK,CAAC,IAAI,CAAC;iBACR,IAAI,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE;gBACzC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC;YACtD,CAAC,CAAC;iBACD,SAAS,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -0,0 +1,8 @@
1
+ import { Deobfuscate } from "./deobfuscate.js";
2
+ import { PipelineRunner, type Pipeline } from "./Runner.class.js";
3
+ export declare const Pipelines: Readonly<{
4
+ deobfuscate: typeof Deobfuscate;
5
+ }>;
6
+ export { PipelineRunner };
7
+ export type { Pipeline };
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/pipelines/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EACL,cAAc,EACd,KAAK,QAAQ,EACd,MAAM,mBAAmB,CAAC;AAE3B,eAAO,MAAM,SAAS;;EAEwB,CAAC;AAE/C,OAAO,EAAE,cAAc,EAAE,CAAC;AAC1B,YAAY,EAAE,QAAQ,EAAE,CAAC"}
@@ -0,0 +1,8 @@
1
+ // Import Internal Dependencies
2
+ import { Deobfuscate } from "./deobfuscate.js";
3
+ import { PipelineRunner } from "./Runner.class.js";
4
+ export const Pipelines = Object.freeze({
5
+ deobfuscate: Deobfuscate
6
+ });
7
+ export { PipelineRunner };
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/pipelines/index.ts"],"names":[],"mappings":"AAAA,+BAA+B;AAC/B,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EACL,cAAc,EAEf,MAAM,mBAAmB,CAAC;AAE3B,MAAM,CAAC,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC;IACrC,WAAW,EAAE,WAAW;CACzB,CAA6C,CAAC;AAE/C,OAAO,EAAE,cAAc,EAAE,CAAC"}
@@ -0,0 +1,19 @@
1
+ import type { ESTree } from "meriyah";
2
+ import type { ProbeContext } from "../ProbeRunner.js";
3
+ import { type SourceArrayLocation } from "../utils/toArrayLocation.js";
4
+ type DataExfiltrationContextDef = Record<string, SourceArrayLocation[]>;
5
+ declare function validateNode(node: ESTree.Node, ctx: ProbeContext): [boolean, any?];
6
+ declare function main(node: ESTree.CallExpression, ctx: ProbeContext<DataExfiltrationContextDef>): void;
7
+ declare function initialize(ctx: ProbeContext<DataExfiltrationContextDef>): void;
8
+ declare function finalize(ctx: ProbeContext<DataExfiltrationContextDef>): void;
9
+ declare const dateExifiltration: {
10
+ name: string;
11
+ validateNode: typeof validateNode;
12
+ initialize: typeof initialize;
13
+ finalize: typeof finalize;
14
+ main: typeof main;
15
+ breakOnMatch: boolean;
16
+ context: {};
17
+ };
18
+ export default dateExifiltration;
19
+ //# sourceMappingURL=data-exfiltration.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-exfiltration.d.ts","sourceRoot":"","sources":["../../src/probes/data-exfiltration.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAItC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAiC,KAAK,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAUtG,KAAK,0BAA0B,GAAG,MAAM,CAAC,MAAM,EAAE,mBAAmB,EAAE,CAAC,CAAC;AAExE,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,GAAG,EAAE,YAAY,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAmBjB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,MAAM,CAAC,cAAc,EAC3B,GAAG,EAAE,YAAY,CAAC,0BAA0B,CAAC,QAoB9C;AAED,iBAAS,UAAU,CACjB,GAAG,EAAE,YAAY,CAAC,0BAA0B,CAAC,QAmB9C;AAED,iBAAS,QAAQ,CAAC,GAAG,EAAE,YAAY,CAAC,0BAA0B,CAAC,QAO9D;AAED,QAAA,MAAM,iBAAiB;;;;;;;;CAQtB,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
@@ -0,0 +1,84 @@
1
+ // Import Third-party Dependencies
2
+ import { getCallExpressionIdentifier } from "@nodesecure/estree-ast-utils";
3
+ // Import Internal Dependencies
4
+ import { generateWarning } from "../warnings.js";
5
+ import { rootLocation, toArrayLocation } from "../utils/toArrayLocation.js";
6
+ // CONSTANTS
7
+ const kSensitiveMethods = [
8
+ "os.userInfo",
9
+ "os.networkInterfaces",
10
+ "os.cpus",
11
+ "dns.getServers"
12
+ ];
13
+ function validateNode(node, ctx) {
14
+ const tracer = ctx.sourceFile.tracer;
15
+ const id = getCallExpressionIdentifier(node);
16
+ if (id === null) {
17
+ return [false];
18
+ }
19
+ const data = tracer.getDataFromIdentifier(id);
20
+ if (data === null || data.identifierOrMemberExpr !== "JSON.stringify") {
21
+ return [false];
22
+ }
23
+ const castedNode = node;
24
+ if (castedNode.arguments.length === 0) {
25
+ return [false];
26
+ }
27
+ return [true];
28
+ }
29
+ function main(node, ctx) {
30
+ const { sourceFile } = ctx;
31
+ const firstArg = node.arguments[0];
32
+ if (firstArg.type !== "CallExpression") {
33
+ return;
34
+ }
35
+ const id = getCallExpressionIdentifier(firstArg);
36
+ const data = sourceFile.tracer.getDataFromIdentifier(id);
37
+ if (kSensitiveMethods.some((method) => data?.identifierOrMemberExpr === method
38
+ && sourceFile.tracer.importedModules.has(method.split(".")[0]))) {
39
+ const arrayLocation = ctx.context?.[data?.identifierOrMemberExpr];
40
+ if (arrayLocation) {
41
+ arrayLocation.push(toArrayLocation(firstArg.loc ?? rootLocation()));
42
+ }
43
+ else {
44
+ ctx.context[data?.identifierOrMemberExpr] = [toArrayLocation(firstArg.loc ?? rootLocation())];
45
+ }
46
+ }
47
+ }
48
+ function initialize(ctx) {
49
+ const { sourceFile: { tracer } } = ctx;
50
+ tracer
51
+ .trace("JSON.stringify", {
52
+ followConsecutiveAssignment: true
53
+ }).trace("os.userInfo", {
54
+ moduleName: "os",
55
+ followConsecutiveAssignment: true
56
+ }).trace("os.networkInterfaces", {
57
+ moduleName: "os",
58
+ followConsecutiveAssignment: true
59
+ }).trace("os.cpus", {
60
+ moduleName: "os",
61
+ followConsecutiveAssignment: true
62
+ }).trace("dns.getServers", {
63
+ moduleName: "dns",
64
+ followConsecutiveAssignment: true
65
+ });
66
+ }
67
+ function finalize(ctx) {
68
+ const { sourceFile, context } = ctx;
69
+ if (context && Object.keys(context).length > 0) {
70
+ const warning = generateWarning("data-exfiltration", { value: Object.keys(context).join(", ") });
71
+ sourceFile.warnings.push({ ...warning, location: Object.values(context).flat() });
72
+ }
73
+ }
74
+ const dateExifiltration = {
75
+ name: "dataExfiltration",
76
+ validateNode,
77
+ initialize,
78
+ finalize,
79
+ main,
80
+ breakOnMatch: false,
81
+ context: {}
82
+ };
83
+ export default dateExifiltration;
84
+ //# sourceMappingURL=data-exfiltration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-exfiltration.js","sourceRoot":"","sources":["../../src/probes/data-exfiltration.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import type { ESTree } from "meriyah";
2
+ import { SourceFile } from "../SourceFile.js";
3
+ /**
4
+ * @description Search for ArrayExpression AST Node (Commonly known as JS Arrays)
5
+ *
6
+ * @see https://github.com/estree/estree/blob/master/es5.md#arrayexpression
7
+ * @example
8
+ * ["foo", "bar", 1]
9
+ */
10
+ declare function validateNode(node: ESTree.Node): [boolean, any?];
11
+ declare function main(node: ESTree.ArrayExpression, { sourceFile }: {
12
+ sourceFile: SourceFile;
13
+ }): void;
14
+ declare const _default: {
15
+ name: string;
16
+ validateNode: typeof validateNode;
17
+ main: typeof main;
18
+ breakOnMatch: boolean;
19
+ };
20
+ export default _default;
21
+ //# sourceMappingURL=isArrayExpression.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isArrayExpression.d.ts","sourceRoot":"","sources":["../../src/probes/isArrayExpression.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAM9C;;;;;;GAMG;AACH,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAIjB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,MAAM,CAAC,eAAe,EAC5B,EAAE,UAAU,EAAE,EAAE;IAAE,UAAU,EAAE,UAAU,CAAC;CAAE,QAM5C;;;;;;;AAED,wBAKE"}
@@ -0,0 +1,27 @@
1
+ // Import Internal Dependencies
2
+ import { SourceFile } from "../SourceFile.js";
3
+ import { extractNode } from "../utils/index.js";
4
+ // CONSTANTS
5
+ const kLiteralExtractor = extractNode("Literal");
6
+ /**
7
+ * @description Search for ArrayExpression AST Node (Commonly known as JS Arrays)
8
+ *
9
+ * @see https://github.com/estree/estree/blob/master/es5.md#arrayexpression
10
+ * @example
11
+ * ["foo", "bar", 1]
12
+ */
13
+ function validateNode(node) {
14
+ return [
15
+ node.type === "ArrayExpression"
16
+ ];
17
+ }
18
+ function main(node, { sourceFile }) {
19
+ kLiteralExtractor((literalNode) => sourceFile.analyzeLiteral(literalNode, true), node.elements);
20
+ }
21
+ export default {
22
+ name: "isArrayExpression",
23
+ validateNode,
24
+ main,
25
+ breakOnMatch: false
26
+ };
27
+ //# sourceMappingURL=isArrayExpression.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isArrayExpression.js","sourceRoot":"","sources":["../../src/probes/isArrayExpression.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,YAAY;AACZ,MAAM,iBAAiB,GAAG,WAAW,CAAiB,SAAS,CAAC,CAAC;AAEjE;;;;;;GAMG;AACH,SAAS,YAAY,CACnB,IAAiB;IAEjB,OAAO;QACL,IAAI,CAAC,IAAI,KAAK,iBAAiB;KAChC,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CACX,IAA4B,EAC5B,EAAE,UAAU,EAA+B;IAE3C,iBAAiB,CACf,CAAC,WAAW,EAAE,EAAE,CAAC,UAAU,CAAC,cAAc,CAAC,WAAW,EAAE,IAAI,CAAC,EAC7D,IAAI,CAAC,QAAQ,CACd,CAAC;AACJ,CAAC;AAED,eAAe;IACb,IAAI,EAAE,mBAAmB;IACzB,YAAY;IACZ,IAAI;IACJ,YAAY,EAAE,KAAK;CACpB,CAAC"}
@@ -0,0 +1,21 @@
1
+ import type { ESTree } from "meriyah";
2
+ import { SourceFile } from "../SourceFile.js";
3
+ /**
4
+ * @description Search for BinaryExpression AST Node.
5
+ *
6
+ * @see https://github.com/estree/estree/blob/master/es5.md#binaryexpression
7
+ * @example
8
+ * 5 + 5 + 10
9
+ */
10
+ declare function validateNode(node: ESTree.Node): [boolean, any?];
11
+ declare function main(node: ESTree.BinaryExpression, options: {
12
+ sourceFile: SourceFile;
13
+ }): void;
14
+ declare const _default: {
15
+ name: string;
16
+ validateNode: typeof validateNode;
17
+ main: typeof main;
18
+ breakOnMatch: boolean;
19
+ };
20
+ export default _default;
21
+ //# sourceMappingURL=isBinaryExpression.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isBinaryExpression.d.ts","sourceRoot":"","sources":["../../src/probes/isBinaryExpression.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C;;;;;;GAMG;AACH,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAIjB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,MAAM,CAAC,gBAAgB,EAC7B,OAAO,EAAE;IAAE,UAAU,EAAE,UAAU,CAAC;CAAE,QAWrC;;;;;;;AAkCD,wBAKE"}
@@ -0,0 +1,54 @@
1
+ // Import Internal Dependencies
2
+ import { SourceFile } from "../SourceFile.js";
3
+ /**
4
+ * @description Search for BinaryExpression AST Node.
5
+ *
6
+ * @see https://github.com/estree/estree/blob/master/es5.md#binaryexpression
7
+ * @example
8
+ * 5 + 5 + 10
9
+ */
10
+ function validateNode(node) {
11
+ return [
12
+ node.type === "BinaryExpression"
13
+ ];
14
+ }
15
+ function main(node, options) {
16
+ const { sourceFile } = options;
17
+ const [binaryExprDeepness, hasUnaryExpression] = walkBinaryExpression(node);
18
+ if (binaryExprDeepness >= 3 && hasUnaryExpression) {
19
+ sourceFile.deobfuscator.deepBinaryExpression++;
20
+ }
21
+ }
22
+ /**
23
+ * @description Look for suspicious BinaryExpression (read the Obfuscator.io section of the linked G.Doc)
24
+ * @see https://docs.google.com/document/d/11ZrfW0bDQ-kd7Gr_Ixqyk8p3TGvxckmhFH3Z8dFoPhY/edit?usp=sharing
25
+ * @see https://github.com/estree/estree/blob/master/es5.md#unaryexpression
26
+ * @example
27
+ * 0x1*-0x12df+-0x1fb9*-0x1+0x2*-0x66d
28
+ */
29
+ function walkBinaryExpression(expr, level = 1) {
30
+ const [lt, rt] = [expr.left.type, expr.right.type];
31
+ let hasUnaryExpression = lt === "UnaryExpression" || rt === "UnaryExpression";
32
+ let currentLevel = lt === "BinaryExpression" || rt === "BinaryExpression" ?
33
+ level + 1 :
34
+ level;
35
+ for (const currExpr of [expr.left, expr.right]) {
36
+ if (currExpr.type === "BinaryExpression") {
37
+ const [deepLevel, deepHasUnaryExpression] = walkBinaryExpression(currExpr, currentLevel);
38
+ if (deepLevel > currentLevel) {
39
+ currentLevel = deepLevel;
40
+ }
41
+ if (!hasUnaryExpression && deepHasUnaryExpression) {
42
+ hasUnaryExpression = true;
43
+ }
44
+ }
45
+ }
46
+ return [currentLevel, hasUnaryExpression];
47
+ }
48
+ export default {
49
+ name: "isBinaryExpression",
50
+ validateNode,
51
+ main,
52
+ breakOnMatch: false
53
+ };
54
+ //# sourceMappingURL=isBinaryExpression.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isBinaryExpression.js","sourceRoot":"","sources":["../../src/probes/isBinaryExpression.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C;;;;;;GAMG;AACH,SAAS,YAAY,CACnB,IAAiB;IAEjB,OAAO;QACL,IAAI,CAAC,IAAI,KAAK,kBAAkB;KACjC,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CACX,IAA6B,EAC7B,OAAoC;IAEpC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAE/B,MAAM,CACJ,kBAAkB,EAClB,kBAAkB,CACnB,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC;IAC/B,IAAI,kBAAkB,IAAI,CAAC,IAAI,kBAAkB,EAAE,CAAC;QAClD,UAAU,CAAC,YAAY,CAAC,oBAAoB,EAAE,CAAC;IACjD,CAAC;AACH,CAAC;AAED;;;;;;GAMG;AACH,SAAS,oBAAoB,CAC3B,IAA6B,EAC7B,KAAK,GAAG,CAAC;IAET,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACnD,IAAI,kBAAkB,GAAG,EAAE,KAAK,iBAAiB,IAAI,EAAE,KAAK,iBAAiB,CAAC;IAC9E,IAAI,YAAY,GAAG,EAAE,KAAK,kBAAkB,IAAI,EAAE,KAAK,kBAAkB,CAAC,CAAC;QACzE,KAAK,GAAG,CAAC,CAAC,CAAC;QACX,KAAK,CAAC;IAER,KAAK,MAAM,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QAC/C,IAAI,QAAQ,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YACzC,MAAM,CAAC,SAAS,EAAE,sBAAsB,CAAC,GAAG,oBAAoB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;YACzF,IAAI,SAAS,GAAG,YAAY,EAAE,CAAC;gBAC7B,YAAY,GAAG,SAAS,CAAC;YAC3B,CAAC;YACD,IAAI,CAAC,kBAAkB,IAAI,sBAAsB,EAAE,CAAC;gBAClD,kBAAkB,GAAG,IAAI,CAAC;YAC5B,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;AAC5C,CAAC;AAED,eAAe;IACb,IAAI,EAAE,oBAAoB;IAC1B,YAAY;IACZ,IAAI;IACJ,YAAY,EAAE,KAAK;CACpB,CAAC"}
@@ -0,0 +1,24 @@
1
+ import type { ESTree } from "meriyah";
2
+ import { SourceFile } from "../SourceFile.js";
3
+ import type { Literal } from "../types/estree.js";
4
+ /**
5
+ * @description Search for ESM Export
6
+ *
7
+ * @example
8
+ * export { bar } from "./foo.js";
9
+ * export * from "./bar.js";
10
+ */
11
+ declare function validateNode(node: ESTree.Node): [boolean, any?];
12
+ declare function main(node: (ESTree.ExportNamedDeclaration | ESTree.ExportAllDeclaration) & {
13
+ source: Literal<string>;
14
+ }, { sourceFile }: {
15
+ sourceFile: SourceFile;
16
+ }): void;
17
+ declare const _default: {
18
+ name: string;
19
+ validateNode: typeof validateNode;
20
+ main: typeof main;
21
+ breakOnMatch: boolean;
22
+ };
23
+ export default _default;
24
+ //# sourceMappingURL=isESMExport.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isESMExport.d.ts","sourceRoot":"","sources":["../../src/probes/isESMExport.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAElD;;;;;;GAMG;AACH,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAajB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,CACF,MAAM,CAAC,sBAAsB,GAC7B,MAAM,CAAC,oBAAoB,CAC9B,GAAG;IAAE,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;CAAE,EAChC,EAAE,UAAU,EAAE,EAAE;IAAE,UAAU,EAAE,UAAU,CAAC;CAAE,QAM5C;;;;;;;AAED,wBAKE"}
@@ -0,0 +1,30 @@
1
+ // Import Internal Dependencies
2
+ import { SourceFile } from "../SourceFile.js";
3
+ /**
4
+ * @description Search for ESM Export
5
+ *
6
+ * @example
7
+ * export { bar } from "./foo.js";
8
+ * export * from "./bar.js";
9
+ */
10
+ function validateNode(node) {
11
+ if (node.type !== "ExportNamedDeclaration" &&
12
+ node.type !== "ExportAllDeclaration") {
13
+ return [false];
14
+ }
15
+ return [
16
+ node.source !== null &&
17
+ node.source.type === "Literal" &&
18
+ typeof node.source.value === "string"
19
+ ];
20
+ }
21
+ function main(node, { sourceFile }) {
22
+ sourceFile.addDependency(node.source.value, node.loc);
23
+ }
24
+ export default {
25
+ name: "isESMExport",
26
+ validateNode,
27
+ main,
28
+ breakOnMatch: true
29
+ };
30
+ //# sourceMappingURL=isESMExport.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isESMExport.js","sourceRoot":"","sources":["../../src/probes/isESMExport.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAG9C;;;;;;GAMG;AACH,SAAS,YAAY,CACnB,IAAiB;IAEjB,IACE,IAAI,CAAC,IAAI,KAAK,wBAAwB;QACtC,IAAI,CAAC,IAAI,KAAK,sBAAsB,EACpC,CAAC;QACD,OAAO,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,MAAM,KAAK,IAAI;YACpB,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS;YAC9B,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,QAAQ;KACtC,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CACX,IAGgC,EAChC,EAAE,UAAU,EAA+B;IAE3C,UAAU,CAAC,aAAa,CACtB,IAAI,CAAC,MAAM,CAAC,KAAK,EACjB,IAAI,CAAC,GAAG,CACT,CAAC;AACJ,CAAC;AAED,eAAe;IACb,IAAI,EAAE,aAAa;IACnB,YAAY;IACZ,IAAI;IACJ,YAAY,EAAE,IAAI;CACnB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import type { ESTree } from "meriyah";
2
+ import type { ProbeContext } from "../ProbeRunner.js";
3
+ declare function validateNode(node: ESTree.Node, ctx: ProbeContext): [boolean, any?];
4
+ declare function initialize(ctx: ProbeContext): void;
5
+ declare function main(_node: ESTree.Node, { sourceFile }: ProbeContext): void;
6
+ declare const _default: {
7
+ name: string;
8
+ validateNode: typeof validateNode;
9
+ initialize: typeof initialize;
10
+ main: typeof main;
11
+ breakOnMatch: boolean;
12
+ };
13
+ export default _default;
14
+ //# sourceMappingURL=isFetch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isFetch.d.ts","sourceRoot":"","sources":["../../src/probes/isFetch.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEtD,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,GAAG,EAAE,YAAY,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAWjB;AAED,iBAAS,UAAU,CACjB,GAAG,EAAE,YAAY,QAKlB;AAED,iBAAS,IAAI,CACX,KAAK,EAAE,MAAM,CAAC,IAAI,EAClB,EAAE,UAAU,EAAE,EAAE,YAAY,QAG7B;;;;;;;;AAED,wBAME"}
@@ -0,0 +1,26 @@
1
+ // Import Third-party Dependencies
2
+ import { getCallExpressionIdentifier } from "@nodesecure/estree-ast-utils";
3
+ function validateNode(node, ctx) {
4
+ const { tracer } = ctx.sourceFile;
5
+ const id = getCallExpressionIdentifier(node);
6
+ if (id === null) {
7
+ return [false];
8
+ }
9
+ const data = tracer.getDataFromIdentifier(id);
10
+ return [data !== null && data.identifierOrMemberExpr === "fetch"];
11
+ }
12
+ function initialize(ctx) {
13
+ const { sourceFile } = ctx;
14
+ sourceFile.tracer.trace("fetch", { followConsecutiveAssignment: true });
15
+ }
16
+ function main(_node, { sourceFile }) {
17
+ sourceFile.flags.add("fetch");
18
+ }
19
+ export default {
20
+ name: "isFetch",
21
+ validateNode,
22
+ initialize,
23
+ main,
24
+ breakOnMatch: false
25
+ };
26
+ //# sourceMappingURL=isFetch.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isFetch.js","sourceRoot":"","sources":["../../src/probes/isFetch.ts"],"names":[],"mappings":"AAAA,kCAAkC;AAClC,OAAO,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;AAM3E,SAAS,YAAY,CACnB,IAAiB,EACjB,GAAiB;IAEjB,MAAM,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,UAAU,CAAC;IAClC,MAAM,EAAE,GAAG,2BAA2B,CAAC,IAAI,CAAC,CAAC;IAE7C,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;QAChB,OAAO,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC;IAE9C,OAAO,CAAC,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,sBAAsB,KAAK,OAAO,CAAC,CAAC;AACpE,CAAC;AAED,SAAS,UAAU,CACjB,GAAiB;IAEjB,MAAM,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC;IAE3B,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,2BAA2B,EAAE,IAAI,EAAE,CAAC,CAAC;AAC1E,CAAC;AAED,SAAS,IAAI,CACX,KAAkB,EAClB,EAAE,UAAU,EAAgB;IAE5B,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAChC,CAAC;AAED,eAAe;IACb,IAAI,EAAE,SAAS;IACf,YAAY;IACZ,UAAU;IACV,IAAI;IACJ,YAAY,EAAE,KAAK;CACpB,CAAC"}
@@ -0,0 +1,26 @@
1
+ import type { ESTree } from "meriyah";
2
+ import { SourceFile } from "../SourceFile.js";
3
+ import type { Literal } from "../types/estree.js";
4
+ /**
5
+ * @description Search for ESM ImportDeclaration
6
+ * @see https://github.com/estree/estree/blob/master/es2015.md#importdeclaration
7
+ * @example
8
+ * import * as foo from "bar";
9
+ * import fs from "fs";
10
+ * import "make-promises-safe";
11
+ */
12
+ declare function validateNode(node: ESTree.Node): [boolean, any?];
13
+ declare function main(node: (ESTree.ImportDeclaration | ESTree.ImportExpression) & {
14
+ source: Literal<string>;
15
+ }, options: {
16
+ sourceFile: SourceFile;
17
+ }): void;
18
+ declare const _default: {
19
+ name: string;
20
+ validateNode: typeof validateNode;
21
+ main: typeof main;
22
+ breakOnMatch: boolean;
23
+ breakGroup: string;
24
+ };
25
+ export default _default;
26
+ //# sourceMappingURL=isImportDeclaration.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isImportDeclaration.d.ts","sourceRoot":"","sources":["../../src/probes/isImportDeclaration.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAElD;;;;;;;GAOG;AACH,iBAAS,YAAY,CACnB,IAAI,EAAE,MAAM,CAAC,IAAI,GAChB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAUjB;AAED,iBAAS,IAAI,CACX,IAAI,EAAE,CACF,MAAM,CAAC,iBAAiB,GACxB,MAAM,CAAC,gBAAgB,CAC1B,GAAG;IAAE,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;CAAE,EAChC,OAAO,EAAE;IAAE,UAAU,EAAE,UAAU,CAAC;CAAE,QAcrC;;;;;;;;AAED,wBAME"}
@@ -0,0 +1,38 @@
1
+ // Import Internal Dependencies
2
+ import { SourceFile } from "../SourceFile.js";
3
+ import { generateWarning } from "../warnings.js";
4
+ /**
5
+ * @description Search for ESM ImportDeclaration
6
+ * @see https://github.com/estree/estree/blob/master/es2015.md#importdeclaration
7
+ * @example
8
+ * import * as foo from "bar";
9
+ * import fs from "fs";
10
+ * import "make-promises-safe";
11
+ */
12
+ function validateNode(node) {
13
+ if (node.type !== "ImportDeclaration" && node.type !== "ImportExpression") {
14
+ return [false];
15
+ }
16
+ // Note: the source property is the right-side Literal part of the Import
17
+ return [
18
+ node.source.type === "Literal" &&
19
+ typeof node.source.value === "string"
20
+ ];
21
+ }
22
+ function main(node, options) {
23
+ const { sourceFile } = options;
24
+ // Searching for dangerous import "data:text/javascript;..." statement.
25
+ // see: https://2ality.com/2019/10/eval-via-import.html
26
+ if (node.source.value.startsWith("data:text/javascript")) {
27
+ sourceFile.warnings.push(generateWarning("unsafe-import", { value: node.source.value, location: node.loc }));
28
+ }
29
+ sourceFile.addDependency(node.source.value, node.loc);
30
+ }
31
+ export default {
32
+ name: "isImportDeclaration",
33
+ validateNode,
34
+ main,
35
+ breakOnMatch: true,
36
+ breakGroup: "import"
37
+ };
38
+ //# sourceMappingURL=isImportDeclaration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isImportDeclaration.js","sourceRoot":"","sources":["../../src/probes/isImportDeclaration.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAGjD;;;;;;;GAOG;AACH,SAAS,YAAY,CACnB,IAAiB;IAEjB,IAAI,IAAI,CAAC,IAAI,KAAK,mBAAmB,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;QAC1E,OAAO,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;IAED,yEAAyE;IACzE,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS;YAC9B,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,QAAQ;KACtC,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CACX,IAGgC,EAChC,OAAoC;IAEpC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAE/B,uEAAuE;IACvE,uDAAuD;IACvD,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC;QACzD,UAAU,CAAC,QAAQ,CAAC,IAAI,CACtB,eAAe,CACb,eAAe,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,CAClE,CACF,CAAC;IACJ,CAAC;IACD,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;AACxD,CAAC;AAED,eAAe;IACb,IAAI,EAAE,qBAAqB;IAC3B,YAAY;IACZ,IAAI;IACJ,YAAY,EAAE,IAAI;IAClB,UAAU,EAAE,QAAQ;CACrB,CAAC"}
@@ -0,0 +1,21 @@
1
+ import type { ESTree } from "meriyah";
2
+ import { SourceFile } from "../SourceFile.js";
3
+ import type { Literal } from "../types/estree.js";
4
+ /**
5
+ * @description Search for Literal AST Node
6
+ * @see https://github.com/estree/estree/blob/master/es5.md#literal
7
+ * @example
8
+ * "foobar"
9
+ */
10
+ declare function validateNode(node: ESTree.Node): [boolean, any?];
11
+ declare function main(node: Literal<string>, options: {
12
+ sourceFile: SourceFile;
13
+ }): void;
14
+ declare const _default: {
15
+ name: string;
16
+ validateNode: typeof validateNode;
17
+ main: typeof main;
18
+ breakOnMatch: boolean;
19
+ };
20
+ export default _default;
21
+ //# sourceMappingURL=isLiteral.d.ts.map