@nodesecure/js-x-ray 11.5.0 → 12.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (210) hide show
  1. package/dist/AstAnalyser.d.ts +2 -2
  2. package/dist/AstAnalyser.d.ts.map +1 -1
  3. package/dist/AstAnalyser.js +23 -14
  4. package/dist/AstAnalyser.js.map +1 -1
  5. package/dist/CollectableSet.d.ts +11 -6
  6. package/dist/CollectableSet.d.ts.map +1 -1
  7. package/dist/CollectableSet.js +1 -1
  8. package/dist/CollectableSet.js.map +1 -1
  9. package/dist/CollectableSetRegistry.d.ts +1 -1
  10. package/dist/CollectableSetRegistry.d.ts.map +1 -1
  11. package/dist/CollectableSetRegistry.js +0 -2
  12. package/dist/CollectableSetRegistry.js.map +1 -1
  13. package/dist/Deobfuscator.d.ts.map +1 -1
  14. package/dist/Deobfuscator.js +8 -7
  15. package/dist/Deobfuscator.js.map +1 -1
  16. package/dist/EntryFilesAnalyser.d.ts +1 -1
  17. package/dist/EntryFilesAnalyser.d.ts.map +1 -1
  18. package/dist/EntryFilesAnalyser.js +2 -2
  19. package/dist/EntryFilesAnalyser.js.map +1 -1
  20. package/dist/NodeCounter.js +1 -1
  21. package/dist/ProbeRunner.d.ts.map +1 -1
  22. package/dist/ProbeRunner.js +12 -4
  23. package/dist/ProbeRunner.js.map +1 -1
  24. package/dist/SourceFile.d.ts +3 -3
  25. package/dist/SourceFile.d.ts.map +1 -1
  26. package/dist/SourceFile.js +14 -8
  27. package/dist/SourceFile.js.map +1 -1
  28. package/dist/VariableTracer.d.ts +100 -0
  29. package/dist/VariableTracer.d.ts.map +1 -0
  30. package/dist/VariableTracer.js +463 -0
  31. package/dist/VariableTracer.js.map +1 -0
  32. package/dist/contants.d.ts +1 -0
  33. package/dist/contants.d.ts.map +1 -1
  34. package/dist/contants.js +1 -0
  35. package/dist/contants.js.map +1 -1
  36. package/dist/estree/functions/arrayExpression.d.ts +15 -0
  37. package/dist/estree/functions/arrayExpression.d.ts.map +1 -0
  38. package/dist/estree/functions/arrayExpression.js +69 -0
  39. package/dist/estree/functions/arrayExpression.js.map +1 -0
  40. package/dist/estree/functions/concatBinaryExpression.d.ts +15 -0
  41. package/dist/estree/functions/concatBinaryExpression.d.ts.map +1 -0
  42. package/dist/estree/functions/concatBinaryExpression.js +46 -0
  43. package/dist/estree/functions/concatBinaryExpression.js.map +1 -0
  44. package/dist/estree/functions/extractLogicalExpression.d.ts +6 -0
  45. package/dist/estree/functions/extractLogicalExpression.d.ts.map +1 -0
  46. package/dist/estree/functions/extractLogicalExpression.js +18 -0
  47. package/dist/estree/functions/extractLogicalExpression.js.map +1 -0
  48. package/dist/estree/functions/getCallExpressionArguments.d.ts +4 -0
  49. package/dist/estree/functions/getCallExpressionArguments.d.ts.map +1 -0
  50. package/dist/estree/functions/getCallExpressionArguments.js +52 -0
  51. package/dist/estree/functions/getCallExpressionArguments.js.map +1 -0
  52. package/dist/estree/functions/getCallExpressionIdentifier.d.ts +15 -0
  53. package/dist/estree/functions/getCallExpressionIdentifier.d.ts.map +1 -0
  54. package/dist/estree/functions/getCallExpressionIdentifier.js +24 -0
  55. package/dist/estree/functions/getCallExpressionIdentifier.js.map +1 -0
  56. package/dist/estree/functions/getMemberExpressionIdentifier.d.ts +7 -0
  57. package/dist/estree/functions/getMemberExpressionIdentifier.d.ts.map +1 -0
  58. package/dist/estree/functions/getMemberExpressionIdentifier.js +63 -0
  59. package/dist/estree/functions/getMemberExpressionIdentifier.js.map +1 -0
  60. package/dist/estree/functions/getVariableDeclarationIdentifiers.d.ts +13 -0
  61. package/dist/estree/functions/getVariableDeclarationIdentifiers.d.ts.map +1 -0
  62. package/dist/estree/functions/getVariableDeclarationIdentifiers.js +123 -0
  63. package/dist/estree/functions/getVariableDeclarationIdentifiers.js.map +1 -0
  64. package/dist/estree/functions/toLiteral.d.ts +3 -0
  65. package/dist/estree/functions/toLiteral.d.ts.map +1 -0
  66. package/dist/estree/functions/toLiteral.js +4 -0
  67. package/dist/estree/functions/toLiteral.js.map +1 -0
  68. package/dist/estree/index.d.ts +11 -0
  69. package/dist/estree/index.d.ts.map +1 -0
  70. package/dist/estree/index.js +11 -0
  71. package/dist/estree/index.js.map +1 -0
  72. package/dist/estree/literal.d.ts +4 -0
  73. package/dist/estree/literal.d.ts.map +1 -0
  74. package/dist/estree/literal.js +7 -0
  75. package/dist/estree/literal.js.map +1 -0
  76. package/dist/{types/estree.d.ts → estree/types.d.ts} +5 -1
  77. package/dist/estree/types.d.ts.map +1 -0
  78. package/dist/{types/estree.js → estree/types.js} +4 -1
  79. package/dist/estree/types.js.map +1 -0
  80. package/dist/i18n/arabic.d.ts +29 -0
  81. package/dist/i18n/arabic.d.ts.map +1 -0
  82. package/dist/i18n/arabic.js +28 -0
  83. package/dist/i18n/arabic.js.map +1 -0
  84. package/dist/i18n/english.d.ts +1 -0
  85. package/dist/i18n/english.js +2 -1
  86. package/dist/i18n/english.js.map +1 -1
  87. package/dist/i18n/french.d.ts +1 -0
  88. package/dist/i18n/french.js +2 -1
  89. package/dist/i18n/french.js.map +1 -1
  90. package/dist/i18n/turkish.d.ts +29 -0
  91. package/dist/i18n/turkish.d.ts.map +1 -0
  92. package/dist/i18n/turkish.js +28 -0
  93. package/dist/i18n/turkish.js.map +1 -0
  94. package/dist/index.d.ts +3 -1
  95. package/dist/index.d.ts.map +1 -1
  96. package/dist/index.js +3 -1
  97. package/dist/index.js.map +1 -1
  98. package/dist/obfuscators/freejsobfuscator.d.ts +5 -0
  99. package/dist/obfuscators/freejsobfuscator.d.ts.map +1 -1
  100. package/dist/obfuscators/freejsobfuscator.js +1 -3
  101. package/dist/obfuscators/freejsobfuscator.js.map +1 -1
  102. package/dist/{JsSourceParser.d.ts → parsers/JsSourceParser.d.ts} +8 -0
  103. package/dist/parsers/JsSourceParser.d.ts.map +1 -0
  104. package/dist/{JsSourceParser.js → parsers/JsSourceParser.js} +9 -2
  105. package/dist/parsers/JsSourceParser.js.map +1 -0
  106. package/dist/parsers/TsSourceParser.d.ts +7 -0
  107. package/dist/parsers/TsSourceParser.d.ts.map +1 -0
  108. package/dist/parsers/TsSourceParser.js +25 -0
  109. package/dist/parsers/TsSourceParser.js.map +1 -0
  110. package/dist/pipelines/deobfuscate.d.ts.map +1 -1
  111. package/dist/pipelines/deobfuscate.js +1 -2
  112. package/dist/pipelines/deobfuscate.js.map +1 -1
  113. package/dist/probes/data-exfiltration.d.ts.map +1 -1
  114. package/dist/probes/data-exfiltration.js +3 -3
  115. package/dist/probes/data-exfiltration.js.map +1 -1
  116. package/dist/probes/isESMExport.d.ts +1 -1
  117. package/dist/probes/isFetch.d.ts.map +1 -1
  118. package/dist/probes/isFetch.js +2 -2
  119. package/dist/probes/isFetch.js.map +1 -1
  120. package/dist/probes/isImportDeclaration.d.ts +1 -1
  121. package/dist/probes/isLiteral.d.ts +1 -1
  122. package/dist/probes/isLiteral.d.ts.map +1 -1
  123. package/dist/probes/isLiteral.js +1 -3
  124. package/dist/probes/isLiteral.js.map +1 -1
  125. package/dist/probes/isMonkeyPatch.js +2 -1
  126. package/dist/probes/isMonkeyPatch.js.map +1 -1
  127. package/dist/probes/isPrototypePollution.d.ts +18 -0
  128. package/dist/probes/isPrototypePollution.d.ts.map +1 -0
  129. package/dist/probes/isPrototypePollution.js +31 -0
  130. package/dist/probes/isPrototypePollution.js.map +1 -0
  131. package/dist/probes/isRandom.d.ts +15 -0
  132. package/dist/probes/isRandom.d.ts.map +1 -0
  133. package/dist/probes/isRandom.js +29 -0
  134. package/dist/probes/isRandom.js.map +1 -0
  135. package/dist/probes/isRequire/InlinedRequire.d.ts.map +1 -1
  136. package/dist/probes/isRequire/InlinedRequire.js +1 -2
  137. package/dist/probes/isRequire/InlinedRequire.js.map +1 -1
  138. package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts +1 -1
  139. package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts.map +1 -1
  140. package/dist/probes/isRequire/RequireCallExpressionWalker.js +3 -5
  141. package/dist/probes/isRequire/RequireCallExpressionWalker.js.map +1 -1
  142. package/dist/probes/isRequire/isRequire.d.ts.map +1 -1
  143. package/dist/probes/isRequire/isRequire.js +3 -3
  144. package/dist/probes/isRequire/isRequire.js.map +1 -1
  145. package/dist/probes/isSerializeEnv.d.ts.map +1 -1
  146. package/dist/probes/isSerializeEnv.js +2 -2
  147. package/dist/probes/isSerializeEnv.js.map +1 -1
  148. package/dist/probes/isUnsafeCallee.d.ts +4 -3
  149. package/dist/probes/isUnsafeCallee.d.ts.map +1 -1
  150. package/dist/probes/isUnsafeCallee.js +12 -12
  151. package/dist/probes/isUnsafeCallee.js.map +1 -1
  152. package/dist/probes/isUnsafeCommand.js +3 -2
  153. package/dist/probes/isUnsafeCommand.js.map +1 -1
  154. package/dist/probes/isWeakCrypto.js +1 -1
  155. package/dist/probes/sql-injection.js +2 -1
  156. package/dist/probes/sql-injection.js.map +1 -1
  157. package/dist/utils/extractNode.js +1 -1
  158. package/dist/utils/getSubMemberExpressionSegments.d.ts +2 -0
  159. package/dist/utils/getSubMemberExpressionSegments.d.ts.map +1 -0
  160. package/dist/utils/getSubMemberExpressionSegments.js +9 -0
  161. package/dist/utils/getSubMemberExpressionSegments.js.map +1 -0
  162. package/dist/utils/hex.d.ts +14 -0
  163. package/dist/utils/hex.d.ts.map +1 -0
  164. package/dist/utils/hex.js +44 -0
  165. package/dist/utils/hex.js.map +1 -0
  166. package/dist/utils/index.d.ts +9 -0
  167. package/dist/utils/index.d.ts.map +1 -1
  168. package/dist/utils/index.js +9 -0
  169. package/dist/utils/index.js.map +1 -1
  170. package/dist/utils/isEvilIdentifier.d.ts +3 -0
  171. package/dist/utils/isEvilIdentifier.d.ts.map +1 -0
  172. package/dist/utils/isEvilIdentifier.js +11 -0
  173. package/dist/utils/isEvilIdentifier.js.map +1 -0
  174. package/dist/utils/isOneLineExpressionExport.d.ts.map +1 -1
  175. package/dist/utils/isOneLineExpressionExport.js +2 -1
  176. package/dist/utils/isOneLineExpressionExport.js.map +1 -1
  177. package/dist/utils/isStringBase64.d.ts +8 -0
  178. package/dist/utils/isStringBase64.d.ts.map +1 -0
  179. package/dist/utils/isStringBase64.js +18 -0
  180. package/dist/utils/isStringBase64.js.map +1 -0
  181. package/dist/utils/isSvg.d.ts +7 -0
  182. package/dist/utils/isSvg.d.ts.map +1 -0
  183. package/dist/utils/isSvg.js +26 -0
  184. package/dist/utils/isSvg.js.map +1 -0
  185. package/dist/utils/makePrefixRemover.d.ts +2 -0
  186. package/dist/utils/makePrefixRemover.d.ts.map +1 -0
  187. package/dist/utils/makePrefixRemover.js +13 -0
  188. package/dist/utils/makePrefixRemover.js.map +1 -0
  189. package/dist/utils/patterns.d.ts +24 -0
  190. package/dist/utils/patterns.d.ts.map +1 -0
  191. package/dist/utils/patterns.js +77 -0
  192. package/dist/utils/patterns.js.map +1 -0
  193. package/dist/utils/stringSuspicionScore.d.ts +12 -0
  194. package/dist/utils/stringSuspicionScore.d.ts.map +1 -0
  195. package/dist/utils/stringSuspicionScore.js +53 -0
  196. package/dist/utils/stringSuspicionScore.js.map +1 -0
  197. package/dist/utils/stripNodePrefix.d.ts +2 -0
  198. package/dist/utils/stripNodePrefix.d.ts.map +1 -0
  199. package/dist/utils/stripNodePrefix.js +11 -0
  200. package/dist/utils/stripNodePrefix.js.map +1 -0
  201. package/dist/walker/walker.sync.js +1 -1
  202. package/dist/warnings.d.ts +12 -2
  203. package/dist/warnings.d.ts.map +1 -1
  204. package/dist/warnings.js +10 -0
  205. package/dist/warnings.js.map +1 -1
  206. package/package.json +4 -6
  207. package/dist/JsSourceParser.d.ts.map +0 -1
  208. package/dist/JsSourceParser.js.map +0 -1
  209. package/dist/types/estree.d.ts.map +0 -1
  210. package/dist/types/estree.js.map +0 -1
