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
package/src/constants.ts CHANGED
@@ -1,72 +1,86 @@
1
+ import ControlObject from "./utils/ControlObject";
2
+
3
+ export const predictableFunctionTag = "__JS_PREDICT__";
4
+
1
5
  /**
2
- * Keywords disallowed for variable names in ES5 and under.
6
+ * A function is 'unsafe' if it requires 'eval', 'arguments' or 'this'
7
+ *
8
+ * Transformations will generally not touch unsafe functions.
3
9
  */
4
- export const reservedKeywords = new Set([
5
- "abstract",
6
- "arguments",
7
- "await",
8
- "boolean",
9
- "break",
10
- "byte",
11
- "case",
12
- "catch",
13
- "char",
14
- "class",
15
- "const",
16
- "continue",
17
- "debugger",
18
- "default",
19
- "delete",
20
- "do",
21
- "double",
22
- "else",
23
- "enum",
24
- "eval",
25
- "export",
26
- "extends",
27
- "false",
28
- "final",
29
- "finally",
30
- "float",
31
- "for",
32
- "function",
33
- "goto",
34
- "if",
35
- "implements",
36
- "import",
37
- "in",
38
- "instanceof",
39
- "int",
40
- "interface",
41
- "let",
42
- "long",
43
- "native",
44
- "new",
45
- "null",
46
- "package",
47
- "private",
48
- "protected",
49
- "public",
50
- "return",
51
- "short",
52
- "static",
53
- "super",
54
- "switch",
55
- "synchronized",
56
- "this",
57
- "throw",
58
- "throws",
59
- "transient",
60
- "true",
61
- "try",
62
- "typeof",
63
- "var",
64
- "void",
65
- "volatile",
66
- "while",
67
- "with",
68
- "yield",
69
- ]);
10
+ export const UNSAFE = Symbol("unsafe");
11
+
12
+ /**
13
+ * A function is 'predictable' if the invoking parameter lengths are guaranteed to be known.
14
+ *
15
+ * ```js
16
+ * a(1,2,3) // predictable
17
+ * a(...[1,2,3]) // unpredictable
18
+ * ```
19
+ */
20
+ export const PREDICTABLE = Symbol("predictable");
21
+
22
+ /**
23
+ * A node is marked as 'skip' if it should not be transformed.
24
+ *
25
+ * Preserved throughout transformations, so be careful with this.
26
+ */
27
+ export const SKIP = Symbol("skip");
28
+
29
+ /**
30
+ * Saves the original length of a function.
31
+ */
32
+ export const FN_LENGTH = Symbol("fnLength");
33
+
34
+ export const CONTROL_OBJECTS = Symbol("controlObjects");
35
+
36
+ export const NO_RENAME = Symbol("noRename");
37
+
38
+ /**
39
+ * This Identifier is used for a hexadecimal number or escaped string.
40
+ */
41
+ export const GEN_NODE = Symbol("genNode");
42
+
43
+ /**
44
+ * This function is used to mark functions that when transformed will most likely cause a maximum call stack error.
45
+ *
46
+ * Examples: Native Function Check
47
+ */
48
+ export const MULTI_TRANSFORM = Symbol("multiTransform");
49
+
50
+ /**
51
+ * The function contains a `with` statement.
52
+ *
53
+ * OR
54
+ *
55
+ * This identifier is used for a `with` statement.
56
+ *
57
+ * Tells Pack not to globally transform the node.
58
+ */
59
+ export const WITH_STATEMENT = Symbol("withStatement");
60
+
61
+ /**
62
+ * Symbols describe precomputed semantics of a node, allowing the obfuscator to make the best choices for the node.
63
+ */
64
+ export interface NodeSymbol {
65
+ [UNSAFE]?: boolean;
66
+ [PREDICTABLE]?: boolean;
67
+ [SKIP]?: boolean | number;
68
+ [FN_LENGTH]?: number;
69
+ [CONTROL_OBJECTS]?: ControlObject[];
70
+ [NO_RENAME]?: string | number;
71
+
72
+ [GEN_NODE]?: boolean;
73
+ [MULTI_TRANSFORM]?: boolean;
74
+ [WITH_STATEMENT]?: boolean;
75
+ }
76
+
77
+ /**
78
+ * Allows the user to grab the variable name of a renamed variable.
79
+ */
80
+ export const variableFunctionName = "__JS_CONFUSER_VAR__";
81
+
82
+ export const noRenameVariablePrefix = "__NO_JS_CONFUSER_RENAME__";
83
+ export const placeholderVariablePrefix = "__p_";
70
84
 
