@nodesecure/js-x-ray 11.5.0 → 12.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AstAnalyser.d.ts +2 -2
- package/dist/AstAnalyser.d.ts.map +1 -1
- package/dist/AstAnalyser.js +23 -14
- package/dist/AstAnalyser.js.map +1 -1
- package/dist/CollectableSet.d.ts +11 -6
- package/dist/CollectableSet.d.ts.map +1 -1
- package/dist/CollectableSet.js +1 -1
- package/dist/CollectableSet.js.map +1 -1
- package/dist/CollectableSetRegistry.d.ts +1 -1
- package/dist/CollectableSetRegistry.d.ts.map +1 -1
- package/dist/CollectableSetRegistry.js +0 -2
- package/dist/CollectableSetRegistry.js.map +1 -1
- package/dist/Deobfuscator.d.ts.map +1 -1
- package/dist/Deobfuscator.js +8 -7
- package/dist/Deobfuscator.js.map +1 -1
- package/dist/EntryFilesAnalyser.d.ts +1 -1
- package/dist/EntryFilesAnalyser.d.ts.map +1 -1
- package/dist/EntryFilesAnalyser.js +2 -2
- package/dist/EntryFilesAnalyser.js.map +1 -1
- package/dist/NodeCounter.js +1 -1
- package/dist/ProbeRunner.d.ts.map +1 -1
- package/dist/ProbeRunner.js +12 -4
- package/dist/ProbeRunner.js.map +1 -1
- package/dist/SourceFile.d.ts +3 -3
- package/dist/SourceFile.d.ts.map +1 -1
- package/dist/SourceFile.js +14 -8
- package/dist/SourceFile.js.map +1 -1
- package/dist/VariableTracer.d.ts +100 -0
- package/dist/VariableTracer.d.ts.map +1 -0
- package/dist/VariableTracer.js +463 -0
- package/dist/VariableTracer.js.map +1 -0
- package/dist/contants.d.ts +1 -0
- package/dist/contants.d.ts.map +1 -1
- package/dist/contants.js +1 -0
- package/dist/contants.js.map +1 -1
- package/dist/estree/functions/arrayExpression.d.ts +15 -0
- package/dist/estree/functions/arrayExpression.d.ts.map +1 -0
- package/dist/estree/functions/arrayExpression.js +69 -0
- package/dist/estree/functions/arrayExpression.js.map +1 -0
- package/dist/estree/functions/concatBinaryExpression.d.ts +15 -0
- package/dist/estree/functions/concatBinaryExpression.d.ts.map +1 -0
- package/dist/estree/functions/concatBinaryExpression.js +46 -0
- package/dist/estree/functions/concatBinaryExpression.js.map +1 -0
- package/dist/estree/functions/extractLogicalExpression.d.ts +6 -0
- package/dist/estree/functions/extractLogicalExpression.d.ts.map +1 -0
- package/dist/estree/functions/extractLogicalExpression.js +18 -0
- package/dist/estree/functions/extractLogicalExpression.js.map +1 -0
- package/dist/estree/functions/getCallExpressionArguments.d.ts +4 -0
- package/dist/estree/functions/getCallExpressionArguments.d.ts.map +1 -0
- package/dist/estree/functions/getCallExpressionArguments.js +52 -0
- package/dist/estree/functions/getCallExpressionArguments.js.map +1 -0
- package/dist/estree/functions/getCallExpressionIdentifier.d.ts +15 -0
- package/dist/estree/functions/getCallExpressionIdentifier.d.ts.map +1 -0
- package/dist/estree/functions/getCallExpressionIdentifier.js +24 -0
- package/dist/estree/functions/getCallExpressionIdentifier.js.map +1 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.d.ts +7 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.d.ts.map +1 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.js +63 -0
- package/dist/estree/functions/getMemberExpressionIdentifier.js.map +1 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.d.ts +13 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.d.ts.map +1 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.js +123 -0
- package/dist/estree/functions/getVariableDeclarationIdentifiers.js.map +1 -0
- package/dist/estree/functions/toLiteral.d.ts +3 -0
- package/dist/estree/functions/toLiteral.d.ts.map +1 -0
- package/dist/estree/functions/toLiteral.js +4 -0
- package/dist/estree/functions/toLiteral.js.map +1 -0
- package/dist/estree/index.d.ts +11 -0
- package/dist/estree/index.d.ts.map +1 -0
- package/dist/estree/index.js +11 -0
- package/dist/estree/index.js.map +1 -0
- package/dist/estree/literal.d.ts +4 -0
- package/dist/estree/literal.d.ts.map +1 -0
- package/dist/estree/literal.js +7 -0
- package/dist/estree/literal.js.map +1 -0
- package/dist/{types/estree.d.ts → estree/types.d.ts} +5 -1
- package/dist/estree/types.d.ts.map +1 -0
- package/dist/{types/estree.js → estree/types.js} +4 -1
- package/dist/estree/types.js.map +1 -0
- package/dist/i18n/arabic.d.ts +29 -0
- package/dist/i18n/arabic.d.ts.map +1 -0
- package/dist/i18n/arabic.js +28 -0
- package/dist/i18n/arabic.js.map +1 -0
- package/dist/i18n/english.d.ts +1 -0
- package/dist/i18n/english.js +2 -1
- package/dist/i18n/english.js.map +1 -1
- package/dist/i18n/french.d.ts +1 -0
- package/dist/i18n/french.js +2 -1
- package/dist/i18n/french.js.map +1 -1
- package/dist/i18n/turkish.d.ts +29 -0
- package/dist/i18n/turkish.d.ts.map +1 -0
- package/dist/i18n/turkish.js +28 -0
- package/dist/i18n/turkish.js.map +1 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/obfuscators/freejsobfuscator.d.ts +5 -0
- package/dist/obfuscators/freejsobfuscator.d.ts.map +1 -1
- package/dist/obfuscators/freejsobfuscator.js +1 -3
- package/dist/obfuscators/freejsobfuscator.js.map +1 -1
- package/dist/{JsSourceParser.d.ts → parsers/JsSourceParser.d.ts} +8 -0
- package/dist/parsers/JsSourceParser.d.ts.map +1 -0
- package/dist/{JsSourceParser.js → parsers/JsSourceParser.js} +9 -2
- package/dist/parsers/JsSourceParser.js.map +1 -0
- package/dist/parsers/TsSourceParser.d.ts +7 -0
- package/dist/parsers/TsSourceParser.d.ts.map +1 -0
- package/dist/parsers/TsSourceParser.js +25 -0
- package/dist/parsers/TsSourceParser.js.map +1 -0
- package/dist/pipelines/deobfuscate.d.ts.map +1 -1
- package/dist/pipelines/deobfuscate.js +1 -2
- package/dist/pipelines/deobfuscate.js.map +1 -1
- package/dist/probes/data-exfiltration.d.ts.map +1 -1
- package/dist/probes/data-exfiltration.js +3 -3
- package/dist/probes/data-exfiltration.js.map +1 -1
- package/dist/probes/isESMExport.d.ts +1 -1
- package/dist/probes/isFetch.d.ts.map +1 -1
- package/dist/probes/isFetch.js +2 -2
- package/dist/probes/isFetch.js.map +1 -1
- package/dist/probes/isImportDeclaration.d.ts +1 -1
- package/dist/probes/isLiteral.d.ts +1 -1
- package/dist/probes/isLiteral.d.ts.map +1 -1
- package/dist/probes/isLiteral.js +1 -3
- package/dist/probes/isLiteral.js.map +1 -1
- package/dist/probes/isMonkeyPatch.js +2 -1
- package/dist/probes/isMonkeyPatch.js.map +1 -1
- package/dist/probes/isPrototypePollution.d.ts +18 -0
- package/dist/probes/isPrototypePollution.d.ts.map +1 -0
- package/dist/probes/isPrototypePollution.js +31 -0
- package/dist/probes/isPrototypePollution.js.map +1 -0
- package/dist/probes/isRandom.d.ts +15 -0
- package/dist/probes/isRandom.d.ts.map +1 -0
- package/dist/probes/isRandom.js +29 -0
- package/dist/probes/isRandom.js.map +1 -0
- package/dist/probes/isRequire/InlinedRequire.d.ts.map +1 -1
- package/dist/probes/isRequire/InlinedRequire.js +1 -2
- package/dist/probes/isRequire/InlinedRequire.js.map +1 -1
- package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts +1 -1
- package/dist/probes/isRequire/RequireCallExpressionWalker.d.ts.map +1 -1
- package/dist/probes/isRequire/RequireCallExpressionWalker.js +3 -5
- package/dist/probes/isRequire/RequireCallExpressionWalker.js.map +1 -1
- package/dist/probes/isRequire/isRequire.d.ts.map +1 -1
- package/dist/probes/isRequire/isRequire.js +3 -3
- package/dist/probes/isRequire/isRequire.js.map +1 -1
- package/dist/probes/isSerializeEnv.d.ts.map +1 -1
- package/dist/probes/isSerializeEnv.js +2 -2
- package/dist/probes/isSerializeEnv.js.map +1 -1
- package/dist/probes/isUnsafeCallee.d.ts +4 -3
- package/dist/probes/isUnsafeCallee.d.ts.map +1 -1
- package/dist/probes/isUnsafeCallee.js +12 -12
- package/dist/probes/isUnsafeCallee.js.map +1 -1
- package/dist/probes/isUnsafeCommand.js +3 -2
- package/dist/probes/isUnsafeCommand.js.map +1 -1
- package/dist/probes/isWeakCrypto.js +1 -1
- package/dist/probes/sql-injection.js +2 -1
- package/dist/probes/sql-injection.js.map +1 -1
- package/dist/utils/extractNode.js +1 -1
- package/dist/utils/getSubMemberExpressionSegments.d.ts +2 -0
- package/dist/utils/getSubMemberExpressionSegments.d.ts.map +1 -0
- package/dist/utils/getSubMemberExpressionSegments.js +9 -0
- package/dist/utils/getSubMemberExpressionSegments.js.map +1 -0
- package/dist/utils/hex.d.ts +14 -0
- package/dist/utils/hex.d.ts.map +1 -0
- package/dist/utils/hex.js +44 -0
- package/dist/utils/hex.js.map +1 -0
- package/dist/utils/index.d.ts +9 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +9 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/isEvilIdentifier.d.ts +3 -0
- package/dist/utils/isEvilIdentifier.d.ts.map +1 -0
- package/dist/utils/isEvilIdentifier.js +11 -0
- package/dist/utils/isEvilIdentifier.js.map +1 -0
- package/dist/utils/isOneLineExpressionExport.d.ts.map +1 -1
- package/dist/utils/isOneLineExpressionExport.js +2 -1
- package/dist/utils/isOneLineExpressionExport.js.map +1 -1
- package/dist/utils/isStringBase64.d.ts +8 -0
- package/dist/utils/isStringBase64.d.ts.map +1 -0
- package/dist/utils/isStringBase64.js +18 -0
- package/dist/utils/isStringBase64.js.map +1 -0
- package/dist/utils/isSvg.d.ts +7 -0
- package/dist/utils/isSvg.d.ts.map +1 -0
- package/dist/utils/isSvg.js +26 -0
- package/dist/utils/isSvg.js.map +1 -0
- package/dist/utils/makePrefixRemover.d.ts +2 -0
- package/dist/utils/makePrefixRemover.d.ts.map +1 -0
- package/dist/utils/makePrefixRemover.js +13 -0
- package/dist/utils/makePrefixRemover.js.map +1 -0
- package/dist/utils/patterns.d.ts +24 -0
- package/dist/utils/patterns.d.ts.map +1 -0
- package/dist/utils/patterns.js +77 -0
- package/dist/utils/patterns.js.map +1 -0
- package/dist/utils/stringSuspicionScore.d.ts +12 -0
- package/dist/utils/stringSuspicionScore.d.ts.map +1 -0
- package/dist/utils/stringSuspicionScore.js +53 -0
- package/dist/utils/stringSuspicionScore.js.map +1 -0
- package/dist/utils/stripNodePrefix.d.ts +2 -0
- package/dist/utils/stripNodePrefix.d.ts.map +1 -0
- package/dist/utils/stripNodePrefix.js +11 -0
- package/dist/utils/stripNodePrefix.js.map +1 -0
- package/dist/walker/walker.sync.js +1 -1
- package/dist/warnings.d.ts +12 -2
- package/dist/warnings.d.ts.map +1 -1
- package/dist/warnings.js +10 -0
- package/dist/warnings.js.map +1 -1
- package/package.json +4 -6
- package/dist/JsSourceParser.d.ts.map +0 -1
- package/dist/JsSourceParser.js.map +0 -1
- package/dist/types/estree.d.ts.map +0 -1
- package/dist/types/estree.js.map +0 -1
|
@@ -0,0 +1,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 @@
|
|
|
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":"AAAA,kCAAkC;AAClC,OAAO,YAAY,MAAM,eAAe,CAAC;AAGzC,+BAA+B;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAE7C;;;;;GAKG;AACH,MAAM,UAAU,kBAAkB,CAChC,YAAqC,EACrC,aAAsC;IAEtC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;IACtC,MAAM,QAAQ,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IAExC,6DAA6D;IAC7D,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;IACnF,IAAI,SAAS,GAAG,EAAE,CAAC;IAEnB,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC;QACnC,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;YAC/C,MAAM;QACR,CAAC;QAED,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,OAAO,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;AAC7C,CAAC;AAED,SAAS,aAAa,CACpB,MAAc;IAEd,OAAO,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,kBAAkB,CAChC,OAAe,EACf,QAAgB;IAEhB,MAAM,YAAY,GAAG,kBAAkB,CACrC,aAAa,CAAC,OAAO,CAAC,EACtB,aAAa,CAAC,QAAQ,CAAC,CACxB,CAAC;IAEF,OAAO,YAAY,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;AACpE,CAAC;AAED,MAAM,UAAU,uBAAuB,CACrC,gBAA0B;IAE1B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC;QACrC,MAAM,IAAI,SAAS,CAAC,mCAAmC,CAAC,CAAC;IAC3D,CAAC;IACD,MAAM,MAAM,GAAG,IAAI,YAAY,EAAE,CAAC;IAElC,QAAQ,EAAE,KAAK,MAAM,KAAK,IAAI,gBAAgB,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC;QAC9D,KAAK,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,MAAM,EAAE,CAAC;YACjC,MAAM,SAAS,GAAG,kBAAkB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YAChD,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;gBACvB,SAAS;YACX,CAAC;YAED,IAAI,SAAS,KAAK,EAAE,IAAI,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC;gBACjD,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACjB,CAAC;iBACI,IAAI,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;gBAClC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;gBAClB,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;YACnC,CAAC;YACD,SAAS,QAAQ,CAAC;QACpB,CAAC;QAED,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACpB,CAAC;IAED,oEAAoE;IACpE,IAAI,gBAAgB,GAAG,CAAC,CAAC;IACzB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC;QAC5C,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;YAChB,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACnB,gBAAgB,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;IAED,OAAO;QACL,gBAAgB;QAChB,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC;KACnC,CAAC;AACJ,CAAC"}
|
|
@@ -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 @@
|
|
|
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"}
|
package/dist/warnings.d.ts
CHANGED
|
@@ -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;
|
package/dist/warnings.d.ts.map
CHANGED
|
@@ -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;
|
|
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) {
|
package/dist/warnings.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"warnings.js","sourceRoot":"","sources":["../src/warnings.ts"],"names":[],"mappings":"AAGA,+BAA+B;AAC/B,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EACL,YAAY,EACZ,eAAe,EAEhB,MAAM,4BAA4B,CAAC;
|
|
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": "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
|
-
"@
|
|
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"}
|
package/dist/types/estree.js.map
DELETED
|
@@ -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"}
|