@@ -0,0 +1,8 @@
1
+ export interface Base64Options {
2
+ allowMime?: boolean;
3
+ mimeRequired?: boolean;
4
+ paddingRequired?: boolean;
5
+ allowEmpty?: boolean;
6
+ }
7
+ export declare function isStringBase64(v: string, opts?: Base64Options): boolean;
8
+ //# sourceMappingURL=isStringBase64.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isStringBase64.d.ts","sourceRoot":"","sources":["../../src/utils/isStringBase64.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,wBAAgB,cAAc,CAC5B,CAAC,EAAE,MAAM,EACT,IAAI,GAAE,aAAkB,GACvB,OAAO,CAoBT"}
@@ -0,0 +1,18 @@
1
+ export function isStringBase64(v, opts = {}) {
2
+ if (opts.allowEmpty === false && v === "") {
3
+ return false;
4
+ }
5
+ let regex = "(?:[A-Za-z0-9+\\/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+\\/]{3}=)?";
6
+ const mimeRegex = "(data:\\w+\\/[a-zA-Z\\+\\-\\.]+;base64,)";
7
+ if (opts.mimeRequired === true) {
8
+ regex = mimeRegex + regex;
9
+ }
10
+ else if (opts.allowMime === true) {
11
+ regex = mimeRegex + "?" + regex;
12
+ }
13
+ if (opts.paddingRequired === false) {
14
+ regex = "(?:[A-Za-z0-9+\\/]{4})*(?:[A-Za-z0-9+\\/]{2}(==)?|[A-Za-z0-9+\\/]{3}=?)?";
15
+ }
16
+ return (new RegExp("^" + regex + "$", "gi")).test(v);
17
+ }
18
+ //# sourceMappingURL=isStringBase64.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isStringBase64.js","sourceRoot":"","sources":["../../src/utils/isStringBase64.ts"],"names":[],"mappings":"AAOA,MAAM,UAAU,cAAc,CAC5B,CAAS,EACT,OAAsB,EAAE;IAExB,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QAC1C,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,KAAK,GAAG,oEAAoE,CAAC;IACjF,MAAM,SAAS,GAAG,0CAA0C,CAAC;IAE7D,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE,CAAC;QAC/B,KAAK,GAAG,SAAS,GAAG,KAAK,CAAC;IAC5B,CAAC;SACI,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE,CAAC;QACjC,KAAK,GAAG,SAAS,GAAG,GAAG,GAAG,KAAK,CAAC;IAClC,CAAC;IAED,IAAI,IAAI,CAAC,eAAe,KAAK,KAAK,EAAE,CAAC;QACnC,KAAK,GAAG,0EAA0E,CAAC;IACrF,CAAC;IAED,OAAO,CAAC,IAAI,MAAM,CAAC,GAAG,GAAG,KAAK,GAAG,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACvD,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { ESTree } from "meriyah";
2
+ export declare function isSvg(strOrLiteral: ESTree.Literal | string): boolean;
3
+ /**
4
+ * @description detect if a given string is a svg path or not.
5
+ */
6
+ export declare function isSvgPath(str: string): boolean;
7
+ //# sourceMappingURL=isSvg.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isSvg.d.ts","sourceRoot":"","sources":["../../src/utils/isSvg.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAKtC,wBAAgB,KAAK,CACnB,YAAY,EAAE,MAAM,CAAC,OAAO,GAAG,MAAM,GACpC,OAAO,CAST;AAED;;GAEG;AACH,wBAAgB,SAAS,CACvB,GAAG,EAAE,MAAM,GACV,OAAO,CAST"}
@@ -0,0 +1,26 @@
1
+ // Import Third-party Dependencies
2
+ import isStringSvg from "is-svg";
3
+ // Import Internal Dependencies
4
+ import { toValue } from "../estree/index.js";
5
+ export function isSvg(strOrLiteral) {
6
+ try {
7
+ const value = toValue(strOrLiteral);
8
+ return isStringSvg(value) || isSvgPath(value);
9
+ }
10
+ catch {
11
+ return false;
12
+ }
13
+ }
14
+ /**
15
+ * @description detect if a given string is a svg path or not.
16
+ */
17
+ export function isSvgPath(str) {
18
+ if (typeof str !== "string") {
19
+ return false;
20
+ }
21
+ const trimStr = str.trim();
22
+ return trimStr.length > 4
23
+ && /^[mzlhvcsqta]\s*[-+.0-9][^mlhvzcsqta]+/i.test(trimStr)
24
+ && /[\dz]$/i.test(trimStr);
25
+ }
26
+ //# sourceMappingURL=isSvg.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isSvg.js","sourceRoot":"","sources":["../../src/utils/isSvg.ts"],"names":[],"mappings":"AAAA,kCAAkC;AAClC,OAAO,WAAW,MAAM,QAAQ,CAAC;AAGjC,+BAA+B;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAE7C,MAAM,UAAU,KAAK,CACnB,YAAqC;IAErC,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;QAEpC,OAAO,WAAW,CAAC,KAAK,CAAC,IAAI,SAAS,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IACD,MAAM,CAAC;QACL,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,SAAS,CACvB,GAAW;IAEX,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC5B,OAAO,KAAK,CAAC;IACf,CAAC;IACD,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;IAE3B,OAAO,OAAO,CAAC,MAAM,GAAG,CAAC;WACpB,yCAAyC,CAAC,IAAI,CAAC,OAAO,CAAC;WACvD,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AAC/B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function makePrefixRemover(prefixes: Iterable<string>): (expr: string) => string;
2
+ //# sourceMappingURL=makePrefixRemover.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"makePrefixRemover.d.ts","sourceRoot":"","sources":["../../src/utils/makePrefixRemover.ts"],"names":[],"mappings":"AACA,wBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,QAAQ,CAAC,MAAM,CAAC,GACzB,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,CAe1B"}
@@ -0,0 +1,13 @@
1
+ export function makePrefixRemover(prefixes) {
2
+ return (expr) => {
3
+ if (!expr.includes(".")) {
4
+ return expr;
5
+ }
6
+ const matchedPrefix = Array.from(prefixes)
7
+ .find((globalId) => expr.startsWith(globalId));
8
+ return matchedPrefix ?
9
+ expr.slice(matchedPrefix.length + 1) :
10
+ expr;
11
+ };
12
+ }
13
+ //# sourceMappingURL=makePrefixRemover.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"makePrefixRemover.js","sourceRoot":"","sources":["../../src/utils/makePrefixRemover.ts"],"names":[],"mappings":"AACA,MAAM,UAAU,iBAAiB,CAC/B,QAA0B;IAE1B,OAAO,CACL,IAAI,EACJ,EAAE;QACF,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC;aACvC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEjD,OAAO,aAAa,CAAC,CAAC;YACpB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;YACtC,IAAI,CAAC;IACT,CAAC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,24 @@
1
+ import type { ESTree } from "meriyah";
2
+ /**
3
+ * @description get the common string prefix (at the start) pattern
4
+ * @example
5
+ * commonStringPrefix("boo", "foo"); // null
6
+ * commonStringPrefix("bromance", "brother"); // "bro"
7
+ */
8
+ export declare function commonStringPrefix(leftAnyValue: ESTree.Literal | string, rightAnyValue: ESTree.Literal | string): string | null;
9
+ /**
10
+ * @description get the common string suffixes (at the end) pattern
11
+ * @param {!string} leftStr
12
+ * @param {!string} rightStr
13
+ * @returns {string | null}
14
+ *
15
+ * @example
16
+ * commonStringSuffix("boo", "foo"); // oo
17
+ * commonStringSuffix("bromance", "brother"); // null
18
+ */
19
+ export declare function commonStringSuffix(leftStr: string, rightStr: string): string | null;
20
+ export declare function commonHexadecimalPrefix(identifiersArray: string[]): {
21
+ oneTimeOccurence: number;
22
+ prefix: Record<string, number>;
23
+ };
24
+ //# sourceMappingURL=patterns.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"patterns.d.ts","sourceRoot":"","sources":["../../src/utils/patterns.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAKtC;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAChC,YAAY,EAAE,MAAM,CAAC,OAAO,GAAG,MAAM,EACrC,aAAa,EAAE,MAAM,CAAC,OAAO,GAAG,MAAM,GACrC,MAAM,GAAG,IAAI,CAiBf;AAQD;;;;;;;;;GASG;AACH,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,MAAM,GACf,MAAM,GAAG,IAAI,CAOf;AAED,wBAAgB,uBAAuB,CACrC,gBAAgB,EAAE,MAAM,EAAE,GACzB;IAAE,gBAAgB,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAAE,CAuC/D"}
@@ -0,0 +1,77 @@
1
+ // Import Third-party Dependencies
2
+ import FrequencySet from "frequency-set";
3
+ // Import Internal Dependencies
4
+ import { toValue } from "../estree/index.js";
5
+ /**
6
+ * @description get the common string prefix (at the start) pattern
7
+ * @example
8
+ * commonStringPrefix("boo", "foo"); // null
9
+ * commonStringPrefix("bromance", "brother"); // "bro"
10
+ */
11
+ export function commonStringPrefix(leftAnyValue, rightAnyValue) {
12
+ const leftStr = toValue(leftAnyValue);
13
+ const rightStr = toValue(rightAnyValue);
14
+ // The length of leftStr cannot be greater than that rightStr
15
+ const minLen = leftStr.length > rightStr.length ? rightStr.length : leftStr.length;
16
+ let commonStr = "";
17
+ for (let id = 0; id < minLen; id++) {
18
+ if (leftStr.charAt(id) !== rightStr.charAt(id)) {
19
+ break;
20
+ }
21
+ commonStr += leftStr.charAt(id);
22
+ }
23
+ return commonStr === "" ? null : commonStr;
24
+ }
25
+ function reverseString(string) {
26
+ return string.split("").reverse().join("");
27
+ }
28
+ /**
29
+ * @description get the common string suffixes (at the end) pattern
30
+ * @param {!string} leftStr
31
+ * @param {!string} rightStr
32
+ * @returns {string | null}
33
+ *
34
+ * @example
35
+ * commonStringSuffix("boo", "foo"); // oo
36
+ * commonStringSuffix("bromance", "brother"); // null
37
+ */
38
+ export function commonStringSuffix(leftStr, rightStr) {
39
+ const commonPrefix = commonStringPrefix(reverseString(leftStr), reverseString(rightStr));
40
+ return commonPrefix === null ? null : reverseString(commonPrefix);
41
+ }
42
+ export function commonHexadecimalPrefix(identifiersArray) {
43
+ if (!Array.isArray(identifiersArray)) {
44
+ throw new TypeError("identifiersArray must be an Array");
45
+ }
46
+ const prefix = new FrequencySet();
47
+ mainLoop: for (const value of identifiersArray.slice().sort()) {
48
+ for (const [cp, count] of prefix) {
49
+ const commonStr = commonStringPrefix(value, cp);
50
+ if (commonStr === null) {
51
+ continue;
52
+ }
53
+ if (commonStr === cp || commonStr.startsWith(cp)) {
54
+ prefix.add(cp);
55
+ }
56
+ else if (cp.startsWith(commonStr)) {
57
+ prefix.delete(cp);
58
+ prefix.add(commonStr, count + 1);
59
+ }
60
+ continue mainLoop;
61
+ }
62
+ prefix.add(value);
63
+ }
64
+ // We remove one-time occurences (because they are normal variables)
65
+ let oneTimeOccurence = 0;
66
+ for (const [key, value] of prefix.entries()) {
67
+ if (value === 1) {
68
+ prefix.delete(key);
69
+ oneTimeOccurence++;
70
+ }
71
+ }
72
+ return {
73
+ oneTimeOccurence,
74
+ prefix: Object.fromEntries(prefix)
75
+ };
76
+ }
77
+ //# sourceMappingURL=patterns.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"patterns.js","sourceRoot":"","sources":["../../src/utils/patterns.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @description Get the number of unique chars in a given string
3
+ * @param {!string} str string
4
+ * @param {string[]} [charsToExclude=[]]
5
+ * @returns {number}
6
+ */
7
+ export declare function stringCharDiversity(str: string, charsToExclude?: Iterable<string>): number;
8
+ /**
9
+ * @description Analyze a given string an give it a suspicion score (higher than 1 or 2 mean that the string is highly suspect).
10
+ */
11
+ export declare function stringSuspicionScore(str: string): number;
12
+ //# sourceMappingURL=stringSuspicionScore.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stringSuspicionScore.d.ts","sourceRoot":"","sources":["../../src/utils/stringSuspicionScore.ts"],"names":[],"mappings":"AAsBA;;;;;GAKG;AACH,wBAAgB,mBAAmB,CACjC,GAAG,EAAE,MAAM,EACX,cAAc,GAAE,QAAQ,CAAC,MAAM,CAAM,GACpC,MAAM,CAKR;AAQD;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,GAAG,EAAE,MAAM,GACV,MAAM,CAmBR"}
@@ -0,0 +1,53 @@
1
+ // CONSTANTS
2
+ const kLenSegmenter = new Intl.Segmenter();
3
+ /**
4
+ * Note: this is not a perfect way to calculate the width of a string, but it should be good enough for our use case.
5
+ * We are not trying to be 100% accurate, but rather to have a rough estimate of the width of a string.
6
+ */
7
+ function stringLength(string) {
8
+ if (string === "") {
9
+ return 0;
10
+ }
11
+ let length = 0;
12
+ for (const _ of kLenSegmenter.segment(string)) {
13
+ length++;
14
+ }
15
+ return length;
16
+ }
17
+ /**
18
+ * @description Get the number of unique chars in a given string
19
+ * @param {!string} str string
20
+ * @param {string[]} [charsToExclude=[]]
21
+ * @returns {number}
22
+ */
23
+ export function stringCharDiversity(str, charsToExclude = []) {
24
+ const data = new Set(str);
25
+ [...charsToExclude].forEach((char) => data.delete(char));
26
+ return data.size;
27
+ }
28
+ // ---
29
+ const kMaxSafeStringLen = 45;
30
+ const kMaxSafeStringCharDiversity = 70;
31
+ const kMinUnsafeStringLenThreshold = 200;
32
+ const kScoreStringLengthThreshold = 750;
33
+ /**
34
+ * @description Analyze a given string an give it a suspicion score (higher than 1 or 2 mean that the string is highly suspect).
35
+ */
36
+ export function stringSuspicionScore(str) {
37
+ const strLen = stringLength(str);
38
+ if (strLen < kMaxSafeStringLen) {
39
+ return 0;
40
+ }
41
+ const includeSpace = str.includes(" ");
42
+ const includeSpaceAtStart = includeSpace ?
43
+ str.slice(0, kMaxSafeStringLen).includes(" ") :
44
+ false;
45
+ let suspectScore = includeSpaceAtStart ? 0 : 1;
46
+ if (strLen > kMinUnsafeStringLenThreshold) {
47
+ suspectScore += Math.ceil(strLen / kScoreStringLengthThreshold);
48
+ }
49
+ return stringCharDiversity(str) >= kMaxSafeStringCharDiversity ?
50
+ suspectScore + 2 :
51
+ suspectScore;
52
+ }
53
+ //# sourceMappingURL=stringSuspicionScore.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stringSuspicionScore.js","sourceRoot":"","sources":["../../src/utils/stringSuspicionScore.ts"],"names":[],"mappings":"AAAA,YAAY;AACZ,MAAM,aAAa,GAAG,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;AAE3C;;;GAGG;AACH,SAAS,YAAY,CACnB,MAAc;IAEd,IAAI,MAAM,KAAK,EAAE,EAAE,CAAC;QAClB,OAAO,CAAC,CAAC;IACX,CAAC;IAED,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,KAAK,MAAM,CAAC,IAAI,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;QAC9C,MAAM,EAAE,CAAC;IACX,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,mBAAmB,CACjC,GAAW,EACX,iBAAmC,EAAE;IAErC,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC,GAAG,cAAc,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IAEzD,OAAO,IAAI,CAAC,IAAI,CAAC;AACnB,CAAC;AAED,MAAM;AACN,MAAM,iBAAiB,GAAG,EAAE,CAAC;AAC7B,MAAM,2BAA2B,GAAG,EAAE,CAAC;AACvC,MAAM,4BAA4B,GAAG,GAAG,CAAC;AACzC,MAAM,2BAA2B,GAAG,GAAG,CAAC;AAExC;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAClC,GAAW;IAEX,MAAM,MAAM,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC;IACjC,IAAI,MAAM,GAAG,iBAAiB,EAAE,CAAC;QAC/B,OAAO,CAAC,CAAC;IACX,CAAC;IAED,MAAM,YAAY,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IACvC,MAAM,mBAAmB,GAAG,YAAY,CAAC,CAAC;QACxC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAC/C,KAAK,CAAC;IAER,IAAI,YAAY,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,IAAI,MAAM,GAAG,4BAA4B,EAAE,CAAC;QAC1C,YAAY,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,2BAA2B,CAAC,CAAC;IAClE,CAAC;IAED,OAAO,mBAAmB,CAAC,GAAG,CAAC,IAAI,2BAA2B,CAAC,CAAC;QAC9D,YAAY,GAAG,CAAC,CAAC,CAAC;QAClB,YAAY,CAAC;AACjB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function stripNodePrefix(value: any): any;
2
+ //# sourceMappingURL=stripNodePrefix.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stripNodePrefix.d.ts","sourceRoot":"","sources":["../../src/utils/stripNodePrefix.ts"],"names":[],"mappings":"AAGA,wBAAgB,eAAe,CAAC,KAAK,EAAE,GAAG,GAAG,GAAG,CAQ/C"}
@@ -0,0 +1,11 @@
1
+ // CONSTANTS
2
+ const kNodeModulePrefix = "node:";
3
+ export function stripNodePrefix(value) {
4
+ if (typeof value !== "string") {
5
+ return value;
6
+ }
7
+ return value.startsWith(kNodeModulePrefix) ?
8
+ value.slice(kNodeModulePrefix.length) :
9
+ value;
10
+ }
11
+ //# sourceMappingURL=stripNodePrefix.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stripNodePrefix.js","sourceRoot":"","sources":["../../src/utils/stripNodePrefix.ts"],"names":[],"mappings":"AAAA,YAAY;AACZ,MAAM,iBAAiB,GAAG,OAAO,CAAC;AAElC,MAAM,UAAU,eAAe,CAAC,KAAU;IACxC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC,CAAC;QAC1C,KAAK,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC;QACvC,KAAK,CAAC;AACV,CAAC"}
@@ -1,5 +1,5 @@
1
1
  // Import Internal Dependencies
