fca-zeid 0.0.1-security → 1.5.3

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of fca-zeid might be problematic. Click here for more details.

Files changed (111) hide show
  1. package/.gitattributes +2 -0
  2. package/Extra/Database/index.js +469 -0
  3. package/Extra/ExtraAddons.js +82 -0
  4. package/Extra/ExtraAutoGetAppState.js +20 -0
  5. package/Extra/ExtraFindUID.js +62 -0
  6. package/Extra/ExtraGetThread.js +340 -0
  7. package/Extra/ExtraScreenShot.js +430 -0
  8. package/Extra/ExtraUptimeRobot.js +38 -0
  9. package/Extra/Html/Classic/script.js +119 -0
  10. package/Extra/Html/Classic/style.css +8 -0
  11. package/Extra/Security/Index.js +173 -0
  12. package/Extra/Security/Step_1.js +6 -0
  13. package/Extra/Security/Step_2.js +22 -0
  14. package/Extra/Security/Step_3.js +22 -0
  15. package/Extra/Src/Change_Environment.js +24 -0
  16. package/Extra/Src/Check_Update.js +67 -0
  17. package/Extra/Src/History.js +115 -0
  18. package/Extra/Src/Instant_Update.js +65 -0
  19. package/Extra/Src/Last-Run.js +65 -0
  20. package/Extra/Src/Release_Memory.js +41 -0
  21. package/Extra/Src/Websocket.js +213 -0
  22. package/Extra/Src/image/checkmate.jpg +0 -0
  23. package/Extra/Src/uuid.js +137 -0
  24. package/Func/AcceptAgreement.js +31 -0
  25. package/Func/ClearCache.js +64 -0
  26. package/Func/ReportV1.js +54 -0
  27. package/Index.js +385 -0
  28. package/LICENSE +21 -0
  29. package/Language/index.json +223 -0
  30. package/Main.js +1193 -0
  31. package/README.md +144 -5
  32. package/broadcast.js +40 -0
  33. package/fca-horizon-rebuild.zip +0 -0
  34. package/logger.js +66 -0
  35. package/package.json +224 -3
  36. package/src/Dev_Horizon_Data.js +125 -0
  37. package/src/Premium.js +25 -0
  38. package/src/Screenshot.js +83 -0
  39. package/src/addExternalModule.js +16 -0
  40. package/src/addUserToGroup.js +79 -0
  41. package/src/changeAdminStatus.js +79 -0
  42. package/src/changeArchivedStatus.js +41 -0
  43. package/src/changeAvt.js +85 -0
  44. package/src/changeBio.js +65 -0
  45. package/src/changeBlockedStatus.js +36 -0
  46. package/src/changeGroupImage.js +106 -0
  47. package/src/changeNickname.js +45 -0
  48. package/src/changeThreadColor.js +62 -0
  49. package/src/changeThreadEmoji.js +42 -0
  50. package/src/createNewGroup.js +70 -0
  51. package/src/createPoll.js +60 -0
  52. package/src/deleteMessage.js +45 -0
  53. package/src/deleteThread.js +43 -0
  54. package/src/forwardAttachment.js +48 -0
  55. package/src/getAccessToken.js +28 -0
  56. package/src/getCurrentUserID.js +7 -0
  57. package/src/getEmojiUrl.js +27 -0
  58. package/src/getFriendsList.js +73 -0
  59. package/src/getMessage.js +80 -0
  60. package/src/getThreadHistory.js +537 -0
  61. package/src/getThreadInfo.js +425 -0
  62. package/src/getThreadList.js +213 -0
  63. package/src/getThreadMain.js +220 -0
  64. package/src/getThreadPictures.js +59 -0
  65. package/src/getUID.js +59 -0
  66. package/src/getUserID.js +62 -0
  67. package/src/getUserInfo.js +113 -0
  68. package/src/getUserInfoMain.js +65 -0
  69. package/src/getUserInfoV2.js +32 -0
  70. package/src/getUserInfoV3.js +63 -0
  71. package/src/getUserInfoV4.js +55 -0
  72. package/src/getUserInfoV5.js +61 -0
  73. package/src/handleFriendRequest.js +46 -0
  74. package/src/handleMessageRequest.js +49 -0
  75. package/src/httpGet.js +49 -0
  76. package/src/httpPost.js +48 -0
  77. package/src/httpPostFormData.js +41 -0
  78. package/src/listenMqtt.js +787 -0
  79. package/src/logout.js +68 -0
  80. package/src/markAsDelivered.js +48 -0
  81. package/src/markAsRead.js +70 -0
  82. package/src/markAsReadAll.js +43 -0
  83. package/src/markAsSeen.js +51 -0
  84. package/src/muteThread.js +47 -0
  85. package/src/removeUserFromGroup.js +49 -0
  86. package/src/resolvePhotoUrl.js +37 -0
  87. package/src/searchForThread.js +43 -0
  88. package/src/sendMessage.js +379 -0
  89. package/src/sendTypingIndicator.js +80 -0
  90. package/src/setMessageReaction.js +109 -0
  91. package/src/setPostReaction.js +102 -0
  92. package/src/setTitle.js +74 -0
  93. package/src/threadColors.js +39 -0
  94. package/src/unfriend.js +43 -0
  95. package/src/unsendMessage.js +40 -0
  96. package/test/Database_Test.js +4 -0
  97. package/test/Db2.js +530 -0
  98. package/test/Horizon_Database/A_README.md +1 -0
  99. package/test/Horizon_Database/Database.db +0 -0
  100. package/test/data/shareAttach.js +146 -0
  101. package/test/data/something.mov +0 -0
  102. package/test/data/test.png +0 -0
  103. package/test/data/test.txt +7 -0
  104. package/test/env/.env +0 -0
  105. package/test/example-config.json +18 -0
  106. package/test/example-db.db +0 -0
  107. package/test/memoryleak.js +18 -0
  108. package/test/test-page.js +140 -0
  109. package/test/test.js +385 -0
  110. package/test/testv2.js +18 -0
  111. package/utils.js +1684 -0
