alicezetion 1.0.3 → 1.0.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (85) hide show
  1. package/.cache/replit/__replit_disk_meta.json +1 -1
  2. package/.cache/replit/nix/env.json +1 -1
  3. package/.travis.yml +6 -0
  4. package/index.js +532 -604
  5. package/package.json +78 -75
  6. package/replit.nix +5 -0
  7. package/src/addExternalModule.js +15 -0
  8. package/{alice → src}/addUserToGroup.js +77 -113
  9. package/src/changeAdminStatus.js +47 -0
  10. package/src/changeArchivedStatus.js +41 -0
  11. package/{alice → src}/changeBio.js +64 -77
  12. package/{alice → src}/changeBlockedStatus.js +36 -47
  13. package/{alice → src}/changeGroupImage.js +105 -129
  14. package/src/changeNickname.js +43 -0
  15. package/{alice → src}/changeThreadColor.js +61 -71
  16. package/src/changeThreadEmoji.js +41 -0
  17. package/src/chat.js +315 -0
  18. package/{alice → src}/createNewGroup.js +70 -86
  19. package/{alice → src}/createPoll.js +59 -71
  20. package/src/deleteMessage.js +44 -0
  21. package/src/deleteThread.js +42 -0
  22. package/src/forwardAttachment.js +47 -0
  23. package/src/forwardMessage.js +0 -0
  24. package/{alice → src}/getCurrentUserID.js +7 -7
  25. package/{alice → src}/getEmojiUrl.js +27 -29
  26. package/{alice → src}/getFriendsList.js +73 -84
  27. package/{alice → src}/getThreadHistory.js +537 -645
  28. package/src/getThreadHistoryDeprecated.js +71 -0
  29. package/{alice → src}/getThreadInfo.js +171 -206
  30. package/src/getThreadInfoDeprecated.js +56 -0
  31. package/{alice → src}/getThreadList.js +213 -238
  32. package/src/getThreadListDeprecated.js +46 -0
  33. package/src/getThreadPictures.js +59 -0
  34. package/{alice → src}/getUserID.js +61 -66
  35. package/{alice → src}/getUserInfo.js +66 -72
  36. package/src/handleFriendRequest.js +46 -0
  37. package/src/handleMessageRequest.js +47 -0
  38. package/{alice → src}/httpGet.js +47 -52
  39. package/{alice → src}/httpPost.js +47 -52
  40. package/src/listen.js +553 -0
  41. package/src/listenMqtt-Test.js +687 -0
  42. package/src/listenMqtt.js +677 -0
  43. package/{alice → src}/logout.js +68 -75
  44. package/{alice → src}/markAsDelivered.js +47 -58
  45. package/{alice → src}/markAsRead.js +70 -80
  46. package/{alice/seen.js → src/markAsReadAll.js} +39 -49
  47. package/{alice → src}/markAsSeen.js +48 -59
  48. package/{alice → src}/muteThread.js +45 -52
  49. package/src/removeUserFromGroup.js +45 -0
  50. package/{alice → src}/resolvePhotoUrl.js +36 -45
  51. package/src/searchForThread.js +42 -0
  52. package/{alice → src}/sendTypingIndicator.js +70 -103
  53. package/{alice/react.js → src/setMessageReaction.js} +103 -117
  54. package/{alice → src}/setPostReaction.js +63 -76
  55. package/{alice → src}/setTitle.js +70 -86
  56. package/src/threadColors.js +41 -0
  57. package/{alice → src}/unfriend.js +42 -52
  58. package/{alice → src}/unsendMessage.js +39 -49
  59. package/utils.js +1190 -1357
  60. package/alice/addExternalModule.js +0 -19
  61. package/alice/changeAdminStatus.js +0 -79
  62. package/alice/changeArchivedStatus.js +0 -55
  63. package/alice/changeNickname.js +0 -59
  64. package/alice/changeThreadEmoji.js +0 -55
  65. package/alice/chat.js +0 -459
  66. package/alice/deleteMessage.js +0 -56
  67. package/alice/deleteThread.js +0 -56
  68. package/alice/forwardAttachment.js +0 -60
  69. package/alice/getThreadHistoryDeprecated.js +0 -93
  70. package/alice/getThreadInfoDeprecated.js +0 -80
  71. package/alice/getThreadListDeprecated.js +0 -75
  72. package/alice/getThreadPictures.js +0 -79
  73. package/alice/handleFriendRequest.js +0 -61
  74. package/alice/handleMessageRequest.js +0 -65
  75. package/alice/listenMqtt.js +0 -789
  76. package/alice/removeUserFromGroup.js +0 -79
  77. package/alice/searchForThread.js +0 -53
  78. package/alice/threadColors.js +0 -57
  79. package/test/data/shareAttach.js +0 -146
  80. package/test/data/something.mov +0 -0
  81. package/test/data/test.png +0 -0
  82. package/test/data/test.txt +0 -7
  83. package/test/example-config.json +0 -18
  84. package/test/test-page.js +0 -140
  85. package/test/test.js +0 -385
