@dongdev/fca-unofficial 1.0.19 → 2.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 (128) hide show
  1. package/.gitattributes +1 -0
  2. package/CHANGELOG.md +30 -27
  3. package/DOCS.md +727 -592
  4. package/README.md +94 -97
  5. package/func/logger.js +112 -0
  6. package/html.html +474 -0
  7. package/index.js +1 -379
  8. package/module/config.js +26 -0
  9. package/module/login.js +45 -0
  10. package/module/loginHelper.js +634 -0
  11. package/module/options.js +49 -0
  12. package/package.json +6 -39
  13. package/src/api/action/addExternalModule.js +25 -0
  14. package/src/api/action/changeAvatar.js +136 -0
  15. package/src/api/action/changeBio.js +76 -0
  16. package/src/api/action/getCurrentUserID.js +7 -0
  17. package/src/api/action/handleFriendRequest.js +57 -0
  18. package/src/api/action/logout.js +75 -0
  19. package/src/{refreshFb_dtsg.js → api/action/refreshFb_dtsg.js} +8 -8
  20. package/src/api/action/setPostReaction.js +107 -0
  21. package/src/api/action/unfriend.js +55 -0
  22. package/src/api/http/httpGet.js +65 -0
  23. package/src/api/http/httpPost.js +65 -0
  24. package/src/{postFormData.js → api/http/postFormData.js} +10 -10
  25. package/src/api/messaging/addUserToGroup.js +69 -0
  26. package/src/api/messaging/changeAdminStatus.js +103 -0
  27. package/src/api/messaging/changeArchivedStatus.js +55 -0
  28. package/src/api/messaging/changeBlockedStatus.js +49 -0
  29. package/src/api/messaging/changeGroupImage.js +135 -0
  30. package/src/api/messaging/changeNickname.js +59 -0
  31. package/src/api/messaging/changeThreadColor.js +65 -0
  32. package/src/api/messaging/createNewGroup.js +88 -0
  33. package/src/api/messaging/createPoll.js +70 -0
  34. package/src/api/messaging/deleteMessage.js +56 -0
  35. package/src/api/messaging/deleteThread.js +56 -0
  36. package/src/api/messaging/forwardAttachment.js +60 -0
  37. package/src/api/messaging/getEmojiUrl.js +29 -0
  38. package/src/api/messaging/getFriendsList.js +83 -0
  39. package/src/api/messaging/getMessage.js +834 -0
  40. package/src/api/messaging/getThreadHistory.js +681 -0
  41. package/src/api/messaging/handleMessageRequest.js +65 -0
  42. package/src/api/messaging/markAsDelivered.js +57 -0
  43. package/src/api/messaging/markAsRead.js +88 -0
  44. package/src/api/messaging/markAsReadAll.js +50 -0
  45. package/src/api/messaging/markAsSeen.js +61 -0
  46. package/src/api/messaging/muteThread.js +51 -0
  47. package/src/api/messaging/removeUserFromGroup.js +79 -0
  48. package/src/api/messaging/resolvePhotoUrl.js +44 -0
  49. package/src/api/messaging/searchForThread.js +53 -0
  50. package/src/api/messaging/sendMessage.js +306 -0
  51. package/src/api/messaging/sendMessageMqtt.js +321 -0
  52. package/src/api/messaging/sendTypingIndicator.js +110 -0
  53. package/src/{setMessageReaction.js → api/messaging/setMessageReaction.js} +20 -20
  54. package/src/api/messaging/setTitle.js +90 -0
  55. package/src/api/messaging/shareContact.js +51 -0
  56. package/src/api/messaging/threadColors.js +131 -0
  57. package/src/api/messaging/unsendMessage.js +44 -0
  58. package/src/api/messaging/uploadAttachment.js +93 -0
  59. package/src/api/socket/detail/buildStream.js +100 -0
  60. package/src/{listenMqtt.js → api/socket/listenMqtt.js} +172 -256
  61. package/src/api/threads/changeThreadEmoji.js +55 -0
  62. package/src/api/threads/getThreadInfo.js +572 -0
  63. package/src/{getThreadList.js → api/threads/getThreadList.js} +110 -54
  64. package/src/api/threads/getThreadPictures.js +79 -0
  65. package/src/api/users/getUserID.js +66 -0
  66. package/src/api/users/getUserInfo.js +88 -0
  67. package/src/core/sendReqMqtt.js +63 -0
  68. package/{lib → src}/database/models/index.js +12 -10
  69. package/{lib → src}/database/models/thread.js +5 -5
  70. package/{lib → src}/database/threadData.js +19 -14
  71. package/src/utils/client.js +159 -0
  72. package/src/utils/constants.js +13 -0
  73. package/src/utils/format.js +60 -0
  74. package/src/utils/headers.js +41 -0
  75. package/src/utils/index.js +1497 -0
  76. package/src/utils/request.js +147 -0
  77. package/lib/logger.js +0 -96
  78. package/src/addExternalModule.js +0 -19
  79. package/src/addUserToGroup.js +0 -113
  80. package/src/changeAdminStatus.js +0 -79
  81. package/src/changeArchivedStatus.js +0 -55
  82. package/src/changeAvatar.js +0 -126
  83. package/src/changeBio.js +0 -77
  84. package/src/changeBlockedStatus.js +0 -47
  85. package/src/changeGroupImage.js +0 -132
  86. package/src/changeNickname.js +0 -59
  87. package/src/changeThreadColor.js +0 -65
  88. package/src/changeThreadEmoji.js +0 -55
  89. package/src/createNewGroup.js +0 -86
  90. package/src/createPoll.js +0 -71
  91. package/src/deleteMessage.js +0 -56
  92. package/src/deleteThread.js +0 -56
  93. package/src/forwardAttachment.js +0 -60
  94. package/src/getCurrentUserID.js +0 -7
  95. package/src/getEmojiUrl.js +0 -29
  96. package/src/getFriendsList.js +0 -83
  97. package/src/getMessage.js +0 -796
  98. package/src/getThreadHistory.js +0 -666
  99. package/src/getThreadInfo.js +0 -535
  100. package/src/getThreadPictures.js +0 -79
  101. package/src/getUserID.js +0 -66
  102. package/src/getUserInfo.js +0 -80
  103. package/src/handleFriendRequest.js +0 -61
  104. package/src/handleMessageRequest.js +0 -65
  105. package/src/httpGet.js +0 -57
  106. package/src/httpPost.js +0 -57
  107. package/src/httpPostFormData.js +0 -63
  108. package/src/logout.js +0 -75
  109. package/src/markAsDelivered.js +0 -58
  110. package/src/markAsRead.js +0 -80
  111. package/src/markAsReadAll.js +0 -50
  112. package/src/markAsSeen.js +0 -59
  113. package/src/muteThread.js +0 -52
  114. package/src/removeUserFromGroup.js +0 -79
  115. package/src/resolvePhotoUrl.js +0 -45
  116. package/src/searchForThread.js +0 -53
  117. package/src/sendMessage.js +0 -328
  118. package/src/sendMessageMqtt.js +0 -316
  119. package/src/sendTypingIndicator.js +0 -103
  120. package/src/setPostReaction.js +0 -109
  121. package/src/setTitle.js +0 -86
  122. package/src/shareContact.js +0 -49
  123. package/src/threadColors.js +0 -131
  124. package/src/unfriend.js +0 -52
  125. package/src/unsendMessage.js +0 -49
  126. package/src/uploadAttachment.js +0 -95
  127. package/utils.js +0 -1387
  128. /package/{lib → func}/login.js +0 -0
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+
3
+ const utils = require("../../utils");
4
+ const log = require("npmlog");
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
+ log.error("sendTypingIndicator", err);
33
+ if (utils.getType(err) == "Object" && err.error === "Not logged in") {
34
+ ctx.loggedIn = false;
35
+ }
36
+ return callback(err);
37
+ });
38
+ } else {
39
+ api.getUserInfo(threadID, function(err, res) {
40
+ if (err) {
41
+ return callback(err);
42
+ }
43
+
44
+ // If id is single person chat
45
+ if (Object.keys(res).length > 0) {
46
+ form.to = threadID;
47
+ }
48
+
49
+ defaultFuncs
50
+ .post(
51
+ "https://www.facebook.com/ajax/messaging/typ.php",
52
+ ctx.jar,
53
+ form
54
+ )
55
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
56
+ .then(function(resData) {
57
+ if (resData.error) {
58
+ throw resData;
59
+ }
60
+
61
+ return callback();
62
+ })
63
+ .catch(function(err) {
64
+ log.error("sendTypingIndicator", err);
65
+ if (
66
+ utils.getType(err) == "Object" &&
67
+ err.error === "Not logged in."
68
+ ) {
69
+ ctx.loggedIn = false;
70
+ }
71
+ return callback(err);
72
+ });
73
+ });
74
+ }
75
+ }
76
+
77
+ return function sendTypingIndicator(threadID, callback, isGroup) {
78
+ if (
79
+ utils.getType(callback) !== "Function" &&
80
+ utils.getType(callback) !== "AsyncFunction"
81
+ ) {
82
+ if (callback) {
83
+ log.warn(
84
+ "sendTypingIndicator",
85
+ "callback is not a function - ignoring."
86
+ );
87
+ }
88
+ callback = () => {};
89
+ }
90
+
91
+ makeTypingIndicator(true, threadID, callback, isGroup);
92
+
93
+ return function end(cb) {
94
+ if (
95
+ utils.getType(cb) !== "Function" &&
96
+ utils.getType(cb) !== "AsyncFunction"
97
+ ) {
98
+ if (cb) {
99
+ log.warn(
100
+ "sendTypingIndicator",
101
+ "callback is not a function - ignoring."
102
+ );
103
+ }
104
+ cb = () => {};
105
+ }
106
+
107
+ makeTypingIndicator(false, threadID, cb, isGroup);
108
+ };
109
+ };
110
+ };
@@ -1,19 +1,19 @@
1
1
  "use strict";
