koja-uptime-fca 12.9.6

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

Potentially problematic release.


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

Files changed (90) hide show
  1. package/.cache/replit/__replit_disk_meta.json +1 -0
  2. package/.cache/replit/modules.stamp +0 -0
  3. package/.cache/replit/nix/env.json +1 -0
  4. package/.gitattributes +2 -0
  5. package/.travis.yml +6 -0
  6. package/CHANGELOG.md +4 -0
  7. package/DOCS.md +1738 -0
  8. package/Extra/ExtraAddons.js +78 -0
  9. package/Extra/ExtraFindUID.js +60 -0
  10. package/Extra/ExtraGetThread.js +118 -0
  11. package/Extra/ExtraTranslate.js +62 -0
  12. package/Extra/Src/Last-Run.js +65 -0
  13. package/GetThreadInfo.js +118 -0
  14. package/LICENSE-MIT +21 -0
  15. package/Readme.md +87 -0
  16. package/StateCrypt.js +28 -0
  17. package/base/Data-Vegito.js +358 -0
  18. package/base/test.js +3 -0
  19. package/broadcast.js +1 -0
  20. package/index.js +687 -0
  21. package/languages/languages.json +123 -0
  22. package/logger.js +1 -0
  23. package/package.json +122 -0
  24. package/src/ReportV1.js +55 -0
  25. package/src/addExternalModule.js +16 -0
  26. package/src/addUserToGroup.js +78 -0
  27. package/src/changeAdminStatus.js +79 -0
  28. package/src/changeArchivedStatus.js +41 -0
  29. package/src/changeAvt.js +86 -0
  30. package/src/changeBio.js +65 -0
  31. package/src/changeBlockedStatus.js +36 -0
  32. package/src/changeGroupImage.js +106 -0
  33. package/src/changeNickname.js +45 -0
  34. package/src/changeThreadColor.js +62 -0
  35. package/src/changeThreadEmoji.js +42 -0
  36. package/src/createNewGroup.js +70 -0
  37. package/src/createPoll.js +60 -0
  38. package/src/data/getThreadInfo.json +1 -0
  39. package/src/deleteMessage.js +45 -0
  40. package/src/deleteThread.js +43 -0
  41. package/src/forwardAttachment.js +48 -0
  42. package/src/forwardMessage.js +0 -0
  43. package/src/getAccessToken.js +33 -0
  44. package/src/getCurrentUserID.js +7 -0
  45. package/src/getEmojiUrl.js +27 -0
  46. package/src/getFriendsList.js +73 -0
  47. package/src/getMessage.js +79 -0
  48. package/src/getThreadHistory.js +537 -0
  49. package/src/getThreadHistoryDeprecated.js +71 -0
  50. package/src/getThreadInfo.js +206 -0
  51. package/src/getThreadInfoDeprecated.js +56 -0
  52. package/src/getThreadList.js +213 -0
  53. package/src/getThreadListDeprecated.js +46 -0
  54. package/src/getThreadMain.js +219 -0
  55. package/src/getThreadPictures.js +59 -0
  56. package/src/getUserID.js +62 -0
  57. package/src/getUserInfo.js +66 -0
  58. package/src/getUserInfoMain.js +65 -0
  59. package/src/getUserInfoV2.js +35 -0
  60. package/src/getUserInfoV3.js +63 -0
  61. package/src/getUserInfoV4.js +55 -0
  62. package/src/getUserInfoV5.js +61 -0
  63. package/src/handleFriendRequest.js +46 -0
  64. package/src/handleMessageRequest.js +49 -0
  65. package/src/httpGet.js +49 -0
  66. package/src/httpPost.js +48 -0
  67. package/src/httpPostFormData.js +41 -0
  68. package/src/listen.js +553 -0
  69. package/src/listenMqtt.js +629 -0
  70. package/src/logout.js +68 -0
  71. package/src/markAsDelivered.js +48 -0
  72. package/src/markAsRead.js +70 -0
  73. package/src/markAsReadAll.js +43 -0
  74. package/src/markAsSeen.js +51 -0
  75. package/src/muteThread.js +47 -0
  76. package/src/removeUserFromGroup.js +49 -0
  77. package/src/resolvePhotoUrl.js +37 -0
  78. package/src/searchForThread.js +43 -0
  79. package/src/sendMessage.js +381 -0
  80. package/src/sendTypingIndicator.js +80 -0
  81. package/src/setMessageReaction.js +109 -0
  82. package/src/setPostReaction.js +102 -0
  83. package/src/setTitle.js +74 -0
  84. package/src/threadColors.js +39 -0
  85. package/src/unfriend.js +43 -0
  86. package/src/unsendMessage.js +40 -0
  87. package/test/example-config.json +18 -0
  88. package/test/test-page.js +140 -0
  89. package/test/test.js +385 -0
  90. package/utils.js +2476 -0
