js-confuser 1.7.2 → 2.0.0-alpha.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/.github/ISSUE_TEMPLATE/bug_report.md +6 -4
- package/.github/workflows/node.js.yml +1 -1
- package/CHANGELOG.md +105 -0
- package/Migration.md +57 -0
- package/README.md +23 -913
- package/dist/constants.js +69 -13
- package/dist/index.js +108 -152
- package/dist/obfuscator.js +316 -118
- package/dist/options.js +1 -109
- package/dist/order.js +30 -30
- package/dist/presets.js +47 -45
- package/dist/probability.js +25 -32
- package/dist/templates/bufferToStringTemplate.js +9 -0
- package/dist/templates/deadCodeTemplates.js +9 -0
- package/dist/templates/getGlobalTemplate.js +19 -0
- package/dist/templates/integrityTemplate.js +30 -0
- package/dist/templates/setFunctionLengthTemplate.js +9 -0
- package/dist/templates/stringCompressionTemplate.js +10 -0
- package/dist/templates/tamperProtectionTemplates.js +21 -0
- package/dist/templates/template.js +213 -93
- package/dist/transforms/astScrambler.js +100 -0
- package/dist/transforms/calculator.js +70 -127
- package/dist/transforms/controlFlowFlattening.js +1182 -0
- package/dist/transforms/deadCode.js +62 -577
- package/dist/transforms/dispatcher.js +300 -309
- package/dist/transforms/extraction/duplicateLiteralsRemoval.js +88 -189
- package/dist/transforms/extraction/objectExtraction.js +131 -215
- package/dist/transforms/finalizer.js +56 -59
- package/dist/transforms/flatten.js +275 -276
- package/dist/transforms/functionOutlining.js +230 -0
- package/dist/transforms/identifier/globalConcealing.js +217 -103
- package/dist/transforms/identifier/movedDeclarations.js +167 -91
- package/dist/transforms/identifier/renameVariables.js +240 -187
- package/dist/transforms/lock/integrity.js +61 -184
- package/dist/transforms/lock/lock.js +263 -303
- package/dist/transforms/minify.js +431 -436
- package/dist/transforms/opaquePredicates.js +65 -118
- package/dist/transforms/pack.js +160 -0
- package/dist/transforms/plugin.js +179 -0
- package/dist/transforms/preparation.js +263 -163
- package/dist/transforms/renameLabels.js +132 -56
- package/dist/transforms/rgf.js +142 -240
- package/dist/transforms/shuffle.js +52 -145
- package/dist/transforms/string/encoding.js +45 -173
- package/dist/transforms/string/stringCompression.js +81 -126
- package/dist/transforms/string/stringConcealing.js +189 -224
- package/dist/transforms/string/stringEncoding.js +32 -40
- package/dist/transforms/string/stringSplitting.js +54 -55
- package/dist/transforms/variableMasking.js +232 -0
- package/dist/utils/ControlObject.js +125 -0
- package/dist/utils/IntGen.js +46 -0
- package/dist/utils/NameGen.js +106 -0
- package/dist/utils/ast-utils.js +560 -0
- package/dist/utils/function-utils.js +56 -0
- package/dist/utils/gen-utils.js +48 -0
- package/dist/utils/node.js +77 -0
- package/dist/utils/object-utils.js +21 -0
- package/dist/utils/random-utils.js +91 -0
- package/dist/utils/static-utils.js +64 -0
- package/dist/validateOptions.js +122 -0
- package/index.d.ts +1 -17
- package/package.json +27 -22
- package/src/constants.ts +139 -77
- package/src/index.ts +70 -163
- package/src/obfuscationResult.ts +43 -0
- package/src/obfuscator.ts +328 -135
- package/src/options.ts +154 -623
- package/src/order.ts +14 -14
- package/src/presets.ts +39 -34
- package/src/probability.ts +21 -36
- package/src/templates/{bufferToString.ts → bufferToStringTemplate.ts} +5 -54
- package/src/templates/deadCodeTemplates.ts +1185 -0
- package/src/templates/getGlobalTemplate.ts +72 -0
- package/src/templates/integrityTemplate.ts +69 -0
- package/src/templates/setFunctionLengthTemplate.ts +11 -0
- package/src/templates/stringCompressionTemplate.ts +42 -0
- package/src/templates/tamperProtectionTemplates.ts +116 -0
- package/src/templates/template.ts +183 -92
- package/src/transforms/astScrambler.ts +99 -0
- package/src/transforms/calculator.ts +96 -224
- package/src/transforms/controlFlowFlattening.ts +1594 -0
- package/src/transforms/deadCode.ts +85 -628
- package/src/transforms/dispatcher.ts +431 -636
- package/src/transforms/extraction/duplicateLiteralsRemoval.ts +147 -299
- package/src/transforms/extraction/objectExtraction.ts +160 -333
- package/src/transforms/finalizer.ts +63 -64
- package/src/transforms/flatten.ts +439 -557
- package/src/transforms/functionOutlining.ts +225 -0
- package/src/transforms/identifier/globalConcealing.ts +261 -189
- package/src/transforms/identifier/movedDeclarations.ts +228 -142
- package/src/transforms/identifier/renameVariables.ts +252 -258
- package/src/transforms/lock/integrity.ts +84 -260
- package/src/transforms/lock/lock.ts +342 -491
- package/src/transforms/minify.ts +523 -663
- package/src/transforms/opaquePredicates.ts +90 -229
- package/src/transforms/pack.ts +195 -0
- package/src/transforms/plugin.ts +185 -0
- package/src/transforms/preparation.ts +337 -215
- package/src/transforms/renameLabels.ts +176 -77
- package/src/transforms/rgf.ts +293 -386
- package/src/transforms/shuffle.ts +80 -254
- package/src/transforms/string/encoding.ts +26 -129
- package/src/transforms/string/stringCompression.ts +118 -236
- package/src/transforms/string/stringConcealing.ts +255 -339
- package/src/transforms/string/stringEncoding.ts +28 -47
- package/src/transforms/string/stringSplitting.ts +61 -75
- package/src/transforms/variableMasking.ts +257 -0
- package/src/utils/ControlObject.ts +141 -0
- package/src/utils/IntGen.ts +33 -0
- package/src/utils/NameGen.ts +106 -0
- package/src/utils/ast-utils.ts +667 -0
- package/src/utils/function-utils.ts +50 -0
- package/src/utils/gen-utils.ts +48 -0
- package/src/utils/node.ts +78 -0
- package/src/utils/object-utils.ts +21 -0
- package/src/utils/random-utils.ts +79 -0
- package/src/utils/static-utils.ts +66 -0
- package/src/validateOptions.ts +256 -0
- package/tsconfig.json +13 -8
- package/babel.config.js +0 -12
- package/dev.js +0 -8
- package/dist/compiler.js +0 -34
- package/dist/parser.js +0 -59
- package/dist/precedence.js +0 -66
- package/dist/templates/bufferToString.js +0 -108
- package/dist/templates/crash.js +0 -59
- package/dist/templates/es5.js +0 -137
- package/dist/templates/functionLength.js +0 -34
- package/dist/templates/globals.js +0 -9
- package/dist/transforms/antiTooling.js +0 -88
- package/dist/transforms/controlFlowFlattening/controlFlowFlattening.js +0 -1281
- package/dist/transforms/controlFlowFlattening/expressionObfuscation.js +0 -131
- package/dist/transforms/es5/antiClass.js +0 -164
- package/dist/transforms/es5/antiDestructuring.js +0 -193
- package/dist/transforms/es5/antiES6Object.js +0 -185
- package/dist/transforms/es5/antiSpreadOperator.js +0 -35
- package/dist/transforms/es5/antiTemplate.js +0 -66
- package/dist/transforms/es5/es5.js +0 -123
- package/dist/transforms/extraction/classExtraction.js +0 -83
- package/dist/transforms/identifier/globalAnalysis.js +0 -70
- package/dist/transforms/identifier/variableAnalysis.js +0 -104
- package/dist/transforms/lock/antiDebug.js +0 -76
- package/dist/transforms/stack.js +0 -343
- package/dist/transforms/transform.js +0 -350
- package/dist/traverse.js +0 -110
- package/dist/util/compare.js +0 -145
- package/dist/util/gen.js +0 -564
- package/dist/util/guard.js +0 -9
- package/dist/util/identifiers.js +0 -355
- package/dist/util/insert.js +0 -362
- package/dist/util/math.js +0 -19
- package/dist/util/object.js +0 -40
- package/dist/util/random.js +0 -130
- package/dist/util/scope.js +0 -20
- package/docs/ControlFlowFlattening.md +0 -595
- package/docs/Countermeasures.md +0 -63
- package/docs/ES5.md +0 -197
- package/docs/Integrity.md +0 -75
- package/docs/RGF.md +0 -419
- package/samples/example.js +0 -15
- package/samples/high.js +0 -1
- package/samples/input.js +0 -3
- package/samples/javascriptobfuscator.com.js +0 -8
- package/samples/jscrambler_advanced.js +0 -1894
- package/samples/jscrambler_light.js +0 -1134
- package/samples/low.js +0 -1
- package/samples/medium.js +0 -1
- package/samples/obfuscator.io.js +0 -1686
- package/samples/preemptive.com.js +0 -16
- package/src/compiler.ts +0 -35
- package/src/parser.ts +0 -49
- package/src/precedence.ts +0 -61
- package/src/templates/crash.ts +0 -55
- package/src/templates/es5.ts +0 -131
- package/src/templates/functionLength.ts +0 -32
- package/src/templates/globals.ts +0 -3
- package/src/transforms/antiTooling.ts +0 -102
- package/src/transforms/controlFlowFlattening/controlFlowFlattening.ts +0 -2146
- package/src/transforms/controlFlowFlattening/expressionObfuscation.ts +0 -179
- package/src/transforms/es5/antiClass.ts +0 -272
- package/src/transforms/es5/antiDestructuring.ts +0 -294
- package/src/transforms/es5/antiES6Object.ts +0 -267
- package/src/transforms/es5/antiSpreadOperator.ts +0 -56
- package/src/transforms/es5/antiTemplate.ts +0 -98
- package/src/transforms/es5/es5.ts +0 -149
- package/src/transforms/extraction/classExtraction.ts +0 -168
- package/src/transforms/identifier/globalAnalysis.ts +0 -85
- package/src/transforms/identifier/variableAnalysis.ts +0 -118
- package/src/transforms/lock/antiDebug.ts +0 -112
- package/src/transforms/stack.ts +0 -551
- package/src/transforms/transform.ts +0 -453
- package/src/traverse.ts +0 -120
- package/src/types.ts +0 -131
- package/src/util/compare.ts +0 -181
- package/src/util/gen.ts +0 -651
- package/src/util/guard.ts +0 -7
- package/src/util/identifiers.ts +0 -494
- package/src/util/insert.ts +0 -419
- package/src/util/math.ts +0 -15
- package/src/util/object.ts +0 -39
- package/src/util/random.ts +0 -141
- package/src/util/scope.ts +0 -21
- package/test/code/Cash.src.js +0 -1011
- package/test/code/Cash.test.ts +0 -49
- package/test/code/Dynamic.src.js +0 -118
- package/test/code/Dynamic.test.ts +0 -49
- package/test/code/ES6.src.js +0 -235
- package/test/code/ES6.test.ts +0 -42
- package/test/code/NewFeatures.test.ts +0 -19
- package/test/code/StrictMode.src.js +0 -65
- package/test/code/StrictMode.test.js +0 -37
- package/test/compare.test.ts +0 -104
- package/test/index.test.ts +0 -249
- package/test/options.test.ts +0 -132
- package/test/presets.test.ts +0 -22
- package/test/probability.test.ts +0 -44
- package/test/templates/template.test.ts +0 -14
- package/test/transforms/antiTooling.test.ts +0 -52
- package/test/transforms/calculator.test.ts +0 -78
- package/test/transforms/controlFlowFlattening/controlFlowFlattening.test.ts +0 -1274
- package/test/transforms/controlFlowFlattening/expressionObfuscation.test.ts +0 -192
- package/test/transforms/deadCode.test.ts +0 -85
- package/test/transforms/dispatcher.test.ts +0 -457
- package/test/transforms/es5/antiClass.test.ts +0 -427
- package/test/transforms/es5/antiDestructuring.test.ts +0 -157
- package/test/transforms/es5/antiES6Object.test.ts +0 -245
- package/test/transforms/es5/antiTemplate.test.ts +0 -116
- package/test/transforms/es5/es5.test.ts +0 -110
- package/test/transforms/extraction/classExtraction.test.ts +0 -86
- package/test/transforms/extraction/duplicateLiteralsRemoval.test.ts +0 -200
- package/test/transforms/extraction/objectExtraction.test.ts +0 -491
- package/test/transforms/flatten.test.ts +0 -721
- package/test/transforms/hexadecimalNumbers.test.ts +0 -62
- package/test/transforms/identifier/globalConcealing.test.ts +0 -72
- package/test/transforms/identifier/movedDeclarations.test.ts +0 -275
- package/test/transforms/identifier/renameVariables.test.ts +0 -621
- package/test/transforms/lock/antiDebug.test.ts +0 -66
- package/test/transforms/lock/browserLock.test.ts +0 -129
- package/test/transforms/lock/countermeasures.test.ts +0 -100
- package/test/transforms/lock/integrity.test.ts +0 -161
- package/test/transforms/lock/lock.test.ts +0 -204
- package/test/transforms/lock/osLock.test.ts +0 -312
- package/test/transforms/lock/selfDefending.test.ts +0 -68
- package/test/transforms/minify.test.ts +0 -575
- package/test/transforms/opaquePredicates.test.ts +0 -43
- package/test/transforms/preparation.test.ts +0 -157
- package/test/transforms/renameLabels.test.ts +0 -95
- package/test/transforms/rgf.test.ts +0 -378
- package/test/transforms/shuffle.test.ts +0 -135
- package/test/transforms/stack.test.ts +0 -573
- package/test/transforms/string/stringCompression.test.ts +0 -120
- package/test/transforms/string/stringConcealing.test.ts +0 -299
- package/test/transforms/string/stringEncoding.test.ts +0 -95
- package/test/transforms/string/stringSplitting.test.ts +0 -135
- package/test/transforms/transform.test.ts +0 -66
- package/test/traverse.test.ts +0 -139
- package/test/util/compare.test.ts +0 -34
- package/test/util/gen.test.ts +0 -121
- package/test/util/identifiers.test.ts +0 -253
- package/test/util/insert.test.ts +0 -142
- package/test/util/math.test.ts +0 -5
- package/test/util/random.test.ts +0 -71
- /package/dist/{types.js → obfuscationResult.js} +0 -0
package/dist/transforms/stack.js
DELETED
|
@@ -1,343 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _assert = require("assert");
|
|
8
|
-
var _order = require("../order");
|
|
9
|
-
var _probability = require("../probability");
|
|
10
|
-
var _template = _interopRequireDefault(require("../templates/template"));
|
|
11
|
-
var _traverse = require("../traverse");
|
|
12
|
-
var _gen = require("../util/gen");
|
|
13
|
-
var _identifiers = require("../util/identifiers");
|
|
14
|
-
var _insert = require("../util/insert");
|
|
15
|
-
var _random = require("../util/random");
|
|
16
|
-
var _transform = _interopRequireDefault(require("./transform"));
|
|
17
|
-
var _constants = require("../constants");
|
|
18
|
-
var _functionLength = require("../templates/functionLength");
|
|
19
|
-
var _globals = require("../templates/globals");
|
|
20
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
21
|
-
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
22
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
23
|
-
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
24
|
-
class Stack extends _transform.default {
|
|
25
|
-
constructor(o) {
|
|
26
|
-
super(o, _order.ObfuscateOrder.Stack);
|
|
27
|
-
_defineProperty(this, "mangledExpressionsMade", void 0);
|
|
28
|
-
_defineProperty(this, "functionLengthName", void 0);
|
|
29
|
-
this.mangledExpressionsMade = 0;
|
|
30
|
-
}
|
|
31
|
-
match(object, parents) {
|
|
32
|
-
return (0, _insert.isFunction)(object) && !object.params.find(x => x.type !== "Identifier") && object.body.type === "BlockStatement" && !parents.find(x => x.$dispatcherSkip) && !object.$requiresEval;
|
|
33
|
-
}
|
|
34
|
-
transform(object, parents) {
|
|
35
|
-
var _this = this;
|
|
36
|
-
return () => {
|
|
37
|
-
var _getBlockBody$;
|
|
38
|
-
// Uncaught SyntaxError: Getter must not have any formal parameters.
|
|
39
|
-
// Uncaught SyntaxError: Setter must have exactly one formal parameter
|
|
40
|
-
var propIndex = parents.findIndex(x => x.type === "Property" || x.type === "MethodDefinition");
|
|
41
|
-
if (propIndex !== -1) {
|
|
42
|
-
if (parents[propIndex].value === (parents[propIndex - 1] || object)) {
|
|
43
|
-
if (parents[propIndex].kind !== "init" || parents[propIndex].method) {
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
// Don't apply to functions with 'use strict' directive
|
|
50
|
-
if ((_getBlockBody$ = (0, _insert.getBlockBody)(object.body)[0]) !== null && _getBlockBody$ !== void 0 && _getBlockBody$.directive) {
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
if (!(0, _probability.ComputeProbabilityMap)(this.options.stack)) {
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
var defined = new Set();
|
|
57
|
-
var referenced = new Set();
|
|
58
|
-
var illegal = new Set();
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* Maps old names to new indices
|
|
62
|
-
*/
|
|
63
|
-
var subscripts = new Map();
|
|
64
|
-
var deadValues = Object.create(null);
|
|
65
|
-
var propertyGen = this.getGenerator();
|
|
66
|
-
function isTransformableFunction(functionNode) {
|
|
67
|
-
if (functionNode.$requiresEval) return false;
|
|
68
|
-
|
|
69
|
-
// Check for 'this'
|
|
70
|
-
var isIllegal = false;
|
|
71
|
-
(0, _traverse.walk)(functionNode.body, [], (o, p) => {
|
|
72
|
-
if (o.type === "ThisExpression") {
|
|
73
|
-
isIllegal = true;
|
|
74
|
-
return "EXIT";
|
|
75
|
-
}
|
|
76
|
-
});
|
|
77
|
-
return !isIllegal;
|
|
78
|
-
}
|
|
79
|
-
function setSubscript(string, index) {
|
|
80
|
-
subscripts.set(string, index + "");
|
|
81
|
-
}
|
|
82
|
-
object.params.forEach(param => {
|
|
83
|
-
(0, _assert.ok)(param.name);
|
|
84
|
-
defined.add(param.name);
|
|
85
|
-
setSubscript(param.name, subscripts.size);
|
|
86
|
-
});
|
|
87
|
-
var startingSize = subscripts.size;
|
|
88
|
-
var isIllegal = false;
|
|
89
|
-
(0, _traverse.walk)(object.body, [object, ...parents], (o, p) => {
|
|
90
|
-
if (o.type === "Identifier" && o.name === "arguments") {
|
|
91
|
-
isIllegal = true;
|
|
92
|
-
return "EXIT";
|
|
93
|
-
}
|
|
94
|
-
if (o.type == "Identifier") {
|
|
95
|
-
var info = (0, _identifiers.getIdentifierInfo)(o, p);
|
|
96
|
-
if (!info.spec.isReferenced || info.spec.isExported) {
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
var c = info.spec.isDefined ? (0, _insert.getDefiningContext)(o, p) : (0, _insert.getReferencingContexts)(o, p).find(x => (0, _insert.isVarContext)(x));
|
|
100
|
-
if (c !== object) {
|
|
101
|
-
// this.log(o.name + " is illegal due to different context");
|
|
102
|
-
illegal.add(o.name);
|
|
103
|
-
}
|
|
104
|
-
if (o.name.startsWith(_constants.noRenameVariablePrefix)) {
|
|
105
|
-
illegal.add(o.name);
|
|
106
|
-
}
|
|
107
|
-
if (info.isClauseParameter || info.isFunctionParameter || (0, _insert.isForInitialize)(o, p)) {
|
|
108
|
-
// this.log(
|
|
109
|
-
// o.name + " is illegal due to clause parameter/function parameter"
|
|
110
|
-
// );
|
|
111
|
-
illegal.add(o.name);
|
|
112
|
-
}
|
|
113
|
-
if (o.hidden) {
|
|
114
|
-
illegal.add(o.name);
|
|
115
|
-
}
|
|
116
|
-
if (info.spec.isDefined) {
|
|
117
|
-
if (defined.has(o.name)) {
|
|
118
|
-
illegal.add(o.name);
|
|
119
|
-
}
|
|
120
|
-
if (info.isFunctionDeclaration) {
|
|
121
|
-
(0, _assert.ok)(p[0].type === "FunctionDeclaration");
|
|
122
|
-
if (p[0] !== object.body.body[0] || !isTransformableFunction(p[0])) {
|
|
123
|
-
illegal.add(o.name);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
// The new accessors will either be numbered: [index] or as a string .string
|
|
128
|
-
var newSubscript = (0, _random.choice)([subscripts.size, propertyGen.generate()]);
|
|
129
|
-
setSubscript(o.name, newSubscript);
|
|
130
|
-
defined.add(o.name);
|
|
131
|
-
|
|
132
|
-
// Stack can only process single VariableDeclarations
|
|
133
|
-
var varIndex = p.findIndex(x => x.type == "VariableDeclaration");
|
|
134
|
-
if (varIndex !== -1) {
|
|
135
|
-
// Invalid 'id' property (must be Identifier)
|
|
136
|
-
if (varIndex !== 2) {
|
|
137
|
-
illegal.add(o.name);
|
|
138
|
-
} else if (p[varIndex].declarations.length > 1) {
|
|
139
|
-
illegal.add(o.name);
|
|
140
|
-
} else {
|
|
141
|
-
var value = p[varIndex].declarations[0].init;
|
|
142
|
-
if (value && !isTransformableFunction(value)) {
|
|
143
|
-
illegal.add(o.name);
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
} else if (info.spec.isReferenced) {
|
|
148
|
-
if (info.spec.isModified) {
|
|
149
|
-
var assignmentIndex = p.findIndex(x => x.type === "AssignmentExpression");
|
|
150
|
-
if (assignmentIndex !== -1) {
|
|
151
|
-
var value = p[assignmentIndex].right;
|
|
152
|
-
if (value && !isTransformableFunction(value)) {
|
|
153
|
-
illegal.add(o.name);
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
referenced.add(o.name);
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
});
|
|
161
|
-
if (isIllegal) return;
|
|
162
|
-
illegal.forEach(name => {
|
|
163
|
-
defined.delete(name);
|
|
164
|
-
referenced.delete(name);
|
|
165
|
-
subscripts.delete(name);
|
|
166
|
-
});
|
|
167
|
-
referenced.forEach(name => {
|
|
168
|
-
if (!defined.has(name)) {
|
|
169
|
-
subscripts.delete(name);
|
|
170
|
-
}
|
|
171
|
-
});
|
|
172
|
-
if (object.params.find(x => illegal.has(x.name))) {
|
|
173
|
-
return;
|
|
174
|
-
}
|
|
175
|
-
if (!subscripts.size) {
|
|
176
|
-
return;
|
|
177
|
-
}
|
|
178
|
-
const numberLiteral = function (number) {
|
|
179
|
-
let depth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
180
|
-
(0, _assert.ok)(number === number);
|
|
181
|
-
if (typeof number !== "number" || !Object.keys(deadValues).length || depth > 4 || (0, _random.chance)(75 + depth * 15 + _this.mangledExpressionsMade / 25)) {
|
|
182
|
-
return (0, _gen.Literal)(number);
|
|
183
|
-
}
|
|
184
|
-
_this.mangledExpressionsMade++;
|
|
185
|
-
var opposingIndex = (0, _random.choice)(Object.keys(deadValues));
|
|
186
|
-
if (typeof opposingIndex === "undefined") {
|
|
187
|
-
return (0, _gen.Literal)(number);
|
|
188
|
-
}
|
|
189
|
-
var actualValue = deadValues[opposingIndex];
|
|
190
|
-
(0, _assert.ok)(typeof actualValue === "number");
|
|
191
|
-
return (0, _gen.BinaryExpression)("-", (0, _gen.MemberExpression)((0, _gen.Identifier)(stackName), numberLiteral(isNaN(parseFloat(opposingIndex)) ? opposingIndex : parseFloat(opposingIndex), depth + 1), true), numberLiteral(actualValue - number, depth + 1));
|
|
192
|
-
};
|
|
193
|
-
function getMemberExpression(index) {
|
|
194
|
-
(0, _assert.ok)(typeof index === "string", typeof index);
|
|
195
|
-
return (0, _gen.MemberExpression)((0, _gen.Identifier)(stackName), numberLiteral(isNaN(parseFloat(index)) ? index : parseFloat(index)), true);
|
|
196
|
-
}
|
|
197
|
-
var stackName = this.getPlaceholder() + "_stack";
|
|
198
|
-
const scan = (o, p) => {
|
|
199
|
-
if (o.type == "Identifier") {
|
|
200
|
-
var index = subscripts.get(o.name);
|
|
201
|
-
if (typeof index !== "undefined") {
|
|
202
|
-
var info = (0, _identifiers.getIdentifierInfo)(o, p);
|
|
203
|
-
if (!info.spec.isReferenced) {
|
|
204
|
-
return;
|
|
205
|
-
}
|
|
206
|
-
var member = getMemberExpression(index);
|
|
207
|
-
if (info.spec.isDefined) {
|
|
208
|
-
if (info.isVariableDeclaration) {
|
|
209
|
-
(0, _traverse.walk)(p[2], p.slice(3), (oo, pp) => {
|
|
210
|
-
if (oo != o) {
|
|
211
|
-
return scan(oo, pp);
|
|
212
|
-
}
|
|
213
|
-
});
|
|
214
|
-
this.replace(p[2], (0, _gen.ExpressionStatement)((0, _gen.AssignmentExpression)("=", member, p[0].init || (0, _gen.Identifier)("undefined"))));
|
|
215
|
-
return;
|
|
216
|
-
} else if (info.isFunctionDeclaration) {
|
|
217
|
-
(0, _traverse.walk)(p[0], p.slice(1), (oo, pp) => {
|
|
218
|
-
if (oo != o) {
|
|
219
|
-
return scan(oo, pp);
|
|
220
|
-
}
|
|
221
|
-
});
|
|
222
|
-
this.replace(p[0], (0, _gen.ExpressionStatement)((0, _gen.AssignmentExpression)("=", member, {
|
|
223
|
-
...p[0],
|
|
224
|
-
type: "FunctionExpression",
|
|
225
|
-
id: null,
|
|
226
|
-
expression: false
|
|
227
|
-
})));
|
|
228
|
-
return;
|
|
229
|
-
} else if (info.isClassDeclaration) {
|
|
230
|
-
(0, _traverse.walk)(p[0], p.slice(1), (oo, pp) => {
|
|
231
|
-
if (oo != o) {
|
|
232
|
-
return scan(oo, pp);
|
|
233
|
-
}
|
|
234
|
-
});
|
|
235
|
-
this.replace(p[0], (0, _gen.ExpressionStatement)((0, _gen.AssignmentExpression)("=", member, {
|
|
236
|
-
...p[0],
|
|
237
|
-
type: "ClassExpression"
|
|
238
|
-
})));
|
|
239
|
-
return;
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
if (info.spec.isReferenced) {
|
|
243
|
-
this.replace(o, member);
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
if (o.type == "Literal" && typeof o.value === "number" && Math.floor(o.value) === o.value && Math.abs(o.value) < 100_000 && p.find(x => (0, _insert.isFunction)(x)) === object && (0, _random.chance)(50)) {
|
|
248
|
-
return () => {
|
|
249
|
-
this.replaceIdentifierOrLiteral(o, numberLiteral(o.value, 0), p);
|
|
250
|
-
};
|
|
251
|
-
}
|
|
252
|
-
};
|
|
253
|
-
var rotateNodes = Object.create(null);
|
|
254
|
-
object.body.body.forEach((stmt, index) => {
|
|
255
|
-
var isFirst = index == 0;
|
|
256
|
-
if (isFirst || (0, _random.chance)(50 - index * 10)) {
|
|
257
|
-
var exprs = [];
|
|
258
|
-
var changes = (0, _random.getRandomInteger)(1, 3);
|
|
259
|
-
for (var i = 0; i < changes; i++) {
|
|
260
|
-
var expr;
|
|
261
|
-
var type = (0, _random.choice)(["set", "deadValue"]);
|
|
262
|
-
var valueSet = new Set([...Array.from(subscripts.values()), ...Object.keys(deadValues)]);
|
|
263
|
-
var newIndex;
|
|
264
|
-
var i = 0;
|
|
265
|
-
do {
|
|
266
|
-
newIndex = (0, _random.choice)([propertyGen.generate(), (0, _random.getRandomInteger)(0, 250 + subscripts.size + i * 1000) + ""]);
|
|
267
|
-
i++;
|
|
268
|
-
} while (valueSet.has(newIndex));
|
|
269
|
-
switch (type) {
|
|
270
|
-
case "set":
|
|
271
|
-
var randomName = (0, _random.choice)(Array.from(subscripts.keys()));
|
|
272
|
-
var currentIndex = subscripts.get(randomName);
|
|
273
|
-
expr = (0, _gen.AssignmentExpression)("=", getMemberExpression(newIndex), getMemberExpression(currentIndex));
|
|
274
|
-
(0, _assert.ok)(typeof deadValues[newIndex] === "undefined", deadValues[newIndex]);
|
|
275
|
-
setSubscript(randomName, newIndex);
|
|
276
|
-
break;
|
|
277
|
-
case "deadValue":
|
|
278
|
-
var rand = (0, _random.getRandomInteger)(-150, 150);
|
|
279
|
-
|
|
280
|
-
// modify an already existing dead value index
|
|
281
|
-
if ((0, _random.chance)(50)) {
|
|
282
|
-
var alreadyExisting = (0, _random.choice)(Object.keys(deadValues));
|
|
283
|
-
if (typeof alreadyExisting === "string") {
|
|
284
|
-
newIndex = alreadyExisting;
|
|
285
|
-
}
|
|
286
|
-
}
|
|
287
|
-
expr = (0, _gen.AssignmentExpression)("=", getMemberExpression(newIndex), numberLiteral(rand));
|
|
288
|
-
deadValues[newIndex] = rand;
|
|
289
|
-
break;
|
|
290
|
-
}
|
|
291
|
-
exprs.push(expr);
|
|
292
|
-
}
|
|
293
|
-
rotateNodes[index] = (0, _gen.ExpressionStatement)((0, _gen.SequenceExpression)(exprs));
|
|
294
|
-
}
|
|
295
|
-
(0, _traverse.walk)(stmt, [object.body.body, object.body, object, ...parents], (o, p) => {
|
|
296
|
-
return scan(o, p);
|
|
297
|
-
});
|
|
298
|
-
if (stmt.type == "ReturnStatement") {
|
|
299
|
-
var opposing = (0, _random.choice)(Object.keys(deadValues));
|
|
300
|
-
if (typeof opposing === "string") {
|
|
301
|
-
this.replace(stmt, (0, _gen.IfStatement)((0, _gen.BinaryExpression)(">", getMemberExpression(opposing), numberLiteral(deadValues[opposing] + (0, _random.getRandomInteger)(40, 140))), [(0, _gen.ReturnStatement)(getMemberExpression((0, _random.getRandomInteger)(-250, 250) + ""))], [(0, _gen.ReturnStatement)(stmt.argument)]));
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
});
|
|
305
|
-
|
|
306
|
-
// Add in the rotation nodes
|
|
307
|
-
Object.keys(rotateNodes).forEach((index, i) => {
|
|
308
|
-
object.body.body.splice(parseInt(index) + i, 0, rotateNodes[index]);
|
|
309
|
-
});
|
|
310
|
-
|
|
311
|
-
// Preserve function.length property
|
|
312
|
-
var originalFunctionLength = (0, _insert.computeFunctionLength)(object.params);
|
|
313
|
-
|
|
314
|
-
// Set the params for this function to be the stack array
|
|
315
|
-
object.params = [(0, _gen.RestElement)((0, _gen.Identifier)(stackName))];
|
|
316
|
-
|
|
317
|
-
// Ensure the array is correct length
|
|
318
|
-
(0, _insert.prepend)(object.body, (0, _template.default)(`${stackName}["length"] = ${startingSize}`).single());
|
|
319
|
-
if (this.options.preserveFunctionLength && originalFunctionLength !== 0) {
|
|
320
|
-
if (!this.functionLengthName) {
|
|
321
|
-
this.functionLengthName = this.getPlaceholder();
|
|
322
|
-
(0, _insert.prepend)(parents[parents.length - 1] || object, _functionLength.FunctionLengthTemplate.single({
|
|
323
|
-
name: this.functionLengthName,
|
|
324
|
-
ObjectDefineProperty: this.createInitVariable(_globals.ObjectDefineProperty, parents)
|
|
325
|
-
}));
|
|
326
|
-
}
|
|
327
|
-
if (object.type === "FunctionDeclaration") {
|
|
328
|
-
var body = parents[0];
|
|
329
|
-
if (Array.isArray(body)) {
|
|
330
|
-
var index = body.indexOf(object);
|
|
331
|
-
body.splice(index, 0, (0, _gen.ExpressionStatement)((0, _gen.CallExpression)((0, _gen.Identifier)(this.functionLengthName), [(0, _gen.Identifier)(object.id.name), (0, _gen.Literal)(originalFunctionLength)])));
|
|
332
|
-
}
|
|
333
|
-
} else {
|
|
334
|
-
(0, _assert.ok)(object.type === "FunctionExpression" || object.type === "ArrowFunctionExpression");
|
|
335
|
-
this.replace(object, (0, _gen.CallExpression)((0, _gen.Identifier)(this.functionLengthName), [{
|
|
336
|
-
...object
|
|
337
|
-
}, (0, _gen.Literal)(originalFunctionLength)]));
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
};
|
|
341
|
-
}
|
|
342
|
-
}
|
|
343
|
-
exports.default = Stack;
|
|
@@ -1,350 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _traverse = _interopRequireDefault(require("../traverse"));
|
|
8
|
-
var _gen = require("../util/gen");
|
|
9
|
-
var _random = require("../util/random");
|
|
10
|
-
var _assert = require("assert");
|
|
11
|
-
var _obfuscator = _interopRequireDefault(require("../obfuscator"));
|
|
12
|
-
var _probability = require("../probability");
|
|
13
|
-
var _constants = require("../constants");
|
|
14
|
-
var _order = require("../order");
|
|
15
|
-
var _insert = require("../util/insert");
|
|
16
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
17
|
-
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
18
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
19
|
-
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
20
|
-
/**
|
|
21
|
-
* Base-class for all transformations.
|
|
22
|
-
* - Transformations can have preparation transformations `.before`
|
|
23
|
-
* - Transformations can have cleanup transformations `.after`
|
|
24
|
-
*
|
|
25
|
-
* - `match()` function returns true/false if possible candidate
|
|
26
|
-
* - `transform()` function modifies the object
|
|
27
|
-
*
|
|
28
|
-
* ```js
|
|
29
|
-
* class Example extends Transform {
|
|
30
|
-
* constructor(o){
|
|
31
|
-
* super(o);
|
|
32
|
-
* }
|
|
33
|
-
*
|
|
34
|
-
* match(object, parents){
|
|
35
|
-
* return object.type == "...";
|
|
36
|
-
* }
|
|
37
|
-
*
|
|
38
|
-
* transform(object, parents){
|
|
39
|
-
* // onEnter
|
|
40
|
-
*
|
|
41
|
-
* return ()=>{
|
|
42
|
-
* // onExit
|
|
43
|
-
* }
|
|
44
|
-
* }
|
|
45
|
-
*
|
|
46
|
-
* apply(tree){
|
|
47
|
-
* // onStart
|
|
48
|
-
*
|
|
49
|
-
* super.apply(tree);
|
|
50
|
-
*
|
|
51
|
-
* // onEnd
|
|
52
|
-
* }
|
|
53
|
-
* }
|
|
54
|
-
* ```
|
|
55
|
-
*/
|
|
56
|
-
class Transform {
|
|
57
|
-
constructor(obfuscator) {
|
|
58
|
-
let priority = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : -1;
|
|
59
|
-
/**
|
|
60
|
-
* The obfuscator.
|
|
61
|
-
*/
|
|
62
|
-
_defineProperty(this, "obfuscator", void 0);
|
|
63
|
-
/**
|
|
64
|
-
* The user's options.
|
|
65
|
-
*/
|
|
66
|
-
_defineProperty(this, "options", void 0);
|
|
67
|
-
/**
|
|
68
|
-
* Only required for top-level transformations.
|
|
69
|
-
*/
|
|
70
|
-
_defineProperty(this, "priority", void 0);
|
|
71
|
-
/**
|
|
72
|
-
* Transforms to run before, such as `Variable Analysis`.
|
|
73
|
-
*/
|
|
74
|
-
_defineProperty(this, "before", void 0);
|
|
75
|
-
/**
|
|
76
|
-
* Transforms to run after.
|
|
77
|
-
*/
|
|
78
|
-
_defineProperty(this, "after", void 0);
|
|
79
|
-
_defineProperty(this, "initVariables", new Map());
|
|
80
|
-
_defineProperty(this, "createInitVariable", (value, parents) => {
|
|
81
|
-
var key = value.templates[0];
|
|
82
|
-
if (this.initVariables.has(key)) {
|
|
83
|
-
return this.initVariables.get(key);
|
|
84
|
-
}
|
|
85
|
-
var root = parents[parents.length - 1];
|
|
86
|
-
(0, _assert.ok)(root.type === "Program");
|
|
87
|
-
var name = this.getPlaceholder();
|
|
88
|
-
this.initVariables.set(key, name);
|
|
89
|
-
(0, _insert.prepend)(root, (0, _gen.VariableDeclaration)((0, _gen.VariableDeclarator)(name, value.single().expression)));
|
|
90
|
-
return name;
|
|
91
|
-
});
|
|
92
|
-
(0, _assert.ok)(obfuscator instanceof _obfuscator.default, "obfuscator should be an Obfuscator");
|
|
93
|
-
this.obfuscator = obfuscator;
|
|
94
|
-
this.options = this.obfuscator.options;
|
|
95
|
-
this.priority = priority;
|
|
96
|
-
this.before = [];
|
|
97
|
-
this.after = [];
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
* The transformation name.
|
|
102
|
-
*/
|
|
103
|
-
get className() {
|
|
104
|
-
return _order.ObfuscateOrder[this.priority] || this.__proto__.constructor.name;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* Run an AST through the transformation (including `pre` and `post` transforms)
|
|
109
|
-
* @param tree
|
|
110
|
-
*/
|
|
111
|
-
apply(tree) {
|
|
112
|
-
if (tree.type == "Program" && this.options.verbose) {
|
|
113
|
-
if (this.priority === -1) {
|
|
114
|
-
console.log("#", ">", this.className);
|
|
115
|
-
} else {
|
|
116
|
-
console.log("#", this.priority, this.className);
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
/**
|
|
121
|
-
* Run through pre-transformations
|
|
122
|
-
*/
|
|
123
|
-
this.before.forEach(x => x.apply(tree));
|
|
124
|
-
|
|
125
|
-
/**
|
|
126
|
-
* Run this transformation
|
|
127
|
-
*/
|
|
128
|
-
(0, _traverse.default)(tree, (object, parents) => {
|
|
129
|
-
return this.input(object, parents);
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* Cleanup transformations
|
|
134
|
-
*/
|
|
135
|
-
this.after.forEach(x => x.apply(tree));
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
/**
|
|
139
|
-
* The `match` function filters for possible candidates.
|
|
140
|
-
*
|
|
141
|
-
* - If `true`, the node is sent to the `transform()` method
|
|
142
|
-
* - else it's discarded.
|
|
143
|
-
*
|
|
144
|
-
* @param object
|
|
145
|
-
* @param parents
|
|
146
|
-
* @param block
|
|
147
|
-
*/
|
|
148
|
-
match(object, parents) {
|
|
149
|
-
throw new Error("not implemented");
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/**
|
|
153
|
-
* Modifies the given node.
|
|
154
|
-
*
|
|
155
|
-
* - Return a function to be ran when the node is exited.
|
|
156
|
-
* - The node is safe to modify in most cases.
|
|
157
|
-
*
|
|
158
|
-
* @param object - Current node
|
|
159
|
-
* @param parents - Array of ancestors `[Closest, ..., Root]`
|
|
160
|
-
* @param block
|
|
161
|
-
*/
|
|
162
|
-
transform(object, parents) {
|
|
163
|
-
throw new Error("not implemented");
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
/**
|
|
167
|
-
* Calls `.match` with the given parameters, and then `.transform` if satisfied.
|
|
168
|
-
* @private
|
|
169
|
-
*/
|
|
170
|
-
input(object, parents) {
|
|
171
|
-
if (this.match(object, parents)) {
|
|
172
|
-
return this.transform(object, parents);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
/**
|
|
177
|
-
* Returns a random string.
|
|
178
|
-
*
|
|
179
|
-
* Used for creating temporary variables names, typically before RenameVariables has ran.
|
|
180
|
-
*
|
|
181
|
-
* These long temp names will be converted to short, mangled names by RenameVariables.
|
|
182
|
-
*/
|
|
183
|
-
getPlaceholder() {
|
|
184
|
-
const genRanHex = size => [...Array(size)].map(() => Math.floor(Math.random() * 10).toString(10)).join("");
|
|
185
|
-
return _constants.placeholderVariablePrefix + genRanHex(10);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
/**
|
|
189
|
-
* Returns an independent name generator with it's own counter.
|
|
190
|
-
* @param overrideMode - Override the user's `identifierGenerator` option
|
|
191
|
-
* @returns
|
|
192
|
-
*/
|
|
193
|
-
getGenerator(overrideMode) {
|
|
194
|
-
var count = 0;
|
|
195
|
-
var identifiers = new Set();
|
|
196
|
-
return {
|
|
197
|
-
generate: () => {
|
|
198
|
-
var retValue;
|
|
199
|
-
do {
|
|
200
|
-
count++;
|
|
201
|
-
retValue = this.generateIdentifier(-1, count, overrideMode);
|
|
202
|
-
} while (identifiers.has(retValue));
|
|
203
|
-
identifiers.add(retValue);
|
|
204
|
-
return retValue;
|
|
205
|
-
}
|
|
206
|
-
};
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
/**
|
|
210
|
-
* Generates a valid variable name.
|
|
211
|
-
* @param length Default length is 6 to 10 characters.
|
|
212
|
-
* @returns **`string`**
|
|
213
|
-
*/
|
|
214
|
-
generateIdentifier() {
|
|
215
|
-
let length = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : -1;
|
|
216
|
-
let count = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : -1;
|
|
217
|
-
let overrideMode = arguments.length > 2 ? arguments[2] : undefined;
|
|
218
|
-
if (length == -1) {
|
|
219
|
-
length = (0, _random.getRandomInteger)(6, 8);
|
|
220
|
-
}
|
|
221
|
-
var set = new Set();
|
|
222
|
-
if (count == -1) {
|
|
223
|
-
this.obfuscator.varCount++;
|
|
224
|
-
count = this.obfuscator.varCount;
|
|
225
|
-
set = this.obfuscator.generated;
|
|
226
|
-
}
|
|
227
|
-
var identifier;
|
|
228
|
-
do {
|
|
229
|
-
identifier = (0, _probability.ComputeProbabilityMap)(overrideMode || this.options.identifierGenerator, function () {
|
|
230
|
-
let mode = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "randomized";
|
|
231
|
-
switch (mode) {
|
|
232
|
-
case "randomized":
|
|
233
|
-
var characters = "_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");
|
|
234
|
-
var numbers = "0123456789".split("");
|
|
235
|
-
var combined = [...characters, ...numbers];
|
|
236
|
-
var result = "";
|
|
237
|
-
for (var i = 0; i < length; i++) {
|
|
238
|
-
result += (0, _random.choice)(i == 0 ? characters : combined);
|
|
239
|
-
}
|
|
240
|
-
return result;
|
|
241
|
-
case "hexadecimal":
|
|
242
|
-
const genRanHex = size => [...Array(size)].map(() => Math.floor(Math.random() * 16).toString(16)).join("");
|
|
243
|
-
return "_0x" + genRanHex(length).toUpperCase();
|
|
244
|
-
case "mangled":
|
|
245
|
-
while (1) {
|
|
246
|
-
var result = (0, _random.alphabeticalGenerator)(count);
|
|
247
|
-
count++;
|
|
248
|
-
if (_constants.reservedKeywords.has(result) || _constants.reservedIdentifiers.has(result)) {} else {
|
|
249
|
-
return result;
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
throw new Error("impossible but TypeScript insists");
|
|
253
|
-
case "number":
|
|
254
|
-
return "var_" + count;
|
|
255
|
-
case "zeroWidth":
|
|
256
|
-
var keyWords = ["if", "in", "for", "let", "new", "try", "var", "case", "else", "null", "break", "catch", "class", "const", "super", "throw", "while", "yield", "delete", "export", "import", "public", "return", "switch", "default", "finally", "private", "continue", "debugger", "function", "arguments", "protected", "instanceof", "function", "await", "async"];
|
|
257
|
-
var safe = "\u200C".repeat(count + 1);
|
|
258
|
-
var base = (0, _random.choice)(keyWords) + safe;
|
|
259
|
-
return base;
|
|
260
|
-
}
|
|
261
|
-
throw new Error("Invalid 'identifierGenerator' mode: " + mode);
|
|
262
|
-
});
|
|
263
|
-
} while (set.has(identifier));
|
|
264
|
-
if (!identifier) {
|
|
265
|
-
throw new Error("identifier null");
|
|
266
|
-
}
|
|
267
|
-
set.add(identifier);
|
|
268
|
-
return identifier;
|
|
269
|
-
}
|
|
270
|
-
/**
|
|
271
|
-
* Smartly appends a comment to a Node.
|
|
272
|
-
* - Includes the transformation's name.
|
|
273
|
-
* @param node
|
|
274
|
-
* @param text
|
|
275
|
-
* @param i
|
|
276
|
-
*/
|
|
277
|
-
addComment(node, text) {
|
|
278
|
-
if (this.options.debugComments) {
|
|
279
|
-
return (0, _gen.AddComment)(node, `[${this.className}] ${text}`);
|
|
280
|
-
}
|
|
281
|
-
return node;
|
|
282
|
-
}
|
|
283
|
-
replace(node1, node2) {
|
|
284
|
-
for (var key in node1) {
|
|
285
|
-
delete node1[key];
|
|
286
|
-
}
|
|
287
|
-
this.objectAssign(node1, node2);
|
|
288
|
-
}
|
|
289
|
-
replaceIdentifierOrLiteral(node1, node2, parents) {
|
|
290
|
-
// Fix 2. Make parent property key computed
|
|
291
|
-
if (parents[0] && (parents[0].type == "Property" || parents[0].type == "MethodDefinition") && parents[0].key == node1) {
|
|
292
|
-
parents[0].computed = true;
|
|
293
|
-
parents[0].shorthand = false;
|
|
294
|
-
}
|
|
295
|
-
this.replace(node1, node2);
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
/**
|
|
299
|
-
* Smartly merges two Nodes.
|
|
300
|
-
* - Null checking
|
|
301
|
-
* - Preserves comments
|
|
302
|
-
* @param node1
|
|
303
|
-
* @param node2
|
|
304
|
-
*/
|
|
305
|
-
objectAssign(node1, node2) {
|
|
306
|
-
(0, _assert.ok)(node1);
|
|
307
|
-
(0, _assert.ok)(node2);
|
|
308
|
-
var comments1 = node1.leadingComments || [];
|
|
309
|
-
var comments2 = node2.leadingComments || [];
|
|
310
|
-
var comments = [...comments1, ...comments2];
|
|
311
|
-
node2.leadingComments = comments;
|
|
312
|
-
node1._transform = node2._transform = this.className;
|
|
313
|
-
return Object.assign(node1, node2);
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
/**
|
|
317
|
-
* Verbose logging for this transformation.
|
|
318
|
-
* @param messages
|
|
319
|
-
*/
|
|
320
|
-
log() {
|
|
321
|
-
if (this.options.verbose) {
|
|
322
|
-
for (var _len = arguments.length, messages = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
323
|
-
messages[_key] = arguments[_key];
|
|
324
|
-
}
|
|
325
|
-
console.log("[" + this.className + "]", ...messages);
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
|
|
329
|
-
/**
|
|
330
|
-
* Verbose logging for warning/important messages.
|
|
331
|
-
* @param messages
|
|
332
|
-
*/
|
|
333
|
-
warn() {
|
|
334
|
-
if (this.options.verbose) {
|
|
335
|
-
for (var _len2 = arguments.length, messages = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
|
336
|
-
messages[_key2] = arguments[_key2];
|
|
337
|
-
}
|
|
338
|
-
console.log("[ WARN " + this.className + " ]", ...messages);
|
|
339
|
-
}
|
|
340
|
-
}
|
|
341
|
-
|
|
342
|
-
/**
|
|
343
|
-
* Throws an error. Appends the transformation's name to the error's message.
|
|
344
|
-
* @param error
|
|
345
|
-
*/
|
|
346
|
-
error(error) {
|
|
347
|
-
throw new Error(`${this.className} Error: ${error.message}`);
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
exports.default = Transform;
|