js-confuser 1.7.3 → 2.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (269) hide show
  1. package/.github/ISSUE_TEMPLATE/bug_report.md +6 -4
  2. package/CHANGELOG.md +70 -0
  3. package/Migration.md +57 -0
  4. package/README.md +23 -929
  5. package/dist/constants.js +65 -14
  6. package/dist/index.js +108 -160
  7. package/dist/obfuscator.js +316 -118
  8. package/dist/options.js +1 -119
  9. package/dist/order.js +30 -30
  10. package/dist/presets.js +47 -45
  11. package/dist/probability.js +25 -32
  12. package/dist/templates/bufferToStringTemplate.js +9 -0
  13. package/dist/templates/deadCodeTemplates.js +9 -0
  14. package/dist/templates/getGlobalTemplate.js +19 -0
  15. package/dist/templates/integrityTemplate.js +30 -0
  16. package/dist/templates/setFunctionLengthTemplate.js +9 -0
  17. package/dist/templates/stringCompressionTemplate.js +10 -0
  18. package/dist/templates/tamperProtectionTemplates.js +21 -0
  19. package/dist/templates/template.js +199 -184
  20. package/dist/transforms/astScrambler.js +100 -0
  21. package/dist/transforms/calculator.js +70 -127
  22. package/dist/transforms/controlFlowFlattening.js +1182 -0
  23. package/dist/transforms/deadCode.js +62 -587
  24. package/dist/transforms/dispatcher.js +300 -313
  25. package/dist/transforms/extraction/duplicateLiteralsRemoval.js +88 -189
  26. package/dist/transforms/extraction/objectExtraction.js +131 -215
  27. package/dist/transforms/finalizer.js +56 -59
  28. package/dist/transforms/flatten.js +275 -276
  29. package/dist/transforms/functionOutlining.js +230 -0
  30. package/dist/transforms/identifier/globalConcealing.js +214 -135
  31. package/dist/transforms/identifier/movedDeclarations.js +167 -91
  32. package/dist/transforms/identifier/renameVariables.js +239 -193
  33. package/dist/transforms/lock/integrity.js +61 -184
  34. package/dist/transforms/lock/lock.js +261 -387
  35. package/dist/transforms/minify.js +431 -436
  36. package/dist/transforms/opaquePredicates.js +65 -118
  37. package/dist/transforms/pack.js +160 -0
  38. package/dist/transforms/plugin.js +179 -0
  39. package/dist/transforms/preparation.js +261 -173
  40. package/dist/transforms/renameLabels.js +132 -56
  41. package/dist/transforms/rgf.js +140 -267
  42. package/dist/transforms/shuffle.js +52 -145
  43. package/dist/transforms/string/encoding.js +44 -175
  44. package/dist/transforms/string/stringCompression.js +79 -155
  45. package/dist/transforms/string/stringConcealing.js +189 -225
  46. package/dist/transforms/string/stringEncoding.js +32 -40
  47. package/dist/transforms/string/stringSplitting.js +54 -55
  48. package/dist/transforms/variableMasking.js +232 -0
  49. package/dist/utils/ControlObject.js +125 -0
  50. package/dist/utils/IntGen.js +46 -0
  51. package/dist/utils/NameGen.js +106 -0
  52. package/dist/utils/ast-utils.js +560 -0
  53. package/dist/utils/function-utils.js +56 -0
  54. package/dist/utils/gen-utils.js +48 -0
  55. package/dist/utils/node.js +77 -0
  56. package/dist/utils/object-utils.js +21 -0
  57. package/dist/utils/random-utils.js +91 -0
  58. package/dist/utils/static-utils.js +64 -0
  59. package/dist/validateOptions.js +122 -0
  60. package/index.d.ts +1 -17
  61. package/package.json +27 -22
  62. package/src/constants.ts +139 -82
  63. package/src/index.ts +70 -165
  64. package/src/obfuscationResult.ts +43 -0
  65. package/src/obfuscator.ts +328 -135
  66. package/src/options.ts +149 -658
  67. package/src/order.ts +14 -14
  68. package/src/presets.ts +39 -34
  69. package/src/probability.ts +21 -36
  70. package/src/templates/bufferToStringTemplate.ts +57 -0
  71. package/src/templates/deadCodeTemplates.ts +1185 -0
  72. package/src/templates/getGlobalTemplate.ts +72 -0
  73. package/src/templates/integrityTemplate.ts +69 -0
  74. package/src/templates/setFunctionLengthTemplate.ts +11 -0
  75. package/src/templates/stringCompressionTemplate.ts +42 -0
  76. package/src/templates/tamperProtectionTemplates.ts +116 -0
  77. package/src/templates/template.ts +149 -157
  78. package/src/transforms/astScrambler.ts +99 -0
  79. package/src/transforms/calculator.ts +96 -226
  80. package/src/transforms/controlFlowFlattening.ts +1594 -0
  81. package/src/transforms/deadCode.ts +85 -676
  82. package/src/transforms/dispatcher.ts +431 -640
  83. package/src/transforms/extraction/duplicateLiteralsRemoval.ts +147 -295
  84. package/src/transforms/extraction/objectExtraction.ts +160 -333
  85. package/src/transforms/finalizer.ts +63 -64
  86. package/src/transforms/flatten.ts +439 -557
  87. package/src/transforms/functionOutlining.ts +225 -0
  88. package/src/transforms/identifier/globalConcealing.ts +255 -266
  89. package/src/transforms/identifier/movedDeclarations.ts +228 -142
  90. package/src/transforms/identifier/renameVariables.ts +250 -271
  91. package/src/transforms/lock/integrity.ts +85 -263
  92. package/src/transforms/lock/lock.ts +338 -579
  93. package/src/transforms/minify.ts +523 -663
  94. package/src/transforms/opaquePredicates.ts +90 -229
  95. package/src/transforms/pack.ts +195 -0
  96. package/src/transforms/plugin.ts +185 -0
  97. package/src/transforms/preparation.ts +337 -231
  98. package/src/transforms/renameLabels.ts +176 -77
  99. package/src/transforms/rgf.ts +293 -424
  100. package/src/transforms/shuffle.ts +80 -254
  101. package/src/transforms/string/encoding.ts +20 -126
  102. package/src/transforms/string/stringCompression.ts +117 -307
  103. package/src/transforms/string/stringConcealing.ts +254 -342
  104. package/src/transforms/string/stringEncoding.ts +28 -47
  105. package/src/transforms/string/stringSplitting.ts +61 -75
  106. package/src/transforms/variableMasking.ts +257 -0
  107. package/src/utils/ControlObject.ts +141 -0
  108. package/src/utils/IntGen.ts +33 -0
  109. package/src/utils/NameGen.ts +106 -0
  110. package/src/utils/ast-utils.ts +667 -0
  111. package/src/utils/function-utils.ts +50 -0
  112. package/src/utils/gen-utils.ts +48 -0
  113. package/src/utils/node.ts +78 -0
  114. package/src/utils/object-utils.ts +21 -0
  115. package/src/utils/random-utils.ts +79 -0
  116. package/src/utils/static-utils.ts +66 -0
  117. package/src/validateOptions.ts +256 -0
  118. package/tsconfig.json +13 -8
  119. package/babel.config.js +0 -12
  120. package/dev.js +0 -8
  121. package/dist/compiler.js +0 -34
  122. package/dist/parser.js +0 -59
  123. package/dist/precedence.js +0 -66
  124. package/dist/templates/bufferToString.js +0 -129
  125. package/dist/templates/core.js +0 -35
  126. package/dist/templates/crash.js +0 -28
  127. package/dist/templates/es5.js +0 -137
  128. package/dist/templates/functionLength.js +0 -34
  129. package/dist/templates/globals.js +0 -9
  130. package/dist/transforms/antiTooling.js +0 -88
  131. package/dist/transforms/controlFlowFlattening/controlFlowFlattening.js +0 -1287
  132. package/dist/transforms/controlFlowFlattening/expressionObfuscation.js +0 -131
  133. package/dist/transforms/es5/antiClass.js +0 -164
  134. package/dist/transforms/es5/antiDestructuring.js +0 -193
  135. package/dist/transforms/es5/antiES6Object.js +0 -185
  136. package/dist/transforms/es5/antiSpreadOperator.js +0 -35
  137. package/dist/transforms/es5/antiTemplate.js +0 -66
  138. package/dist/transforms/es5/es5.js +0 -123
  139. package/dist/transforms/extraction/classExtraction.js +0 -83
  140. package/dist/transforms/identifier/globalAnalysis.js +0 -83
  141. package/dist/transforms/identifier/variableAnalysis.js +0 -104
  142. package/dist/transforms/lock/antiDebug.js +0 -76
  143. package/dist/transforms/stack.js +0 -349
  144. package/dist/transforms/transform.js +0 -372
  145. package/dist/traverse.js +0 -110
  146. package/dist/util/compare.js +0 -145
  147. package/dist/util/gen.js +0 -564
  148. package/dist/util/guard.js +0 -14
  149. package/dist/util/identifiers.js +0 -355
  150. package/dist/util/insert.js +0 -362
  151. package/dist/util/math.js +0 -19
  152. package/dist/util/object.js +0 -40
  153. package/dist/util/random.js +0 -156
  154. package/dist/util/scope.js +0 -20
  155. package/docs/ControlFlowFlattening.md +0 -595
  156. package/docs/Countermeasures.md +0 -70
  157. package/docs/ES5.md +0 -197
  158. package/docs/Integrity.md +0 -82
  159. package/docs/RGF.md +0 -424
  160. package/docs/RenameVariables.md +0 -116
  161. package/docs/TamperProtection.md +0 -100
  162. package/docs/Template.md +0 -117
  163. package/samples/example.js +0 -15
  164. package/samples/high.js +0 -1
  165. package/samples/input.js +0 -3
  166. package/samples/javascriptobfuscator.com.js +0 -8
  167. package/samples/jscrambler_advanced.js +0 -1894
  168. package/samples/jscrambler_light.js +0 -1134
  169. package/samples/low.js +0 -1
  170. package/samples/medium.js +0 -1
  171. package/samples/obfuscator.io.js +0 -1686
  172. package/samples/preemptive.com.js +0 -16
  173. package/src/compiler.ts +0 -35
  174. package/src/parser.ts +0 -49
  175. package/src/precedence.ts +0 -61
  176. package/src/templates/bufferToString.ts +0 -136
  177. package/src/templates/core.ts +0 -29
  178. package/src/templates/crash.ts +0 -23
  179. package/src/templates/es5.ts +0 -131
  180. package/src/templates/functionLength.ts +0 -32
  181. package/src/templates/globals.ts +0 -3
  182. package/src/transforms/antiTooling.ts +0 -102
  183. package/src/transforms/controlFlowFlattening/controlFlowFlattening.ts +0 -2153
  184. package/src/transforms/controlFlowFlattening/expressionObfuscation.ts +0 -179
  185. package/src/transforms/es5/antiClass.ts +0 -276
  186. package/src/transforms/es5/antiDestructuring.ts +0 -294
  187. package/src/transforms/es5/antiES6Object.ts +0 -267
  188. package/src/transforms/es5/antiSpreadOperator.ts +0 -56
  189. package/src/transforms/es5/antiTemplate.ts +0 -98
  190. package/src/transforms/es5/es5.ts +0 -149
  191. package/src/transforms/extraction/classExtraction.ts +0 -168
  192. package/src/transforms/identifier/globalAnalysis.ts +0 -102
  193. package/src/transforms/identifier/variableAnalysis.ts +0 -118
  194. package/src/transforms/lock/antiDebug.ts +0 -112
  195. package/src/transforms/stack.ts +0 -557
  196. package/src/transforms/transform.ts +0 -441
  197. package/src/traverse.ts +0 -120
  198. package/src/types.ts +0 -133
  199. package/src/util/compare.ts +0 -181
  200. package/src/util/gen.ts +0 -651
  201. package/src/util/guard.ts +0 -17
  202. package/src/util/identifiers.ts +0 -494
  203. package/src/util/insert.ts +0 -419
  204. package/src/util/math.ts +0 -15
  205. package/src/util/object.ts +0 -39
  206. package/src/util/random.ts +0 -221
  207. package/src/util/scope.ts +0 -21
  208. package/test/code/Cash.src.js +0 -1011
  209. package/test/code/Cash.test.ts +0 -132
  210. package/test/code/Dynamic.src.js +0 -118
  211. package/test/code/Dynamic.test.ts +0 -49
  212. package/test/code/ES6.src.js +0 -235
  213. package/test/code/ES6.test.ts +0 -42
  214. package/test/code/NewFeatures.test.ts +0 -19
  215. package/test/code/StrictMode.src.js +0 -65
  216. package/test/code/StrictMode.test.js +0 -37
  217. package/test/compare.test.ts +0 -104
  218. package/test/index.test.ts +0 -249
  219. package/test/options.test.ts +0 -150
  220. package/test/presets.test.ts +0 -22
  221. package/test/probability.test.ts +0 -44
  222. package/test/templates/template.test.ts +0 -224
  223. package/test/transforms/antiTooling.test.ts +0 -52
  224. package/test/transforms/calculator.test.ts +0 -78
  225. package/test/transforms/controlFlowFlattening/controlFlowFlattening.test.ts +0 -1274
  226. package/test/transforms/controlFlowFlattening/expressionObfuscation.test.ts +0 -192
  227. package/test/transforms/deadCode.test.ts +0 -85
  228. package/test/transforms/dispatcher.test.ts +0 -457
  229. package/test/transforms/es5/antiClass.test.ts +0 -427
  230. package/test/transforms/es5/antiDestructuring.test.ts +0 -157
  231. package/test/transforms/es5/antiES6Object.test.ts +0 -245
  232. package/test/transforms/es5/antiTemplate.test.ts +0 -116
  233. package/test/transforms/es5/es5.test.ts +0 -110
  234. package/test/transforms/extraction/classExtraction.test.ts +0 -86
  235. package/test/transforms/extraction/duplicateLiteralsRemoval.test.ts +0 -200
  236. package/test/transforms/extraction/objectExtraction.test.ts +0 -491
  237. package/test/transforms/flatten.test.ts +0 -721
  238. package/test/transforms/hexadecimalNumbers.test.ts +0 -62
  239. package/test/transforms/identifier/globalConcealing.test.ts +0 -142
  240. package/test/transforms/identifier/movedDeclarations.test.ts +0 -275
  241. package/test/transforms/identifier/renameVariables.test.ts +0 -695
  242. package/test/transforms/lock/antiDebug.test.ts +0 -66
  243. package/test/transforms/lock/browserLock.test.ts +0 -129
  244. package/test/transforms/lock/countermeasures.test.ts +0 -100
  245. package/test/transforms/lock/integrity.test.ts +0 -161
  246. package/test/transforms/lock/lock.test.ts +0 -204
  247. package/test/transforms/lock/osLock.test.ts +0 -312
  248. package/test/transforms/lock/selfDefending.test.ts +0 -68
  249. package/test/transforms/lock/tamperProtection.test.ts +0 -336
  250. package/test/transforms/minify.test.ts +0 -575
  251. package/test/transforms/opaquePredicates.test.ts +0 -43
  252. package/test/transforms/preparation.test.ts +0 -157
  253. package/test/transforms/renameLabels.test.ts +0 -95
  254. package/test/transforms/rgf.test.ts +0 -378
  255. package/test/transforms/shuffle.test.ts +0 -135
  256. package/test/transforms/stack.test.ts +0 -573
  257. package/test/transforms/string/stringCompression.test.ts +0 -120
  258. package/test/transforms/string/stringConcealing.test.ts +0 -299
  259. package/test/transforms/string/stringEncoding.test.ts +0 -95
  260. package/test/transforms/string/stringSplitting.test.ts +0 -135
  261. package/test/transforms/transform.test.ts +0 -66
  262. package/test/traverse.test.ts +0 -139
  263. package/test/util/compare.test.ts +0 -34
  264. package/test/util/gen.test.ts +0 -121
  265. package/test/util/identifiers.test.ts +0 -253
  266. package/test/util/insert.test.ts +0 -142
  267. package/test/util/math.test.ts +0 -5
  268. package/test/util/random.test.ts +0 -71
  269. /package/dist/{types.js → obfuscationResult.js} +0 -0
