js-confuser 1.6.0 → 1.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +23 -0
- package/README.md +215 -170
- package/dist/constants.js +6 -2
- package/dist/obfuscator.js +0 -6
- package/dist/options.js +4 -4
- package/dist/presets.js +6 -7
- package/dist/templates/crash.js +2 -2
- package/dist/templates/functionLength.js +16 -0
- package/dist/transforms/dispatcher.js +4 -1
- package/dist/transforms/extraction/duplicateLiteralsRemoval.js +89 -58
- package/dist/transforms/flatten.js +224 -147
- package/dist/transforms/identifier/movedDeclarations.js +38 -85
- package/dist/transforms/identifier/renameVariables.js +94 -41
- package/dist/transforms/lock/lock.js +0 -37
- package/dist/transforms/minify.js +2 -2
- package/dist/transforms/rgf.js +139 -246
- package/dist/transforms/stack.js +42 -1
- package/dist/transforms/transform.js +1 -1
- package/dist/util/gen.js +2 -1
- package/dist/util/identifiers.js +37 -3
- package/dist/util/insert.js +24 -3
- package/docs/ControlFlowFlattening.md +595 -0
- package/{Countermeasures.md → docs/Countermeasures.md} +1 -15
- package/{Integrity.md → docs/Integrity.md} +2 -2
- package/docs/RGF.md +419 -0
- package/package.json +1 -1
- package/src/constants.ts +3 -0
- package/src/obfuscator.ts +0 -4
- package/src/options.ts +9 -86
- package/src/presets.ts +6 -7
- package/src/templates/crash.ts +10 -10
- package/src/templates/functionLength.ts +14 -0
- package/src/transforms/dispatcher.ts +5 -1
- package/src/transforms/extraction/duplicateLiteralsRemoval.ts +130 -129
- package/src/transforms/flatten.ts +357 -290
- package/src/transforms/identifier/movedDeclarations.ts +50 -96
- package/src/transforms/identifier/renameVariables.ts +120 -56
- package/src/transforms/lock/lock.ts +1 -42
- package/src/transforms/minify.ts +11 -2
- package/src/transforms/rgf.ts +214 -404
- package/src/transforms/stack.ts +62 -0
- package/src/transforms/transform.ts +6 -2
- package/src/util/gen.ts +7 -2
- package/src/util/identifiers.ts +43 -2
- package/src/util/insert.ts +26 -2
- package/test/code/ES6.src.js +24 -0
- package/test/transforms/flatten.test.ts +352 -88
- package/test/transforms/identifier/movedDeclarations.test.ts +37 -9
- package/test/transforms/identifier/renameVariables.test.ts +37 -0
- package/test/transforms/lock/lock.test.ts +1 -48
- package/test/transforms/minify.test.ts +19 -0
- package/test/transforms/rgf.test.ts +262 -353
- package/test/transforms/stack.test.ts +52 -0
- package/test/util/identifiers.test.ts +113 -1
- package/test/util/insert.test.ts +57 -3
- package/src/transforms/eval.ts +0 -89
- package/src/transforms/identifier/nameRecycling.ts +0 -280
- package/test/transforms/eval.test.ts +0 -131
- package/test/transforms/identifier/nameRecycling.test.ts +0 -205
package/docs/RGF.md
ADDED
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
## `RGF`
|
|
2
|
+
|
|
3
|
+
RGF (Runtime-Generated-Functions) uses the [`new Function(code...)`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/Function) syntax to construct executable code from strings. (`true/false/0-1`)
|
|
4
|
+
|
|
5
|
+
- **This can break your code.**
|
|
6
|
+
- **Due to the security concerns of arbitrary code execution, you must enable this yourself.**
|
|
7
|
+
- The arbitrary code is also obfuscated.
|
|
8
|
+
|
|
9
|
+
Option name: `rgf`
|
|
10
|
+
|
|
11
|
+
Option values: `true/false/0-1`
|
|
12
|
+
|
|
13
|
+
Note: RGF will only apply to functions that do not rely on any outside-scoped variables. Enable `flatten` along with `rgf` to apply to these functions.
|
|
14
|
+
|
|
15
|
+
Note: Does not apply to arrow, async, or generator functions.
|
|
16
|
+
|
|
17
|
+
Use a number to control the percentage of functions changed.
|
|
18
|
+
|
|
19
|
+
```js
|
|
20
|
+
// Input
|
|
21
|
+
function printToConsole(message){
|
|
22
|
+
console.log(message);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
printToConsole("Hello World"); // "Hello World"
|
|
26
|
+
|
|
27
|
+
// Output
|
|
28
|
+
var Ricvq8s = [new Function('function HIGRHaD(ANVivo_){console[\'log\'](ANVivo_)}return HIGRHaD[\'apply\'](this,arguments)')];
|
|
29
|
+
function uhj6obs() {
|
|
30
|
+
return Ricvq8s[0]['apply'](this, arguments);
|
|
31
|
+
}
|
|
32
|
+
uhj6obs('Hello World'); // "Hello World"
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
## With `Flatten`
|
|
36
|
+
|
|
37
|
+
Enable `flatten` with `rgf` to apply to functions that rely on outside-scoped variables.
|
|
38
|
+
|
|
39
|
+
Flatten is able to isolate functions from their scope so then RGF can then apply on them.
|
|
40
|
+
|
|
41
|
+
```js
|
|
42
|
+
{
|
|
43
|
+
target: "node",
|
|
44
|
+
rgf: true,
|
|
45
|
+
flatten: true
|
|
46
|
+
}
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
```js
|
|
50
|
+
// Input
|
|
51
|
+
var outsideVariable = 0;
|
|
52
|
+
function incrementOutsideVariable(){
|
|
53
|
+
outsideVariable++;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
incrementOutsideVariable(); // outsideVariable = 1
|
|
57
|
+
incrementOutsideVariable(); // outsideVariable = 2
|
|
58
|
+
incrementOutsideVariable(); // outsideVariable = 3
|
|
59
|
+
|
|
60
|
+
console.log(outsideVariable); // 3
|
|
61
|
+
|
|
62
|
+
// Output
|
|
63
|
+
var J3NLZFR = [
|
|
64
|
+
new Function(
|
|
65
|
+
"function Q7Rh6l([],reFzsi){reFzsi['XaBIEIZ']++}return Q7Rh6l['apply'](this,arguments)"
|
|
66
|
+
),
|
|
67
|
+
];
|
|
68
|
+
function pCG9mH() {
|
|
69
|
+
return J3NLZFR[0]["apply"](this, arguments);
|
|
70
|
+
}
|
|
71
|
+
var outsideVariable = 0;
|
|
72
|
+
function incrementOutsideVariable(...muLxIC) {
|
|
73
|
+
var udg38ch = {
|
|
74
|
+
set ["XaBIEIZ"](H5p1op) {
|
|
75
|
+
outsideVariable = H5p1op;
|
|
76
|
+
},
|
|
77
|
+
get ["XaBIEIZ"]() {
|
|
78
|
+
return outsideVariable;
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
return pCG9mH(muLxIC, udg38ch);
|
|
82
|
+
}
|
|
83
|
+
!(incrementOutsideVariable(),
|
|
84
|
+
incrementOutsideVariable(),
|
|
85
|
+
incrementOutsideVariable(),
|
|
86
|
+
console["log"](outsideVariable)); // 3
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
## With `String Concealing`
|
|
90
|
+
|
|
91
|
+
Enable `stringConcealing` to encrypt the `new Function(code)` code string.
|
|
92
|
+
|
|
93
|
+
```js
|
|
94
|
+
// Input
|
|
95
|
+
function add(x, y){
|
|
96
|
+
return x + y;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
console.log(add(5, 10)); // 15
|
|
100
|
+
|
|
101
|
+
// Output
|
|
102
|
+
var MAKh7o = [],
|
|
103
|
+
BCG3CXC = 0,
|
|
104
|
+
W33d4e = (function () {
|
|
105
|
+
var To7ztdg = [
|
|
106
|
+
"n%v2do>o/Ro<B",
|
|
107
|
+
"ad/z~7_MP#]yCZ(ZlG2Hr@3B3UuHQbXj~7$GZ7w@h#g<J9G",
|
|
108
|
+
']+=c$.zNPP+/G9BY1G$x3_M+]8EU"[XpkwUdV^QC!Pk.XbK',
|
|
109
|
+
"Hd8=l@<:%59/L]J",
|
|
110
|
+
"u)jdloP1|6k.*Z}iV5UHt#[z<IW31wwn{nnEkj5vyJ",
|
|
111
|
+
"@4P0goQYcRNlUD",
|
|
112
|
+
'"!>fj>~p!It3M^hX',
|
|
113
|
+
".t)F;!&u)J?+gEFe4zAz;3A",
|
|
114
|
+
":!><}7qC*2i.2xI",
|
|
115
|
+
"&2rd(iQYsRJ2ID",
|
|
116
|
+
'H)?/f2lvs4KinCkR]Db.znuuY%"uk,Uorf`yo2:M97n',
|
|
117
|
+
'KEFK73EeT2m/77Hg,i&Fu#qePMp{Lv(mUzf0v+Jj6U<xhQQn%XM,d^jN%yh*ZFAe>]w;Uvz`Y3G.Z*ClC:?<HwU6g&?E(u+NFEgbL^YI]GJ3nv$Y:"29ZXRipw(wD7=!xS!lPaRi{Z{^EqU2#@lZ3dJuX2@y4@AV{PWlCMszhDm#]eh5G)*[|ja2D:rZ%#L0BJ(u+N"i`Km]2MyTQUO[8Lx7<fY<L|%Te.{+;T@z/z!=86D8fO+*FYg%(:Ef5?L7Y{LntO|LE:?,V[GUY?sQWq>iPeI!Y{DJU3$@Qcf<Kz`m/#F(g!jmFTG&ywX,Zj0T1c>[vP0/oxJk>oCPL?G*aWmUk,(y0CG62t6[)gaz^I3]Z[$yVRra,S7!Hc!i6CAP4m&BRn_URI{c]GlN07361pmfja!i6CAPo{CN/US8U==[${lT,r|]7j}UD=U*7*K0T^4b$q"z^I3]Z[$yp!kbWi|?p>P:_Y2$E`~.8jcB9c!=!Yy#c%x@Moi5e39=TXi#c.~MLOD]Wf=[RvK0U6myWoa=zg>[;NmTd/<P1o:JzI{*bv.!T^a9_o_zU=W}[;FWGvCFph(UE=U*7*|N47Tm_o@|[;c,`pE$nwaxTOU?p>W}FjMR6t{]8d5)VKU,0{8!@+q[wh[i/2s)+{ZR50ixOg#4]I^[5ds!Wz|a?N~<[go@J`+9M6>x=Tgzzgh`(`+9p!kbWijr71d,!YI9)dN.`onDF3w)Eqj9Z<,alLX}ecF.ieL%`r|]Km=GzI>3m6<!!/,]XXPSufp@A:nKGvCFpht2V3O:/p/3LsyxQn[DE=M*qerR4msj]o0aU=$bz*[&2/ZQ;mI=[go@J`+9!+ZQ!q@|[;V<#NLR#V;a8jg5y;:t*NN!v3Jx+rgzzgh`FjMR6tOyCknDF3w)PZ1$2/a9{j9o(IP:T[K0T^pQUo44!H{*+G+K70WFph>DF3w)9v6IE?zj0p$z>vM{bTs7a6q[whQ5zg7=O$^G[+O9$XrM^Ia>H[r%Apry0ht2V3O:/pH981.^rmWX01nv{Y<!ApL+YiXBCdmvb*7Lj{Y8?UdP(gt@mC}!f%ixHl3oG,b>"M#1b6_.YiXB)H%n!6#1l!#bof)%vE5pUIKU&::ZmlaXYeg9<{a!A.,]CmtoIJq/A:nK$#TO<a>cy;F<"@QS]4"50Vs<t<r@6iMR6t(7?nZJ):Er{!`6r*Kl_ci?:=):%p$Mr^zj8pt,[;RkS:f8$V0PuoSrlf*1&M(2%8=lAl5Xk3@!rpEJ8_`N7R_Z;K6_A@%#?rT+nlR}A>[h@eG$909MBke!>fF(tTrIM{$YASl<+H%n!6#1d{Z*nlR}A>[h%R814_O+9rOr"z&im$|6r*Kl_cyfba~aGSC(o!e9jLDSzw?:g{"%.(]68R[+M,U!7viTu*o8NOndi;{^LB&z:::uQVQz^Kb9<{a!A.,]4jAj_y]m<!iQP<tNOVy!n>b>"M#13m)7?nZJ):jeI:(GD.*9KmePgZC.Z`+92/ZQ;mI=qwp@1;>4WzpENnxo)=u%.!yPn?fbiR5]xw?:g{"%.(o@sOn?dEh|Yo1$Xw_jOg`O}JevRp30CpS*ASU?.bbj(ve8$V0PuoSrlf*1&M(2%83,DT@ZaFNmKq1$Xw_jOg`O}JevRp30CpS*ASoPE=f,eIFHX?"*ml)|kyBkh`:!tRqZpTF]AbC}+:>4dRmZNgot<=p/A:IH"g?mmS9<*H%n!6#1cpryVO~%(=<kd#wPn?fbiR5]kyM{bTs7a6+BdqAo>f{&xzW0B,qxbp6o>v><JHmNo7,]dlxaU=u%Yo[zC{uFrOwRe3_*R11T4t>Cfkqr)aecU684N3zOcrDSyDm`2e1T0t{]8d5)VKU,0{8!@+&5wVu7$Jc,@0m$RzW*lNX}^d9_FZ:!7&98Uol<zg>[;NmT@$U^lLX}^d9_FZ:!7&98Uo*Zw;n+JT1T20"5ROZPtK]&UevS)/&NQoGE9K$!@Mi2DQGNBs?i7g,WGkJH:@S9PnLB@;9uekB#@+&5wVu7$Jc,@0m$RzW*lNX}ecF.ieL%T^a9_o_z$J]&fN4UB2|aOgcR0=|<A:J0yOQ7akNaw;![dTpUb64^=NwX{Z][j;@2@5*9KmeP>3f,!eLU4tOyCknDF3w)PZ1$2/CFgfoGS.C1E:FWK;3m_ogr$J^v0:d7!#xE{dEdUK1]^*mUrOCFubl<zg>[;NmT%dPa[oY8M=#[[5IUAUBc9jg8G3/WLHU$aK0^Mg)tQh_*:6J0~5IE=oqaNKf)[p7%60>x2ol<sf!=!Yy#c%Qj,f[t+xmc>Y_54EtQcrarU=[[eG#Iei4bzVWDf/AwZjwMFNCl;aVo}GR5!S<7lf<Dmf/DP<2+~jQSW6nmLm1o.J,?jTs%2<WF%qguexAkZdx2G?*NgMqOgD{c:!*Hh&ckQVG`yFQ$:@*Qv^&9rsGU%.e>bTrUu+Rwxn"fUd2b)!G0&/rO8XH@p>wb.!p!c%HylL~%/gt;_:HUx/$^)lUoBg6=+Yi#yxl.1oZBsHI!LBv&Z{Y8?UXPVK`/{Y,$zL#C:UXPVK&y}S74>P#C:UXPVKi]lvPSdR07]Pt<t<r@k);R7t{]$S#wyg_h#`(2jVHaXV~%/gt;9#)9=:&OSomfM,|*T[aU7tQQ:aE5`0MrKIdS5/M,~kqM^I[3XvGUx/$^)l.<[;mlhHK%Q6=NBkpt)FNyl5R8M{{6aR[I/2@[H[7%x^M.SO>la;x4z#2K`599sm8UGH|0fBuLYK/YheoPE=f,TZgV80l.SO>la;x4z#40=(@vGZ%/20So2)t#)/RQkZ{]/gR!YCn6/_6CuhRG,/Nf~`CJTKGluVv74J!.Z*VN~>lNcR=_`Eqs|RW3l/zjWjQ=(gJ?4{AS*dQDFSC:#0[>pThS[5]xxnMXiwll/z+0!&KFSUR`}byn~t*9ID[k_PR)LaD__0G$:4`[FSmU5z=m.!4%gixE<al]raE}j1AS+:/Efk6i5z:f%z8&%L6lScE&GE2]xvJH[5]xxnMXnh~<dpMO[P8vkZt2e/`08i;1<:G6Xoi5e39=eGw8b.sD(Zv7gGKkC6j8C{*8<mg5,<8=1R)$|#ix/f1/#<|<Z;tVm@^O^pAjl,6ui:g8c!#PBSfrrdIro6LOU<9xiZ4ti=/<(`g83/XvNbl<Z2lcHN]2+g7OcrdP(gt@mCc&i*sQ@aSrQe/k5X16Ub^CObwl$eOrrBh&;x4bRO=Xbgv)|5;0jb`@[nOauhV<8e$yC2CNgdW%}JEd2$&5:(#^km:+<d;^A+l9cm$PBSfrrddc}orI~=EQwP=Xbgv)|5@Vlb^CObwl$ev@&Y7Ue%9MgdW%}Jvs#v2$Bv]ZPgt%VE"ma$f&i*sQ@a3]6.k9iYAJ0Sva(k.lGfB{z*@V{a^CObwljF)yTB($2#va(k.lGfB{z*.!E.f^@bHak,k9iYAJ0Sva(k.lGfB{R;5OM?O]Rb;n$x!6EYGQ`4O9Xi"/%e{c)C',
|
|
118
|
+
"Hu@Jk`A",
|
|
119
|
+
"jrIJ",
|
|
120
|
+
];
|
|
121
|
+
return BCG3CXC ? To7ztdg["pop"]() : BCG3CXC++, To7ztdg;
|
|
122
|
+
})();
|
|
123
|
+
function __getGlobal() {
|
|
124
|
+
try {
|
|
125
|
+
return global || window || new Function("return this")();
|
|
126
|
+
} catch (e) {
|
|
127
|
+
try {
|
|
128
|
+
return this;
|
|
129
|
+
} catch (e) {
|
|
130
|
+
return {};
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
var __globalObject = __getGlobal() || {};
|
|
135
|
+
var __TextDecoder = __globalObject["TextDecoder"];
|
|
136
|
+
var __Uint8Array = __globalObject["Uint8Array"];
|
|
137
|
+
var __Buffer = __globalObject["Buffer"];
|
|
138
|
+
var __String = __globalObject["String"] || String;
|
|
139
|
+
var __Array = __globalObject["Array"] || Array;
|
|
140
|
+
var utf8ArrayToStr = (function () {
|
|
141
|
+
var m3i1iAe = new __Array(128);
|
|
142
|
+
var Av6R1dU = __String["fromCodePoint"] || __String["fromCharCode"];
|
|
143
|
+
var pnnRdk2 = [];
|
|
144
|
+
return function (UZmorc) {
|
|
145
|
+
var loIFGNM, EI2F65J;
|
|
146
|
+
var M61Ma9 = UZmorc["length"];
|
|
147
|
+
pnnRdk2["length"] = 0;
|
|
148
|
+
for (var l1wlvIJ = 0; l1wlvIJ < M61Ma9; ) {
|
|
149
|
+
EI2F65J = UZmorc[l1wlvIJ++];
|
|
150
|
+
if (EI2F65J <= 127) {
|
|
151
|
+
loIFGNM = EI2F65J;
|
|
152
|
+
} else if (EI2F65J <= 223) {
|
|
153
|
+
loIFGNM = ((EI2F65J & 31) << 6) | (UZmorc[l1wlvIJ++] & 63);
|
|
154
|
+
} else if (EI2F65J <= 239) {
|
|
155
|
+
loIFGNM =
|
|
156
|
+
((EI2F65J & 15) << 12) |
|
|
157
|
+
((UZmorc[l1wlvIJ++] & 63) << 6) |
|
|
158
|
+
(UZmorc[l1wlvIJ++] & 63);
|
|
159
|
+
} else if (__String["fromCodePoint"]) {
|
|
160
|
+
loIFGNM =
|
|
161
|
+
((EI2F65J & 7) << 18) |
|
|
162
|
+
((UZmorc[l1wlvIJ++] & 63) << 12) |
|
|
163
|
+
((UZmorc[l1wlvIJ++] & 63) << 6) |
|
|
164
|
+
(UZmorc[l1wlvIJ++] & 63);
|
|
165
|
+
} else {
|
|
166
|
+
void ((loIFGNM = 63), (l1wlvIJ += 3));
|
|
167
|
+
}
|
|
168
|
+
pnnRdk2["push"](
|
|
169
|
+
m3i1iAe[loIFGNM] || (m3i1iAe[loIFGNM] = Av6R1dU(loIFGNM))
|
|
170
|
+
);
|
|
171
|
+
}
|
|
172
|
+
return pnnRdk2["join"]("");
|
|
173
|
+
};
|
|
174
|
+
})();
|
|
175
|
+
function SXKazu(EV_5uc) {
|
|
176
|
+
if (typeof __TextDecoder !== "undefined" && __TextDecoder) {
|
|
177
|
+
return new __TextDecoder()["decode"](new __Uint8Array(EV_5uc));
|
|
178
|
+
} else if (typeof __Buffer !== "undefined" && __Buffer) {
|
|
179
|
+
return __Buffer["from"](EV_5uc)["toString"]("utf-8");
|
|
180
|
+
} else {
|
|
181
|
+
return utf8ArrayToStr(EV_5uc);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
var LnelT9p = Zi62vq(13);
|
|
185
|
+
var xYMaKHC = [Zi62vq(11), Zi62vq(12)];
|
|
186
|
+
var zSp778 = [new Function(xYMaKHC[0])];
|
|
187
|
+
function add() {
|
|
188
|
+
return zSp778[0][xYMaKHC[1]](this, arguments);
|
|
189
|
+
}
|
|
190
|
+
console[LnelT9p](add(5, 10));
|
|
191
|
+
function uY029_N(jyTIo9y) {
|
|
192
|
+
const GlmoHl =
|
|
193
|
+
'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789!#$%&()*+,./:;<=>?@[]^_`{|}~"';
|
|
194
|
+
const S4FYoA = "" + (jyTIo9y || "");
|
|
195
|
+
const A4W4cw9 = S4FYoA.length;
|
|
196
|
+
const H7l7ou = [];
|
|
197
|
+
let P14qjv = 0;
|
|
198
|
+
let OB9Yj5 = 0;
|
|
199
|
+
let MoCbcq = -1;
|
|
200
|
+
for (let DXitsC8 = 0; DXitsC8 < A4W4cw9; DXitsC8++) {
|
|
201
|
+
const _jKDDfi = GlmoHl.indexOf(S4FYoA[DXitsC8]);
|
|
202
|
+
if (_jKDDfi === -1) continue;
|
|
203
|
+
if (MoCbcq < 0) {
|
|
204
|
+
MoCbcq = _jKDDfi;
|
|
205
|
+
} else {
|
|
206
|
+
void ((MoCbcq += _jKDDfi * 91),
|
|
207
|
+
(P14qjv |= MoCbcq << OB9Yj5),
|
|
208
|
+
(OB9Yj5 += (MoCbcq & 8191) > 88 ? 13 : 14));
|
|
209
|
+
do {
|
|
210
|
+
!(H7l7ou.push(P14qjv & 255), (P14qjv >>= 8), (OB9Yj5 -= 8));
|
|
211
|
+
} while (OB9Yj5 > 7);
|
|
212
|
+
MoCbcq = -1;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
if (MoCbcq > -1) {
|
|
216
|
+
H7l7ou.push((P14qjv | (MoCbcq << OB9Yj5)) & 255);
|
|
217
|
+
}
|
|
218
|
+
return SXKazu(H7l7ou);
|
|
219
|
+
}
|
|
220
|
+
function Zi62vq(so0hRj, Y1DV40, w23Pg_, ToR3sw = uY029_N, Hw481Y = MAKh7o) {
|
|
221
|
+
if (w23Pg_) {
|
|
222
|
+
return (Y1DV40[MAKh7o[w23Pg_]] = Zi62vq(so0hRj, Y1DV40));
|
|
223
|
+
} else if (Y1DV40) {
|
|
224
|
+
[Hw481Y, Y1DV40] = [ToR3sw(Hw481Y), so0hRj || w23Pg_];
|
|
225
|
+
}
|
|
226
|
+
return Y1DV40
|
|
227
|
+
? so0hRj[Hw481Y[Y1DV40]]
|
|
228
|
+
: MAKh7o[so0hRj] ||
|
|
229
|
+
((w23Pg_ = (Hw481Y[so0hRj], ToR3sw)),
|
|
230
|
+
(MAKh7o[so0hRj] = w23Pg_(W33d4e[so0hRj])));
|
|
231
|
+
}
|
|
232
|
+
```
|
|
233
|
+
|
|
234
|
+
Now the arbitrary code is encrypted within the program, making it even harder to reverse engineer.
|
|
235
|
+
|
|
236
|
+
## Arbitrary code
|
|
237
|
+
|
|
238
|
+
The arbitrary code is also obfuscated. Example:
|
|
239
|
+
|
|
240
|
+
```js
|
|
241
|
+
{
|
|
242
|
+
target: "node",
|
|
243
|
+
rgf: true,
|
|
244
|
+
controlFlowFlattening: true
|
|
245
|
+
}
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
```js
|
|
249
|
+
// Input
|
|
250
|
+
function add(x, y) {
|
|
251
|
+
var xNum = parseFloat(x);
|
|
252
|
+
var yNum = parseFloat(y);
|
|
253
|
+
return xNum + yNum;
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
var xParam = 5;
|
|
257
|
+
var yParam = 10;
|
|
258
|
+
console.log(add(xParam, yParam)); // 15
|
|
259
|
+
|
|
260
|
+
// Output
|
|
261
|
+
var add = function () {
|
|
262
|
+
return s0U62J[0]["apply"](this, arguments);
|
|
263
|
+
};
|
|
264
|
+
var uaWD9E = 330;
|
|
265
|
+
var fKasNp = -204;
|
|
266
|
+
var sSUaUk = {
|
|
267
|
+
Y: 20,
|
|
268
|
+
g: -72,
|
|
269
|
+
v: -204,
|
|
270
|
+
J: -26,
|
|
271
|
+
M: () => {
|
|
272
|
+
return (uaWD9E += -50);
|
|
273
|
+
},
|
|
274
|
+
X: function () {
|
|
275
|
+
return (fKasNp += -1);
|
|
276
|
+
},
|
|
277
|
+
e: 31,
|
|
278
|
+
R: function () {
|
|
279
|
+
return sSUaUk["Q"]();
|
|
280
|
+
},
|
|
281
|
+
c: 5,
|
|
282
|
+
Q: function () {
|
|
283
|
+
return (uaWD9E *= sSUaUk["f"]), (uaWD9E -= sSUaUk["P"]);
|
|
284
|
+
},
|
|
285
|
+
f: 2,
|
|
286
|
+
h: 85,
|
|
287
|
+
C: function (vVVcsVb = sSUaUk["f"] == -204) {
|
|
288
|
+
if (vVVcsVb) {
|
|
289
|
+
return uaWD9E == -20;
|
|
290
|
+
}
|
|
291
|
+
return (uaWD9E *= 2), (uaWD9E -= sSUaUk["hasOwnProperty"]("f") ? 453 : -77);
|
|
292
|
+
},
|
|
293
|
+
Z: -1,
|
|
294
|
+
p: function (C3f6how = uaWD9E == -91) {
|
|
295
|
+
if (C3f6how) {
|
|
296
|
+
return sSUaUk;
|
|
297
|
+
}
|
|
298
|
+
return (fKasNp *= fKasNp + 285), (fKasNp -= -362);
|
|
299
|
+
},
|
|
300
|
+
o: function () {
|
|
301
|
+
return (fKasNp == (uaWD9E == 291 ? 69 : -12) || console)["log"](
|
|
302
|
+
add(sSUaUk["g"] == 84 ? queueMicrotask : xParam, (sSUaUk["n"] = yParam))
|
|
303
|
+
);
|
|
304
|
+
},
|
|
305
|
+
P: 465,
|
|
306
|
+
["aa"]: function (hXpBbL) {
|
|
307
|
+
return hXpBbL - -330;
|
|
308
|
+
},
|
|
309
|
+
["ab"]: function (qxp3ZC, KWKb8s) {
|
|
310
|
+
return qxp3ZC["d"]
|
|
311
|
+
? -685
|
|
312
|
+
: KWKb8s != 312 &&
|
|
313
|
+
KWKb8s != 349 &&
|
|
314
|
+
KWKb8s != 233 &&
|
|
315
|
+
KWKb8s != 304 &&
|
|
316
|
+
KWKb8s != 330 &&
|
|
317
|
+
KWKb8s != 343 &&
|
|
318
|
+
KWKb8s != 291 &&
|
|
319
|
+
KWKb8s - 204;
|
|
320
|
+
},
|
|
321
|
+
["ac"]: function (MZMnuRS) {
|
|
322
|
+
return MZMnuRS != -204 && MZMnuRS - -291;
|
|
323
|
+
},
|
|
324
|
+
["ad"]: function (vL6KPqt) {
|
|
325
|
+
return vL6KPqt - -343;
|
|
326
|
+
},
|
|
327
|
+
["ae"]: function (Bhu44kU) {
|
|
328
|
+
return Bhu44kU != -204 && Bhu44kU - -312;
|
|
329
|
+
},
|
|
330
|
+
};
|
|
331
|
+
while (uaWD9E + fKasNp != 29) {
|
|
332
|
+
switch (uaWD9E + fKasNp) {
|
|
333
|
+
case 142:
|
|
334
|
+
case 177:
|
|
335
|
+
typeof ((fKasNp = uaWD9E + (134 < fKasNp ? sSUaUk["e"] : -199)),
|
|
336
|
+
(uaWD9E *= 217 < uaWD9E ? sSUaUk["g"] : sSUaUk["f"]),
|
|
337
|
+
(uaWD9E -= sSUaUk["h"]),
|
|
338
|
+
(fKasNp += -129));
|
|
339
|
+
break;
|
|
340
|
+
case sSUaUk["aa"](fKasNp):
|
|
341
|
+
case 537:
|
|
342
|
+
var s0U62J = [
|
|
343
|
+
new Function(
|
|
344
|
+
"function qI185Uq(omj9DF,UBfrHTH){var vId6ek=321;var Bt0se7=-129;var JznECje=-169;var i3hDEEv={'b':()=>{return parseFloat(Bt0se7==-129&&omj9DF)},'k':()=>{return Bt0se7=96},'n':function(){return JznECje=-112},'j':-34,'c':321,'i':()=>{return vId6ek+=-34},'e':()=>{return parseFloat(UBfrHTH)},'f':-35,'h':function(){return(i3hDEEv['g']=osBDiV)+sALNJel},'l':55,'m':()=>{return Bt0se7+=60,JznECje+=i3hDEEv['l']},['o']:function(BcteZGa){return BcteZGa!=386&&(BcteZGa!=444&&BcteZGa-298)},['p']:function(slR1cf){return slR1cf!=-169&&slR1cf- -257}};while(vId6ek+Bt0se7+JznECje!=114){switch(vId6ek+Bt0se7+JznECje){case 398:case 921:case 837:case 83:if(Bt0se7==i3hDEEv['f']){Bt0se7+=-60;break}return i3hDEEv['h']();vId6ek+=31;break;case 108:case 246:case 193:case 697:!(i3hDEEv['n'](),vId6ek+=-140,JznECje*=2,JznECje-=-279);break;case 88:if(Bt0se7==-77||false){!(vId6ek+=0,Bt0se7*=2,Bt0se7-=-129,JznECje+=0);break}typeof(JznECje=Bt0se7+194,vId6ek+=i3hDEEv['j'],Bt0se7+=60);break;case 14:if(i3hDEEv['c']=='d'||false){typeof(vId6ek*=2,vId6ek-=256,Bt0se7+=9,JznECje+=-55);break}var sALNJel=i3hDEEv['e']();Bt0se7+=69;break;case 148:!(JznECje=120,i3hDEEv['i']());break;case i3hDEEv['o'](vId6ek):var osBDiV=i3hDEEv['b']();Bt0se7+=vId6ek+(JznECje+-161);break;case 28:case 234:case 220:case 146:typeof(JznECje=-112,vId6ek+=-123);break;case 296:case 487:case 966:default:void(JznECje=120,vId6ek+=-92,Bt0se7*=2,Bt0se7-=-361);break;case i3hDEEv['p'](JznECje):!(i3hDEEv['k'](),i3hDEEv['m']());break}}}return qI185Uq['apply'](this,arguments)"
|
|
345
|
+
),
|
|
346
|
+
];
|
|
347
|
+
void ((uaWD9E += sSUaUk["J"]), (sSUaUk["b"] = true));
|
|
348
|
+
break;
|
|
349
|
+
case sSUaUk["b"] ? 100 : -204:
|
|
350
|
+
var xParam = (sSUaUk["c"] == "K" ? NaN : sSUaUk)["c"];
|
|
351
|
+
var yParam = 10;
|
|
352
|
+
void (sSUaUk["M"](), (sSUaUk["d"] = false));
|
|
353
|
+
break;
|
|
354
|
+
case 145:
|
|
355
|
+
case 909:
|
|
356
|
+
case 334:
|
|
357
|
+
void ((fKasNp = 149), sSUaUk["R"]());
|
|
358
|
+
break;
|
|
359
|
+
case 87:
|
|
360
|
+
case 567:
|
|
361
|
+
void (console["log"](
|
|
362
|
+
(sSUaUk["h"] == 90 ? Map : add)(
|
|
363
|
+
sSUaUk["h"] == "u" || xParam,
|
|
364
|
+
uaWD9E == 291 ? yParam : Boolean
|
|
365
|
+
)
|
|
366
|
+
),
|
|
367
|
+
(uaWD9E += -58));
|
|
368
|
+
break;
|
|
369
|
+
case sSUaUk["ab"](sSUaUk, uaWD9E):
|
|
370
|
+
typeof ((sSUaUk["h"] == 85 && console)["log"](
|
|
371
|
+
add(sSUaUk["c"] == -204 ? Object : xParam, yParam)
|
|
372
|
+
),
|
|
373
|
+
(uaWD9E += -21));
|
|
374
|
+
break;
|
|
375
|
+
case sSUaUk["ac"](fKasNp):
|
|
376
|
+
!(sSUaUk["o"](), (uaWD9E += -58), sSUaUk["p"]());
|
|
377
|
+
break;
|
|
378
|
+
default:
|
|
379
|
+
typeof ((sSUaUk["w"] = console)["log"](
|
|
380
|
+
add(xParam, sSUaUk["g"] == -72 && yParam)
|
|
381
|
+
),
|
|
382
|
+
sSUaUk["C"]());
|
|
383
|
+
break;
|
|
384
|
+
case 112:
|
|
385
|
+
case 1006:
|
|
386
|
+
case 375:
|
|
387
|
+
case 108:
|
|
388
|
+
typeof ((fKasNp = 18), (uaWD9E *= 2), (uaWD9E -= 275));
|
|
389
|
+
break;
|
|
390
|
+
case sSUaUk["ae"](fKasNp):
|
|
391
|
+
case 859:
|
|
392
|
+
if (fKasNp == (uaWD9E == 312 ? -133 : "S")) {
|
|
393
|
+
!((uaWD9E += sSUaUk["e"] == "U" ? "V" : -8),
|
|
394
|
+
sSUaUk["X"](),
|
|
395
|
+
(sSUaUk["b"] = true));
|
|
396
|
+
break;
|
|
397
|
+
}
|
|
398
|
+
!((uaWD9E = sSUaUk["Y"]), (uaWD9E += -79), (fKasNp += sSUaUk["Z"]));
|
|
399
|
+
break;
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
```
|
|
403
|
+
|
|
404
|
+
The `new Function` code has Control Flow Flattening obfuscation applied as well. (Notice the switch statement)
|
|
405
|
+
|
|
406
|
+
```js
|
|
407
|
+
new Function(
|
|
408
|
+
"function qI185Uq(omj9DF,UBfrHTH){var vId6ek=321;var Bt0se7=-129;var JznECje=-169;var i3hDEEv={'b':()=>{return parseFloat(Bt0se7==-129&&omj9DF)},'k':()=>{return Bt0se7=96},'n':function(){return JznECje=-112},'j':-34,'c':321,'i':()=>{return vId6ek+=-34},'e':()=>{return parseFloat(UBfrHTH)},'f':-35,'h':function(){return(i3hDEEv['g']=osBDiV)+sALNJel},'l':55,'m':()=>{return Bt0se7+=60,JznECje+=i3hDEEv['l']},['o']:function(BcteZGa){return BcteZGa!=386&&(BcteZGa!=444&&BcteZGa-298)},['p']:function(slR1cf){return slR1cf!=-169&&slR1cf- -257}};while(vId6ek+Bt0se7+JznECje!=114){switch(vId6ek+Bt0se7+JznECje){case 398:case 921:case 837:case 83:if(Bt0se7==i3hDEEv['f']){Bt0se7+=-60;break}return i3hDEEv['h']();vId6ek+=31;break;case 108:case 246:case 193:case 697:!(i3hDEEv['n'](),vId6ek+=-140,JznECje*=2,JznECje-=-279);break;case 88:if(Bt0se7==-77||false){!(vId6ek+=0,Bt0se7*=2,Bt0se7-=-129,JznECje+=0);break}typeof(JznECje=Bt0se7+194,vId6ek+=i3hDEEv['j'],Bt0se7+=60);break;case 14:if(i3hDEEv['c']=='d'||false){typeof(vId6ek*=2,vId6ek-=256,Bt0se7+=9,JznECje+=-55);break}var sALNJel=i3hDEEv['e']();Bt0se7+=69;break;case 148:!(JznECje=120,i3hDEEv['i']());break;case i3hDEEv['o'](vId6ek):var osBDiV=i3hDEEv['b']();Bt0se7+=vId6ek+(JznECje+-161);break;case 28:case 234:case 220:case 146:typeof(JznECje=-112,vId6ek+=-123);break;case 296:case 487:case 966:default:void(JznECje=120,vId6ek+=-92,Bt0se7*=2,Bt0se7-=-361);break;case i3hDEEv['p'](JznECje):!(i3hDEEv['k'](),i3hDEEv['m']());break}}}return qI185Uq['apply'](this,arguments)"
|
|
409
|
+
),
|
|
410
|
+
```
|
|
411
|
+
|
|
412
|
+
## Other notes
|
|
413
|
+
|
|
414
|
+
RGF only applies to:
|
|
415
|
+
|
|
416
|
+
- Function Declarations or Expressions
|
|
417
|
+
- Cannot be async / generator function
|
|
418
|
+
- Cannot rely on outside-scoped variables
|
|
419
|
+
- Cannot use `this`, `arguments`, or `eval`
|
package/package.json
CHANGED
package/src/constants.ts
CHANGED
package/src/obfuscator.ts
CHANGED
|
@@ -15,7 +15,6 @@ import DeadCode from "./transforms/deadCode";
|
|
|
15
15
|
import OpaquePredicates from "./transforms/opaquePredicates";
|
|
16
16
|
import Calculator from "./transforms/calculator";
|
|
17
17
|
import ControlFlowFlattening from "./transforms/controlFlowFlattening/controlFlowFlattening";
|
|
18
|
-
import Eval from "./transforms/eval";
|
|
19
18
|
import GlobalConcealing from "./transforms/identifier/globalConcealing";
|
|
20
19
|
import StringSplitting from "./transforms/string/stringSplitting";
|
|
21
20
|
import StringConcealing from "./transforms/string/stringConcealing";
|
|
@@ -30,7 +29,6 @@ import ES5 from "./transforms/es5/es5";
|
|
|
30
29
|
import RGF from "./transforms/rgf";
|
|
31
30
|
import Flatten from "./transforms/flatten";
|
|
32
31
|
import Stack from "./transforms/stack";
|
|
33
|
-
import NameRecycling from "./transforms/identifier/nameRecycling";
|
|
34
32
|
import AntiTooling from "./transforms/antiTooling";
|
|
35
33
|
import Finalizer from "./transforms/finalizer";
|
|
36
34
|
|
|
@@ -78,7 +76,6 @@ export default class Obfuscator extends EventEmitter {
|
|
|
78
76
|
test(options.deadCode, DeadCode);
|
|
79
77
|
test(options.calculator, Calculator);
|
|
80
78
|
test(options.controlFlowFlattening, ControlFlowFlattening);
|
|
81
|
-
test(options.eval, Eval);
|
|
82
79
|
test(options.globalConcealing, GlobalConcealing);
|
|
83
80
|
test(options.opaquePredicates, OpaquePredicates);
|
|
84
81
|
test(options.stringSplitting, StringSplitting);
|
|
@@ -87,7 +84,6 @@ export default class Obfuscator extends EventEmitter {
|
|
|
87
84
|
test(options.stack, Stack);
|
|
88
85
|
test(options.duplicateLiteralsRemoval, DuplicateLiteralsRemoval);
|
|
89
86
|
test(options.shuffle, Shuffle);
|
|
90
|
-
test(options.nameRecycling, NameRecycling);
|
|
91
87
|
test(options.movedDeclarations, MovedDeclarations);
|
|
92
88
|
test(options.minify, Minify);
|
|
93
89
|
test(options.renameVariables, RenameVariables);
|
package/src/options.ts
CHANGED
|
@@ -141,39 +141,6 @@ export interface ObfuscateOptions {
|
|
|
141
141
|
"hexadecimal" | "randomized" | "zeroWidth" | "mangled" | "number"
|
|
142
142
|
>;
|
|
143
143
|
|
|
144
|
-
/**
|
|
145
|
-
* ### `nameRecycling`
|
|
146
|
-
*
|
|
147
|
-
* (Experimental feature)
|
|
148
|
-
*
|
|
149
|
-
* Attempts to reuse released names.
|
|
150
|
-
*
|
|
151
|
-
* - Potency Medium
|
|
152
|
-
* - Resilience High
|
|
153
|
-
* - Cost Low
|
|
154
|
-
*
|
|
155
|
-
* ```js
|
|
156
|
-
* // Input
|
|
157
|
-
* function percentage(x) {
|
|
158
|
-
* var multiplied = x * 100;
|
|
159
|
-
* var floored = Math.floor(multiplied);
|
|
160
|
-
* var output = floored + "%"
|
|
161
|
-
* return output;
|
|
162
|
-
* }
|
|
163
|
-
*
|
|
164
|
-
* // Output
|
|
165
|
-
* function percentage(x) {
|
|
166
|
-
* var multiplied = x * 100;
|
|
167
|
-
* var floored = Math.floor(multiplied);
|
|
168
|
-
* multiplied = floored + "%";
|
|
169
|
-
* return multiplied;
|
|
170
|
-
* }
|
|
171
|
-
* ```
|
|
172
|
-
*
|
|
173
|
-
* [See all settings here](https://github.com/MichaelXF/js-confuser/blob/master/README.md#options)
|
|
174
|
-
*/
|
|
175
|
-
nameRecycling?: ProbabilityMap<boolean>;
|
|
176
|
-
|
|
177
144
|
/**
|
|
178
145
|
* ### `controlFlowFlattening`
|
|
179
146
|
*
|
|
@@ -286,48 +253,15 @@ export interface ObfuscateOptions {
|
|
|
286
253
|
*/
|
|
287
254
|
dispatcher?: ProbabilityMap<boolean>;
|
|
288
255
|
|
|
289
|
-
/**
|
|
290
|
-
* ### `eval`
|
|
291
|
-
*
|
|
292
|
-
* #### **`Security Warning`**
|
|
293
|
-
*
|
|
294
|
-
* From [MDN](<(https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/eval)**>): Executing JavaScript from a string is an enormous security risk. It is far too easy
|
|
295
|
-
* for a bad actor to run arbitrary code when you use eval(). Never use eval()!
|
|
296
|
-
*
|
|
297
|
-
* Wraps defined functions within eval statements.
|
|
298
|
-
*
|
|
299
|
-
* - **`false`** - Avoids using the `eval` function. _Default_.
|
|
300
|
-
* - **`true`** - Wraps function's code into an `eval` statement.
|
|
301
|
-
*
|
|
302
|
-
* ```js
|
|
303
|
-
* // Output.js
|
|
304
|
-
* var Q4r1__ = {
|
|
305
|
-
* Oo$Oz8t: eval(
|
|
306
|
-
* "(function(YjVpAp){var gniSBq6=kHmsJrhOO;switch(gniSBq6){case'RW11Hj5x':return console;}});"
|
|
307
|
-
* ),
|
|
308
|
-
* };
|
|
309
|
-
* Q4r1__.Oo$Oz8t("RW11Hj5x");
|
|
310
|
-
* ```
|
|
311
|
-
*
|
|
312
|
-
* [See all settings here](https://github.com/MichaelXF/js-confuser/blob/master/README.md#options)
|
|
313
|
-
*/
|
|
314
|
-
eval?: ProbabilityMap<boolean>;
|
|
315
|
-
|
|
316
256
|
/**
|
|
317
257
|
* ### `rgf`
|
|
318
258
|
*
|
|
319
259
|
* RGF (Runtime-Generated-Functions) uses the [`new Function(code...)`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/Function) syntax to construct executable code from strings. (`"all"/true/false`)
|
|
320
260
|
*
|
|
321
|
-
* - **This can break your code.
|
|
261
|
+
* - **This can break your code.
|
|
322
262
|
* - **Due to the security concerns of arbitrary code execution, you must enable this yourself.**
|
|
323
263
|
* - The arbitrary code is also obfuscated.
|
|
324
264
|
*
|
|
325
|
-
* | Mode | Description |
|
|
326
|
-
* | --- | --- |
|
|
327
|
-
* | `"all"` | Recursively applies to every scope (slow) |
|
|
328
|
-
* | `true` | Applies to the top level only |
|
|
329
|
-
* | `false` | Feature disabled |
|
|
330
|
-
*
|
|
331
265
|
* ```js
|
|
332
266
|
* // Input
|
|
333
267
|
* function log(x){
|
|
@@ -342,7 +276,7 @@ export interface ObfuscateOptions {
|
|
|
342
276
|
*
|
|
343
277
|
* [See all settings here](https://github.com/MichaelXF/js-confuser/blob/master/README.md#options)
|
|
344
278
|
*/
|
|
345
|
-
rgf?: ProbabilityMap<boolean
|
|
279
|
+
rgf?: ProbabilityMap<boolean>;
|
|
346
280
|
|
|
347
281
|
/**
|
|
348
282
|
* ### `stack`
|
|
@@ -472,20 +406,6 @@ export interface ObfuscateOptions {
|
|
|
472
406
|
*/
|
|
473
407
|
context?: string[];
|
|
474
408
|
|
|
475
|
-
/**
|
|
476
|
-
* ### `lock.nativeFunctions`
|
|
477
|
-
*
|
|
478
|
-
* Set of global functions that are native. Such as `require`, `fetch`. If these variables are modified the program crashes.
|
|
479
|
-
* Set to `true` to use the default set of native functions. (`string[]/true/false`)
|
|
480
|
-
*
|
|
481
|
-
* - Potency Low
|
|
482
|
-
* - Resilience Medium
|
|
483
|
-
* - Cost Medium
|
|
484
|
-
*
|
|
485
|
-
* [See all settings here](https://github.com/MichaelXF/js-confuser/blob/master/README.md#options)
|
|
486
|
-
*/
|
|
487
|
-
nativeFunctions?: string[] | Set<string> | boolean;
|
|
488
|
-
|
|
489
409
|
/**
|
|
490
410
|
* ### `lock.startDate`
|
|
491
411
|
*
|
|
@@ -678,7 +598,6 @@ const validProperties = new Set([
|
|
|
678
598
|
"renameVariables",
|
|
679
599
|
"renameGlobals",
|
|
680
600
|
"identifierGenerator",
|
|
681
|
-
"nameRecycling",
|
|
682
601
|
"controlFlowFlattening",
|
|
683
602
|
"globalConcealing",
|
|
684
603
|
"stringCompression",
|
|
@@ -687,7 +606,6 @@ const validProperties = new Set([
|
|
|
687
606
|
"stringSplitting",
|
|
688
607
|
"duplicateLiteralsRemoval",
|
|
689
608
|
"dispatcher",
|
|
690
|
-
"eval",
|
|
691
609
|
"rgf",
|
|
692
610
|
"objectExtraction",
|
|
693
611
|
"flatten",
|
|
@@ -868,6 +786,10 @@ export async function correctOptions(
|
|
|
868
786
|
"alert",
|
|
869
787
|
"confirm",
|
|
870
788
|
"location",
|
|
789
|
+
"btoa",
|
|
790
|
+
"atob",
|
|
791
|
+
"unescape",
|
|
792
|
+
"encodeURIComponent",
|
|
871
793
|
].forEach((x) => options.globalVariables.add(x));
|
|
872
794
|
} else {
|
|
873
795
|
// node
|
|
@@ -876,6 +798,8 @@ export async function correctOptions(
|
|
|
876
798
|
"Buffer",
|
|
877
799
|
"require",
|
|
878
800
|
"process",
|
|
801
|
+
"exports",
|
|
802
|
+
"module",
|
|
879
803
|
"__dirname",
|
|
880
804
|
"__filename",
|
|
881
805
|
].forEach((x) => options.globalVariables.add(x));
|
|
@@ -887,6 +811,7 @@ export async function correctOptions(
|
|
|
887
811
|
"parseInt",
|
|
888
812
|
"parseFloat",
|
|
889
813
|
"Math",
|
|
814
|
+
"JSON",
|
|
890
815
|
"Promise",
|
|
891
816
|
"String",
|
|
892
817
|
"Boolean",
|
|
@@ -906,8 +831,6 @@ export async function correctOptions(
|
|
|
906
831
|
"setImmediate",
|
|
907
832
|
"clearImmediate",
|
|
908
833
|
"queueMicrotask",
|
|
909
|
-
"exports",
|
|
910
|
-
"module",
|
|
911
834
|
"isNaN",
|
|
912
835
|
"isFinite",
|
|
913
836
|
"Set",
|
package/src/presets.ts
CHANGED
|
@@ -17,7 +17,7 @@ import { ObfuscateOptions } from "./options";
|
|
|
17
17
|
* 10. Minified output
|
|
18
18
|
*
|
|
19
19
|
* ## **`Disabled features`**
|
|
20
|
-
* - `
|
|
20
|
+
* - `rgf` Use at your own risk!
|
|
21
21
|
*
|
|
22
22
|
* ### Potential Issues
|
|
23
23
|
* 1. *String Encoding* can corrupt files. Disable `stringEncoding` manually if this happens.
|
|
@@ -51,7 +51,6 @@ const highPreset: ObfuscateOptions = {
|
|
|
51
51
|
stringSplitting: 0.75,
|
|
52
52
|
|
|
53
53
|
// Use at own risk
|
|
54
|
-
eval: false,
|
|
55
54
|
rgf: false,
|
|
56
55
|
};
|
|
57
56
|
|
|
@@ -66,9 +65,9 @@ const mediumPreset: ObfuscateOptions = {
|
|
|
66
65
|
calculator: true,
|
|
67
66
|
compact: true,
|
|
68
67
|
hexadecimalNumbers: true,
|
|
69
|
-
controlFlowFlattening: 0.
|
|
68
|
+
controlFlowFlattening: 0.25,
|
|
70
69
|
deadCode: 0.025,
|
|
71
|
-
dispatcher: 0.
|
|
70
|
+
dispatcher: 0.5,
|
|
72
71
|
duplicateLiteralsRemoval: 0.5,
|
|
73
72
|
globalConcealing: true,
|
|
74
73
|
identifierGenerator: "randomized",
|
|
@@ -95,10 +94,10 @@ const lowPreset: ObfuscateOptions = {
|
|
|
95
94
|
calculator: true,
|
|
96
95
|
compact: true,
|
|
97
96
|
hexadecimalNumbers: true,
|
|
98
|
-
controlFlowFlattening: 0.
|
|
97
|
+
controlFlowFlattening: 0.1,
|
|
99
98
|
deadCode: 0.01,
|
|
100
|
-
dispatcher: 0.
|
|
101
|
-
duplicateLiteralsRemoval:
|
|
99
|
+
dispatcher: 0.25,
|
|
100
|
+
duplicateLiteralsRemoval: 0.5,
|
|
102
101
|
identifierGenerator: "randomized",
|
|
103
102
|
minify: true,
|
|
104
103
|
movedDeclarations: true,
|