@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.
Files changed (127) 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 +32 -22
  11. package/test/fca.test.cjs +533 -0
  12. package/CHANGELOG.md +0 -296
  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 -53
  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 -90
  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 -296
  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 -402
  88. package/src/api/users/getUserInfoV2.js +0 -134
  89. package/src/core/sendReqMqtt.js +0 -96
  90. package/src/database/helpers.js +0 -53
  91. package/src/database/models/index.js +0 -88
  92. package/src/database/models/thread.js +0 -50
  93. package/src/database/models/user.js +0 -46
  94. package/src/database/threadData.js +0 -94
  95. package/src/database/userData.js +0 -98
  96. package/src/remote/remoteClient.js +0 -123
  97. package/src/utils/broadcast.js +0 -51
  98. package/src/utils/client.js +0 -10
  99. package/src/utils/constants.js +0 -23
  100. package/src/utils/cookies.js +0 -68
  101. package/src/utils/format/attachment.js +0 -357
  102. package/src/utils/format/cookie.js +0 -9
  103. package/src/utils/format/date.js +0 -50
  104. package/src/utils/format/decode.js +0 -44
  105. package/src/utils/format/delta.js +0 -194
  106. package/src/utils/format/ids.js +0 -64
  107. package/src/utils/format/index.js +0 -64
  108. package/src/utils/format/message.js +0 -88
  109. package/src/utils/format/presence.js +0 -132
  110. package/src/utils/format/readTyp.js +0 -44
  111. package/src/utils/format/thread.js +0 -42
  112. package/src/utils/format/utils.js +0 -141
  113. package/src/utils/headers.js +0 -115
  114. package/src/utils/loginParser/autoLogin.js +0 -125
  115. package/src/utils/loginParser/helpers.js +0 -43
  116. package/src/utils/loginParser/index.js +0 -10
  117. package/src/utils/loginParser/parseAndCheckLogin.js +0 -220
  118. package/src/utils/loginParser/textUtils.js +0 -28
  119. package/src/utils/request/client.js +0 -26
  120. package/src/utils/request/config.js +0 -23
  121. package/src/utils/request/defaults.js +0 -46
  122. package/src/utils/request/helpers.js +0 -46
  123. package/src/utils/request/index.js +0 -17
  124. package/src/utils/request/methods.js +0 -163
  125. package/src/utils/request/proxy.js +0 -21
  126. package/src/utils/request/retry.js +0 -77
  127. 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
- };
@@ -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;
@@ -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
- };