@dongdev/fca-unofficial 3.0.30 → 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.
Files changed (104) hide show
  1. package/LICENSE +191 -0
  2. package/README.md +224 -406
  3. package/dist/index.d.mts +1241 -0
  4. package/dist/index.d.ts +1241 -0
  5. package/dist/index.js +27749 -0
  6. package/dist/index.mjs +27713 -0
  7. package/docs/ARCHITECTURE.md +467 -0
  8. package/docs/DOCS.md +686 -0
  9. package/fca-config.example.json +33 -0
  10. package/package.json +33 -22
  11. package/test/fca.test.cjs +533 -0
  12. package/CHANGELOG.md +0 -293
  13. package/DOCS.md +0 -2712
  14. package/func/checkUpdate.js +0 -222
  15. package/func/logAdapter.js +0 -33
  16. package/func/logger.js +0 -48
  17. package/index.d.ts +0 -751
  18. package/index.js +0 -8
  19. package/module/config.js +0 -40
  20. package/module/login.js +0 -133
  21. package/module/loginHelper.js +0 -1296
  22. package/module/options.js +0 -44
  23. package/src/api/action/addExternalModule.js +0 -25
  24. package/src/api/action/changeAvatar.js +0 -137
  25. package/src/api/action/changeBio.js +0 -75
  26. package/src/api/action/enableAutoSaveAppState.js +0 -73
  27. package/src/api/action/getCurrentUserID.js +0 -7
  28. package/src/api/action/handleFriendRequest.js +0 -57
  29. package/src/api/action/logout.js +0 -76
  30. package/src/api/action/refreshFb_dtsg.js +0 -48
  31. package/src/api/action/setPostReaction.js +0 -106
  32. package/src/api/action/unfriend.js +0 -54
  33. package/src/api/http/httpGet.js +0 -46
  34. package/src/api/http/httpPost.js +0 -52
  35. package/src/api/http/postFormData.js +0 -47
  36. package/src/api/messaging/addUserToGroup.js +0 -68
  37. package/src/api/messaging/changeAdminStatus.js +0 -126
  38. package/src/api/messaging/changeArchivedStatus.js +0 -55
  39. package/src/api/messaging/changeBlockedStatus.js +0 -48
  40. package/src/api/messaging/changeGroupImage.js +0 -91
  41. package/src/api/messaging/changeNickname.js +0 -70
  42. package/src/api/messaging/changeThreadColor.js +0 -79
  43. package/src/api/messaging/changeThreadEmoji.js +0 -111
  44. package/src/api/messaging/createNewGroup.js +0 -88
  45. package/src/api/messaging/createPoll.js +0 -46
  46. package/src/api/messaging/createThemeAI.js +0 -98
  47. package/src/api/messaging/deleteMessage.js +0 -136
  48. package/src/api/messaging/deleteThread.js +0 -56
  49. package/src/api/messaging/editMessage.js +0 -68
  50. package/src/api/messaging/forwardAttachment.js +0 -57
  51. package/src/api/messaging/getEmojiUrl.js +0 -29
  52. package/src/api/messaging/getFriendsList.js +0 -82
  53. package/src/api/messaging/getMessage.js +0 -829
  54. package/src/api/messaging/getThemePictures.js +0 -62
  55. package/src/api/messaging/handleMessageRequest.js +0 -65
  56. package/src/api/messaging/markAsDelivered.js +0 -57
  57. package/src/api/messaging/markAsRead.js +0 -88
  58. package/src/api/messaging/markAsReadAll.js +0 -49
  59. package/src/api/messaging/markAsSeen.js +0 -61
  60. package/src/api/messaging/muteThread.js +0 -50
  61. package/src/api/messaging/removeUserFromGroup.js +0 -62
  62. package/src/api/messaging/resolvePhotoUrl.js +0 -43
  63. package/src/api/messaging/scheduler.js +0 -264
  64. package/src/api/messaging/searchForThread.js +0 -52
  65. package/src/api/messaging/sendMessage.js +0 -270
  66. package/src/api/messaging/sendTypingIndicator.js +0 -74
  67. package/src/api/messaging/setMessageReaction.js +0 -91
  68. package/src/api/messaging/setTitle.js +0 -124
  69. package/src/api/messaging/shareContact.js +0 -49
  70. package/src/api/messaging/threadColors.js +0 -128
  71. package/src/api/messaging/unsendMessage.js +0 -81
  72. package/src/api/messaging/uploadAttachment.js +0 -492
  73. package/src/api/socket/core/connectMqtt.js +0 -258
  74. package/src/api/socket/core/emitAuth.js +0 -103
  75. package/src/api/socket/core/getSeqID.js +0 -320
  76. package/src/api/socket/core/getTaskResponseData.js +0 -25
  77. package/src/api/socket/core/parseDelta.js +0 -377
  78. package/src/api/socket/detail/buildStream.js +0 -215
  79. package/src/api/socket/detail/constants.js +0 -28
  80. package/src/api/socket/listenMqtt.js +0 -377
  81. package/src/api/socket/middleware/index.js +0 -216
  82. package/src/api/threads/getThreadHistory.js +0 -664
  83. package/src/api/threads/getThreadInfo.js +0 -295
  84. package/src/api/threads/getThreadList.js +0 -293
  85. package/src/api/threads/getThreadPictures.js +0 -78
  86. package/src/api/users/getUserID.js +0 -65
  87. package/src/api/users/getUserInfo.js +0 -399
  88. package/src/api/users/getUserInfoV2.js +0 -134
  89. package/src/core/sendReqMqtt.js +0 -96
  90. package/src/database/models/index.js +0 -87
  91. package/src/database/models/thread.js +0 -50
  92. package/src/database/models/user.js +0 -46
  93. package/src/database/threadData.js +0 -98
  94. package/src/database/userData.js +0 -89
  95. package/src/remote/remoteClient.js +0 -123
  96. package/src/utils/broadcast.js +0 -51
  97. package/src/utils/client.js +0 -10
  98. package/src/utils/constants.js +0 -23
  99. package/src/utils/cookies.js +0 -68
  100. package/src/utils/format.js +0 -1174
  101. package/src/utils/headers.js +0 -115
  102. package/src/utils/loginParser.js +0 -365
  103. package/src/utils/messageFormat.js +0 -1173
  104. package/src/utils/request.js +0 -332
