@dongdev/fca-unofficial 3.0.31 → 4.0.1
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 +238 -398
- package/dist/cjs.cjs +9 -0
- package/dist/index.d.mts +1250 -0
- package/dist/index.d.ts +1250 -0
- package/dist/index.js +27772 -0
- package/dist/index.mjs +27735 -0
- package/docs/ARCHITECTURE.md +467 -0
- package/docs/DOCS.md +709 -0
- package/fca-config.example.json +33 -0
- package/package.json +32 -22
- package/test/fca.test.cjs +540 -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,54 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("../../../func/logAdapter");
|
|
4
|
-
const { parseAndCheckLogin } = require("../../utils/client");
|
|
5
|
-
module.exports = function(defaultFuncs, api, ctx) {
|
|
6
|
-
return function unfriend(userID, 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
|
-
uid: userID,
|
|
25
|
-
unref: "bd_friends_tab",
|
|
26
|
-
floc: "friends_tab",
|
|
27
|
-
"nctr[_mod]":
|
|
28
|
-
"pagelet_timeline_app_collection_" +
|
|
29
|
-
ctx.userID +
|
|
30
|
-
":2356318349:2"
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
defaultFuncs
|
|
34
|
-
.post(
|
|
35
|
-
"https://www.facebook.com/ajax/profile/removefriendconfirm.php",
|
|
36
|
-
ctx.jar,
|
|
37
|
-
form
|
|
38
|
-
)
|
|
39
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
40
|
-
.then(function(resData) {
|
|
41
|
-
if (resData.error) {
|
|
42
|
-
throw resData;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
return callback(null, true);
|
|
46
|
-
})
|
|
47
|
-
.catch(function(err) {
|
|
48
|
-
log.error("unfriend", err);
|
|
49
|
-
return callback(err);
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
return returnPromise;
|
|
53
|
-
};
|
|
54
|
-
};
|
package/src/api/http/httpGet.js
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { getType } = require("../../utils/format");
|
|
4
|
-
const { get } = require("../../utils/request");
|
|
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("../../../func/logAdapter");
|
|
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");
|
|
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,126 +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
|
-
if (typeof ctx.wsReqNumber !== "number") ctx.wsReqNumber = 0;
|
|
11
|
-
const reqID = ++ctx.wsReqNumber;
|
|
12
|
-
let wsContent = {
|
|
13
|
-
request_id: reqID,
|
|
14
|
-
type: 3,
|
|
15
|
-
payload: {
|
|
16
|
-
version_id: '3816854585040595',
|
|
17
|
-
tasks: [],
|
|
18
|
-
epoch_id: generateOfflineThreadingID(),
|
|
19
|
-
data_trace_id: null
|
|
20
|
-
},
|
|
21
|
-
app_id: '772021112871879'
|
|
22
|
-
}
|
|
23
|
-
if (getType(adminID) === "Array") {
|
|
24
|
-
for (let i = 0; i < adminID.length; i++) {
|
|
25
|
-
wsContent.payload.tasks.push({
|
|
26
|
-
label: '25',
|
|
27
|
-
payload: JSON.stringify({ thread_key: threadID, contact_id: adminID[i], is_admin: adminStatus }),
|
|
28
|
-
queue_name: 'admin_status',
|
|
29
|
-
task_id: i + 1,
|
|
30
|
-
failure_count: null
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
} else {
|
|
34
|
-
wsContent.payload.tasks.push({
|
|
35
|
-
label: '25',
|
|
36
|
-
payload: JSON.stringify({ thread_key: threadID, contact_id: adminID, is_admin: adminStatus }),
|
|
37
|
-
queue_name: 'admin_status',
|
|
38
|
-
task_id: 1,
|
|
39
|
-
failure_count: null
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
wsContent.payload = JSON.stringify(wsContent.payload);
|
|
43
|
-
return new Promise((resolve, reject) => {
|
|
44
|
-
if (!ctx.mqttClient) {
|
|
45
|
-
return reject(new Error("Not connected to MQTT"));
|
|
46
|
-
}
|
|
47
|
-
ctx.mqttClient.publish("/ls_req", JSON.stringify(wsContent), {}, (err) => {
|
|
48
|
-
if (err) return reject(err);
|
|
49
|
-
resolve();
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
};
|
|
53
|
-
function changeAdminStatusMqtt(threadID, adminID, adminStatus) {
|
|
54
|
-
if (!ctx.mqttClient) {
|
|
55
|
-
throw new Error("Not connected to MQTT");
|
|
56
|
-
}
|
|
57
|
-
if (getType(threadID) !== "String") {
|
|
58
|
-
throw { error: "changeAdminStatus: threadID must be a string" };
|
|
59
|
-
}
|
|
60
|
-
if (getType(adminID) !== "String" && getType(adminID) !== "Array") {
|
|
61
|
-
throw { error: "changeAdminStatus: adminID must be a string or an array" };
|
|
62
|
-
}
|
|
63
|
-
if (getType(adminStatus) !== "Boolean") {
|
|
64
|
-
throw { error: "changeAdminStatus: adminStatus must be true or false" };
|
|
65
|
-
}
|
|
66
|
-
const tasks = [];
|
|
67
|
-
const isAdmin = adminStatus ? 1 : 0;
|
|
68
|
-
const epochID = generateOfflineThreadingID();
|
|
69
|
-
if (getType(adminID) === "Array") {
|
|
70
|
-
adminID.forEach((id, index) => {
|
|
71
|
-
tasks.push({
|
|
72
|
-
failure_count: null,
|
|
73
|
-
label: "25",
|
|
74
|
-
payload: JSON.stringify({
|
|
75
|
-
thread_key: threadID,
|
|
76
|
-
contact_id: id,
|
|
77
|
-
is_admin: isAdmin
|
|
78
|
-
}),
|
|
79
|
-
queue_name: "admin_status",
|
|
80
|
-
task_id: index + 1
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
} else {
|
|
84
|
-
tasks.push({
|
|
85
|
-
failure_count: null,
|
|
86
|
-
label: "25",
|
|
87
|
-
payload: JSON.stringify({
|
|
88
|
-
thread_key: threadID,
|
|
89
|
-
contact_id: adminID,
|
|
90
|
-
is_admin: isAdmin
|
|
91
|
-
}),
|
|
92
|
-
queue_name: "admin_status",
|
|
93
|
-
task_id: 1
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
if (typeof ctx.wsReqNumber !== "number") ctx.wsReqNumber = 0;
|
|
97
|
-
const reqID = ++ctx.wsReqNumber;
|
|
98
|
-
const form = JSON.stringify({
|
|
99
|
-
app_id: "2220391788200892",
|
|
100
|
-
payload: JSON.stringify({
|
|
101
|
-
epoch_id: epochID,
|
|
102
|
-
tasks: tasks,
|
|
103
|
-
version_id: "8798795233522156"
|
|
104
|
-
}),
|
|
105
|
-
request_id: reqID,
|
|
106
|
-
type: 3
|
|
107
|
-
});
|
|
108
|
-
return new Promise((resolve, reject) => {
|
|
109
|
-
ctx.mqttClient.publish("/ls_req", form, {}, (err) => {
|
|
110
|
-
if (err) return reject(err);
|
|
111
|
-
resolve();
|
|
112
|
-
});
|
|
113
|
-
});
|
|
114
|
-
};
|
|
115
|
-
return function changeAdminStatus(threadID, adminID, adminStatus) {
|
|
116
|
-
if (ctx.mqttClient) {
|
|
117
|
-
try {
|
|
118
|
-
return changeAdminStatusMqtt(threadID, adminID, adminStatus);
|
|
119
|
-
} catch (e) {
|
|
120
|
-
return changeAdminStatusNoMqtt(threadID, adminID, adminStatus);
|
|
121
|
-
}
|
|
122
|
-
} else {
|
|
123
|
-
return changeAdminStatusNoMqtt(threadID, adminID, adminStatus);
|
|
124
|
-
}
|
|
125
|
-
};
|
|
126
|
-
};
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const log = require("../../../func/logAdapter");
|
|
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
|
-
};
|
|
@@ -1,48 +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 changeBlockedStatus(userID, block, 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) {
|
|
16
|
-
if (err) {
|
|
17
|
-
return rejectFunc(err);
|
|
18
|
-
}
|
|
19
|
-
resolveFunc();
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
defaultFuncs
|
|
24
|
-
.post(
|
|
25
|
-
`https://www.facebook.com/messaging/${
|
|
26
|
-
block ? "" : "un"
|
|
27
|
-
}block_messages/`,
|
|
28
|
-
ctx.jar,
|
|
29
|
-
{
|
|
30
|
-
fbid: userID
|
|
31
|
-
}
|
|
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("changeBlockedStatus", err);
|
|
44
|
-
return callback(err);
|
|
45
|
-
});
|
|
46
|
-
return returnPromise;
|
|
47
|
-
};
|
|
48
|
-
};
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { generateOfflineThreadingID } = require("../../utils/format");
|
|
4
|
-
const log = require("../../../func/logAdapter");
|
|
5
|
-
|
|
6
|
-
module.exports = function (defaultFuncs, api, ctx) {
|
|
7
|
-
function handleUpload(image) {
|
|
8
|
-
const form = {
|
|
9
|
-
images_only: "true",
|
|
10
|
-
fb_dtsg: ctx.fb_dtsg,
|
|
11
|
-
"attachment[]": image
|
|
12
|
-
};
|
|
13
|
-
return defaultFuncs
|
|
14
|
-
.postFormData("https://www.facebook.com/ajax/mercury/upload.php", ctx.jar, form, {})
|
|
15
|
-
.then(parseAndCheckLogin(ctx, defaultFuncs))
|
|
16
|
-
.then(resData => {
|
|
17
|
-
if (resData.error) throw resData;
|
|
18
|
-
return resData.payload.metadata[0];
|
|
19
|
-
});
|
|
20
|
-
}
|
|
21
|
-
return function changeGroupImage(image, threadID, callback) {
|
|
22
|
-
return new Promise((resolve, reject) => {
|
|
23
|
-
if (!ctx.mqttClient) {
|
|
24
|
-
const err = new Error("Not connected to MQTT");
|
|
25
|
-
callback?.(err);
|
|
26
|
-
return reject(err);
|
|
27
|
-
}
|
|
28
|
-
if (!threadID || typeof threadID !== "string") {
|
|
29
|
-
const err = new Error("Invalid threadID");
|
|
30
|
-
callback?.(err);
|
|
31
|
-
return reject(err);
|
|
32
|
-
}
|
|
33
|
-
const reqID = ++ctx.wsReqNumber;
|
|
34
|
-
const taskID = ++ctx.wsTaskNumber;
|
|
35
|
-
const onResponse = (topic, message) => {
|
|
36
|
-
if (topic !== "/ls_resp") return;
|
|
37
|
-
let jsonMsg;
|
|
38
|
-
try {
|
|
39
|
-
jsonMsg = JSON.parse(message.toString());
|
|
40
|
-
jsonMsg.payload = JSON.parse(jsonMsg.payload);
|
|
41
|
-
} catch (err) {
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
if (jsonMsg.request_id !== reqID) return;
|
|
45
|
-
ctx.mqttClient.removeListener("message", onResponse);
|
|
46
|
-
callback?.(null, { success: true, response: jsonMsg.payload });
|
|
47
|
-
return resolve({ success: true, response: jsonMsg.payload });
|
|
48
|
-
};
|
|
49
|
-
ctx.mqttClient.on("message", onResponse);
|
|
50
|
-
handleUpload(image)
|
|
51
|
-
.then(payload => {
|
|
52
|
-
const imageID = payload.image_id;
|
|
53
|
-
const taskPayload = {
|
|
54
|
-
thread_key: threadID,
|
|
55
|
-
image_id: imageID,
|
|
56
|
-
sync_group: 1
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
const mqttPayload = {
|
|
60
|
-
epoch_id: generateOfflineThreadingID(),
|
|
61
|
-
tasks: [
|
|
62
|
-
{
|
|
63
|
-
failure_count: null,
|
|
64
|
-
label: "37",
|
|
65
|
-
payload: JSON.stringify(taskPayload),
|
|
66
|
-
queue_name: "thread_image",
|
|
67
|
-
task_id: taskID
|
|
68
|
-
}
|
|
69
|
-
],
|
|
70
|
-
version_id: "8798795233522156"
|
|
71
|
-
};
|
|
72
|
-
const request = {
|
|
73
|
-
app_id: "2220391788200892",
|
|
74
|
-
payload: JSON.stringify(mqttPayload),
|
|
75
|
-
request_id: reqID,
|
|
76
|
-
type: 3
|
|
77
|
-
};
|
|
78
|
-
ctx.mqttClient.publish("/ls_req", JSON.stringify(request), {
|
|
79
|
-
qos: 1,
|
|
80
|
-
retain: false
|
|
81
|
-
});
|
|
82
|
-
})
|
|
83
|
-
.catch(err => {
|
|
84
|
-
ctx.mqttClient.removeListener("message", onResponse);
|
|
85
|
-
log.error("changeGroupImageMqtt", err);
|
|
86
|
-
callback?.(err);
|
|
87
|
-
reject(err);
|
|
88
|
-
});
|
|
89
|
-
});
|
|
90
|
-
};
|
|
91
|
-
};
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const { generateOfflineThreadingID } = require("../../utils/format");
|
|
4
|
-
const log = require("../../../func/logAdapter");
|
|
5
|
-
|
|
6
|
-
module.exports = function (defaultFuncs, api, ctx) {
|
|
7
|
-
return function changeNickname(nickname, threadID, participantID, callback) {
|
|
8
|
-
return new Promise((resolve, reject) => {
|
|
9
|
-
if (!ctx.mqttClient) {
|
|
10
|
-
const err = new Error("Not connected to MQTT");
|
|
11
|
-
callback?.(err);
|
|
12
|
-
return reject(err);
|
|
13
|
-
}
|
|
14
|
-
if (!threadID || !participantID) {
|
|
15
|
-
const err = new Error("Missing required parameters");
|
|
16
|
-
callback?.(err);
|
|
17
|
-
return reject(err);
|
|
18
|
-
}
|
|
19
|
-
const reqID = ++ctx.wsReqNumber;
|
|
20
|
-
const taskID = ++ctx.wsTaskNumber;
|
|
21
|
-
const payload = {
|
|
22
|
-
epoch_id: generateOfflineThreadingID(),
|
|
23
|
-
tasks: [
|
|
24
|
-
{
|
|
25
|
-
failure_count: null,
|
|
26
|
-
label: "44",
|
|
27
|
-
payload: JSON.stringify({
|
|
28
|
-
thread_key: threadID,
|
|
29
|
-
contact_id: participantID,
|
|
30
|
-
nickname: nickname || "",
|
|
31
|
-
sync_group: 1
|
|
32
|
-
}),
|
|
33
|
-
queue_name: "thread_participant_nickname",
|
|
34
|
-
task_id: taskID
|
|
35
|
-
}
|
|
36
|
-
],
|
|
37
|
-
version_id: "8798795233522156"
|
|
38
|
-
};
|
|
39
|
-
const request = {
|
|
40
|
-
app_id: "2220391788200892",
|
|
41
|
-
payload: JSON.stringify(payload),
|
|
42
|
-
request_id: reqID,
|
|
43
|
-
type: 3
|
|
44
|
-
};
|
|
45
|
-
const onResponse = (topic, message) => {
|
|
46
|
-
if (topic !== "/ls_resp") return;
|
|
47
|
-
let jsonMsg;
|
|
48
|
-
try {
|
|
49
|
-
jsonMsg = JSON.parse(message.toString());
|
|
50
|
-
jsonMsg.payload = JSON.parse(jsonMsg.payload);
|
|
51
|
-
} catch (err) {
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
if (jsonMsg.request_id !== reqID) return;
|
|
55
|
-
ctx.mqttClient.removeListener("message", onResponse);
|
|
56
|
-
callback?.(null, { success: true, response: jsonMsg.payload });
|
|
57
|
-
return resolve({ success: true, response: jsonMsg.payload });
|
|
58
|
-
};
|
|
59
|
-
ctx.mqttClient.on("message", onResponse);
|
|
60
|
-
ctx.mqttClient.publish("/ls_req", JSON.stringify(request), { qos: 1, retain: false }, (err) => {
|
|
61
|
-
if (err) {
|
|
62
|
-
ctx.mqttClient.removeListener("message", onResponse);
|
|
63
|
-
log.error("changeNicknameMqtt", err);
|
|
64
|
-
callback?.(err);
|
|
65
|
-
return reject(err);
|
|
66
|
-
}
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
};
|
|
70
|
-
};
|