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.
Files changed (263) hide show
  1. package/.github/ISSUE_TEMPLATE/bug_report.md +6 -4
  2. package/.github/workflows/node.js.yml +1 -1
  3. package/CHANGELOG.md +105 -0
  4. package/Migration.md +57 -0
  5. package/README.md +23 -913
  6. package/dist/constants.js +69 -13
  7. package/dist/index.js +108 -152
  8. package/dist/obfuscator.js +316 -118
  9. package/dist/options.js +1 -109
  10. package/dist/order.js +30 -30
  11. package/dist/presets.js +47 -45
  12. package/dist/probability.js +25 -32
  13. package/dist/templates/bufferToStringTemplate.js +9 -0
  14. package/dist/templates/deadCodeTemplates.js +9 -0
  15. package/dist/templates/getGlobalTemplate.js +19 -0
  16. package/dist/templates/integrityTemplate.js +30 -0
  17. package/dist/templates/setFunctionLengthTemplate.js +9 -0
  18. package/dist/templates/stringCompressionTemplate.js +10 -0
  19. package/dist/templates/tamperProtectionTemplates.js +21 -0
  20. package/dist/templates/template.js +213 -93
  21. package/dist/transforms/astScrambler.js +100 -0
  22. package/dist/transforms/calculator.js +70 -127
  23. package/dist/transforms/controlFlowFlattening.js +1182 -0
  24. package/dist/transforms/deadCode.js +62 -577
  25. package/dist/transforms/dispatcher.js +300 -309
  26. package/dist/transforms/extraction/duplicateLiteralsRemoval.js +88 -189
  27. package/dist/transforms/extraction/objectExtraction.js +131 -215
  28. package/dist/transforms/finalizer.js +56 -59
  29. package/dist/transforms/flatten.js +275 -276
  30. package/dist/transforms/functionOutlining.js +230 -0
  31. package/dist/transforms/identifier/globalConcealing.js +217 -103
  32. package/dist/transforms/identifier/movedDeclarations.js +167 -91
  33. package/dist/transforms/identifier/renameVariables.js +240 -187
  34. package/dist/transforms/lock/integrity.js +61 -184
  35. package/dist/transforms/lock/lock.js +263 -303
  36. package/dist/transforms/minify.js +431 -436
  37. package/dist/transforms/opaquePredicates.js +65 -118
  38. package/dist/transforms/pack.js +160 -0
  39. package/dist/transforms/plugin.js +179 -0
  40. package/dist/transforms/preparation.js +263 -163
  41. package/dist/transforms/renameLabels.js +132 -56
  42. package/dist/transforms/rgf.js +142 -240
  43. package/dist/transforms/shuffle.js +52 -145
  44. package/dist/transforms/string/encoding.js +45 -173
  45. package/dist/transforms/string/stringCompression.js +81 -126
  46. package/dist/transforms/string/stringConcealing.js +189 -224
  47. package/dist/transforms/string/stringEncoding.js +32 -40
  48. package/dist/transforms/string/stringSplitting.js +54 -55
  49. package/dist/transforms/variableMasking.js +232 -0
  50. package/dist/utils/ControlObject.js +125 -0
  51. package/dist/utils/IntGen.js +46 -0
  52. package/dist/utils/NameGen.js +106 -0
  53. package/dist/utils/ast-utils.js +560 -0
  54. package/dist/utils/function-utils.js +56 -0
  55. package/dist/utils/gen-utils.js +48 -0
  56. package/dist/utils/node.js +77 -0
  57. package/dist/utils/object-utils.js +21 -0
  58. package/dist/utils/random-utils.js +91 -0
  59. package/dist/utils/static-utils.js +64 -0
  60. package/dist/validateOptions.js +122 -0
  61. package/index.d.ts +1 -17
  62. package/package.json +27 -22
  63. package/src/constants.ts +139 -77
  64. package/src/index.ts +70 -163
  65. package/src/obfuscationResult.ts +43 -0
  66. package/src/obfuscator.ts +328 -135
  67. package/src/options.ts +154 -623
  68. package/src/order.ts +14 -14
  69. package/src/presets.ts +39 -34
  70. package/src/probability.ts +21 -36
  71. package/src/templates/{bufferToString.ts → bufferToStringTemplate.ts} +5 -54
  72. package/src/templates/deadCodeTemplates.ts +1185 -0
  73. package/src/templates/getGlobalTemplate.ts +72 -0
  74. package/src/templates/integrityTemplate.ts +69 -0
  75. package/src/templates/setFunctionLengthTemplate.ts +11 -0
  76. package/src/templates/stringCompressionTemplate.ts +42 -0
  77. package/src/templates/tamperProtectionTemplates.ts +116 -0
  78. package/src/templates/template.ts +183 -92
  79. package/src/transforms/astScrambler.ts +99 -0
  80. package/src/transforms/calculator.ts +96 -224
  81. package/src/transforms/controlFlowFlattening.ts +1594 -0
  82. package/src/transforms/deadCode.ts +85 -628
  83. package/src/transforms/dispatcher.ts +431 -636
  84. package/src/transforms/extraction/duplicateLiteralsRemoval.ts +147 -299
  85. package/src/transforms/extraction/objectExtraction.ts +160 -333
  86. package/src/transforms/finalizer.ts +63 -64
  87. package/src/transforms/flatten.ts +439 -557
  88. package/src/transforms/functionOutlining.ts +225 -0
  89. package/src/transforms/identifier/globalConcealing.ts +261 -189
  90. package/src/transforms/identifier/movedDeclarations.ts +228 -142
  91. package/src/transforms/identifier/renameVariables.ts +252 -258
  92. package/src/transforms/lock/integrity.ts +84 -260
  93. package/src/transforms/lock/lock.ts +342 -491
  94. package/src/transforms/minify.ts +523 -663
  95. package/src/transforms/opaquePredicates.ts +90 -229
  96. package/src/transforms/pack.ts +195 -0
  97. package/src/transforms/plugin.ts +185 -0
  98. package/src/transforms/preparation.ts +337 -215
  99. package/src/transforms/renameLabels.ts +176 -77
  100. package/src/transforms/rgf.ts +293 -386
  101. package/src/transforms/shuffle.ts +80 -254
  102. package/src/transforms/string/encoding.ts +26 -129
  103. package/src/transforms/string/stringCompression.ts +118 -236
  104. package/src/transforms/string/stringConcealing.ts +255 -339
  105. package/src/transforms/string/stringEncoding.ts +28 -47
  106. package/src/transforms/string/stringSplitting.ts +61 -75
  107. package/src/transforms/variableMasking.ts +257 -0
  108. package/src/utils/ControlObject.ts +141 -0
  109. package/src/utils/IntGen.ts +33 -0
  110. package/src/utils/NameGen.ts +106 -0
  111. package/src/utils/ast-utils.ts +667 -0
  112. package/src/utils/function-utils.ts +50 -0
  113. package/src/utils/gen-utils.ts +48 -0
  114. package/src/utils/node.ts +78 -0
  115. package/src/utils/object-utils.ts +21 -0
  116. package/src/utils/random-utils.ts +79 -0
  117. package/src/utils/static-utils.ts +66 -0
  118. package/src/validateOptions.ts +256 -0
  119. package/tsconfig.json +13 -8
  120. package/babel.config.js +0 -12
  121. package/dev.js +0 -8
  122. package/dist/compiler.js +0 -34
  123. package/dist/parser.js +0 -59
  124. package/dist/precedence.js +0 -66
  125. package/dist/templates/bufferToString.js +0 -108
  126. package/dist/templates/crash.js +0 -59
  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 -1281
  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 -70
  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 -343
  144. package/dist/transforms/transform.js +0 -350
  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 -9
  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 -130
  154. package/dist/util/scope.js +0 -20
  155. package/docs/ControlFlowFlattening.md +0 -595
  156. package/docs/Countermeasures.md +0 -63
  157. package/docs/ES5.md +0 -197
  158. package/docs/Integrity.md +0 -75
  159. package/docs/RGF.md +0 -419
  160. package/samples/example.js +0 -15
  161. package/samples/high.js +0 -1
  162. package/samples/input.js +0 -3
  163. package/samples/javascriptobfuscator.com.js +0 -8
  164. package/samples/jscrambler_advanced.js +0 -1894
  165. package/samples/jscrambler_light.js +0 -1134
  166. package/samples/low.js +0 -1
  167. package/samples/medium.js +0 -1
  168. package/samples/obfuscator.io.js +0 -1686
  169. package/samples/preemptive.com.js +0 -16
  170. package/src/compiler.ts +0 -35
  171. package/src/parser.ts +0 -49
  172. package/src/precedence.ts +0 -61
  173. package/src/templates/crash.ts +0 -55
  174. package/src/templates/es5.ts +0 -131
  175. package/src/templates/functionLength.ts +0 -32
  176. package/src/templates/globals.ts +0 -3
  177. package/src/transforms/antiTooling.ts +0 -102
  178. package/src/transforms/controlFlowFlattening/controlFlowFlattening.ts +0 -2146
  179. package/src/transforms/controlFlowFlattening/expressionObfuscation.ts +0 -179
  180. package/src/transforms/es5/antiClass.ts +0 -272
  181. package/src/transforms/es5/antiDestructuring.ts +0 -294
  182. package/src/transforms/es5/antiES6Object.ts +0 -267
  183. package/src/transforms/es5/antiSpreadOperator.ts +0 -56
  184. package/src/transforms/es5/antiTemplate.ts +0 -98
  185. package/src/transforms/es5/es5.ts +0 -149
  186. package/src/transforms/extraction/classExtraction.ts +0 -168
  187. package/src/transforms/identifier/globalAnalysis.ts +0 -85
  188. package/src/transforms/identifier/variableAnalysis.ts +0 -118
  189. package/src/transforms/lock/antiDebug.ts +0 -112
  190. package/src/transforms/stack.ts +0 -551
  191. package/src/transforms/transform.ts +0 -453
  192. package/src/traverse.ts +0 -120
  193. package/src/types.ts +0 -131
  194. package/src/util/compare.ts +0 -181
  195. package/src/util/gen.ts +0 -651
  196. package/src/util/guard.ts +0 -7
  197. package/src/util/identifiers.ts +0 -494
  198. package/src/util/insert.ts +0 -419
  199. package/src/util/math.ts +0 -15
  200. package/src/util/object.ts +0 -39
  201. package/src/util/random.ts +0 -141
  202. package/src/util/scope.ts +0 -21
  203. package/test/code/Cash.src.js +0 -1011
  204. package/test/code/Cash.test.ts +0 -49
  205. package/test/code/Dynamic.src.js +0 -118
  206. package/test/code/Dynamic.test.ts +0 -49
  207. package/test/code/ES6.src.js +0 -235
  208. package/test/code/ES6.test.ts +0 -42
  209. package/test/code/NewFeatures.test.ts +0 -19
  210. package/test/code/StrictMode.src.js +0 -65
  211. package/test/code/StrictMode.test.js +0 -37
  212. package/test/compare.test.ts +0 -104
  213. package/test/index.test.ts +0 -249
  214. package/test/options.test.ts +0 -132
  215. package/test/presets.test.ts +0 -22
  216. package/test/probability.test.ts +0 -44
  217. package/test/templates/template.test.ts +0 -14
  218. package/test/transforms/antiTooling.test.ts +0 -52
  219. package/test/transforms/calculator.test.ts +0 -78
  220. package/test/transforms/controlFlowFlattening/controlFlowFlattening.test.ts +0 -1274
  221. package/test/transforms/controlFlowFlattening/expressionObfuscation.test.ts +0 -192
  222. package/test/transforms/deadCode.test.ts +0 -85
  223. package/test/transforms/dispatcher.test.ts +0 -457
  224. package/test/transforms/es5/antiClass.test.ts +0 -427
  225. package/test/transforms/es5/antiDestructuring.test.ts +0 -157
  226. package/test/transforms/es5/antiES6Object.test.ts +0 -245
  227. package/test/transforms/es5/antiTemplate.test.ts +0 -116
  228. package/test/transforms/es5/es5.test.ts +0 -110
  229. package/test/transforms/extraction/classExtraction.test.ts +0 -86
  230. package/test/transforms/extraction/duplicateLiteralsRemoval.test.ts +0 -200
  231. package/test/transforms/extraction/objectExtraction.test.ts +0 -491
  232. package/test/transforms/flatten.test.ts +0 -721
  233. package/test/transforms/hexadecimalNumbers.test.ts +0 -62
  234. package/test/transforms/identifier/globalConcealing.test.ts +0 -72
  235. package/test/transforms/identifier/movedDeclarations.test.ts +0 -275
  236. package/test/transforms/identifier/renameVariables.test.ts +0 -621
  237. package/test/transforms/lock/antiDebug.test.ts +0 -66
  238. package/test/transforms/lock/browserLock.test.ts +0 -129
  239. package/test/transforms/lock/countermeasures.test.ts +0 -100
  240. package/test/transforms/lock/integrity.test.ts +0 -161
  241. package/test/transforms/lock/lock.test.ts +0 -204
  242. package/test/transforms/lock/osLock.test.ts +0 -312
  243. package/test/transforms/lock/selfDefending.test.ts +0 -68
  244. package/test/transforms/minify.test.ts +0 -575
  245. package/test/transforms/opaquePredicates.test.ts +0 -43
  246. package/test/transforms/preparation.test.ts +0 -157
  247. package/test/transforms/renameLabels.test.ts +0 -95
  248. package/test/transforms/rgf.test.ts +0 -378
  249. package/test/transforms/shuffle.test.ts +0 -135
  250. package/test/transforms/stack.test.ts +0 -573
  251. package/test/transforms/string/stringCompression.test.ts +0 -120
  252. package/test/transforms/string/stringConcealing.test.ts +0 -299
  253. package/test/transforms/string/stringEncoding.test.ts +0 -95
  254. package/test/transforms/string/stringSplitting.test.ts +0 -135
  255. package/test/transforms/transform.test.ts +0 -66
  256. package/test/traverse.test.ts +0 -139
  257. package/test/util/compare.test.ts +0 -34
  258. package/test/util/gen.test.ts +0 -121
  259. package/test/util/identifiers.test.ts +0 -253
  260. package/test/util/insert.test.ts +0 -142
  261. package/test/util/math.test.ts +0 -5
  262. package/test/util/random.test.ts +0 -71
  263. /package/dist/{types.js → obfuscationResult.js} +0 -0