@@ -0,0 +1,78 @@
1
+ var utils = require('../utils');
2
+ var logger = require('../logger')
3
+ var OTP = require('totp-generator');
4
+
5
+ module.exports.getInfo = async function (id,jar,ctx,defaultFuncs) {
6
+ var AccessToken = await module.exports.getAccessToken(jar,ctx,defaultFuncs);
7
+ var { body:Data } = await utils.get(`https://graph.facebook.com/${id}?fields=name,first_name,email,about,birthday,gender,website,hometown,link,location,quotes,relationship_status,significant_other,username,subscribers.limite(0)&access_token=${AccessToken}`,jar,null,ctx.globalOptions);
8
+ var Format = {
9
+ id: JSON.parse(Data).id || "No Deta",
10
+ name: JSON.parse(Data).name || "No Deta",
11
+ first_name: JSON.parse(Data).first_name || "No Deta",
12
+ username: JSON.parse(Data).username || "No Deta",
13
+ link: JSON.parse(Data).link || "No Deta",
14
+ verified: JSON.parse(Data).verified || "No Deta",
15
+ about: JSON.parse(Data).about || "No Deta",
16
+ avatar: `https://graph.facebook.com/${id}/picture?height=1500&width=1500&access_token=1449557605494892|aaf0a865c8bafc314ced5b7f18f3caa6` || "No Deta",
17
+ birthday: JSON.parse(Data).birthday || "No Deta",
18
+ follow: JSON.parse(Data).subscribers.summary.total_count || "No Deta",
19
+ gender: JSON.parse(Data).gender || "No Deta",
20
+ hometown: JSON.parse(Data).hometown || "No Deta",
21
+ email: JSON.parse(Data).email || "No Deta",
22
+ interested_in: JSON.parse(Data).interested_in || "No data",
23
+ location: JSON.parse(Data).location || "No Deta",
24
+ locale: JSON.parse(Data).locale || "No Deta",
25
+ relationship_status: JSON.parse(Data).relationship_status || "No Deta",
26
+ love: JSON.parse(Data).significant_other || "No Deta",
27
+ website: JSON.parse(Data).website || "No Deta",
28
+ quotes: JSON.parse(Data).quotes || "No Deta",
29
+ timezone: JSON.parse(Data).timezone || "No Deta",
30
+ updated_time: JSON.parse(Data).updated_time || "No Deta"
31
+ }
32
+ return Format;
33
+ }
34
+
35
+ /**
36
+ * Help: @ManhG
37
+ * Author: @KanzuWakazaki
38
+ */
39
+
40
+ module.exports.getAccessToken = async function (jar, ctx,defaultFuncs) {
41
+ if (global.Fca.Data.AccessToken) {
42
+ return global.Fca.Data.AccessToken;
43
+ }
44
+ else {
45
+ var netURLS = "https://business.facebook.com/security/twofactor/reauth/enter/"
46
+ return defaultFuncs.get('https://business.facebook.com/business_locations', jar, null, ctx.globalOptions).then(async function(data) {
47
+ try {
48
+ if (/"],\["(.*?)","/.exec(/LMBootstrapper(.*?){"__m":"LMBootstrapper"}/.exec(data.body)[1])[1]) {
49
+ global.Fca.Data.AccessToken = /"],\["(.*?)","/.exec(/LMBootstrapper(.*?){"__m":"LMBootstrapper"}/.exec(data.body)[1])[1];
50
+ return /"],\["(.*?)","/.exec(/LMBootstrapper(.*?){"__m":"LMBootstrapper"}/.exec(data.body)[1])[1];
51
+ }
52
+ }
53
+ catch (_) {
54
+ if (global.Fca.Require.FastConfig.AuthString.includes('|')) return logger.Error(global.Fca.Require.Language.Index.Missing)
55
+ var OPTCODE = global.Fca.Require.FastConfig.AuthString.includes(" ") ? global.Fca.Require.FastConfig.AuthString.replace(RegExp(" ", 'g'), "") : global.Fca.Require.FastConfig.AuthString;
56
+ var Form = {
57
+ approvals_code: OTP(String(OPTCODE)),
58
+ save_device: true,
59
+ lsd: utils.getFrom(data.body, "[\"LSD\",[],{\"token\":\"", "\"}")
60
+ }
61
+ return defaultFuncs.post(netURLS, jar, Form, ctx.globalOptions, {
62
+ referer: "https://business.facebook.com/security/twofactor/reauth/?twofac_next=https%3A%2F%2Fbusiness.facebook.com%2Fbusiness_locations&type=avoid_bypass&app_id=0&save_device=1",
63
+ }).then(async function(data) {
64
+ if (String(data.body).includes(false)) throw { Error: "Invaild OTP | FastConfigFca.json: AuthString" }
65
+ return defaultFuncs.get('https://business.facebook.com/business_locations', jar, null, ctx.globalOptions,{
66
+ referer: "https://business.facebook.com/security/twofactor/reauth/?twofac_next=https%3A%2F%2Fbusiness.facebook.com%2Fbusiness_locations&type=avoid_bypass&app_id=0&save_device=1",
67
+ }).then(async function(data) {
68
+ var Access_Token = /"],\["(.*?)","/.exec(/LMBootstrapper(.*?){"__m":"LMBootstrapper"}/.exec(data.body)[1])[1];
69
+ global.Fca.Data.AccessToken = Access_Token;
70
+ return Access_Token;
71
+ });
72
+ });
73
+ }
74
+ })
75
+ }
76
+ }
77
+
78
+ //hard working =))
@@ -0,0 +1,60 @@
1
+ const got = global.Fca.Require.Fetch;
2
+
3
+ /**
4
+ * @param {string | URL} url
5
+ * @param {{ sendMessage: (arg0: string, arg1: any) => any; }} api
6
+ */
7
+ async function getUIDSlow(url,api) {
8
+ var FormData = require("form-data");
9
+ var Form = new FormData();
10
+ var Url = new URL(url);
11
+ Form.append('username', Url.pathname.replace(/\//g, ""));
12
+ try {
13
+ var data = await got.post('https://api.findids.net/api/get-uid-from-username',{
14
+ body: Form,
15
+ userAgent: 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.79 Safari/537.36'
16
+ })
17
+ } catch (e) {
18
+ console.log(global.Fca.Data.event.threadID,e)
19
+ return api.sendMessage("Lỗi: " + e.message,global.Fca.Data.event.threadID);
20
+ }
21
+ if (JSON.parse(data.body.toString()).status != 200) return api.sendMessage('Đã bị lỗi !',global.Fca.Data.event.threadID)
22
+ if (typeof JSON.parse(data.body.toString()).error === 'string') return "errr"
23
+ else return JSON.parse(data.body.toString()).data.id || "nịt";
24
+ }
25
+
26
+ /**
27
+ * @param {string | URL} url
28
+ * @param {{ sendMessage: (arg0: string, arg1: any, arg2: any) => any; }} api
29
+ */
30
+ async function getUIDFast(url,api) {
31
+ var FormData = require("form-data");
32
+ var Form = new FormData();
33
+ var Url = new URL(url);
34
+ Form.append('link', Url.href);
35
+ try {
36
+ var data = await got.post('https://id.traodoisub.com/api.php',{
37
+ body: Form
38
+ })
39
+ } catch (e) {
40
+ return api.sendMessage("Lỗi: " + e.message,global.Fca.Data.event.threadID,global.Fca.Data.event.messageID);
41
+ }
42
+ if (JSON.parse(data.body.toString()).error) return api.sendMessage(JSON.parse(data.body.toString()).error,global.Fca.Data.event.threadID,global.Fca.Data.event.messageID);
43
+ else return JSON.parse(data.body.toString()).id || "co cai nit huhu";
44
+ }
45
+
46
+ /**
47
+ * @param {any} url
48
+ * @param {any} api
49
+ */
50
+ async function getUID(url,api) {
51
+ var getUID = await getUIDFast(url,api);
52
+ if (!isNaN(getUID) == true) return getUID;
53
+ else {
54
+ let getUID = await getUIDSlow(url,api);
55
+ if (!isNaN(data) == true) return getUID;
56
+ else return null;
57
+ }
58
+ }
59
+
60
+ module.exports = getUID;
@@ -0,0 +1,118 @@
1
+ /* eslint-disable */
2
+ "use strict";
3
+ var Database = require("../base/Data-Vegito");
4
+ var { lastRun,capture } = require('./Src/Last-Run');
5
+ var logger = require("../logger");
6
+ var getText = global.Fca.getText;
7
+ var language = require("../Language/index.json");
8
+ language = language.find(i => i.Language == require("../../../Koja-Jutt.json").Language).Folder.ExtraGetThread;
9
+
10
+ exports.createData = function(threadID,threadData) {
11
+ try {
12
+ Database.set(String(threadID),Object(threadData),true);
13
+ logger.Normal(getText(language.CreateDatabaseSuccess,String(threadID)));
14
+ }
15
+ catch (e) {
16
+ console.log(e);
17
+ logger.Warning(getText(language.CreateDatabaseFailure,String(threadID)));
18
+ }
19
+ }
20
+
21
+ exports.updateData = function(threadID,threadData) {
22
+ try {
23
+ Database.set(String(threadID),Object(threadData),true);
24
+ logger.Normal(getText(language.updateDataSuccess,String(threadID)));
25
+ }
26
+ catch (e) {
27
+ console.log(e);
28
+ logger.Warning(getText(language.updateDataFailure,String(threadID)));
29
+ }
30
+ }
31
+
32
+ exports.updateMessageCount = function(threadID,threadData) {
33
+ try {
34
+ Database.set(String(threadID),Object(threadData),true);
35
+ }
36
+ catch (e) {
37
+ console.log(e);
38
+ }
39
+ }
40
+
41
+ exports.getData = function(threadID) {
42
+ switch (Database.has(String(threadID),true)) {
43
+ case true: {
44
+ return Database.get(String(threadID),{},true)
45
+ }
46
+ case false: {
47
+ return null;
48
+ }
49
+ }
50
+ }
51
+
52
+ exports.deleteAll = function(data) {
53
+ for (let i of data) {
54
+ Database.delete(String(i),true);
55
+ }
56
+ }
57
+
58
+ exports.getAll = function() {
59
+ return Database.list(true);
60
+ }
61
+
62
+ exports.hasData = function(threadID) {
63
+ return Database.has(String(threadID),true);
64
+ }
65
+
66
+ exports.alreadyUpdate = function(threadID) {
67
+ var Time = Database.get(String(threadID),{},true).TimeUpdate;
68
+ try {
69
+ if (global.Fca.startTime >= (Time + (3600 * 1000))) {
70
+ logger.Normal(getText(language.alreadyUpdate, String(threadID)));
71
+ return true;
72
+ }
73
+ else return false;
74
+ }
75
+ catch (e) {
76
+ console.log(e);
77
+ return true;
78
+ }
79
+ }
80
+
81
+ exports.readyCreate = function(Name) {
82
+ switch (Database.has(String(Name),true)) {
83
+ case true: {
84
+ if (Number(global.Fca.startTime) >= Number(Database.get(String(Name),{},true) + (120 * 1000))) {
85
+ return true;
86
+ }
87
+ else {
88
+ return false;
89
+ }
90
+ }
91
+ case false: {
92
+ return false;
93
+ }
94
+ }
95
+ }
96
+
97
+ exports.setLastRun = function(Name,LastRun) {
98
+ Database.set(String(Name),String(lastRun(LastRun)),true);
99
+ }
100
+
101
+ exports.getLastRun = function(Name) {
102
+ switch (Database.has(String(Name),true)) {
103
+ case true: {
104
+ return Database.get(String(Name),{},true);
105
+ }
106
+ case false: {
107
+ try {
108
+ capture(Name)
109
+ this.setLastRun(Name,Name);
110
+ return Database.get(String(Name),{},true);
111
+ }
112
+ catch(e) {
113
+ console.log(e);
114
+ return Date.now();
115
+ }
116
+ }
117
+ }
118
+ }
@@ -0,0 +1,62 @@
1
+ // Credit: Kb2a Team
2
+
3
+ var fetch = require("got")
4
+
5
+ /**
6
+ * Translate a text from <from> to <to> using Bing engine
7
+ * @async
8
+ * @method bing
9
+ * @param {string} text Text to be translated
10
+ * @param {string} from Source language
11
+ * @param {string} to Destination language
12
+ * @return {string} Translated text
13
+ * @example
14
+ * await bing("xin chào kẻ mạo danh", "vi", "en") // => "hello impostor"
15
+ */
16
+ async function bing(text, from, to) {
17
+ const body = await fetch.get(`http://api.microsofttranslator.com/V2/Ajax.svc/Translate?appId=68D088969D79A8B23AF8585CC83EBA2A05A97651&from=${from}&to=${to}&text=${text}`).text()
18
+ return body.replace(/\"/g,'')
19
+ }
20
+
21
+ /**
22
+ * Translate a text from <from> to <to> using Google engine
23
+ * @async
24
+ * @method bing
25
+ * @param {string} text Text to be translated
26
+ * @param {string} [from="auto"] Source language
27
+ * @param {string} to Destination language
28
+ * @return {string} Translated text
29
+ * @example
30
+ * await google("giữa chúng ta", null, "en") // => "among us"
31
+ */
32
+
33
+ async function google(text, from, to) {
34
+ const json = await
35
+ fetch
36
+ .get(
37
+ `https://translate.googleapis.com/translate_a/single?client=gtx&sl=${from}&tl=${to}&dt=t&q=${text}
38
+ `)
39
+ .json()
40
+ return json[0][0][0];
41
+ }
42
+
43
+ /**
44
+ * Detect language that the text are using
45
+ * @async
46
+ * @method detect
47
+ * @param {string} text Source text
48
+ * @return {string} language
49
+ * @example
50
+ * await detect("Hello") // => "vi"
51
+ */
52
+
53
+ async function detect(text) {
54
+ const body = await fetch.get(`https://api.microsofttranslator.com/V2/Http.svc/Detect?&appid=68D088969D79A8B23AF8585CC83EBA2A05A97651&text=${text}`);
55
+ return />(.*?)</.exec(body.body)[1]
56
+ }
57
+
58
+ module.exports = {
59
+ bing,
60
+ google,
61
+ detect
62
+ }
@@ -0,0 +1,65 @@
1
+ /* eslint-disable linebreak-style */
2
+ 'use strict';
3
+
4
+ var assert = require('assert');
5
+
6
+ var runtimes = new WeakMap();
7
+
8
+ /**
9
+ * @param {any} fn
10
+ */
11
+ function isFunction(fn) {
12
+ return typeof fn === 'function';
13
+ }
14
+
15
+ /**
16
+ * @param {object} fn
17
+ * @param {string} timeResolution
18
+ */
19
+ function lastRun(fn, timeResolution) {
20
+ assert(isFunction(fn), 'Only functions can check lastRun');
21
+
22
+ var time = runtimes.get(fn);
23
+
24
+ if (time == null) {
25
+ return;
26
+ }
27
+
28
+ var resolution = parseInt(timeResolution, 10) || 1;
29
+ return time - (time % resolution);
30
+ }
31
+
32
+ /**
33
+ * @param {object} fn
34
+ * @param {number} timestamp
35
+ */
36
+ function capture(fn, timestamp) {
37
+ assert(isFunction(fn), 'Only functions can be captured');
38
+
39
+ timestamp = timestamp || Date.now();
40
+
41
+ runtimes.set(fn, timestamp);
42
+ }
43
+
44
+ /**
45
+ * @param {object} name
46
+ */
47
+ function has(name) {
48
+ return runtimes.has(name);
49
+ }
50
+
51
+ /**
52
+ * @param {object} fn
53
+ */
54
+ function release(fn) {
55
+ assert(isFunction(fn), 'Only functions can be captured');
56
+
57
+ runtimes.delete(fn);
58
+ }
59
+
60
+ module.exports = {
61
+ lastRun,
62
+ capture,
63
+ release,
64
+ has
65
+ };
@@ -0,0 +1,118 @@
1
+ /* eslint-disable */
2
+ "use strict";
3
+ var Database = require("./base/Data-Vegito");
4
+ var { lastRun,capture } = require('./Extra/Src/Last-Run');
5
+ var logger = require("../logger");
6
+ var getText = global.Fca.getText;
7
+ var language = require("../Languages/index.json");
8
+ language = language.find(i => i.Language == require("../../../Koja-Jutt.json").Language).Folder.GetThreads;
9
+
10
+ exports.createData = function(threadID,threadData) {
11
+ try {
12
+ Database.set(String(threadID),Object(threadData),true);
13
+ logger.Normal(getText(language.CreateDatabaseSuccess,String(threadID)));
14
+ }
15
+ catch (e) {
16
+ console.log(e);
17
+ logger.Warning(getText(language.CreateDatabaseFailure,String(threadID)));
18
+ }
19
+ }
20
+
21
+ exports.updateData = function(threadID,threadData) {
22
+ try {
23
+ Database.set(String(threadID),Object(threadData),true);
24
+ logger.Normal(getText(language.updateDataSuccess,String(threadID)));
25
+ }
26
+ catch (e) {
27
+ console.log(e);
28
+ logger.Warning(getText(language.updateDataFailure,String(threadID)));
29
+ }
30
+ }
31
+
32
+ exports.updateMessageCount = function(threadID,threadData) {
33
+ try {
34
+ Database.set(String(threadID),Object(threadData),true);
35
+ }
36
+ catch (e) {
37
+ console.log(e);
38
+ }
39
+ }
40
+
41
+ exports.getData = function(threadID) {
42
+ switch (Database.has(String(threadID),true)) {
43
+ case true: {
44
+ return Database.get(String(threadID),{},true)
45
+ }
46
+ case false: {
47
+ return null;
48
+ }
49
+ }
50
+ }
51
+
52
+ exports.deleteAll = function(data) {
53
+ for (let i of data) {
54
+ Database.delete(String(i),true);
55
+ }
56
+ }
57
+
58
+ exports.getAll = function() {
59
+ return Database.list(true);
60
+ }
61
+
62
+ exports.hasData = function(threadID) {
63
+ return Database.has(String(threadID),true);
64
+ }
65
+
66
+ exports.alreadyUpdate = function(threadID) {
67
+ var Time = Database.get(String(threadID),{},true).TimeUpdate;
68
+ try {
69
+ if (global.Fca.startTime >= (Time + (3600 * 1000))) {
70
+ logger.Normal(getText(language.alreadyUpdate, String(threadID)));
71
+ return true;
72
+ }
73
+ else return false;
74
+ }
75
+ catch (e) {
76
+ console.log(e);
77
+ return true;
78
+ }
79
+ }
80
+
81
+ exports.readyCreate = function(Name) {
82
+ switch (Database.has(String(Name),true)) {
83
+ case true: {
84
+ if (Number(global.Fca.startTime) >= Number(Database.get(String(Name),{},true) + (120 * 1000))) {
85
+ return true;
86
+ }
87
+ else {
88
+ return false;
89
+ }
90
+ }
91
+ case false: {
92
+ return false;
93
+ }
94
+ }
95
+ }
96
+
97
+ exports.setLastRun = function(Name,LastRun) {
98
+ Database.set(String(Name),String(lastRun(LastRun)),true);
99
+ }
100
+
101
+ exports.getLastRun = function(Name) {
102
+ switch (Database.has(String(Name),true)) {
103
+ case true: {
104
+ return Database.get(String(Name),{},true);
105
+ }
106
+ case false: {
107
+ try {
108
+ capture(Name)
109
+ this.setLastRun(Name,Name);
110
+ return Database.get(String(Name),{},true);
111
+ }
112
+ catch(e) {
113
+ console.log(e);
114
+ return Date.now();
115
+ }
116
+ }
117
+ }
118
+ }
package/LICENSE-MIT ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2015 Avery, Benjamin, David, Maude
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
13
+ all 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
21
+ THE SOFTWARE.
package/Readme.md ADDED
@@ -0,0 +1,87 @@
1
+ [![Socket Badge](https://socket.dev/api/badge/npm/package/koja-uptime-fca)](https://socket.dev/npm/package/koja-uptime-fca)
2
+
3
+ ## Important !
4
+
5
+ THIS IS UPTIME FCA MADE BY KOJA BABU
6
+ DON'T COPY THIS
7
+ OTHWISE I FUÇK YOU'RE MOTHER✅🥵
8
+
9
+ This package require NodeJS 14.17.0 to work properly.
10
+
11
+ ## Notification !
12
+
13
+
14
+ Original Project(Deprecated): https://github.com/Schmavery/facebook-chat-api
15
+
16
+ ## Support For :
17
+
18
+ + Support English, VietNamese !,
19
+ + All bot if using listenMqtt first.
20
+
21
+ # Api Cho ChatBot Messenger
22
+
23
+ Facebook Already Has And For Users To Create Api For Chatbots 😪 At Dey => [Here](https://developers.facebook.com/docs/messenger-platform).
24
+
25
+ ### This Api Can Make You Payy Acc Like You Never Have, Please Pay Attention =))
26
+
27
+ Note ! If You Want To Share This Api Please See The Document At [Here](https://github.com/Schmavery/facebook-chat-api).
28
+
29
+ ## Download
30
+
31
+ If You Want To Use It, Download It By:
32
+ ```bash
33
+ npm i koja-uptime-fca
34
+ ```
35
+ or
36
+ ```bash
37
+ npm install koja-uptime-fca
38
+ ```
39
+
40
+ It Will Load Into node_modules (Your Lib) - Note Replit Won't Show Where to Find
41
+
42
+ ### Download Latest Version Or Update
43
+
44
+ If You Want To Use The Latest Version Or Update Then Go To Terminal Or Command Prompt Enter :
45
+ ```bash
46
+ npm install koja-uptime-fca@latest
47
+ ```
48
+ Or
49
+ ```bash
50
+ npm i koja-uptime-fca@latest
51
+ ```
52
+
53
+ ## If You Want To Test Api
54
+
55
+ Benefits For This You Will Not Spend Time Paying Acc And Have Acc
56
+ Use it with a Demo Account => [Facebook Whitehat Accounts](https://www.facebook.com/whitehat/
57
+
58
+ ```javascript
59
+ const login = require("koja-uptime-fca"); // lấy từ lib ra
60
+
61
+
62
+ To Save You Need 1 Apstate Type (Cookie, etc,..) To Save Or Use Login Code As Above To Login !
63
+
64
+ And This Mode Is Already Available In Some ALI Bots So You Can Rest In Peace !
65
+
66
+ __Hướng Dẫn Với Appstate__
67
+
68
+ ```js
69
+ const fs = require("fs");
70
+ const login = require("koja-uptime-fca");
71
+
72
+ var credentials = {email: "FB_EMAIL", password: "FB_PASSWORD"}; // thông tin tk
73
+
74
+ login(credentials, (err, api) => {
75
+ if(err) return console.error(err);
76
+ // đăng nhập
77
+ fs.writeFileSync('appstate.json', JSON.stringify(api.getAppState(), null,'\t')); //tạo appstate
78
+ });
79
+ ```
80
+
81
+ Or Easier (Professional) You Can Use => [c3c-fbstate](https://github.com/c3cbot/c3c-fbstate) To Get Fbstate And Rename To Apstate Also ! (appstate.json)
82
+
83
+ ------------------------------------
84
+
85
+ ## FAQS
86
+
87
+ FAQS => [Link](https://github.com/K0J4/kojab0t#FAQS)
package/StateCrypt.js ADDED
@@ -0,0 +1,28 @@
1
+ /* eslint-disable linebreak-style */
2
+ const crypto = require('crypto');
3
+ const aes = require("aes-js");
4
+
5
+ function encryptState(data, key) {
6
+ let hashEngine = crypto.createHash("sha256");
7
+ let hashKey = hashEngine.update(key).digest();
8
+ let bytes = aes.utils.utf8.toBytes(data);
9
+ let aesCtr = new aes.ModeOfOperation.ctr(hashKey);
10
+ let encryptedData = aesCtr.encrypt(bytes);
11
+
12
+ return aes.utils.hex.fromBytes(encryptedData);
13
+ }
14
+
15
+ function decryptState(data, key) {
16
+ let hashEngine = crypto.createHash("sha256");
17
+ let hashKey = hashEngine.update(key).digest();
18
+
19
+ let encryptedBytes = aes.utils.hex.toBytes(data);
20
+ let aesCtr = new aes.ModeOfOperation.ctr(hashKey);
21
+ let decryptedData = aesCtr.decrypt(encryptedBytes);
22
+
23
+ return aes.utils.utf8.fromBytes(decryptedData);
24
+ }
25
+ module.exports = {
26
+ encryptState:encryptState,
27
+ decryptState:decryptState
28
+ };