2
2
 
3
- var utils = require("../utils");
3
+ const utils = require("../../utils");
4
4
  var log = require("npmlog");
5
- const { generateOfflineThreadingID } = require("../utils");
5
+ const { generateOfflineThreadingID } = require("../../utils");
6
6
 
7
- module.exports = function (defaultFuncs, api, ctx) {
7
+ module.exports = function(defaultFuncs, api, ctx) {
8
8
  function setMessageReactionNoMqtt(reaction, messageID, callback) {
9
- var resolveFunc = function () {};
10
- var rejectFunc = function () {};
11
- var returnPromise = new Promise(function (resolve, reject) {
9
+ var resolveFunc = function() {};
10
+ var rejectFunc = function() {};
11
+ var returnPromise = new Promise(function(resolve, reject) {
12
12
  resolveFunc = resolve;
13
13
  rejectFunc = reject;
14
14
  });
15
15
  if (!callback) {
16
- callback = function (err, friendList) {
16
+ callback = function(err, friendList) {
17
17
  if (err) {
18
18
  return rejectFunc(err);
19
19
  }
@@ -26,23 +26,23 @@ module.exports = function (defaultFuncs, api, ctx) {
26
26
  actor_id: ctx.userID,
27
27
  action: reaction == "" ? "REMOVE_REACTION" : "ADD_REACTION",
28
28
  message_id: messageID,
29
- reaction: reaction,
30
- },
29
+ reaction: reaction
30
+ }
31
31
  };
32
32
  var qs = {
33
33
  doc_id: "1491398900900362",
34
34
  variables: JSON.stringify(variables),
35
- dpr: 1,
35
+ dpr: 1
36
36
  };
37
37
  defaultFuncs
38
38
  .postFormData(
39
39
  "https://www.facebook.com/webgraphql/mutation/",
40
40
  ctx.jar,
41
41
  {},
42
- qs,
42
+ qs
43
43
  )
44
44
  .then(utils.parseAndCheckLogin(ctx.jar, defaultFuncs))
45
- .then(function (resData) {
45
+ .then(function(resData) {
46
46
  if (!resData) {
47
47
  throw { error: "setReaction returned empty object." };
48
48
  }
@@ -51,7 +51,7 @@ module.exports = function (defaultFuncs, api, ctx) {
51
51
  }
52
52
  callback(null);
53
53
  })
54
- .catch(function (err) {
54
+ .catch(function(err) {
55
55
  log.error("setReaction", err);
56
56
  return callback(err);
57
57
  });
@@ -73,14 +73,14 @@ module.exports = function (defaultFuncs, api, ctx) {
73
73
  actor_id: ctx.userID,
74
74
  reaction_style: null,
75
75
  sync_group: 1,
76
- send_attribution: Math.random() < 0.5 ? 65537 : 524289,
76
+ send_attribution: Math.random() < 0.5 ? 65537 : 524289
77
77
  };
78
78
  const task = {
79
79
  failure_count: null,
80
80
  label: "29",
81
81
  payload: JSON.stringify(taskPayload),
82
82
  queue_name: JSON.stringify(["reaction", messageID]),
83
- task_id: taskNumber,
83
+ task_id: taskNumber
84
84
  };
85
85
  const content = {
86
86
  app_id: "2220391788200892",
@@ -88,20 +88,20 @@ module.exports = function (defaultFuncs, api, ctx) {
88
88
  data_trace_id: null,
89
89
  epoch_id: parseInt(generateOfflineThreadingID()),
90
90
  tasks: [task],
91
- version_id: "7158486590867448",
91
+ version_id: "7158486590867448"
92
92
  }),
93
93
  request_id: ctx.wsReqNumber,
94
- type: 3,
94
+ type: 3
95
95
  };
96
96
  if (typeof callback === "function") {
97
97
  ctx["tasks"].set(taskNumber, {
98
98
  type: "set_message_reaction",
99
- callback: callback,
99
+ callback: callback
100
100
  });
101
101
  }
102
102
  ctx.mqttClient.publish("/ls_req", JSON.stringify(content), {
103
103
  qos: 1,
104
- retain: false,
104
+ retain: false
105
105
  });
106
106
  }
107
107
  return function setMessageReaction(reaction, messageID, threadID, callback) {
@@ -116,4 +116,4 @@ module.exports = function (defaultFuncs, api, ctx) {
116
116
  setMessageReactionNoMqtt(reaction, messageID, callback);
117
117
  }
118
118
  };
119
- };
119
+ };
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+
3
+ const utils = require("../../utils");
4
+ const log = require("npmlog");
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.i_userID || 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
+ log.error("setTitle", err);
85
+ return callback(err);
86
+ });
87
+
88
+ return returnPromise;
89
+ };
90
+ };
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+
3
+ const utils = require("../../utils");
4
+ var log = require("npmlog");
5
+
6
+ module.exports = function(defaultFuncs, api, ctx) {
7
+ return function shareContact(text, senderID, threadID, callback) {
8
+ if (!text) {
9
+ text = "";
10
+ }
11
+ var resolveFunc = function() {};
12
+ var rejectFunc = function() {};
13
+ var returnPromise = new Promise(function(resolve, reject) {
14
+ resolveFunc = resolve;
15
+ rejectFunc = reject;
16
+ });
17
+ if (!callback) {
18
+ callback = function(err, data) {
19
+ if (err) return rejectFunc(err);
20
+ resolveFunc(data);
21
+ data;
22
+ };
23
+ }
24
+ let count_req = 0;
25
+ var form = JSON.stringify({
26
+ app_id: "2220391788200892",
27
+ payload: JSON.stringify({
28
+ tasks: [
29
+ {
30
+ label: "359",
31
+ payload: JSON.stringify({
32
+ contact_id: senderID,
33
+ sync_group: 1,
34
+ text: text || "",
35
+ thread_id: threadID
36
+ }),
37
+ queue_name: "messenger_contact_sharing",
38
+ task_id: (Math.random() * 1001) << 0,
39
+ failure_count: null
40
+ }
41
+ ],
42
+ epoch_id: utils.generateOfflineThreadingID(),
43
+ version_id: "7214102258676893"
44
+ }),
45
+ request_id: ++count_req,
46
+ type: 3
47
+ });
48
+ mqttClient.publish("/ls_req", form);
49
+ return returnPromise;
50
+ };
51
+ };
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+
3
+ module.exports = function(_defaultFuncs, _api, _ctx) {
4
+ // Currently the only colors that can be passed to api.changeThreadColor(); may change if Facebook adds more
5
+ return {
6
+ //Old hex colors.
7
+ ////MessengerBlue: null,
8
+ ////Viking: "#44bec7",
9
+ ////GoldenPoppy: "#ffc300",
10
+ ////RadicalRed: "#fa3c4c",
11
+ ////Shocking: "#d696bb",
12
+ ////PictonBlue: "#6699cc",
13
+ ////FreeSpeechGreen: "#13cf13",
14
+ ////Pumpkin: "#ff7e29",
15
+ ////LightCoral: "#e68585",
16
+ ////MediumSlateBlue: "#7646ff",
17
+ ////DeepSkyBlue: "#20cef5",
18
+ ////Fern: "#67b868",
19
+ ////Cameo: "#d4a88c",
20
+ ////BrilliantRose: "#ff5ca1",
21
+ ////BilobaFlower: "#a695c7"
22
+
23
+ //#region This part is for backward compatibly
24
+ //trying to match the color one-by-one. kill me plz
25
+ MessengerBlue: "196241301102133", //DefaultBlue
26
+ Viking: "1928399724138152", //TealBlue
27
+ GoldenPoppy: "174636906462322", //Yellow
28
+ RadicalRed: "2129984390566328", //Red
29
+ Shocking: "2058653964378557", //LavenderPurple
30
+ FreeSpeechGreen: "2136751179887052", //Green
31
+ Pumpkin: "175615189761153", //Orange
32
+ LightCoral: "980963458735625", //CoralPink
33
+ MediumSlateBlue: "234137870477637", //BrightPurple
34
+ DeepSkyBlue: "2442142322678320", //AquaBlue
35
+ BrilliantRose: "169463077092846", //HotPink
36
+ //i've tried my best, everything else can't be mapped. (or is it?) -UIRI 2020
37
+ //#endregion
38
+
39
+ DefaultBlue: "196241301102133",
40
+ HotPink: "169463077092846",
41
+ AquaBlue: "2442142322678320",
42
+ BrightPurple: "234137870477637",
43
+ CoralPink: "980963458735625",
44
+ Orange: "175615189761153",
45
+ Green: "2136751179887052",
46
+ LavenderPurple: "2058653964378557",
47
+ Red: "2129984390566328",
48
+ Yellow: "174636906462322",
49
+ TealBlue: "1928399724138152",
50
+ Aqua: "417639218648241",
51
+ Mango: "930060997172551",
52
+ Berry: "164535220883264",
53
+ Citrus: "370940413392601",
54
+ Candy: "205488546921017",
55
+
56
+ /**
57
+ * July 06, 2022
58
+ * added by @NTKhang
59
+ */
60
+ Earth: "1833559466821043",
61
+ Support: "365557122117011",
62
+ Music: "339021464972092",
63
+ Pride: "1652456634878319",
64
+ DoctorStrange: "538280997628317",
65
+ LoFi: "1060619084701625",
66
+ Sky: "3190514984517598",
67
+ LunarNewYear: "357833546030778",
68
+ Celebration: "627144732056021",
69
+ Chill: "390127158985345",
70
+ StrangerThings: "1059859811490132",
71
+ Dune: "1455149831518874",
72
+ Care: "275041734441112",
73
+ Astrology: "3082966625307060",
74
+ JBalvin: "184305226956268",
75
+ Birthday: "621630955405500",
76
+ Cottagecore: "539927563794799",
77
+ Ocean: "736591620215564",
78
+ Love: "741311439775765",
79
+ TieDye: "230032715012014",
80
+ Monochrome: "788274591712841",
81
+ Default: "3259963564026002",
82
+ Rocket: "582065306070020",
83
+ Berry2: "724096885023603",
84
+ Candy2: "624266884847972",
85
+ Unicorn: "273728810607574",
86
+ Tropical: "262191918210707",
87
+ Maple: "2533652183614000",
88
+ Sushi: "909695489504566",
89
+ Citrus2: "557344741607350",
90
+ Lollipop: "280333826736184",
91
+ Shadow: "271607034185782",
92
+ Rose: "1257453361255152",
93
+ Lavender: "571193503540759",
94
+ Tulip: "2873642949430623",
95
+ Classic: "3273938616164733",
96
+ Peach: "3022526817824329",
97
+ Honey: "672058580051520",
98
+ Kiwi: "3151463484918004",
99
+ Grape: "193497045377796",
100
+
101
+ /**
102
+ * July 15, 2022
103
+ * added by @NTKhang
104
+ */
105
+ NonBinary: "737761000603635",
106
+
107
+ /**
108
+ * November 25, 2022
109
+ * added by @NTKhang
110
+ */
111
+ ThankfulForFriends: "1318983195536293",
112
+ Transgender: "504518465021637",
113
+ TaylorSwift: "769129927636836",
114
+ NationalComingOutDay: "788102625833584",
115
+ Autumn: "822549609168155",
116
+ Cyberpunk2077: "780962576430091",
117
+
118
+ /**
119
+ * May 13, 2023
120
+ */
121
+ MothersDay: "1288506208402340",
122
+ APAHM: "121771470870245",
123
+ Parenthood: "810978360551741",
124
+ StarWars: "1438011086532622",
125
+ GuardianOfTheGalaxy: "101275642962533",
126
+ Bloom: "158263147151440",
127
+ BubbleTea: "195296273246380",
128
+ Basketball: "6026716157422736",
129
+ ElephantsAndFlowers: "693996545771691"
130
+ };
131
+ };
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ const utils = require("../../utils");
3
+ const log = require("npmlog");
4
+
5
+ module.exports = function(defaultFuncs, api, ctx) {
6
+ return function unsendMessage(messageID, 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
+ message_id: messageID
25
+ };
26
+
27
+ defaultFuncs
28
+ .post("https://www.facebook.com/messaging/unsend_message/", ctx.jar, form)
29
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
30
+ .then(function(resData) {
31
+ if (resData.error) {
32
+ throw resData;
33
+ }
34
+
35
+ return callback();
36
+ })
37
+ .catch(function(err) {
38
+ log.error("unsendMessage", err);
39
+ return callback(err);
40
+ });
41
+
42
+ return returnPromise;
43
+ };
44
+ };
@@ -0,0 +1,93 @@
1
+ const utils = require("../../utils");
2
+ const log = require("npmlog");
3
+
4
+ module.exports = function(defaultFuncs, api, ctx) {
5
+ function upload(attachments, callback) {
6
+ callback = callback || function() {};
7
+ const uploads = [];
8
+
9
+ // create an array of promises
10
+ for (let i = 0; i < attachments.length; i++) {
11
+ if (!utils.isReadableStream(attachments[i])) {
12
+ throw {
13
+ error:
14
+ "Attachment should be a readable stream and not " +
15
+ utils.getType(attachments[i]) +
16
+ "."
17
+ };
18
+ }
19
+
20
+ const form = {
21
+ upload_1024: attachments[i],
22
+ voice_clip: "true"
23
+ };
24
+
25
+ uploads.push(
26
+ defaultFuncs
27
+ .postFormData(
28
+ "https://upload.facebook.com/ajax/mercury/upload.php",
29
+ ctx.jar,
30
+ form,
31
+ {}
32
+ )
33
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
+ .then(function(resData) {
35
+ if (resData.error) {
36
+ throw resData;
37
+ }
38
+
39
+ // We have to return the data unformatted unless we want to change it
40
+ // back in sendMessage.
41
+ return resData.payload.metadata[0];
42
+ })
43
+ );
44
+ }
45
+
46
+ // resolve all promises
47
+ Promise.all(uploads)
48
+ .then(function(resData) {
49
+ callback(null, resData);
50
+ })
51
+ .catch(function(err) {
52
+ log.error("uploadAttachment", err);
53
+ return callback(err);
54
+ });
55
+ }
56
+
57
+ return function uploadAttachment(attachments, callback) {
58
+ if (
59
+ !attachments &&
60
+ !utils.isReadableStream(attachments) &&
61
+ !utils.getType(attachments) === "Array" &&
62
+ utils.getType(attachments) === "Array" && !attachments.length
63
+ )
64
+ throw { error: "Please pass an attachment or an array of attachments." };
65
+
66
+ let resolveFunc = function() {};
67
+ let rejectFunc = function() {};
68
+ const returnPromise = new Promise(function(resolve, reject) {
69
+ resolveFunc = resolve;
70
+ rejectFunc = reject;
71
+ });
72
+
73
+ if (!callback) {
74
+ callback = function(err, info) {
75
+ if (err) {
76
+ return rejectFunc(err);
77
+ }
78
+ resolveFunc(info);
79
+ };
80
+ }
81
+
82
+ if (utils.getType(attachments) !== "Array") attachments = [attachments];
83
+
84
+ upload(attachments, (err, info) => {
85
+ if (err) {
86
+ return callback(err);
87
+ }
88
+ callback(null, info);
89
+ });
90
+
91
+ return returnPromise;
92
+ };
93
+ };