stfca 1.0.1 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +32 -0
- package/README.md +45 -2
- package/checkUpdate.js +109 -0
- package/index.js +460 -1
- package/package.json +22 -46
- package/src/{api/action/addExternalModule.js → addExternalModule.js} +25 -25
- package/src/addUserToGroup.js +115 -0
- package/src/changeAdminStatus.js +103 -0
- package/src/changeArchivedStatus.js +55 -0
- package/src/{api/action/changeAvatar.js → changeAvatar.js} +136 -137
- package/src/changeAvatarV2.js +86 -0
- package/src/changeAvt.js +85 -0
- package/src/{api/action/changeBio.js → changeBio.js} +76 -75
- package/src/{api/messaging/changeBlockedStatus.js → changeBlockedStatus.js} +49 -48
- package/src/changeBlockedStatusMqtt.js +80 -0
- package/src/changeCover.js +72 -0
- package/src/changeGroupImage.js +135 -0
- package/src/changeName.js +79 -0
- package/src/changeNickname.js +59 -0
- package/src/changeThreadColor.js +65 -0
- package/src/changeThreadEmoji.js +55 -0
- package/src/changeUsername.js +59 -0
- package/src/createCommentPost.js +230 -0
- package/src/{api/messaging/createNewGroup.js → createNewGroup.js} +88 -88
- package/src/createPoll.js +71 -0
- package/src/createPost.js +276 -0
- package/src/{api/messaging/deleteMessage.js → deleteMessage.js} +56 -56
- package/src/{api/messaging/deleteThread.js → deleteThread.js} +56 -56
- package/src/editMessage.js +68 -0
- package/src/editMessageOld.js +67 -0
- package/src/follow.js +74 -0
- package/src/forwardAttachment.js +60 -0
- package/src/getAccess.js +112 -0
- package/src/getAvatarUser.js +78 -0
- package/src/{api/action/getCurrentUserID.js → getCurrentUserID.js} +7 -7
- package/src/{api/messaging/getEmojiUrl.js → getEmojiUrl.js} +2 -2
- package/src/{api/messaging/getFriendsList.js → getFriendsList.js} +83 -82
- package/src/{api/messaging/getMessage.js → getMessage.js} +847 -829
- package/src/getRegion.js +7 -0
- package/src/{api/threads/getThreadHistory.js → getThreadHistory.js} +680 -664
- package/src/getThreadHistoryDeprecated.js +71 -0
- package/src/getThreadInfo.js +232 -0
- package/src/getThreadInfoDeprecated.js +56 -0
- package/src/getThreadList.js +213 -0
- package/src/getThreadListDeprecated.js +46 -0
- package/src/getThreadPictures.js +59 -0
- package/src/getUID.js +119 -0
- package/src/{api/users/getUserID.js → getUserID.js} +61 -65
- package/src/getUserInfo.js +66 -0
- package/src/handleFriendRequest.js +46 -0
- package/src/handleMessageRequest.js +47 -0
- package/src/httpGet.js +49 -0
- package/src/httpPost.js +48 -0
- package/src/listenMqtt.js +833 -0
- package/src/logout.js +75 -0
- package/src/markAsDelivered.js +47 -0
- package/src/markAsRead.js +70 -0
- package/src/markAsReadAll.js +40 -0
- package/src/markAsSeen.js +48 -0
- package/src/muteThread.js +45 -0
- package/src/refreshFb_dtsg.js +89 -0
- package/src/removeUserFromGroup.js +79 -0
- package/src/{api/messaging/resolvePhotoUrl.js → resolvePhotoUrl.js} +45 -43
- package/src/{api/messaging/searchForThread.js → searchForThread.js} +53 -52
- package/src/searchStickers.js +53 -0
- package/src/sendMessage.js +379 -0
- package/src/{api/messaging/sendMessageMqtt.js → sendMessageMqtt.js} +322 -323
- package/src/sendTypingIndicator.js +101 -0
- package/src/sendTypingIndicatorV2.js +28 -0
- package/src/setMessageReaction.js +122 -0
- package/src/setMessageReactionMqtt.js +62 -0
- package/src/{api/action/setPostReaction.js → setPostReaction.js} +112 -106
- package/src/setStoryReaction.js +64 -0
- package/src/setTitle.js +90 -0
- package/src/shareContact.js +110 -0
- package/src/shareLink.js +59 -0
- package/src/stopListenMqtt.js +23 -0
- package/src/{api/messaging/threadColors.js → threadColors.js} +131 -128
- package/src/{api/action/unfriend.js → unfriend.js} +52 -54
- package/src/unsendMessage.js +45 -0
- package/src/{api/messaging/uploadAttachment.js → uploadAttachment.js} +93 -95
- package/utils.js +2876 -0
- package/LICENSE-MIT +0 -4
- package/index.d.ts +0 -615
- package/module/config.js +0 -33
- package/module/login.js +0 -48
- package/module/loginHelper.js +0 -722
- package/module/options.js +0 -44
- package/src/api/action/handleFriendRequest.js +0 -57
- package/src/api/action/logout.js +0 -76
- package/src/api/action/refreshFb_dtsg.js +0 -71
- package/src/api/http/httpGet.js +0 -46
- package/src/api/http/httpPost.js +0 -52
- package/src/api/http/postFormData.js +0 -47
- package/src/api/messaging/addUserToGroup.js +0 -68
- package/src/api/messaging/changeAdminStatus.js +0 -122
- package/src/api/messaging/changeArchivedStatus.js +0 -55
- package/src/api/messaging/changeGroupImage.js +0 -90
- package/src/api/messaging/changeNickname.js +0 -70
- package/src/api/messaging/changeThreadColor.js +0 -79
- package/src/api/messaging/changeThreadEmoji.js +0 -106
- package/src/api/messaging/createPoll.js +0 -43
- package/src/api/messaging/editMessage.js +0 -68
- package/src/api/messaging/forwardAttachment.js +0 -51
- package/src/api/messaging/handleMessageRequest.js +0 -65
- package/src/api/messaging/markAsDelivered.js +0 -57
- package/src/api/messaging/markAsRead.js +0 -88
- package/src/api/messaging/markAsReadAll.js +0 -49
- package/src/api/messaging/markAsSeen.js +0 -61
- package/src/api/messaging/muteThread.js +0 -50
- package/src/api/messaging/removeUserFromGroup.js +0 -105
- package/src/api/messaging/sendMessage.js +0 -379
- package/src/api/messaging/sendTypingIndicator.js +0 -67
- package/src/api/messaging/setMessageReaction.js +0 -75
- package/src/api/messaging/setTitle.js +0 -119
- package/src/api/messaging/shareContact.js +0 -49
- package/src/api/messaging/unsendMessage.js +0 -81
- package/src/api/socket/core/connectMqtt.js +0 -179
- package/src/api/socket/core/getSeqID.js +0 -25
- package/src/api/socket/core/getTaskResponseData.js +0 -22
- package/src/api/socket/core/markDelivery.js +0 -12
- package/src/api/socket/core/parseDelta.js +0 -351
- package/src/api/socket/detail/buildStream.js +0 -208
- package/src/api/socket/detail/constants.js +0 -24
- package/src/api/socket/listenMqtt.js +0 -133
- package/src/api/threads/getThreadInfo.js +0 -358
- package/src/api/threads/getThreadList.js +0 -248
- package/src/api/threads/getThreadPictures.js +0 -78
- package/src/api/users/getUserInfo.js +0 -319
- package/src/api/users/getUserInfoV2.js +0 -133
- package/src/core/sendReqMqtt.js +0 -63
- package/src/database/models/index.js +0 -49
- package/src/database/models/thread.js +0 -31
- package/src/database/models/user.js +0 -32
- package/src/database/threadData.js +0 -98
- package/src/database/userData.js +0 -89
- package/src/utils/client.js +0 -214
- package/src/utils/constants.js +0 -23
- package/src/utils/format.js +0 -1111
- package/src/utils/headers.js +0 -41
- package/src/utils/request.js +0 -215
package/module/options.js
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
const { getType } = require("../src/utils/format");
|
|
2
|
-
const { setProxy } = require("../src/utils/request");
|
|
3
|
-
const Boolean_Option = [
|
|
4
|
-
"online",
|
|
5
|
-
"selfListen",
|
|
6
|
-
"listenEvents",
|
|
7
|
-
"updatePresence",
|
|
8
|
-
"forceLogin",
|
|
9
|
-
"autoMarkDelivery",
|
|
10
|
-
"autoMarkRead",
|
|
11
|
-
"listenTyping",
|
|
12
|
-
"autoReconnect",
|
|
13
|
-
"emitReady",
|
|
14
|
-
"selfListenEvent"
|
|
15
|
-
];
|
|
16
|
-
function setOptions(globalOptions, options) {
|
|
17
|
-
for (const key of Object.keys(options || {})) {
|
|
18
|
-
if (Boolean_Option.includes(key)) {
|
|
19
|
-
globalOptions[key] = Boolean(options[key]);
|
|
20
|
-
continue;
|
|
21
|
-
}
|
|
22
|
-
switch (key) {
|
|
23
|
-
case "userAgent": {
|
|
24
|
-
globalOptions.userAgent = options.userAgent || "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36";
|
|
25
|
-
break;
|
|
26
|
-
}
|
|
27
|
-
case "proxy": {
|
|
28
|
-
if (typeof options.proxy !== "string") {
|
|
29
|
-
delete globalOptions.proxy;
|
|
30
|
-
setProxy();
|
|
31
|
-
} else {
|
|
32
|
-
globalOptions.proxy = options.proxy;
|
|
33
|
-
setProxy(globalOptions.proxy);
|
|
34
|
-
}
|
|
35
|
-
break;
|
|
36
|
-
}
|
|
37
|
-
default: {
|
|
38
|
-
console.warn("setOptions Unrecognized option given to setOptions: " + key);
|
|
39
|
-
break;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
module.exports = { setOptions, Boolean_Option };
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("npmlog");
|
|
4
|
-
const { parseAndCheckLogin } = require("../../utils/client");
|
|
5
|
-
const { getType } = require("../../utils/format");
|
|
6
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
-
return function handleFriendRequest(userID, accept, callback) {
|
|
8
|
-
if (getType(accept) !== "Boolean") {
|
|
9
|
-
throw {
|
|
10
|
-
error: "Please pass a boolean as a second argument."
|
|
11
|
-
};
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
let resolveFunc = function() {};
|
|
15
|
-
let rejectFunc = function() {};
|
|
16
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
17
|
-
resolveFunc = resolve;
|
|
18
|
-
rejectFunc = reject;
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
if (!callback) {
|
|
22
|
-
callback = function(err, friendList) {
|
|
23
|
-
if (err) {
|
|
24
|
-
return rejectFunc(err);
|
|
25
|
-
}
|
|
26
|
-
resolveFunc(friendList);
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
const form = {
|
|
31
|
-
viewer_id: ctx.userID,
|
|
32
|
-
"frefs[0]": "jwl",
|
|
33
|
-
floc: "friend_center_requests",
|
|
34
|
-
ref: "/reqs.php",
|
|
35
|
-
action: accept ? "confirm" : "reject"
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
defaultFuncs
|
|
39
|
-
.post("https://www.facebook.com/requests/friends/ajax/", ctx.jar, form)
|
|
40
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
41
|
-
.then(function(resData) {
|
|
42
|
-
if (resData.payload.err) {
|
|
43
|
-
throw {
|
|
44
|
-
err: resData.payload.err
|
|
45
|
-
};
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
return callback();
|
|
49
|
-
})
|
|
50
|
-
.catch(function(err) {
|
|
51
|
-
log.error("handleFriendRequest", err);
|
|
52
|
-
return callback(err);
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
return returnPromise;
|
|
56
|
-
};
|
|
57
|
-
};
|
package/src/api/action/logout.js
DELETED
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("npmlog");
|
|
4
|
-
const { parseAndCheckLogin } = require("../../utils/client");
|
|
5
|
-
const { getFrom } = require("../../utils/constants");
|
|
6
|
-
const { saveCookies } = require("../../utils/client");
|
|
7
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
8
|
-
return function logout(callback) {
|
|
9
|
-
let resolveFunc = function() {};
|
|
10
|
-
let rejectFunc = function() {};
|
|
11
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
12
|
-
resolveFunc = resolve;
|
|
13
|
-
rejectFunc = reject;
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
if (!callback) {
|
|
17
|
-
callback = function(err, friendList) {
|
|
18
|
-
if (err) {
|
|
19
|
-
return rejectFunc(err);
|
|
20
|
-
}
|
|
21
|
-
resolveFunc(friendList);
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const form = {
|
|
26
|
-
pmid: "0"
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
defaultFuncs
|
|
30
|
-
.post(
|
|
31
|
-
"https://www.facebook.com/bluebar/modern_settings_menu/?help_type=364455653583099&show_contextual_help=1",
|
|
32
|
-
ctx.jar,
|
|
33
|
-
form
|
|
34
|
-
)
|
|
35
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
36
|
-
.then(function(resData) {
|
|
37
|
-
const elem = resData.jsmods.instances[0][2][0].filter(function(v) {
|
|
38
|
-
return v.value === "logout";
|
|
39
|
-
})[0];
|
|
40
|
-
|
|
41
|
-
const html = resData.jsmods.markup.filter(function(v) {
|
|
42
|
-
return v[0] === elem.markup.__m;
|
|
43
|
-
})[0][1].__html;
|
|
44
|
-
|
|
45
|
-
const form = {
|
|
46
|
-
fb_dtsg: getFrom(html, '"fb_dtsg" value="', '"'),
|
|
47
|
-
ref: getFrom(html, '"ref" value="', '"'),
|
|
48
|
-
h: getFrom(html, '"h" value="', '"')
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
return defaultFuncs
|
|
52
|
-
.post("https://www.facebook.com/logout.php", ctx.jar, form)
|
|
53
|
-
.then(saveCookies(ctx.jar));
|
|
54
|
-
})
|
|
55
|
-
.then(function(res) {
|
|
56
|
-
if (!res.headers) {
|
|
57
|
-
throw { error: "An error occurred when logging out." };
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
return defaultFuncs
|
|
61
|
-
.get(res.headers.location, ctx.jar)
|
|
62
|
-
.then(saveCookies(ctx.jar));
|
|
63
|
-
})
|
|
64
|
-
.then(function() {
|
|
65
|
-
ctx.loggedIn = false;
|
|
66
|
-
log.info("logout", "Logged out successfully.");
|
|
67
|
-
callback();
|
|
68
|
-
})
|
|
69
|
-
.catch(function(err) {
|
|
70
|
-
log.error("logout", err);
|
|
71
|
-
return callback(err);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
return returnPromise;
|
|
75
|
-
};
|
|
76
|
-
};
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("npmlog");
|
|
4
|
-
const { getFrom } = require("../../utils/constants");
|
|
5
|
-
const { get } = require("../../utils/request")
|
|
6
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
-
return function refreshFb_dtsg(obj, callback) {
|
|
8
|
-
let resolveFunc, rejectFunc;
|
|
9
|
-
const returnPromise = new Promise((resolve, reject) => {
|
|
10
|
-
resolveFunc = resolve;
|
|
11
|
-
rejectFunc = reject;
|
|
12
|
-
});
|
|
13
|
-
if (
|
|
14
|
-
getType(obj) === "Function" ||
|
|
15
|
-
getType(obj) === "AsyncFunction"
|
|
16
|
-
) {
|
|
17
|
-
callback = obj;
|
|
18
|
-
obj = {};
|
|
19
|
-
}
|
|
20
|
-
if (!obj) obj = {};
|
|
21
|
-
if (getType(obj) !== "Object") {
|
|
22
|
-
throw Error(
|
|
23
|
-
"The first parameter must be an object or a callback function"
|
|
24
|
-
);
|
|
25
|
-
}
|
|
26
|
-
if (!callback) {
|
|
27
|
-
callback = (err, data) => (err ? rejectFunc(err) : resolveFunc(data));
|
|
28
|
-
}
|
|
29
|
-
if (Object.keys(obj).length === 0) {
|
|
30
|
-
get(
|
|
31
|
-
"https://www.facebook.com/",
|
|
32
|
-
ctx.jar,
|
|
33
|
-
null,
|
|
34
|
-
ctx.globalOptions,
|
|
35
|
-
{
|
|
36
|
-
noRef: true
|
|
37
|
-
}
|
|
38
|
-
)
|
|
39
|
-
.then(resData => {
|
|
40
|
-
const fb_dtsg = getFrom(
|
|
41
|
-
resData.body,
|
|
42
|
-
'["DTSGInitData",[],{"token":"',
|
|
43
|
-
'","'
|
|
44
|
-
);
|
|
45
|
-
const jazoest = getFrom(resData.body, "jazoest=", '",');
|
|
46
|
-
if (!fb_dtsg) {
|
|
47
|
-
throw Error(
|
|
48
|
-
"Could not find fb_dtsg in HTML after requesting Facebook."
|
|
49
|
-
);
|
|
50
|
-
}
|
|
51
|
-
ctx.fb_dtsg = fb_dtsg;
|
|
52
|
-
ctx.jazoest = jazoest;
|
|
53
|
-
callback(null, {
|
|
54
|
-
data: { fb_dtsg, jazoest },
|
|
55
|
-
message: "Refreshed fb_dtsg and jazoest"
|
|
56
|
-
});
|
|
57
|
-
})
|
|
58
|
-
.catch(err => {
|
|
59
|
-
log.error("refreshFb_dtsg", err);
|
|
60
|
-
callback(err);
|
|
61
|
-
});
|
|
62
|
-
} else {
|
|
63
|
-
Object.assign(ctx, obj);
|
|
64
|
-
callback(null, {
|
|
65
|
-
data: obj,
|
|
66
|
-
message: "Refreshed " + Object.keys(obj).join(", ")
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
return returnPromise;
|
|
70
|
-
};
|
|
71
|
-
};
|
package/src/api/http/httpGet.js
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { getType } = require("../../utils/format.js");
|
|
4
|
-
const { get } = require("../../utils/request.js");
|
|
5
|
-
|
|
6
|
-
const httpGetFactory = function (defaultFuncs, api, ctx) {
|
|
7
|
-
return function httpGet(url, form, callback, notAPI) {
|
|
8
|
-
let resolveFunc = () => { };
|
|
9
|
-
let rejectFunc = () => { };
|
|
10
|
-
|
|
11
|
-
const returnPromise = new Promise((resolve, reject) => {
|
|
12
|
-
resolveFunc = resolve;
|
|
13
|
-
rejectFunc = reject;
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
if (
|
|
17
|
-
!callback &&
|
|
18
|
-
(getType(form) === "Function" || getType(form) === "AsyncFunction")
|
|
19
|
-
) {
|
|
20
|
-
callback = form;
|
|
21
|
-
form = {};
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
form = form || {};
|
|
25
|
-
|
|
26
|
-
callback =
|
|
27
|
-
callback ||
|
|
28
|
-
function (err, data) {
|
|
29
|
-
if (err) return rejectFunc(err);
|
|
30
|
-
resolveFunc(data);
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
const executor = notAPI ? get : defaultFuncs.get;
|
|
34
|
-
|
|
35
|
-
executor(url, ctx.jar, form)
|
|
36
|
-
.then((resData) => callback(null, resData.data))
|
|
37
|
-
.catch(function (err) {
|
|
38
|
-
console.error("httpGet", err);
|
|
39
|
-
return callback(err);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
return returnPromise;
|
|
43
|
-
};
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
module.exports = httpGetFactory;
|
package/src/api/http/httpPost.js
DELETED
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { post } = require("../../utils/request");
|
|
4
|
-
const { getType } = require("../../utils/format");
|
|
5
|
-
|
|
6
|
-
const httpPostFactory = function (defaultFuncs, api, ctx) {
|
|
7
|
-
return function httpPost(url, form, callback, notAPI) {
|
|
8
|
-
let resolveFunc = () => { };
|
|
9
|
-
let rejectFunc = () => { };
|
|
10
|
-
|
|
11
|
-
const returnPromise = new Promise((resolve, reject) => {
|
|
12
|
-
resolveFunc = resolve;
|
|
13
|
-
rejectFunc = reject;
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
if (
|
|
17
|
-
!callback &&
|
|
18
|
-
(getType(form) === "Function" || getType(form) === "AsyncFunction")
|
|
19
|
-
) {
|
|
20
|
-
callback = form;
|
|
21
|
-
form = {};
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
form = form || {};
|
|
25
|
-
|
|
26
|
-
callback =
|
|
27
|
-
callback ||
|
|
28
|
-
function (err, data) {
|
|
29
|
-
if (err) return rejectFunc(err);
|
|
30
|
-
resolveFunc(data);
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
const executor = notAPI ? post : defaultFuncs.post;
|
|
34
|
-
|
|
35
|
-
executor(url, ctx.jar, form, ctx.globalOptions)
|
|
36
|
-
.then((resData) => {
|
|
37
|
-
let data = resData.data;
|
|
38
|
-
if (typeof data === "object") {
|
|
39
|
-
data = JSON.stringify(data, null, 2);
|
|
40
|
-
}
|
|
41
|
-
callback(null, data);
|
|
42
|
-
})
|
|
43
|
-
.catch((err) => {
|
|
44
|
-
console.error("httpPost", err);
|
|
45
|
-
return callback(err);
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
return returnPromise;
|
|
49
|
-
};
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
module.exports = httpPostFactory;
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var log = require("npmlog");
|
|
4
|
-
const { getType } = require("../../utils/format");
|
|
5
|
-
const { parseAndCheckLogin } = require("../../utils/client");
|
|
6
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
-
return function postFormData(url, form, callback) {
|
|
8
|
-
var resolveFunc = function() {};
|
|
9
|
-
var rejectFunc = function() {};
|
|
10
|
-
|
|
11
|
-
var returnPromise = new Promise(function(resolve, reject) {
|
|
12
|
-
resolveFunc = resolve;
|
|
13
|
-
rejectFunc = reject;
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
if (
|
|
17
|
-
!callback &&
|
|
18
|
-
(getType(form) == "Function" ||
|
|
19
|
-
getType(form) == "AsyncFunction")
|
|
20
|
-
) {
|
|
21
|
-
callback = form;
|
|
22
|
-
form = {};
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
form = form || {};
|
|
26
|
-
|
|
27
|
-
callback =
|
|
28
|
-
callback ||
|
|
29
|
-
function(err, data) {
|
|
30
|
-
if (err) return rejectFunc(err);
|
|
31
|
-
resolveFunc(data);
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
defaultFuncs
|
|
35
|
-
.postFormData(url, ctx.jar, form, {})
|
|
36
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
37
|
-
.then(function(resData) {
|
|
38
|
-
callback(null, resData);
|
|
39
|
-
})
|
|
40
|
-
.catch(function(err) {
|
|
41
|
-
log.error("postFormData", err);
|
|
42
|
-
return callback(err);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
return returnPromise;
|
|
46
|
-
};
|
|
47
|
-
};
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { generateOfflineThreadingID, getType } = require("../../utils/format.js");
|
|
4
|
-
module.exports = function (defaultFuncs, api, ctx) {
|
|
5
|
-
return function addUserToGroup(userID, threadID, callback) {
|
|
6
|
-
return new Promise((resolve, reject) => {
|
|
7
|
-
if (!ctx.mqttClient) {
|
|
8
|
-
const err = new Error("Not connected to MQTT");
|
|
9
|
-
callback?.(err);
|
|
10
|
-
return reject(err);
|
|
11
|
-
}
|
|
12
|
-
if (getType(threadID) !== "Number" && getType(threadID) !== "String") {
|
|
13
|
-
const err = new Error("ThreadID should be of type Number or String.");
|
|
14
|
-
callback?.(err);
|
|
15
|
-
return reject(err);
|
|
16
|
-
}
|
|
17
|
-
if (getType(userID) !== "Array") userID = [userID];
|
|
18
|
-
const reqID = ++ctx.wsReqNumber;
|
|
19
|
-
const taskID = ++ctx.wsTaskNumber;
|
|
20
|
-
|
|
21
|
-
const payload = {
|
|
22
|
-
epoch_id: generateOfflineThreadingID(),
|
|
23
|
-
tasks: [
|
|
24
|
-
{
|
|
25
|
-
failure_count: null,
|
|
26
|
-
label: "23",
|
|
27
|
-
payload: JSON.stringify({
|
|
28
|
-
thread_key: threadID,
|
|
29
|
-
contact_ids: userID,
|
|
30
|
-
sync_group: 1
|
|
31
|
-
}),
|
|
32
|
-
queue_name: threadID.toString(),
|
|
33
|
-
task_id: taskID
|
|
34
|
-
}
|
|
35
|
-
],
|
|
36
|
-
version_id: "24502707779384158"
|
|
37
|
-
};
|
|
38
|
-
const form = JSON.stringify({
|
|
39
|
-
app_id: "772021112871879",
|
|
40
|
-
payload: JSON.stringify(payload),
|
|
41
|
-
request_id: reqID,
|
|
42
|
-
type: 3
|
|
43
|
-
});
|
|
44
|
-
const handleRes = (topic, message) => {
|
|
45
|
-
if (topic !== "/ls_resp") return;
|
|
46
|
-
let jsonMsg;
|
|
47
|
-
try {
|
|
48
|
-
jsonMsg = JSON.parse(message.toString());
|
|
49
|
-
jsonMsg.payload = JSON.parse(jsonMsg.payload);
|
|
50
|
-
} catch {
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
if (jsonMsg.request_id !== reqID) return;
|
|
54
|
-
ctx.mqttClient.removeListener("message", handleRes);
|
|
55
|
-
callback?.(null, { success: true, response: jsonMsg.payload });
|
|
56
|
-
resolve({ success: true, response: jsonMsg.payload });
|
|
57
|
-
};
|
|
58
|
-
ctx.mqttClient.on("message", handleRes);
|
|
59
|
-
ctx.mqttClient.publish("/ls_req", form, { qos: 1, retain: false }, (err) => {
|
|
60
|
-
if (err) {
|
|
61
|
-
ctx.mqttClient.removeListener("message", handleRes);
|
|
62
|
-
callback?.(err);
|
|
63
|
-
reject(err);
|
|
64
|
-
}
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
};
|
|
68
|
-
};
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { generateOfflineThreadingID, getType } = require("../../utils/format");
|
|
4
|
-
|
|
5
|
-
module.exports = function (defaultFuncs, api, ctx) {
|
|
6
|
-
function changeAdminStatusNoMqtt(threadID, adminID, adminStatus) {
|
|
7
|
-
if (getType(threadID) !== "String") throw { error: "changeAdminStatus: threadID must be a string" };
|
|
8
|
-
if (getType(adminID) !== "String" && getType(adminID) !== "Array") throw { error: "changeAdminStatus: adminID must be a string or an array" };
|
|
9
|
-
if (getType(adminStatus) !== "Boolean") throw { error: "changeAdminStatus: adminStatus must be true or false" };
|
|
10
|
-
let wsContent = {
|
|
11
|
-
request_id: 1,
|
|
12
|
-
type: 3,
|
|
13
|
-
payload: {
|
|
14
|
-
version_id: '3816854585040595',
|
|
15
|
-
tasks: [],
|
|
16
|
-
epoch_id: generateOfflineThreadingID(),
|
|
17
|
-
data_trace_id: null
|
|
18
|
-
},
|
|
19
|
-
app_id: '772021112871879'
|
|
20
|
-
}
|
|
21
|
-
if (getType(adminID) === "Array") {
|
|
22
|
-
for (let i = 0; i < adminID.length; i++) {
|
|
23
|
-
wsContent.payload.tasks.push({
|
|
24
|
-
label: '25',
|
|
25
|
-
payload: JSON.stringify({ thread_key: threadID, contact_id: adminID[i], is_admin: adminStatus }),
|
|
26
|
-
queue_name: 'admin_status',
|
|
27
|
-
task_id: i + 1,
|
|
28
|
-
failure_count: null
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
} else {
|
|
32
|
-
wsContent.payload.tasks.push({
|
|
33
|
-
label: '25',
|
|
34
|
-
payload: JSON.stringify({ thread_key: threadID, contact_id: adminID, is_admin: adminStatus }),
|
|
35
|
-
queue_name: 'admin_status',
|
|
36
|
-
task_id: 1,
|
|
37
|
-
failure_count: null
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
wsContent.payload = JSON.stringify(wsContent.payload);
|
|
41
|
-
return new Promise((resolve, reject) => ctx.mqttClient && ctx.mqttClient.publish('/ls_req', JSON.stringify(wsContent), {}, (err, _packet) => err ? reject(err) : resolve()));
|
|
42
|
-
};
|
|
43
|
-
function changeAdminStatusMqtt(threadID, adminID, adminStatus) {
|
|
44
|
-
if (!ctx.mqttClient) {
|
|
45
|
-
throw new Error("Not connected to MQTT");
|
|
46
|
-
}
|
|
47
|
-
if (getType(threadID) !== "String") {
|
|
48
|
-
throw { error: "changeAdminStatus: threadID must be a string" };
|
|
49
|
-
}
|
|
50
|
-
if (getType(adminID) !== "String" && getType(adminID) !== "Array") {
|
|
51
|
-
throw { error: "changeAdminStatus: adminID must be a string or an array" };
|
|
52
|
-
}
|
|
53
|
-
if (getType(adminStatus) !== "Boolean") {
|
|
54
|
-
throw { error: "changeAdminStatus: adminStatus must be true or false" };
|
|
55
|
-
}
|
|
56
|
-
const tasks = [];
|
|
57
|
-
const isAdmin = adminStatus ? 1 : 0;
|
|
58
|
-
const epochID = generateOfflineThreadingID();
|
|
59
|
-
if (getType(adminID) === "Array") {
|
|
60
|
-
adminID.forEach((id, index) => {
|
|
61
|
-
tasks.push({
|
|
62
|
-
failure_count: null,
|
|
63
|
-
label: "25",
|
|
64
|
-
payload: JSON.stringify({
|
|
65
|
-
thread_key: threadID,
|
|
66
|
-
contact_id: id,
|
|
67
|
-
is_admin: isAdmin
|
|
68
|
-
}),
|
|
69
|
-
queue_name: "admin_status",
|
|
70
|
-
task_id: index + 1
|
|
71
|
-
});
|
|
72
|
-
});
|
|
73
|
-
} else {
|
|
74
|
-
tasks.push({
|
|
75
|
-
failure_count: null,
|
|
76
|
-
label: "25",
|
|
77
|
-
payload: JSON.stringify({
|
|
78
|
-
thread_key: threadID,
|
|
79
|
-
contact_id: adminID,
|
|
80
|
-
is_admin: isAdmin
|
|
81
|
-
}),
|
|
82
|
-
queue_name: "admin_status",
|
|
83
|
-
task_id: 1
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
let count_req = 0
|
|
87
|
-
const form = JSON.stringify({
|
|
88
|
-
app_id: "2220391788200892",
|
|
89
|
-
payload: JSON.stringify({
|
|
90
|
-
epoch_id: epochID,
|
|
91
|
-
tasks: tasks,
|
|
92
|
-
version_id: "8798795233522156"
|
|
93
|
-
}),
|
|
94
|
-
request_id: ++count_req,
|
|
95
|
-
type: 3
|
|
96
|
-
});
|
|
97
|
-
return new Promise((resolve, reject) => {
|
|
98
|
-
if (ctx.mqttClient) {
|
|
99
|
-
ctx.mqttClient.publish("/ls_req", form, {}, (err, _packet) => {
|
|
100
|
-
if (err) {
|
|
101
|
-
reject(err);
|
|
102
|
-
} else {
|
|
103
|
-
resolve();
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
} else {
|
|
107
|
-
reject(new Error("MQTT client is not available"));
|
|
108
|
-
}
|
|
109
|
-
});
|
|
110
|
-
};
|
|
111
|
-
return function changeAdminStatus(threadID, adminID, adminStatus) {
|
|
112
|
-
if (ctx.mqttClient) {
|
|
113
|
-
try {
|
|
114
|
-
changeAdminStatusMqtt(threadID, adminID, adminStatus);
|
|
115
|
-
} catch (e) {
|
|
116
|
-
changeAdminStatusNoMqtt(threadID, adminID, adminStatus);
|
|
117
|
-
}
|
|
118
|
-
} else {
|
|
119
|
-
changeAdminStatusNoMqtt(threadID, adminID, adminStatus);
|
|
120
|
-
}
|
|
121
|
-
};
|
|
122
|
-
};
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("npmlog");
|
|
4
|
-
const { formatID } = require("../../utils/format");
|
|
5
|
-
const { parseAndCheckLogin } = require("../../utils/client");
|
|
6
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
-
return function changeArchivedStatus(threadOrThreads, archive, callback) {
|
|
8
|
-
let resolveFunc = function() {};
|
|
9
|
-
let rejectFunc = function() {};
|
|
10
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
11
|
-
resolveFunc = resolve;
|
|
12
|
-
rejectFunc = reject;
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
if (!callback) {
|
|
16
|
-
callback = function(err) {
|
|
17
|
-
if (err) {
|
|
18
|
-
return rejectFunc(err);
|
|
19
|
-
}
|
|
20
|
-
resolveFunc();
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const form = {};
|
|
25
|
-
|
|
26
|
-
if (Array.isArray(threadOrThreads)) {
|
|
27
|
-
for (let i = 0; i < threadOrThreads.length; i++) {
|
|
28
|
-
form["ids[" + formatID(threadOrThreads[i]) + "]"] = archive;
|
|
29
|
-
}
|
|
30
|
-
} else {
|
|
31
|
-
form["ids[" + formatID(threadOrThreads) + "]"] = archive;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
defaultFuncs
|
|
35
|
-
.post(
|
|
36
|
-
"https://www.facebook.com/ajax/mercury/change_archived_status.php",
|
|
37
|
-
ctx.jar,
|
|
38
|
-
form
|
|
39
|
-
)
|
|
40
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
41
|
-
.then(function(resData) {
|
|
42
|
-
if (resData.error) {
|
|
43
|
-
throw resData;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
return callback();
|
|
47
|
-
})
|
|
48
|
-
.catch(function(err) {
|
|
49
|
-
log.error("changeArchivedStatus", err);
|
|
50
|
-
return callback(err);
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
return returnPromise;
|
|
54
|
-
};
|
|
55
|
-
};
|