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,695 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../../src/index";
|
|
2
|
-
import { ObfuscateOptions } from "../../../src/options";
|
|
3
|
-
|
|
4
|
-
test("Variant #1: Rename variables properly", async () => {
|
|
5
|
-
var code = "var TEST_VARIABLE = 1;";
|
|
6
|
-
var output = await JsConfuser(code, {
|
|
7
|
-
target: "browser",
|
|
8
|
-
renameVariables: true,
|
|
9
|
-
renameGlobals: true,
|
|
10
|
-
identifierGenerator: "mangled",
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
expect(output.split("var ")[1].split("=")[0]).not.toEqual("TEST_VARIABLE");
|
|
14
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
test("Variant #2: Don't rename global accessors", async () => {
|
|
18
|
-
var code = `
|
|
19
|
-
var TEST_VARIABLE = 1;
|
|
20
|
-
success(TEST_VARIABLE); // success should not be renamed
|
|
21
|
-
`;
|
|
22
|
-
|
|
23
|
-
var output = await JsConfuser(code, {
|
|
24
|
-
target: "browser",
|
|
25
|
-
renameVariables: true,
|
|
26
|
-
renameGlobals: true,
|
|
27
|
-
identifierGenerator: "mangled",
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
expect(output).toContain("success");
|
|
31
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
32
|
-
|
|
33
|
-
var passed = false;
|
|
34
|
-
function success() {
|
|
35
|
-
passed = true;
|
|
36
|
-
}
|
|
37
|
-
eval(output);
|
|
38
|
-
|
|
39
|
-
expect(passed).toStrictEqual(true);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
test("Variant #3: Rename shadowed variables properly", async () => {
|
|
43
|
-
var code = `
|
|
44
|
-
var TEST_VARIABLE = 1;
|
|
45
|
-
|
|
46
|
-
function run(){
|
|
47
|
-
var TEST_VARIABLE = 10;
|
|
48
|
-
input(TEST_VARIABLE);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
run();
|
|
52
|
-
`;
|
|
53
|
-
|
|
54
|
-
var output = await JsConfuser(code, {
|
|
55
|
-
target: "browser",
|
|
56
|
-
renameVariables: true,
|
|
57
|
-
renameGlobals: true,
|
|
58
|
-
identifierGenerator: "mangled",
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
var value = false;
|
|
62
|
-
function input(valueIn) {
|
|
63
|
-
value = valueIn;
|
|
64
|
-
}
|
|
65
|
-
eval(output);
|
|
66
|
-
|
|
67
|
-
expect(value).toStrictEqual(10);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
test("Variant #4: Don't rename member properties", async () => {
|
|
71
|
-
var code = `
|
|
72
|
-
|
|
73
|
-
var TEST_OBJECT = { TEST_PROPERTY: 100 }
|
|
74
|
-
|
|
75
|
-
input(TEST_OBJECT.TEST_PROPERTY); // "TEST_PROPERTY" should not be renamed
|
|
76
|
-
`;
|
|
77
|
-
|
|
78
|
-
var output = await JsConfuser(code, {
|
|
79
|
-
target: "browser",
|
|
80
|
-
renameVariables: true,
|
|
81
|
-
renameGlobals: true,
|
|
82
|
-
identifierGenerator: "mangled",
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
expect(output).toContain("TEST_PROPERTY");
|
|
86
|
-
|
|
87
|
-
var value = false;
|
|
88
|
-
function input(valueIn) {
|
|
89
|
-
value = valueIn;
|
|
90
|
-
}
|
|
91
|
-
eval(output);
|
|
92
|
-
|
|
93
|
-
expect(value).toStrictEqual(100);
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
test("Variant #5: Handle variable defined with let (1)", async () => {
|
|
97
|
-
var code = `
|
|
98
|
-
|
|
99
|
-
// lexically bound
|
|
100
|
-
let TEST_OBJECT = { TEST_PROPERTY: 100 }
|
|
101
|
-
|
|
102
|
-
input(TEST_OBJECT.TEST_PROPERTY); // "TEST_PROPERTY" should not be renamed
|
|
103
|
-
`;
|
|
104
|
-
|
|
105
|
-
var output = await JsConfuser(code, {
|
|
106
|
-
target: "browser",
|
|
107
|
-
renameVariables: true,
|
|
108
|
-
renameGlobals: true,
|
|
109
|
-
identifierGenerator: "mangled",
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
var value = false;
|
|
113
|
-
function input(valueIn) {
|
|
114
|
-
value = valueIn;
|
|
115
|
-
}
|
|
116
|
-
eval(output);
|
|
117
|
-
|
|
118
|
-
expect(value).toStrictEqual(100);
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
test("Variant #6: Handle variable defined with let (2)", async () => {
|
|
122
|
-
var code = `
|
|
123
|
-
|
|
124
|
-
// lexically bound
|
|
125
|
-
let TEST_OBJECT = { TEST_PROPERTY: "UPPER_VALUE" }
|
|
126
|
-
if ( true ) {
|
|
127
|
-
let TEST_OBJECT = { TEST_PROPERTY: 100 }
|
|
128
|
-
input(TEST_OBJECT.TEST_PROPERTY); // "TEST_PROPERTY" should not be renamed
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
`;
|
|
132
|
-
|
|
133
|
-
var output = await JsConfuser(code, {
|
|
134
|
-
target: "browser",
|
|
135
|
-
renameVariables: true,
|
|
136
|
-
renameGlobals: true,
|
|
137
|
-
identifierGenerator: "mangled",
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
var value = false;
|
|
141
|
-
function input(valueIn) {
|
|
142
|
-
value = valueIn;
|
|
143
|
-
}
|
|
144
|
-
eval(output);
|
|
145
|
-
|
|
146
|
-
expect(value).toStrictEqual(100);
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
test("Variant #7: Handle variable defined with let (3)", async () => {
|
|
150
|
-
var code = `
|
|
151
|
-
|
|
152
|
-
// lexically bound
|
|
153
|
-
let TEST_OBJECT = { TEST_PROPERTY: "UPPER_VALUE" }
|
|
154
|
-
if ( true ) {
|
|
155
|
-
let TEST_OBJECT = { TEST_PROPERTY: 100 }
|
|
156
|
-
input(TEST_OBJECT.TEST_PROPERTY); // "TEST_PROPERTY" should not be renamed
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
`;
|
|
160
|
-
|
|
161
|
-
var output = await JsConfuser(code, {
|
|
162
|
-
target: "browser",
|
|
163
|
-
renameVariables: true,
|
|
164
|
-
renameGlobals: true,
|
|
165
|
-
identifierGenerator: "mangled",
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
expect(output).not.toContain("TEST_OBJECT");
|
|
169
|
-
expect(output).toContain("TEST_PROPERTY");
|
|
170
|
-
expect(output).toContain("input");
|
|
171
|
-
expect(output).toContain("let a");
|
|
172
|
-
expect(typeof output.split("let a")[1]).toStrictEqual("string");
|
|
173
|
-
|
|
174
|
-
var value = false;
|
|
175
|
-
function input(valueIn) {
|
|
176
|
-
value = valueIn;
|
|
177
|
-
}
|
|
178
|
-
eval(output);
|
|
179
|
-
|
|
180
|
-
expect(value).toStrictEqual(100);
|
|
181
|
-
});
|
|
182
|
-
|
|
183
|
-
test("Variant #8: Don't rename null (reservedIdentifiers)", async () => {
|
|
184
|
-
var code = `
|
|
185
|
-
input(null)
|
|
186
|
-
`;
|
|
187
|
-
|
|
188
|
-
var output = await JsConfuser(code, {
|
|
189
|
-
target: "browser",
|
|
190
|
-
renameVariables: true,
|
|
191
|
-
renameGlobals: true,
|
|
192
|
-
});
|
|
193
|
-
|
|
194
|
-
var value = false;
|
|
195
|
-
function input(valueIn) {
|
|
196
|
-
value = valueIn;
|
|
197
|
-
}
|
|
198
|
-
eval(output);
|
|
199
|
-
|
|
200
|
-
expect(value).toStrictEqual(null);
|
|
201
|
-
});
|
|
202
|
-
|
|
203
|
-
test("Variant #9: Don't rename exported names", async () => {
|
|
204
|
-
var code = `
|
|
205
|
-
export function abc(){
|
|
206
|
-
|
|
207
|
-
}
|
|
208
|
-
`;
|
|
209
|
-
|
|
210
|
-
var output = await JsConfuser(code, {
|
|
211
|
-
target: "browser",
|
|
212
|
-
renameVariables: true,
|
|
213
|
-
renameGlobals: true,
|
|
214
|
-
});
|
|
215
|
-
|
|
216
|
-
expect(output).toContain("abc");
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
test("Variant #10: Call renameVariables callback properly (variables)", async () => {
|
|
220
|
-
var code = `
|
|
221
|
-
var myVariable = 1;
|
|
222
|
-
`;
|
|
223
|
-
|
|
224
|
-
var input = [];
|
|
225
|
-
|
|
226
|
-
var output = await JsConfuser(code, {
|
|
227
|
-
target: "browser",
|
|
228
|
-
renameGlobals: true,
|
|
229
|
-
renameVariables: (name, isTopLevel) => {
|
|
230
|
-
input = [name, isTopLevel];
|
|
231
|
-
},
|
|
232
|
-
});
|
|
233
|
-
|
|
234
|
-
expect(input).toEqual(["myVariable", true]);
|
|
235
|
-
});
|
|
236
|
-
|
|
237
|
-
test("Variant #11: Call renameVariables callback properly (variables, nested)", async () => {
|
|
238
|
-
var code = `
|
|
239
|
-
(function(){
|
|
240
|
-
var myVariable = 1;
|
|
241
|
-
})();
|
|
242
|
-
`;
|
|
243
|
-
|
|
244
|
-
var input = [];
|
|
245
|
-
|
|
246
|
-
var output = await JsConfuser(code, {
|
|
247
|
-
target: "browser",
|
|
248
|
-
renameGlobals: true,
|
|
249
|
-
renameVariables: (name, isTopLevel) => {
|
|
250
|
-
input = [name, isTopLevel];
|
|
251
|
-
},
|
|
252
|
-
});
|
|
253
|
-
|
|
254
|
-
expect(input).toEqual(["myVariable", false]);
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
test("Variant #12: Call renameVariables callback properly (function declaration)", async () => {
|
|
258
|
-
var code = `
|
|
259
|
-
function myFunction(){
|
|
260
|
-
|
|
261
|
-
}
|
|
262
|
-
`;
|
|
263
|
-
|
|
264
|
-
var input = [];
|
|
265
|
-
|
|
266
|
-
var output = await JsConfuser(code, {
|
|
267
|
-
target: "browser",
|
|
268
|
-
renameGlobals: true,
|
|
269
|
-
renameVariables: (name, isTopLevel) => {
|
|
270
|
-
input = [name, isTopLevel];
|
|
271
|
-
},
|
|
272
|
-
});
|
|
273
|
-
|
|
274
|
-
expect(input).toEqual(["myFunction", true]);
|
|
275
|
-
});
|
|
276
|
-
|
|
277
|
-
test("Variant #13: Allow excluding custom variables from being renamed", async () => {
|
|
278
|
-
var code = `
|
|
279
|
-
var myVariable1 = 1;
|
|
280
|
-
var myVariable2 = 1;
|
|
281
|
-
`;
|
|
282
|
-
|
|
283
|
-
var output = await JsConfuser(code, {
|
|
284
|
-
target: "browser",
|
|
285
|
-
renameVariables: (name, isTopLevel) => {
|
|
286
|
-
return name !== "myVariable1";
|
|
287
|
-
},
|
|
288
|
-
renameGlobals: true,
|
|
289
|
-
});
|
|
290
|
-
|
|
291
|
-
expect(output).toContain("myVariable1");
|
|
292
|
-
expect(output).not.toContain("myVariable2");
|
|
293
|
-
});
|
|
294
|
-
|
|
295
|
-
test("Variant #14: should not break global variable references", async () => {
|
|
296
|
-
/**
|
|
297
|
-
* In this case `b` is a global variable,
|
|
298
|
-
*
|
|
299
|
-
* "mangled" names are a,b,c,d...
|
|
300
|
-
*
|
|
301
|
-
* therefore make sure `b` is NOT used as it breaks program
|
|
302
|
-
*/
|
|
303
|
-
var code = `
|
|
304
|
-
var a = "";
|
|
305
|
-
|
|
306
|
-
function myFunction(param1, param2){
|
|
307
|
-
b(param1);
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
myFunction("Hello World");
|
|
311
|
-
`;
|
|
312
|
-
|
|
313
|
-
var output = await JsConfuser(code, {
|
|
314
|
-
target: "node",
|
|
315
|
-
renameVariables: true,
|
|
316
|
-
renameGlobals: true,
|
|
317
|
-
identifierGenerator: "mangled",
|
|
318
|
-
});
|
|
319
|
-
|
|
320
|
-
expect(output).not.toContain("b(b)");
|
|
321
|
-
|
|
322
|
-
var value;
|
|
323
|
-
function b(valueIn) {
|
|
324
|
-
value = valueIn;
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
eval(output);
|
|
328
|
-
|
|
329
|
-
expect(value).toStrictEqual("Hello World");
|
|
330
|
-
});
|
|
331
|
-
|
|
332
|
-
test("Variant #15: Function parameter default value", async () => {
|
|
333
|
-
/**
|
|
334
|
-
* In this case `b` is a global variable,
|
|
335
|
-
*
|
|
336
|
-
* "mangled" names are a,b,c,d...
|
|
337
|
-
*
|
|
338
|
-
* therefore make sure `b` is NOT used as it breaks program
|
|
339
|
-
*/
|
|
340
|
-
var code = `
|
|
341
|
-
var a = "Filler Variables";
|
|
342
|
-
var b = "Hello World";
|
|
343
|
-
var c = "Another incorrect string";
|
|
344
|
-
|
|
345
|
-
function myFunction(param1 = ()=>{
|
|
346
|
-
return b;
|
|
347
|
-
}){
|
|
348
|
-
var b = param1();
|
|
349
|
-
if(false){
|
|
350
|
-
a,c;
|
|
351
|
-
}
|
|
352
|
-
input(b);
|
|
353
|
-
}
|
|
354
|
-
|
|
355
|
-
myFunction();
|
|
356
|
-
`;
|
|
357
|
-
|
|
358
|
-
var output = await JsConfuser(code, {
|
|
359
|
-
target: "node",
|
|
360
|
-
renameVariables: true,
|
|
361
|
-
renameGlobals: true,
|
|
362
|
-
identifierGenerator: "mangled",
|
|
363
|
-
});
|
|
364
|
-
|
|
365
|
-
var value;
|
|
366
|
-
function input(valueIn) {
|
|
367
|
-
value = valueIn;
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
eval(output);
|
|
371
|
-
|
|
372
|
-
expect(value).toStrictEqual("Hello World");
|
|
373
|
-
});
|
|
374
|
-
|
|
375
|
-
// https://github.com/MichaelXF/js-confuser/issues/24
|
|
376
|
-
test("Variant #16: Function with multiple parameters and a default value", async () => {
|
|
377
|
-
var code = `
|
|
378
|
-
function FuncA(param1, param2 = FuncB){
|
|
379
|
-
param2()
|
|
380
|
-
}
|
|
381
|
-
|
|
382
|
-
function FuncB(){
|
|
383
|
-
input("Success!");
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
FuncA();
|
|
387
|
-
`;
|
|
388
|
-
|
|
389
|
-
var output = await JsConfuser(code, {
|
|
390
|
-
target: "node",
|
|
391
|
-
renameVariables: true,
|
|
392
|
-
renameGlobals: true,
|
|
393
|
-
identifierGenerator: "mangled",
|
|
394
|
-
});
|
|
395
|
-
|
|
396
|
-
var value;
|
|
397
|
-
function input(valueIn) {
|
|
398
|
-
value = valueIn;
|
|
399
|
-
}
|
|
400
|
-
|
|
401
|
-
eval(output);
|
|
402
|
-
|
|
403
|
-
expect(value).toStrictEqual("Success!");
|
|
404
|
-
});
|
|
405
|
-
|
|
406
|
-
// https://github.com/MichaelXF/js-confuser/issues/60
|
|
407
|
-
test("Variant #17: Function parameter and lexical variable clash", async () => {
|
|
408
|
-
var code = `
|
|
409
|
-
function fun1(a) {
|
|
410
|
-
let b;
|
|
411
|
-
}
|
|
412
|
-
`;
|
|
413
|
-
|
|
414
|
-
var output = await JsConfuser(code, {
|
|
415
|
-
target: "node",
|
|
416
|
-
renameVariables: true,
|
|
417
|
-
renameGlobals: true,
|
|
418
|
-
});
|
|
419
|
-
|
|
420
|
-
eval(output);
|
|
421
|
-
});
|
|
422
|
-
|
|
423
|
-
test("Variant #18: Catch parameter and lexical variable clash", async () => {
|
|
424
|
-
var code = `
|
|
425
|
-
try {
|
|
426
|
-
|
|
427
|
-
} catch (a){
|
|
428
|
-
let b;
|
|
429
|
-
}
|
|
430
|
-
`;
|
|
431
|
-
|
|
432
|
-
var output = await JsConfuser(code, {
|
|
433
|
-
target: "node",
|
|
434
|
-
renameVariables: true,
|
|
435
|
-
renameGlobals: true,
|
|
436
|
-
});
|
|
437
|
-
|
|
438
|
-
eval(output);
|
|
439
|
-
});
|
|
440
|
-
|
|
441
|
-
// https://github.com/MichaelXF/js-confuser/issues/69
|
|
442
|
-
test("Variant #19: Don't break Import Declarations", async () => {
|
|
443
|
-
var output = await JsConfuser(
|
|
444
|
-
`
|
|
445
|
-
import { createHash } from 'node:crypto'
|
|
446
|
-
|
|
447
|
-
function sha256(content) {
|
|
448
|
-
return createHash('sha256').update(content).digest('hex')
|
|
449
|
-
}
|
|
450
|
-
|
|
451
|
-
TEST_OUTPUT = sha256("Hash this string");
|
|
452
|
-
`,
|
|
453
|
-
{
|
|
454
|
-
target: "node",
|
|
455
|
-
renameVariables: true,
|
|
456
|
-
}
|
|
457
|
-
);
|
|
458
|
-
|
|
459
|
-
// Ensure the createHash got renamed
|
|
460
|
-
expect(output).toContain("createHash as ");
|
|
461
|
-
|
|
462
|
-
// Convert to runnable code
|
|
463
|
-
// This smartly changes the `import` statement to a require call, keeping the new variable name intact
|
|
464
|
-
var newVarName = output.split("createHash as ")[1].split("}")[0];
|
|
465
|
-
output = output
|
|
466
|
-
.split(";")
|
|
467
|
-
.filter((s) => !s.startsWith("import"))
|
|
468
|
-
.join(";");
|
|
469
|
-
output = `var {createHash: ${newVarName}}=require('crypto');` + output;
|
|
470
|
-
|
|
471
|
-
var TEST_OUTPUT;
|
|
472
|
-
eval(output);
|
|
473
|
-
|
|
474
|
-
expect(TEST_OUTPUT).toStrictEqual(
|
|
475
|
-
"1cac63f39fd68d8c531f27b807610fb3d50f0fc3f186995767fb6316e7200a3e"
|
|
476
|
-
);
|
|
477
|
-
});
|
|
478
|
-
|
|
479
|
-
// https://github.com/MichaelXF/js-confuser/issues/80
|
|
480
|
-
test("Variant #20: Don't break code with var and let variables in same scope", async () => {
|
|
481
|
-
var output = await JsConfuser(
|
|
482
|
-
`
|
|
483
|
-
function log(param) {
|
|
484
|
-
let message = param;
|
|
485
|
-
var isWarning = false;
|
|
486
|
-
var isError = false;
|
|
487
|
-
|
|
488
|
-
TEST_OUTPUT = message;
|
|
489
|
-
};
|
|
490
|
-
|
|
491
|
-
log("Correct Value");
|
|
492
|
-
`,
|
|
493
|
-
{
|
|
494
|
-
target: "node",
|
|
495
|
-
renameVariables: true,
|
|
496
|
-
}
|
|
497
|
-
);
|
|
498
|
-
|
|
499
|
-
var TEST_OUTPUT;
|
|
500
|
-
eval(output);
|
|
501
|
-
|
|
502
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
503
|
-
});
|
|
504
|
-
|
|
505
|
-
test.each(["hexadecimal", "mangled", "number", "zeroWidth"])(
|
|
506
|
-
"Variant #21: Work with custom identifierGenerator mode",
|
|
507
|
-
async (identifierGeneratorMode) => {
|
|
508
|
-
var output = await JsConfuser(
|
|
509
|
-
`
|
|
510
|
-
var myVar1 = "Correct Value";
|
|
511
|
-
|
|
512
|
-
function myFunction(myVar2){
|
|
513
|
-
myVar2 = myVar1;
|
|
514
|
-
let myVar3 = myVar2;
|
|
515
|
-
var myVar4 = myVar3;
|
|
516
|
-
return myVar4;
|
|
517
|
-
}
|
|
518
|
-
|
|
519
|
-
TEST_OUTPUT = myFunction();
|
|
520
|
-
`,
|
|
521
|
-
{
|
|
522
|
-
target: "node",
|
|
523
|
-
renameVariables: true,
|
|
524
|
-
identifierGenerator:
|
|
525
|
-
identifierGeneratorMode as ObfuscateOptions["identifierGenerator"],
|
|
526
|
-
}
|
|
527
|
-
);
|
|
528
|
-
|
|
529
|
-
// Ensure 'myVar1' got renamed
|
|
530
|
-
expect(output).not.toContain("myVar1");
|
|
531
|
-
|
|
532
|
-
var TEST_OUTPUT;
|
|
533
|
-
|
|
534
|
-
eval(output);
|
|
535
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
536
|
-
}
|
|
537
|
-
);
|
|
538
|
-
|
|
539
|
-
test("Variant #22: Don't rename variables prefixed with '__NO_JS_CONFUSER_RENAME__'", async () => {
|
|
540
|
-
var output = await JsConfuser(
|
|
541
|
-
`
|
|
542
|
-
var myValue = "Correct Value";
|
|
543
|
-
|
|
544
|
-
var __NO_JS_CONFUSER_RENAME__myVar4 = "Incorrect Value";
|
|
545
|
-
|
|
546
|
-
__NO_JS_CONFUSER_RENAME__myVar4 = myValue;
|
|
547
|
-
|
|
548
|
-
eval( "TEST_OUTPUT = __NO_JS_CONFUSER_RENAME__myVar4" );
|
|
549
|
-
`,
|
|
550
|
-
{
|
|
551
|
-
target: "node",
|
|
552
|
-
renameVariables: true,
|
|
553
|
-
}
|
|
554
|
-
);
|
|
555
|
-
|
|
556
|
-
// Ensure 'myValue' got renamed
|
|
557
|
-
expect(output).not.toContain("myValue");
|
|
558
|
-
// Ensure '__NO_JS_CONFUSER_RENAME__myVar4' was not renamed
|
|
559
|
-
expect(output).toContain("__NO_JS_CONFUSER_RENAME__myVar4");
|
|
560
|
-
|
|
561
|
-
// Test the code
|
|
562
|
-
var TEST_OUTPUT;
|
|
563
|
-
|
|
564
|
-
eval(output);
|
|
565
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
566
|
-
});
|
|
567
|
-
|
|
568
|
-
test("Variant #23: Re-use previously generated names", async () => {
|
|
569
|
-
var output = await JsConfuser(
|
|
570
|
-
`
|
|
571
|
-
function log(message){
|
|
572
|
-
TEST_OUTPUT = message;
|
|
573
|
-
}
|
|
574
|
-
|
|
575
|
-
log("Correct Value");
|
|
576
|
-
`,
|
|
577
|
-
{
|
|
578
|
-
target: "node",
|
|
579
|
-
renameVariables: true,
|
|
580
|
-
identifierGenerator: "mangled",
|
|
581
|
-
}
|
|
582
|
-
);
|
|
583
|
-
|
|
584
|
-
expect(output).not.toContain("log");
|
|
585
|
-
expect(output).toContain("function a(a)");
|
|
586
|
-
|
|
587
|
-
var TEST_OUTPUT;
|
|
588
|
-
eval(output);
|
|
589
|
-
|
|
590
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
591
|
-
});
|
|
592
|
-
|
|
593
|
-
test("Variant #24: Reference function name with parameter", async () => {
|
|
594
|
-
var output = await JsConfuser(
|
|
595
|
-
`
|
|
596
|
-
function myFunction(myFunction){
|
|
597
|
-
myFunction.property = "Correct Value";
|
|
598
|
-
}
|
|
599
|
-
|
|
600
|
-
myFunction(myFunction);
|
|
601
|
-
TEST_OUTPUT = myFunction.property;
|
|
602
|
-
`,
|
|
603
|
-
{ target: "node", renameVariables: true }
|
|
604
|
-
);
|
|
605
|
-
|
|
606
|
-
var TEST_OUTPUT;
|
|
607
|
-
eval(output);
|
|
608
|
-
|
|
609
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
610
|
-
});
|
|
611
|
-
|
|
612
|
-
test("Variant #25: Reference catch parameter", async () => {
|
|
613
|
-
var output = await JsConfuser(
|
|
614
|
-
`
|
|
615
|
-
try {
|
|
616
|
-
throw "Correct Value";
|
|
617
|
-
} catch ( e ) {
|
|
618
|
-
TEST_OUTPUT = e;
|
|
619
|
-
}
|
|
620
|
-
`,
|
|
621
|
-
{ target: "node", renameVariables: true }
|
|
622
|
-
);
|
|
623
|
-
|
|
624
|
-
var TEST_OUTPUT;
|
|
625
|
-
eval(output);
|
|
626
|
-
|
|
627
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
628
|
-
});
|
|
629
|
-
|
|
630
|
-
test("Variant #26: Transform __JS_CONFUSER_VAR__ to access variable mappings", async () => {
|
|
631
|
-
var output = await JsConfuser(
|
|
632
|
-
`
|
|
633
|
-
var myVar1 = "Incorrect Value";
|
|
634
|
-
|
|
635
|
-
function myFunction(){
|
|
636
|
-
var myVar1 = "Correct Value";
|
|
637
|
-
TEST_OUTPUT = eval( __JS_CONFUSER_VAR__(myVar1) );
|
|
638
|
-
}
|
|
639
|
-
|
|
640
|
-
myFunction();
|
|
641
|
-
`,
|
|
642
|
-
{ target: "node", renameVariables: true }
|
|
643
|
-
);
|
|
644
|
-
|
|
645
|
-
expect(output).not.toContain("myVar1");
|
|
646
|
-
expect(output).not.toContain("__JS_CONFUSER_VAR__");
|
|
647
|
-
|
|
648
|
-
var TEST_OUTPUT;
|
|
649
|
-
|
|
650
|
-
eval(output);
|
|
651
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
652
|
-
});
|
|
653
|
-
|
|
654
|
-
test("Variant #27: Transform __JS_CONFUSER_VAR__ even when Rename Variables is disabled", async () => {
|
|
655
|
-
var output = await JsConfuser(
|
|
656
|
-
`
|
|
657
|
-
var name = "John Doe";
|
|
658
|
-
TEST_OUTPUT = __JS_CONFUSER_VAR__(name);
|
|
659
|
-
`,
|
|
660
|
-
{ target: "node", renameVariables: false }
|
|
661
|
-
);
|
|
662
|
-
|
|
663
|
-
expect(output).not.toContain("__JS_CONFUSER_VAR__");
|
|
664
|
-
|
|
665
|
-
var TEST_OUTPUT;
|
|
666
|
-
|
|
667
|
-
eval(output);
|
|
668
|
-
expect(TEST_OUTPUT).toStrictEqual("name");
|
|
669
|
-
});
|
|
670
|
-
|
|
671
|
-
test("Variant #28: Transform __JS_CONFUSER_VAR__ on High Preset", async () => {
|
|
672
|
-
var output = await JsConfuser(
|
|
673
|
-
`
|
|
674
|
-
function myFunction(){
|
|
675
|
-
var a
|
|
676
|
-
var b
|
|
677
|
-
var c
|
|
678
|
-
|
|
679
|
-
return "Correct Value"
|
|
680
|
-
}
|
|
681
|
-
TEST_OUTPUT = eval(__JS_CONFUSER_VAR__(myFunction) + "()");
|
|
682
|
-
`,
|
|
683
|
-
{
|
|
684
|
-
target: "node",
|
|
685
|
-
preset: "high",
|
|
686
|
-
}
|
|
687
|
-
);
|
|
688
|
-
|
|
689
|
-
expect(output).not.toContain("__JS_CONFUSER_VAR__");
|
|
690
|
-
|
|
691
|
-
var TEST_OUTPUT;
|
|
692
|
-
eval(output);
|
|
693
|
-
|
|
694
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
695
|
-
});
|