fca-sahu 1.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 (92) hide show
  1. package/index.js +552 -0
  2. package/package.json +61 -0
  3. package/src/OldMessage.js +357 -0
  4. package/src/addExternalModule.js +25 -0
  5. package/src/addUserToGroup.js +115 -0
  6. package/src/changeAdminStatus.js +103 -0
  7. package/src/changeArchivedStatus.js +55 -0
  8. package/src/changeAvatar.js +136 -0
  9. package/src/changeAvatarV2.js +86 -0
  10. package/src/changeAvt.js +85 -0
  11. package/src/changeBio.js +76 -0
  12. package/src/changeBlockedStatus.js +49 -0
  13. package/src/changeBlockedStatusMqtt.js +80 -0
  14. package/src/changeCover.js +72 -0
  15. package/src/changeGroupImage.js +135 -0
  16. package/src/changeName.js +79 -0
  17. package/src/changeNickname.js +59 -0
  18. package/src/changeThreadColor.js +65 -0
  19. package/src/changeThreadEmoji.js +55 -0
  20. package/src/changeUsername.js +59 -0
  21. package/src/createCommentPost.js +230 -0
  22. package/src/createNewGroup.js +88 -0
  23. package/src/createPoll.js +71 -0
  24. package/src/createPost.js +276 -0
  25. package/src/deleteMessage.js +56 -0
  26. package/src/deleteThread.js +56 -0
  27. package/src/editMessage.js +68 -0
  28. package/src/editMessageOld.js +67 -0
  29. package/src/follow.js +74 -0
  30. package/src/forwardAttachment.js +60 -0
  31. package/src/friendList.js +103 -0
  32. package/src/getAccess.js +112 -0
  33. package/src/getAvatarUser.js +78 -0
  34. package/src/getCurrentUserID.js +7 -0
  35. package/src/getEmojiUrl.js +29 -0
  36. package/src/getFriendsList.js +83 -0
  37. package/src/getMessage.js +847 -0
  38. package/src/getRegion.js +7 -0
  39. package/src/getThreadHistory.js +680 -0
  40. package/src/getThreadHistoryDeprecated.js +71 -0
  41. package/src/getThreadInfo.js +232 -0
  42. package/src/getThreadInfoDeprecated.js +56 -0
  43. package/src/getThreadList.js +213 -0
  44. package/src/getThreadListDeprecated.js +46 -0
  45. package/src/getThreadPictures.js +59 -0
  46. package/src/getThreadTheme.js +82 -0
  47. package/src/getUID.js +119 -0
  48. package/src/getUserID.js +61 -0
  49. package/src/getUserInfo.js +66 -0
  50. package/src/handleFriendRequest.js +46 -0
  51. package/src/handleMessageRequest.js +47 -0
  52. package/src/httpGet.js +49 -0
  53. package/src/httpPost.js +48 -0
  54. package/src/listenMqtt.js +719 -0
  55. package/src/logout.js +75 -0
  56. package/src/markAsDelivered.js +47 -0
  57. package/src/markAsRead.js +70 -0
  58. package/src/markAsReadAll.js +40 -0
  59. package/src/markAsSeen.js +48 -0
  60. package/src/metaTheme.js +190 -0
  61. package/src/muteThread.js +45 -0
  62. package/src/note.js +228 -0
  63. package/src/refreshFb_dtsg.js +89 -0
  64. package/src/removeSuspiciousAccount.js +79 -0
  65. package/src/removeUserFromGroup.js +79 -0
  66. package/src/resolvePhotoUrl.js +45 -0
  67. package/src/searchForThread.js +53 -0
  68. package/src/searchFriends.js +139 -0
  69. package/src/searchStickers.js +53 -0
  70. package/src/sendFriendRequest.js +113 -0
  71. package/src/sendMessage.js +258 -0
  72. package/src/sendMessageMqtt.js +322 -0
  73. package/src/sendTypingIndicator.js +45 -0
  74. package/src/setActiveStatus.js +93 -0
  75. package/src/setMessageReaction.js +122 -0
  76. package/src/setMessageReactionMqtt.js +62 -0
  77. package/src/setPostReaction.js +112 -0
  78. package/src/setProfileLock.js +98 -0
  79. package/src/setStoryReaction.js +134 -0
  80. package/src/setStorySeen.js +109 -0
  81. package/src/setThreadTheme.js +103 -0
  82. package/src/setTitle.js +90 -0
  83. package/src/shareContact.js +110 -0
  84. package/src/shareLink.js +59 -0
  85. package/src/stopListenMqtt.js +23 -0
  86. package/src/storyManager.js +358 -0
  87. package/src/suggestFriend.js +133 -0
  88. package/src/threadColors.js +131 -0
  89. package/src/unfriend.js +52 -0
  90. package/src/unsendMessage.js +45 -0
  91. package/src/uploadAttachment.js +93 -0
  92. package/utils.js +2962 -0