71
85
  /**
72
86
  * Identifiers that are not actually variables.
@@ -80,17 +94,65 @@ export const reservedIdentifiers = new Set([
80
94
  "arguments",
81
95
  ]);
82
96
 
83
- export const noRenameVariablePrefix = "__NO_JS_CONFUSER_RENAME__";
84
- export const placeholderVariablePrefix = "__p_";
97
+ export const reservedObjectPrototype = new Set([
98
+ "toString",
99
+ "valueOf",
100
+ "constructor",
101
+ "__proto__",
102
+ "hasOwnProperty",
103
+ "isPrototypeOf",
104
+ "propertyIsEnumerable",
105
+ "toLocaleString",
106
+ ]);
85
107
 
86
108
  /**
87
- * Tells the obfuscator this function is predictable:
88
- * - Never called with extraneous parameters
109
+ * For Zero Width generator - Mangled variable names
89
110
  */
90
- export const predictableFunctionTag = "__JS_PREDICT__";
111
+ export const reservedKeywords = [
112
+ "if",
113
+ "in",
114
+ "for",
115
+ "let",
116
+ "new",
117
+ "try",
118
+ "var",
119
+ "case",
120
+ "else",
121
+ "null",
122
+ "break",
123
+ "catch",
124
+ "class",
125
+ "const",
126
+ "super",
127
+ "throw",
128
+ "while",
129
+ "yield",
130
+ "delete",
131
+ "export",
132
+ "import",
133
+ "public",
134
+ "return",
135
+ "switch",
136
+ "default",
137
+ "finally",
138
+ "private",
139
+ "continue",
140
+ "debugger",
141
+ "function",
142
+ "arguments",
143
+ "protected",
144
+ "instanceof",
145
+ "await",
146
+ "async",
91
147
 
92
- /**
93
- * Tells the obfuscator this function is critical for the Obfuscated code.
94
- * - Example: string decryption function
95
- */
96
- export const criticalFunctionTag = "__JS_CRITICAL__";
148
+ // new key words and other fun stuff :P
149
+ "NaN",
150
+ "undefined",
151
+ "true",
152
+ "false",
153
+ "typeof",
154
+ "this",
155
+ "static",
156
+ "void",
157
+ "of",
158
+ ];
package/src/index.ts CHANGED
@@ -1,196 +1,103 @@
1
- import compileJs, { compileJsSync } from "./compiler";
2
- import parseJS, { parseSync } from "./parser";
1
+ import * as babelTypes from "@babel/types";
3
2
  import Obfuscator from "./obfuscator";
4
- import Transform from "./transforms/transform";
5
- import { remove$Properties } from "./util/object";
6
- import presets from "./presets";
7
-
8
- import * as assert from "assert";
9
- import { correctOptions, ObfuscateOptions, validateOptions } from "./options";
3
+ import { ObfuscateOptions } from "./options";
10
4
  import {
11
- IJsConfuser,
12
- IJsConfuserDebugObfuscation,
13
- IJsConfuserDebugTransformations,
14
- } from "./types";
15
-
16
- /**
17
- * **JsConfuser**: Obfuscates JavaScript.
18
- * @param code - The code to be obfuscated.
19
- * @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
20
- */
21
- export async function obfuscate(code: string, options: ObfuscateOptions) {
22
- return await JsConfuser(code, options);
23
- }
24
-
25
- /**
26
- * Obfuscates an [ESTree](https://github.com/estree/estree) compliant AST.
27
- *
28
- * **Note:** Mutates the object.
29
- *
30
- * @param AST - The [ESTree](https://github.com/estree/estree) compliant AST. This object will be mutated.
31
- * @param options - The obfuscation options.
32
- *
33
- * [See all settings here](https://github.com/MichaelXF/js-confuser#options)
34
- */
35
- export async function obfuscateAST(AST, options: ObfuscateOptions) {
36
- assert.ok(typeof AST === "object", "AST must be type object");
37
- assert.ok(AST.type == "Program", "AST.type must be equal to 'Program'");
38
- validateOptions(options);
39
-
40
- options = await correctOptions(options);
41
-
42
- var obfuscator = new Obfuscator(options);
43
-
44
- await obfuscator.apply(AST);
5
+ ObfuscationResult,
6
+ ProfileData,
7
+ ProfilerCallback,
8
+ ProfilerLog,
9
+ } from "./obfuscationResult";
10
+ import presets from "./presets";
11
+ import Template from "./templates/template";
45
12
 
