@dongdev/fca-unofficial 3.0.31 → 4.0.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.
- package/LICENSE +191 -0
- package/README.md +224 -406
- package/dist/index.d.mts +1241 -0
- package/dist/index.d.ts +1241 -0
- package/dist/index.js +27749 -0
- package/dist/index.mjs +27713 -0
- package/docs/ARCHITECTURE.md +467 -0
- package/docs/DOCS.md +686 -0
- package/fca-config.example.json +33 -0
- package/package.json +32 -22
- package/test/fca.test.cjs +533 -0
- package/CHANGELOG.md +0 -296
- package/DOCS.md +0 -2712
- package/func/checkUpdate.js +0 -222
- package/func/logAdapter.js +0 -33
- package/func/logger.js +0 -48
- package/index.d.ts +0 -751
- package/index.js +0 -8
- package/module/config.js +0 -40
- package/module/login.js +0 -133
- package/module/loginHelper.js +0 -1296
- package/module/options.js +0 -44
- package/src/api/action/addExternalModule.js +0 -25
- package/src/api/action/changeAvatar.js +0 -137
- package/src/api/action/changeBio.js +0 -75
- package/src/api/action/enableAutoSaveAppState.js +0 -73
- package/src/api/action/getCurrentUserID.js +0 -7
- package/src/api/action/handleFriendRequest.js +0 -57
- package/src/api/action/logout.js +0 -76
- package/src/api/action/refreshFb_dtsg.js +0 -48
- package/src/api/action/setPostReaction.js +0 -106
- package/src/api/action/unfriend.js +0 -54
- 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 -126
- package/src/api/messaging/changeArchivedStatus.js +0 -55
- package/src/api/messaging/changeBlockedStatus.js +0 -48
- package/src/api/messaging/changeGroupImage.js +0 -91
- package/src/api/messaging/changeNickname.js +0 -70
- package/src/api/messaging/changeThreadColor.js +0 -79
- package/src/api/messaging/changeThreadEmoji.js +0 -111
- package/src/api/messaging/createNewGroup.js +0 -88
- package/src/api/messaging/createPoll.js +0 -46
- package/src/api/messaging/createThemeAI.js +0 -98
- package/src/api/messaging/deleteMessage.js +0 -136
- package/src/api/messaging/deleteThread.js +0 -56
- package/src/api/messaging/editMessage.js +0 -68
- package/src/api/messaging/forwardAttachment.js +0 -57
- package/src/api/messaging/getEmojiUrl.js +0 -29
- package/src/api/messaging/getFriendsList.js +0 -82
- package/src/api/messaging/getMessage.js +0 -829
- package/src/api/messaging/getThemePictures.js +0 -62
- 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 -62
- package/src/api/messaging/resolvePhotoUrl.js +0 -43
- package/src/api/messaging/scheduler.js +0 -264
- package/src/api/messaging/searchForThread.js +0 -53
- package/src/api/messaging/sendMessage.js +0 -270
- package/src/api/messaging/sendTypingIndicator.js +0 -74
- package/src/api/messaging/setMessageReaction.js +0 -90
- package/src/api/messaging/setTitle.js +0 -124
- package/src/api/messaging/shareContact.js +0 -49
- package/src/api/messaging/threadColors.js +0 -128
- package/src/api/messaging/unsendMessage.js +0 -81
- package/src/api/messaging/uploadAttachment.js +0 -492
- package/src/api/socket/core/connectMqtt.js +0 -258
- package/src/api/socket/core/emitAuth.js +0 -103
- package/src/api/socket/core/getSeqID.js +0 -320
- package/src/api/socket/core/getTaskResponseData.js +0 -25
- package/src/api/socket/core/parseDelta.js +0 -377
- package/src/api/socket/detail/buildStream.js +0 -215
- package/src/api/socket/detail/constants.js +0 -28
- package/src/api/socket/listenMqtt.js +0 -377
- package/src/api/socket/middleware/index.js +0 -216
- package/src/api/threads/getThreadHistory.js +0 -664
- package/src/api/threads/getThreadInfo.js +0 -296
- package/src/api/threads/getThreadList.js +0 -293
- package/src/api/threads/getThreadPictures.js +0 -78
- package/src/api/users/getUserID.js +0 -65
- package/src/api/users/getUserInfo.js +0 -402
- package/src/api/users/getUserInfoV2.js +0 -134
- package/src/core/sendReqMqtt.js +0 -96
- package/src/database/helpers.js +0 -53
- package/src/database/models/index.js +0 -88
- package/src/database/models/thread.js +0 -50
- package/src/database/models/user.js +0 -46
- package/src/database/threadData.js +0 -94
- package/src/database/userData.js +0 -98
- package/src/remote/remoteClient.js +0 -123
- package/src/utils/broadcast.js +0 -51
- package/src/utils/client.js +0 -10
- package/src/utils/constants.js +0 -23
- package/src/utils/cookies.js +0 -68
- package/src/utils/format/attachment.js +0 -357
- package/src/utils/format/cookie.js +0 -9
- package/src/utils/format/date.js +0 -50
- package/src/utils/format/decode.js +0 -44
- package/src/utils/format/delta.js +0 -194
- package/src/utils/format/ids.js +0 -64
- package/src/utils/format/index.js +0 -64
- package/src/utils/format/message.js +0 -88
- package/src/utils/format/presence.js +0 -132
- package/src/utils/format/readTyp.js +0 -44
- package/src/utils/format/thread.js +0 -42
- package/src/utils/format/utils.js +0 -141
- package/src/utils/headers.js +0 -115
- package/src/utils/loginParser/autoLogin.js +0 -125
- package/src/utils/loginParser/helpers.js +0 -43
- package/src/utils/loginParser/index.js +0 -10
- package/src/utils/loginParser/parseAndCheckLogin.js +0 -220
- package/src/utils/loginParser/textUtils.js +0 -28
- package/src/utils/request/client.js +0 -26
- package/src/utils/request/config.js +0 -23
- package/src/utils/request/defaults.js +0 -46
- package/src/utils/request/helpers.js +0 -46
- package/src/utils/request/index.js +0 -17
- package/src/utils/request/methods.js +0 -163
- package/src/utils/request/proxy.js +0 -21
- package/src/utils/request/retry.js +0 -77
- package/src/utils/request/sanitize.js +0 -49
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("../../../func/logAdapter");
|
|
4
|
-
const { parseAndCheckLogin } = require("../../utils/client");
|
|
5
|
-
const { getType } = require("../../utils/format");
|
|
6
|
-
module.exports = function (defaultFuncs, api, ctx) {
|
|
7
|
-
return function getThemePictures(id, 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
|
-
if (
|
|
17
|
-
getType(callback) == "Function" ||
|
|
18
|
-
getType(callback) == "AsyncFunction"
|
|
19
|
-
) {
|
|
20
|
-
callback = callback;
|
|
21
|
-
} else {
|
|
22
|
-
callback = function (err, data) {
|
|
23
|
-
if (err) {
|
|
24
|
-
return rejectFunc(err);
|
|
25
|
-
}
|
|
26
|
-
resolveFunc(data);
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
if (getType(id) != "String") {
|
|
32
|
-
id = "";
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const form = {
|
|
36
|
-
fb_api_caller_class: "RelayModern",
|
|
37
|
-
fb_api_req_friendly_name: "MWPThreadThemeProviderQuery",
|
|
38
|
-
doc_id: "9734829906576883",
|
|
39
|
-
server_timestamps: true,
|
|
40
|
-
variables: JSON.stringify({
|
|
41
|
-
id
|
|
42
|
-
}),
|
|
43
|
-
av: ctx.userID
|
|
44
|
-
};
|
|
45
|
-
defaultFuncs
|
|
46
|
-
.post("https://www.facebook.com/api/graphql/", ctx.jar, form)
|
|
47
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
48
|
-
.then(function (resData) {
|
|
49
|
-
if (resData.errors) {
|
|
50
|
-
throw resData;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
return callback(null, resData);
|
|
54
|
-
})
|
|
55
|
-
.catch(function (err) {
|
|
56
|
-
log.error("getThemePictures", err);
|
|
57
|
-
return callback(err);
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
return returnPromise;
|
|
61
|
-
};
|
|
62
|
-
};
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("../../../func/logAdapter");
|
|
4
|
-
const { parseAndCheckLogin } = require("../../utils/client");
|
|
5
|
-
const { getType } = require("../../utils/format");
|
|
6
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
-
return function handleMessageRequest(threadID, 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
|
-
client: "mercury"
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
if (getType(threadID) !== "Array") {
|
|
35
|
-
threadID = [threadID];
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const messageBox = accept ? "inbox" : "other";
|
|
39
|
-
|
|
40
|
-
for (let i = 0; i < threadID.length; i++) {
|
|
41
|
-
form[messageBox + "[" + i + "]"] = threadID[i];
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
defaultFuncs
|
|
45
|
-
.post(
|
|
46
|
-
"https://www.facebook.com/ajax/mercury/move_thread.php",
|
|
47
|
-
ctx.jar,
|
|
48
|
-
form
|
|
49
|
-
)
|
|
50
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
51
|
-
.then(function(resData) {
|
|
52
|
-
if (resData.error) {
|
|
53
|
-
throw resData;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return callback();
|
|
57
|
-
})
|
|
58
|
-
.catch(function(err) {
|
|
59
|
-
log.error("handleMessageRequest", err);
|
|
60
|
-
return callback(err);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
return returnPromise;
|
|
64
|
-
};
|
|
65
|
-
};
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const log = require("../../../func/logAdapter");
|
|
3
|
-
const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
|
|
4
|
-
const { getType } = require("../../utils/format");
|
|
5
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
6
|
-
return function markAsDelivered(threadID, messageID, callback) {
|
|
7
|
-
let resolveFunc = function() {};
|
|
8
|
-
let rejectFunc = function() {};
|
|
9
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
10
|
-
resolveFunc = resolve;
|
|
11
|
-
rejectFunc = reject;
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
if (!callback) {
|
|
15
|
-
callback = function(err, friendList) {
|
|
16
|
-
if (err) {
|
|
17
|
-
return rejectFunc(err);
|
|
18
|
-
}
|
|
19
|
-
resolveFunc(friendList);
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
if (!threadID || !messageID) {
|
|
24
|
-
return callback("Error: messageID or threadID is not defined");
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const form = {};
|
|
28
|
-
|
|
29
|
-
form["message_ids[0]"] = messageID;
|
|
30
|
-
form["thread_ids[" + threadID + "][0]"] = messageID;
|
|
31
|
-
|
|
32
|
-
defaultFuncs
|
|
33
|
-
.post(
|
|
34
|
-
"https://www.facebook.com/ajax/mercury/delivery_receipts.php",
|
|
35
|
-
ctx.jar,
|
|
36
|
-
form
|
|
37
|
-
)
|
|
38
|
-
.then(saveCookies(ctx.jar))
|
|
39
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
40
|
-
.then(function(resData) {
|
|
41
|
-
if (resData.error) {
|
|
42
|
-
throw resData;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
return callback();
|
|
46
|
-
})
|
|
47
|
-
.catch(function(err) {
|
|
48
|
-
log.error("markAsDelivered", err);
|
|
49
|
-
if (getType(err) == "Object" && err.error === "Not logged in.") {
|
|
50
|
-
ctx.loggedIn = false;
|
|
51
|
-
}
|
|
52
|
-
return callback(err);
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
return returnPromise;
|
|
56
|
-
};
|
|
57
|
-
};
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("../../../func/logAdapter");
|
|
4
|
-
const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
|
|
5
|
-
const { getType } = require("../../utils/format");
|
|
6
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
-
return async function markAsRead(threadID, read, callback) {
|
|
8
|
-
if (
|
|
9
|
-
getType(read) === "Function" ||
|
|
10
|
-
getType(read) === "AsyncFunction"
|
|
11
|
-
) {
|
|
12
|
-
callback = read;
|
|
13
|
-
read = true;
|
|
14
|
-
}
|
|
15
|
-
if (read == undefined) {
|
|
16
|
-
read = true;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
if (!callback) {
|
|
20
|
-
callback = () => {};
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const form = {};
|
|
24
|
-
|
|
25
|
-
if (typeof ctx.globalOptions.pageID !== "undefined") {
|
|
26
|
-
form["source"] = "PagesManagerMessagesInterface";
|
|
27
|
-
form["request_user_id"] = ctx.globalOptions.pageID;
|
|
28
|
-
form["ids[" + threadID + "]"] = read;
|
|
29
|
-
form["watermarkTimestamp"] = new Date().getTime();
|
|
30
|
-
form["shouldSendReadReceipt"] = true;
|
|
31
|
-
form["commerce_last_message_type"] = "";
|
|
32
|
-
//form["titanOriginatedThreadId"] = utils.generateThreadingID(ctx.clientID);
|
|
33
|
-
|
|
34
|
-
let resData;
|
|
35
|
-
try {
|
|
36
|
-
resData = await defaultFuncs
|
|
37
|
-
.post(
|
|
38
|
-
"https://www.facebook.com/ajax/mercury/change_read_status.php",
|
|
39
|
-
ctx.jar,
|
|
40
|
-
form
|
|
41
|
-
)
|
|
42
|
-
.then(saveCookies(ctx.jar))
|
|
43
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs));
|
|
44
|
-
} catch (e) {
|
|
45
|
-
callback(e);
|
|
46
|
-
return e;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
if (resData.error) {
|
|
50
|
-
const err = resData.error;
|
|
51
|
-
log.error("markAsRead", err);
|
|
52
|
-
if (getType(err) == "Object" && err.error === "Not logged in.") {
|
|
53
|
-
ctx.loggedIn = false;
|
|
54
|
-
}
|
|
55
|
-
callback(err);
|
|
56
|
-
return err;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
callback();
|
|
60
|
-
return null;
|
|
61
|
-
} else {
|
|
62
|
-
try {
|
|
63
|
-
if (ctx.mqttClient) {
|
|
64
|
-
const err = await new Promise(r =>
|
|
65
|
-
ctx.mqttClient.publish(
|
|
66
|
-
"/mark_thread",
|
|
67
|
-
JSON.stringify({
|
|
68
|
-
threadID,
|
|
69
|
-
mark: "read",
|
|
70
|
-
state: read
|
|
71
|
-
}),
|
|
72
|
-
{ qos: 1, retain: false },
|
|
73
|
-
r
|
|
74
|
-
)
|
|
75
|
-
);
|
|
76
|
-
if (err) throw err;
|
|
77
|
-
} else {
|
|
78
|
-
throw {
|
|
79
|
-
error: "You can only use this function after you start listening."
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
} catch (e) {
|
|
83
|
-
callback(e);
|
|
84
|
-
return e;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
|
-
};
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("../../../func/logAdapter");
|
|
4
|
-
const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
|
|
5
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
6
|
-
return function markAsReadAll(callback) {
|
|
7
|
-
let resolveFunc = function() {};
|
|
8
|
-
let rejectFunc = function() {};
|
|
9
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
10
|
-
resolveFunc = resolve;
|
|
11
|
-
rejectFunc = reject;
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
if (!callback) {
|
|
15
|
-
callback = function(err, friendList) {
|
|
16
|
-
if (err) {
|
|
17
|
-
return rejectFunc(err);
|
|
18
|
-
}
|
|
19
|
-
resolveFunc(friendList);
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const form = {
|
|
24
|
-
folder: "inbox"
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
defaultFuncs
|
|
28
|
-
.post(
|
|
29
|
-
"https://www.facebook.com/ajax/mercury/mark_folder_as_read.php",
|
|
30
|
-
ctx.jar,
|
|
31
|
-
form
|
|
32
|
-
)
|
|
33
|
-
.then(saveCookies(ctx.jar))
|
|
34
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
35
|
-
.then(function(resData) {
|
|
36
|
-
if (resData.error) {
|
|
37
|
-
throw resData;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return callback();
|
|
41
|
-
})
|
|
42
|
-
.catch(function(err) {
|
|
43
|
-
log.error("markAsReadAll", err);
|
|
44
|
-
return callback(err);
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
return returnPromise;
|
|
48
|
-
};
|
|
49
|
-
};
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("../../../func/logAdapter");
|
|
4
|
-
const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
|
|
5
|
-
const { getType } = require("../../utils/format");
|
|
6
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
-
return function markAsRead(seen_timestamp, callback) {
|
|
8
|
-
if (
|
|
9
|
-
getType(seen_timestamp) == "Function" ||
|
|
10
|
-
getType(seen_timestamp) == "AsyncFunction"
|
|
11
|
-
) {
|
|
12
|
-
callback = seen_timestamp;
|
|
13
|
-
seen_timestamp = Date.now();
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
let resolveFunc = function() {};
|
|
17
|
-
let rejectFunc = function() {};
|
|
18
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
19
|
-
resolveFunc = resolve;
|
|
20
|
-
rejectFunc = reject;
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
if (!callback) {
|
|
24
|
-
callback = function(err, friendList) {
|
|
25
|
-
if (err) {
|
|
26
|
-
return rejectFunc(err);
|
|
27
|
-
}
|
|
28
|
-
resolveFunc(friendList);
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const form = {
|
|
33
|
-
seen_timestamp: seen_timestamp
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
defaultFuncs
|
|
37
|
-
.post(
|
|
38
|
-
"https://www.facebook.com/ajax/mercury/mark_seen.php",
|
|
39
|
-
ctx.jar,
|
|
40
|
-
form
|
|
41
|
-
)
|
|
42
|
-
.then(saveCookies(ctx.jar))
|
|
43
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
44
|
-
.then(function(resData) {
|
|
45
|
-
if (resData.error) {
|
|
46
|
-
throw resData;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
return callback();
|
|
50
|
-
})
|
|
51
|
-
.catch(function(err) {
|
|
52
|
-
log.error("markAsSeen", err);
|
|
53
|
-
if (getType(err) == "Object" && err.error === "Not logged in.") {
|
|
54
|
-
ctx.loggedIn = false;
|
|
55
|
-
}
|
|
56
|
-
return callback(err);
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
return returnPromise;
|
|
60
|
-
};
|
|
61
|
-
};
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const log = require("../../../func/logAdapter");
|
|
3
|
-
const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
|
|
4
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
5
|
-
// muteSecond: -1=permanent mute, 0=unmute, 60=one minute, 3600=one hour, etc.
|
|
6
|
-
return function muteThread(threadID, muteSeconds, callback) {
|
|
7
|
-
let resolveFunc = function() {};
|
|
8
|
-
let rejectFunc = function() {};
|
|
9
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
10
|
-
resolveFunc = resolve;
|
|
11
|
-
rejectFunc = reject;
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
if (!callback) {
|
|
15
|
-
callback = function(err, friendList) {
|
|
16
|
-
if (err) {
|
|
17
|
-
return rejectFunc(err);
|
|
18
|
-
}
|
|
19
|
-
resolveFunc(friendList);
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const form = {
|
|
24
|
-
thread_fbid: threadID,
|
|
25
|
-
mute_settings: muteSeconds
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
defaultFuncs
|
|
29
|
-
.post(
|
|
30
|
-
"https://www.facebook.com/ajax/mercury/change_mute_thread.php",
|
|
31
|
-
ctx.jar,
|
|
32
|
-
form
|
|
33
|
-
)
|
|
34
|
-
.then(saveCookies(ctx.jar))
|
|
35
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
36
|
-
.then(function(resData) {
|
|
37
|
-
if (resData.error) {
|
|
38
|
-
throw resData;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
return callback();
|
|
42
|
-
})
|
|
43
|
-
.catch(function(err) {
|
|
44
|
-
log.error("muteThread", err);
|
|
45
|
-
return callback(err);
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
return returnPromise;
|
|
49
|
-
};
|
|
50
|
-
};
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { getType, generateOfflineThreadingID } = require("../../utils/format");
|
|
4
|
-
|
|
5
|
-
module.exports = function (defaultFuncs, api, ctx) {
|
|
6
|
-
return function removeUserFromGroup(userID, threadID, callback) {
|
|
7
|
-
if (!ctx.mqttClient) {
|
|
8
|
-
const err = new Error("Not connected to MQTT");
|
|
9
|
-
if (callback) return callback(err);
|
|
10
|
-
return Promise.reject(err);
|
|
11
|
-
}
|
|
12
|
-
if (!callback && (getType(threadID) === "Function" || getType(threadID) === "AsyncFunction")) throw { error: "please pass a threadID as a second argument." };
|
|
13
|
-
if (getType(threadID) !== "Number" && getType(threadID) !== "String") throw { error: "threadID should be of type Number or String and not " + getType(threadID) + "." };
|
|
14
|
-
if (getType(userID) !== "Number" && getType(userID) !== "String") throw { error: "userID should be of type Number or String and not " + getType(userID) + "." };
|
|
15
|
-
var resolveFunc = function () { };
|
|
16
|
-
var rejectFunc = function () { };
|
|
17
|
-
var returnPromise = new Promise(function (resolve, reject) {
|
|
18
|
-
resolveFunc = resolve;
|
|
19
|
-
rejectFunc = reject;
|
|
20
|
-
});
|
|
21
|
-
if (!callback) {
|
|
22
|
-
callback = function (err, data) {
|
|
23
|
-
if (err) return rejectFunc(err);
|
|
24
|
-
resolveFunc(data);
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
if (typeof ctx.wsReqNumber !== "number") ctx.wsReqNumber = 0;
|
|
28
|
-
const reqID = ++ctx.wsReqNumber;
|
|
29
|
-
var form = JSON.stringify({
|
|
30
|
-
"app_id": "2220391788200892",
|
|
31
|
-
"payload": JSON.stringify({
|
|
32
|
-
epoch_id: generateOfflineThreadingID(),
|
|
33
|
-
tasks: [
|
|
34
|
-
{
|
|
35
|
-
failure_count: null,
|
|
36
|
-
label: '140',
|
|
37
|
-
payload: JSON.stringify({
|
|
38
|
-
"thread_id": threadID,
|
|
39
|
-
"contact_id": userID,
|
|
40
|
-
"sync_group": 1
|
|
41
|
-
}),
|
|
42
|
-
queue_name: 'remove_participant_v2',
|
|
43
|
-
task_id: Math.random() * 1001 << 0
|
|
44
|
-
}
|
|
45
|
-
],
|
|
46
|
-
version_id: '25002366262773827'
|
|
47
|
-
}),
|
|
48
|
-
"request_id": reqID,
|
|
49
|
-
"type": 3
|
|
50
|
-
});
|
|
51
|
-
ctx.mqttClient.publish('/ls_req', form, (err, data) => {
|
|
52
|
-
if (err) {
|
|
53
|
-
callback(err, null);
|
|
54
|
-
rejectFunc(err);
|
|
55
|
-
} else {
|
|
56
|
-
callback(null, true);
|
|
57
|
-
resolveFunc(true);
|
|
58
|
-
}
|
|
59
|
-
});
|
|
60
|
-
return returnPromise;
|
|
61
|
-
};
|
|
62
|
-
};
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const log = require("../../../func/logAdapter");
|
|
3
|
-
const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
|
|
4
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
5
|
-
return function resolvePhotoUrl(photoID, callback) {
|
|
6
|
-
let resolveFunc = function() {};
|
|
7
|
-
let rejectFunc = function() {};
|
|
8
|
-
const returnPromise = new Promise(function(resolve, reject) {
|
|
9
|
-
resolveFunc = resolve;
|
|
10
|
-
rejectFunc = reject;
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
if (!callback) {
|
|
14
|
-
callback = function(err, friendList) {
|
|
15
|
-
if (err) {
|
|
16
|
-
return rejectFunc(err);
|
|
17
|
-
}
|
|
18
|
-
resolveFunc(friendList);
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
defaultFuncs
|
|
23
|
-
.get("https://www.facebook.com/mercury/attachments/photo", ctx.jar, {
|
|
24
|
-
photo_id: photoID
|
|
25
|
-
})
|
|
26
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
27
|
-
.then(resData => {
|
|
28
|
-
if (resData.error) {
|
|
29
|
-
throw resData;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const photoUrl = resData.jsmods.require[0][3][0];
|
|
33
|
-
|
|
34
|
-
return callback(null, photoUrl);
|
|
35
|
-
})
|
|
36
|
-
.catch(err => {
|
|
37
|
-
log.error("resolvePhotoUrl", err);
|
|
38
|
-
return callback(err);
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
return returnPromise;
|
|
42
|
-
};
|
|
43
|
-
};
|