@@ -1,595 +0,0 @@
1
- ## `Control Flow Flattening`
2
-
3
- Control-flow Flattening hinders program comprehension by creating convoluted switch statements.
4
-
5
- **⚠️ Significantly impacts performance, use sparingly!**
6
-
7
- Option name: `controlFlowFlattening`
8
-
9
- Option values: `true/false/0-1`
10
-
11
- Use a number to control the percentage from 0 to 1.
12
-
13
- ## Example
14
-
15
- ```js
16
- // Input
17
- function countTo(num){
18
- for ( var i = 1; i <= num; i++ ) {
19
- console.log(i);
20
- }
21
- }
22
-
23
- var number = 10;
24
- countTo(number); // 1,2,3,4,5,6,7,8,9,10
25
-
26
- // Output
27
- var n2DUka,
28
- O7yZ0oU,
29
- mJMdMhJ = -337,
30
- A1Nyvv = -94,
31
- xDwpOk6 = 495,
32
- uKcJl2 = {
33
- TGCpW6t: "log",
34
- qUrjFe: function () {
35
- return xDwpOk6 == (126 > mJMdMhJ ? -16 : 34);
36
- },
37
- YN20IBx: function () {
38
- return (A1Nyvv -= 53);
39
- },
40
- CTW4vwx: -73,
41
- PLzWYDx: function () {
42
- return (O7yZ0oU = [[385, -94, -282], [10]]);
43
- },
44
- bW2FK2: function () {
45
- return (mJMdMhJ *= 2), (mJMdMhJ += 366);
46
- },
47
- AfOoRT: function () {
48
- return xDwpOk6 == xDwpOk6 + 867;
49
- },
50
- KTNMdj: function () {
51
- if (uKcJl2.AfOoRT()) {
52
- typeof ((mJMdMhJ += 0), uKcJl2.Q0I6e4f(), (xDwpOk6 += 0));
53
- return "cobTe8G";
54
- }
55
- typeof (uKcJl2.htRXYx(),
56
- (mJMdMhJ += 59),
57
- (A1Nyvv -= 537),
58
- (xDwpOk6 += uKcJl2.mLuSzZ < mJMdMhJ ? 449 : -33));
59
- return "cobTe8G";
60
- },
61
- };
62
- while (mJMdMhJ + A1Nyvv + xDwpOk6 != 83) {
63
- var yQNDJh = (mJMdMhJ + A1Nyvv + xDwpOk6) * 58 + 54;
64
- switch (yQNDJh) {
65
- case 750:
66
- if (A1Nyvv == 24) {
67
- uKcJl2.FxREGd6();
68
- break;
69
- }
70
- case 1214:
71
- if (uKcJl2.qUrjFe()) {
72
- typeof ((mJMdMhJ *= -8 > xDwpOk6 ? -109 : 2),
73
- (mJMdMhJ += 1168),
74
- (xDwpOk6 += xDwpOk6 - 1290));
75
- break;
76
- }
77
- function _VSsIw() {
78
- var [yQNDJh, _VSsIw] = O7yZ0oU,
79
- [L9B14E] = _VSsIw,
80
- uTyFFb = 322;
81
- while (uTyFFb != 23) {
82
- var cBx3ysg = uTyFFb * 48 - 77;
83
- switch (cBx3ysg) {
84
- case 15379:
85
- var IOoqIZ = 1;
86
- uTyFFb -= 306;
87
- break;
88
- case 691:
89
- uTyFFb += IOoqIZ <= L9B14E ? 976 : 7;
90
- break;
91
- case 47539:
92
- typeof (console[uKcJl2.TGCpW6t](IOoqIZ), (uTyFFb -= 795));
93
- break;
94
- case 9379:
95
- !(IOoqIZ++, (uTyFFb -= 181));
96
- }
97
- }
98
- return ([mJMdMhJ, A1Nyvv, xDwpOk6] = yQNDJh), (n2DUka = void 0);
99
- }
100
- (xDwpOk6 == -73 ? parseInt : _VSsIw)();
101
- break;
102
- case 576:
103
- typeof (mJMdMhJ == -4 ? clearImmediate : void 0,
104
- uKcJl2.bky8kL(),
105
- (xDwpOk6 -= 463));
106
- break;
107
- case 4172:
108
- var L9B14E = 10;
109
- void ((O7yZ0oU = [[385, -94, -282], [10]]),
110
- (mJMdMhJ -= 187),
111
- uKcJl2.YN20IBx(),
112
- (xDwpOk6 += 189));
113
- break;
114
- case 3766:
115
- !((uKcJl2.Fpp8x5 = -167),
116
- (uKcJl2.mLuSzZ = 144),
117
- (uKcJl2.FxREGd6 = function () {
118
- return (mJMdMhJ += uKcJl2.Fpp8x5), (xDwpOk6 += 164);
119
- }),
120
- (uKcJl2.bky8kL = function () {
121
- return (A1Nyvv += 537);
122
- }),
123
- (uKcJl2.Q0I6e4f = function () {
124
- return (A1Nyvv += 0);
125
- }),
126
- (uKcJl2.htRXYx = function () {
127
- return (xDwpOk6 = -82);
128
- }));
129
- var L9B14E = 10;
130
- void (uKcJl2.PLzWYDx(), uKcJl2.bW2FK2(), (xDwpOk6 += uKcJl2.CTW4vwx));
131
- break;
132
- default:
133
- if (uKcJl2.KTNMdj() == "cobTe8G") {
134
- break;
135
- }
136
- }
137
- }
138
- ```
139
-
140
- As seen in the example, your code will be wrapped in a large, complicated switch statement. The makes the behavior of your program very hard to understand and is resistent to deobfuscators. This comes with a large performance reduction.
141
-
142
- ## Flattening Control Structures
143
-
144
- Control Flow Flattening is able to flatten the following statements:
145
-
146
- 1. `If Statement`
147
- 2. `For Statement`
148
- 3. `While Statement` / `Do While Statement`
149
- 4. `Switch Statement`
150
-
151
- ```js
152
- // Input
153
- if(true) {
154
- console.log("This code runs"); // "This code runs"
155
- }
156
-
157
- var numbers1To10 = [];
158
- for(var i = 1; i <= 10; i++) {
159
- numbers1To10.push(i);
160
- }
161
-
162
- console.log(numbers1To10); // [1,2,3,4,5,6,7,8,9,10]
163
-
164
- // Output
165
- var b7C5lP = 1362,
166
- DOLvaG = -418,
167
- YJSKU81 = -373,
168
- _tLqjib = -373,
169
- WB0kIJ0 = {
170
- P: -15,
171
- d: "log",
172
- av: () => (b7C5lP += 34),
173
- f: 1,
174
- x: 91,
175
- ay: -76,
176
- am: () => (DOLvaG += 76),
177
- W: (DOLvaG = YJSKU81 == 28) => {
178
- if (DOLvaG) {
179
- return _tLqjib == 33;
180
- }
181
- return (b7C5lP -= 28);
182
- },
183
- ad: y9tPuB((YJSKU81 = DOLvaG == 1090) => {
184
- if (!YJSKU81) {
185
- return DOLvaG;
186
- }
187
- return (b7C5lP += _tLqjib + 233);
188
- }),
189
- w: 1659,
190
- v: y9tPuB(() => {
191
- return (b7C5lP -= 1604);
192
- }),
193
- V: y9tPuB(() => {
194
- if (WB0kIJ0.a) {
195
- !((b7C5lP += DOLvaG == 1090 ? 1709 : "N"),
196
- (DOLvaG -= 1491),
197
- (WB0kIJ0.c = !0));
198
- return "T";
199
- }
200
- !((YJSKU81 += WB0kIJ0.P),
201
- (_tLqjib += WB0kIJ0.d == "log" ? 10 : WB0kIJ0.S));
202
- return "T";
203
- }),
204
- u: () => (WB0kIJ0.s = hup9cE).push(YJSKU81 == WB0kIJ0.t || R6QFdZ),
205
- Z: -363,
206
- h: -1735,
207
- J: (b7C5lP = WB0kIJ0.d == "K") => {
208
- if (b7C5lP) {
209
- return _tLqjib == -25;
210
- }
211
- return (DOLvaG -= 187), (YJSKU81 -= 15), (_tLqjib += 10);
212
- },
213
- an: -101,
214
- l: 4,
215
- m: 85,
216
- g: 10,
217
- ag: y9tPuB((b7C5lP = WB0kIJ0.Z == "aj") => {
218
- if (b7C5lP) {
219
- return WB0kIJ0;
220
- }
221
- return WB0kIJ0.ad(), (DOLvaG += 76);
222
- }),
223
- aB: (b7C5lP = WB0kIJ0.l == -912) => {
224
- if (b7C5lP) {
225
- return WB0kIJ0.aE();
226
- }
227
- return (_tLqjib = 15);
228
- },
229
- az: -453,
230
- t: -39,
231
- F: -1709,
232
- aI: y9tPuB((WB0kIJ0) => {
233
- return WB0kIJ0.c ? 234 : -276;
234
- }),
235
- aJ: y9tPuB((YJSKU81) => {
236
- return YJSKU81 + 574;
237
- }),
238
- aK: y9tPuB((WB0kIJ0) => {
239
- return WB0kIJ0.b ? 217 : -467;
240
- }),
241
- aL: y9tPuB((WB0kIJ0) => {
242
- return WB0kIJ0.e ? -244 : 203;
243
- }),
244
- aM: y9tPuB((DOLvaG) => {
245
- return DOLvaG - 1079;
246
- }),
247
- };
248
- while (b7C5lP + DOLvaG + YJSKU81 + _tLqjib != 37)
249
- switch (b7C5lP + DOLvaG + YJSKU81 + _tLqjib) {
250
- default:
251
- typeof ((WB0kIJ0.hasOwnProperty("d") ? console : _tLqjib)[WB0kIJ0.d](
252
- "This code runs"
253
- ),
254
- (b7C5lP += WB0kIJ0.F),
255
- (DOLvaG += typeof WB0kIJ0.d == "function" ? 45 : 1678),
256
- (WB0kIJ0.e = !1));
257
- break;
258
- case 571:
259
- case 113:
260
- case 158:
261
- if (typeof WB0kIJ0.h == "undefined" || !1) {
262
- WB0kIJ0.av();
263
- break;
264
- }
265
- void ((WB0kIJ0.f == 1 && hup9cE).push(WB0kIJ0.x == "ax" || R6QFdZ),
266
- (b7C5lP += -369 < YJSKU81 ? 117 : _tLqjib + 397));
267
- break;
268
- case WB0kIJ0.aJ(YJSKU81):
269
- void (WB0kIJ0.aB(),
270
- (b7C5lP += 1042),
271
- (DOLvaG -= 1584),
272
- (YJSKU81 += 112),
273
- (_tLqjib += 539),
274
- (WB0kIJ0.b = !0));
275
- break;
276
- case 123:
277
- case 756:
278
- case 714:
279
- if (_tLqjib == 31) {
280
- !((b7C5lP += WB0kIJ0.g == "i" ? WB0kIJ0.k : -1604),
281
- (DOLvaG += 1659),
282
- (YJSKU81 += WB0kIJ0.l),
283
- (_tLqjib += 10));
284
- break;
285
- }
286
- !(WB0kIJ0.u(),
287
- WB0kIJ0.v(),
288
- (DOLvaG += WB0kIJ0.w),
289
- (YJSKU81 += b7C5lP + 246),
290
- (_tLqjib += 10));
291
- break;
292
- case 735:
293
- case WB0kIJ0.aK(WB0kIJ0):
294
- if (WB0kIJ0.l == -373 || !1) {
295
- YJSKU81 -= 19;
296
- break;
297
- }
298
- !((WB0kIJ0.a = !0), (b7C5lP -= 1709), (DOLvaG += 1508));
299
- break;
300
- case 134:
301
- typeof (R6QFdZ++,
302
- (b7C5lP -= 568),
303
- (DOLvaG += WB0kIJ0.ay),
304
- (_tLqjib += 620));
305
- break;
306
- case 82:
307
- case 516:
308
- if (_tLqjib == WB0kIJ0.Z && !1) {
309
- b7C5lP += 28;
310
- break;
311
- }
312
- if (
313
- (_tLqjib == (typeof WB0kIJ0.h == "number" ? -363 : -50)
314
- ? WB0kIJ0
315
- : void 0
316
- ).a
317
- ) {
318
- WB0kIJ0.ag();
319
- break;
320
- }
321
- !((b7C5lP += b7C5lP + 872),
322
- WB0kIJ0.am(),
323
- (YJSKU81 *= -369 > YJSKU81 ? WB0kIJ0.an : 2),
324
- (YJSKU81 -= WB0kIJ0.an == "ar" ? "as" : -285),
325
- (_tLqjib -= 620));
326
- break;
327
- case 198:
328
- void ((YJSKU81 += WB0kIJ0.l == "y" ? WB0kIJ0.A : 19), (WB0kIJ0.b = !0));
329
- break;
330
- case 16:
331
- if (WB0kIJ0.V() == "T") {
332
- break;
333
- }
334
- case 192:
335
- typeof ((b7C5lP += 562), (_tLqjib *= 2), (_tLqjib -= 257));
336
- break;
337
- case WB0kIJ0.aL(WB0kIJ0):
338
- case 422:
339
- case 310:
340
- if (!1) {
341
- }
342
- WB0kIJ0.J();
343
- break;
344
- case 50:
345
- case 555:
346
- case 984:
347
- typeof ((YJSKU81 == WB0kIJ0.az ? console : YJSKU81).log(
348
- (WB0kIJ0.aA = hup9cE)
349
- ),
350
- (YJSKU81 -= 13));
351
- break;
352
- case WB0kIJ0.aM(DOLvaG):
353
- var hup9cE = [],
354
- R6QFdZ = (DOLvaG == -2 || WB0kIJ0).f;
355
- b7C5lP += 99;
356
- break;
357
- case 28:
358
- typeof ((WB0kIJ0.aF = "aG"), (b7C5lP += 130));
359
- break;
360
- case 110:
361
- typeof ((WB0kIJ0.a = R6QFdZ <= WB0kIJ0.g), WB0kIJ0.W());
362
- }
363
- function y9tPuB(b7C5lP) {
364
- return function () {
365
- return b7C5lP(...arguments);
366
- };
367
- }
368
- ```
369
-
370
- As you can see, the If-statement and For-loop are nowhere to be found in the output code. These control structures were added to switch statement by converting them into their equivalent 'goto style of code.'
371
-
372
- ## Goto style of code
373
-
374
- Control Flow Flattening converts your code into a 'goto style of code.'
375
- Example:
376
-
377
- ```js
378
- // Input
379
- console.log("Start of code");
380
-
381
- if(true){
382
- console.log("This code runs");
383
- }
384
-
385
- console.log("End of code");
386
-
387
- // Output
388
- chunk_0:
389
- console.log("Start of code");
390
- var TEST = true;
391
- if( TEST ) goto chunk_1;
392
- else goto chunk_2;
393
-
394
- chunk_1:
395
- console.log("This code runs");
396
- goto chunk_2;
397
-
398
- chunk_2:
399
- console.log("End of code");
400
- ```
401
-
402
- JavaScript does not support the `goto` keyword. This is where the while-loop and switch statement come in.
403
-
404
- ```js
405
- var state = 0;
406
- while (state != 3) {
407
- switch (state) {
408
- case 0: // 'chunk_0'
409
- console.log("Start of code");
410
- var TEST = true;
411
- if (TEST) {
412
- state = 1; // 'goto chunk_1'
413
- break;
414
- }
415
- state = 2; // 'goto chunk_2'
416
- break;
417
- case 1: // 'chunk_1'
418
- console.log("This code runs");
419
- state = 2; // 'goto chunk_2'
420
- break;
421
- case 2:
422
- console.log("End of code");
423
- state = 3; // 'end of program'
424
- break;
425
- }
426
- }
427
- ```
428
-
429
- This code replicates functionality of the `goto` statement in JavaScript by using a while-loop paired with a switch-statement.
430
-
431
- The 'state' variable determines which chunk will execute. Each chunk is placed as a Switch-case with a number assigned to it.
432
-
433
- This is just the simple version of things. JS-Confuser uses a variety of techniques to further obfuscate the switch statement:
434
-
435
- ```js
436
- // Input
437
- var numbers1To10 = [];
438
- for (var i = 1; i <= 10; i++) {
439
- numbers1To10.push(i);
440
- }
441
-
442
- console.log(numbers1To10); // [1,2,3,4,5,6,7,8,9,10]
443
-
444
- // Output
445
- // (1) Multiple state variables (C2Ihj2, z0UNXR7, yAt1T_y, baOORjm)
446
- var C2Ihj2 = 262,
447
- z0UNXR7 = 203,
448
- yAt1T_y = -557,
449
- baOORjm = 167;
450
-
451
- // (2) Control object that holds data: (Wnhi6cp)
452
- // - Strings used by the code
453
- // - Numbers used by the code
454
- // - Outlined expressions
455
- var Wnhi6cp = {
456
- e: -39,
457
- l: () => (Wnhi6cp.a = (Wnhi6cp.c == "j" ? Proxy : XGGmew) <= Wnhi6cp.c),
458
- E: () => {
459
- return (yAt1T_y += 133);
460
- },
461
- q: () => {
462
- if (Wnhi6cp.a) {
463
- !((C2Ihj2 -= 39), (yAt1T_y += z0UNXR7 + 172));
464
- return "o";
465
- }
466
- !((C2Ihj2 -= 39), (yAt1T_y += Wnhi6cp.n), (baOORjm -= 64));
467
- return "o";
468
- },
469
- m: () => {
470
- return (baOORjm += 273);
471
- },
472
- d: "push",
473
- c: 10,
474
- P: () => (yAt1T_y -= 60),
475
- f: () => (z0UNXR7 -= 339),
476
- K: -426,
477
- t: () => (yAt1T_y += Wnhi6cp.s),
478
- n: 133,
479
- L: -454,
480
- h: -830,
481
- s: -839,
482
- r: 313,
483
- b: 1,
484
- J: () => {
485
- return (
486
- (C2Ihj2 += 39),
487
- (z0UNXR7 += -42 != yAt1T_y ? 313 : -66),
488
- (yAt1T_y += Wnhi6cp.n == 262 ? 67 : -133),
489
- (baOORjm -= 273)
490
- );
491
- },
492
- i: -1493,
493
- T: (yAt1T_y) => {
494
- return yAt1T_y + 373;
495
- },
496
- U: (z0UNXR7) => {
497
- return z0UNXR7 + 177;
498
- },
499
- V: (baOORjm) => {
500
- return baOORjm != -454 && baOORjm + 528;
501
- },
502
- };
503
- while (C2Ihj2 + z0UNXR7 + yAt1T_y + baOORjm != 63)
504
- switch (C2Ihj2 + z0UNXR7 + yAt1T_y + baOORjm) {
505
- // (3) Multiple test expressions (default, 394, 241)
506
- default:
507
- case 394:
508
- case 241:
509
- var PMHmf7g = [],
510
- XGGmew = (Wnhi6cp.g = Wnhi6cp).b;
511
- // (4) Relative state assignment (yAt1T_y += 839)
512
- yAt1T_y += 839;
513
- // (5) Mangled numbers (Wnhi6cp.h)
514
- baOORjm += Wnhi6cp.h;
515
- break;
516
- case Wnhi6cp.T(yAt1T_y):
517
- if (false) {
518
- // (6) Dead Code
519
- yAt1T_y += yAt1T_y + Wnhi6cp.K;
520
- }
521
- case 939:
522
- case 25:
523
- case 461:
524
- // (7) Mangled test expressions (C2Ihj2 - 149)
525
- case C2Ihj2 - 149:
526
- console.log(C2Ihj2 == -86 ? setTimeout : PMHmf7g);
527
- // (4, again) Relative state assignment (yAt1T_y += yAt1T_y + Wnhi6cp.K)
528
- yAt1T_y += yAt1T_y + Wnhi6cp.K;
529
- break;
530
- case Wnhi6cp.U(z0UNXR7):
531
- yAt1T_y -= 62;
532
- break;
533
- case 5:
534
- case 802:
535
- case 300:
536
- if (baOORjm == -118) {
537
- typeof ((C2Ihj2 += 39),
538
- (z0UNXR7 += Wnhi6cp.r),
539
- Wnhi6cp.t(),
540
- (baOORjm += Wnhi6cp.c == -390 ? 40 : 557));
541
- break;
542
- }
543
- // (8) Mangled Identifiers (baOORjm == 91 ? ReferenceError : PMHmf7g)
544
- void ((baOORjm == 91 ? ReferenceError : PMHmf7g)[
545
- (Wnhi6cp.hasOwnProperty("B") ? eval : Wnhi6cp).d
546
- ](yAt1T_y == 78 ? Function : XGGmew),
547
- Wnhi6cp.E());
548
- break;
549
- case 84:
550
- if (C2Ihj2 == 10) {
551
- typeof ((yAt1T_y -= 839), (baOORjm *= 2), (baOORjm -= Wnhi6cp.i));
552
- break;
553
- }
554
- typeof (Wnhi6cp.l(), (z0UNXR7 += C2Ihj2 - 575), Wnhi6cp.m());
555
- break;
556
- // (6, again) Dead code
557
- case Wnhi6cp.V(baOORjm):
558
- delete Wnhi6cp.S;
559
- // (9) Opaque predicates (typeof Wnhi6cp.s == 'function')
560
- if (typeof Wnhi6cp.s == "function" || !1) {
561
- yAt1T_y -= 133;
562
- break;
563
- }
564
- void (XGGmew++, Wnhi6cp.J());
565
- break;
566
- case 37:
567
- case 257:
568
- case 989:
569
- case 398:
570
- void ((yAt1T_y = -(Wnhi6cp.d == -75 ? "N" : 47)),
571
- (z0UNXR7 += 26),
572
- Wnhi6cp.P(),
573
- (baOORjm += 64));
574
- break;
575
- case 44:
576
- if (Wnhi6cp.q() == "o") {
577
- break;
578
- }
579
- }
580
- ```
581
-
582
- As you can see the code is still very unreadable even with the comments explaining the techniques used.
583
-
584
- The techniques used by Control Flow Flattening are always improving to stop deobfuscators from being able to work.
585
-
586
- ## Performance reduction
587
-
588
- Control Flow Flattening reduces the performance of your program. You should adjust the option `controlFlowFlattening` to be a percentage that is appropriate for your app.
589
-
590
- ## Other notes
591
-
592
- Control Flow Flattening only applies to:
593
-
594
- - Blocks of 3 statements or more
595
- - Cannot use `let`/`const` in these blocks of code
@@ -1,70 +0,0 @@
1
- ## `Countermeasures`
2
-
3
- Countermeasures is a property on the `lock` object, determining the response to a triggered lock.
4
-
5
- For instance, the `domainLock` determines the current domain is invalid.
6
-
7
- ```js
8
- {
9
- target: "node",
10
- lock: {
11
- domainLock: ["mywebsite.com"],
12
-
13
- // crash process (default)
14
- countermeasures: true,
15
-
16
- // custom callback to invoke
17
- countermeasures: "onLockTriggered"
18
- }
19
- }
20
- ```
21
-
22
- ## Crash Process
23
-
24
- The default behavior is to crash the process This is done by an infinite loop to ensure the process becomes useless.
25
-
26
- ```js
27
- while(true) {
28
- // ...
29
- }
30
- ```
31
-
32
- ## Custom Callback
33
-
34
- By setting countermeasures to a string, it can point to a callback to invoke when a lock is triggered.
35
-
36
- The countermeasures callback function can either be a local name or an external name.
37
-
38
- Examples:
39
- - `"onLockTriggered"`
40
- - `"window.onLockTriggered"`
41
-
42
- If the function is defined within the locked code, it must follow the local name rules.
43
-
44
- ## Local Name rules
45
-
46
- 1. The function must be defined at the top-level of your program.
47
- 2. The function must not rely on any scoped variables.
48
- 3. The function cannot call functions outside it's context.
49
-
50
- These rules are necessary to prevent an infinite loop from occurring.
51
-
52
- ## Test your countermeasure
53
-
54
- #### Domain Lock:
55
-
56
- Try your code within DevTools while on another website.
57
-
58
- #### Time Lock:
59
-
60
- Try setting your machine time to the past or before the allowed range.
61
-
62
- #### Integrity:
63
-
64
- Try changing a string within your code.
65
-
66
- ### See also
67
-
68
- - [Integrity](Integrity.md)
69
- - [Tamper Protection](TamperProtection.md)
70
-