46
- options.verbose && console.log("* Removing $ properties");
13
+ export async function obfuscate(
14
+ sourceCode: string,
15
+ options: ObfuscateOptions
16
+ ): Promise<ObfuscationResult> {
17
+ const obfuscator = new Obfuscator(options);
47
18
 
48
- remove$Properties(AST);
19
+ return obfuscator.obfuscate(sourceCode);
49
20
  }
50
21
 
51
- /**
52
- * **JsConfuser**: Obfuscates JavaScript.
53
- * @param code - The code to be obfuscated.
54
- * @param options - An object of obfuscation options: `{preset: "medium", target: "browser"}`.
55
- */
56
- var JsConfuser: IJsConfuser = async function (
57
- code: string,
22
+ export async function obfuscateAST(
23
+ ast: babelTypes.File,
58
24
  options: ObfuscateOptions
59
- ): Promise<string> {
60
- if (typeof code !== "string") {
61
- throw new TypeError("code must be type string");
62
- }
63
- validateOptions(options);
64
-
65
- options = await correctOptions(options);
66
-
67
- options.verbose && console.log("* Parsing source code");
68
-
69
- var tree = await parseJS(code);
70
-
71
- options.verbose && console.log("* Obfuscating...");
72
-
73
- var obfuscator = new Obfuscator(options);
74
-
75
- await obfuscator.apply(tree);
76
-
77
- options.verbose && console.log("* Removing $ properties");
78
-
79
- remove$Properties(tree);
80
-
81
- options.verbose && console.log("* Generating code");
82
-
83
- var result = await compileJs(tree, options);
84
-
85
- return result;
86
- } as any;
87
-
88
- export const debugTransformations: IJsConfuserDebugTransformations =
89
- async function (
90
- code: string,
91
- options: ObfuscateOptions
92
- ): Promise<{ name: string; code: string; ms: number }[]> {
93
- validateOptions(options);
94
- options = await correctOptions(options);
95
-
96
- var frames = [];
97
-
98
- var tree = parseSync(code);
99
- var obfuscator = new Obfuscator(options);
100
-
101
- var time = Date.now();
102
-
103
- obfuscator.on("debug", (name: string, tree: Node) => {
104
- frames.push({
105
- name: name,
106
- code: compileJsSync(tree, options),
107
- ms: Date.now() - time,
108
- });
109
-
110
- time = Date.now();
111
- });
112
-
113
- await obfuscator.apply(tree, true);
25
+ ) {
26
+ const obfuscator = new Obfuscator(options);
114
27
 
115
- return frames;
116
- };
28
+ return obfuscator.obfuscateAST(ast);
29
+ }
117
30
 
