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,157 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../src/index";
|
|
2
|
-
|
|
3
|
-
test("Variant #1: Force Block Statements on If statements", async () => {
|
|
4
|
-
var output = await JsConfuser.obfuscate(
|
|
5
|
-
`
|
|
6
|
-
if ( a ) b();
|
|
7
|
-
|
|
8
|
-
if ( a ) {} else c()
|
|
9
|
-
`,
|
|
10
|
-
{
|
|
11
|
-
target: "node",
|
|
12
|
-
compact: true, // <- Something needs to be enabled
|
|
13
|
-
}
|
|
14
|
-
);
|
|
15
|
-
|
|
16
|
-
// Ensure parenthesis were added
|
|
17
|
-
expect(output).toContain("{b()}");
|
|
18
|
-
expect(output).toContain("{c()}");
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
test("Variant #2: Force Block Statements on Arrow functions", async () => {
|
|
22
|
-
var output = await JsConfuser.obfuscate(
|
|
23
|
-
`
|
|
24
|
-
TEST_OUTPUT = ()=>true;
|
|
25
|
-
`,
|
|
26
|
-
{
|
|
27
|
-
target: "node",
|
|
28
|
-
compact: true, // <- Something needs to be enabled
|
|
29
|
-
}
|
|
30
|
-
);
|
|
31
|
-
|
|
32
|
-
// Ensure parenthesis were added
|
|
33
|
-
expect(output).toContain("return");
|
|
34
|
-
expect(output).toContain("{");
|
|
35
|
-
expect(output).toContain("}");
|
|
36
|
-
|
|
37
|
-
// Ensure code still works
|
|
38
|
-
var TEST_OUTPUT;
|
|
39
|
-
eval(output);
|
|
40
|
-
|
|
41
|
-
expect(typeof TEST_OUTPUT).toStrictEqual("function");
|
|
42
|
-
expect(TEST_OUTPUT()).toStrictEqual(true);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
test("Variant #3: Force Block Statements on For loops", async () => {
|
|
46
|
-
var output = await JsConfuser.obfuscate(
|
|
47
|
-
`
|
|
48
|
-
for(;;) forStatement();
|
|
49
|
-
for(a in b) forInStatement();
|
|
50
|
-
for(a of b) forOfStatement();
|
|
51
|
-
`,
|
|
52
|
-
{
|
|
53
|
-
target: "node",
|
|
54
|
-
compact: true, // <- Something needs to be enabled
|
|
55
|
-
}
|
|
56
|
-
);
|
|
57
|
-
|
|
58
|
-
// Ensure parenthesis were added
|
|
59
|
-
expect(output).toContain("{forStatement()}");
|
|
60
|
-
expect(output).toContain("{forInStatement()}");
|
|
61
|
-
expect(output).toContain("{forOfStatement()}");
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
test("Variant #4: Force Block Statements on While loops/With statement", async () => {
|
|
65
|
-
var output = await JsConfuser.obfuscate(
|
|
66
|
-
`
|
|
67
|
-
while(1) whileStatement();
|
|
68
|
-
with(a) withStatement();
|
|
69
|
-
`,
|
|
70
|
-
{
|
|
71
|
-
target: "node",
|
|
72
|
-
compact: true, // <- Something needs to be enabled
|
|
73
|
-
}
|
|
74
|
-
);
|
|
75
|
-
|
|
76
|
-
// Ensure parenthesis were added
|
|
77
|
-
expect(output).toContain("{whileStatement()}");
|
|
78
|
-
expect(output).toContain("{withStatement()}");
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
test("Variant #5: Force object accessors to use strings instead", async () => {
|
|
82
|
-
var output = await JsConfuser.obfuscate(
|
|
83
|
-
`
|
|
84
|
-
console.log("Hello World")
|
|
85
|
-
`,
|
|
86
|
-
{
|
|
87
|
-
target: "node",
|
|
88
|
-
compact: true, // <- Something needs to be enabled
|
|
89
|
-
}
|
|
90
|
-
);
|
|
91
|
-
|
|
92
|
-
// Ensure the member expression got changed to a string
|
|
93
|
-
expect(output).toContain("console['log']");
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
test("Variant #6: Force object property keys to use strings instead", async () => {
|
|
97
|
-
var output = await JsConfuser.obfuscate(
|
|
98
|
-
`
|
|
99
|
-
var myObject = {
|
|
100
|
-
myKey: 1
|
|
101
|
-
}
|
|
102
|
-
`,
|
|
103
|
-
{
|
|
104
|
-
target: "node",
|
|
105
|
-
compact: true, // <- Something needs to be enabled
|
|
106
|
-
}
|
|
107
|
-
);
|
|
108
|
-
|
|
109
|
-
// Ensure key got changed to a string
|
|
110
|
-
expect(output).toContain("'myKey'");
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
test("Variant #7: Force Variable declarations to be expanded", async () => {
|
|
114
|
-
var output = await JsConfuser.obfuscate(
|
|
115
|
-
`
|
|
116
|
-
var myVar1, myVar2, myVar3;
|
|
117
|
-
|
|
118
|
-
switch(true){
|
|
119
|
-
case true:
|
|
120
|
-
var mySwitchVar1, mySwitchVar2, mySwitchVar3;
|
|
121
|
-
break;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
{
|
|
125
|
-
var myBlockVar1;
|
|
126
|
-
var myBlockVar2;
|
|
127
|
-
var myBlockVar3;
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
if(true) var myIfVar1, myIfVar2, myIfVar3;
|
|
131
|
-
`,
|
|
132
|
-
{
|
|
133
|
-
target: "node",
|
|
134
|
-
compact: true, // <- Something needs to be enabled
|
|
135
|
-
}
|
|
136
|
-
);
|
|
137
|
-
|
|
138
|
-
// Ensure the variable declarations got changed
|
|
139
|
-
expect(output).toContain("var myVar1;");
|
|
140
|
-
expect(output).toContain("var myVar2;");
|
|
141
|
-
expect(output).toContain("var myVar3;");
|
|
142
|
-
|
|
143
|
-
// Ensure the switch declarations got changed
|
|
144
|
-
expect(output).toContain("var mySwitchVar1;");
|
|
145
|
-
expect(output).toContain("var mySwitchVar2;");
|
|
146
|
-
expect(output).toContain("var mySwitchVar3;");
|
|
147
|
-
|
|
148
|
-
// Ensure the block declarations got changed
|
|
149
|
-
expect(output).toContain("var myBlockVar1;");
|
|
150
|
-
expect(output).toContain("var myBlockVar2;");
|
|
151
|
-
expect(output).toContain("var myBlockVar3");
|
|
152
|
-
|
|
153
|
-
// Ensure the if-statement declarations got changed
|
|
154
|
-
expect(output).toContain("var myIfVar1;");
|
|
155
|
-
expect(output).toContain("var myIfVar2;");
|
|
156
|
-
expect(output).toContain("var myIfVar3");
|
|
157
|
-
});
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../src/index";
|
|
2
|
-
|
|
3
|
-
it("should rename labels", async () => {
|
|
4
|
-
var code = `
|
|
5
|
-
TEST_LABEL: while(0){}
|
|
6
|
-
`;
|
|
7
|
-
|
|
8
|
-
var output = await JsConfuser(code, {
|
|
9
|
-
target: "browser",
|
|
10
|
-
objectExtraction: true,
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
expect(output).not.toContain("TEST_LABEL");
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
it("should remove labels unused labels", async () => {
|
|
17
|
-
var code = `
|
|
18
|
-
TEST_LABEL: while(0){}
|
|
19
|
-
`;
|
|
20
|
-
|
|
21
|
-
var output = await JsConfuser(code, {
|
|
22
|
-
target: "browser",
|
|
23
|
-
objectExtraction: true,
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
expect(output).not.toContain("TEST_LABEL");
|
|
27
|
-
expect(output).not.toContain(":"); // No labels are required here
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
it("should use label-less break statements when possible", async () => {
|
|
31
|
-
var code = `
|
|
32
|
-
TEST_LABEL: while(0){
|
|
33
|
-
break TEST_LABEL;
|
|
34
|
-
}
|
|
35
|
-
`;
|
|
36
|
-
|
|
37
|
-
var output = await JsConfuser(code, {
|
|
38
|
-
target: "browser",
|
|
39
|
-
objectExtraction: true,
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
expect(output).not.toContain("TEST_LABEL");
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it("should not rename nested labels", async () => {
|
|
46
|
-
var code = `
|
|
47
|
-
TEST_LABEL: for ( var i =0; i < 10; i++ ) {
|
|
48
|
-
switch(1){
|
|
49
|
-
case 1:
|
|
50
|
-
break TEST_LABEL;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
`;
|
|
54
|
-
|
|
55
|
-
var output = await JsConfuser(code, {
|
|
56
|
-
target: "browser",
|
|
57
|
-
objectExtraction: true,
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
expect(output).not.toContain("TEST_LABEL");
|
|
61
|
-
expect(output).toContain(":for");
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
it("should not remove labels on block statements", async () => {
|
|
65
|
-
var code = `
|
|
66
|
-
TEST_LABEL: {
|
|
67
|
-
break TEST_LABEL;
|
|
68
|
-
}
|
|
69
|
-
`;
|
|
70
|
-
|
|
71
|
-
var output = await JsConfuser(code, {
|
|
72
|
-
target: "browser",
|
|
73
|
-
objectExtraction: true,
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
expect(output).not.toContain("TEST_LABEL");
|
|
77
|
-
expect(output).toContain(":{");
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it("should remove labels on block statements when the label was never used", async () => {
|
|
81
|
-
var code = `
|
|
82
|
-
TEST_LABEL: {
|
|
83
|
-
"";
|
|
84
|
-
}
|
|
85
|
-
`;
|
|
86
|
-
|
|
87
|
-
var output = await JsConfuser(code, {
|
|
88
|
-
target: "browser",
|
|
89
|
-
objectExtraction: true,
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
expect(output).not.toContain("TEST_LABEL");
|
|
93
|
-
expect(output).not.toContain(":{");
|
|
94
|
-
expect(output).toContain("{");
|
|
95
|
-
});
|
|
@@ -1,378 +0,0 @@
|
|
|
1
|
-
import { writeFileSync } from "fs";
|
|
2
|
-
import JsConfuser from "../../src/index";
|
|
3
|
-
|
|
4
|
-
test("Variant #1: Convert Function Declaration into 'new Function' code", async () => {
|
|
5
|
-
var output = await JsConfuser.obfuscate(
|
|
6
|
-
`
|
|
7
|
-
function addTwoNumbers(a, b){
|
|
8
|
-
return a + b;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
TEST_OUTPUT = addTwoNumbers(10, 5);
|
|
12
|
-
`,
|
|
13
|
-
{
|
|
14
|
-
target: "node",
|
|
15
|
-
rgf: true,
|
|
16
|
-
}
|
|
17
|
-
);
|
|
18
|
-
|
|
19
|
-
expect(output).toContain("new Function");
|
|
20
|
-
|
|
21
|
-
var TEST_OUTPUT;
|
|
22
|
-
eval(output);
|
|
23
|
-
|
|
24
|
-
expect(TEST_OUTPUT).toStrictEqual(15);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
test("Variant #2: Convert Function Expression into 'new Function' code", async () => {
|
|
28
|
-
var output = await JsConfuser.obfuscate(
|
|
29
|
-
`
|
|
30
|
-
var addTwoNumbers = function(a, b){
|
|
31
|
-
return a + b;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
TEST_OUTPUT = addTwoNumbers(10, 5);
|
|
35
|
-
`,
|
|
36
|
-
{
|
|
37
|
-
target: "node",
|
|
38
|
-
rgf: true,
|
|
39
|
-
}
|
|
40
|
-
);
|
|
41
|
-
|
|
42
|
-
expect(output).toContain("new Function");
|
|
43
|
-
|
|
44
|
-
var TEST_OUTPUT;
|
|
45
|
-
eval(output);
|
|
46
|
-
|
|
47
|
-
expect(TEST_OUTPUT).toStrictEqual(15);
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
test("Variant #3: Convert functions that use global variables", async () => {
|
|
51
|
-
var output = await JsConfuser.obfuscate(
|
|
52
|
-
`
|
|
53
|
-
function floorNumber(num){
|
|
54
|
-
return Math.floor(num);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
TEST_OUTPUT = floorNumber(1.9);
|
|
58
|
-
`,
|
|
59
|
-
{
|
|
60
|
-
target: "node",
|
|
61
|
-
rgf: true,
|
|
62
|
-
}
|
|
63
|
-
);
|
|
64
|
-
|
|
65
|
-
expect(output).toContain("new Function");
|
|
66
|
-
|
|
67
|
-
var TEST_OUTPUT;
|
|
68
|
-
eval(output);
|
|
69
|
-
|
|
70
|
-
expect(TEST_OUTPUT).toStrictEqual(1);
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
test("Variant #4: Don't convert functions that rely on outside-scoped variables", async () => {
|
|
74
|
-
var output = await JsConfuser.obfuscate(
|
|
75
|
-
`
|
|
76
|
-
var _Math = Math;
|
|
77
|
-
|
|
78
|
-
function floorNumber(num){
|
|
79
|
-
return _Math.floor(num);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
TEST_OUTPUT = floorNumber(1.9);
|
|
83
|
-
`,
|
|
84
|
-
{
|
|
85
|
-
target: "node",
|
|
86
|
-
rgf: true,
|
|
87
|
-
}
|
|
88
|
-
);
|
|
89
|
-
|
|
90
|
-
expect(output).not.toContain("new Function");
|
|
91
|
-
|
|
92
|
-
var TEST_OUTPUT;
|
|
93
|
-
eval(output);
|
|
94
|
-
|
|
95
|
-
expect(TEST_OUTPUT).toStrictEqual(1);
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
test("Variant #5: Don't convert functions that rely on outside-scoped variables (trap)", async () => {
|
|
99
|
-
var output = await JsConfuser.obfuscate(
|
|
100
|
-
`
|
|
101
|
-
var _Math = Math;
|
|
102
|
-
|
|
103
|
-
function floorNumber(num){
|
|
104
|
-
(()=>{
|
|
105
|
-
var _Math;
|
|
106
|
-
})();
|
|
107
|
-
return _Math.floor(num);
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
TEST_OUTPUT = floorNumber(1.9);
|
|
111
|
-
`,
|
|
112
|
-
{
|
|
113
|
-
target: "node",
|
|
114
|
-
rgf: true,
|
|
115
|
-
}
|
|
116
|
-
);
|
|
117
|
-
|
|
118
|
-
expect(output).not.toContain("new Function");
|
|
119
|
-
|
|
120
|
-
var TEST_OUTPUT;
|
|
121
|
-
eval(output);
|
|
122
|
-
|
|
123
|
-
expect(TEST_OUTPUT).toStrictEqual(1);
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
test("Variant #6: Work on High Preset", async () => {
|
|
127
|
-
var output = await JsConfuser.obfuscate(
|
|
128
|
-
`
|
|
129
|
-
function addTwoNumbers(a, b){
|
|
130
|
-
return a + b;
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
TEST_OUTPUT = addTwoNumbers(10, 5);
|
|
134
|
-
`,
|
|
135
|
-
{
|
|
136
|
-
target: "node",
|
|
137
|
-
preset: "high",
|
|
138
|
-
rgf: true,
|
|
139
|
-
}
|
|
140
|
-
);
|
|
141
|
-
|
|
142
|
-
var TEST_OUTPUT;
|
|
143
|
-
eval(output);
|
|
144
|
-
|
|
145
|
-
expect(TEST_OUTPUT).toStrictEqual(15);
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
test("Variant #7: Don't convert arrow, async, or generator functions", async () => {
|
|
149
|
-
var output = await JsConfuser.obfuscate(
|
|
150
|
-
`
|
|
151
|
-
var arrowFunction = ()=>{};
|
|
152
|
-
async function asyncFunction(){
|
|
153
|
-
|
|
154
|
-
};
|
|
155
|
-
function* generatorFunction(){
|
|
156
|
-
yield "Correct Value";
|
|
157
|
-
};
|
|
158
|
-
|
|
159
|
-
TEST_OUTPUT = generatorFunction().next().value;
|
|
160
|
-
`,
|
|
161
|
-
{
|
|
162
|
-
target: "node",
|
|
163
|
-
rgf: true,
|
|
164
|
-
}
|
|
165
|
-
);
|
|
166
|
-
|
|
167
|
-
expect(output).not.toContain("new Function");
|
|
168
|
-
|
|
169
|
-
var TEST_OUTPUT;
|
|
170
|
-
eval(output);
|
|
171
|
-
|
|
172
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
test("Variant #8: Modified Function", async () => {
|
|
176
|
-
var output = await JsConfuser.obfuscate(
|
|
177
|
-
`
|
|
178
|
-
function addTwoNumbers(x,y){
|
|
179
|
-
return x + y;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
addTwoNumbers = function(){
|
|
183
|
-
return "Incorrect Value";
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
addTwoNumbers = ()=>{
|
|
187
|
-
return "Correct Value";
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
TEST_OUTPUT = addTwoNumbers(10, 5);
|
|
191
|
-
`,
|
|
192
|
-
{
|
|
193
|
-
target: "node",
|
|
194
|
-
rgf: true,
|
|
195
|
-
}
|
|
196
|
-
);
|
|
197
|
-
|
|
198
|
-
expect(output).toContain("new Function");
|
|
199
|
-
|
|
200
|
-
var TEST_OUTPUT;
|
|
201
|
-
eval(output);
|
|
202
|
-
|
|
203
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
204
|
-
});
|
|
205
|
-
|
|
206
|
-
test("Variant #8: Modified Function (non function value)", async () => {
|
|
207
|
-
var output = await JsConfuser.obfuscate(
|
|
208
|
-
`
|
|
209
|
-
function addTwoNumbers(x,y){
|
|
210
|
-
return x+y;
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
addTwoNumbers = "Correct Value";
|
|
214
|
-
|
|
215
|
-
TEST_OUTPUT = addTwoNumbers;
|
|
216
|
-
`,
|
|
217
|
-
{
|
|
218
|
-
target: "node",
|
|
219
|
-
rgf: true,
|
|
220
|
-
}
|
|
221
|
-
);
|
|
222
|
-
|
|
223
|
-
expect(output).toContain("new Function");
|
|
224
|
-
|
|
225
|
-
var TEST_OUTPUT;
|
|
226
|
-
eval(output);
|
|
227
|
-
|
|
228
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
229
|
-
});
|
|
230
|
-
|
|
231
|
-
test("Variant #9: Work with Flatten on any function", async () => {
|
|
232
|
-
var output = await JsConfuser.obfuscate(
|
|
233
|
-
`
|
|
234
|
-
var outsideCounter = 0;
|
|
235
|
-
var outsideFlag = false;
|
|
236
|
-
|
|
237
|
-
function incrementOutsideCounter(){
|
|
238
|
-
outsideCounter++;
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
function incrementTimes(times){
|
|
242
|
-
for( var i = 0; i < times; i++ ) {
|
|
243
|
-
incrementOutsideCounter();
|
|
244
|
-
}
|
|
245
|
-
if( outsideFlag ) {
|
|
246
|
-
TEST_OUTPUT = times === 1 && outsideCounter === 10 ? "Correct Value" : "Incorrect Value";
|
|
247
|
-
}
|
|
248
|
-
outsideFlag = true;
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
incrementOutsideCounter();
|
|
252
|
-
incrementTimes(8);
|
|
253
|
-
incrementTimes(1);
|
|
254
|
-
`,
|
|
255
|
-
{
|
|
256
|
-
target: "node",
|
|
257
|
-
rgf: true,
|
|
258
|
-
flatten: true,
|
|
259
|
-
}
|
|
260
|
-
);
|
|
261
|
-
|
|
262
|
-
expect(output).toContain("new Function");
|
|
263
|
-
|
|
264
|
-
var TEST_OUTPUT;
|
|
265
|
-
eval(output);
|
|
266
|
-
|
|
267
|
-
expect(TEST_OUTPUT).toStrictEqual("Correct Value");
|
|
268
|
-
});
|
|
269
|
-
|
|
270
|
-
test("Variant #10: Configurable by custom function option", async () => {
|
|
271
|
-
var functionNames: string[] = [];
|
|
272
|
-
|
|
273
|
-
var output = await JsConfuser(
|
|
274
|
-
`
|
|
275
|
-
"use strict";
|
|
276
|
-
|
|
277
|
-
// By checking strict-mode, we can check if the function was RGF or not
|
|
278
|
-
function rgfThisFunction(){
|
|
279
|
-
var isStrictMode = () => {
|
|
280
|
-
try {
|
|
281
|
-
undefined = true;
|
|
282
|
-
} catch (E) {
|
|
283
|
-
return true;
|
|
284
|
-
}
|
|
285
|
-
return false;
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
return isStrictMode();
|
|
289
|
-
}
|
|
290
|
-
|
|
291
|
-
function doNotRgfThisFunction(){
|
|
292
|
-
var isStrictMode = () => {
|
|
293
|
-
try {
|
|
294
|
-
undefined = true;
|
|
295
|
-
} catch (E) {
|
|
296
|
-
return true;
|
|
297
|
-
}
|
|
298
|
-
return false;
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
return isStrictMode();
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
TEST_OUTPUT_1 = rgfThisFunction();
|
|
305
|
-
TEST_OUTPUT_2 = doNotRgfThisFunction();
|
|
306
|
-
`,
|
|
307
|
-
{
|
|
308
|
-
target: "node",
|
|
309
|
-
rgf: (name) => {
|
|
310
|
-
functionNames.push(name);
|
|
311
|
-
return name !== "doNotRgfThisFunction";
|
|
312
|
-
},
|
|
313
|
-
}
|
|
314
|
-
);
|
|
315
|
-
|
|
316
|
-
expect(functionNames).toStrictEqual([
|
|
317
|
-
"rgfThisFunction",
|
|
318
|
-
"doNotRgfThisFunction",
|
|
319
|
-
]);
|
|
320
|
-
expect(output).toContain("new Function");
|
|
321
|
-
|
|
322
|
-
var TEST_OUTPUT_1;
|
|
323
|
-
var TEST_OUTPUT_2;
|
|
324
|
-
|
|
325
|
-
eval(output);
|
|
326
|
-
expect(TEST_OUTPUT_1).toStrictEqual(false);
|
|
327
|
-
expect(TEST_OUTPUT_2).toStrictEqual(true);
|
|
328
|
-
});
|
|
329
|
-
|
|
330
|
-
test("Variant #11: Function containing function should both be changed", async function () {
|
|
331
|
-
var output = await JsConfuser(
|
|
332
|
-
`
|
|
333
|
-
function FunctionA(){
|
|
334
|
-
function FunctionB(){
|
|
335
|
-
var bVar = 10;
|
|
336
|
-
return bVar
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
var bFn = FunctionB;
|
|
340
|
-
var aVar = bFn();
|
|
341
|
-
return aVar + 1
|
|
342
|
-
}
|
|
343
|
-
|
|
344
|
-
TEST_OUTPUT = FunctionA();
|
|
345
|
-
`,
|
|
346
|
-
{ target: "node", rgf: true }
|
|
347
|
-
);
|
|
348
|
-
|
|
349
|
-
// 2 means one Function changed, 3 means two Functions changed
|
|
350
|
-
expect(output.split("new Function").length).toStrictEqual(3);
|
|
351
|
-
|
|
352
|
-
var TEST_OUTPUT;
|
|
353
|
-
eval(output);
|
|
354
|
-
|
|
355
|
-
expect(TEST_OUTPUT).toStrictEqual(11);
|
|
356
|
-
});
|
|
357
|
-
|
|
358
|
-
test("Variant #12: Preserve Function.length", async function () {
|
|
359
|
-
var output = await JsConfuser(
|
|
360
|
-
`
|
|
361
|
-
function myFunction(a,b,c,d = ""){ // Function.length = 3
|
|
362
|
-
|
|
363
|
-
}
|
|
364
|
-
|
|
365
|
-
myFunction()
|
|
366
|
-
TEST_OUTPUT = myFunction.length
|
|
367
|
-
`,
|
|
368
|
-
{
|
|
369
|
-
target: "node",
|
|
370
|
-
rgf: true,
|
|
371
|
-
}
|
|
372
|
-
);
|
|
373
|
-
|
|
374
|
-
var TEST_OUTPUT;
|
|
375
|
-
eval(output);
|
|
376
|
-
|
|
377
|
-
expect(TEST_OUTPUT).toStrictEqual(3);
|
|
378
|
-
});
|