chatbot-fca 0.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.

Potentially problematic release.


This version of chatbot-fca might be problematic. Click here for more details.

Files changed (97) hide show
  1. package/.cache/nix/binary-cache-v6.sqlite +0 -0
  2. package/.cache/nix/binary-cache-v6.sqlite-journal +0 -0
  3. package/.cache/replit/env/latest +125 -0
  4. package/.cache/replit/env/latest.json +1 -0
  5. package/.cache/replit/modules/nix.res +1 -0
  6. package/.cache/replit/modules/nodejs-20.res +1 -0
  7. package/.cache/replit/modules/replit.res +1 -0
  8. package/.cache/replit/modules.stamp +0 -0
  9. package/.cache/replit/nix/env.json +1 -0
  10. package/.replit +8 -0
  11. package/LICENSE +21 -0
  12. package/index.js +460 -0
  13. package/package.json +46 -0
  14. package/replit.nix +3 -0
  15. package/src/Screenshot.js +83 -0
  16. package/src/addExternalModule.js +25 -0
  17. package/src/addUserToGroup.js +115 -0
  18. package/src/changeAdminStatus.js +103 -0
  19. package/src/changeArchivedStatus.js +55 -0
  20. package/src/changeAvatar.js +136 -0
  21. package/src/changeAvatarV2.js +86 -0
  22. package/src/changeAvt.js +85 -0
  23. package/src/changeBio.js +76 -0
  24. package/src/changeBlockedStatus.js +49 -0
  25. package/src/changeBlockedStatusMqtt.js +80 -0
  26. package/src/changeCover.js +72 -0
  27. package/src/changeGroupImage.js +135 -0
  28. package/src/changeName.js +79 -0
  29. package/src/changeNickname.js +59 -0
  30. package/src/changeThreadColor.js +65 -0
  31. package/src/changeThreadEmoji.js +55 -0
  32. package/src/changeUsername.js +59 -0
  33. package/src/createCommentPost.js +230 -0
  34. package/src/createNewGroup.js +88 -0
  35. package/src/createPoll.js +71 -0
  36. package/src/createPost.js +276 -0
  37. package/src/deleteMessage.js +56 -0
  38. package/src/deleteThread.js +56 -0
  39. package/src/editMessage.js +68 -0
  40. package/src/editMessageOld.js +67 -0
  41. package/src/follow.js +74 -0
  42. package/src/forwardAttachment.js +60 -0
  43. package/src/getAccess.js +112 -0
  44. package/src/getAvatarUser.js +78 -0
  45. package/src/getCurrentUserID.js +7 -0
  46. package/src/getEmojiUrl.js +29 -0
  47. package/src/getFriendsList.js +83 -0
  48. package/src/getMessage.js +835 -0
  49. package/src/getRegion.js +7 -0
  50. package/src/getThreadHistory.js +680 -0
  51. package/src/getThreadHistoryDeprecated.js +71 -0
  52. package/src/getThreadInfo.js +232 -0
  53. package/src/getThreadInfoDeprecated.js +56 -0
  54. package/src/getThreadList.js +213 -0
  55. package/src/getThreadListDeprecated.js +46 -0
  56. package/src/getThreadPictures.js +59 -0
  57. package/src/getUID.js +119 -0
  58. package/src/getUserID.js +61 -0
  59. package/src/getUserInfo.js +66 -0
  60. package/src/handleFriendRequest.js +46 -0
  61. package/src/handleMessageRequest.js +47 -0
  62. package/src/httpGet.js +49 -0
  63. package/src/httpPost.js +48 -0
  64. package/src/listenMqtt.js +827 -0
  65. package/src/listenMqtt.txt +827 -0
  66. package/src/logout.js +75 -0
  67. package/src/markAsDelivered.js +47 -0
  68. package/src/markAsRead.js +70 -0
  69. package/src/markAsReadAll.js +40 -0
  70. package/src/markAsSeen.js +48 -0
  71. package/src/muteThread.js +45 -0
  72. package/src/postFormData.txt +46 -0
  73. package/src/refreshFb_dtsg.js +89 -0
  74. package/src/removeUserFromGroup.js +79 -0
  75. package/src/resolvePhotoUrl.js +45 -0
  76. package/src/searchForThread.js +53 -0
  77. package/src/searchStickers.js +53 -0
  78. package/src/sendMessage.js +329 -0
  79. package/src/sendMessageMqtt.js +322 -0
  80. package/src/sendTypingIndicator.js +101 -0
  81. package/src/sendTypingIndicatorV2.js +28 -0
  82. package/src/setMessageReaction.js +122 -0
  83. package/src/setMessageReactionMqtt.js +62 -0
  84. package/src/setPostReaction.js +112 -0
  85. package/src/setStoryReaction.js +64 -0
  86. package/src/setTitle.js +90 -0
  87. package/src/shareContact.js +110 -0
  88. package/src/shareLink.js +59 -0
  89. package/src/stopListenMqtt.js +23 -0
  90. package/src/threadColors.js +131 -0
  91. package/src/unfriend.js +52 -0
  92. package/src/unsendMessage.js +45 -0
  93. package/src/uploadAttachment.js +94 -0
  94. package/test/example-config.json +18 -0
  95. package/test/test-page.js +140 -0
  96. package/test/test.js +385 -0
  97. package/utils.js +2876 -0
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ function makeTypingIndicator(typ, threadID, callback, isGroup) {
8
+ const form = {
9
+ typ: +typ,
10
+ to: "",
11
+ source: "mercury-chat",
12
+ thread: threadID,
13
+ };
14
+
15
+ // Check if thread is a single person chat or a group chat
16
+ // More info on this is in api.sendMessage
17
+ if (utils.getType(isGroup) == "Boolean") {
18
+ if (!isGroup) {
19
+ form.to = threadID;
20
+ }
21
+ defaultFuncs
22
+ .post("https://www.facebook.com/ajax/messaging/typ.php", ctx.jar, form)
23
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
24
+ .then(function (resData) {
25
+ if (resData.error) {
26
+ throw resData;
27
+ }
28
+
29
+ return callback();
30
+ })
31
+ .catch(function (err) {
32
+ console.error("sendTypingIndicator", err);
33
+ return callback(err);
34
+ });
35
+ } else {
36
+ api.getUserInfo(threadID, function (err, res) {
37
+ if (err) {
38
+ return callback(err);
39
+ }
40
+
41
+ // If id is single person chat
42
+ if (Object.keys(res).length > 0) {
43
+ form.to = threadID;
44
+ }
45
+
46
+ defaultFuncs
47
+ .post(
48
+ "https://www.facebook.com/ajax/messaging/typ.php",
49
+ ctx.jar,
50
+ form,
51
+ )
52
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
53
+ .then(function (resData) {
54
+ if (resData.error) {
55
+ throw resData;
56
+ }
57
+
58
+ return callback();
59
+ })
60
+ .catch(function (err) {
61
+ console.error("sendTypingIndicator", err);
62
+ return callback(err);
63
+ });
64
+ });
65
+ }
66
+ }
67
+
68
+ return function sendTypingIndicator(threadID, callback, isGroup) {
69
+ if (
70
+ utils.getType(callback) !== "Function" &&
71
+ utils.getType(callback) !== "AsyncFunction"
72
+ ) {
73
+ if (callback) {
74
+ console.warn(
75
+ "sendTypingIndicator",
76
+ "callback is not a function - ignoring.",
77
+ );
78
+ }
79
+ callback = () => {};
80
+ }
81
+
82
+ makeTypingIndicator(true, threadID, callback, isGroup);
83
+
84
+ return function end(cb) {
85
+ if (
86
+ utils.getType(cb) !== "Function" &&
87
+ utils.getType(cb) !== "AsyncFunction"
88
+ ) {
89
+ if (cb) {
90
+ console.warn(
91
+ "sendTypingIndicator",
92
+ "callback is not a function - ignoring.",
93
+ );
94
+ }
95
+ cb = () => {};
96
+ }
97
+
98
+ makeTypingIndicator(false, threadID, cb, isGroup);
99
+ };
100
+ };
101
+ };
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+
3
+
4
+
5
+ var utils = require("../utils");
6
+ // @NethWs3Dev
7
+
8
+ module.exports = function (defaultFuncs, api, ctx) {
9
+ return async function sendTypingIndicatorV2(sendTyping,threadID, callback) {
10
+ let count_req = 0
11
+ var wsContent = {
12
+ app_id: 2220391788200892,
13
+ payload: JSON.stringify({
14
+ label: 3,
15
+ payload: JSON.stringify({
16
+ thread_key: threadID.toString(),
17
+ is_group_thread: +(threadID.toString().length >= 16),
18
+ is_typing: +sendTyping,
19
+ attribution: 0
20
+ }),
21
+ version: 5849951561777440
22
+ }),
23
+ request_id: ++count_req,
24
+ type: 4
25
+ };
26
+ await new Promise((resolve, reject) => mqttClient.publish('/ls_req', JSON.stringify(wsContent), {}, (err, _packet) => err ? reject(err) : resolve()));
27
+ };
28
+ };
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function setMessageReaction(
8
+ reaction,
9
+ messageID,
10
+ callback,
11
+ forceCustomReaction,
12
+ ) {
13
+ let resolveFunc = function () {};
14
+ let rejectFunc = function () {};
15
+ const returnPromise = new Promise(function (resolve, reject) {
16
+ resolveFunc = resolve;
17
+ rejectFunc = reject;
18
+ });
19
+
20
+ if (!callback) {
21
+ callback = function (err, friendList) {
22
+ if (err) {
23
+ return rejectFunc(err);
24
+ }
25
+ resolveFunc(friendList);
26
+ };
27
+ }
28
+
29
+ switch (reaction) {
30
+ case "\uD83D\uDE0D": //:heart_eyes:
31
+ case "\uD83D\uDE06": //:laughing:
32
+ case "\uD83D\uDE2E": //:open_mouth:
33
+ case "\uD83D\uDE22": //:cry:
34
+ case "\uD83D\uDE20": //:angry:
35
+ case "\uD83D\uDC4D": //:thumbsup:
36
+ case "\uD83D\uDC4E": //:thumbsdown:
37
+ case "\u2764": //:heart:
38
+ case "\uD83D\uDC97": //:glowingheart:
39
+ case "":
40
+ //valid
41
+ break;
42
+ case ":heart_eyes:":
43
+ case ":love:":
44
+ reaction = "\uD83D\uDE0D";
45
+ break;
46
+ case ":laughing:":
47
+ case ":haha:":
48
+ reaction = "\uD83D\uDE06";
49
+ break;
50
+ case ":open_mouth:":
51
+ case ":wow:":
52
+ reaction = "\uD83D\uDE2E";
53
+ break;
54
+ case ":cry:":
55
+ case ":sad:":
56
+ reaction = "\uD83D\uDE22";
57
+ break;
58
+ case ":angry:":
59
+ reaction = "\uD83D\uDE20";
60
+ break;
61
+ case ":thumbsup:":
62
+ case ":like:":
63
+ reaction = "\uD83D\uDC4D";
64
+ break;
65
+ case ":thumbsdown:":
66
+ case ":dislike:":
67
+ reaction = "\uD83D\uDC4E";
68
+ break;
69
+ case ":heart:":
70
+ reaction = "\u2764";
71
+ break;
72
+ case ":glowingheart:":
73
+ reaction = "\uD83D\uDC97";
74
+ break;
75
+ default:
76
+ if (forceCustomReaction) {
77
+ break;
78
+ }
79
+ return callback({ error: "Reaction is not a valid emoji." });
80
+ }
81
+
82
+ const variables = {
83
+ data: {
84
+ client_mutation_id: ctx.clientMutationId++,
85
+ actor_id: ctx.userID,
86
+ action: reaction == "" ? "REMOVE_REACTION" : "ADD_REACTION",
87
+ message_id: messageID,
88
+ reaction: reaction,
89
+ },
90
+ };
91
+
92
+ const qs = {
93
+ doc_id: "1491398900900362",
94
+ variables: JSON.stringify(variables),
95
+ dpr: 1,
96
+ };
97
+
98
+ defaultFuncs
99
+ .postFormData(
100
+ "https://www.facebook.com/webgraphql/mutation/",
101
+ ctx.jar,
102
+ {},
103
+ qs,
104
+ )
105
+ .then(utils.parseAndCheckLogin(ctx.jar, defaultFuncs))
106
+ .then(function (resData) {
107
+ if (!resData) {
108
+ throw { error: "setReaction returned empty object." };
109
+ }
110
+ if (resData.error) {
111
+ throw resData;
112
+ }
113
+ callback(null);
114
+ })
115
+ .catch(function (err) {
116
+ console.error("setReaction", err);
117
+ return callback(err);
118
+ });
119
+
120
+ return returnPromise;
121
+ };
122
+ };
@@ -0,0 +1,62 @@
1
+
2
+ 'use strict';
3
+
4
+ const { generateOfflineThreadingID } = require('../utils');
5
+
6
+ function isCallable(func) {
7
+ try {
8
+ Reflect.apply(func, null, []);
9
+ return true;
10
+ } catch (error) {
11
+ return false;
12
+ }
13
+ }
14
+
15
+ module.exports = function (defaultFuncs, api, ctx) {
16
+ return function setMessageReactionMqtt(reaction, messageID, threadID, callback) {
17
+ if (!ctx.mqttClient) {
18
+ throw new Error('Not connected to MQTT');
19
+ }
20
+
21
+
22
+ ctx.wsReqNumber += 1;
23
+ ctx.wsTaskNumber += 1;
24
+
25
+ const taskPayload = {
26
+ thread_key: threadID,
27
+ timestamp_ms: Date.now(),
28
+ message_id: messageID,
29
+ reaction: reaction,
30
+ actor_id: ctx.userID,
31
+ reaction_style: null,
32
+ sync_group: 1,
33
+ send_attribution: Math.random() < 0.5 ? 65537 : 524289
34
+ };
35
+
36
+ const task = {
37
+ failure_count: null,
38
+ label: '29',
39
+ payload: JSON.stringify(taskPayload),
40
+ queue_name: JSON.stringify(['reaction', messageID]),
41
+ task_id: ctx.wsTaskNumber,
42
+ };
43
+
44
+ const content = {
45
+ app_id: '2220391788200892',
46
+ payload: JSON.stringify({
47
+ data_trace_id: null,
48
+ epoch_id: parseInt(generateOfflineThreadingID()),
49
+ tasks: [task],
50
+ version_id: '7158486590867448',
51
+ }),
52
+ request_id: ctx.wsReqNumber,
53
+ type: 3,
54
+ };
55
+
56
+ if (isCallable(callback)) {
57
+ ctx.reqCallbacks[ctx.wsReqNumber] = callback;
58
+ }
59
+
60
+ ctx.mqttClient.publish('/ls_req', JSON.stringify(content), { qos: 1, retain: false });
61
+ };
62
+ };
@@ -0,0 +1,112 @@
1
+ /**
2
+ * @fix by NTKhang
3
+ * update as Thursday, 10 February 2022
4
+ * do not remove the author name to get more updates
5
+ */
6
+
7
+ "use strict";
8
+
9
+ const utils = require("../utils");
10
+ // @NethWs3Dev
11
+
12
+ function formatData(resData) {
13
+ return {
14
+ viewer_feedback_reaction_info:
15
+ resData.feedback_react.feedback.viewer_feedback_reaction_info,
16
+ supported_reactions: resData.feedback_react.feedback.supported_reactions,
17
+ top_reactions: resData.feedback_react.feedback.top_reactions.edges,
18
+ reaction_count: resData.feedback_react.feedback.reaction_count,
19
+ };
20
+ }
21
+
22
+ module.exports = function (defaultFuncs, api, ctx) {
23
+ return function setPostReaction(postID, type, callback) {
24
+ let resolveFunc = function () {};
25
+ let rejectFunc = function () {};
26
+ const returnPromise = new Promise(function (resolve, reject) {
27
+ resolveFunc = resolve;
28
+ rejectFunc = reject;
29
+ });
30
+
31
+ if (!callback) {
32
+ if (
33
+ utils.getType(type) === "Function" ||
34
+ utils.getType(type) === "AsyncFunction"
35
+ ) {
36
+ callback = type;
37
+ type = 0;
38
+ } else {
39
+ callback = function (err, data) {
40
+ if (err) {
41
+ return rejectFunc(err);
42
+ }
43
+ resolveFunc(data);
44
+ };
45
+ }
46
+ }
47
+
48
+ const map = {
49
+ unlike: 0,
50
+ like: 1,
51
+ heart: 2,
52
+ love: 16,
53
+ haha: 4,
54
+ wow: 3,
55
+ sad: 7,
56
+ angry: 8,
57
+ };
58
+
59
+ if (utils.getType(type) !== "Number" && utils.getType(type) === "String") {
60
+ type = map[type.toLowerCase()];
61
+ }
62
+
63
+ if (utils.getType(type) !== "Number" && utils.getType(type) !== "String") {
64
+ throw {
65
+ error: "setPostReaction: Invalid reaction type",
66
+ };
67
+ }
68
+
69
+ if (type != 0 && !type) {
70
+ throw {
71
+ error: "setPostReaction: Invalid reaction type",
72
+ };
73
+ }
74
+
75
+ const form = {
76
+ av: ctx.userID,
77
+ fb_api_caller_class: "RelayModern",
78
+ fb_api_req_friendly_name: "CometUFIFeedbackReactMutation",
79
+ doc_id: "4769042373179384",
80
+ variables: JSON.stringify({
81
+ input: {
82
+ actor_id: ctx.userID,
83
+ feedback_id: new Buffer("feedback:" + postID).toString("base64"),
84
+ feedback_reaction: type,
85
+ feedback_source: "OBJECT",
86
+ is_tracking_encrypted: true,
87
+ tracking: [],
88
+ session_id: "f7dd50dd-db6e-4598-8cd9-561d5002b423",
89
+ client_mutation_id: Math.round(Math.random() * 19).toString(),
90
+ },
91
+ useDefaultActor: false,
92
+ scale: 3,
93
+ }),
94
+ };
95
+
96
+ defaultFuncs
97
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
98
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
99
+ .then(function (resData) {
100
+ if (resData.errors) {
101
+ throw resData;
102
+ }
103
+ return callback(null, formatData(resData.data));
104
+ })
105
+ .catch(function (err) {
106
+ console.error("setPostReaction", err);
107
+ return callback(err);
108
+ });
109
+
110
+ return returnPromise;
111
+ };
112
+ };
@@ -0,0 +1,64 @@
1
+ 'use strict';
2
+
3
+ var utils = require('../utils.js');
4
+ var log = require('npmlog');
5
+
6
+ module.exports = function(defaultFuncs, api, ctx) {
7
+ return function setStoryReaction(storyID, react, callback) {
8
+ var cb;
9
+ var returnPromise = new Promise(function(resolve, reject) {
10
+ cb = error => error ? reject(error) : resolve();
11
+ });
12
+
13
+ if (typeof react == 'function') {
14
+ callback = react;
15
+ react = 1;
16
+ }
17
+ if (typeof callback == 'function') cb = callback;
18
+ if (typeof Number(react) != 'number') react = 1;
19
+
20
+ var map = {
21
+ 1: '👍',
22
+ 2: '❤️',
23
+ 3: '🤗',
24
+ 4: '😆',
25
+ 5: '😮',
26
+ 6: '😢',
27
+ 7: '😡'
28
+ }
29
+ var form = {
30
+ fb_api_req_friendly_name: 'useStoriesSendReplyMutation',
31
+ variables: JSON.stringify({
32
+ input: {
33
+ attribution_id_v2: `StoriesCometSuspenseRoot.react,comet.stories.viewer,unexpected,${Date.now()},538296,,;CometHomeRoot.react,comet.home,via_cold_start,${Date.now()},850302,4748854339,`,
34
+ lightweight_reaction_actions: {
35
+ offsets: [0],
36
+ reaction: map[react] || map[1]
37
+ },
38
+ message: map[react] || map[1],
39
+ story_id: storyID,
40
+ story_reply_type: "LIGHT_WEIGHT",
41
+ actor_id: ctx.userID,
42
+ client_mutation_id: String(parseInt(Math.random() * 16))
43
+ }
44
+ }),
45
+ doc_id: '4826141330837571'
46
+ }
47
+
48
+ defaultFuncs
49
+ .post('https://www.facebook.com/api/graphql/', ctx.jar, form)
50
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
51
+ .then(function(res) {
52
+ if (res.errors) throw res;
53
+ return cb();
54
+ })
55
+ .catch(function(err) {
56
+ console.error('setPostReaction', err);
57
+ return cb(err);
58
+ });
59
+
60
+ return returnPromise;
61
+ }
62
+ }
63
+
64
+ //new update version 1.0.9
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function setTitle(newTitle, threadID, callback) {
8
+ if (
9
+ !callback &&
10
+ (utils.getType(threadID) === "Function" ||
11
+ utils.getType(threadID) === "AsyncFunction")
12
+ ) {
13
+ throw { error: "please pass a threadID as a second argument." };
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 messageAndOTID = utils.generateOfflineThreadingID();
33
+ const form = {
34
+ client: "mercury",
35
+ action_type: "ma-type:log-message",
36
+ author: "fbid:" + (ctx.userID),
37
+ author_email: "",
38
+ coordinates: "",
39
+ timestamp: Date.now(),
40
+ timestamp_absolute: "Today",
41
+ timestamp_relative: utils.generateTimestampRelative(),
42
+ timestamp_time_passed: "0",
43
+ is_unread: false,
44
+ is_cleared: false,
45
+ is_forward: false,
46
+ is_filtered_content: false,
47
+ is_spoof_warning: false,
48
+ source: "source:chat:web",
49
+ "source_tags[0]": "source:chat",
50
+ status: "0",
51
+ offline_threading_id: messageAndOTID,
52
+ message_id: messageAndOTID,
53
+ threading_id: utils.generateThreadingID(ctx.clientID),
54
+ manual_retry_cnt: "0",
55
+ thread_fbid: threadID,
56
+ thread_name: newTitle,
57
+ thread_id: threadID,
58
+ log_message_type: "log:thread-name",
59
+ };
60
+
61
+ defaultFuncs
62
+ .post(
63
+ "https://www.facebook.com/messaging/set_thread_name/",
64
+ ctx.jar,
65
+ form,
66
+ )
67
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
68
+ .then(function (resData) {
69
+ if (resData.error && resData.error === 1545012) {
70
+ throw { error: "Cannot change chat title: Not member of chat." };
71
+ }
72
+
73
+ if (resData.error && resData.error === 1545003) {
74
+ throw { error: "Cannot set title of single-user chat." };
75
+ }
76
+
77
+ if (resData.error) {
78
+ throw resData;
79
+ }
80
+
81
+ return callback();
82
+ })
83
+ .catch(function (err) {
84
+ console.error("setTitle", err);
85
+ return callback(err);
86
+ });
87
+
88
+ return returnPromise;
89
+ };
90
+ };
@@ -0,0 +1,110 @@
1
+ /* eslint-disable linebreak-style */
2
+ "use strict";
3
+
4
+ // fixed by kenneth panio
5
+
6
+ var utils = require("../utils");
7
+
8
+ module.exports = function(defaultFuncs, api, ctx) {
9
+ return function shareContact(text, senderID, threadID, callback) {
10
+ if (!ctx.mqttClient) {
11
+ throw new Error('Not connected to MQTT');
12
+ }
13
+
14
+ ctx.wsReqNumber ??= 0;
15
+ ctx.wsTaskNumber ??= 0;
16
+
17
+ ctx.wsReqNumber += 1;
18
+ ctx.wsTaskNumber += 1;
19
+
20
+ const queryPayload = {
21
+ contact_id: senderID,
22
+ sync_group: 1,
23
+ text: text || "",
24
+ thread_id: threadID
25
+ };
26
+
27
+ const query = {
28
+ failure_count: null,
29
+ label: '359',
30
+ payload: JSON.stringify(queryPayload),
31
+ queue_name: 'messenger_contact_sharing',//xma_open_contact_share
32
+ task_id: Math.random() * 1001 << 0,
33
+ };
34
+
35
+ const context = {
36
+ app_id: '2220391788200892',
37
+ payload: {
38
+ tasks: [query],
39
+ epoch_id: utils.generateOfflineThreadingID(),
40
+ version_id: '7214102258676893',
41
+ },
42
+ request_id: ctx.wsReqNumber,
43
+ type: 3,
44
+ };
45
+
46
+ context.payload = JSON.stringify(context.payload);
47
+
48
+ if (typeof callback === 'function') {
49
+ ctx.callback_Task[ctx.wsReqNumber] = { callback, type: "shareContact" };
50
+ }
51
+
52
+ ctx.mqttClient.publish('/ls_req', JSON.stringify(context), { qos: 1, retain: false });
53
+ };
54
+ };
55
+
56
+ /*"use strict";
57
+
58
+
59
+ var utils = require("../utils");
60
+
61
+ // @NethWs3Dev
62
+
63
+
64
+ module.exports = function (defaultFuncs, api, ctx) {
65
+ return async function shareContact(text, senderID, threadID, callback) {
66
+ await utils.parseAndCheckLogin(ctx, defaultFuncs);
67
+ const mqttClient = ctx.mqttClient;
68
+
69
+ if (!mqttClient) {
70
+ throw new Error("Not connected to MQTT");
71
+ }
72
+ var resolveFunc = function () { };
73
+ var rejectFunc = function () { };
74
+ var returnPromise = new Promise(function (resolve, reject) {
75
+ resolveFunc = resolve;
76
+ rejectFunc = reject;
77
+ });
78
+ if (!callback) {
79
+ callback = function (err, data) {
80
+ if (err) return rejectFunc(err);
81
+ resolveFunc(data);
82
+ data };
83
+ }
84
+ let count_req = 0
85
+ var form = JSON.stringify({
86
+ "app_id": "2220391788200892",
87
+ "payload": JSON.stringify({
88
+ tasks: [{
89
+ label: '359',
90
+ payload: JSON.stringify({
91
+ "contact_id": senderID,
92
+ "sync_group": 1,
93
+ "text": text || "",
94
+ "thread_id": threadID
95
+ }),
96
+ queue_name: 'messenger_contact_sharing',
97
+ task_id: Math.random() * 1001 << 0,
98
+ failure_count: null,
99
+ }],
100
+ epoch_id: utils.generateOfflineThreadingID(),
101
+ version_id: '7214102258676893',
102
+ }),
103
+ "request_id": ++count_req,
104
+ "type": 3
105
+ });
106
+ mqttClient.publish('/ls_req',form)
107
+
108
+ return returnPromise;
109
+ };
110
+ };*/