package/src/chat.js ADDED
@@ -0,0 +1,315 @@
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+ var bluebird = require("bluebird");
6
+
7
+ var allowedProperties = {
8
+ attachment: true,
9
+ url: true,
10
+ sticker: true,
11
+ emoji: true,
12
+ emojiSize: true,
13
+ body: true,
14
+ mentions: true,
15
+ location: true,
16
+ };
17
+
18
+ module.exports = function(defaultFuncs, api, ctx) {
19
+ function uploadAttachment(attachments, callback) {
20
+ var uploads = [];
21
+
22
+ // create an array of promises
23
+ for (var i = 0; i < attachments.length; i++) {
24
+ if (!utils.isReadableStream(attachments[i])) throw { error: "Attachment should be a readable stream and not " + utils.getType(attachments[i]) + "." };
25
+ var form = {
26
+ upload_1024: attachments[i],
27
+ voice_clip: "true"
28
+ };
29
+
30
+ uploads.push(
31
+ defaultFuncs
32
+ .postFormData("https://upload.facebook.com/ajax/mercury/upload.php", ctx.jar, form, {})
33
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
+ .then(function(resData) {
35
+ if (resData.error) throw resData;
36
+ // We have to return the data unformatted unless we want to change it
37
+ // back in sendMessage.
38
+ return resData.payload.metadata[0];
39
+ })
40
+ );
41
+ }
42
+
43
+ // resolve all promises
44
+ bluebird
45
+ .all(uploads)
46
+ .then(resData => callback(null, resData))
47
+ .catch(function(err) {
48
+ log.error("uploadAttachment", err);
49
+ return callback(err);
50
+ });
51
+ }
52
+
53
+ function getUrl(url, callback) {
54
+ var form = {
55
+ image_height: 960,
56
+ image_width: 960,
57
+ uri: url
58
+ };
59
+
60
+ defaultFuncs
61
+ .post("https://www.facebook.com/message_share_attachment/fromURI/", ctx.jar, form)
62
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
63
+ .then(function(resData) {
64
+ if (resData.error) return callback(resData);
65
+ if (!resData.payload) return callback({ error: "Invalid url" });
66
+ callback(null, resData.payload.share_data.share_params);
67
+ })
68
+ .catch(function(err) {
69
+ log.error("getUrl", err);
70
+ return callback(err);
71
+ });
72
+ }
73
+
74
+ function sendContent(form, threadID, isSingleUser, messageAndOTID, callback) {
75
+ // There are three cases here:
76
+ // 1. threadID is of type array, where we're starting a new group chat with users
77
+ // specified in the array.
78
+ // 2. User is sending a message to a specific user.
79
+ // 3. No additional form params and the message goes to an existing group chat.
80
+ if (utils.getType(threadID) === "Array") {
81
+ for (var i = 0; i < threadID.length; i++) form["specific_to_list[" + i + "]"] = "fbid:" + threadID[i];
82
+ form["specific_to_list[" + threadID.length + "]"] = "fbid:" + ctx.userID;
83
+ form["client_thread_id"] = "root:" + messageAndOTID;
84
+ log.info("sendMessage", "Sending message to multiple users: " + threadID);
85
+ } else {
86
+ // This means that threadID is the id of a user, and the chat
87
+ // is a single person chat
88
+ if (isSingleUser) {
89
+ form["specific_to_list[0]"] = "fbid:" + threadID;
90
+ form["specific_to_list[1]"] = "fbid:" + ctx.userID;
91
+ form["other_user_fbid"] = threadID;
92
+ } else form["thread_fbid"] = threadID;
93
+ }
94
+
95
+ if (ctx.globalOptions.pageID) {
96
+ form["author"] = "fbid:" + ctx.globalOptions.pageID;
97
+ form["specific_to_list[1]"] = "fbid:" + ctx.globalOptions.pageID;
98
+ form["creator_info[creatorID]"] = ctx.userID;
99
+ form["creator_info[creatorType]"] = "direct_admin";
100
+ form["creator_info[labelType]"] = "sent_message";
101
+ form["creator_info[pageID]"] = ctx.globalOptions.pageID;
102
+ form["request_user_id"] = ctx.globalOptions.pageID;
103
+ form["creator_info[profileURI]"] = "https://www.facebook.com/profile.php?id=" + ctx.userID;
104
+ }
105
+
106
+ defaultFuncs
107
+ .post("https://www.facebook.com/messaging/send/", ctx.jar, form)
108
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
109
+ .then(function(resData) {
110
+ if (!resData) return callback({ error: "Send message failed." });
111
+ if (resData.error) {
112
+ if (resData.error === 1545012) log.warn("sendMessage", "Got error 1545012. This might mean that you're not part of the conversation " + threadID);
113
+ return callback(resData);
114
+ }
115
+
116
+ var messageInfo = resData.payload.actions.reduce(function(p, v) {
117
+ return ({
118
+ threadID: v.thread_fbid,
119
+ messageID: v.message_id,
120
+ timestamp: v.timestamp
121
+ } || p);
122
+ }, null);
123
+
124
+ return callback(null, messageInfo);
125
+ })
126
+ .catch(function(err) {
127
+ log.error("sendMessage", err);
128
+ if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
129
+ return callback(err);
130
+ });
131
+ }
132
+
133
+ function send(form, threadID, messageAndOTID, callback, isGroup) {
134
+ // fix lỗi = cach fetch threadID
135
+ // iq 5 trieu nam =))
136
+ if (utils.getType(threadID) === "Array") sendContent(form, threadID, false, messageAndOTID, callback);
137
+ else {
138
+ var THREADFIX = "ThreadID".replace("ThreadID", threadID);
139
+ if (THREADFIX.length <= 15 && THREADFIX.indexOf(1) == 0) return sendContent(form, threadID, !isGroup, messageAndOTID, callback);
140
+ else if (THREADFIX.length >= 15) return sendContent(form, threadID, threadID.length === 15, messageAndOTID, callback);
141
+ else return sendContent(form, threadID, threadID.length === 15, messageAndOTID, callback);
142
+ }
143
+ }
144
+
145
+ function handleUrl(msg, form, callback, cb) {
146
+ if (msg.url) {
147
+ form["shareable_attachment[share_type]"] = "100";
148
+ getUrl(msg.url, function(err, params) {
149
+ if (err) return callback(err);
150
+ form["shareable_attachment[share_params]"] = params;
151
+ cb();
152
+ });
153
+ } else cb();
154
+ }
155
+
156
+ function handleLocation(msg, form, callback, cb) {
157
+ if (msg.location) {
158
+ if (msg.location.latitude == null || msg.location.longitude == null) return callback({ error: "location property needs both latitude and longitude" });
159
+ form["location_attachment[coordinates][latitude]"] = msg.location.latitude;
160
+ form["location_attachment[coordinates][longitude]"] = msg.location.longitude;
161
+ form["location_attachment[is_current_location]"] = !!msg.location.current;
162
+ }
163
+ cb();
164
+ }
165
+
166
+ function handleSticker(msg, form, callback, cb) {
167
+ if (msg.sticker) form["sticker_id"] = msg.sticker;
168
+ cb();
169
+ }
170
+
171
+ function handleEmoji(msg, form, callback, cb) {
172
+ if (msg.emojiSize != null && msg.emoji == null) return callback({ error: "emoji property is empty" });
173
+ if (msg.emoji) {
174
+ if (msg.emojiSize == null) msg.emojiSize = "medium";
175
+ if (msg.emojiSize != "small" && msg.emojiSize != "medium" && msg.emojiSize != "large") return callback({ error: "emojiSize property is invalid" });
176
+ if (form["body"] != null && form["body"] != "") return callback({ error: "body is not empty" });
177
+ form["body"] = msg.emoji;
178
+ form["tags[0]"] = "hot_emoji_size:" + msg.emojiSize;
179
+ }
180
+ cb();
181
+ }
182
+
183
+ function handleAttachment(msg, form, callback, cb) {
184
+ if (msg.attachment) {
185
+ form["image_ids"] = [];
186
+ form["gif_ids"] = [];
187
+ form["file_ids"] = [];
188
+ form["video_ids"] = [];
189
+ form["audio_ids"] = [];
190
+
191
+ if (utils.getType(msg.attachment) !== "Array") msg.attachment = [msg.attachment];
192
+
193
+ uploadAttachment(msg.attachment, function(err, files) {
194
+ if (err) return callback(err);
195
+ files.forEach(function(file) {
196
+ var key = Object.keys(file);
197
+ var type = key[0]; // image_id, file_id, etc
198
+ form["" + type + "s"].push(file[type]); // push the id
199
+ });
200
+ cb();
201
+ });
202
+ } else cb();
203
+ }
204
+
205
+ function handleMention(msg, form, callback, cb) {
206
+ if (msg.mentions) {
207
+ for (let i = 0; i < msg.mentions.length; i++) {
208
+ const mention = msg.mentions[i];
209
+ const tag = mention.tag;
210
+ if (typeof tag !== "string") return callback({ error: "Mention tags must be strings." });
211
+ const offset = msg.body.indexOf(tag, mention.fromIndex || 0);
212
+ if (offset < 0) log.warn("handleMention", 'Mention for "' + tag + '" not found in message string.');
213
+ if (mention.id == null) log.warn("handleMention", "Mention id should be non-null.");
214
+
215
+ const id = mention.id || 0;
216
+ const emptyChar = '\u200E';
217
+ form["body"] = emptyChar + msg.body;
218
+ form["profile_xmd[" + i + "][offset]"] = offset + 1;
219
+ form["profile_xmd[" + i + "][length]"] = tag.length;
220
+ form["profile_xmd[" + i + "][id]"] = id;
221
+ form["profile_xmd[" + i + "][type]"] = "p";
222
+ }
223
+ }
224
+ cb();
225
+ }
226
+
227
+ return function sendMessage(msg, threadID, callback, replyToMessage, isGroup) {
228
+ typeof isGroup == "undefined" ? isGroup = null : "";
229
+ if (!callback && (utils.getType(threadID) === "Function" || utils.getType(threadID) === "AsyncFunction")) return threadID({ error: "Pass a threadID as a second argument." });
230
+ if (!replyToMessage && utils.getType(callback) === "String") {
231
+ replyToMessage = callback;
232
+ callback = function() {};
233
+ }
234
+
235
+ var resolveFunc = function() {};
236
+ var rejectFunc = function() {};
237
+ var returnPromise = new Promise(function(resolve, reject) {
238
+ resolveFunc = resolve;
239
+ rejectFunc = reject;
240
+ });
241
+
242
+ if (!callback) {
243
+ callback = function(err, data) {
244
+ if (err) return rejectFunc(err);
245
+ resolveFunc(data);
246
+ };
247
+ }
248
+
249
+ var msgType = utils.getType(msg);
250
+ var threadIDType = utils.getType(threadID);
251
+ var messageIDType = utils.getType(replyToMessage);
252
+
253
+ if (msgType !== "String" && msgType !== "Object") return callback({ error: "Message should be of type string or object and not " + msgType + "." });
254
+
255
+ // Changing this to accomodate an array of users
256
+ if (threadIDType !== "Array" && threadIDType !== "Number" && threadIDType !== "String") return callback({ error: "ThreadID should be of type number, string, or array and not " + threadIDType + "." });
257
+
258
+ if (replyToMessage && messageIDType !== 'String') return callback({ error: "MessageID should be of type string and not " + threadIDType + "." });
259
+
260
+ if (msgType === "String") msg = { body: msg };
261
+ var disallowedProperties = Object.keys(msg).filter(prop => !allowedProperties[prop]);
262
+ if (disallowedProperties.length > 0) return callback({ error: "Dissallowed props: `" + disallowedProperties.join(", ") + "`" });
263
+
264
+ var messageAndOTID = utils.generateOfflineThreadingID();
265
+
266
+ var form = {
267
+ client: "mercury",
268
+ action_type: "ma-type:user-generated-message",
269
+ author: "fbid:" + ctx.userID,
270
+ timestamp: Date.now(),
271
+ timestamp_absolute: "Today",
272
+ timestamp_relative: utils.generateTimestampRelative(),
273
+ timestamp_time_passed: "0",
274
+ is_unread: false,
275
+ is_cleared: false,
276
+ is_forward: false,
277
+ is_filtered_content: false,
278
+ is_filtered_content_bh: false,
279
+ is_filtered_content_account: false,
280
+ is_filtered_content_quasar: false,
281
+ is_filtered_content_invalid_app: false,
282
+ is_spoof_warning: false,
283
+ source: "source:chat:web",
284
+ "source_tags[0]": "source:chat",
285
+ body: msg.body ? msg.body.toString() : "",
286
+ html_body: false,
287
+ ui_push_phase: "V3",
288
+ status: "0",
289
+ offline_threading_id: messageAndOTID,
290
+ message_id: messageAndOTID,
291
+ threading_id: utils.generateThreadingID(ctx.clientID),
292
+ "ephemeral_ttl_mode:": "0",
293
+ manual_retry_cnt: "0",
294
+ has_attachment: !!(msg.attachment || msg.url || msg.sticker),
295
+ signatureID: utils.getSignatureID(),
296
+ replied_to_message_id: replyToMessage
297
+ };
298
+
299
+ handleLocation(msg, form, callback, () =>
300
+ handleSticker(msg, form, callback, () =>
301
+ handleAttachment(msg, form, callback, () =>
302
+ handleUrl(msg, form, callback, () =>
303
+ handleEmoji(msg, form, callback, () =>
304
+ handleMention(msg, form, callback, () =>
305
+ send(form, threadID, messageAndOTID, callback, isGroup)
306
+ )
307
+ )
308
+ )
309
+ )
310
+ )
311
+ );
312
+
313
+ return returnPromise;
314
+ };
315
+ };
@@ -1,86 +1,70 @@
1
- "use strict";
2
-
3
- var utils = require("../utils");
4
- var log = require("npmlog");
5
-
6
- module.exports = function(defaultFuncs, api, ctx) {
7
- return function createNewGroup(participantIDs, groupTitle, callback) {
8
- if (utils.getType(groupTitle) == "Function") {
9
- callback = groupTitle;
10
- groupTitle = null;
11
- }
12
-
13
- if (utils.getType(participantIDs) !== "Array") {
14
- throw { error: "createNewGroup: participantIDs should be an array." };
15
- }
16
-
17
- if (participantIDs.length < 2) {
18
- throw { error: "createNewGroup: participantIDs should have at least 2 IDs." };
19
- }
20
-
21
- var resolveFunc = function(){};
22
- var rejectFunc = function(){};
23
- var returnPromise = new Promise(function (resolve, reject) {
24
- resolveFunc = resolve;
25
- rejectFunc = reject;
26
- });
27
-
28
- if (!callback) {
29
- callback = function (err, threadID) {
30
- if (err) {
31
- return rejectFunc(err);
32
- }
33
- resolveFunc(threadID);
34
- };
35
- }
36
-
37
- var pids = [];
38
- for (var n in participantIDs) {
39
- pids.push({
40
- fbid: participantIDs[n]
41
- });
42
- }
43
- pids.push({fbid: ctx.userID});
44
-
45
- var form = {
46
- fb_api_caller_class: "RelayModern",
47
- fb_api_req_friendly_name: "MessengerGroupCreateMutation",
48
- av: ctx.userID,
49
- //This doc_id is valid as of January 11th, 2020
50
- doc_id: "577041672419534",
51
- variables: JSON.stringify({
52
- input: {
53
- entry_point: "jewel_new_group",
54
- actor_id: ctx.userID,
55
- participants: pids,
56
- client_mutation_id: Math.round(Math.random() * 1024).toString(),
57
- thread_settings: {
58
- name: groupTitle,
59
- joinable_mode: "PRIVATE",
60
- thread_image_fbid: null
61
- }
62
- }
63
- })
64
- };
65
-
66
- defaultFuncs
67
- .post(
68
- "https://www.facebook.com/api/graphql/",
69
- ctx.jar,
70
- form
71
- )
72
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
73
- .then(function(resData) {
74
- if (resData.errors) {
75
- throw resData;
76
- }
77
- return callback(null, resData.data.messenger_group_thread_create.thread.thread_key.thread_fbid);
78
- })
79
- .catch(function(err) {
80
- log.error("createNewGroup", err);
81
- return callback(err);
82
- });
83
-
84
- return returnPromise;
85
- };
86
- };
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function createNewGroup(participantIDs, groupTitle, callback) {
8
+ if (utils.getType(groupTitle) == "Function") {
9
+ callback = groupTitle;
10
+ groupTitle = null;
11
+ }
12
+
13
+ if (utils.getType(participantIDs) !== "Array") throw { error: "createNewGroup: participantIDs should be an array." };
14
+
15
+ if (participantIDs.length < 2) throw { error: "createNewGroup: participantIDs should have at least 2 IDs." };
16
+
17
+ var resolveFunc = function () { };
18
+ var rejectFunc = function () { };
19
+ var returnPromise = new Promise(function (resolve, reject) {
20
+ resolveFunc = resolve;
21
+ rejectFunc = reject;
22
+ });
23
+
24
+ if (!callback) {
25
+ callback = function (err, threadID) {
26
+ if (err) return rejectFunc(err);
27
+ resolveFunc(threadID);
28
+ };
29
+ }
30
+
31
+ var pids = [];
32
+ for (var n in participantIDs) pids.push({ fbid: participantIDs[n] });
33
+ pids.push({ fbid: ctx.userID });
34
+
35
+ var form = {
36
+ fb_api_caller_class: "RelayModern",
37
+ fb_api_req_friendly_name: "MessengerGroupCreateMutation",
38
+ av: ctx.userID,
39
+ //This doc_id is valid as of January 11th, 2020
40
+ doc_id: "577041672419534",
41
+ variables: JSON.stringify({
42
+ input: {
43
+ entry_point: "jewel_new_group",
44
+ actor_id: ctx.userID,
45
+ participants: pids,
46
+ client_mutation_id: Math.round(Math.random() * 1024).toString(),
47
+ thread_settings: {
48
+ name: groupTitle,
49
+ joinable_mode: "PRIVATE",
50
+ thread_image_fbid: null
51
+ }
52
+ }
53
+ })
54
+ };
55
+
56
+ defaultFuncs
57
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
58
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
59
+ .then(function (resData) {
60
+ if (resData.errors) throw resData;
61
+ return callback(null, resData.data.messenger_group_thread_create.thread.thread_key.thread_fbid);
62
+ })
63
+ .catch(function (err) {
64
+ log.error("createNewGroup", err);
65
+ return callback(err);
66
+ });
67
+
68
+ return returnPromise;
69
+ };
70
+ };
@@ -1,71 +1,59 @@
1
- "use strict";
2
-
3
- var utils = require("../utils");
4
- var log = require("npmlog");
5
-
6
- module.exports = function(defaultFuncs, api, ctx) {
7
- return function createPoll(title, threadID, options, callback) {
8
- var resolveFunc = function(){};
9
- var rejectFunc = function(){};
10
- var returnPromise = new Promise(function (resolve, reject) {
11
- resolveFunc = resolve;
12
- rejectFunc = reject;
13
- });
14
-
15
- if (!callback) {
16
- if (utils.getType(options) == "Function") {
17
- callback = options;
18
- options = null;
19
- } else {
20
- callback = function(err) {
21
- if (err) {
22
- return rejectFunc(err);
23
- }
24
- resolveFunc();
25
- };
26
- }
27
- }
28
- if (!options) {
29
- options = {}; // Initial poll options are optional
30
- }
31
-
32
- var form = {
33
- target_id: threadID,
34
- question_text: title
35
- };
36
-
37
- // Set fields for options (and whether they are selected initially by the posting user)
38
- var ind = 0;
39
- for (var opt in options) {
40
- // eslint-disable-next-line no-prototype-builtins
41
- if (options.hasOwnProperty(opt)) {
42
- form["option_text_array[" + ind + "]"] = opt;
43
- form["option_is_selected_array[" + ind + "]"] = options[opt]
44
- ? "1"
45
- : "0";
46
- ind++;
47
- }
48
- }
49
-
50
- defaultFuncs
51
- .post(
52
- "https://www.facebook.com/messaging/group_polling/create_poll/?dpr=1",
53
- ctx.jar,
54
- form
55
- )
56
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
57
- .then(function(resData) {
58
- if (resData.payload.status != "success") {
59
- throw resData;
60
- }
61
-
62
- return callback();
63
- })
64
- .catch(function(err) {
65
- log.error("createPoll", err);
66
- return callback(err);
67
- });
68
-
69
- return returnPromise;
70
- };
71
- };
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function createPoll(title, threadID, options, callback) {
8
+ var resolveFunc = function () { };
9
+ var rejectFunc = function () { };
10
+ var returnPromise = new Promise(function (resolve, reject) {
11
+ resolveFunc = resolve;
12
+ rejectFunc = reject;
13
+ });
14
+
15
+ if (!callback) {
16
+ if (utils.getType(options) == "Function") {
17
+ callback = options;
18
+ options = null;
19
+ }
20
+ else {
21
+ callback = function (err) {
22
+ if (err) return rejectFunc(err);
23
+ resolveFunc();
24
+ };
25
+ }
26
+ }
27
+ if (!options) options = {}; // Initial poll options are optional
28
+
29
+ var form = {
30
+ target_id: threadID,
31
+ question_text: title
32
+ };
33
+
34
+ // Set fields for options (and whether they are selected initially by the posting user)
35
+ var ind = 0;
36
+ for (var opt in options) {
37
+ // eslint-disable-next-line no-prototype-builtins
38
+ if (options.hasOwnProperty(opt)) {
39
+ form["option_text_array[" + ind + "]"] = opt;
40
+ form["option_is_selected_array[" + ind + "]"] = options[opt] ? "1" : "0";
41
+ ind++;
42
+ }
43
+ }
44
+
45
+ defaultFuncs
46
+ .post("https://www.facebook.com/messaging/group_polling/create_poll/?dpr=1", ctx.jar, form)
47
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
48
+ .then(function (resData) {
49
+ if (resData.payload.status != "success") throw resData;
50
+ return callback();
51
+ })
52
+ .catch(function (err) {
53
+ log.error("createPoll", err);
54
+ return callback(err);
55
+ });
56
+
57
+ return returnPromise;
58
+ };
59
+ };
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function deleteMessage(messageOrMessages, callback) {
8
+ var resolveFunc = function () { };
9
+ var rejectFunc = function () { };
10
+ var returnPromise = new Promise(function (resolve, reject) {
11
+ resolveFunc = resolve;
12
+ rejectFunc = reject;
13
+ });
14
+ if (!callback) {
15
+ callback = function (err) {
16
+ if (err) return rejectFunc(err);
17
+
18
+ resolveFunc();
19
+ };
20
+ }
21
+
22
+ var form = {
23
+ client: "mercury"
24
+ };
25
+
26
+ if (utils.getType(messageOrMessages) !== "Array") messageOrMessages = [messageOrMessages];
27
+
28
+ for (var i = 0; i < messageOrMessages.length; i++) form["message_ids[" + i + "]"] = messageOrMessages[i];
29
+
30
+ defaultFuncs
31
+ .post("https://www.facebook.com/ajax/mercury/delete_messages.php", ctx.jar, form)
32
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
33
+ .then(function (resData) {
34
+ if (resData.error) throw resData;
35
+ return callback();
36
+ })
37
+ .catch(function (err) {
38
+ log.error("deleteMessage", err);
39
+ return callback(err);
40
+ });
41
+
42
+ return returnPromise;
43
+ };
44
+ };