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,441 +0,0 @@
1
- import traverse, { ExitCallback } from "../traverse";
2
- import {
3
- AddComment,
4
- Node,
5
- VariableDeclaration,
6
- VariableDeclarator,
7
- } from "../util/gen";
8
- import {
9
- alphabeticalGenerator,
10
- choice,
11
- createZeroWidthGenerator,
12
- getRandomInteger,
13
- shuffle,
14
- } from "../util/random";
15
- import { ok } from "assert";
16
- import Obfuscator from "../obfuscator";
17
- import { ComputeProbabilityMap } from "../probability";
18
- import {
19
- placeholderVariablePrefix,
20
- reservedIdentifiers,
21
- reservedKeywords,
22
- } from "../constants";
23
- import { ObfuscateOrder } from "../order";
24
- import { prepend } from "../util/insert";
25
- import Lock from "./lock/lock";
26
- import Template from "../templates/template";
27
-
28
- /**
29
- * Base-class for all transformations.
30
- * - Transformations can have preparation transformations `.before`
31
- * - Transformations can have cleanup transformations `.after`
32
- *
33
- * - `match()` function returns true/false if possible candidate
34
- * - `transform()` function modifies the object
35
- *
36
- * ```js
37
- * class Example extends Transform {
38
- * constructor(o){
39
- * super(o);
40
- * }
41
- *
42
- * match(object, parents){
43
- * return object.type == "...";
44
- * }
45
- *
46
- * transform(object, parents){
47
- * // onEnter
48
- *
49
- * return ()=>{
50
- * // onExit
51
- * }
52
- * }
53
- *
54
- * apply(tree){
55
- * // onStart
56
- *
57
- * super.apply(tree);
58
- *
59
- * // onEnd
60
- * }
61
- * }
62
- * ```
63
- */
64
- export default class Transform {
65
- /**
66
- * The obfuscator.
67
- */
68
- obfuscator: Obfuscator;
69
-
70
- /**
71
- * The user's options.
72
- */
73
- options: Obfuscator["options"];
74
-
75
- /**
76
- * Only required for top-level transformations.
77
- */
78
- priority: number;
79
-
80
- /**
81
- * Transforms to run before, such as `Variable Analysis`.
82
- */
83
- before: Transform[];
84
-
85
- /**
86
- * Transforms to run after.
87
- */
88
- after: Transform[];
89
-
90
- initVariables = new Map<string, string>();
91
-
92
- zeroWidthGenerator = createZeroWidthGenerator();
93
-
94
- constructor(obfuscator, priority: number = -1) {
95
- ok(obfuscator instanceof Obfuscator, "obfuscator should be an Obfuscator");
96
-
97
- this.obfuscator = obfuscator;
98
- this.options = this.obfuscator.options;
99
-
100
- this.priority = priority;
101
-
102
- this.before = [];
103
- this.after = [];
104
- }
105
-
106
- /**
107
- * The transformation name.
108
- */
109
- get className() {
110
- return (
111
- ObfuscateOrder[this.priority] || (this as any).__proto__.constructor.name
112
- );
113
- }
114
-
115
- /**
116
- * Gets the `Lock` transformation.
117
- */
118
- get lockTransform(): Lock {
119
- var transform = this.obfuscator.transforms["Lock"] as Lock;
120
-
121
- ok(transform, "Lock transform not created");
122
-
123
- return transform;
124
- }
125
-
126
- /**
127
- * Wraps the given name with the `__JS_CONFUSER_VAR__` function call.
128
- *
129
- * If `Rename Variables` is disabled, the name is returned as-is.
130
- * @param name
131
- * @returns
132
- */
133
- jsConfuserVar(name: string) {
134
- if (!this.obfuscator.transforms["RenameVariables"]) {
135
- return `"${name}"`;
136
- }
137
-
138
- return `__JS_CONFUSER_VAR__(${name})`;
139
- }
140
-
141
- /**
142
- * Run an AST through the transformation (including `pre` and `post` transforms)
143
- * @param tree
144
- */
145
- apply(tree: Node) {
146
- if (tree.type == "Program" && this.options.verbose) {
147
- if (this.priority === -1) {
148
- console.log("#", ">", this.className);
149
- } else {
150
- console.log("#", this.priority, this.className);
151
- }
152
- }
153
-
154
- /**
155
- * Run through pre-transformations
156
- */
157
- this.before.forEach((x) => x.apply(tree));
158
-
159
- /**
160
- * Run this transformation
161
- */
162
- traverse(tree, (object, parents) => {
163
- return this.input(object, parents);
164
- });
165
-
166
- /**
167
- * Cleanup transformations
168
- */
169
- this.after.forEach((x) => x.apply(tree));
170
- }
171
-
172
- /**
173
- * The `match` function filters for possible candidates.
174
- *
175
- * - If `true`, the node is sent to the `transform()` method
176
- * - else it's discarded.
177
- *
178
- * @param object
179
- * @param parents
180
- * @param block
181
- */
182
- match(object: Node, parents: Node[]): boolean {
183
- throw new Error("not implemented");
184
- }
185
-
186
- /**
187
- * Modifies the given node.
188
- *
189
- * - Return a function to be ran when the node is exited.
190
- * - The node is safe to modify in most cases.
191
- *
192
- * @param object - Current node
193
- * @param parents - Array of ancestors `[Closest, ..., Root]`
194
- * @param block
195
- */
196
- transform(object: Node, parents: Node[]): ExitCallback | void {
197
- throw new Error("not implemented");
198
- }
199
-
200
- /**
201
- * Calls `.match` with the given parameters, and then `.transform` if satisfied.
202
- * @private
203
- */
204
- input(object: Node, parents: Node[]): ExitCallback | void {
205
- if (this.match(object, parents)) {
206
- return this.transform(object, parents);
207
- }
208
- }
209
-
210
- /**
211
- * Returns a random string.
212
- *
213
- * Used for creating temporary variables names, typically before RenameVariables has ran.
214
- *
215
- * These long temp names will be converted to short, mangled names by RenameVariables.
216
- */
217
- getPlaceholder() {
218
- const genRanHex = (size) =>
219
- [...Array(size)]
220
- .map(() => Math.floor(Math.random() * 10).toString(10))
221
- .join("");
222
- return placeholderVariablePrefix + genRanHex(10);
223
- }
224
-
225
- /**
226
- * Returns an independent name generator with it's own counter.
227
- * @param overrideMode - Override the user's `identifierGenerator` option
228
- * @returns
229
- */
230
- getGenerator(overrideMode?: string) {
231
- var count = 0;
232
- var identifiers = new Set();
233
- return {
234
- generate: () => {
235
- var retValue: string;
236
- do {
237
- count++;
238
- retValue = this.generateIdentifier(-1, count, overrideMode);
239
- } while (identifiers.has(retValue));
240
-
241
- identifiers.add(retValue);
242
-
243
- return retValue;
244
- },
245
- };
246
- }
247
-
248
- /**
249
- * Generates a valid variable name.
250
- * @param length Default length is 6 to 10 characters.
251
- * @returns **`string`**
252
- */
253
- generateIdentifier(
254
- length: number = -1,
255
- count = -1,
256
- overrideMode?: string
257
- ): string {
258
- if (length == -1) {
259
- length = getRandomInteger(6, 8);
260
- }
261
-
262
- var set = new Set();
263
-
264
- if (count == -1) {
265
- this.obfuscator.varCount++;
266
- count = this.obfuscator.varCount;
267
- set = this.obfuscator.generated;
268
- }
269
-
270
- var identifier;
271
- do {
272
- identifier = ComputeProbabilityMap(
273
- overrideMode || this.options.identifierGenerator,
274
- (mode = "randomized") => {
275
- switch (mode) {
276
- case "randomized":
277
- var characters =
278
- "_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(
279
- ""
280
- );
281
- var numbers = "0123456789".split("");
282
-
283
- var combined = [...characters, ...numbers];
284
-
285
- var result = "";
286
- for (var i = 0; i < length; i++) {
287
- result += choice(i == 0 ? characters : combined);
288
- }
289
- return result;
290
-
291
- case "hexadecimal":
292
- const genRanHex = (size) =>
293
- [...Array(size)]
294
- .map(() => Math.floor(Math.random() * 16).toString(16))
295
- .join("");
296
-
297
- return "_0x" + genRanHex(length).toUpperCase();
298
-
299
- case "mangled":
300
- while (1) {
301
- var result = alphabeticalGenerator(count);
302
- count++;
303
-
304
- if (
305
- reservedKeywords.has(result) ||
306
- reservedIdentifiers.has(result)
307
- ) {
308
- } else {
309
- return result;
310
- }
311
- }
312
-
313
- throw new Error("impossible but TypeScript insists");
314
-
315
- case "number":
316
- return "var_" + count;
317
-
318
- case "zeroWidth":
319
- return this.zeroWidthGenerator.generate();
320
- }
321
-
322
- throw new Error("Invalid 'identifierGenerator' mode: " + mode);
323
- }
324
- );
325
- } while (set.has(identifier));
326
-
327
- if (!identifier) {
328
- throw new Error("identifier null");
329
- }
330
-
331
- set.add(identifier);
332
-
333
- return identifier;
334
- }
335
-
336
- createInitVariable = (value: Template, parents: Node[]) => {
337
- var key = value.templates[0];
338
- if (this.initVariables.has(key)) {
339
- return this.initVariables.get(key);
340
- }
341
-
342
- var root = parents[parents.length - 1];
343
- ok(root.type === "Program");
344
-
345
- var name = this.getPlaceholder();
346
- this.initVariables.set(key, name);
347
-
348
- prepend(
349
- root,
350
- VariableDeclaration(VariableDeclarator(name, value.single().expression))
351
- );
352
-
353
- return name;
354
- };
355
-
356
- /**
357
- * Smartly appends a comment to a Node.
358
- * - Includes the transformation's name.
359
- * @param node
360
- * @param text
361
- * @param i
362
- */
363
- addComment(node: Node, text: string) {
364
- if (this.options.debugComments) {
365
- return AddComment(node, `[${this.className}] ${text}`);
366
- }
367
- return node;
368
- }
369
-
370
- replace(node1: Node, node2: Node) {
371
- for (var key in node1) {
372
- delete node1[key];
373
- }
374
-
375
- this.objectAssign(node1, node2);
376
- }
377
-
378
- replaceIdentifierOrLiteral(node1: Node, node2: Node, parents: Node[]) {
379
- // Fix 2. Make parent property key computed
380
- if (
381
- parents[0] &&
382
- (parents[0].type == "Property" ||
383
- parents[0].type == "MethodDefinition") &&
384
- parents[0].key == node1
385
- ) {
386
- parents[0].computed = true;
387
- parents[0].shorthand = false;
388
- }
389
- this.replace(node1, node2);
390
- }
391
-
392
- /**
393
- * Smartly merges two Nodes.
394
- * - Null checking
395
- * - Preserves comments
396
- * @param node1
397
- * @param node2
398
- */
399
- objectAssign(node1: Node, node2: Node): Node {
400
- ok(node1);
401
- ok(node2);
402
-
403
- var comments1 = node1.leadingComments || [];
404
- var comments2 = node2.leadingComments || [];
405
- var comments = [...comments1, ...comments2];
406
-
407
- node2.leadingComments = comments;
408
-
409
- node1._transform = node2._transform = this.className;
410
-
411
- return Object.assign(node1, node2);
412
- }
413
-
414
- /**
415
- * Verbose logging for this transformation.
416
- * @param messages
417
- */
418
- log(...messages: any[]) {
419
- if (this.options.verbose) {
420
- console.log("[" + this.className + "]", ...messages);
421
- }
422
- }
423
-
424
- /**
425
- * Verbose logging for warning/important messages.
426
- * @param messages
427
- */
428
- warn(...messages: any[]) {
429
- if (this.options.verbose) {
430
- console.log("[ WARN " + this.className + " ]", ...messages);
431
- }
432
- }
433
-
434
- /**
435
- * Throws an error. Appends the transformation's name to the error's message.
436
- * @param error
437
- */
438
- error(error: Error): never {
439
- throw new Error(`${this.className} Error: ${error.message}`);
440
- }
441
- }
package/src/traverse.ts DELETED
@@ -1,120 +0,0 @@
1
- import { Node } from "./util/gen";
2
- import { validateChain } from "./util/identifiers";
3
-
4
- /**
5
- * A block refers to any object that has a **`.body`** property where code is nested.
6
- *
7
- * Types: `BlockStatement`, `Program`
8
- *
9
- * @param object
10
- * @param parents
11
- */
12
- export function getBlock(object: any, parents: any[]) {
13
- if (!Array.isArray(parents)) {
14
- throw new Error("parents must be an array");
15
- }
16
- return [object, ...parents].find((node) => isBlock(node));
17
- }
18
-
19
- /**
20
- * Must have a **`.body`** property and be an array.
21
- *
22
- * - "BlockStatement"
23
- * - "Program"
24
- *
25
- * @param object
26
- */
27
- export function isBlock(object: any) {
28
- return (
29
- object && (object.type == "BlockStatement" || object.type == "Program")
30
- );
31
- }
32
-
33
- export type EnterCallback = (
34
- object: Node,
35
- parents: Node[]
36
- ) => ExitCallback | "EXIT" | void;
37
- export type ExitCallback = () => void;
38
-
39
- export function walk(
40
- object: Node | Node[],
41
- parents: Node[],
42
- onEnter: EnterCallback
43
- ): "EXIT" | void {
44
- if (typeof object === "object" && object) {
45
- var newParents: Node[] = [object as Node, ...parents];
46
-
47
- // if (!Array.isArray(object)) {
48
- // validateChain(object, parents);
49
- // }
50
-
51
- // 1. Call `onEnter` function and remember any onExit callback returned
52
- var onExit = onEnter(object as Node, parents);
53
-
54
- // 2. Traverse children
55
- if (Array.isArray(object)) {
56
- var copy = [...object];
57
- for (var element of copy) {
58
- if (walk(element, newParents, onEnter) === "EXIT") {
59
- return "EXIT";
60
- }
61
- }
62
- } else {
63
- var keys = Object.keys(object);
64
- for (var key of keys) {
65
- if (!key.startsWith("$")) {
66
- if (walk(object[key], newParents, onEnter) === "EXIT") {
67
- return "EXIT";
68
- }
69
- }
70
- }
71
- }
72
-
73
- if (onExit === "EXIT") {
74
- return "EXIT";
75
- }
76
-
77
- // 3. Done with children, call `onExit` callback
78
- if (onExit) {
79
- onExit();
80
- }
81
- }
82
- }
83
-
84
- /**
85
- * The bare-bones walker.
86
- *
87
- * - Recursively traverse an AST object.
88
- * - Calls the `onEnter` function with:
89
- * - - `object` - The current node
90
- * - - `parents` - Array of ancestors `[closest, ..., root]`
91
- * - The `onEnter` callback can return an `onExit` callback for that node.
92
- *
93
- * - *Note*: Does not validate the property names.
94
- *
95
- * @param tree
96
- * @param onEnter
97
- */
98
- export default function traverse(tree, onEnter: EnterCallback) {
99
- walk(tree, [], onEnter);
100
- }
101
-
102
- /**
103
- * This is debugging function used to test for circular references.
104
- */
105
- export function assertNoCircular(object) {
106
- var seen = new Set();
107
-
108
- traverse(object, (node, nodeParents) => {
109
- if (node && typeof node === "object") {
110
- if (seen.has(node)) {
111
- console.log(nodeParents);
112
- console.log(node);
113
-
114
- throw new Error("FOUND CIRCULAR REFERENCE");
115
- }
116
-
117
- seen.add(node);
118
- }
119
- });
120
- }
package/src/types.ts DELETED
@@ -1,133 +0,0 @@
1
- import Obfuscator from "./obfuscator";
2
- import { ObfuscateOptions } from "./options";
3
- import Template from "./templates/template";
4
- import Transform from "./transforms/transform";
5
-
6
- /**
7
- * **JsConfuser**: Obfuscates JavaScript.
8
- * @param code - The code to be obfuscated.
9
- * @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
10
- *
11
- * [See all settings here](https://github.com/MichaelXF/js-confuser#options)
12
- */
13
- export interface IJsConfuser {
14
- obfuscate: IJsConfuserObfuscate;
15
- obfuscateAST: IJsConfuserObfuscateAST;
16
-
17
- presets: IJsConfuserPresets;
18
- debugTransformations: IJsConfuserDebugTransformations;
19
- debugObfuscation: IJsConfuserDebugObfuscation;
20
-
21
- (code: string, options: ObfuscateOptions): Promise<string>;
22
-
23
- Transform: typeof Transform;
24
- Obfuscator: typeof Obfuscator;
25
- Template: typeof Template;
26
- }
27
-
28
- /**
29
- * **JsConfuser**: Obfuscates JavaScript.
30
- * @param code - The code to be obfuscated.
31
- * @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
32
- *
33
- * [See all settings here](https://github.com/MichaelXF/js-confuser#options)
34
- */
35
- export interface IJsConfuserObfuscate {
36
- (code: string, options: ObfuscateOptions): Promise<string>;
37
- }
38
-
39
- /**
40
- * Obfuscates an [ESTree](https://github.com/estree/estree) compliant AST.
41
- *
42
- * **Note:** Mutates the object.
43
- *
44
- * @param AST - The [ESTree](https://github.com/estree/estree) compliant AST. This object will be mutated.
45
- * @param options - The obfuscation options.
46
- *
47
- * [See all settings here](https://github.com/MichaelXF/js-confuser#options)
48
- */
49
- export interface IJsConfuserObfuscateAST {
50
- (AST: any, options: ObfuscateOptions): Promise<void>;
51
- }
52
-
53
- export interface IJsConfuserPresets {
54
- high: ObfuscateOptions;
55
- medium: ObfuscateOptions;
56
- low: ObfuscateOptions;
57
- }
58
-
59
- /**
60
- * Obfuscates code but returns an array of `frames`
61
- *
62
- * ```js
63
- * [
64
- * {
65
- * name: "Preparation",
66
- * code: "console['log']('Hello World')",
67
- * ms: 4
68
- * }, {
69
- * name: "ControlFlowFlattening",
70
- * code: "var....",
71
- * ms: 400
72
- * },
73
- * // ....
74
- * ]
75
- * ```
76
- */
77
- export type IJsConfuserDebugTransformations = (
78
- code: string,
79
- options: ObfuscateOptions
80
- ) => Promise<{ name: string; code: string; ms: number }[]>;
81
-
82
- /**
83
- * Obfuscates code but calls the callback function after each transform.
84
- *
85
- * This is used to display a progress bar to the user on the official website.
86
- *
87
- * `callback(name: string, complete: number, totalTransforms: number)`
88
- *
89
- * ```js
90
- * var callback = (name, complete, totalTransforms) => {
91
- * console.log(name, complete, totalTransforms)
92
- * };
93
- * ```
94
- *
95
- * ```js
96
- * // Preparation 1 22
97
- * // ObjectExtraction 2 22
98
- * // Flatten 3 22
99
- * // Dispatcher 4 22
100
- * // DeadCode 5 22
101
- * // Calculator 6 22
102
- * // ControlFlowFlattening 7 22
103
- * // GlobalConcealing 8 22
104
- * // OpaquePredicates 9 22
105
- * // StringSplitting 10 22
106
- * // StringConcealing 11 22
107
- * // StringCompression 12 22
108
- * // HideInitializingCode 13 22
109
- * // Stack 14 22
110
- * // DuplicateLiteralsRemoval 15 22
111
- * // Shuffle 16 22
112
- * // MovedDeclarations 17 22
113
- * // RenameVariables 18 22
114
- * // RenameLabels 19 22
115
- * // Minify 20 22
116
- * // StringEncoding 21 22
117
- * // AntiTooling 22 22
118
- * ```
119
- */
120
- export type IJsConfuserDebugObfuscation = (
121
- code: string,
122
- options: ObfuscateOptions,
123
- callback: (name: string, complete: number, totalTransforms: number) => void,
124
- performance: Performance
125
- ) => Promise<{
126
- obfuscated: string;
127
- transformationTimes: { [transformName: string]: number };
128
- parseTime: number;
129
- compileTime: number;
130
- obfuscationTime: number;
131
- totalTransforms: number;
132
- totalPossibleTransforms: number;
133
- }>;