package/Index.js ADDED
@@ -0,0 +1,385 @@
1
+ 'use strict';
2
+ /* eslint-disable linebreak-style */
3
+ const utils = require('./utils');
4
+ global.Fca = new Object({
5
+ isThread: new Array(),
6
+ isUser: new Array(),
7
+ startTime: Date.now(),
8
+ Setting: new Map(),
9
+ Version: require('./package.json').version,
10
+ Require: new Object({
11
+ fs: require("fs"),
12
+ Fetch: require('got'),
13
+ log: require("npmlog"),
14
+ utils: require("./utils.js"),
15
+ logger: require('./logger.js'),
16
+ languageFile: require('./Language/index.json'),
17
+ Security: require('./Extra/Src/uuid.js')
18
+ }),
19
+ getText: function(/** @type {any[]} */...Data) {
20
+ var Main = (Data.splice(0,1)).toString();
21
+ for (let i = 0; i < Data.length; i++) Main = Main.replace(RegExp(`%${i + 1}`, 'g'), Data[i]);
22
+ return Main;
23
+ },
24
+ Data: new Object({
25
+ ObjFastConfig: {
26
+ "Language": "vi",
27
+ "PreKey": "",
28
+ "AutoUpdate": true,
29
+ "MainColor": "#9900FF",
30
+ "MainName": "[ FCA-ZEID ]",
31
+ "Uptime": false,
32
+ "Config": "default",
33
+ "DevMode": false,
34
+ "Login2Fa": false,
35
+ "AutoLogin": false,
36
+ "BroadCast": true,
37
+ "AuthString": "SD4S XQ32 O2JA WXB3 FUX2 OPJ7 Q7JZ 4R6Z | https://i.imgur.com/RAg3rvw.png Please remove this !, Recommend If You Using getUserInfoV2",
38
+ "EncryptFeature": true,
39
+ "ResetDataLogin": false,
40
+ "AutoInstallNode": false,
41
+ "AntiSendAppState": true,
42
+ "AutoRestartMinutes": 0,
43
+ "RestartMQTT_Minutes": 0,
44
+ "Websocket_Extension": {
45
+ "Status": false,
46
+ "ResetData": false
47
+ },
48
+ "HTML": {
49
+ "HTML": true,
50
+ "UserName": "Guest",
51
+ "MusicLink": "https://drive.google.com/uc?id=1zlAALlxk1TnO7jXtEP_O6yvemtzA2ukA&export=download"
52
+ },
53
+ "AntiGetInfo": {
54
+ "Database_Type": "default", //json or default
55
+ "AntiGetThreadInfo": true,
56
+ "AntiGetUserInfo": true
57
+ },
58
+ "Stable_Version": {
59
+ "Accept": false,
60
+ "Version": ""
61
+ },
62
+ "AutoGetAppState": false,
63
+ "AutoGetAppStateMinutes": 30, // autoget after 30 minutes
64
+ "AppState_Path": "appstate.json"
65
+ },
66
+ CountTime: function() {
67
+ var fs = global.Fca.Require.fs;
68
+ if (fs.existsSync(__dirname + '/CountTime.json')) {
69
+ try {
70
+ var data = Number(fs.readFileSync(__dirname + '/CountTime.json', 'utf8')),
71
+ hours = Math.floor(data / (60 * 60));
72
+ }
73
+ catch (e) {
74
+ fs.writeFileSync(__dirname + '/CountTime.json', 0);
75
+ hours = 0;
76
+ }
77
+ }
78
+ else {
79
+ hours = 0;
80
+ }
81
+ return `${hours} Hours`;
82
+ }
83
+ }),
84
+ Action: function(Type) {
85
+ switch (Type) {
86
+ case "AutoLogin": {
87
+ var Database = require('./Extra/Database');
88
+ var logger = global.Fca.Require.logger;
89
+ var Email = (Database().get('Account')).replace(RegExp('"', 'g'), ''); //hmm IDK
90
+ var PassWord = (Database().get('Password')).replace(RegExp('"', 'g'), '');
91
+ require('./Main')({ email: Email, password: PassWord},async (error, api) => {
92
+ if (error) {
93
+ logger.Error(JSON.stringify(error,null,2), function() { logger.Error("AutoLogin Failed!", function() { process.exit(0); }) });
94
+ }
95
+ try {
96
+ Database().set("TempState", Database().get('Through2Fa'));
97
+ }
98
+ catch(e) {
99
+ logger.Warning(global.Fca.Require.Language.Index.ErrDatabase);
100
+ logger.Error();
101
+ process.exit(0);
102
+ }
103
+ process.exit(1);
104
+ });
105
+ }
106
+ break;
107
+ default: {
108
+ require('npmlog').Error("Invalid Message!");
109
+ };
110
+ }
111
+ }
112
+ });
113
+
114
+ try {
115
+ let Boolean_Fca = ["AntiSendAppState","AutoUpdate","Uptime","BroadCast","EncryptFeature","AutoLogin","ResetDataLogin","Login2Fa", "DevMode","AutoInstallNode", "AutoGetAppState"];
116
+ let String_Fca = ["MainName","PreKey","Language","AuthString","Config"]
117
+ let Number_Fca = ["AutoRestartMinutes","RestartMQTT_Minutes", "AutoGetAppStateMinutes"];
118
+ let Object_Fca = ["HTML","Stable_Version","AntiGetInfo","Websocket_Extension"];
119
+ let All_Variable = Boolean_Fca.concat(String_Fca,Number_Fca,Object_Fca);
120
+
121
+
122
+ if (!global.Fca.Require.fs.existsSync(process.cwd() + '/ConfigFca.json')) {
123
+ global.Fca.Require.fs.writeFileSync(process.cwd() + "/ConfigFca.json", JSON.stringify(global.Fca.Data.ObjFastConfig, null, "\t"));
124
+ process.exit(1);
125
+ }
126
+
127
+ try {
128
+ var Data_Setting = require(process.cwd() + "/ConfigFca.json");
129
+ }
130
+ catch (e) {
131
+ global.Fca.Require.logger.Error('Detect Your ConfigFca Settings Invalid!, Carry out default restoration');
132
+ global.Fca.Require.fs.writeFileSync(process.cwd() + "/ConfigFca.json", JSON.stringify(global.Fca.Data.ObjFastConfig, null, "\t"));
133
+ process.exit(1)
134
+ }
135
+ if (global.Fca.Require.fs.existsSync(process.cwd() + '/ConfigFca.json')) {
136
+
137
+ for (let i of All_Variable) {
138
+ if (Data_Setting[i] == undefined) {
139
+ Data_Setting[i] = global.Fca.Data.ObjFastConfig[i];
140
+ global.Fca.Require.fs.writeFileSync(process.cwd() + "/ConfigFca.json", JSON.stringify(Data_Setting, null, "\t"));
141
+ }
142
+ else continue;
143
+ } //Check Variable
144
+
145
+ for (let i in Data_Setting) {
146
+ if (Boolean_Fca.includes(i)) {
147
+ if (global.Fca.Require.utils.getType(Data_Setting[i]) != "Boolean") logger.Error(i + " Is Not A Boolean, Need To Be true Or false !", function() { process.exit(0) });
148
+ else continue;
149
+ }
150
+ else if (String_Fca.includes(i)) {
151
+ if (global.Fca.Require.utils.getType(Data_Setting[i]) != "String") logger.Error(i + " Is Not A String, Need To Be String!", function() { process.exit(0) });
152
+ else continue;
153
+ }
154
+ else if (Number_Fca.includes(i)) {
155
+ if (global.Fca.Require.utils.getType(Data_Setting[i]) != "Number") logger.Error(i + " Is Not A Number, Need To Be Number !", function() { process.exit(0) });
156
+ else continue;
157
+ }
158
+ else if (Object_Fca.includes(i)) {
159
+ if (global.Fca.Require.utils.getType(Data_Setting[i]) != "Object") {
160
+ Data_Setting[i] = global.Fca.Data.ObjFastConfig[i];
161
+ global.Fca.Require.fs.writeFileSync(process.cwd() + "/ConfigFca.json", JSON.stringify(Data_Setting, null, "\t"));
162
+ }
163
+ else continue;
164
+ }
165
+ }
166
+
167
+ for (let i of Object_Fca) {
168
+ const All_Paths = utils.getPaths(global.Fca.Data.ObjFastConfig[i]);
169
+ const Mission = { Main_Path: i, Data_Path: All_Paths }
170
+ for (let i of Mission.Data_Path) {
171
+ if (Data_Setting[Mission.Main_Path] == undefined) {
172
+ Data_Setting[Mission.Main_Path] = global.Fca.Data.ObjFastConfig[Mission.Main_Path];
173
+ global.Fca.Require.fs.writeFileSync(process.cwd() + "/ConfigFca.json", JSON.stringify(Data_Setting, null, "\t"));
174
+ }
175
+ const User_Data = (utils.getData_Path(Data_Setting[Mission.Main_Path], i, 0))
176
+ const User_Data_Type = utils.getType(User_Data);
177
+ if (User_Data_Type == "Number") {
178
+ const Mission_Path = User_Data == 0 ? i : i.slice(0, User_Data);
179
+ const Mission_Obj = utils.getData_Path(global.Fca.Data.ObjFastConfig[Mission.Main_Path], Mission_Path, 0);
180
+ Data_Setting[Mission.Main_Path] = utils.setData_Path(Data_Setting[Mission.Main_Path], Mission_Path, Mission_Obj)
181
+ global.Fca.Require.fs.writeFileSync(process.cwd() + "/ConfigFca.json", JSON.stringify(Data_Setting, null, "\t"));
182
+ }
183
+ }
184
+ }
185
+
186
+ if (!global.Fca.Require.languageFile.some((/** @type {{ Language: string; }} */i) => i.Language == Data_Setting.Language)) {
187
+ global.Fca.Require.logger.Warning("Not Support Language: " + Data_Setting.Language + " Only 'en' and 'vi'");
188
+ process.exit(0);
189
+ }
190
+ global.Fca.Require.Language = global.Fca.Require.languageFile.find((/** @type {{ Language: string; }} */i) => i.Language == Data_Setting.Language).Folder;
191
+ } else process.exit(1);
192
+ global.Fca.Require.FastConfig = Data_Setting;
193
+ }
194
+ catch (e) {
195
+ console.log(e);
196
+ global.Fca.Require.logger.Error();
197
+ }
198
+
199
+ if (global.Fca.Require.FastConfig.Websocket_Extension.Status) {
200
+ console.history = new Array();
201
+ var Convert = require('ansi-to-html');
202
+ var convert = new Convert();
203
+ console.__log = console.log;
204
+ console.log = function (data) {
205
+ const log = convert.toHtml(data)
206
+ console.history.push(log)
207
+ console.__log.apply(console,arguments)
208
+ }
209
+ }
210
+
211
+ module.exports = function(loginData, options, callback) {
212
+ const Language = global.Fca.Require.languageFile.find((/** @type {{ Language: string; }} */i) => i.Language == global.Fca.Require.FastConfig.Language).Folder.Index;
213
+ const login = require('./Main');
214
+ const fs = require('fs-extra');
215
+ const got = require('got');
216
+ const log = require('npmlog');
217
+ const { execSync } = require('child_process');
218
+ const Database = require('./Extra/Database');
219
+
220
+ if (global.Fca.Require.FastConfig.DevMode) {
221
+ require('./Extra/Src/Release_Memory');
222
+ }
223
+
224
+ return got.get('https://github.com/KanzuXHorizon/Global_Horizon/raw/main/InstantAction.json').then(async function(res) {
225
+ if (global.Fca.Require.FastConfig.AutoInstallNode) {
226
+ switch (fs.existsSync(process.cwd() + "/replit.nix") && process.env["REPL_ID"] != undefined) {
227
+ case true: {
228
+ await require('./Extra/Src/Change_Environment.js')();
229
+ break;
230
+ }
231
+ case false: {
232
+ const NodeVersion = execSync('node -v').toString().replace(/(\r\n|\n|\r)/gm, "");
233
+ if (!NodeVersion.includes("v14") && !NodeVersion.includes("v16") && !Database(true).has('SkipReplitNix')) {
234
+ log.warn("[ FCA-UPDATE ] •",global.Fca.getText(Language.NodeVersionNotSupported, NodeVersion));
235
+ await new Promise(resolve => setTimeout(resolve, 3000));
236
+ try {
237
+ switch (process.platform) {
238
+ case "win32": {
239
+ try {
240
+ //check if user using nvm
241
+ if (fs.existsSync(process.env.APPDATA + "/nvm/nvm.exe")) {
242
+ log.warn("[ FCA-UPDATE ] •", Language.UsingNVM);
243
+ process.exit(0);
244
+ }
245
+ //download NodeJS v14 for Windows and slient install
246
+ await got('https://nodejs.org/dist/v14.17.0/node-v14.17.0-x64.msi').pipe(fs.createWriteStream(process.cwd() + "/node-v14.17.0-x64.msi"));
247
+ log.info("[ FCA-UPDATE ] •", Language.DownloadingNode);
248
+ await new Promise(resolve => setTimeout(resolve, 3000));
249
+ execSync('msiexec /i node-v14.17.0-x64.msi /qn');
250
+ log.info("[ FCA-UPDATE ] •", Language.NodeDownloadingComplete);
251
+ await new Promise(resolve => setTimeout(resolve, 3000));
252
+ log.info("[ FCA-UPDATE ] •", Language.RestartRequire);
253
+ Database(true).set("NeedRebuild", true);
254
+ process.exit(0);
255
+ }
256
+ catch (e) {
257
+ log.error("[ FCA-UPDATE ] •",Language.ErrNodeDownload);
258
+ process.exit(0);
259
+ }
260
+ }
261
+ case "linux": {
262
+
263
+ try {
264
+ if (process.env["REPL_ID"] != undefined) {
265
+ log.warn("[ FCA-UPDATE ] •", "Look like you are using Replit, and didn't have replit.nix file in your project, i don't know how to help you, hmm i will help you pass this step, but you need to install NodeJS v14 by yourself, and restart your repl");
266
+ Database(true).set('SkipReplitNix', true);
267
+ await new Promise(resolve => setTimeout(resolve, 3000));
268
+ process.exit(1);
269
+ }
270
+ //check if user using nvm
271
+ if (fs.existsSync(process.env.HOME + "/.nvm/nvm.sh")) {
272
+ log.warn("[ FCA-UPDATE ] •", Language.UsingNVM);
273
+ process.exit(0);
274
+ }
275
+ //download NodeJS v14 for Linux and slient install
276
+ await got('https://nodejs.org/dist/v14.17.0/node-v14.17.0-linux-x64.tar.xz').pipe(fs.createWriteStream(process.cwd() + "/node-v14.17.0-linux-x64.tar.xz"));
277
+ log.info("[ FCA-UPDATE ] •", Language.DownloadingNode);
278
+ await new Promise(resolve => setTimeout(resolve, 3000));
279
+ execSync('tar -xf node-v14.17.0-linux-x64.tar.xz');
280
+ execSync('cd node-v14.17.0-linux-x64');
281
+ execSync('sudo cp -R * /usr/local/');
282
+ log.info("[ FCA-UPDATE ] •", Language.NodeDownloadingComplete);
283
+ await new Promise(resolve => setTimeout(resolve, 3000));
284
+ log.info("[ FCA-UPDATE ] •",Language.RestartingN);
285
+ Database(true).set("NeedRebuild", true);
286
+ process.exit(1);
287
+ }
288
+ catch (e) {
289
+ log.error("[ FCA-UPDATE ] •",Language.ErrNodeDownload);
290
+ process.exit(0);
291
+ }
292
+ }
293
+ case "darwin": {
294
+ try {
295
+ //check if user using nvm
296
+ if (fs.existsSync(process.env.HOME + "/.nvm/nvm.sh")) {
297
+ log.warn("[ FCA-UPDATE ] •", Language.UsingNVM);
298
+ process.exit(0);
299
+ }
300
+ //download NodeJS v14 for MacOS and slient install
301
+ await got('https://nodejs.org/dist/v14.17.0/node-v14.17.0-darwin-x64.tar.gz').pipe(fs.createWriteStream(process.cwd() + "/node-v14.17.0-darwin-x64.tar.gz"));
302
+ log.info("[ FCA-UPDATE ] •", Language.DownloadingNode);
303
+ await new Promise(resolve => setTimeout(resolve, 3000));
304
+ execSync('tar -xf node-v14.17.0-darwin-x64.tar.gz');
305
+ execSync('cd node-v14.17.0-darwin-x64');
306
+ execSync('sudo cp -R * /usr/local/');
307
+ log.info("[ FCA-UPDATE ] •", Language.NodeDownloadingComplete);
308
+ await new Promise(resolve => setTimeout(resolve, 3000));
309
+ log.info("[ FCA-UPDATE ] •",Language.RestartingN);
310
+ Database(true).set("NeedRebuild", true);
311
+ process.exit(1);
312
+ }
313
+ catch (e) {
314
+ log.error("[ FCA-UPDATE ] •",Language.ErrNodeDownload);
315
+ process.exit(0);
316
+ }
317
+ }
318
+ }
319
+ }
320
+ catch (e) {
321
+ console.log(e);
322
+ log.error("[ FCA-UPDATE ] •","NodeJS v14 Installation Failed, Please Try Again and Contact fb.com/Lazic.Kanzu!");
323
+ process.exit(0);
324
+ }
325
+ }
326
+ }
327
+ }
328
+ }
329
+ if ((Database(true).get("NeedRebuild")) == true) {
330
+ Database(true).set("NeedRebuild", false);
331
+ log.info("[ FCA-UPDATE ] •",Language.Rebuilding);
332
+ await new Promise(resolve => setTimeout(resolve, 3000));
333
+ try {
334
+ execSync('npm rebuild', {stdio: 'inherit'});
335
+ }
336
+ catch (e) {
337
+ console.log(e);
338
+ log.error("[ FCA-UPDATE ] •",Language.ErrRebuilding);
339
+ }
340
+ log.info("[ FCA-UPDATE ] •",Language.SuccessRebuilding);
341
+ await new Promise(resolve => setTimeout(resolve, 3000));
342
+ log.info("[ FCA-UPDATE ] •",Language.RestartingN);
343
+ process.exit(1);
344
+ }
345
+
346
+ let Data = JSON.parse(res.body);
347
+ if (global.Fca.Require.FastConfig.Stable_Version.Accept == true) {
348
+ if (Data.Stable_Version.Valid_Version.includes(global.Fca.Require.FastConfig.Stable_Version.Version)) {
349
+ let TimeStamp = Database(true).get('Check_Update');
350
+ if (TimeStamp == null || TimeStamp == undefined || Date.now() - TimeStamp > 300000) {
351
+ var Check_Update = require('./Extra/Src/Check_Update.js');
352
+ await Check_Update(global.Fca.Require.FastConfig.Stable_Version.Version);
353
+ }
354
+ }
355
+ else {
356
+ log.warn("[ FCA-UPDATE ] •", "Error Stable Version, Please Check Your Stable Version in FastConfig.json, Automatically turn off Stable Version!");
357
+ global.Fca.Require.FastConfig.Stable_Version.Accept = false;
358
+ global.Fca.Require.fs.writeFileSync(process.cwd() + "/ConfigFca.json", JSON.stringify(global.Fca.Require.FastConfig, null, "\t"));
359
+ process.exit(1);
360
+ }
361
+ }
362
+ else {
363
+ if (Data.HasProblem == true || Data.ForceUpdate == true) {
364
+ let TimeStamp = Database(true).get('Instant_Update');
365
+ if (TimeStamp == null || TimeStamp == undefined || Date.now() - TimeStamp > 500) {
366
+ var Instant_Update = require('./Extra/Src/Instant_Update.js');
367
+ await Instant_Update()
368
+ }
369
+ }
370
+ else {
371
+ let TimeStamp = Database(true).get('Check_Update');
372
+ if (TimeStamp == null || TimeStamp == undefined || Date.now() - TimeStamp > 300000) {
373
+ var Check_Update = require('./Extra/Src/Check_Update.js');
374
+ await Check_Update()
375
+ }
376
+ }
377
+ }
378
+ return login(loginData, options, callback);
379
+ }).catch(function(err) {
380
+ console.log(err)
381
+ log.error("[ FCA-UPDATE ] •",Language.UnableToConnect);
382
+ log.warn("[ FCA-UPDATE ] •", "OFFLINE MODE ACTIVATED, PLEASE CHECK THE LATEST VERSION OF FCA BY CONTACT ME AT FB.COM/LAZIC.KANZU");
383
+ return login(loginData, options, callback);
384
+ });
385
+ };
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2023 KanzuWakazaki
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,223 @@
1
+ [
2
+ {
3
+ "Language": "vi",
4
+ "Folder": {
5
+ "Index": {
6
+ "ErrAppState": "Appstate - Cookie Của Bạn Đã Bị Lỗi, Hãy Thay Cái Mới, Hoặc Vô Trình Duyệt Ẩn Danh Rồi Đăng Nhập Và Thử Lại !",
7
+ "CheckPointLevelI": "Phát Hiện CheckPoint - Không Đăng Nhập Được, Hãy Thử Logout Rồi Login Và Lấy Lại Appstate - Cookie !",
8
+ "UID": "Đăng Nhập Tại ID: %1",
9
+ "Area": "Vùng Của Tài Khoản Là: %1",
10
+ "NoAreaData": "Không Thể Lấy Vùng Của Tài Khoản !",
11
+ "OnLogin": "Đang Đăng Nhập ...",
12
+ "InvaildAccount": "Sai Mật Khẩu Hoặc Tài Khoản !",
13
+ "TwoAuth": "Bạn Đang Bật 2 Bảo Mật !",
14
+ "InvaildTwoAuthCode": "Sai Mã Hai Bảo Mật !",
15
+ "ApprovalsErr": "Lỗi Khi Đăng Nhập Với Hai Bảo Mật !",
16
+ "VerifiedCheck": "Xác Nhận Từ Trình Duyệt, Đang Đăng Nhập...",
17
+ "ForceLoginNotEnable": "Không Thể Đăng Nhập, Hãy Thử Bật 'forceLogin' !",
18
+ "SubmitErrSuccess": "Đã Gửi Báo Cáo Lỗi Tới Server !",
19
+ "ErrorWhileSendErr": "Đã Xảy Ra Lỗi Khi Cố Gửi Lỗi Đến Server !",
20
+ "OnProcess": "Khởi Động Tiến Trình Đăng Nhập !",
21
+ "BackupNoti": "Đang Thay AppState Từ Backup, Nếu Điều Này Tiếp Tục Diễn Ra, Hãy Liên Hệ Với Fb.com/Lazic.Kanzu",
22
+ "ErrGetPassWord": "Lỗi Khi Lấy Mật Khẩu Mã Hoá AppState !",
23
+ "ErrGenerateKey": "Lỗi Khi Tạo Mật Khẩu Cho AppState !",
24
+ "UnsupportedDevice": "Hệ Điều Hành Của Bạn Hiện Không Được Hỗ Trợ !",
25
+ "NotReadyToDecrypt": "Chưa Sẵn Sàng Để Giải Hóa Appstate !",
26
+ "DecryptSuccess": "Giải Hóa Appstate Thành Công !",
27
+ "ErrBackup": "Lỗi Khi Sao Lưu AppState, Hãy Thay AppState !",
28
+ "DecryptFailed": "Giải Hóa Không Thành Công, Hãy Thử Thay AppState !",
29
+ "InvaildAppState": "Không Nhận Dạng Được AppState, Xin Vui Lòng Thay AppState !",
30
+ "YourAppStatePass": "Mật Khẩu AppState Của Bạn Là: %1",
31
+ "BackupFailed": "Sao Lưu AppState Không Thành Công !",
32
+ "ScreenShotConsoleAndSendToAdmin": "Chụp Lại Màn Hình Dòng Này Và Gửi Vô Facebook: Fb.com/Lazic.Kanzu",
33
+ "DoneLogin": "Hoàn Thành Quá Trình Đăng Nhập !",
34
+ "AutoCheckUpdateFailure": "Lỗi Khi Kiểm Tra Cập Nhật, Vui Lòng Thử Lại Sau !",
35
+ "AutoCheckUpdate": "Đang Kiểm Tra Bản Cập Nhật !",
36
+ "NewVersionFound": "Phiên Bản Mới Đã Được Cập Nhật: %1 => %2",
37
+ "AutoUpdate": "Tiến Hành Tự Động Cập Nhật Lên Phiên Bản Mới Nhất !",
38
+ "UpdateSuccess": "Nâng Cấp Phiên Bản Thành Công !",
39
+ "RestartAfterUpdate": "Đang Khởi Động Lại Để Phiên Bản Mới Có Hiệu Lực !",
40
+ "UpdateFailed": "Lỗi Khi Nâng Cấp Lên Phiên Bản Mới Nhất !",
41
+ "UseSupportToolAfterUpdateFailed": "Nâng Cấp Thức Bại, Tiến Hành Sử Dụng Công Cụ Hỗ Trợ !",
42
+ "InstallSupportTool": "Đang Tải Dụng Cụ Hộ Trợ Cho Fca !",
43
+ "NotiAfterUseToolFail": "Hãy Tự Fix Bằng Cách Nhập:",
44
+ "LocalVersion": "Phiên Bản Đang Dùng Hiện Tại Là: %1 !",
45
+ "EncryptSuccess": "Mã Hoá AppState Thành Công !",
46
+ "ProcessDone": "Kết Thúc Với: %1 !",
47
+ "CountTime": "Tổng Thời Gian Bạn Sử Dụng: %1",
48
+ "InvaildMainColor": "%1 Không Phải Là Một Màu Hex !",
49
+ "IsNotABoolean": "%1 Không Phải Là Một Boolean, Cần Là true Hoặc false !",
50
+ "InvaildOption": "%1 Không Phải Là Một Lựa Chọn !",
51
+ "EncryptStateOff": "Tính Năng EncryptState Đã Bị Tắt !",
52
+
53
+ "AutoLogin": "AutoLogin Đang Bật, Tiến Hành Đăng Nhập Lại !",
54
+ "TypeAccount": "Hãy Nhập Tài Khoản: ",
55
+ "TypePassword": "Hãy Nhập Mật Khẩu: ",
56
+ "TypeAccountError": "Tài Khoản Cần Là ID Hoặc Số Điện Thoại Hay Là Gmail !",
57
+ "ErrDataBase": "Lỗi Khi Đặt Dữ Liệu Auto Login !",
58
+ "SuccessSetData": "Đã Đặt Dữ Liệu Auto Login Thành Công !",
59
+ "Missing": "Bạn Vui Lòng Ghi Mã 2Fa Theo Hướng Dẫn Của Ảnh Trong FastConfigFca.json Dòng AuthString !",
60
+
61
+ "EnterSecurityCode": "Hãy Nhập Mã Xác Thực 2 Yếu Tố Của Bạn: ",
62
+ "ErrThroughCookies": "Đã Xảy Ra Lỗi Khi Xuyên 2Fa, Hãy Nhập Mã 2Fa Lại !",
63
+
64
+ "NodeVersionNotSupported": "Phiên Bản: %1 Không Được Hỗ Trợ, Tự Động Tải Phiên Bản Nodejs V14",
65
+ "UsingNVM": "Bạn đang sử dụng nvm để control node version, hãy bấm 'nvm install 14.17.0' sau đó bấm 'nvm use 14.17.0' để chuyển sang phiên bản được hỗ trợ !",
66
+ "DownloadingNode": "Đang tải phiên bản Node V14 Được Hỗ Trợ !",
67
+ "NodeDownloadingComplete": "Tải Phiên Bản Node V14 Thành Công !",
68
+ "RestartRequire": "Tải Thành Công, Yêu Cầu Người Dùng Restart Máy Để Có Tác Dụng!",
69
+ "ErrNodeDownload": "Đã Xảy Ra Lỗi Trong Lúc Tự Động Tải Node Phiên Bản 14, Hãy Liên Hệ Fb.com/Lazic.Kanzu!",
70
+ "RestartingN": "Đang Khởi Động Lại Chương Trình",
71
+ "Rebuilding": "Đang Rebuild Lại Package NPM tránh lỗi !",
72
+ "ErrRebuilding": "Đã Sảy Ra Lỗi Tại Khu Vực Rebuilding - npm install",
73
+ "SuccessRebuilding": "Rebuilding Thành Công !",
74
+ "UnableToConnect": "Đã Sảy Ra Lỗi Trong Lúc Kết Nối Tới Máy Chủ Instant Action, Hãy Kiểm Tra Lại Wifi!",
75
+ "EVMChange": "Đang Thay Đổi Replit.nix Để Hỗ Trợ Node V14!",
76
+ "EVMChangeSuccess": "Thay Đổi Replit.nix Thành Công, Tiến Hành Restarting!",
77
+
78
+ "Ws_TypeUserName": "Hãy Nhập Một UserName Cho Tài Khoản Websocket Extension của bạn: ",
79
+ "Ws_TypePassWord": "Hãy Nhập Một Mật Khẩu Cho Tài Khoản WebSocket Extension của bạn : ",
80
+ "Ws_Success": "Đặt Dữ Liệu Cho Websocket Extension Thành Công !",
81
+ "Ws_2Fa": "Đây là mã xác thực 2 yếu tố(2FA) của bạn cho Horizon_Extension, hãy sử dụng Google Authenticator để lấy mã phòng trường hợp quên mật khẩu hoặc yêu cầu xác minh !\n\n=> Đây: %1",
82
+ "Ws_2Fa_Check": "Hãy nhập mã 2Fa của bạn từ ứng dụng xác thực: ",
83
+
84
+ "WishMessage": [
85
+ "Chúc Bạn Một Ngày Tốt Lành Nhé !",
86
+ "Hãy Báo Cáo Với Admin Khi Có Lỗi Fca Nhé !",
87
+ "Cảm Ơn Đã Sử Dụng Fca Của Horizon !",
88
+ "Donate Tại: Momo: 0946838477",
89
+ "Fork By ZeidTeam"
90
+ ]
91
+ },
92
+ "ExtraGetThread": {
93
+ "CreateDatabaseSuccess": "Khởi Tạo Thành Công Database Cho Nhóm: %1",
94
+ "CreateDatabaseFailure": "Khởi Tạo Thất Bại Database Của Nhóm: %1",
95
+ "alreadyUpdate": "%1 Đã Sẵn Sàng Để Update Database",
96
+ "updateDataSuccess": "Cập Nhật Dữ Liệu Cho Nhóm %1 Thành Công !",
97
+ "updateDataFailure": "Cập Nhật Dữ Liệu Cho Nhóm %1 Thất Bại !"
98
+ },
99
+ "ExtraUpTime": {
100
+ "Uptime": "Kết Nối Đến Server Uptime Thành Công !",
101
+ "PM2": "Đang Vào Chế Độ Uptime !",
102
+ "InPm2Mode": "Bạn Đang Ở Chế Độ Uptime PM2",
103
+ "NotSupport": "Không Hỗ Trợ Uptime Server!",
104
+ "Maintenance": "Server Uptime Đang Bảo Trì, Hãy Thử Lại Sau !"
105
+ },
106
+ "Src": {
107
+ "AutoRestart": "Tự Động Khởi Động Lại Sau: %1 Phút Nữa !",
108
+ "OnRestart": "Đang Restart..."
109
+ },
110
+ "ExtraAutoGetAppState": {
111
+ "StartAutoGetAppState": "Khởi Động Chức Năng Auto Get AppState",
112
+ "GetAppState": "Đang Tiến Hành Lấy AppState Mới",
113
+ "Restart": "Đã Làm Mới AppState, Đang Tiến Hành Khởi Động Lại"
114
+ }
115
+ }
116
+ },
117
+ {
118
+ "Language": "en",
119
+ "Folder": {
120
+ "Index": {
121
+ "ErrAppState": "Appstate - Your Cookie Is Wrong, Please Replace It, Or Go To Incognito Browser Then Sign In And Try Again !",
122
+ "CheckPointLevelI": "CheckPoint Detected - Can't Login, Try Logout Then Login And Retrieve Appstate - Cookie !",
123
+ "UID": "Login as ID: %1",
124
+ "Area": "Area Of Account Is: %1",
125
+ "NoAreaData": "Can't Get Area Of Account !",
126
+ "OnLogin": "Currently logged ...",
127
+ "InvaildAccount": "Wrong Password Or Account !",
128
+ "TwoAuth": "You Currently On 2 Factor Security !",
129
+ "InvaildTwoAuthCode": "Wrong Code Two Factor Security !",
130
+ "ApprovalsErr": "Error When Login With Two Factor Security !",
131
+ "VerifiedCheck": "Confirm From Browser, Logging In...",
132
+ "ForceLoginNotEnable": "Can't Login, Try Enable 'forceLogin' !",
133
+ "SubmitErrSuccess": "Error Report Sent To Server !",
134
+ "ErrorWhileSendErr": "An error occurred while trying to send an error to the server !",
135
+ "OnProcess": "Start the Login Process !",
136
+ "BackupNoti": "Changing AppState From Backup, If This Continues, Contact Fb.com/Lazic.Kanzu",
137
+ "ErrGetPassWord": "Error Retrieving AppState Encryption Password !",
138
+ "ErrGenerateKey": "Error Creating Password For AppState !",
139
+ "UnsupportedDevice": "Your Operating System Is Currently Not Supported !",
140
+ "NotReadyToDecrypt": "Not Ready To Solve Appstate !",
141
+ "DecryptSuccess": "Successfully Appstate Solved !",
142
+ "ErrBackup": "Error When Backing Up AppState, Please Replace AppState !",
143
+ "DecryptFailed": "Solution Failed, Try Replacing AppState !",
144
+ "InvaildAppState": "AppState Not Recognized, Please Replace AppState !",
145
+ "YourAppStatePass": "Your AppState Password Is: %1",
146
+ "BackupFailed": "AppState Backup Failed !",
147
+ "ScreenShotConsoleAndSendToAdmin": "Take a Screenshot of This Line And Send It To Facebook: Fb.com/Lazic.Kanzu",
148
+ "DoneLogin": "Complete the Login Process !",
149
+ "AutoCheckUpdate": "Checking for Updates !",
150
+ "NewVersionFound": "New Version, Ready to Update: %1 => %2",
151
+ "AutoUpdate": "Perform Automatic Update to the Latest Version !",
152
+ "UpdateSuccess": "Upgrade Version Successfully !",
153
+ "RestartAfterUpdate": "Rebooting For New Version To Take Effect !",
154
+ "UpdateFailed": "Error When Upgrading To Latest Version !",
155
+ "UseSupportToolAfterUpdateFailed": "Upgrade Failed, Proceed to Using Support Tools !",
156
+ "InstallSupportTool": "Loading Support Tools For FCA !",
157
+ "NotiAfterUseToolFail": "Please Fix It Yourself By Entering:",
158
+ "LocalVersion": "You Are Currently Using Version: %1 !",
159
+ "EncryptSuccess": "Encrypt Appstate Success !",
160
+ "ProcessDone": "Process Done: %1 !",
161
+ "InvaildMainColor": "%1 Is Not A Hex Color Code !",
162
+ "IsNotABoolean": "%1 Is Not A Boolean, Need To Be true Or false !",
163
+ "EncryptStateOff": "Encryption Has Been Turned Off !",
164
+ "InvaildOption": "Invail Option: %1",
165
+ "CountTime": "Total Time You Use: %1",
166
+
167
+ "AutoLogin": "AutoLogin Is On, Proceed to Log Back in!",
168
+ "TypeAccount": "Enter Account: ",
169
+ "TypePassword": "Enter a Password: ",
170
+ "TypeAccountError": "The account needs to be an ID or Phone number or Gmail!",
171
+ "ErrDataBase": "Error When Setting Auto Login Data !",
172
+ "SuccessSetData": "Auto Login Data Set Successfully !",
173
+ "Missing": "Please Code 2Fa According to the Photo's Guide in FastConfigFca.json Series AuthString!",
174
+ "EnterSecurityCode": "Enter your 2-Factor Authentication Code: ",
175
+ "ErrThroughCookies": "2Fa Piercing Error Occurred, Enter Code 2Fa Again! ",
176
+
177
+ "NodeVersionNotSupported": "Version: %1 is not supported, automatically download nodejs version v14",
178
+ "UsingNVM": "You are using nvm to control node version, please type 'nvm install 14.17.0' then type 'nvm use 14.17.0' to switch to the supported version!",
179
+ "DownloadingNode": "Downloading node version v14 which is supported!",
180
+ "NodeDownloadingComplete": "Successfully downloaded node version v14!",
181
+ "RestartRequire": "Download successful, user needs to restart the computer to take effect!",
182
+ "ErrNodeDownload": "An error occurred while automatically downloading node version 14, please contact fb.com/lazic.kanzu!",
183
+ "RestartingN": "Restarting the program",
184
+ "Rebuilding": "Rebuilding npm package to avoid errors !",
185
+ "ErrRebuilding": "An error occurred in the rebuilding area - npm install",
186
+ "SuccessRebuilding": "Successfully rebuilt !",
187
+ "UnableToConnect": "An error occurred while connecting to the instant action server, please check your wifi connection!",
188
+ "EVMChange": "Changing replit.nix to support node v14!",
189
+ "EVMChangeSuccess": "Successfully changed replit.nix, go ahead and restart!",
190
+
191
+ "Ws_TypeUserName": "Please enter a username for your websocket extension account: ",
192
+ "Ws_TypePassWord": "Please enter a password for your websocket extension account: ",
193
+ "Ws_Success": "Successfully set data for websocket extension!",
194
+ "Ws_2Fa": "This is your two-factor authentication (2FA) code for horizon_extension. Please use Google Authenticator to retrieve the backup code in case you forget your password or require verification.\n\n=> Here: %1",
195
+ "Ws_2Fa_Check": "Please enter your 2FA code from the authentication app: ",
196
+
197
+ "WishMessage": [
198
+ "Have a Nice Day !",
199
+ "Please Report To Admin When There Is Error in FCA !",
200
+ "Thank You For Using Horizon's FCA !"
201
+ ]
202
+ },
203
+ "ExtraGetThread": {
204
+ "CreateDatabaseSuccess": "Successfully Initiate Database for Group: %1",
205
+ "CreateDatabaseFailure": "Initialization of Group Database Failure: %1",
206
+ "alreadyUpdate": "%1 Ready to Update Database",
207
+ "updateDataSuccess": "Data Update for Group %1 Success!",
208
+ "updateDataFailure": "Data Update for Group %1 Failed!"
209
+ },
210
+ "ExtraUpTime": {
211
+ "Uptime": "Connecting To Server Uptime Succeeds!",
212
+ "PM2": "Trying to PM2 Mode!",
213
+ "InPm2Mode": "You Are In Uptime PM2 Mode !",
214
+ "NotSupport": "Your Operating System does not currently support Uptime Server !",
215
+ "Maintenance": "Server Uptime In Maintenance, Try Again Later!"
216
+ },
217
+ "Src": {
218
+ "AutoRestart": "Automatically Restart After: %1 Minutes !",
219
+ "OnRestart": "Restarting..."
220
+ }
221
+ }
222
+ }
223
+ ]