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
package/test/index.test.ts
DELETED
|
@@ -1,249 +0,0 @@
|
|
|
1
|
-
import JsConfuser, {
|
|
2
|
-
debugObfuscation,
|
|
3
|
-
debugTransformations,
|
|
4
|
-
} from "../src/index";
|
|
5
|
-
|
|
6
|
-
it("should be a function", async () => {
|
|
7
|
-
expect(typeof JsConfuser).toBe("function");
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
it("should return be an awaited string", async () => {
|
|
11
|
-
var output = await JsConfuser("5+5", {
|
|
12
|
-
target: "browser",
|
|
13
|
-
opaquePredicates: true,
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
expect(typeof output).toBe("string");
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
it("should error when options are empty", async () => {
|
|
20
|
-
var invalid: any = {};
|
|
21
|
-
|
|
22
|
-
await expect(async () => {
|
|
23
|
-
return await JsConfuser("5+5", invalid);
|
|
24
|
-
}).rejects.toThrow();
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
it("should error when no obfuscation options", async () => {
|
|
28
|
-
var invalid: any = {
|
|
29
|
-
target: "browser",
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
await expect(async () => {
|
|
33
|
-
return await JsConfuser("5+5", invalid);
|
|
34
|
-
}).rejects.toThrow();
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it("should error on invalid target values", async () => {
|
|
38
|
-
var invalid: any = {
|
|
39
|
-
target: "__invalid__target__",
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
await expect(async () => {
|
|
43
|
-
return await JsConfuser("5+5", invalid);
|
|
44
|
-
}).rejects.toThrow();
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
it("should error when target property missing", async () => {
|
|
48
|
-
var invalid: any = {
|
|
49
|
-
objectExtraction: true,
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
await expect(async () => {
|
|
53
|
-
return await JsConfuser("5+5", invalid);
|
|
54
|
-
}).rejects.toThrow();
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
it("should error when invalid options are passed in", async () => {
|
|
58
|
-
var invalid: any = {
|
|
59
|
-
target: "browser",
|
|
60
|
-
__invalid__prop__: true,
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
await expect(async () => {
|
|
64
|
-
return await JsConfuser("5+5", invalid);
|
|
65
|
-
}).rejects.toThrow();
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it("should error when browserLock is used on target 'node'", async () => {
|
|
69
|
-
var invalid: any = {
|
|
70
|
-
target: "node",
|
|
71
|
-
lock: {
|
|
72
|
-
browserLock: ["firefox"],
|
|
73
|
-
},
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
await expect(async () => {
|
|
77
|
-
return await JsConfuser("5+5", invalid);
|
|
78
|
-
}).rejects.toThrow();
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
it("should error when invalid browser names are passed in", async () => {
|
|
82
|
-
var invalid: any = {
|
|
83
|
-
target: "browser",
|
|
84
|
-
lock: {
|
|
85
|
-
browserLock: ["__invalid__browser__"],
|
|
86
|
-
},
|
|
87
|
-
};
|
|
88
|
-
|
|
89
|
-
await expect(async () => {
|
|
90
|
-
return await JsConfuser("5+5", invalid);
|
|
91
|
-
}).rejects.toThrow();
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it("should error when invalid os names are passed in", async () => {
|
|
95
|
-
var invalid: any = {
|
|
96
|
-
target: "browser",
|
|
97
|
-
lock: {
|
|
98
|
-
osLock: ["__invalid__browser__"],
|
|
99
|
-
},
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
await expect(async () => {
|
|
103
|
-
return await JsConfuser("5+5", invalid);
|
|
104
|
-
}).rejects.toThrow();
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
it("should error when invalid startDate is passed in", async () => {
|
|
108
|
-
var invalid: any = {
|
|
109
|
-
target: "browser",
|
|
110
|
-
lock: {
|
|
111
|
-
startDate: "__invalid__date__object__",
|
|
112
|
-
},
|
|
113
|
-
};
|
|
114
|
-
|
|
115
|
-
await expect(async () => {
|
|
116
|
-
return await JsConfuser("5+5", invalid);
|
|
117
|
-
}).rejects.toThrow();
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
it("should error when invalid endDate is passed in", async () => {
|
|
121
|
-
var invalid: any = {
|
|
122
|
-
target: "browser",
|
|
123
|
-
lock: {
|
|
124
|
-
endDate: "__invalid__date__object__",
|
|
125
|
-
},
|
|
126
|
-
};
|
|
127
|
-
|
|
128
|
-
await expect(async () => {
|
|
129
|
-
return await JsConfuser("5+5", invalid);
|
|
130
|
-
}).rejects.toThrow();
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
it("should error when source code is not a string", async () => {
|
|
134
|
-
await expect(async () => {
|
|
135
|
-
return await JsConfuser({} as any, {
|
|
136
|
-
target: "node",
|
|
137
|
-
preset: "low",
|
|
138
|
-
});
|
|
139
|
-
}).rejects.toThrow();
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
it("should error when invalid source code is passed in", async () => {
|
|
143
|
-
await expect(async () => {
|
|
144
|
-
return await JsConfuser("#?!if?//for:;1(function:class{))]][]", {
|
|
145
|
-
target: "node",
|
|
146
|
-
preset: "low",
|
|
147
|
-
});
|
|
148
|
-
}).rejects.toThrow();
|
|
149
|
-
});
|
|
150
|
-
|
|
151
|
-
describe("obfuscateAST", () => {
|
|
152
|
-
test("Variant #1: Mutate AST", async () => {
|
|
153
|
-
var AST = {
|
|
154
|
-
type: "Program",
|
|
155
|
-
body: [
|
|
156
|
-
{
|
|
157
|
-
type: "ExpressionStatement",
|
|
158
|
-
expression: { type: "Literal", value: true },
|
|
159
|
-
},
|
|
160
|
-
],
|
|
161
|
-
};
|
|
162
|
-
var before = JSON.stringify(AST);
|
|
163
|
-
|
|
164
|
-
JsConfuser.obfuscateAST(AST, { target: "node", es5: true });
|
|
165
|
-
|
|
166
|
-
var after = JSON.stringify(AST);
|
|
167
|
-
|
|
168
|
-
// Same object reference
|
|
169
|
-
expect(AST === AST).toStrictEqual(true);
|
|
170
|
-
|
|
171
|
-
// Different string
|
|
172
|
-
expect(before !== after).toStrictEqual(false);
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
test("Variant #2: Error on invalid parameters", async () => {
|
|
176
|
-
await expect(async () => {
|
|
177
|
-
return await JsConfuser.obfuscateAST("string", {
|
|
178
|
-
target: "node",
|
|
179
|
-
preset: "low",
|
|
180
|
-
});
|
|
181
|
-
}).rejects.toThrow();
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
test("Variant #3: Error on invalid AST", async () => {
|
|
185
|
-
await expect(async () => {
|
|
186
|
-
var invalidAST = {
|
|
187
|
-
type: "NotProgram",
|
|
188
|
-
};
|
|
189
|
-
|
|
190
|
-
return await JsConfuser.obfuscateAST(invalidAST, {
|
|
191
|
-
target: "node",
|
|
192
|
-
preset: "low",
|
|
193
|
-
});
|
|
194
|
-
}).rejects.toThrow();
|
|
195
|
-
});
|
|
196
|
-
});
|
|
197
|
-
|
|
198
|
-
describe("debugTransformations", () => {
|
|
199
|
-
test("Variant #1: Return array of objects containing `name`, `code`, and `ms` properties", async () => {
|
|
200
|
-
var frames = await debugTransformations(`console.log(1)`, {
|
|
201
|
-
target: "node",
|
|
202
|
-
preset: "low",
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
expect(Array.isArray(frames)).toStrictEqual(true);
|
|
206
|
-
expect(frames.length).toBeTruthy();
|
|
207
|
-
|
|
208
|
-
frames.forEach((frame) => {
|
|
209
|
-
expect(typeof frame.name).toStrictEqual("string");
|
|
210
|
-
expect(typeof frame.code).toStrictEqual("string");
|
|
211
|
-
expect(typeof frame.ms).toStrictEqual("number");
|
|
212
|
-
});
|
|
213
|
-
});
|
|
214
|
-
});
|
|
215
|
-
|
|
216
|
-
describe("debugObfuscation", () => {
|
|
217
|
-
test("Variant #1: Return array of objects containing code, ms, and name properties", async () => {
|
|
218
|
-
var called = false;
|
|
219
|
-
|
|
220
|
-
var callback = (name, complete, totalTransforms) => {
|
|
221
|
-
expect(typeof name).toStrictEqual("string");
|
|
222
|
-
expect(typeof complete).toStrictEqual("number");
|
|
223
|
-
expect(typeof totalTransforms).toStrictEqual("number");
|
|
224
|
-
|
|
225
|
-
called = true;
|
|
226
|
-
};
|
|
227
|
-
var output = await debugObfuscation(
|
|
228
|
-
`console.log(1)`,
|
|
229
|
-
{ target: "node", preset: "low" },
|
|
230
|
-
callback,
|
|
231
|
-
require("perf_hooks").performance
|
|
232
|
-
);
|
|
233
|
-
|
|
234
|
-
expect(typeof output).toStrictEqual("object");
|
|
235
|
-
expect(typeof output.obfuscated).toStrictEqual("string");
|
|
236
|
-
expect(typeof output.obfuscationTime).toStrictEqual("number");
|
|
237
|
-
expect(typeof output.compileTime).toStrictEqual("number");
|
|
238
|
-
expect(typeof output.parseTime).toStrictEqual("number");
|
|
239
|
-
expect(typeof output.totalPossibleTransforms).toStrictEqual("number");
|
|
240
|
-
expect(typeof output.totalTransforms).toStrictEqual("number");
|
|
241
|
-
expect(typeof output.transformationTimes).toStrictEqual("object");
|
|
242
|
-
expect(typeof output.transformationTimes.RenameVariables).toStrictEqual(
|
|
243
|
-
"number"
|
|
244
|
-
);
|
|
245
|
-
|
|
246
|
-
eval(output.obfuscated);
|
|
247
|
-
expect(called).toStrictEqual(true);
|
|
248
|
-
});
|
|
249
|
-
});
|
package/test/options.test.ts
DELETED
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../src/index";
|
|
2
|
-
|
|
3
|
-
describe("options", () => {
|
|
4
|
-
test("Variant #1: Accept percentages", async () => {
|
|
5
|
-
var output = await JsConfuser(`var TEST_VARIABLE;`, {
|
|
6
|
-
target: "node",
|
|
7
|
-
renameGlobals: true,
|
|
8
|
-
renameVariables: true,
|
|
9
|
-
stringConcealing: 0.5,
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
test("Variant #2: Accept probability arrays", async () => {
|
|
16
|
-
var output = await JsConfuser(`var TEST_VARIABLE;`, {
|
|
17
|
-
target: "node",
|
|
18
|
-
renameVariables: true,
|
|
19
|
-
renameGlobals: true,
|
|
20
|
-
identifierGenerator: ["hexadecimal", "mangled"], // half hexadecimal, half randomized
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
test("Variant #3: Accept probability maps", async () => {
|
|
27
|
-
var output = await JsConfuser(`var TEST_VARIABLE;`, {
|
|
28
|
-
target: "node",
|
|
29
|
-
renameVariables: true,
|
|
30
|
-
renameGlobals: true,
|
|
31
|
-
identifierGenerator: {
|
|
32
|
-
// 25% each
|
|
33
|
-
hexadecimal: 0.25,
|
|
34
|
-
randomized: 0.25,
|
|
35
|
-
mangled: 0.25,
|
|
36
|
-
number: 0.25,
|
|
37
|
-
},
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
test("Variant #4: Work with compact false", async () => {
|
|
44
|
-
var output = await JsConfuser(`var TEST_VARIABLE;`, {
|
|
45
|
-
target: "node",
|
|
46
|
-
renameGlobals: true,
|
|
47
|
-
renameVariables: true,
|
|
48
|
-
compact: false,
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
test("Variant #5: Work with indent set to 2 spaces", async () => {
|
|
55
|
-
var output = await JsConfuser(`var TEST_VARIABLE;`, {
|
|
56
|
-
target: "node",
|
|
57
|
-
renameGlobals: true,
|
|
58
|
-
renameVariables: true,
|
|
59
|
-
compact: false,
|
|
60
|
-
indent: 2,
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
test("Variant #6: Work with debugComments enabled", async () => {
|
|
67
|
-
var output = await JsConfuser(`var TEST_VARIABLE;`, {
|
|
68
|
-
target: "node",
|
|
69
|
-
renameGlobals: true,
|
|
70
|
-
renameVariables: true,
|
|
71
|
-
compact: false,
|
|
72
|
-
indent: 2,
|
|
73
|
-
debugComments: true,
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
expect(output).not.toContain("TEST_VARIABLE");
|
|
77
|
-
});
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
describe("options.preserveFunctionLength", () => {
|
|
81
|
-
test("Variant #1: Enabled by default", async () => {
|
|
82
|
-
var output = await JsConfuser(
|
|
83
|
-
`
|
|
84
|
-
function myFunction(a, b, c, d = "") {
|
|
85
|
-
// Function.length = 3
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
TEST_OUTPUT = myFunction.length; // 3
|
|
89
|
-
`,
|
|
90
|
-
{
|
|
91
|
-
target: "node",
|
|
92
|
-
preset: "high",
|
|
93
|
-
}
|
|
94
|
-
);
|
|
95
|
-
|
|
96
|
-
var TEST_OUTPUT;
|
|
97
|
-
eval(output);
|
|
98
|
-
expect(TEST_OUTPUT).toStrictEqual(3);
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
test("Variant #2: Disabled", async () => {
|
|
102
|
-
var output = await JsConfuser(
|
|
103
|
-
`
|
|
104
|
-
function myFunction(a, b, c, d = "") {
|
|
105
|
-
// Function.length = 3
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
TEST_OUTPUT = myFunction.length; // 3
|
|
109
|
-
`,
|
|
110
|
-
{
|
|
111
|
-
target: "node",
|
|
112
|
-
preset: "high",
|
|
113
|
-
preserveFunctionLength: false,
|
|
114
|
-
|
|
115
|
-
stringEncoding: false,
|
|
116
|
-
stringCompression: false,
|
|
117
|
-
stringConcealing: false,
|
|
118
|
-
stringSplitting: false,
|
|
119
|
-
deadCode: false,
|
|
120
|
-
duplicateLiteralsRemoval: false,
|
|
121
|
-
|
|
122
|
-
rgf: true,
|
|
123
|
-
}
|
|
124
|
-
);
|
|
125
|
-
|
|
126
|
-
expect(output).not.toContain("defineProperty");
|
|
127
|
-
|
|
128
|
-
var TEST_OUTPUT;
|
|
129
|
-
eval(output);
|
|
130
|
-
expect(TEST_OUTPUT).not.toStrictEqual(3);
|
|
131
|
-
});
|
|
132
|
-
});
|
package/test/presets.test.ts
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import presets from "../src/presets";
|
|
2
|
-
|
|
3
|
-
it('High preset should have "preset": "high"', async () => {
|
|
4
|
-
expect(presets.high.preset).toStrictEqual("high");
|
|
5
|
-
});
|
|
6
|
-
|
|
7
|
-
it('Medium preset should have "preset": "medium"', async () => {
|
|
8
|
-
expect(presets.medium.preset).toStrictEqual("medium");
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
it('Low preset should have "preset": "low"', async () => {
|
|
12
|
-
expect(presets.low.preset).toStrictEqual("low");
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it("No preset should have eval, lock, or RGF enabled", async () => {
|
|
16
|
-
Object.keys(presets).forEach((key) => {
|
|
17
|
-
expect(typeof presets[key]).toStrictEqual("object");
|
|
18
|
-
expect(!!presets[key].eval).toEqual(false);
|
|
19
|
-
expect(!!presets[key].lock).toEqual(false);
|
|
20
|
-
expect(!!presets[key].rgf).toEqual(false);
|
|
21
|
-
});
|
|
22
|
-
});
|
package/test/probability.test.ts
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import { isProbabilityMapProbable } from "../src/probability";
|
|
2
|
-
|
|
3
|
-
describe("isProbabilityMapProbable", function () {
|
|
4
|
-
test("Variant #1: True examples", function () {
|
|
5
|
-
expect(isProbabilityMapProbable(true)).toStrictEqual(true);
|
|
6
|
-
expect(isProbabilityMapProbable(1)).toStrictEqual(true);
|
|
7
|
-
expect(isProbabilityMapProbable(0.1)).toStrictEqual(true);
|
|
8
|
-
|
|
9
|
-
expect(
|
|
10
|
-
isProbabilityMapProbable({
|
|
11
|
-
mode: 1,
|
|
12
|
-
})
|
|
13
|
-
).toStrictEqual(true);
|
|
14
|
-
|
|
15
|
-
expect(isProbabilityMapProbable(["mode"])).toStrictEqual(true);
|
|
16
|
-
|
|
17
|
-
// Function are always true
|
|
18
|
-
expect(isProbabilityMapProbable(() => true)).toStrictEqual(true);
|
|
19
|
-
expect(isProbabilityMapProbable(() => false)).toStrictEqual(true);
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
test("Variant #2: False examples", function () {
|
|
23
|
-
expect(isProbabilityMapProbable(false)).toStrictEqual(false);
|
|
24
|
-
expect(isProbabilityMapProbable(0)).toStrictEqual(false);
|
|
25
|
-
expect(isProbabilityMapProbable(undefined)).toStrictEqual(false);
|
|
26
|
-
expect(isProbabilityMapProbable(null)).toStrictEqual(false);
|
|
27
|
-
|
|
28
|
-
expect(isProbabilityMapProbable([false])).toStrictEqual(false);
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
test("Variant #3: Invalid examples", function () {
|
|
32
|
-
// Invalid percentage
|
|
33
|
-
expect(() => isProbabilityMapProbable(1.1)).toThrow();
|
|
34
|
-
expect(() => isProbabilityMapProbable(50)).toThrow();
|
|
35
|
-
expect(() => isProbabilityMapProbable(-0.1)).toThrow();
|
|
36
|
-
expect(() => isProbabilityMapProbable(NaN)).toThrow();
|
|
37
|
-
|
|
38
|
-
// Empty object
|
|
39
|
-
expect(() => isProbabilityMapProbable({})).toThrow();
|
|
40
|
-
|
|
41
|
-
// Empty array
|
|
42
|
-
expect(() => isProbabilityMapProbable([])).toThrow();
|
|
43
|
-
});
|
|
44
|
-
});
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import Template from "../../src/templates/template";
|
|
2
|
-
|
|
3
|
-
describe("Template", () => {
|
|
4
|
-
test("Variant #1: Error when invalid code passed in", () => {
|
|
5
|
-
var _consoleError = console.error;
|
|
6
|
-
console.error = () => {};
|
|
7
|
-
|
|
8
|
-
expect(() => {
|
|
9
|
-
Template(`#&!#Ylet{}class)--1]?|:!@#`).compile();
|
|
10
|
-
}).toThrow();
|
|
11
|
-
|
|
12
|
-
console.error = _consoleError;
|
|
13
|
-
});
|
|
14
|
-
});
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../src/index";
|
|
2
|
-
|
|
3
|
-
// https://github.com/MichaelXF/js-confuser/issues/74
|
|
4
|
-
test("Variant #1: Don't break Symbols", async () => {
|
|
5
|
-
if (typeof Symbol !== "undefined") {
|
|
6
|
-
for (var i = 0; i < 6; i++) {
|
|
7
|
-
var output = await JsConfuser(
|
|
8
|
-
`
|
|
9
|
-
|
|
10
|
-
var sym1 = Symbol();
|
|
11
|
-
|
|
12
|
-
if (true) {
|
|
13
|
-
sym1;
|
|
14
|
-
sym1;
|
|
15
|
-
sym1;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
TEST_OUTPUT = sym1;
|
|
19
|
-
|
|
20
|
-
`,
|
|
21
|
-
{ target: "node", renameVariables: true }
|
|
22
|
-
);
|
|
23
|
-
|
|
24
|
-
var TEST_OUTPUT;
|
|
25
|
-
|
|
26
|
-
eval(output);
|
|
27
|
-
expect(typeof TEST_OUTPUT).toStrictEqual("symbol");
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
test("Variant #2: Join expressions into sequence expressions", async () => {
|
|
33
|
-
var output = await JsConfuser(
|
|
34
|
-
`
|
|
35
|
-
TEST_OUTPUT = 0;
|
|
36
|
-
TEST_OUTPUT++;
|
|
37
|
-
TEST_OUTPUT++;
|
|
38
|
-
TEST_OUTPUT++;
|
|
39
|
-
if(TEST_OUTPUT > 0) {
|
|
40
|
-
TEST_OUTPUT *= 2;
|
|
41
|
-
}
|
|
42
|
-
`,
|
|
43
|
-
{ target: "node", renameVariables: true }
|
|
44
|
-
);
|
|
45
|
-
|
|
46
|
-
expect(output).toContain("(TEST_OUTPUT=0,TEST_OUTPUT++");
|
|
47
|
-
|
|
48
|
-
var TEST_OUTPUT;
|
|
49
|
-
eval(output);
|
|
50
|
-
|
|
51
|
-
expect(TEST_OUTPUT).toStrictEqual(6);
|
|
52
|
-
});
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import JsConfuser from "../../src/index";
|
|
2
|
-
|
|
3
|
-
it("should hide binary expressions", async () => {
|
|
4
|
-
var code = `5 + 5`;
|
|
5
|
-
|
|
6
|
-
var output = await JsConfuser(code, { target: "browser", calculator: true });
|
|
7
|
-
|
|
8
|
-
expect(output).not.toContain("5+5");
|
|
9
|
-
expect(output).not.toContain("5 + 5");
|
|
10
|
-
expect(output).toContain("switch");
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
it("should result with correct values", async () => {
|
|
14
|
-
var code = `input(5 + 5)`;
|
|
15
|
-
|
|
16
|
-
var output = await JsConfuser(code, { target: "browser", calculator: true });
|
|
17
|
-
|
|
18
|
-
function input(x) {
|
|
19
|
-
expect(x).toStrictEqual(10);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
eval(output);
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
it("should execute property with complex operations", async () => {
|
|
26
|
-
var code = `input((40 * 35 + 4) * 4 + 2)`;
|
|
27
|
-
|
|
28
|
-
var output = await JsConfuser(code, { target: "browser", calculator: true });
|
|
29
|
-
|
|
30
|
-
var value;
|
|
31
|
-
function input(x) {
|
|
32
|
-
value = x;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
eval(output);
|
|
36
|
-
|
|
37
|
-
expect(value).toStrictEqual(5618);
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
it("should apply to unary operators", async () => {
|
|
41
|
-
var code = `
|
|
42
|
-
var one = +1;
|
|
43
|
-
var negativeOne = -one;
|
|
44
|
-
|
|
45
|
-
var trueValue = true;
|
|
46
|
-
var falseValue = !trueValue;
|
|
47
|
-
|
|
48
|
-
TEST_OUTPUT = typeof (1, falseValue) === "boolean" && negativeOne === ~~-1 && void 0 === undefined;
|
|
49
|
-
`;
|
|
50
|
-
|
|
51
|
-
var output = await JsConfuser(code, { target: "node", calculator: true });
|
|
52
|
-
|
|
53
|
-
expect(output).toContain("_calc");
|
|
54
|
-
expect(output).not.toContain("+1");
|
|
55
|
-
expect(output).not.toContain("-one");
|
|
56
|
-
expect(output).not.toContain("typeof(1,falseValue)");
|
|
57
|
-
expect(output).not.toContain("void 0");
|
|
58
|
-
|
|
59
|
-
var TEST_OUTPUT = true;
|
|
60
|
-
eval(output);
|
|
61
|
-
|
|
62
|
-
expect(TEST_OUTPUT).toStrictEqual(true);
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
it("should not break typeof expressions", async () => {
|
|
66
|
-
var code = `
|
|
67
|
-
TEST_OUTPUT = typeof nonExistentVariable === "undefined";
|
|
68
|
-
`;
|
|
69
|
-
|
|
70
|
-
var output = await JsConfuser(code, { target: "node", calculator: true });
|
|
71
|
-
|
|
72
|
-
expect(output).not.toContain("_calc");
|
|
73
|
-
|
|
74
|
-
var TEST_OUTPUT;
|
|
75
|
-
eval(output);
|
|
76
|
-
|
|
77
|
-
expect(TEST_OUTPUT).toStrictEqual(true);
|
|
78
|
-
});
|