118
- /**
119
- * This method is used by the obfuscator website to display a progress bar and additional information
120
- * about the obfuscation.
121
- *
122
- * @param code - Source code to obfuscate
123
- * @param options - Options
124
- * @param callback - Progress callback, called after each transformation
125
- * @returns
126
- */
127
- export const debugObfuscation: IJsConfuserDebugObfuscation = async function (
128
- code: string,
31
+ export async function obfuscateWithProfiler(
32
+ sourceCode: string,
129
33
  options: ObfuscateOptions,
130
- callback: (name: string, complete: number, totalTransforms: number) => void,
131
- performance: Performance
132
- ) {
34
+ profiler: {
35
+ callback: ProfilerCallback;
36
+ performance: { now(): number };
37
+ }
38
+ ): Promise<ObfuscationResult & { profileData: ProfileData }> {
133
39
  const startTime = performance.now();
134
40
 
135
- validateOptions(options);
136
- options = await correctOptions(options);
41
+ const obfuscator = new Obfuscator(options);
42
+ let totalTransforms = obfuscator.plugins.length;
43
+
44
+ let transformMap: ProfileData["transforms"] = Object.create(null);
137
45
 
138
46
  const beforeParseTime = performance.now();
139
47
 
140
- var tree = parseSync(code);
48
+ let ast = Obfuscator.parseCode(sourceCode);
141
49
 
142
50
  const parseTime = performance.now() - beforeParseTime;
143
51
 
144
- var obfuscator = new Obfuscator(options);
145
- var totalTransforms = obfuscator.array.length;
146
-
147
- var transformationTimes = Object.create(null);
148
- var currentTransformTime = performance.now();
149
-
150
- obfuscator.on("debug", (name: string, tree: Node, i: number) => {
151
- var nowTime = performance.now();
152
- transformationTimes[name] = nowTime - currentTransformTime;
153
- currentTransformTime = nowTime;
154
-
155
- callback(name, i, totalTransforms);
52
+ let currentTransformTime = performance.now();
53
+
54
+ ast = obfuscator.obfuscateAST(ast, {
55
+ profiler: (log: ProfilerLog) => {
56
+ var nowTime = performance.now();
57
+ transformMap[log.currentTransform] = {
58
+ transformTime: nowTime - currentTransformTime,
59
+ changeData: {},
60
+ };
61
+ currentTransformTime = nowTime;
62
+ profiler.callback(log);
63
+ },
156
64
  });
157
65
 
158
- await obfuscator.apply(tree, true);
66
+ obfuscator.plugins.forEach(({ pluginInstance }) => {
67
+ if (transformMap[pluginInstance.name]) {
68
+ transformMap[pluginInstance.name].changeData = pluginInstance.changeData;
69
+ }
70
+ });
159
71
 
160
72
  const beforeCompileTime = performance.now();
161
73
 
162
- var output = await compileJs(tree, options);
74
+ const code = Obfuscator.generateCode(ast, obfuscator.options);
163
75
 
164
76
  const compileTime = performance.now() - beforeCompileTime;
165
77
 
166
78
  const endTime = performance.now();
167
79
 
80
+ const obfuscationTime = endTime - startTime;
81
+
168
82
  return {
169
- obfuscated: output,
170
- transformationTimes: transformationTimes,
171
- obfuscationTime: endTime - startTime,
172
- parseTime: parseTime,
173
- compileTime: compileTime,
174
- totalTransforms: totalTransforms,
175
- totalPossibleTransforms: obfuscator.totalPossibleTransforms,
83
+ code: code,
84
+ profileData: {
85
+ transforms: transformMap,
86
+ obfuscationTime: obfuscationTime,
87
+ parseTime: parseTime,
88
+ compileTime: compileTime,
89
+ totalTransforms: totalTransforms,
90
+ totalPossibleTransforms: obfuscator.totalPossibleTransforms,
91
+ },
176
92
  };
177
- };
178
-
179
- JsConfuser.obfuscate = obfuscate;
180
- JsConfuser.obfuscateAST = obfuscateAST;
181
- JsConfuser.presets = presets;
182
- JsConfuser.debugTransformations = debugTransformations;
183
- JsConfuser.debugObfuscation = debugObfuscation;
184
- JsConfuser.Obfuscator = Obfuscator;
185
- JsConfuser.Transform = Transform;
186
-
187
- if (typeof window !== "undefined") {
188
- window["JsConfuser"] = JsConfuser;
189
- }
190
- if (typeof global !== "undefined") {
191
- global["JsConfuser"] = JsConfuser;
192
93
  }
193
94
 
194
- export default JsConfuser;
95
+ const JsConfuser = {
96
+ obfuscate,
97
+ obfuscateAST,
98
+ obfuscateWithProfiler,
99
+ presets,
100
+ Template,
101
+ };
195
102
 
196
- export { presets, Obfuscator, Transform };
103
+ export default JsConfuser;
@@ -0,0 +1,43 @@
1
+ import { PluginInstance } from "./transforms/plugin";
2
+
3
+ /**
4
+ * Obfuscation result object.
5
+ */
6
+ export interface ObfuscationResult {
7
+ /**
8
+ * Obfuscated code.
9
+ */
10
+ code: string;
11
+ }
12
+
13
+ /**
14
+ * Profile report for the obfuscation process.
15
+ */
16
+ export interface ProfileData {
17
+ obfuscationTime: number;
18
+ compileTime: number;
19
+ parseTime: number;
20
+ totalPossibleTransforms: number;
21
+ totalTransforms: number;
22
+ transforms: {
23
+ [transformName: string]: {
24
+ transformTime: number;
25
+ changeData: PluginInstance["changeData"];
26
+ };
27
+ };
28
+ }
29
+
30
+ /**
31
+ * A callback function that is called when a transform is applied.
32
+ */
33
+ export type ProfilerCallback = (log: ProfilerLog) => void;
34
+
35
+ /**
36
+ * The current progress of the obfuscation process.
37
+ */
38
+ export interface ProfilerLog {
39
+ index: number;
40
+ currentTransform: string;
41
+ nextTransform: string;
42
+ totalTransforms: number;
43
+ }