js-confuser 1.7.3 → 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/CHANGELOG.md +70 -0
- package/Migration.md +57 -0
- package/README.md +23 -929
- package/dist/constants.js +65 -14
- package/dist/index.js +108 -160
- package/dist/obfuscator.js +316 -118
- package/dist/options.js +1 -119
- 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 +199 -184
- 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 -587
- package/dist/transforms/dispatcher.js +300 -313
- 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 +214 -135
- package/dist/transforms/identifier/movedDeclarations.js +167 -91
- package/dist/transforms/identifier/renameVariables.js +239 -193
- package/dist/transforms/lock/integrity.js +61 -184
- package/dist/transforms/lock/lock.js +261 -387
- 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 +261 -173
- package/dist/transforms/renameLabels.js +132 -56
- package/dist/transforms/rgf.js +140 -267
- package/dist/transforms/shuffle.js +52 -145
- package/dist/transforms/string/encoding.js +44 -175
- package/dist/transforms/string/stringCompression.js +79 -155
- package/dist/transforms/string/stringConcealing.js +189 -225
- 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 -82
- package/src/index.ts +70 -165
- package/src/obfuscationResult.ts +43 -0
- package/src/obfuscator.ts +328 -135
- package/src/options.ts +149 -658
- package/src/order.ts +14 -14
- package/src/presets.ts +39 -34
- package/src/probability.ts +21 -36
- package/src/templates/bufferToStringTemplate.ts +57 -0
- 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 +149 -157
- package/src/transforms/astScrambler.ts +99 -0
- package/src/transforms/calculator.ts +96 -226
- package/src/transforms/controlFlowFlattening.ts +1594 -0
- package/src/transforms/deadCode.ts +85 -676
- package/src/transforms/dispatcher.ts +431 -640
- package/src/transforms/extraction/duplicateLiteralsRemoval.ts +147 -295
- 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 +255 -266
- package/src/transforms/identifier/movedDeclarations.ts +228 -142
- package/src/transforms/identifier/renameVariables.ts +250 -271
- package/src/transforms/lock/integrity.ts +85 -263
- package/src/transforms/lock/lock.ts +338 -579
- 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 -231
- package/src/transforms/renameLabels.ts +176 -77
- package/src/transforms/rgf.ts +293 -424
- package/src/transforms/shuffle.ts +80 -254
- package/src/transforms/string/encoding.ts +20 -126
- package/src/transforms/string/stringCompression.ts +117 -307
- package/src/transforms/string/stringConcealing.ts +254 -342
- 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 -129
- package/dist/templates/core.js +0 -35
- package/dist/templates/crash.js +0 -28
- 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 -1287
- 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 -83
- package/dist/transforms/identifier/variableAnalysis.js +0 -104
- package/dist/transforms/lock/antiDebug.js +0 -76
- package/dist/transforms/stack.js +0 -349
- package/dist/transforms/transform.js +0 -372
- 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 -14
- 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 -156
- package/dist/util/scope.js +0 -20
- package/docs/ControlFlowFlattening.md +0 -595
- package/docs/Countermeasures.md +0 -70
- package/docs/ES5.md +0 -197
- package/docs/Integrity.md +0 -82
- package/docs/RGF.md +0 -424
- package/docs/RenameVariables.md +0 -116
- package/docs/TamperProtection.md +0 -100
- package/docs/Template.md +0 -117
- 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/bufferToString.ts +0 -136
- package/src/templates/core.ts +0 -29
- package/src/templates/crash.ts +0 -23
- 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 -2153
- package/src/transforms/controlFlowFlattening/expressionObfuscation.ts +0 -179
- package/src/transforms/es5/antiClass.ts +0 -276
- 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 -102
- package/src/transforms/identifier/variableAnalysis.ts +0 -118
- package/src/transforms/lock/antiDebug.ts +0 -112
- package/src/transforms/stack.ts +0 -557
- package/src/transforms/transform.ts +0 -441
- package/src/traverse.ts +0 -120
- package/src/types.ts +0 -133
- package/src/util/compare.ts +0 -181
- package/src/util/gen.ts +0 -651
- package/src/util/guard.ts +0 -17
- 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 -221
- package/src/util/scope.ts +0 -21
- package/test/code/Cash.src.js +0 -1011
- package/test/code/Cash.test.ts +0 -132
- 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 -150
- package/test/presets.test.ts +0 -22
- package/test/probability.test.ts +0 -44
- package/test/templates/template.test.ts +0 -224
- 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 -142
- package/test/transforms/identifier/movedDeclarations.test.ts +0 -275
- package/test/transforms/identifier/renameVariables.test.ts +0 -695
- 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/lock/tamperProtection.test.ts +0 -336
- 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
|
@@ -1,441 +0,0 @@
|
|
|
1
|
-
import traverse, { ExitCallback } from "../traverse";
|
|
2
|
-
import {
|
|
3
|
-
AddComment,
|
|
4
|
-
Node,
|
|
5
|
-
VariableDeclaration,
|
|
6
|
-
VariableDeclarator,
|
|
7
|
-
} from "../util/gen";
|
|
8
|
-
import {
|
|
9
|
-
alphabeticalGenerator,
|
|
10
|
-
choice,
|
|
11
|
-
createZeroWidthGenerator,
|
|
12
|
-
getRandomInteger,
|
|
13
|
-
shuffle,
|
|
14
|
-
} from "../util/random";
|
|
15
|
-
import { ok } from "assert";
|
|
16
|
-
import Obfuscator from "../obfuscator";
|
|
17
|
-
import { ComputeProbabilityMap } from "../probability";
|
|
18
|
-
import {
|
|
19
|
-
placeholderVariablePrefix,
|
|
20
|
-
reservedIdentifiers,
|
|
21
|
-
reservedKeywords,
|
|
22
|
-
} from "../constants";
|
|
23
|
-
import { ObfuscateOrder } from "../order";
|
|
24
|
-
import { prepend } from "../util/insert";
|
|
25
|
-
import Lock from "./lock/lock";
|
|
26
|
-
import Template from "../templates/template";
|
|
27
|
-
|
|
28
|
-
/**
|
|
29
|
-
* Base-class for all transformations.
|
|
30
|
-
* - Transformations can have preparation transformations `.before`
|
|
31
|
-
* - Transformations can have cleanup transformations `.after`
|
|
32
|
-
*
|
|
33
|
-
* - `match()` function returns true/false if possible candidate
|
|
34
|
-
* - `transform()` function modifies the object
|
|
35
|
-
*
|
|
36
|
-
* ```js
|
|
37
|
-
* class Example extends Transform {
|
|
38
|
-
* constructor(o){
|
|
39
|
-
* super(o);
|
|
40
|
-
* }
|
|
41
|
-
*
|
|
42
|
-
* match(object, parents){
|
|
43
|
-
* return object.type == "...";
|
|
44
|
-
* }
|
|
45
|
-
*
|
|
46
|
-
* transform(object, parents){
|
|
47
|
-
* // onEnter
|
|
48
|
-
*
|
|
49
|
-
* return ()=>{
|
|
50
|
-
* // onExit
|
|
51
|
-
* }
|
|
52
|
-
* }
|
|
53
|
-
*
|
|
54
|
-
* apply(tree){
|
|
55
|
-
* // onStart
|
|
56
|
-
*
|
|
57
|
-
* super.apply(tree);
|
|
58
|
-
*
|
|
59
|
-
* // onEnd
|
|
60
|
-
* }
|
|
61
|
-
* }
|
|
62
|
-
* ```
|
|
63
|
-
*/
|
|
64
|
-
export default class Transform {
|
|
65
|
-
/**
|
|
66
|
-
* The obfuscator.
|
|
67
|
-
*/
|
|
68
|
-
obfuscator: Obfuscator;
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* The user's options.
|
|
72
|
-
*/
|
|
73
|
-
options: Obfuscator["options"];
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* Only required for top-level transformations.
|
|
77
|
-
*/
|
|
78
|
-
priority: number;
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* Transforms to run before, such as `Variable Analysis`.
|
|
82
|
-
*/
|
|
83
|
-
before: Transform[];
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* Transforms to run after.
|
|
87
|
-
*/
|
|
88
|
-
after: Transform[];
|
|
89
|
-
|
|
90
|
-
initVariables = new Map<string, string>();
|
|
91
|
-
|
|
92
|
-
zeroWidthGenerator = createZeroWidthGenerator();
|
|
93
|
-
|
|
94
|
-
constructor(obfuscator, priority: number = -1) {
|
|
95
|
-
ok(obfuscator instanceof Obfuscator, "obfuscator should be an Obfuscator");
|
|
96
|
-
|
|
97
|
-
this.obfuscator = obfuscator;
|
|
98
|
-
this.options = this.obfuscator.options;
|
|
99
|
-
|
|
100
|
-
this.priority = priority;
|
|
101
|
-
|
|
102
|
-
this.before = [];
|
|
103
|
-
this.after = [];
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* The transformation name.
|
|
108
|
-
*/
|
|
109
|
-
get className() {
|
|
110
|
-
return (
|
|
111
|
-
ObfuscateOrder[this.priority] || (this as any).__proto__.constructor.name
|
|
112
|
-
);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
/**
|
|
116
|
-
* Gets the `Lock` transformation.
|
|
117
|
-
*/
|
|
118
|
-
get lockTransform(): Lock {
|
|
119
|
-
var transform = this.obfuscator.transforms["Lock"] as Lock;
|
|
120
|
-
|
|
121
|
-
ok(transform, "Lock transform not created");
|
|
122
|
-
|
|
123
|
-
return transform;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* Wraps the given name with the `__JS_CONFUSER_VAR__` function call.
|
|
128
|
-
*
|
|
129
|
-
* If `Rename Variables` is disabled, the name is returned as-is.
|
|
130
|
-
* @param name
|
|
131
|
-
* @returns
|
|
132
|
-
*/
|
|
133
|
-
jsConfuserVar(name: string) {
|
|
134
|
-
if (!this.obfuscator.transforms["RenameVariables"]) {
|
|
135
|
-
return `"${name}"`;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
return `__JS_CONFUSER_VAR__(${name})`;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
/**
|
|
142
|
-
* Run an AST through the transformation (including `pre` and `post` transforms)
|
|
143
|
-
* @param tree
|
|
144
|
-
*/
|
|
145
|
-
apply(tree: Node) {
|
|
146
|
-
if (tree.type == "Program" && this.options.verbose) {
|
|
147
|
-
if (this.priority === -1) {
|
|
148
|
-
console.log("#", ">", this.className);
|
|
149
|
-
} else {
|
|
150
|
-
console.log("#", this.priority, this.className);
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
/**
|
|
155
|
-
* Run through pre-transformations
|
|
156
|
-
*/
|
|
157
|
-
this.before.forEach((x) => x.apply(tree));
|
|
158
|
-
|
|
159
|
-
/**
|
|
160
|
-
* Run this transformation
|
|
161
|
-
*/
|
|
162
|
-
traverse(tree, (object, parents) => {
|
|
163
|
-
return this.input(object, parents);
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
/**
|
|
167
|
-
* Cleanup transformations
|
|
168
|
-
*/
|
|
169
|
-
this.after.forEach((x) => x.apply(tree));
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
/**
|
|
173
|
-
* The `match` function filters for possible candidates.
|
|
174
|
-
*
|
|
175
|
-
* - If `true`, the node is sent to the `transform()` method
|
|
176
|
-
* - else it's discarded.
|
|
177
|
-
*
|
|
178
|
-
* @param object
|
|
179
|
-
* @param parents
|
|
180
|
-
* @param block
|
|
181
|
-
*/
|
|
182
|
-
match(object: Node, parents: Node[]): boolean {
|
|
183
|
-
throw new Error("not implemented");
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
/**
|
|
187
|
-
* Modifies the given node.
|
|
188
|
-
*
|
|
189
|
-
* - Return a function to be ran when the node is exited.
|
|
190
|
-
* - The node is safe to modify in most cases.
|
|
191
|
-
*
|
|
192
|
-
* @param object - Current node
|
|
193
|
-
* @param parents - Array of ancestors `[Closest, ..., Root]`
|
|
194
|
-
* @param block
|
|
195
|
-
*/
|
|
196
|
-
transform(object: Node, parents: Node[]): ExitCallback | void {
|
|
197
|
-
throw new Error("not implemented");
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
/**
|
|
201
|
-
* Calls `.match` with the given parameters, and then `.transform` if satisfied.
|
|
202
|
-
* @private
|
|
203
|
-
*/
|
|
204
|
-
input(object: Node, parents: Node[]): ExitCallback | void {
|
|
205
|
-
if (this.match(object, parents)) {
|
|
206
|
-
return this.transform(object, parents);
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
/**
|
|
211
|
-
* Returns a random string.
|
|
212
|
-
*
|
|
213
|
-
* Used for creating temporary variables names, typically before RenameVariables has ran.
|
|
214
|
-
*
|
|
215
|
-
* These long temp names will be converted to short, mangled names by RenameVariables.
|
|
216
|
-
*/
|
|
217
|
-
getPlaceholder() {
|
|
218
|
-
const genRanHex = (size) =>
|
|
219
|
-
[...Array(size)]
|
|
220
|
-
.map(() => Math.floor(Math.random() * 10).toString(10))
|
|
221
|
-
.join("");
|
|
222
|
-
return placeholderVariablePrefix + genRanHex(10);
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
/**
|
|
226
|
-
* Returns an independent name generator with it's own counter.
|
|
227
|
-
* @param overrideMode - Override the user's `identifierGenerator` option
|
|
228
|
-
* @returns
|
|
229
|
-
*/
|
|
230
|
-
getGenerator(overrideMode?: string) {
|
|
231
|
-
var count = 0;
|
|
232
|
-
var identifiers = new Set();
|
|
233
|
-
return {
|
|
234
|
-
generate: () => {
|
|
235
|
-
var retValue: string;
|
|
236
|
-
do {
|
|
237
|
-
count++;
|
|
238
|
-
retValue = this.generateIdentifier(-1, count, overrideMode);
|
|
239
|
-
} while (identifiers.has(retValue));
|
|
240
|
-
|
|
241
|
-
identifiers.add(retValue);
|
|
242
|
-
|
|
243
|
-
return retValue;
|
|
244
|
-
},
|
|
245
|
-
};
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
/**
|
|
249
|
-
* Generates a valid variable name.
|
|
250
|
-
* @param length Default length is 6 to 10 characters.
|
|
251
|
-
* @returns **`string`**
|
|
252
|
-
*/
|
|
253
|
-
generateIdentifier(
|
|
254
|
-
length: number = -1,
|
|
255
|
-
count = -1,
|
|
256
|
-
overrideMode?: string
|
|
257
|
-
): string {
|
|
258
|
-
if (length == -1) {
|
|
259
|
-
length = getRandomInteger(6, 8);
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
var set = new Set();
|
|
263
|
-
|
|
264
|
-
if (count == -1) {
|
|
265
|
-
this.obfuscator.varCount++;
|
|
266
|
-
count = this.obfuscator.varCount;
|
|
267
|
-
set = this.obfuscator.generated;
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
var identifier;
|
|
271
|
-
do {
|
|
272
|
-
identifier = ComputeProbabilityMap(
|
|
273
|
-
overrideMode || this.options.identifierGenerator,
|
|
274
|
-
(mode = "randomized") => {
|
|
275
|
-
switch (mode) {
|
|
276
|
-
case "randomized":
|
|
277
|
-
var characters =
|
|
278
|
-
"_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(
|
|
279
|
-
""
|
|
280
|
-
);
|
|
281
|
-
var numbers = "0123456789".split("");
|
|
282
|
-
|
|
283
|
-
var combined = [...characters, ...numbers];
|
|
284
|
-
|
|
285
|
-
var result = "";
|
|
286
|
-
for (var i = 0; i < length; i++) {
|
|
287
|
-
result += choice(i == 0 ? characters : combined);
|
|
288
|
-
}
|
|
289
|
-
return result;
|
|
290
|
-
|
|
291
|
-
case "hexadecimal":
|
|
292
|
-
const genRanHex = (size) =>
|
|
293
|
-
[...Array(size)]
|
|
294
|
-
.map(() => Math.floor(Math.random() * 16).toString(16))
|
|
295
|
-
.join("");
|
|
296
|
-
|
|
297
|
-
return "_0x" + genRanHex(length).toUpperCase();
|
|
298
|
-
|
|
299
|
-
case "mangled":
|
|
300
|
-
while (1) {
|
|
301
|
-
var result = alphabeticalGenerator(count);
|
|
302
|
-
count++;
|
|
303
|
-
|
|
304
|
-
if (
|
|
305
|
-
reservedKeywords.has(result) ||
|
|
306
|
-
reservedIdentifiers.has(result)
|
|
307
|
-
) {
|
|
308
|
-
} else {
|
|
309
|
-
return result;
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
|
|
313
|
-
throw new Error("impossible but TypeScript insists");
|
|
314
|
-
|
|
315
|
-
case "number":
|
|
316
|
-
return "var_" + count;
|
|
317
|
-
|
|
318
|
-
case "zeroWidth":
|
|
319
|
-
return this.zeroWidthGenerator.generate();
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
throw new Error("Invalid 'identifierGenerator' mode: " + mode);
|
|
323
|
-
}
|
|
324
|
-
);
|
|
325
|
-
} while (set.has(identifier));
|
|
326
|
-
|
|
327
|
-
if (!identifier) {
|
|
328
|
-
throw new Error("identifier null");
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
set.add(identifier);
|
|
332
|
-
|
|
333
|
-
return identifier;
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
createInitVariable = (value: Template, parents: Node[]) => {
|
|
337
|
-
var key = value.templates[0];
|
|
338
|
-
if (this.initVariables.has(key)) {
|
|
339
|
-
return this.initVariables.get(key);
|
|
340
|
-
}
|
|
341
|
-
|
|
342
|
-
var root = parents[parents.length - 1];
|
|
343
|
-
ok(root.type === "Program");
|
|
344
|
-
|
|
345
|
-
var name = this.getPlaceholder();
|
|
346
|
-
this.initVariables.set(key, name);
|
|
347
|
-
|
|
348
|
-
prepend(
|
|
349
|
-
root,
|
|
350
|
-
VariableDeclaration(VariableDeclarator(name, value.single().expression))
|
|
351
|
-
);
|
|
352
|
-
|
|
353
|
-
return name;
|
|
354
|
-
};
|
|
355
|
-
|
|
356
|
-
/**
|
|
357
|
-
* Smartly appends a comment to a Node.
|
|
358
|
-
* - Includes the transformation's name.
|
|
359
|
-
* @param node
|
|
360
|
-
* @param text
|
|
361
|
-
* @param i
|
|
362
|
-
*/
|
|
363
|
-
addComment(node: Node, text: string) {
|
|
364
|
-
if (this.options.debugComments) {
|
|
365
|
-
return AddComment(node, `[${this.className}] ${text}`);
|
|
366
|
-
}
|
|
367
|
-
return node;
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
replace(node1: Node, node2: Node) {
|
|
371
|
-
for (var key in node1) {
|
|
372
|
-
delete node1[key];
|
|
373
|
-
}
|
|
374
|
-
|
|
375
|
-
this.objectAssign(node1, node2);
|
|
376
|
-
}
|
|
377
|
-
|
|
378
|
-
replaceIdentifierOrLiteral(node1: Node, node2: Node, parents: Node[]) {
|
|
379
|
-
// Fix 2. Make parent property key computed
|
|
380
|
-
if (
|
|
381
|
-
parents[0] &&
|
|
382
|
-
(parents[0].type == "Property" ||
|
|
383
|
-
parents[0].type == "MethodDefinition") &&
|
|
384
|
-
parents[0].key == node1
|
|
385
|
-
) {
|
|
386
|
-
parents[0].computed = true;
|
|
387
|
-
parents[0].shorthand = false;
|
|
388
|
-
}
|
|
389
|
-
this.replace(node1, node2);
|
|
390
|
-
}
|
|
391
|
-
|
|
392
|
-
/**
|
|
393
|
-
* Smartly merges two Nodes.
|
|
394
|
-
* - Null checking
|
|
395
|
-
* - Preserves comments
|
|
396
|
-
* @param node1
|
|
397
|
-
* @param node2
|
|
398
|
-
*/
|
|
399
|
-
objectAssign(node1: Node, node2: Node): Node {
|
|
400
|
-
ok(node1);
|
|
401
|
-
ok(node2);
|
|
402
|
-
|
|
403
|
-
var comments1 = node1.leadingComments || [];
|
|
404
|
-
var comments2 = node2.leadingComments || [];
|
|
405
|
-
var comments = [...comments1, ...comments2];
|
|
406
|
-
|
|
407
|
-
node2.leadingComments = comments;
|
|
408
|
-
|
|
409
|
-
node1._transform = node2._transform = this.className;
|
|
410
|
-
|
|
411
|
-
return Object.assign(node1, node2);
|
|
412
|
-
}
|
|
413
|
-
|
|
414
|
-
/**
|
|
415
|
-
* Verbose logging for this transformation.
|
|
416
|
-
* @param messages
|
|
417
|
-
*/
|
|
418
|
-
log(...messages: any[]) {
|
|
419
|
-
if (this.options.verbose) {
|
|
420
|
-
console.log("[" + this.className + "]", ...messages);
|
|
421
|
-
}
|
|
422
|
-
}
|
|
423
|
-
|
|
424
|
-
/**
|
|
425
|
-
* Verbose logging for warning/important messages.
|
|
426
|
-
* @param messages
|
|
427
|
-
*/
|
|
428
|
-
warn(...messages: any[]) {
|
|
429
|
-
if (this.options.verbose) {
|
|
430
|
-
console.log("[ WARN " + this.className + " ]", ...messages);
|
|
431
|
-
}
|
|
432
|
-
}
|
|
433
|
-
|
|
434
|
-
/**
|
|
435
|
-
* Throws an error. Appends the transformation's name to the error's message.
|
|
436
|
-
* @param error
|
|
437
|
-
*/
|
|
438
|
-
error(error: Error): never {
|
|
439
|
-
throw new Error(`${this.className} Error: ${error.message}`);
|
|
440
|
-
}
|
|
441
|
-
}
|
package/src/traverse.ts
DELETED
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
import { Node } from "./util/gen";
|
|
2
|
-
import { validateChain } from "./util/identifiers";
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* A block refers to any object that has a **`.body`** property where code is nested.
|
|
6
|
-
*
|
|
7
|
-
* Types: `BlockStatement`, `Program`
|
|
8
|
-
*
|
|
9
|
-
* @param object
|
|
10
|
-
* @param parents
|
|
11
|
-
*/
|
|
12
|
-
export function getBlock(object: any, parents: any[]) {
|
|
13
|
-
if (!Array.isArray(parents)) {
|
|
14
|
-
throw new Error("parents must be an array");
|
|
15
|
-
}
|
|
16
|
-
return [object, ...parents].find((node) => isBlock(node));
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Must have a **`.body`** property and be an array.
|
|
21
|
-
*
|
|
22
|
-
* - "BlockStatement"
|
|
23
|
-
* - "Program"
|
|
24
|
-
*
|
|
25
|
-
* @param object
|
|
26
|
-
*/
|
|
27
|
-
export function isBlock(object: any) {
|
|
28
|
-
return (
|
|
29
|
-
object && (object.type == "BlockStatement" || object.type == "Program")
|
|
30
|
-
);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
export type EnterCallback = (
|
|
34
|
-
object: Node,
|
|
35
|
-
parents: Node[]
|
|
36
|
-
) => ExitCallback | "EXIT" | void;
|
|
37
|
-
export type ExitCallback = () => void;
|
|
38
|
-
|
|
39
|
-
export function walk(
|
|
40
|
-
object: Node | Node[],
|
|
41
|
-
parents: Node[],
|
|
42
|
-
onEnter: EnterCallback
|
|
43
|
-
): "EXIT" | void {
|
|
44
|
-
if (typeof object === "object" && object) {
|
|
45
|
-
var newParents: Node[] = [object as Node, ...parents];
|
|
46
|
-
|
|
47
|
-
// if (!Array.isArray(object)) {
|
|
48
|
-
// validateChain(object, parents);
|
|
49
|
-
// }
|
|
50
|
-
|
|
51
|
-
// 1. Call `onEnter` function and remember any onExit callback returned
|
|
52
|
-
var onExit = onEnter(object as Node, parents);
|
|
53
|
-
|
|
54
|
-
// 2. Traverse children
|
|
55
|
-
if (Array.isArray(object)) {
|
|
56
|
-
var copy = [...object];
|
|
57
|
-
for (var element of copy) {
|
|
58
|
-
if (walk(element, newParents, onEnter) === "EXIT") {
|
|
59
|
-
return "EXIT";
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
} else {
|
|
63
|
-
var keys = Object.keys(object);
|
|
64
|
-
for (var key of keys) {
|
|
65
|
-
if (!key.startsWith("$")) {
|
|
66
|
-
if (walk(object[key], newParents, onEnter) === "EXIT") {
|
|
67
|
-
return "EXIT";
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
if (onExit === "EXIT") {
|
|
74
|
-
return "EXIT";
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
// 3. Done with children, call `onExit` callback
|
|
78
|
-
if (onExit) {
|
|
79
|
-
onExit();
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
/**
|
|
85
|
-
* The bare-bones walker.
|
|
86
|
-
*
|
|
87
|
-
* - Recursively traverse an AST object.
|
|
88
|
-
* - Calls the `onEnter` function with:
|
|
89
|
-
* - - `object` - The current node
|
|
90
|
-
* - - `parents` - Array of ancestors `[closest, ..., root]`
|
|
91
|
-
* - The `onEnter` callback can return an `onExit` callback for that node.
|
|
92
|
-
*
|
|
93
|
-
* - *Note*: Does not validate the property names.
|
|
94
|
-
*
|
|
95
|
-
* @param tree
|
|
96
|
-
* @param onEnter
|
|
97
|
-
*/
|
|
98
|
-
export default function traverse(tree, onEnter: EnterCallback) {
|
|
99
|
-
walk(tree, [], onEnter);
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* This is debugging function used to test for circular references.
|
|
104
|
-
*/
|
|
105
|
-
export function assertNoCircular(object) {
|
|
106
|
-
var seen = new Set();
|
|
107
|
-
|
|
108
|
-
traverse(object, (node, nodeParents) => {
|
|
109
|
-
if (node && typeof node === "object") {
|
|
110
|
-
if (seen.has(node)) {
|
|
111
|
-
console.log(nodeParents);
|
|
112
|
-
console.log(node);
|
|
113
|
-
|
|
114
|
-
throw new Error("FOUND CIRCULAR REFERENCE");
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
seen.add(node);
|
|
118
|
-
}
|
|
119
|
-
});
|
|
120
|
-
}
|
package/src/types.ts
DELETED
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import Obfuscator from "./obfuscator";
|
|
2
|
-
import { ObfuscateOptions } from "./options";
|
|
3
|
-
import Template from "./templates/template";
|
|
4
|
-
import Transform from "./transforms/transform";
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* **JsConfuser**: Obfuscates JavaScript.
|
|
8
|
-
* @param code - The code to be obfuscated.
|
|
9
|
-
* @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
|
|
10
|
-
*
|
|
11
|
-
* [See all settings here](https://github.com/MichaelXF/js-confuser#options)
|
|
12
|
-
*/
|
|
13
|
-
export interface IJsConfuser {
|
|
14
|
-
obfuscate: IJsConfuserObfuscate;
|
|
15
|
-
obfuscateAST: IJsConfuserObfuscateAST;
|
|
16
|
-
|
|
17
|
-
presets: IJsConfuserPresets;
|
|
18
|
-
debugTransformations: IJsConfuserDebugTransformations;
|
|
19
|
-
debugObfuscation: IJsConfuserDebugObfuscation;
|
|
20
|
-
|
|
21
|
-
(code: string, options: ObfuscateOptions): Promise<string>;
|
|
22
|
-
|
|
23
|
-
Transform: typeof Transform;
|
|
24
|
-
Obfuscator: typeof Obfuscator;
|
|
25
|
-
Template: typeof Template;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
/**
|
|
29
|
-
* **JsConfuser**: Obfuscates JavaScript.
|
|
30
|
-
* @param code - The code to be obfuscated.
|
|
31
|
-
* @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
|
|
32
|
-
*
|
|
33
|
-
* [See all settings here](https://github.com/MichaelXF/js-confuser#options)
|
|
34
|
-
*/
|
|
35
|
-
export interface IJsConfuserObfuscate {
|
|
36
|
-
(code: string, options: ObfuscateOptions): Promise<string>;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Obfuscates an [ESTree](https://github.com/estree/estree) compliant AST.
|
|
41
|
-
*
|
|
42
|
-
* **Note:** Mutates the object.
|
|
43
|
-
*
|
|
44
|
-
* @param AST - The [ESTree](https://github.com/estree/estree) compliant AST. This object will be mutated.
|
|
45
|
-
* @param options - The obfuscation options.
|
|
46
|
-
*
|
|
47
|
-
* [See all settings here](https://github.com/MichaelXF/js-confuser#options)
|
|
48
|
-
*/
|
|
49
|
-
export interface IJsConfuserObfuscateAST {
|
|
50
|
-
(AST: any, options: ObfuscateOptions): Promise<void>;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
export interface IJsConfuserPresets {
|
|
54
|
-
high: ObfuscateOptions;
|
|
55
|
-
medium: ObfuscateOptions;
|
|
56
|
-
low: ObfuscateOptions;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
/**
|
|
60
|
-
* Obfuscates code but returns an array of `frames`
|
|
61
|
-
*
|
|
62
|
-
* ```js
|
|
63
|
-
* [
|
|
64
|
-
* {
|
|
65
|
-
* name: "Preparation",
|
|
66
|
-
* code: "console['log']('Hello World')",
|
|
67
|
-
* ms: 4
|
|
68
|
-
* }, {
|
|
69
|
-
* name: "ControlFlowFlattening",
|
|
70
|
-
* code: "var....",
|
|
71
|
-
* ms: 400
|
|
72
|
-
* },
|
|
73
|
-
* // ....
|
|
74
|
-
* ]
|
|
75
|
-
* ```
|
|
76
|
-
*/
|
|
77
|
-
export type IJsConfuserDebugTransformations = (
|
|
78
|
-
code: string,
|
|
79
|
-
options: ObfuscateOptions
|
|
80
|
-
) => Promise<{ name: string; code: string; ms: number }[]>;
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Obfuscates code but calls the callback function after each transform.
|
|
84
|
-
*
|
|
85
|
-
* This is used to display a progress bar to the user on the official website.
|
|
86
|
-
*
|
|
87
|
-
* `callback(name: string, complete: number, totalTransforms: number)`
|
|
88
|
-
*
|
|
89
|
-
* ```js
|
|
90
|
-
* var callback = (name, complete, totalTransforms) => {
|
|
91
|
-
* console.log(name, complete, totalTransforms)
|
|
92
|
-
* };
|
|
93
|
-
* ```
|
|
94
|
-
*
|
|
95
|
-
* ```js
|
|
96
|
-
* // Preparation 1 22
|
|
97
|
-
* // ObjectExtraction 2 22
|
|
98
|
-
* // Flatten 3 22
|
|
99
|
-
* // Dispatcher 4 22
|
|
100
|
-
* // DeadCode 5 22
|
|
101
|
-
* // Calculator 6 22
|
|
102
|
-
* // ControlFlowFlattening 7 22
|
|
103
|
-
* // GlobalConcealing 8 22
|
|
104
|
-
* // OpaquePredicates 9 22
|
|
105
|
-
* // StringSplitting 10 22
|
|
106
|
-
* // StringConcealing 11 22
|
|
107
|
-
* // StringCompression 12 22
|
|
108
|
-
* // HideInitializingCode 13 22
|
|
109
|
-
* // Stack 14 22
|
|
110
|
-
* // DuplicateLiteralsRemoval 15 22
|
|
111
|
-
* // Shuffle 16 22
|
|
112
|
-
* // MovedDeclarations 17 22
|
|
113
|
-
* // RenameVariables 18 22
|
|
114
|
-
* // RenameLabels 19 22
|
|
115
|
-
* // Minify 20 22
|
|
116
|
-
* // StringEncoding 21 22
|
|
117
|
-
* // AntiTooling 22 22
|
|
118
|
-
* ```
|
|
119
|
-
*/
|
|
120
|
-
export type IJsConfuserDebugObfuscation = (
|
|
121
|
-
code: string,
|
|
122
|
-
options: ObfuscateOptions,
|
|
123
|
-
callback: (name: string, complete: number, totalTransforms: number) => void,
|
|
124
|
-
performance: Performance
|
|
125
|
-
) => Promise<{
|
|
126
|
-
obfuscated: string;
|
|
127
|
-
transformationTimes: { [transformName: string]: number };
|
|
128
|
-
parseTime: number;
|
|
129
|
-
compileTime: number;
|
|
130
|
-
obfuscationTime: number;
|
|
131
|
-
totalTransforms: number;
|
|
132
|
-
totalPossibleTransforms: number;
|
|
133
|
-
}>;
|