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
|
@@ -1,200 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../../src/index";
|
|
2
|
-
|
|
3
|
-
test("Variant #1: Remove duplicate literals", async () => {
|
|
4
|
-
var code = `
|
|
5
|
-
|
|
6
|
-
var TEST_ARRAY = [5,5];
|
|
7
|
-
`;
|
|
8
|
-
|
|
9
|
-
var output = await JsConfuser(code, {
|
|
10
|
-
target: "node",
|
|
11
|
-
duplicateLiteralsRemoval: true,
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
expect(output).not.toContain("5,5");
|
|
15
|
-
expect(output).toContain("5");
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
test("Variant #2: Remove duplicate literals and execute correctly", async () => {
|
|
19
|
-
var code = `
|
|
20
|
-
|
|
21
|
-
TEST_ARRAY = [5,5];
|
|
22
|
-
`;
|
|
23
|
-
|
|
24
|
-
var output = await JsConfuser(code, {
|
|
25
|
-
target: "node",
|
|
26
|
-
duplicateLiteralsRemoval: true,
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
expect(output).not.toContain("5,5");
|
|
30
|
-
expect(output).toContain("5");
|
|
31
|
-
|
|
32
|
-
var TEST_ARRAY;
|
|
33
|
-
|
|
34
|
-
eval(output);
|
|
35
|
-
|
|
36
|
-
expect(TEST_ARRAY).toEqual([5, 5]);
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
test("Variant #3: Remove 'undefined' and 'null' values", async () => {
|
|
40
|
-
var code = `
|
|
41
|
-
|
|
42
|
-
TEST_ARRAY = [undefined,undefined,null,null];
|
|
43
|
-
`;
|
|
44
|
-
|
|
45
|
-
var output = await JsConfuser(code, {
|
|
46
|
-
target: "node",
|
|
47
|
-
duplicateLiteralsRemoval: true,
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
expect(output).not.toContain("undefined,undefined");
|
|
51
|
-
expect(output).toContain("undefined");
|
|
52
|
-
|
|
53
|
-
expect(output).not.toContain("null,null");
|
|
54
|
-
expect(output).toContain("null");
|
|
55
|
-
|
|
56
|
-
var TEST_ARRAY;
|
|
57
|
-
|
|
58
|
-
eval(output);
|
|
59
|
-
|
|
60
|
-
expect(TEST_ARRAY).toEqual([undefined, undefined, null, null]);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
test("Variant #4: Do not remove empty strings", async () => {
|
|
64
|
-
var code = `
|
|
65
|
-
|
|
66
|
-
TEST_ARRAY = ['','','',''];
|
|
67
|
-
`;
|
|
68
|
-
|
|
69
|
-
var output = await JsConfuser(code, {
|
|
70
|
-
target: "node",
|
|
71
|
-
duplicateLiteralsRemoval: true,
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
expect(output).toContain("'','','',''");
|
|
75
|
-
|
|
76
|
-
var TEST_ARRAY;
|
|
77
|
-
|
|
78
|
-
eval(output);
|
|
79
|
-
|
|
80
|
-
expect(TEST_ARRAY).toEqual(["", "", "", ""]);
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
test("Variant #5: Work with NaN values", async () => {
|
|
84
|
-
var code = `
|
|
85
|
-
|
|
86
|
-
TEST_ARRAY = [NaN];
|
|
87
|
-
`;
|
|
88
|
-
|
|
89
|
-
var output = await JsConfuser(code, {
|
|
90
|
-
target: "node",
|
|
91
|
-
duplicateLiteralsRemoval: true,
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
var TEST_ARRAY;
|
|
95
|
-
|
|
96
|
-
eval(output);
|
|
97
|
-
|
|
98
|
-
expect(TEST_ARRAY[0] === TEST_ARRAY[0]).toStrictEqual(false);
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
test("Variant #6: Work on property keys", async () => {
|
|
102
|
-
var code = `
|
|
103
|
-
var myObject = {
|
|
104
|
-
myKey: 100
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
var myObject2 = {
|
|
108
|
-
myKey: 50
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
TEST_VAR = myObject.myKey;
|
|
112
|
-
`;
|
|
113
|
-
|
|
114
|
-
var output = await JsConfuser(code, {
|
|
115
|
-
target: "node",
|
|
116
|
-
duplicateLiteralsRemoval: true,
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
expect(output).toContain("]:100");
|
|
120
|
-
|
|
121
|
-
var TEST_VAR;
|
|
122
|
-
eval(output);
|
|
123
|
-
|
|
124
|
-
expect(TEST_VAR).toStrictEqual(100);
|
|
125
|
-
});
|
|
126
|
-
|
|
127
|
-
test("Variant #7: Work on class keys", async () => {
|
|
128
|
-
var code = `
|
|
129
|
-
class MyClass {
|
|
130
|
-
myMethod(){
|
|
131
|
-
return 100;
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
var myObject = new MyClass();
|
|
136
|
-
|
|
137
|
-
TEST_VAR = myObject.myMethod();
|
|
138
|
-
`;
|
|
139
|
-
|
|
140
|
-
var output = await JsConfuser(code, {
|
|
141
|
-
target: "node",
|
|
142
|
-
duplicateLiteralsRemoval: true,
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
expect(output).toContain("](){return 100}");
|
|
146
|
-
|
|
147
|
-
var TEST_VAR;
|
|
148
|
-
eval(output);
|
|
149
|
-
|
|
150
|
-
expect(TEST_VAR).toStrictEqual(100);
|
|
151
|
-
});
|
|
152
|
-
|
|
153
|
-
test("Variant #8: Do not encode constructor key", async () => {
|
|
154
|
-
var code = `
|
|
155
|
-
class MyClass {
|
|
156
|
-
constructor(){
|
|
157
|
-
TEST_VAR = 100;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
class MyClass2 {
|
|
162
|
-
constructor(){
|
|
163
|
-
TEST_VAR = 50;
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
new MyClass();
|
|
168
|
-
`;
|
|
169
|
-
|
|
170
|
-
var output = await JsConfuser(code, {
|
|
171
|
-
target: "node",
|
|
172
|
-
duplicateLiteralsRemoval: true,
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
var TEST_VAR;
|
|
176
|
-
eval(output);
|
|
177
|
-
|
|
178
|
-
expect(TEST_VAR).toStrictEqual(100);
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
// https://github.com/MichaelXF/js-confuser/issues/105
|
|
182
|
-
test("Variant #9: Undefined as variable name", async () => {
|
|
183
|
-
var output = await JsConfuser(
|
|
184
|
-
`
|
|
185
|
-
var undefined = 0;
|
|
186
|
-
var undefined = 1;
|
|
187
|
-
|
|
188
|
-
try {
|
|
189
|
-
(undefined = 0);
|
|
190
|
-
undefined = 1;
|
|
191
|
-
} catch (e) {
|
|
192
|
-
}
|
|
193
|
-
`,
|
|
194
|
-
{ target: "node", duplicateLiteralsRemoval: true }
|
|
195
|
-
);
|
|
196
|
-
|
|
197
|
-
expect(output).toContain("(undefined=");
|
|
198
|
-
|
|
199
|
-
eval(output);
|
|
200
|
-
});
|
|
@@ -1,491 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../../src/index";
|
|
2
|
-
|
|
3
|
-
test("Variant #1: Extract properties", async () => {
|
|
4
|
-
var code = `
|
|
5
|
-
var TEST_OBJECT = {
|
|
6
|
-
TEST_1: "Hello World",
|
|
7
|
-
'TEST_2': 64
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
// ensures the original object is no longer defined
|
|
11
|
-
var check = false;
|
|
12
|
-
eval(\`
|
|
13
|
-
try {TEST_OBJECT} catch(e) {
|
|
14
|
-
check = true;
|
|
15
|
-
}
|
|
16
|
-
\`);
|
|
17
|
-
|
|
18
|
-
input(TEST_OBJECT.TEST_1, TEST_OBJECT['TEST_2'], check);
|
|
19
|
-
`;
|
|
20
|
-
|
|
21
|
-
var output = await JsConfuser(code, {
|
|
22
|
-
target: "browser",
|
|
23
|
-
objectExtraction: true,
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
// console.log(output);
|
|
27
|
-
|
|
28
|
-
function input(a, b, c) {
|
|
29
|
-
expect(a).toStrictEqual("Hello World");
|
|
30
|
-
expect(b).toStrictEqual(64);
|
|
31
|
-
expect(c).toStrictEqual(true);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
eval(output);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
test("Variant #2: Extract function properties correctly", async () => {
|
|
38
|
-
var code = `
|
|
39
|
-
var TEST_OBJECT = {
|
|
40
|
-
isBoolean: x=>typeof x === "boolean",
|
|
41
|
-
isString: function(x){return typeof x === "string"}
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
// ensures the original object is no longer defined
|
|
45
|
-
var check = false;
|
|
46
|
-
eval(\`
|
|
47
|
-
try {TEST_OBJECT} catch(e) {
|
|
48
|
-
check = true;
|
|
49
|
-
}
|
|
50
|
-
\`);
|
|
51
|
-
|
|
52
|
-
input(TEST_OBJECT.isBoolean(true), TEST_OBJECT.isString(false), check);
|
|
53
|
-
`;
|
|
54
|
-
|
|
55
|
-
var output = await JsConfuser(code, {
|
|
56
|
-
target: "browser",
|
|
57
|
-
objectExtraction: true,
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
// console.log(output);
|
|
61
|
-
|
|
62
|
-
function input(a, b, c) {
|
|
63
|
-
expect(a).toStrictEqual(true);
|
|
64
|
-
expect(b).toStrictEqual(false);
|
|
65
|
-
expect(c).toStrictEqual(true);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
eval(output);
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
test("Variant #3: Not extract properties on with dynamically added keys", async () => {
|
|
72
|
-
var code = `
|
|
73
|
-
var TEST_OBJECT = {
|
|
74
|
-
first_key: 1
|
|
75
|
-
};
|
|
76
|
-
|
|
77
|
-
TEST_OBJECT['DYNAMIC_PROPERTY'] = 1;
|
|
78
|
-
TEST_OBJECT.DYNAMIC_PROPERTY = 1;
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
var check = false;
|
|
82
|
-
eval(\`
|
|
83
|
-
try {TEST_OBJECT} catch(e) {
|
|
84
|
-
check = true;
|
|
85
|
-
}
|
|
86
|
-
\`);
|
|
87
|
-
|
|
88
|
-
input(check);
|
|
89
|
-
`;
|
|
90
|
-
|
|
91
|
-
var output = await JsConfuser(code, {
|
|
92
|
-
target: "browser",
|
|
93
|
-
objectExtraction: true,
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
function input(x) {
|
|
97
|
-
expect(x).toStrictEqual(false);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
eval(output);
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
test("Variant #4: Not extract properties on with dynamically added keys even when in nested contexts", async () => {
|
|
104
|
-
var code = `
|
|
105
|
-
var TEST_OBJECT = {
|
|
106
|
-
first_key: 1
|
|
107
|
-
};
|
|
108
|
-
|
|
109
|
-
(function(){
|
|
110
|
-
TEST_OBJECT['DYNAMIC_PROPERTY'] = 1;
|
|
111
|
-
TEST_OBJECT.DYNAMIC_PROPERTY = 1;
|
|
112
|
-
})()
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
var check = false;
|
|
117
|
-
eval(\`
|
|
118
|
-
try {TEST_OBJECT} catch(e) {
|
|
119
|
-
check = true;
|
|
120
|
-
}
|
|
121
|
-
\`);
|
|
122
|
-
|
|
123
|
-
input(check);
|
|
124
|
-
`;
|
|
125
|
-
|
|
126
|
-
var output = await JsConfuser(code, {
|
|
127
|
-
target: "browser",
|
|
128
|
-
objectExtraction: true,
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
function input(x) {
|
|
132
|
-
expect(x).toStrictEqual(false);
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
eval(output);
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
test("Variant #5: Not extract properties on objects with computed properties", async () => {
|
|
139
|
-
var code = `
|
|
140
|
-
|
|
141
|
-
var key = "111"
|
|
142
|
-
var TEST_OBJECT = {
|
|
143
|
-
[key]: 111,
|
|
144
|
-
};
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
var check = false;
|
|
148
|
-
eval(\`
|
|
149
|
-
try {TEST_OBJECT} catch(e) {
|
|
150
|
-
check = true;
|
|
151
|
-
}
|
|
152
|
-
\`);
|
|
153
|
-
|
|
154
|
-
input(check);
|
|
155
|
-
`;
|
|
156
|
-
|
|
157
|
-
var output = await JsConfuser(code, {
|
|
158
|
-
target: "browser",
|
|
159
|
-
objectExtraction: true,
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
function input(x) {
|
|
163
|
-
expect(x).toStrictEqual(false);
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
eval(output);
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
test("Variant #6: Not extract properties on objects with computed properties (string)", async () => {
|
|
170
|
-
var code = `
|
|
171
|
-
|
|
172
|
-
var v = "key";
|
|
173
|
-
var TEST_OBJECT = {
|
|
174
|
-
[v + ""]: 111,
|
|
175
|
-
};
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
var check = false;
|
|
179
|
-
eval(\`
|
|
180
|
-
try {TEST_OBJECT} catch(e) {
|
|
181
|
-
check = true;
|
|
182
|
-
}
|
|
183
|
-
\`);
|
|
184
|
-
|
|
185
|
-
input(check);
|
|
186
|
-
`;
|
|
187
|
-
|
|
188
|
-
var output = await JsConfuser(code, {
|
|
189
|
-
target: "browser",
|
|
190
|
-
objectExtraction: true,
|
|
191
|
-
});
|
|
192
|
-
|
|
193
|
-
function input(x) {
|
|
194
|
-
expect(x).toStrictEqual(false);
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
eval(output);
|
|
198
|
-
});
|
|
199
|
-
|
|
200
|
-
test("Variant #7: Not extract properties on objects when the object is referenced independently", async () => {
|
|
201
|
-
var code = `
|
|
202
|
-
|
|
203
|
-
var TEST_OBJECT = {
|
|
204
|
-
isString: x=>typeof x === "string"
|
|
205
|
-
};
|
|
206
|
-
|
|
207
|
-
TEST_OBJECT;
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
var check = false;
|
|
211
|
-
eval(\`
|
|
212
|
-
try {TEST_OBJECT} catch(e) {
|
|
213
|
-
check = true;
|
|
214
|
-
}
|
|
215
|
-
\`);
|
|
216
|
-
|
|
217
|
-
input(check);
|
|
218
|
-
`;
|
|
219
|
-
|
|
220
|
-
var output = await JsConfuser(code, {
|
|
221
|
-
target: "browser",
|
|
222
|
-
objectExtraction: true,
|
|
223
|
-
});
|
|
224
|
-
|
|
225
|
-
function input(x) {
|
|
226
|
-
expect(x).toStrictEqual(false);
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
eval(output);
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
test("Variant #8: Not extract properties on objects when the variable gets redefined", async () => {
|
|
233
|
-
var code = `
|
|
234
|
-
|
|
235
|
-
var TEST_OBJECT = {
|
|
236
|
-
key: "value"
|
|
237
|
-
};
|
|
238
|
-
var TEST_OBJECT = {x: 1};
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
var check = false;
|
|
242
|
-
eval(\`
|
|
243
|
-
try {TEST_OBJECT} catch(e) {
|
|
244
|
-
check = true;
|
|
245
|
-
}
|
|
246
|
-
\`);
|
|
247
|
-
|
|
248
|
-
input(check);
|
|
249
|
-
`;
|
|
250
|
-
|
|
251
|
-
var output = await JsConfuser(code, {
|
|
252
|
-
target: "browser",
|
|
253
|
-
objectExtraction: true,
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
function input(x) {
|
|
257
|
-
expect(x).toStrictEqual(false);
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
eval(output);
|
|
261
|
-
});
|
|
262
|
-
|
|
263
|
-
test("Variant #9: Not extract properties on objects when the variable gets reassigned", async () => {
|
|
264
|
-
var code = `
|
|
265
|
-
|
|
266
|
-
var TEST_OBJECT = {
|
|
267
|
-
key: "value"
|
|
268
|
-
};
|
|
269
|
-
|
|
270
|
-
TEST_OBJECT = {key: "value_2"}
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
var check = false;
|
|
274
|
-
eval(\`
|
|
275
|
-
try {TEST_OBJECT} catch(e) {
|
|
276
|
-
check = true;
|
|
277
|
-
}
|
|
278
|
-
\`);
|
|
279
|
-
|
|
280
|
-
input(check);
|
|
281
|
-
`;
|
|
282
|
-
|
|
283
|
-
var output = await JsConfuser(code, {
|
|
284
|
-
target: "browser",
|
|
285
|
-
objectExtraction: true,
|
|
286
|
-
});
|
|
287
|
-
|
|
288
|
-
function input(x) {
|
|
289
|
-
expect(x).toStrictEqual(false);
|
|
290
|
-
}
|
|
291
|
-
|
|
292
|
-
eval(output);
|
|
293
|
-
});
|
|
294
|
-
|
|
295
|
-
test("Variant #10: Not extract properties on objects with methods referencing 'this'", async () => {
|
|
296
|
-
var code = `
|
|
297
|
-
|
|
298
|
-
var TEST_OBJECT = {
|
|
299
|
-
key: "value",
|
|
300
|
-
getKey: function(){
|
|
301
|
-
return this.key;
|
|
302
|
-
}
|
|
303
|
-
};
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
var check = false;
|
|
307
|
-
eval(\`
|
|
308
|
-
try {TEST_OBJECT} catch(e) {
|
|
309
|
-
check = true;
|
|
310
|
-
}
|
|
311
|
-
\`);
|
|
312
|
-
|
|
313
|
-
input(check);
|
|
314
|
-
`;
|
|
315
|
-
|
|
316
|
-
var output = await JsConfuser(code, {
|
|
317
|
-
target: "browser",
|
|
318
|
-
objectExtraction: true,
|
|
319
|
-
});
|
|
320
|
-
|
|
321
|
-
function input(x) {
|
|
322
|
-
expect(x).toStrictEqual(false);
|
|
323
|
-
}
|
|
324
|
-
|
|
325
|
-
eval(output);
|
|
326
|
-
});
|
|
327
|
-
|
|
328
|
-
test("Variant #11: Not extract properties on objects when properties are dynamically deleted", async () => {
|
|
329
|
-
var code = `
|
|
330
|
-
|
|
331
|
-
var TEST_OBJECT = {
|
|
332
|
-
key: "value"
|
|
333
|
-
};
|
|
334
|
-
|
|
335
|
-
delete TEST_OBJECT.key;
|
|
336
|
-
|
|
337
|
-
var check = false;
|
|
338
|
-
eval(\`
|
|
339
|
-
try {TEST_OBJECT} catch(e) {
|
|
340
|
-
check = true;
|
|
341
|
-
}
|
|
342
|
-
\`);
|
|
343
|
-
|
|
344
|
-
input(check);
|
|
345
|
-
`;
|
|
346
|
-
|
|
347
|
-
var output = await JsConfuser(code, {
|
|
348
|
-
target: "browser",
|
|
349
|
-
objectExtraction: true,
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
function input(x) {
|
|
353
|
-
expect(x).toStrictEqual(false);
|
|
354
|
-
}
|
|
355
|
-
|
|
356
|
-
eval(output);
|
|
357
|
-
});
|
|
358
|
-
|
|
359
|
-
test("Variant #12: Not extract properties on objects with computed accessors", async () => {
|
|
360
|
-
var code = `
|
|
361
|
-
|
|
362
|
-
var TEST_OBJECT = {
|
|
363
|
-
key: "value"
|
|
364
|
-
};
|
|
365
|
-
|
|
366
|
-
TEST_OBJECT["k" + "e" + "y"];
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
var check = false;
|
|
370
|
-
eval(\`
|
|
371
|
-
try {TEST_OBJECT} catch(e) {
|
|
372
|
-
check = true;
|
|
373
|
-
}
|
|
374
|
-
\`);
|
|
375
|
-
|
|
376
|
-
input(check);
|
|
377
|
-
`;
|
|
378
|
-
|
|
379
|
-
var output = await JsConfuser(code, {
|
|
380
|
-
target: "browser",
|
|
381
|
-
objectExtraction: true,
|
|
382
|
-
});
|
|
383
|
-
|
|
384
|
-
function input(x) {
|
|
385
|
-
expect(x).toStrictEqual(false);
|
|
386
|
-
}
|
|
387
|
-
|
|
388
|
-
eval(output);
|
|
389
|
-
});
|
|
390
|
-
|
|
391
|
-
test("Variant #13: Properly use custom callback to exclude certain names from being changed", async () => {
|
|
392
|
-
var code = `
|
|
393
|
-
|
|
394
|
-
var TEST_OBJECT = {
|
|
395
|
-
key: "value",
|
|
396
|
-
};
|
|
397
|
-
|
|
398
|
-
var check = false;
|
|
399
|
-
eval(\`
|
|
400
|
-
try {TEST_OBJECT} catch(e) {
|
|
401
|
-
check = true;
|
|
402
|
-
}
|
|
403
|
-
\`);
|
|
404
|
-
|
|
405
|
-
input(check);
|
|
406
|
-
`;
|
|
407
|
-
|
|
408
|
-
var seen = new Set();
|
|
409
|
-
var output = await JsConfuser(code, {
|
|
410
|
-
target: "browser",
|
|
411
|
-
objectExtraction: (name) => {
|
|
412
|
-
seen.add(name);
|
|
413
|
-
|
|
414
|
-
return name !== "TEST_OBJECT";
|
|
415
|
-
},
|
|
416
|
-
});
|
|
417
|
-
|
|
418
|
-
expect(seen.has("TEST_OBJECT")).toStrictEqual(true);
|
|
419
|
-
|
|
420
|
-
function input(x) {
|
|
421
|
-
expect(x).toStrictEqual(false);
|
|
422
|
-
}
|
|
423
|
-
|
|
424
|
-
eval(output);
|
|
425
|
-
});
|
|
426
|
-
|
|
427
|
-
test("Variant #14: Not apply to objects with non-init properties (method, set, get)", async () => {
|
|
428
|
-
var code = `
|
|
429
|
-
|
|
430
|
-
var realValue = 0;
|
|
431
|
-
var TEST_OBJECT = {
|
|
432
|
-
set key(newValue){
|
|
433
|
-
realValue = newValue;
|
|
434
|
-
},
|
|
435
|
-
get key(){
|
|
436
|
-
return realValue;
|
|
437
|
-
}
|
|
438
|
-
};
|
|
439
|
-
`;
|
|
440
|
-
|
|
441
|
-
var output = await JsConfuser(code, {
|
|
442
|
-
target: "node",
|
|
443
|
-
objectExtraction: true,
|
|
444
|
-
});
|
|
445
|
-
|
|
446
|
-
expect(output).toContain("TEST_OBJECT");
|
|
447
|
-
expect(output).toContain("set ");
|
|
448
|
-
});
|
|
449
|
-
|
|
450
|
-
// https://github.com/MichaelXF/js-confuser/issues/78
|
|
451
|
-
test("Variant #15: Handle objects with spread elements", async () => {
|
|
452
|
-
var output = await JsConfuser(
|
|
453
|
-
`
|
|
454
|
-
var x = { firstName: "John", lastName: "Doe" }
|
|
455
|
-
var y = { ...x };
|
|
456
|
-
|
|
457
|
-
TEST_OUTPUT = y;
|
|
458
|
-
`,
|
|
459
|
-
{
|
|
460
|
-
target: "node",
|
|
461
|
-
objectExtraction: true,
|
|
462
|
-
}
|
|
463
|
-
);
|
|
464
|
-
|
|
465
|
-
var TEST_OUTPUT;
|
|
466
|
-
eval(output);
|
|
467
|
-
|
|
468
|
-
expect(TEST_OUTPUT).toStrictEqual({ firstName: "John", lastName: "Doe" });
|
|
469
|
-
});
|
|
470
|
-
|
|
471
|
-
// https://github.com/MichaelXF/js-confuser/issues/106
|
|
472
|
-
test("Variant #16: Handle const declarations", async () => {
|
|
473
|
-
var output = await JsConfuser(
|
|
474
|
-
`
|
|
475
|
-
const obj = {prop: 0};
|
|
476
|
-
obj.prop = 1;
|
|
477
|
-
TEST_OUTPUT = obj.prop;
|
|
478
|
-
`,
|
|
479
|
-
{
|
|
480
|
-
target: "node",
|
|
481
|
-
objectExtraction: true,
|
|
482
|
-
}
|
|
483
|
-
);
|
|
484
|
-
|
|
485
|
-
expect(output).toContain("let");
|
|
486
|
-
|
|
487
|
-
var TEST_OUTPUT;
|
|
488
|
-
eval(output);
|
|
489
|
-
|
|
490
|
-
expect(TEST_OUTPUT).toStrictEqual(1);
|
|
491
|
-
});
|