@@ -1,453 +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
- getRandomInteger,
12
- } from "../util/random";
13
- import { ok } from "assert";
14
- import Obfuscator from "../obfuscator";
15
- import { ObfuscateOptions } from "../options";
16
- import { ComputeProbabilityMap } from "../probability";
17
- import {
18
- placeholderVariablePrefix,
19
- reservedIdentifiers,
20
- reservedKeywords,
21
- } from "../constants";
22
- import { ObfuscateOrder } from "../order";
23
- import { ITemplate } from "../templates/template";
24
- import { prepend } from "../util/insert";
25
-
26
- /**
27
- * Base-class for all transformations.
28
- * - Transformations can have preparation transformations `.before`
29
- * - Transformations can have cleanup transformations `.after`
30
- *
31
- * - `match()` function returns true/false if possible candidate
32
- * - `transform()` function modifies the object
33
- *
34
- * ```js
35
- * class Example extends Transform {
36
- * constructor(o){
37
- * super(o);
38
- * }
39
- *
40
- * match(object, parents){
41
- * return object.type == "...";
42
- * }
43
- *
44
- * transform(object, parents){
45
- * // onEnter
46
- *
47
- * return ()=>{
48
- * // onExit
49
- * }
50
- * }
51
- *
52
- * apply(tree){
53
- * // onStart
54
- *
55
- * super.apply(tree);
56
- *
57
- * // onEnd
58
- * }
59
- * }
60
- * ```
61
- */
62
- export default class Transform {
63
- /**
64
- * The obfuscator.
65
- */
66
- obfuscator: Obfuscator;
67
-
68
- /**
69
- * The user's options.
70
- */
71
- options: ObfuscateOptions;
72
-
73
- /**
74
- * Only required for top-level transformations.
75
- */
76
- priority: number;
77
-
78
- /**
79
- * Transforms to run before, such as `Variable Analysis`.
80
- */
81
- before: Transform[];
82
-
83
- /**
84
- * Transforms to run after.
85
- */
86
- after: Transform[];
87
-
88
- initVariables = new Map<string, string>();
89
-
90
- constructor(obfuscator, priority: number = -1) {
91
- ok(obfuscator instanceof Obfuscator, "obfuscator should be an Obfuscator");
92
-
93
- this.obfuscator = obfuscator;
94
- this.options = this.obfuscator.options;
95
-
96
- this.priority = priority;
97
-
98
- this.before = [];
99
- this.after = [];
100
- }
101
-
102
- /**
103
- * The transformation name.
104
- */
105
- get className() {
106
- return (
107
- ObfuscateOrder[this.priority] || (this as any).__proto__.constructor.name
108
- );
109
- }
110
-
111
- /**
112
- * Run an AST through the transformation (including `pre` and `post` transforms)
113
- * @param tree
114
- */
115
- apply(tree: Node) {
116
- if (tree.type == "Program" && this.options.verbose) {
117
- if (this.priority === -1) {
118
- console.log("#", ">", this.className);
119
- } else {
120
- console.log("#", this.priority, this.className);
121
- }
122
- }
123
-
124
- /**
125
- * Run through pre-transformations
126
- */
127
- this.before.forEach((x) => x.apply(tree));
128
-
129
- /**
130
- * Run this transformation
131
- */
132
- traverse(tree, (object, parents) => {
133
- return this.input(object, parents);
134
- });
135
-
136
- /**
137
- * Cleanup transformations
138
- */
139
- this.after.forEach((x) => x.apply(tree));
140
- }
141
-
142
- /**
143
- * The `match` function filters for possible candidates.
144
- *
145
- * - If `true`, the node is sent to the `transform()` method
146
- * - else it's discarded.
147
- *
148
- * @param object
149
- * @param parents
150
- * @param block
151
- */
152
- match(object: Node, parents: Node[]): boolean {
153
- throw new Error("not implemented");
154
- }
155
-
156
- /**
157
- * Modifies the given node.
158
- *
159
- * - Return a function to be ran when the node is exited.
160
- * - The node is safe to modify in most cases.
161
- *
162
- * @param object - Current node
163
- * @param parents - Array of ancestors `[Closest, ..., Root]`
164
- * @param block
165
- */
166
- transform(object: Node, parents: Node[]): ExitCallback | void {
167
- throw new Error("not implemented");
168
- }
169
-
170
- /**
171
- * Calls `.match` with the given parameters, and then `.transform` if satisfied.
172
- * @private
173
- */
174
- input(object: Node, parents: Node[]): ExitCallback | void {
175
- if (this.match(object, parents)) {
176
- return this.transform(object, parents);
177
- }
178
- }
179
-
180
- /**
181
- * Returns a random string.
182
- *
183
- * Used for creating temporary variables names, typically before RenameVariables has ran.
184
- *
185
- * These long temp names will be converted to short, mangled names by RenameVariables.
186
- */
187
- getPlaceholder() {
188
- const genRanHex = (size) =>
189
- [...Array(size)]
190
- .map(() => Math.floor(Math.random() * 10).toString(10))
191
- .join("");
192
- return placeholderVariablePrefix + genRanHex(10);
193
- }
194
-
195
- /**
196
- * Returns an independent name generator with it's own counter.
197
- * @param overrideMode - Override the user's `identifierGenerator` option
198
- * @returns
199
- */
200
- getGenerator(overrideMode?: string) {
201
- var count = 0;
202
- var identifiers = new Set();
203
- return {
204
- generate: () => {
205
- var retValue: string;
206
- do {
207
- count++;
208
- retValue = this.generateIdentifier(-1, count, overrideMode);
209
- } while (identifiers.has(retValue));
210
-
211
- identifiers.add(retValue);
212
-
213
- return retValue;
214
- },
215
- };
216
- }
217
-
218
- /**
219
- * Generates a valid variable name.
220
- * @param length Default length is 6 to 10 characters.
221
- * @returns **`string`**
222
- */
223
- generateIdentifier(
224
- length: number = -1,
225
- count = -1,
226
- overrideMode?: string
227
- ): string {
228
- if (length == -1) {
229
- length = getRandomInteger(6, 8);
230
- }
231
-
232
- var set = new Set();
233
-
234
- if (count == -1) {
235
- this.obfuscator.varCount++;
236
- count = this.obfuscator.varCount;
237
- set = this.obfuscator.generated;
238
- }
239
-
240
- var identifier;
241
- do {
242
- identifier = ComputeProbabilityMap(
243
- overrideMode || this.options.identifierGenerator,
244
- (mode = "randomized") => {
245
- switch (mode) {
246
- case "randomized":
247
- var characters =
248
- "_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(
249
- ""
250
- );
251
- var numbers = "0123456789".split("");
252
-
253
- var combined = [...characters, ...numbers];
254
-
255
- var result = "";
256
- for (var i = 0; i < length; i++) {
257
- result += choice(i == 0 ? characters : combined);
258
- }
259
- return result;
260
-
261
- case "hexadecimal":
262
- const genRanHex = (size) =>
263
- [...Array(size)]
264
- .map(() => Math.floor(Math.random() * 16).toString(16))
265
- .join("");
266
-
267
- return "_0x" + genRanHex(length).toUpperCase();
268
-
269
- case "mangled":
270
- while (1) {
271
- var result = alphabeticalGenerator(count);
272
- count++;
273
-
274
- if (
275
- reservedKeywords.has(result) ||
276
- reservedIdentifiers.has(result)
277
- ) {
278
- } else {
279
- return result;
280
- }
281
- }
282
-
283
- throw new Error("impossible but TypeScript insists");
284
-
285
- case "number":
286
- return "var_" + count;
287
-
288
- case "zeroWidth":
289
- var keyWords = [
290
- "if",
291
- "in",
292
- "for",
293
- "let",
294
- "new",
295
- "try",
296
- "var",
297
- "case",
298
- "else",
299
- "null",
300
- "break",
301
- "catch",
302
- "class",
303
- "const",
304
- "super",
305
- "throw",
306
- "while",
307
- "yield",
308
- "delete",
309
- "export",
310
- "import",
311
- "public",
312
- "return",
313
- "switch",
314
- "default",
315
- "finally",
316
- "private",
317
- "continue",
318
- "debugger",
319
- "function",
320
- "arguments",
321
- "protected",
322
- "instanceof",
323
- "function",
324
- "await",
325
- "async",
326
- ];
327
-
328
- var safe = "\u200C".repeat(count + 1);
329
-
330
- var base = choice(keyWords) + safe;
331
- return base;
332
- }
333
-
334
- throw new Error("Invalid 'identifierGenerator' mode: " + mode);
335
- }
336
- );
337
- } while (set.has(identifier));
338
-
339
- if (!identifier) {
340
- throw new Error("identifier null");
341
- }
342
-
343
- set.add(identifier);
344
-
345
- return identifier;
346
- }
347
-
348
- createInitVariable = (value: ITemplate, parents: Node[]) => {
349
- var key = value.templates[0];
350
- if (this.initVariables.has(key)) {
351
- return this.initVariables.get(key);
352
- }
353
-
354
- var root = parents[parents.length - 1];
355
- ok(root.type === "Program");
356
-
357
- var name = this.getPlaceholder();
358
- this.initVariables.set(key, name);
359
-
360
- prepend(
361
- root,
362
- VariableDeclaration(VariableDeclarator(name, value.single().expression))
363
- );
364
-
365
- return name;
366
- };
367
-
368
- /**
369
- * Smartly appends a comment to a Node.
370
- * - Includes the transformation's name.
371
- * @param node
372
- * @param text
373
- * @param i
374
- */
375
- addComment(node: Node, text: string) {
376
- if (this.options.debugComments) {
377
- return AddComment(node, `[${this.className}] ${text}`);
378
- }
379
- return node;
380
- }
381
-
382
- replace(node1: Node, node2: Node) {
383
- for (var key in node1) {
384
- delete node1[key];
385
- }
386
-
387
- this.objectAssign(node1, node2);
388
- }
389
-
390
- replaceIdentifierOrLiteral(node1: Node, node2: Node, parents: Node[]) {
391
- // Fix 2. Make parent property key computed
392
- if (
393
- parents[0] &&
394
- (parents[0].type == "Property" ||
395
- parents[0].type == "MethodDefinition") &&
396
- parents[0].key == node1
397
- ) {
398
- parents[0].computed = true;
399
- parents[0].shorthand = false;
400
- }
401
- this.replace(node1, node2);
402
- }
403
-
404
- /**
405
- * Smartly merges two Nodes.
406
- * - Null checking
407
- * - Preserves comments
408
- * @param node1
409
- * @param node2
410
- */
411
- objectAssign(node1: Node, node2: Node): Node {
412
- ok(node1);
413
- ok(node2);
414
-
415
- var comments1 = node1.leadingComments || [];
416
- var comments2 = node2.leadingComments || [];
417
- var comments = [...comments1, ...comments2];
418
-
419
- node2.leadingComments = comments;
420
-
421
- node1._transform = node2._transform = this.className;
422
-
423
- return Object.assign(node1, node2);
424
- }
425
-
426
- /**
427
- * Verbose logging for this transformation.
428
- * @param messages
429
- */
430
- log(...messages: any[]) {
431
- if (this.options.verbose) {
432
- console.log("[" + this.className + "]", ...messages);
433
- }
434
- }
435
-
436
- /**
437
- * Verbose logging for warning/important messages.
438
- * @param messages
439
- */
440
- warn(...messages: any[]) {
441
- if (this.options.verbose) {
442
- console.log("[ WARN " + this.className + " ]", ...messages);
443
- }
444
- }
445
-
446
- /**
447
- * Throws an error. Appends the transformation's name to the error's message.
448
- * @param error
449
- */
450
- error(error: Error): never {
451
- throw new Error(`${this.className} Error: ${error.message}`);
452
- }
453
- }
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,131 +0,0 @@
1
- import Obfuscator from "./obfuscator";
2
- import { ObfuscateOptions } from "./options";
3
- import Transform from "./transforms/transform";
4
-
5
- /**
6
- * **JsConfuser**: Obfuscates JavaScript.
7
- * @param code - The code to be obfuscated.
8
- * @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
9
- *
10
- * [See all settings here](https://github.com/MichaelXF/js-confuser#options)
11
- */
12
- export interface IJsConfuser {
13
- obfuscate: IJsConfuserObfuscate;
14
- obfuscateAST: IJsConfuserObfuscateAST;
15
-
16
- presets: IJsConfuserPresets;
17
- debugTransformations: IJsConfuserDebugTransformations;
18
- debugObfuscation: IJsConfuserDebugObfuscation;
19
-
20
- (code: string, options: ObfuscateOptions): Promise<string>;
21
-
22
- Transform: typeof Transform;
23
- Obfuscator: typeof Obfuscator;
24
- }
25
-
26
- /**
27
- * **JsConfuser**: Obfuscates JavaScript.
28
- * @param code - The code to be obfuscated.
29
- * @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
30
- *
31
- * [See all settings here](https://github.com/MichaelXF/js-confuser#options)
32
- */
33
- export interface IJsConfuserObfuscate {
34
- (code: string, options: ObfuscateOptions): Promise<string>;
35
- }
36
-
37
- /**
38
- * Obfuscates an [ESTree](https://github.com/estree/estree) compliant AST.
39
- *
40
- * **Note:** Mutates the object.
41
- *
42
- * @param AST - The [ESTree](https://github.com/estree/estree) compliant AST. This object will be mutated.
43
- * @param options - The obfuscation options.
44
- *
45
- * [See all settings here](https://github.com/MichaelXF/js-confuser#options)
46
- */
47
- export interface IJsConfuserObfuscateAST {
48
- (AST: any, options: ObfuscateOptions): Promise<void>;
49
- }
50
-
51
- export interface IJsConfuserPresets {
52
- high: ObfuscateOptions;
53
- medium: ObfuscateOptions;
54
- low: ObfuscateOptions;
55
- }
56
-
57
- /**
58
- * Obfuscates code but returns an array of `frames`
59
- *
60
- * ```js
61
- * [
62
- * {
63
- * name: "Preparation",
64
- * code: "console['log']('Hello World')",
65
- * ms: 4
66
- * }, {
67
- * name: "ControlFlowFlattening",
68
- * code: "var....",
69
- * ms: 400
70
- * },
71
- * // ....
72
- * ]
73
- * ```
74
- */
75
- export type IJsConfuserDebugTransformations = (
76
- code: string,
77
- options: ObfuscateOptions
78
- ) => Promise<{ name: string; code: string; ms: number }[]>;
79
-
80
- /**
81
- * Obfuscates code but calls the callback function after each transform.
82
- *
83
- * This is used to display a progress bar to the user on the official website.
84
- *
85
- * `callback(name: string, complete: number, totalTransforms: number)`
86
- *
87
- * ```js
88
- * var callback = (name, complete, totalTransforms) => {
89
- * console.log(name, complete, totalTransforms)
90
- * };
91
- * ```
92
- *
93
- * ```js
94
- * // Preparation 1 22
95
- * // ObjectExtraction 2 22
96
- * // Flatten 3 22
97
- * // Dispatcher 4 22
98
- * // DeadCode 5 22
99
- * // Calculator 6 22
100
- * // ControlFlowFlattening 7 22
101
- * // GlobalConcealing 8 22
102
- * // OpaquePredicates 9 22
103
- * // StringSplitting 10 22
104
- * // StringConcealing 11 22
105
- * // StringCompression 12 22
106
- * // HideInitializingCode 13 22
107
- * // Stack 14 22
108
- * // DuplicateLiteralsRemoval 15 22
109
- * // Shuffle 16 22
110
- * // MovedDeclarations 17 22
111
- * // RenameVariables 18 22
112
- * // RenameLabels 19 22
113
- * // Minify 20 22
114
- * // StringEncoding 21 22
115
- * // AntiTooling 22 22
116
- * ```
117
- */
118
- export type IJsConfuserDebugObfuscation = (
119
- code: string,
120
- options: ObfuscateOptions,
121
- callback: (name: string, complete: number, totalTransforms: number) => void,
122
- performance: Performance
123
- ) => Promise<{
124
- obfuscated: string;
125
- transformationTimes: { [transformName: string]: number };
126
- parseTime: number;
127
- compileTime: number;
128
- obfuscationTime: number;
129
- totalTransforms: number;
130
- totalPossibleTransforms: number;
131
- }>;