2
- import { isNode } from "../types/estree.js";
2
+ import { isNode } from "../estree/types.js";
3
3
  import { WalkerBase } from "./walker.base.js";
4
4
  export class SyncWalker extends WalkerBase {
5
5
  enter;
@@ -1,7 +1,7 @@
1
1
  import type { ESTree } from "meriyah";
2
2
  import { type SourceArrayLocation } from "./utils/toArrayLocation.ts";
3
- export type OptionalWarningName = "synchronous-io" | "log-usage";
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" | "sql-injection" | "monkey-patch" | OptionalWarningName;
3
+ export type OptionalWarningName = "synchronous-io" | "log-usage" | "insecure-random";
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" | "sql-injection" | "monkey-patch" | "insecure-random" | "prototype-pollution" | OptionalWarningName;
5
5
  export interface Warning<T = WarningName> {
6
6
  kind: T | (string & {});
7
7
  file?: string;
@@ -103,6 +103,16 @@ export declare const warnings: Readonly<{
103
103
  severity: "Warning";
104
104
  experimental: false;
105
105
  };
106
+ "insecure-random": {
107
+ i18n: string;
108
+ severity: "Information";
109
+ experimental: false;
110
+ };
111
+ "prototype-pollution": {
112
+ i18n: string;
113
+ severity: "Warning";
114
+ experimental: false;
115
+ };
106
116
  }>;
107
117
  export interface GenerateWarningOptions {
108
118
  location?: ESTree.SourceLocation | null;
@@ -1 +1 @@
1
- {"version":3,"file":"warnings.d.ts","sourceRoot":"","sources":["../src/warnings.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAItC,OAAO,EAGL,KAAK,mBAAmB,EACzB,MAAM,4BAA4B,CAAC;AAEpC,MAAM,MAAM,mBAAmB,GAC3B,gBAAgB,GAChB,WAAW,CAAC;AAEhB,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,eAAe,GACf,cAAc,GACd,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA2FgE,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;IAChB;;OAEG;IACH,QAAQ,CAAC,EAAE,aAAa,GAAG,SAAS,GAAG,UAAU,CAAC;CACnD;AAED,wBAAgB,eAAe,CAAC,CAAC,SAAS,WAAW,EACnD,IAAI,EAAE,CAAC,EACP,OAAO,EAAE,sBAAsB,GAC9B,OAAO,CAAC,CAAC,CAAC,CA4BZ"}
1
+ {"version":3,"file":"warnings.d.ts","sourceRoot":"","sources":["../src/warnings.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAItC,OAAO,EAGL,KAAK,mBAAmB,EACzB,MAAM,4BAA4B,CAAC;AAEpC,MAAM,MAAM,mBAAmB,GAC3B,gBAAgB,GAChB,WAAW,GACX,iBAAiB,CAAC;AAEtB,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,eAAe,GACf,cAAc,GACd,iBAAiB,GACjB,qBAAqB,GACrB,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqGgE,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;IAChB;;OAEG;IACH,QAAQ,CAAC,EAAE,aAAa,GAAG,SAAS,GAAG,UAAU,CAAC;CACnD;AAED,wBAAgB,eAAe,CAAC,CAAC,SAAS,WAAW,EACnD,IAAI,EAAE,CAAC,EACP,OAAO,EAAE,sBAAsB,GAC9B,OAAO,CAAC,CAAC,CAAC,CA4BZ"}
package/dist/warnings.js CHANGED
@@ -91,6 +91,16 @@ export const warnings = Object.freeze({
91
91
  i18n: "sast_warnings.monkey_patch",
92
92
  severity: "Warning",
93
93
  experimental: false
94
+ },
95
+ "insecure-random": {
96
+ i18n: "sast_warnings.insecure_random",
97
+ severity: "Information",
98
+ experimental: false
99
+ },
100
+ "prototype-pollution": {
101
+ i18n: "sast_warnings.prototype_pollution",
102
+ severity: "Warning",
103
+ experimental: false
94
104
  }
95
105
  });
96
106
  export function generateWarning(kind, options) {
@@ -1 +1 @@
1
- {"version":3,"file":"warnings.js","sourceRoot":"","sources":["../src/warnings.ts"],"names":[],"mappings":"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"}
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": "11.5.0",
3
+ "version": "12.0.0",
4
4
  "description": "JavaScript AST XRay analysis",
5
5
  "type": "module",
6
6
  "exports": {
@@ -20,7 +20,7 @@
20
20
  "scripts": {
21
21
  "prepublishOnly": "npm run build",
22
22
  "build": "tsc",
23
- "test-only": "node --test-reporter=spec --test ./test/**/*.spec.ts",
23
+ "test-only": "node --test-reporter=spec --test './test/**/*.spec.ts'",
24
24
  "test": "c8 --all --src ./src -r html npm run test-only",
25
25
  "bench": "node --expose-gc --experimental-strip-types ./benchmark/index.ts"
26
26
  },
@@ -52,13 +52,11 @@
52
52
  },
53
53
  "homepage": "https://github.com/NodeSecure/js-x-ray#readme",
54
54
  "dependencies": {
55
- "@nodesecure/estree-ast-utils": "^4.3.0",
56
- "@nodesecure/sec-literal": "^1.4.0",
57
- "@nodesecure/tracer": "^4.0.0",
58
- "@nodesecure/ts-source-parser": "1.1.0",
55
+ "@typescript-eslint/typescript-estree": "8.53.1",
59
56
  "digraph-js": "2.2.4",
60
57
  "frequency-set": "^2.1.0",
61
58
  "ipaddr.js": "2.3.0",
59
+ "is-svg": "6.1.0",
62
60
  "meriyah": "7.0.0",
63
61
  "safe-regex": "^2.1.1",
64
62
  "ts-pattern": "^5.0.6"
@@ -1 +0,0 @@
1
- {"version":3,"file":"JsSourceParser.d.ts","sourceRoot":"","sources":["../src/JsSourceParser.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,KAAK,MAAM,EAEZ,MAAM,SAAS,CAAC;AAUjB,MAAM,MAAM,uBAAuB,GAAG,WAAW,GAAG;IAClD,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,GAAG,EAAE,MAAM,CAAC,cAAc,CAAC;CAC5B,CAAC;AAEF,MAAM,WAAW,YAAY;IAC3B,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,SAAS,EAAE,CAAC;CAC7D;AAED,qBAAa,cAAe,YAAW,YAAY;IACjD,MAAM,CAAC,cAAc,cAKlB;IAEH,KAAK,CACH,MAAM,EAAE,MAAM,GACb,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;CA4B1B"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"JsSourceParser.js","sourceRoot":"","sources":["../src/JsSourceParser.ts"],"names":[],"mappings":"AAAA,kCAAkC;AAClC,OAAO,EACL,WAAW,EACX,KAAK,EAGN,MAAM,SAAS,CAAC;AAEjB,YAAY;AACZ,MAAM,eAAe,GAAqB;IACxC,IAAI,EAAE,IAAI;IACV,GAAG,EAAE,IAAI;IACT,GAAG,EAAE,IAAI;IACT,GAAG,EAAE,IAAI;CACV,CAAC;AAcF,MAAM,OAAO,cAAc;IACzB,MAAM,CAAC,cAAc,GAAG,IAAI,GAAG,CAAC;QAC9B,KAAK;QACL,MAAM;QACN,MAAM;QACN,MAAM;KACP,CAAC,CAAC;IAEH,KAAK,CACH,MAAc;QAEd,IAAI,CAAC;YACH,MAAM,EAAE,IAAI,EAAE,GAAG,WAAW,CAC1B,MAAM,EACN,eAAe,CAAC,eAAe,CAAC,CACjC,CAAC;YAEF,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAc,EAAE,CAAC;YACtB,MAAM,WAAW,GAAG,KAAgC,CAAC;YACrD,MAAM,eAAe,GAAG,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC,0BAA0B,CAAC,CAAC;YAErF,IAAI,eAAe,EAAE,CAAC;gBACpB,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CACpB,MAAM,EACN;oBACE,GAAG,eAAe,CAAC,eAAe,CAAC;oBACnC,UAAU,EAAE,UAAU;iBACvB,CACF,CAAC;gBAEF,OAAO,IAAI,CAAC;YACd,CAAC;YAED,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC"}
@@ -1 +0,0 @@
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,OAAO,GACb,KAAK,IAAI,MAAM,CAAC,IAAI,CAOtB;AAED,wBAAgB,SAAS,CACvB,IAAI,EAAE,OAAO,GACZ,IAAI,IAAI,OAAO,CAAC,MAAM,CAAC,CAIzB;AAED,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,OAAO,GACZ,IAAI,IAAI,MAAM,CAAC,eAAe,CAchC;AAED,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,OAAO,GACZ,IAAI,IAAI,MAAM,CAAC,cAAc,CAE/B"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"estree.js","sourceRoot":"","sources":["../../src/types/estree.ts"],"names":[],"mappings":"AAWA,MAAM,UAAU,MAAM,CACpB,KAAc;IAEd,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,IAAa;IAEb,OAAO,MAAM,CAAC,IAAI,CAAC;QACjB,IAAI,CAAC,IAAI,KAAK,SAAS;QACvB,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,IAAa;IAEb,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,iBAAiB,EAAE,CAAC;QACrD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACrC,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,CACL,UAAU,CAAC,IAAI,KAAK,iBAAiB;QACrC,OAAO,UAAU,CAAC,KAAK,CAAC,GAAG,KAAK,QAAQ,CACzC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,IAAa;IAEb,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,CAAC;AACxD,CAAC"}