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,621 +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
|
-
TEST_OUTPUT = myVar1;
|
|
513
|
-
`,
|
|
514
|
-
{
|
|
515
|
-
target: "node",
|
|
516
|
-
renameVariables: true,
|
|
517
|
-
identifierGenerator:
|
|
518
|
-
identifierGeneratorMode as ObfuscateOptions["identifierGenerator"],
|
|
519
|
-
}
|
|
520
|
-
);
|
|
521
|
-
|
|
522
|
-
// Ensure 'myVar1' got renamed
|
|
523
|
-
expect(output).not.toContain("myVar1");
|
|
524
|
-
|
|
525
|
-
var TEST_OUTPUT;
|
|
526
|
-
|
|
527
|
-
eval(output);
|
|
528
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
529
|
-
}
|
|
530
|
-
);
|
|
531
|
-
|
|
532
|
-
test("Variant #22: Don't rename variables prefixed with '__NO_JS_CONFUSER_RENAME__'", async () => {
|
|
533
|
-
var output = await JsConfuser(
|
|
534
|
-
`
|
|
535
|
-
var myValue = "Correct Value";
|
|
536
|
-
|
|
537
|
-
var __NO_JS_CONFUSER_RENAME__myVar4 = "Incorrect Value";
|
|
538
|
-
|
|
539
|
-
__NO_JS_CONFUSER_RENAME__myVar4 = myValue;
|
|
540
|
-
|
|
541
|
-
eval( "TEST_OUTPUT = __NO_JS_CONFUSER_RENAME__myVar4" );
|
|
542
|
-
`,
|
|
543
|
-
{
|
|
544
|
-
target: "node",
|
|
545
|
-
renameVariables: true,
|
|
546
|
-
}
|
|
547
|
-
);
|
|
548
|
-
|
|
549
|
-
// Ensure 'myValue' got renamed
|
|
550
|
-
expect(output).not.toContain("myValue");
|
|
551
|
-
// Ensure '__NO_JS_CONFUSER_RENAME__myVar4' was not renamed
|
|
552
|
-
expect(output).toContain("__NO_JS_CONFUSER_RENAME__myVar4");
|
|
553
|
-
|
|
554
|
-
// Test the code
|
|
555
|
-
var TEST_OUTPUT;
|
|
556
|
-
|
|
557
|
-
eval(output);
|
|
558
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
559
|
-
});
|
|
560
|
-
|
|
561
|
-
test("Variant #23: Re-use previously generated names", async () => {
|
|
562
|
-
var output = await JsConfuser(
|
|
563
|
-
`
|
|
564
|
-
function log(message){
|
|
565
|
-
TEST_OUTPUT = message;
|
|
566
|
-
}
|
|
567
|
-
|
|
568
|
-
log("Correct Value");
|
|
569
|
-
`,
|
|
570
|
-
{
|
|
571
|
-
target: "node",
|
|
572
|
-
renameVariables: true,
|
|
573
|
-
identifierGenerator: "mangled",
|
|
574
|
-
}
|
|
575
|
-
);
|
|
576
|
-
|
|
577
|
-
expect(output).not.toContain("log");
|
|
578
|
-
expect(output).toContain("function a(a)");
|
|
579
|
-
|
|
580
|
-
var TEST_OUTPUT;
|
|
581
|
-
eval(output);
|
|
582
|
-
|
|
583
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
584
|
-
});
|
|
585
|
-
|
|
586
|
-
test("Variant #24: Reference function name with parameter", async () => {
|
|
587
|
-
var output = await JsConfuser(
|
|
588
|
-
`
|
|
589
|
-
function myFunction(myFunction){
|
|
590
|
-
myFunction.property = "Correct Value";
|
|
591
|
-
}
|
|
592
|
-
|
|
593
|
-
myFunction(myFunction);
|
|
594
|
-
TEST_OUTPUT = myFunction.property;
|
|
595
|
-
`,
|
|
596
|
-
{ target: "node", renameVariables: true }
|
|
597
|
-
);
|
|
598
|
-
|
|
599
|
-
var TEST_OUTPUT;
|
|
600
|
-
eval(output);
|
|
601
|
-
|
|
602
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
603
|
-
});
|
|
604
|
-
|
|
605
|
-
test("Variant #25: Reference catch parameter", async () => {
|
|
606
|
-
var output = await JsConfuser(
|
|
607
|
-
`
|
|
608
|
-
try {
|
|
609
|
-
throw "Correct Value";
|
|
610
|
-
} catch ( e ) {
|
|
611
|
-
TEST_OUTPUT = e;
|
|
612
|
-
}
|
|
613
|
-
`,
|
|
614
|
-
{ target: "node", renameVariables: true }
|
|
615
|
-
);
|
|
616
|
-
|
|
617
|
-
var TEST_OUTPUT;
|
|
618
|
-
eval(output);
|
|
619
|
-
|
|
620
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
621
|
-
});
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../../src/index";
|
|
2
|
-
|
|
3
|
-
it("add debugger statements", async () => {
|
|
4
|
-
var output = await JsConfuser.obfuscate("input(true)", {
|
|
5
|
-
target: "node",
|
|
6
|
-
lock: {
|
|
7
|
-
antiDebug: true,
|
|
8
|
-
},
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
expect(output).toContain("debugger");
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
it("add a background interval", async () => {
|
|
15
|
-
var output = await JsConfuser.obfuscate("input(true)", {
|
|
16
|
-
target: "node",
|
|
17
|
-
lock: {
|
|
18
|
-
antiDebug: true,
|
|
19
|
-
},
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
expect(output).toContain("setInterval");
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
it("should place syntax-correct code", async () => {
|
|
26
|
-
for (var i = 0; i < 25; i++) {
|
|
27
|
-
var output = await JsConfuser.obfuscate(
|
|
28
|
-
`
|
|
29
|
-
/**
|
|
30
|
-
* GitHub: https://github.com/MichaelXF/js-confuser
|
|
31
|
-
* NPM: https://www.npmjs.com/package/js-confuser
|
|
32
|
-
*
|
|
33
|
-
* Welcome to Js Confuser
|
|
34
|
-
*
|
|
35
|
-
* You can obfuscate the code with the top right button 'Obfuscate'.
|
|
36
|
-
*
|
|
37
|
-
* You can customize the obfuscator with the button 'Options'.
|
|
38
|
-
* (Set the target to 'node' for NodeJS apps)
|
|
39
|
-
*
|
|
40
|
-
* Happy Hacking!
|
|
41
|
-
*/
|
|
42
|
-
|
|
43
|
-
function greet(name){
|
|
44
|
-
var output = "Hello " + name + "!";
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
greet("Internet User");
|
|
48
|
-
|
|
49
|
-
`,
|
|
50
|
-
{
|
|
51
|
-
compact: true,
|
|
52
|
-
controlFlowFlattening: true,
|
|
53
|
-
identifierGenerator: "randomized",
|
|
54
|
-
lock: { antiDebug: true },
|
|
55
|
-
minify: true,
|
|
56
|
-
target: "node",
|
|
57
|
-
}
|
|
58
|
-
);
|
|
59
|
-
|
|
60
|
-
try {
|
|
61
|
-
eval(output);
|
|
62
|
-
} catch (e) {
|
|
63
|
-
expect(e).toStrictEqual(undefined);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
});
|