@@ -1,79 +0,0 @@
1
- "use strict";
2
-
3
- const { generateOfflineThreadingID } = require("../../utils/format.js");
4
- module.exports = (defaultFuncs, api, ctx) => {
5
- return async (color, threadID, callback) => {
6
- let reqID = ++ctx.wsReqNumber;
7
- let resolveFunc = () => { };
8
- let rejectFunc = () => { };
9
- const returnPromise = new Promise((resolve, reject) => {
10
- resolveFunc = resolve;
11
- rejectFunc = reject;
12
- });
13
-
14
- if (!callback) {
15
- callback = (err, data) => {
16
- if (err) return rejectFunc(err);
17
- resolveFunc(data);
18
- };
19
- }
20
-
21
- const content = {
22
- app_id: "2220391788200892",
23
- payload: JSON.stringify({
24
- data_trace_id: null,
25
- epoch_id: parseInt(generateOfflineThreadingID()),
26
- tasks: [
27
- {
28
- failure_count: null,
29
- label: "43",
30
- payload: JSON.stringify({
31
- thread_key: threadID,
32
- theme_fbid: color,
33
- source: null,
34
- sync_group: 1,
35
- payload: null
36
- }),
37
- queue_name: "thread_theme",
38
- task_id: ++ctx.wsTaskNumber
39
- }
40
- ],
41
- version_id: "8798795233522156"
42
- }),
43
- request_id: reqID,
44
- type: 3
45
- };
46
-
47
- ctx.mqttClient.publish("/ls_req", JSON.stringify(content), {
48
- qos: 1,
49
- retain: false
50
- });
51
-
52
- const handleRes = (topic, message) => {
53
- if (topic !== "/ls_resp") return;
54
- let jsonMsg;
55
- try {
56
- jsonMsg = JSON.parse(message.toString());
57
- jsonMsg.payload = JSON.parse(jsonMsg.payload);
58
- } catch (err) {
59
- return;
60
- }
61
- if (jsonMsg.request_id !== reqID) return;
62
- ctx.mqttClient.removeListener("message", handleRes);
63
- try {
64
- const msgID = jsonMsg.payload.step[1][2][2][1][2];
65
- const msgReplace = jsonMsg.payload.step[1][2][2][1][4];
66
- const bodies = {
67
- body: msgReplace,
68
- messageID: msgID
69
- };
70
- return callback(null, bodies);
71
- } catch (err) {
72
- return callback(null, { success: true });
73
- }
74
- };
75
-
76
- ctx.mqttClient.on("message", handleRes);
77
- return returnPromise;
78
- };
79
- };
@@ -1,111 +0,0 @@
1
- "use strict";
2
-
3
- const { generateOfflineThreadingID } = require("../../utils/format");
4
- const log = require("../../../func/logAdapter");
5
- const { parseAndCheckLogin } = require("../../utils/client");
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- function changeThreadEmojiNoMqtt(emoji, 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
- if (!callback) {
15
- callback = function (err) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc();
20
- };
21
- }
22
- var form = {
23
- emoji_choice: emoji,
24
- thread_or_other_fbid: threadID,
25
- };
26
- defaultFuncs
27
- .post(
28
- "https://www.facebook.com/messaging/save_thread_emoji/?source=thread_settings&__pc=EXP1%3Amessengerdotcom_pkg",
29
- ctx.jar,
30
- form,
31
- )
32
- .then(parseAndCheckLogin(ctx, defaultFuncs))
33
- .then(function (resData) {
34
- if (resData.error === 1357031) {
35
- throw {
36
- error:
37
- "Trying to change emoji of a chat that doesn't exist. Have at least one message in the thread before trying to change the emoji.",
38
- };
39
- }
40
- if (resData.error) {
41
- throw resData;
42
- }
43
- return callback();
44
- })
45
- .catch(function (err) {
46
- log.error("changeThreadEmoji", err);
47
- return callback(err);
48
- });
49
- return returnPromise;
50
- };
51
- function changeThreadEmojiMqtt(emoji, threadID, callback) {
52
- if (!ctx.mqttClient) {
53
- throw new Error("Not connected to MQTT");
54
- }
55
- if (typeof ctx.wsReqNumber !== "number") ctx.wsReqNumber = 0;
56
- const reqID = ++ctx.wsReqNumber;
57
- var resolveFunc = function () { };
58
- var rejectFunc = function () { };
59
- var returnPromise = new Promise(function (resolve, reject) {
60
- resolveFunc = resolve;
61
- rejectFunc = reject;
62
- });
63
- const done = (err, data) => {
64
- if (err) {
65
- if (callback) callback(err);
66
- return rejectFunc(err);
67
- }
68
- if (callback) callback(null, data);
69
- resolveFunc(data);
70
- };
71
- var form = JSON.stringify({
72
- "app_id": "2220391788200892",
73
- "payload": JSON.stringify({
74
- epoch_id: generateOfflineThreadingID(),
75
- tasks: [
76
- {
77
- failure_count: null,
78
- label: '100003',
79
- payload: JSON.stringify({
80
- "thread_key": threadID,
81
- "custom_emoji": emoji,
82
- "avatar_sticker_instruction_key_id": null,
83
- "sync_group": 1
84
- }),
85
- queue_name: 'thread_quick_reaction',
86
- task_id: Math.random() * 1001 << 0
87
- }
88
- ],
89
- version_id: '8798795233522156'
90
- }),
91
- "request_id": reqID,
92
- "type": 3
93
- });
94
- ctx.mqttClient.publish("/ls_req", form, { qos: 1, retain: false }, (err) => {
95
- if (err) return done(err);
96
- done(null, { success: true });
97
- });
98
- return returnPromise;
99
- };
100
- return function changeThreadEmoji(emoji, threadID, callback) {
101
- if (ctx.mqttClient) {
102
- try {
103
- return changeThreadEmojiMqtt(emoji, threadID, callback);
104
- } catch (e) {
105
- return changeThreadEmojiNoMqtt(emoji, threadID, callback);
106
- }
107
- } else {
108
- return changeThreadEmojiNoMqtt(emoji, threadID, callback);
109
- }
110
- };
111
- };
@@ -1,88 +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 createNewGroup(participantIDs, groupTitle, callback) {
8
- if (getType(groupTitle) == "Function") {
9
- callback = groupTitle;
10
- groupTitle = null;
11
- }
12
-
13
- if (getType(participantIDs) !== "Array") {
14
- throw { error: "createNewGroup: participantIDs should be an array." };
15
- }
16
-
17
- if (participantIDs.length < 2) {
18
- throw {
19
- error: "createNewGroup: participantIDs should have at least 2 IDs."
20
- };
21
- }
22
-
23
- let resolveFunc = function() {};
24
- let rejectFunc = function() {};
25
- const returnPromise = new Promise(function(resolve, reject) {
26
- resolveFunc = resolve;
27
- rejectFunc = reject;
28
- });
29
-
30
- if (!callback) {
31
- callback = function(err, threadID) {
32
- if (err) {
33
- return rejectFunc(err);
34
- }
35
- resolveFunc(threadID);
36
- };
37
- }
38
-
39
- const pids = [];
40
- for (const n in participantIDs) {
41
- pids.push({
42
- fbid: participantIDs[n]
43
- });
44
- }
45
- pids.push({ fbid: ctx.i_userID || ctx.userID });
46
-
47
- const form = {
48
- fb_api_caller_class: "RelayModern",
49
- fb_api_req_friendly_name: "MessengerGroupCreateMutation",
50
- av: ctx.i_userID || ctx.userID,
51
- //This doc_id is valid as of January 11th, 2020
52
- doc_id: "577041672419534",
53
- variables: JSON.stringify({
54
- input: {
55
- entry_point: "jewel_new_group",
56
- actor_id: ctx.i_userID || ctx.userID,
57
- participants: pids,
58
- client_mutation_id: Math.round(Math.random() * 1024).toString(),
59
- thread_settings: {
60
- name: groupTitle,
61
- joinable_mode: "PRIVATE",
62
- thread_image_fbid: null
63
- }
64
- }
65
- })
66
- };
67
-
68
- defaultFuncs
69
- .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
70
- .then(parseAndCheckLogin(ctx, defaultFuncs))
71
- .then(function(resData) {
72
- if (resData.errors) {
73
- throw resData;
74
- }
75
- return callback(
76
- null,
77
- resData.data.messenger_group_thread_create.thread.thread_key
78
- .thread_fbid
79
- );
80
- })
81
- .catch(function(err) {
82
- log.error("createNewGroup", err);
83
- return callback(err);
84
- });
85
-
86
- return returnPromise;
87
- };
88
- };
@@ -1,46 +0,0 @@
1
- "use strict";
2
-
3
- const { generateOfflineThreadingID } = require("../../utils/format");
4
-
5
- module.exports = function (defaultFuncs, api, ctx) {
6
- return async function createPoll(threadID, questionText, options) {
7
- let count_req = 0;
8
- return new Promise((resolve, reject) => {
9
- if (!ctx.mqttClient) {
10
- return reject(new Error("Not connected to MQTT"));
11
- }
12
- const payload = {
13
- epoch_id: generateOfflineThreadingID(),
14
- tasks: [
15
- {
16
- failure_count: null,
17
- label: "163",
18
- payload: JSON.stringify({
19
- question_text: questionText,
20
- thread_key: threadID,
21
- options: options,
22
- sync_group: 1,
23
- }),
24
- queue_name: "poll_creation",
25
- task_id: Math.floor(Math.random() * 1001),
26
- },
27
- ],
28
- version_id: "34195258046739157",
29
- };
30
-
31
- const form = JSON.stringify({
32
- app_id: "2220391788200892",
33
- payload: JSON.stringify(payload),
34
- request_id: ++count_req,
35
- type: 3,
36
- });
37
-
38
- try {
39
- ctx.mqttClient.publish("/ls_req", form);
40
- resolve();
41
- } catch (err) {
42
- reject(err);
43
- }
44
- });
45
- };
46
- };
@@ -1,98 +0,0 @@
1
- "use strict";
2
-
3
- const log = require("../../../func/logAdapter");
4
- const { getType } = require("../../utils/format");
5
- const { parseAndCheckLogin } = require("../../utils/client");
6
-
7
- module.exports = function (defaultFuncs, api, ctx) {
8
- return function createThemeAI(prompt, 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, data) {
18
- if (err) return rejectFunc(err);
19
- resolveFunc(data);
20
- };
21
- }
22
-
23
- if (getType(prompt) !== "String") {
24
- return callback({ error: "Invalid prompt. Please provide a string." });
25
- }
26
-
27
- if (!prompt || prompt.trim().length === 0) {
28
- return callback({ error: "Prompt cannot be empty." });
29
- }
30
-
31
- const form = {
32
- av: ctx.userID,
33
- fb_api_caller_class: "RelayModern",
34
- fb_api_req_friendly_name: "useGenerateAIThemeMutation",
35
- doc_id: "23873748445608673",
36
- variables: JSON.stringify({
37
- input: {
38
- client_mutation_id: Math.round(Math.random() * 19).toString(),
39
- actor_id: ctx.userID,
40
- bypass_cache: true,
41
- caller: "MESSENGER",
42
- num_themes: 1,
43
- prompt: prompt.trim()
44
- }
45
- }),
46
- server_timestamps: true
47
- };
48
-
49
- defaultFuncs
50
- .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
51
- .then(parseAndCheckLogin(ctx, defaultFuncs))
52
- .then(function (resData) {
53
- if (resData.errors) {
54
- throw resData;
55
- }
56
-
57
- if (!resData.data || !resData.data.xfb_generate_ai_themes_from_prompt) {
58
- throw {
59
- error: "Invalid response from Facebook API",
60
- res: resData
61
- };
62
- }
63
-
64
- const themes = resData.data.xfb_generate_ai_themes_from_prompt.themes;
65
- if (!themes || !Array.isArray(themes) || themes.length === 0) {
66
- throw {
67
- error: "No themes generated",
68
- res: resData
69
- };
70
- }
71
-
72
- const theme = themes[0];
73
- if (!theme || !theme.id || !theme.background_asset) {
74
- throw {
75
- error: "Invalid theme data",
76
- res: resData
77
- };
78
- }
79
-
80
- callback(null, {
81
- id: theme.id,
82
- accessibility_label: theme.accessibility_label || null,
83
- background_asset: {
84
- id: theme.background_asset.id,
85
- image: {
86
- url: theme.background_asset.image?.uri || null
87
- }
88
- }
89
- });
90
- })
91
- .catch(function (err) {
92
- log.error("createThemeAI", err);
93
- return callback(err);
94
- });
95
-
96
- return returnPromise;
97
- };
98
- };
@@ -1,136 +0,0 @@
1
- "use strict";
2
-
3
- const log = require("../../../func/logAdapter");
4
- const { getType, generateOfflineThreadingID } = require("../../utils/format");
5
-
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- return function deleteMessage(messageOrMessages, 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
- if (!callback) {
15
- callback = function (err) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc();
20
- };
21
- }
22
-
23
- if (getType(messageOrMessages) !== "Array") {
24
- messageOrMessages = [messageOrMessages];
25
- }
26
-
27
- if (!ctx || !ctx.mqttClient) {
28
- const err = new Error("Not connected to MQTT");
29
- callback(err);
30
- return rejectFunc(err);
31
- }
32
-
33
- const epochId = String(generateOfflineThreadingID());
34
- if (typeof ctx.wsTaskNumber !== "number") ctx.wsTaskNumber = 0;
35
- if (typeof ctx.wsReqNumber !== "number") ctx.wsReqNumber = 0;
36
-
37
- const tasks = messageOrMessages.map((threadID) => {
38
- const threadKey = String(threadID);
39
- const taskPayload = `{"thread_key":${threadKey},"remove_type":0,"sync_group":1}`;
40
- return {
41
- failure_count: null,
42
- label: "146",
43
- payload: taskPayload,
44
- queue_name: threadKey,
45
- task_id: ++ctx.wsTaskNumber,
46
- };
47
- });
48
-
49
- const payload = `{"epoch_id":${epochId},"tasks":${JSON.stringify(
50
- tasks,
51
- )},"version_id":"25909428212080747"}`;
52
-
53
- const reqID = ++ctx.wsReqNumber;
54
- const form = JSON.stringify({
55
- app_id: "2220391788200892",
56
- payload,
57
- request_id: reqID,
58
- type: 3,
59
- });
60
-
61
- let timer = null;
62
-
63
- const cleanup = () => {
64
- if (timer) {
65
- clearTimeout(timer);
66
- timer = null;
67
- }
68
- try {
69
- ctx.mqttClient?.removeListener("message", handleRes);
70
- } catch (e) {
71
- // ignore
72
- }
73
- };
74
-
75
- const handleRes = (topic, message) => {
76
- if (topic !== "/ls_resp") return;
77
- let msg;
78
- try {
79
- msg = JSON.parse(message.toString());
80
- } catch {
81
- return;
82
- }
83
- if (msg.request_id !== reqID) return;
84
- cleanup();
85
- try {
86
- msg.payload =
87
- typeof msg.payload === "string"
88
- ? JSON.parse(msg.payload)
89
- : msg.payload;
90
- } catch {}
91
- callback(null, { success: true, response: msg.payload });
92
- resolveFunc({ success: true, response: msg.payload });
93
- };
94
-
95
- try {
96
- ctx.mqttClient.on("message", handleRes);
97
- } catch (err) {
98
- cleanup();
99
- log.error("deleteMessage", err);
100
- callback(err);
101
- rejectFunc(err);
102
- return returnPromise;
103
- }
104
-
105
- timer = setTimeout(() => {
106
- const err = new Error("MQTT response timeout");
107
- cleanup();
108
- log.error("deleteMessage", err);
109
- callback(err);
110
- rejectFunc(err);
111
- }, 20000);
112
-
113
- try {
114
- ctx.mqttClient.publish(
115
- "/ls_req",
116
- form,
117
- { qos: 1, retain: false },
118
- (err) => {
119
- if (err) {
120
- cleanup();
121
- log.error("deleteMessage", err);
122
- callback(err);
123
- rejectFunc(err);
124
- }
125
- },
126
- );
127
- } catch (err) {
128
- cleanup();
129
- log.error("deleteMessage", err);
130
- callback(err);
131
- rejectFunc(err);
132
- }
133
-
134
- return returnPromise;
135
- };
136
- };
@@ -1,56 +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 deleteThread(threadOrThreads, 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
- if (!callback) {
15
- callback = function(err) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc();
20
- };
21
- }
22
-
23
- const form = {
24
- client: "mercury"
25
- };
26
-
27
- if (getType(threadOrThreads) !== "Array") {
28
- threadOrThreads = [threadOrThreads];
29
- }
30
-
31
- for (let i = 0; i < threadOrThreads.length; i++) {
32
- form["ids[" + i + "]"] = threadOrThreads[i];
33
- }
34
-
35
- defaultFuncs
36
- .post(
37
- "https://www.facebook.com/ajax/mercury/delete_thread.php",
38
- ctx.jar,
39
- form
40
- )
41
- .then(parseAndCheckLogin(ctx, defaultFuncs))
42
- .then(function(resData) {
43
- if (resData.error) {
44
- throw resData;
45
- }
46
-
47
- return callback();
48
- })
49
- .catch(function(err) {
50
- log.error("deleteThread", err);
51
- return callback(err);
52
- });
53
-
54
- return returnPromise;
55
- };
56
- };
@@ -1,68 +0,0 @@
1
- "use_strict";
2
-
3
- const { generateOfflineThreadingID } = require("../../utils/format.js");
4
- module.exports = (defaultFuncs, api, ctx) => {
5
- return (text, messageID, callback) => {
6
- let reqID = ctx.wsReqNumber + 1;
7
- var resolveFunc = () => { };
8
- var rejectFunc = () => { };
9
- var returnPromise = new Promise((resolve, reject) => {
10
- resolveFunc = resolve;
11
- rejectFunc = reject;
12
- });
13
- if (!callback) {
14
- callback = (err, data) => {
15
- if (err) {
16
- return rejectFunc(err);
17
- }
18
- resolveFunc(data);
19
- };
20
- }
21
- const content = {
22
- app_id: '2220391788200892',
23
- payload: JSON.stringify({
24
- data_trace_id: null,
25
- epoch_id: parseInt(generateOfflineThreadingID()),
26
- tasks: [{
27
- failure_count: null,
28
- label: '742',
29
- payload: JSON.stringify({
30
- message_id: messageID,
31
- text: text,
32
- }),
33
- queue_name: 'edit_message',
34
- task_id: ++ctx.wsTaskNumber,
35
- }],
36
- version_id: '6903494529735864',
37
- }),
38
- request_id: ++ctx.wsReqNumber,
39
- type: 3
40
- }
41
- ctx.mqttClient.publish('/ls_req', JSON.stringify(content), {
42
- qos: 1,
43
- retain: false
44
- });
45
- const handleRes = (topic, message) => {
46
- if (topic === "/ls_resp") {
47
- let jsonMsg = JSON.parse(message.toString());
48
- jsonMsg.payload = JSON.parse(jsonMsg.payload);
49
- if (jsonMsg.request_id != reqID) return;
50
- ctx.mqttClient.removeListener('message', handleRes);
51
- let msgID = jsonMsg.payload.step[1][2][2][1][2];
52
- let msgReplace = jsonMsg.payload.step[1][2][2][1][4];
53
- const bodies = {
54
- body: msgReplace,
55
- messageID: msgID
56
- };
57
- if (msgReplace != text) {
58
- return callback({
59
- error: "The message is too old or not from you!"
60
- }, bodies);
61
- }
62
- return callback(undefined, bodies);
63
- }
64
- }
65
- ctx.mqttClient.on('message', handleRes);
66
- return returnPromise;
67
- };
68
- }