@@ -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,98 @@
1
+ /**
2
+ * ===========================================================
3
+ * 🧑‍💻 Author: Sheikh Tamim (ST | Sheikh Tamim)
4
+ * 🔰 Owner & Developer
5
+ * 🌐 GitHub: https://github.com/sheikhtamimlover
6
+ * 📸 Instagram: https://instagram.com/sheikh.tamim_lover
7
+ * -----------------------------------------------------------
8
+ * 🕊️ Respect the creator & give proper credits if reused.
9
+ * ===========================================================
10
+ */
11
+ "use strict";
12
+
13
+ const utils = require("../utils");
14
+ const log = require("npmlog");
15
+
16
+ module.exports = function (defaultFuncs, api, ctx) {
17
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Instagram: @sheikh.tamim_lover */
18
+ return function setProfileLock(enable, callback) {
19
+ let resolveFunc = function () { };
20
+ let rejectFunc = function () { };
21
+ const returnPromise = new Promise(function (resolve, reject) {
22
+ resolveFunc = resolve;
23
+ rejectFunc = reject;
24
+ });
25
+
26
+ if (!callback) {
27
+ callback = function (err, data) {
28
+ if (err) {
29
+ return rejectFunc(err);
30
+ }
31
+ resolveFunc(data);
32
+ };
33
+ }
34
+
35
+ if (typeof enable !== "boolean") {
36
+ return callback(new Error("enable must be a boolean value"));
37
+ }
38
+
39
+ const form = {
40
+ av: ctx.userID,
41
+ __aaid: 0,
42
+ __user: ctx.userID,
43
+ __a: 1,
44
+ __req: utils.getGUID(),
45
+ __hs: ctx.fb_dtsg_ag,
46
+ dpr: 1,
47
+ __ccg: "EXCELLENT",
48
+ __rev: ctx.req_ID,
49
+ __s: utils.getGUID(),
50
+ __hsi: ctx.hsi,
51
+ __comet_req: 15,
52
+ fb_dtsg: ctx.fb_dtsg,
53
+ jazoest: utils.getJazoest(ctx.fb_dtsg),
54
+ lsd: ctx.fb_dtsg,
55
+ __spin_r: ctx.req_ID,
56
+ __spin_b: "trunk",
57
+ __spin_t: Date.now(),
58
+ __crn: "comet.fbweb.CometProfileTimelineListViewRoute",
59
+ fb_api_caller_class: "RelayModern",
60
+ fb_api_req_friendly_name: "WemPrivateSharingMutation",
61
+ server_timestamps: true,
62
+ variables: JSON.stringify({
63
+ enable: !enable
64
+ }),
65
+ doc_id: "9144138075685633"
66
+ };
67
+
68
+ defaultFuncs
69
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
70
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
71
+ .then(function (resData) {
72
+ if (resData.error) {
73
+ throw resData;
74
+ }
75
+
76
+ const result = resData?.data?.toggle_wem_private_sharing_control_enabled;
77
+
78
+ if (!result) {
79
+ throw new Error("Cannot toggle profile lock status");
80
+ }
81
+
82
+ return callback(null, {
83
+ private_sharing_enabled: result.private_sharing_enabled,
84
+ is_ppg_converter: result.is_ppg_converter,
85
+ is_ppg_user: result.is_ppg_user,
86
+ last_toggle_time: result.private_sharing_last_toggle_time,
87
+ owner_id: result.owner_id
88
+ });
89
+ })
90
+ .catch(function (err) {
91
+ log.error("setProfileLock", err);
92
+ return callback(err);
93
+ });
94
+
95
+ return returnPromise;
96
+ };
97
+ };
98
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Please give credits if reused. */
@@ -0,0 +1,134 @@
1
+ /**
2
+ * ===========================================================
3
+ * 🧑‍💻 Author: Sheikh Tamim (ST | Sheikh Tamim)
4
+ * 🔰 Owner & Developer
5
+ * 🌐 GitHub: https://github.com/sheikhtamimlover
6
+ * 📸 Instagram: https://instagram.com/sheikh.tamim_lover
7
+ * -----------------------------------------------------------
8
+ * 🕊️ Respect the creator & give proper credits if reused.
9
+ * ===========================================================
10
+ */
11
+ 'use strict';
12
+
13
+ var utils = require('../utils.js');
14
+ var log = require('npmlog');
15
+
16
+ module.exports = function(defaultFuncs, api, ctx) {
17
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Instagram: @sheikh.tamim_lover */
18
+ return function setStoryReaction(storyID, react, callback) {
19
+ var resolveFunc = function () { };
20
+ var rejectFunc = function () { };
21
+ var returnPromise = new Promise(function (resolve, reject) {
22
+ resolveFunc = resolve;
23
+ rejectFunc = reject;
24
+ });
25
+
26
+ if (typeof react == 'function') {
27
+ callback = react;
28
+ react = '❤️'; // Default heart reaction
29
+ }
30
+
31
+ if (!callback) {
32
+ callback = function (err, data) {
33
+ if (err) return rejectFunc(err);
34
+ resolveFunc(data);
35
+ };
36
+ }
37
+
38
+ if (!storyID) {
39
+ return callback({ error: "storyID is required" });
40
+ }
41
+
42
+ var reactionMap = {
43
+ 1: '👍',
44
+ 2: '❤️',
45
+ 3: '🤗',
46
+ 4: '😆',
47
+ 5: '😮',
48
+ 6: '😢',
49
+ 7: '😡',
50
+ 'like': '👍',
51
+ 'love': '❤️',
52
+ 'heart': '❤️',
53
+ 'haha': '😆',
54
+ 'wow': '😮',
55
+ 'sad': '😢',
56
+ 'angry': '😡'
57
+ };
58
+
59
+ var reaction = reactionMap[react] || react || '❤️';
60
+
61
+ var form = {
62
+ av: ctx.userID,
63
+ __aaid: 0,
64
+ __user: ctx.userID,
65
+ __a: 1,
66
+ __req: utils.getSignatureID(),
67
+ __hs: ctx.fb_dtsg_ag,
68
+ dpr: 1,
69
+ __ccg: "EXCELLENT",
70
+ __rev: ctx.req_ID,
71
+ __s: utils.getSignatureID(),
72
+ __hsi: ctx.hsi,
73
+ __comet_req: 15,
74
+ fb_dtsg: ctx.fb_dtsg,
75
+ jazoest: ctx.ttstamp,
76
+ lsd: ctx.fb_dtsg,
77
+ __spin_r: ctx.req_ID,
78
+ __spin_b: "trunk",
79
+ __spin_t: Date.now(),
80
+ fb_api_caller_class: "RelayModern",
81
+ fb_api_req_friendly_name: "useStoriesSendReplyMutation",
82
+ variables: JSON.stringify({
83
+ input: {
84
+ attribution_id_v2: `StoriesCometSuspenseRoot.react,comet.stories.viewer,unexpected,${Date.now()},356653,,;CometHomeRoot.react,comet.home,tap_tabbar,${Date.now()},109945,4748854339,,`,
85
+ lightweight_reaction_actions: {
86
+ offsets: [0],
87
+ reaction: reaction
88
+ },
89
+ message: reaction,
90
+ story_id: storyID,
91
+ story_reply_type: "LIGHT_WEIGHT",
92
+ actor_id: ctx.userID,
93
+ client_mutation_id: String(Math.floor(Math.random() * 16) + 1)
94
+ }
95
+ }),
96
+ server_timestamps: true,
97
+ doc_id: "9697491553691692"
98
+ };
99
+
100
+ defaultFuncs
101
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
102
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
103
+ .then(function (resData) {
104
+ if (resData.error) throw resData;
105
+
106
+ // Parse successful response
107
+ if (resData.data && resData.data.direct_message_reply) {
108
+ const replyData = resData.data.direct_message_reply;
109
+ return callback(null, {
110
+ success: true,
111
+ client_mutation_id: replyData.client_mutation_id,
112
+ story_id: replyData.story?.id || storyID,
113
+ reaction: reaction,
114
+ story_reactions: replyData.story?.story_card_info?.story_card_reactions?.edges || [],
115
+ timestamp: Date.now()
116
+ });
117
+ }
118
+
119
+ return callback(null, {
120
+ success: true,
121
+ reaction: reaction,
122
+ story_id: storyID,
123
+ timestamp: Date.now()
124
+ });
125
+ })
126
+ .catch(function (err) {
127
+ log.error("setStoryReaction", err);
128
+ return callback(err);
129
+ });
130
+
131
+ return returnPromise;
132
+ };
133
+ };
134
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Please give credits if reused. */
@@ -0,0 +1,109 @@
1
+ /**
2
+ * ===========================================================
3
+ * 🧑‍💻 Author: Sheikh Tamim (ST | Sheikh Tamim)
4
+ * 🔰 Owner & Developer
5
+ * 🌐 GitHub: https://github.com/sheikhtamimlover
6
+ * 📸 Instagram: https://instagram.com/sheikh.tamim_lover
7
+ * -----------------------------------------------------------
8
+ * 🕊️ Respect the creator & give proper credits if reused.
9
+ * ===========================================================
10
+ */
11
+ 'use strict';
12
+
13
+ var utils = require('../utils.js');
14
+ var log = require('npmlog');
15
+
16
+ module.exports = function(defaultFuncs, api, ctx) {
17
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Instagram: @sheikh.tamim_lover */
18
+ return function setStorySeen(storyID, callback) {
19
+ var resolveFunc = function () { };
20
+ var rejectFunc = function () { };
21
+ var returnPromise = new Promise(function (resolve, reject) {
22
+ resolveFunc = resolve;
23
+ rejectFunc = reject;
24
+ });
25
+
26
+ if (!callback) {
27
+ callback = function (err, data) {
28
+ if (err) return rejectFunc(err);
29
+ resolveFunc(data);
30
+ };
31
+ }
32
+
33
+ if (!storyID) {
34
+ return callback({ error: "storyID is required" });
35
+ }
36
+
37
+ // Extract bucket_id from story_id if needed
38
+ var bucketID = storyID;
39
+ if (typeof storyID === 'string' && storyID.includes(':')) {
40
+ // Extract bucket ID from the story ID pattern
41
+ try {
42
+ var decoded = Buffer.from(storyID, 'base64').toString('utf-8');
43
+ var match = decoded.match(/(\d+)/);
44
+ if (match) {
45
+ bucketID = match[1];
46
+ }
47
+ } catch (e) {
48
+ // Fallback to using story ID as bucket ID
49
+ bucketID = storyID;
50
+ }
51
+ }
52
+
53
+ var form = {
54
+ av: ctx.userID,
55
+ __aaid: 0,
56
+ __user: ctx.userID,
57
+ __a: 1,
58
+ __req: utils.getSignatureID(),
59
+ __hs: ctx.fb_dtsg_ag,
60
+ dpr: 1,
61
+ __ccg: "EXCELLENT",
62
+ __rev: ctx.req_ID,
63
+ __s: utils.getSignatureID(),
64
+ __hsi: ctx.hsi,
65
+ __comet_req: 15,
66
+ fb_dtsg: ctx.fb_dtsg,
67
+ jazoest: ctx.ttstamp,
68
+ lsd: ctx.fb_dtsg,
69
+ __spin_r: ctx.req_ID,
70
+ __spin_b: "trunk",
71
+ __spin_t: Date.now(),
72
+ fb_api_caller_class: "RelayModern",
73
+ fb_api_req_friendly_name: "storiesUpdateSeenStateMutation",
74
+ variables: JSON.stringify({
75
+ input: {
76
+ bucket_id: bucketID,
77
+ story_id: storyID,
78
+ actor_id: ctx.userID,
79
+ client_mutation_id: String(Math.floor(Math.random() * 16) + 1)
80
+ },
81
+ scale: 1
82
+ }),
83
+ server_timestamps: true,
84
+ doc_id: "9567413276713742"
85
+ };
86
+
87
+ defaultFuncs
88
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
89
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
90
+ .then(function (resData) {
91
+ if (resData.error) throw resData;
92
+
93
+ return callback(null, {
94
+ success: true,
95
+ story_id: storyID,
96
+ bucket_id: bucketID,
97
+ seen_time: Date.now(),
98
+ response: resData
99
+ });
100
+ })
101
+ .catch(function (err) {
102
+ log.error("setStorySeen", err);
103
+ return callback(err);
104
+ });
105
+
106
+ return returnPromise;
107
+ };
108
+ };
109
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Please give credits if reused. */
@@ -0,0 +1,103 @@
1
+ /**
2
+ * ===========================================================
3
+ * 🧑‍💻 Author: Sheikh Tamim (ST | Sheikh Tamim)
4
+ * 🔰 Owner & Developer
5
+ * 🌐 GitHub: https://github.com/sheikhtamimlover
6
+ * 📸 Instagram: https://instagram.com/sheikh.tamim_lover
7
+ * -----------------------------------------------------------
8
+ * 🕊️ Respect the creator & give proper credits if reused.
9
+ * ===========================================================
10
+ */
11
+ 'use strict';
12
+
13
+ const utils = require('../utils');
14
+ const log = require('npmlog');
15
+
16
+ module.exports = function (defaultFuncs, api, ctx) {
17
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Instagram: @sheikh.tamim_lover */
18
+ return function setThreadTheme(threadID, themeFBID, callback) {
19
+ var resolveFunc = function () { };
20
+ var rejectFunc = function () { };
21
+ var returnPromise = new Promise(function (resolve, reject) {
22
+ resolveFunc = resolve;
23
+ rejectFunc = reject;
24
+ });
25
+
26
+ if (!callback) {
27
+ callback = function (err, data) {
28
+ if (err) return rejectFunc(err);
29
+ resolveFunc(data);
30
+ };
31
+ }
32
+
33
+ if (!ctx.mqttClient) {
34
+ return callback(new Error('Not connected to MQTT'));
35
+ }
36
+
37
+ ctx.wsReqNumber += 1;
38
+ let baseTaskNumber = ++ctx.wsTaskNumber;
39
+
40
+ const makeTask = (label, queueName, extraPayload = {}) => ({
41
+ failure_count: null,
42
+ label: String(label),
43
+ payload: JSON.stringify({
44
+ thread_key: threadID,
45
+ theme_fbid: themeFBID,
46
+ sync_group: 1,
47
+ ...extraPayload,
48
+ }),
49
+ queue_name: typeof queueName === 'string' ? queueName : JSON.stringify(queueName),
50
+ task_id: baseTaskNumber++,
51
+ });
52
+
53
+ const messages = [
54
+ {
55
+ label: 1013,
56
+ queue: ['ai_generated_theme', String(threadID)],
57
+ },
58
+ {
59
+ label: 1037,
60
+ queue: ['msgr_custom_thread_theme', String(threadID)],
61
+ },
62
+ {
63
+ label: 1028,
64
+ queue: ['thread_theme_writer', String(threadID)],
65
+ },
66
+ {
67
+ label: 43,
68
+ queue: 'thread_theme',
69
+ extra: { source: null, payload: null },
70
+ },
71
+ ].map(({ label, queue, extra }) => {
72
+ ctx.wsReqNumber += 1;
73
+ return {
74
+ app_id: '772021112871879',
75
+ payload: JSON.stringify({
76
+ epoch_id: parseInt(utils.generateOfflineThreadingID()),
77
+ tasks: [makeTask(label, queue, extra)],
78
+ version_id: '24227364673632991',
79
+ }),
80
+ //pwa_version: '1',
81
+ request_id: ctx.wsReqNumber,
82
+ type: 3,
83
+ };
84
+ });
85
+
86
+ try {
87
+ messages.forEach((msg, idx) => {
88
+ ctx.mqttClient.publish(
89
+ '/ls_req',
90
+ JSON.stringify(msg),
91
+ { qos: 1, retain: false },
92
+ idx === messages.length - 1 && callback ? callback : undefined
93
+ );
94
+ });
95
+ } catch (err) {
96
+ if (callback) callback(err);
97
+ else throw err;
98
+ }
99
+
100
+ return returnPromise;
101
+ };
102
+ };
103
+ /** Developed by Sheikh Tamim | GitHub: sheikhtamimlover | Please give credits if reused. */
@@ -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
+ };