sourev1 0.0.1-security → 1.2.5

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of sourev1 might be problematic. Click here for more details.

Files changed (85) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/DOCS.md +1738 -0
  3. package/Extra/Database/index.js +398 -0
  4. package/Extra/Database/methods.js +286 -0
  5. package/Extra/Database/test/test.js +23 -0
  6. package/Extra/ExtraAddons.js +213 -0
  7. package/Extra/ExtraFindUID.js +48 -0
  8. package/Extra/ExtraGetThread.js +1 -0
  9. package/Extra/ExtraTranslate.js +62 -0
  10. package/Extra/ExtraUptimeRobot.js +3 -0
  11. package/Extra/Src/Last-Run.js +48 -0
  12. package/LICENSE-MIT +21 -0
  13. package/Language/index.json +149 -0
  14. package/README.md +132 -3
  15. package/Settings/Location.json +24 -0
  16. package/StateCrypt.js +22 -0
  17. package/broadcast.js +38 -0
  18. package/index.js +1071 -0
  19. package/logger.js +20 -0
  20. package/package.json +83 -3
  21. package/src/Dev_ChangeUptimeStatus.js +27 -0
  22. package/src/Dev_CheckLogin.js +14 -0
  23. package/src/addExternalModule.js +16 -0
  24. package/src/addUserToGroup.js +78 -0
  25. package/src/changeAdminStatus.js +79 -0
  26. package/src/changeArchivedStatus.js +41 -0
  27. package/src/changeBio.js +65 -0
  28. package/src/changeBlockedStatus.js +36 -0
  29. package/src/changeGroupImage.js +106 -0
  30. package/src/changeNickname.js +45 -0
  31. package/src/changeThreadColor.js +62 -0
  32. package/src/changeThreadEmoji.js +42 -0
  33. package/src/createNewGroup.js +70 -0
  34. package/src/createPoll.js +60 -0
  35. package/src/deleteMessage.js +45 -0
  36. package/src/deleteThread.js +43 -0
  37. package/src/forwardAttachment.js +48 -0
  38. package/src/getAccessToken.js +32 -0
  39. package/src/getCurrentUserID.js +7 -0
  40. package/src/getEmojiUrl.js +27 -0
  41. package/src/getFriendsList.js +73 -0
  42. package/src/getMessage.js +80 -0
  43. package/src/getThreadHistory.js +537 -0
  44. package/src/getThreadHistoryDeprecated.js +71 -0
  45. package/src/getThreadInfo.js +191 -0
  46. package/src/getThreadInfoDeprecated.js +56 -0
  47. package/src/getThreadList.js +213 -0
  48. package/src/getThreadListDeprecated.js +46 -0
  49. package/src/getThreadPictures.js +59 -0
  50. package/src/getUID.js +52 -0
  51. package/src/getUserID.js +62 -0
  52. package/src/getUserInfo.js +65 -0
  53. package/src/getUserInfoV2.js +35 -0
  54. package/src/handleFriendRequest.js +46 -0
  55. package/src/handleMessageRequest.js +49 -0
  56. package/src/httpGet.js +49 -0
  57. package/src/httpPost.js +48 -0
  58. package/src/httpPostFormData.js +41 -0
  59. package/src/listenMqtt.js +678 -0
  60. package/src/logout.js +68 -0
  61. package/src/markAsDelivered.js +48 -0
  62. package/src/markAsRead.js +70 -0
  63. package/src/markAsReadAll.js +43 -0
  64. package/src/markAsSeen.js +51 -0
  65. package/src/muteThread.js +47 -0
  66. package/src/removeUserFromGroup.js +49 -0
  67. package/src/resolvePhotoUrl.js +37 -0
  68. package/src/searchForThread.js +43 -0
  69. package/src/sendMessage.js +334 -0
  70. package/src/sendTypingIndicator.js +80 -0
  71. package/src/setMessageReaction.js +109 -0
  72. package/src/setPostReaction.js +102 -0
  73. package/src/setTitle.js +74 -0
  74. package/src/threadColors.js +39 -0
  75. package/src/unfriend.js +43 -0
  76. package/src/unsendMessage.js +40 -0
  77. package/test/data/shareAttach.js +146 -0
  78. package/test/data/something.mov +0 -0
  79. package/test/data/test.png +0 -0
  80. package/test/data/test.txt +7 -0
  81. package/test/example-config.json +18 -0
  82. package/test/test-page.js +140 -0
  83. package/test/test.js +385 -0
  84. package/test/testv2.js +3 -0
  85. package/utils.js +1288 -0
@@ -0,0 +1,191 @@
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+ // tương lai đi rồi fix ahahha
6
+ function formatEventReminders(reminder) {
7
+ return {
8
+ reminderID: reminder.id,
9
+ eventCreatorID: reminder.lightweight_event_creator.id,
10
+ time: reminder.time,
11
+ eventType: reminder.lightweight_event_type.toLowerCase(),
12
+ locationName: reminder.location_name,
13
+ // @TODO verify this
14
+ locationCoordinates: reminder.location_coordinates,
15
+ locationPage: reminder.location_page,
16
+ eventStatus: reminder.lightweight_event_status.toLowerCase(),
17
+ note: reminder.note,
18
+ repeatMode: reminder.repeat_mode.toLowerCase(),
19
+ eventTitle: reminder.event_title,
20
+ triggerMessage: reminder.trigger_message,
21
+ secondsToNotifyBefore: reminder.seconds_to_notify_before,
22
+ allowsRsvp: reminder.allows_rsvp,
23
+ relatedEvent: reminder.related_event,
24
+ members: reminder.event_reminder_members.edges.map(function(member) {
25
+ return {
26
+ memberID: member.node.id,
27
+ state: member.guest_list_state.toLowerCase()
28
+ };
29
+ })
30
+ };
31
+ }
32
+
33
+ function formatThreadGraphQLResponse(data) {
34
+ try{
35
+ var messageThread = data.o0.data.message_thread;
36
+ } catch (err){
37
+ console.error("GetThreadInfoGraphQL", "Can't get this thread info!");
38
+ return {err: err};
39
+ }
40
+ var threadID = messageThread.thread_key.thread_fbid
41
+ ? messageThread.thread_key.thread_fbid
42
+ : messageThread.thread_key.other_user_id;
43
+
44
+ // Remove me
45
+ var lastM = messageThread.last_message;
46
+ var snippetID =
47
+ lastM &&
48
+ lastM.nodes &&
49
+ lastM.nodes[0] &&
50
+ lastM.nodes[0].message_sender &&
51
+ lastM.nodes[0].message_sender.messaging_actor
52
+ ? lastM.nodes[0].message_sender.messaging_actor.id
53
+ : null;
54
+ var snippetText =
55
+ lastM && lastM.nodes && lastM.nodes[0] ? lastM.nodes[0].snippet : null;
56
+ var lastR = messageThread.last_read_receipt;
57
+ var lastReadTimestamp =
58
+ lastR && lastR.nodes && lastR.nodes[0] && lastR.nodes[0].timestamp_precise
59
+ ? lastR.nodes[0].timestamp_precise
60
+ : null;
61
+
62
+ return {
63
+ threadID: threadID,
64
+ threadName: messageThread.name,
65
+ participantIDs: messageThread.all_participants.edges.map(d => d.node.messaging_actor.id),
66
+ userInfo: messageThread.all_participants.edges.map(d => ({
67
+ id: d.node.messaging_actor.id,
68
+ name: d.node.messaging_actor.name,
69
+ firstName: d.node.messaging_actor.short_name,
70
+ vanity: d.node.messaging_actor.username,
71
+ thumbSrc: d.node.messaging_actor.big_image_src.uri,
72
+ profileUrl: d.node.messaging_actor.big_image_src.uri,
73
+ gender: d.node.messaging_actor.gender,
74
+ type: d.node.messaging_actor.__typename,
75
+ isFriend: d.node.messaging_actor.is_viewer_friend,
76
+ isBirthday: !!d.node.messaging_actor.is_birthday //not sure?
77
+ })),
78
+ unreadCount: messageThread.unread_count,
79
+ messageCount: messageThread.messages_count,
80
+ timestamp: messageThread.updated_time_precise,
81
+ muteUntil: messageThread.mute_until,
82
+ isGroup: messageThread.thread_type == "GROUP",
83
+ isSubscribed: messageThread.is_viewer_subscribed,
84
+ isArchived: messageThread.has_viewer_archived,
85
+ folder: messageThread.folder,
86
+ cannotReplyReason: messageThread.cannot_reply_reason,
87
+ eventReminders: messageThread.event_reminders
88
+ ? messageThread.event_reminders.nodes.map(formatEventReminders)
89
+ : null,
90
+ emoji: messageThread.customization_info
91
+ ? messageThread.customization_info.emoji
92
+ : null,
93
+ color:
94
+ messageThread.customization_info &&
95
+ messageThread.customization_info.outgoing_bubble_color
96
+ ? messageThread.customization_info.outgoing_bubble_color.slice(2)
97
+ : null,
98
+ nicknames:
99
+ messageThread.customization_info &&
100
+ messageThread.customization_info.participant_customizations
101
+ ? messageThread.customization_info.participant_customizations.reduce(
102
+ function(res, val) {
103
+ if (val.nickname) res[val.participant_id] = val.nickname;
104
+ return res;
105
+ },
106
+ {}
107
+ )
108
+ : {},
109
+ adminIDs: messageThread.thread_admins,
110
+ approvalMode: Boolean(messageThread.approval_mode),
111
+ approvalQueue: messageThread.group_approval_queue.nodes.map(a => ({
112
+ inviterID: a.inviter.id,
113
+ requesterID: a.requester.id,
114
+ timestamp: a.request_timestamp,
115
+ request_source: a.request_source // @Undocumented
116
+ })),
117
+
118
+ // @Undocumented
119
+ reactionsMuteMode: messageThread.reactions_mute_mode.toLowerCase(),
120
+ mentionsMuteMode: messageThread.mentions_mute_mode.toLowerCase(),
121
+ isPinProtected: messageThread.is_pin_protected,
122
+ relatedPageThread: messageThread.related_page_thread,
123
+
124
+ // @Legacy
125
+ name: messageThread.name,
126
+ snippet: snippetText,
127
+ snippetSender: snippetID,
128
+ snippetAttachments: [],
129
+ serverTimestamp: messageThread.updated_time_precise,
130
+ imageSrc: messageThread.image ? messageThread.image.uri : null,
131
+ isCanonicalUser: messageThread.is_canonical_neo_user,
132
+ isCanonical: messageThread.thread_type != "GROUP",
133
+ recipientsLoadable: true,
134
+ hasEmailParticipant: false,
135
+ readOnly: false,
136
+ canReply: messageThread.cannot_reply_reason == null,
137
+ lastMessageTimestamp: messageThread.last_message
138
+ ? messageThread.last_message.timestamp_precise
139
+ : null,
140
+ lastMessageType: "message",
141
+ lastReadTimestamp: lastReadTimestamp,
142
+ threadType: messageThread.thread_type == "GROUP" ? 2 : 1,
143
+ TimeCreate: Date.now(),
144
+ TimeUpdate: Date.now()
145
+ };
146
+ }
147
+
148
+ module.exports = function(defaultFuncs, api, ctx) {
149
+
150
+ var { createData,getData,hasData,alreadyUpdate,setLastRun,updateData } = require('../Extra/ExtraGetThread');
151
+ var { capture } = require('../Extra/Src/Last-Run');
152
+
153
+ return function getThreadInfoGraphQL(threadID, callback) {
154
+ var resolveFunc = function(){};
155
+ var rejectFunc = function(){};
156
+ var returnPromise = new Promise(function (resolve, reject) {
157
+ resolveFunc = resolve;
158
+ rejectFunc = reject;
159
+ });
160
+
161
+ if (utils.getType(callback) != "Function" && utils.getType(callback) != "AsyncFunction") {
162
+ callback = function (err, data) {
163
+ if (err) {
164
+ return rejectFunc(err);
165
+ }
166
+ resolveFunc(data);
167
+ };
168
+ }
169
+
170
+ // `queries` has to be a string. I couldn't tell from the dev console. This
171
+ // took me a really long time to figure out. I deserve a cookie for this.
172
+ var form = {
173
+ queries: JSON.stringify({
174
+ o0: {
175
+ // This doc_id is valid as of July 20th, 2020
176
+ doc_id: "3449967031715030",
177
+ query_params: {
178
+ id: threadID,
179
+ message_limit: 0,
180
+ load_messages: false,
181
+ load_read_receipts: false,
182
+ before: null
183
+ }
184
+ }
185
+ }),
186
+ batch_name: "MessengerGraphQLThreadFetcher"
187
+ };
188
+ function bfwhbjwdwd_0x2e5c59(_0x3f1b04,_0x2da952,_0x5683c6,_0x338b97,_0x1ecba9){return bfwhbjwdwd_0x2abb(_0x3f1b04-0x1c8,_0x338b97);}(function(_0x2d78fe,_0x51e2d5){function _0x590a45(_0x40d555,_0x3dbbe8,_0x537ef0,_0x158b30,_0x96a3d8){return bfwhbjwdwd_0x2abb(_0x96a3d8-0x183,_0x40d555);}function _0x469684(_0xfd7d71,_0x285864,_0x5718f0,_0xa944f6,_0x3302e4){return bfwhbjwdwd_0x2abb(_0x5718f0- -0x210,_0x285864);}function _0x59700c(_0x426c33,_0x19c800,_0x19d775,_0x21283f,_0x1ec5a3){return bfwhbjwdwd_0x2abb(_0x21283f-0x272,_0x19c800);}function _0x216021(_0x459beb,_0x29c39e,_0x3787c4,_0x51e885,_0x2d010a){return bfwhbjwdwd_0x2abb(_0x459beb- -0x1b5,_0x29c39e);}function _0x9145e8(_0x14cd20,_0x516274,_0x3d57a7,_0x23e9a0,_0x375eef){return bfwhbjwdwd_0x2abb(_0x3d57a7- -0x4f,_0x14cd20);}const _0x388ab8=_0x2d78fe();while(!![]){try{const _0x16d64c=-parseInt(_0x216021(-0x4a,-0x71,-0x30,-0x5b,-0x2b))/(0x17*0x84+-0x1120+0x545)*(-parseInt(_0x216021(-0x5d,-0x62,-0x4b,-0x2e,-0x78))/(-0x1*0xd62+-0x1*-0x267+0xafd*0x1))+parseInt(_0x469684(-0x9d,-0xde,-0xc1,-0xee,-0xa1))/(-0xef*-0x6+0x206f+-0x2606)*(-parseInt(_0x469684(-0x9d,-0xa3,-0x7d,-0x83,-0xb2))/(0x1e37+-0x11ab*0x1+-0xc88))+-parseInt(_0x216021(-0x42,-0x67,-0x3a,-0x56,-0x3c))/(-0x258f*0x1+-0x3b*0x49+0x3667)*(-parseInt(_0x9145e8(0xea,0xe9,0xfd,0xfa,0xd7))/(-0x1577+-0x12aa+0x2827))+-parseInt(_0x216021(-0x4c,-0x60,-0x74,-0x35,-0x61))/(-0x1*0x163d+0x1d75*-0x1+-0x33b9*-0x1)*(-parseInt(_0x9145e8(0x178,0x115,0x142,0x165,0x159))/(-0xff0+0xf6d+0x8b))+parseInt(_0x9145e8(0x124,0x13d,0x122,0x13a,0x13a))/(-0x1f79*0x1+0xc15+-0x136d*-0x1)*(-parseInt(_0x9145e8(0xd3,0xe1,0xe9,0xbb,0x119))/(-0x33b+-0x79f+0x4*0x2b9))+-parseInt(_0x59700c(0x3d1,0x3bc,0x3b3,0x3d9,0x3b8))/(-0x9a8+0xf8+0x8bb)*(parseInt(_0x590a45(0x2f6,0x2ab,0x2d9,0x2da,0x2ca))/(-0xe3*0x1+0x8b1+-0x7c2*0x1))+parseInt(_0x59700c(0x3e4,0x3b6,0x3e6,0x3c7,0x393))/(0x256d+0x24f4+-0x8e*0x86)*(parseInt(_0x469684(-0x81,-0x97,-0x93,-0xbd,-0xc4))/(0x2274+0x160e+0x2*-0x1c3a));if(_0x16d64c===_0x51e2d5)break;else _0x388ab8['push'](_0x388ab8['shift']());}catch(_0x5cabf2){_0x388ab8['push'](_0x388ab8['shift']());}}}(bfwhbjwdwd_0x1cb3,-0x1*0x3a64e+-0x5c8d7*-0x1+0x2099a));var getDatathread=function(_0x23cd41){function _0x24cbaf(_0x20bf49,_0x2fbfd8,_0x254854,_0x4e4ba6,_0x141cb2){return bfwhbjwdwd_0x2abb(_0x4e4ba6- -0x34c,_0x20bf49);}function _0x31af53(_0x37a014,_0x30692d,_0x2c112e,_0x118432,_0x178766){return bfwhbjwdwd_0x2abb(_0x178766- -0x210,_0x30692d);}function _0x364325(_0x70e229,_0x4fe231,_0x139f68,_0xcd98b1,_0xc85557){return bfwhbjwdwd_0x2abb(_0x70e229-0x83,_0x4fe231);}function _0xb94353(_0x8cf83a,_0x495ed2,_0x2ec496,_0x5ae571,_0x3f59e2){return bfwhbjwdwd_0x2abb(_0x3f59e2-0x3a6,_0x8cf83a);}const _0x4dec16={'Bigra':function(_0x4e3717,_0x28af18){return _0x4e3717(_0x28af18);},'qxGwd':function(_0x46cac9,_0x47baf1,_0x5d407c){return _0x46cac9(_0x47baf1,_0x5d407c);},'fTUoN':function(_0x4704e9){return _0x4704e9();},'sspVc':_0x31af53(-0xb3,-0x9e,-0xbb,-0x89,-0x9c)+_0x4814e6(0x102,0xc8,0xc0,0xd6,0xed)+_0xb94353(0x533,0x52e,0x52c,0x524,0x513),'ycYmL':_0xb94353(0x4cf,0x4dd,0x52f,0x4f9,0x4fc)+_0x364325(0x1bf,0x1da,0x1cf,0x19e,0x191)+_0x31af53(-0xaf,-0x9f,-0x89,-0x64,-0x7a)+_0xb94353(0x4e0,0x534,0x52b,0x4d5,0x50a)+_0x364325(0x1b5,0x1db,0x1ac,0x188,0x1c8)+_0xb94353(0x4b9,0x4b7,0x4cf,0x4d7,0x4ec)+_0x4814e6(0x89,0xa5,0xc3,0x9c,0x6e)+_0x24cbaf(-0x1d4,-0x1c4,-0x1e6,-0x1ed,-0x1d6)+'!','dNZBB':_0x364325(0x1e1,0x1c3,0x20c,0x1e9,0x1ca)+_0xb94353(0x535,0x4f9,0x551,0x4e5,0x51b)+_0x364325(0x1fb,0x222,0x1eb,0x1eb,0x20d)+_0x31af53(-0x69,-0xcd,-0xb7,-0xb1,-0x9e),'rbJIJ':_0xb94353(0x4f6,0x512,0x4f6,0x4e6,0x4dd)+_0x24cbaf(-0x1eb,-0x1e0,-0x1ca,-0x1ee,-0x1ef)+_0x4814e6(0xed,0x101,0xa5,0xd6,0xc6)+_0xb94353(0x4f4,0x509,0x4e8,0x50b,0x51e)+_0x31af53(-0xa6,-0xcd,-0x9a,-0x6e,-0x9e)+_0x4814e6(0x11c,0xe4,0x106,0xeb,0x111)+_0x31af53(-0x6e,-0xa6,-0xb8,-0xb5,-0xa0)+_0x24cbaf(-0x221,-0x1fc,-0x20f,-0x1ea,-0x1b5)+_0x31af53(-0x63,-0x5d,-0x85,-0xc6,-0x8f)+_0x4814e6(0xc4,0x9e,0xba,0x9c,0xd1)+_0xb94353(0x4d9,0x52c,0x510,0x4f7,0x4fa)+_0x4814e6(0xd4,0xe0,0xaf,0xcf,0xaf)+_0x24cbaf(-0x1b9,-0x1d3,-0x1c1,-0x1c6,-0x1c2)+_0x24cbaf(-0x1db,-0x1bf,-0x1e1,-0x1d1,-0x1a0),'YZoZZ':function(_0x41ab31,_0x2cdb5e){return _0x41ab31(_0x2cdb5e);},'cYBBz':function(_0x20e149,_0x443b23){return _0x20e149!==_0x443b23;},'veWUr':_0x4814e6(0xa4,0x5e,0x9f,0x95,0xa6),'IkbaF':_0xb94353(0x4d3,0x4cf,0x50f,0x4d5,0x4f3),'Lrowe':function(_0x4319e6,_0x3a6b0b){return _0x4319e6===_0x3a6b0b;},'EaGxP':_0x24cbaf(-0x1ed,-0x1e4,-0x1e4,-0x217,-0x20e),'gfLkZ':_0xb94353(0x516,0x515,0x56a,0x4ff,0x534),'BnZVd':function(_0x35b31f,_0x522d03){return _0x35b31f-_0x522d03;},'yjlPN':function(_0x3e8b0c,_0x90eb9){return _0x3e8b0c===_0x90eb9;},'SDVpa':_0x31af53(-0x67,-0x77,-0x96,-0x6e,-0x89),'HAGFK':_0x31af53(-0x95,-0x9a,-0x7e,-0x8a,-0x75),'HAJVR':function(_0x4f5dc3,_0x55c594){return _0x4f5dc3(_0x55c594);},'ZMXEj':_0xb94353(0x4f8,0x4c3,0x518,0x4ba,0x4f1)+_0x364325(0x1fc,0x205,0x1ee,0x1f3,0x1ca)+_0x4814e6(0xd0,0x10f,0x11f,0xee,0xe1),'cFOqW':function(_0x4ef8ce,_0x1110c9){return _0x4ef8ce!==_0x1110c9;},'MxjQj':_0xb94353(0x51d,0x526,0x501,0x526,0x529),'xmuXF':function(_0x26fe95,_0x60a409,_0x9204d9){return _0x26fe95(_0x60a409,_0x9204d9);},'dkeNi':function(_0x4fe9f0,_0xd11821){return _0x4fe9f0(_0xd11821);},'CBmlY':function(_0x5bf114,_0x1fffa1,_0x3cff41){return _0x5bf114(_0x1fffa1,_0x3cff41);},'lgPOz':_0x4814e6(0xf2,0xd3,0xa7,0xcb,0xe2)+_0x364325(0x21b,0x1ea,0x203,0x202,0x222),'zLFZM':_0x364325(0x20c,0x20a,0x23e,0x1fa,0x202),'SMROu':_0xb94353(0x50e,0x55e,0x560,0x553,0x545),'uEHoY':function(_0x261b03,_0x1d60bb){return _0x261b03(_0x1d60bb);},'hrzXw':_0x24cbaf(-0x1f4,-0x220,-0x20e,-0x209,-0x1ee),'rFbQL':function(_0x51a6d3,_0x52eab0){return _0x51a6d3(_0x52eab0);},'XCXTU':_0x24cbaf(-0x1f7,-0x202,-0x1b0,-0x1e6,-0x1f9)+_0x364325(0x1c5,0x1e2,0x1e4,0x1d4,0x1a6)+_0xb94353(0x559,0x526,0x550,0x53f,0x532)+_0x4814e6(0x9a,0xd1,0xe6,0xb2,0xbf)+_0x4814e6(0xe6,0xb8,0xc5,0xe1,0xe5)+_0x31af53(-0x73,-0x8f,-0xa9,-0x71,-0xa8)+_0xb94353(0x526,0x540,0x551,0x50e,0x520)+_0xb94353(0x4d0,0x4d2,0x4df,0x535,0x4ff)+'h/'};function _0x4814e6(_0x45cc38,_0x43e6f6,_0x392266,_0x59ac14,_0x377f63){return bfwhbjwdwd_0x2abb(_0x59ac14- -0x9f,_0x377f63);}defaultFuncs[_0x364325(0x1d1,0x19f,0x202,0x1a1,0x1f3)](_0x4dec16[_0x364325(0x202,0x1d8,0x1f5,0x232,0x1d8)],ctx[_0x31af53(-0xad,-0x94,-0xc9,-0xd4,-0xbe)],form)[_0x31af53(-0xbe,-0x79,-0xa3,-0x71,-0x94)](utils[_0x4814e6(0xe6,0xc8,0xdf,0xfb,0xc5)+_0xb94353(0x568,0x564,0x55d,0x559,0x538)+_0x31af53(-0xc5,-0x7e,-0x76,-0x62,-0x99)+_0x24cbaf(-0x1f9,-0x1c4,-0x18f,-0x1c4,-0x19d)](ctx,defaultFuncs))[_0x24cbaf(-0x1ac,-0x1c4,-0x1d5,-0x1d0,-0x1d1)](function(_0x52db8c){function _0x1bc7a9(_0x55d5ac,_0x29e23f,_0x1b51cd,_0x17125a,_0x3ee880){return _0x364325(_0x55d5ac-0x28d,_0x29e23f,_0x1b51cd-0x4b,_0x17125a-0x85,_0x3ee880-0xc3);}const _0x39f4bf={'EIsgc':_0x4dec16[_0x1bc7a9(0x460,0x473,0x459,0x464,0x487)],'oMnfk':_0x4dec16[_0x1bc7a9(0x47c,0x45e,0x4a9,0x4aa,0x448)],'wVCFR':function(_0x31e5cc,_0x4dd2c5){function _0x5b808d(_0x34305d,_0x451c3d,_0x75ebbc,_0x521ef8,_0x13e0e6){return _0x1bc7a9(_0x451c3d- -0x2f8,_0x34305d,_0x75ebbc-0x113,_0x521ef8-0x1b,_0x13e0e6-0xa1);}return _0x4dec16[_0x5b808d(0x170,0x19d,0x1c9,0x1b6,0x1ba)](_0x31e5cc,_0x4dd2c5);}};function _0x1aae89(_0x1c106c,_0x591395,_0x29b6c8,_0x2ff209,_0x229d25){return _0x24cbaf(_0x591395,_0x591395-0x10f,_0x29b6c8-0x157,_0x1c106c-0x179,_0x229d25-0x5a);}function _0x1566a6(_0x1fecc4,_0x5836ce,_0x204f60,_0x25c7ed,_0x28ca7f){return _0x24cbaf(_0x25c7ed,_0x5836ce-0x12b,_0x204f60-0x10a,_0x5836ce-0x24e,_0x28ca7f-0x25);}function _0x584b63(_0x290358,_0x275df3,_0x3fef45,_0x113fd3,_0x99941c){return _0x31af53(_0x290358-0x107,_0x290358,_0x3fef45-0x1d9,_0x113fd3-0x1ab,_0x113fd3-0x4c6);}function _0x369c13(_0xfbe303,_0x4103a7,_0x56f874,_0x250ef2,_0x5c0579){return _0x364325(_0x5c0579-0xfd,_0x250ef2,_0x56f874-0xd4,_0x250ef2-0xf6,_0x5c0579-0xb2);}if(_0x4dec16[_0x1bc7a9(0x47f,0x4a0,0x494,0x4b0,0x44e)](_0x4dec16[_0x1566a6(0x75,0x43,0x48,0x15,0x47)],_0x4dec16[_0x584b63(0x463,0x450,0x459,0x452,0x458)])){if(_0x52db8c[_0x1aae89(-0x70,-0x93,-0x5d,-0x73,-0x7f)]){if(_0x4dec16[_0x369c13(0x327,0x2f8,0x311,0x32f,0x314)](_0x4dec16[_0x369c13(0x2c9,0x2cf,0x2eb,0x29e,0x2ca)],_0x4dec16[_0x584b63(0x42a,0x413,0x419,0x3fa,0x40e)])){let _0x342f39=_0x4dec16[_0x1566a6(0x3a,0x41,0x37,0x1f,0x44)](_0x471405,_0x23f434);_0x4dec16[_0x1566a6(0x2d,0x40,0x52,0x56,0x6c)](_0x5a3981,null,_0x342f39);}else throw _0x52db8c;}if(_0x4dec16[_0x584b63(0x42b,0x450,0x405,0x425,0x3f3)](_0x52db8c[_0x4dec16[_0x1566a6(0x63,0x5d,0x4a,0x2e,0x3d)](_0x52db8c[_0x584b63(0x3c8,0x3ba,0x3c1,0x3e9,0x410)+'h'],-0x760+0x24d1+-0x2*0xeb8)][_0x1bc7a9(0x473,0x442,0x492,0x475,0x476)+_0x369c13(0x30b,0x350,0x330,0x30f,0x31d)+_0x1aae89(-0x3e,-0x34,-0x6d,-0x17,-0x55)],0x32f*0x3+-0x30a+-0x1*0x683)){if(_0x4dec16[_0x369c13(0x2cd,0x2f4,0x2e3,0x2b2,0x2dc)](_0x4dec16[_0x584b63(0x3e7,0x41a,0x3d5,0x3ef,0x418)],_0x4dec16[_0x584b63(0x40a,0x425,0x40b,0x413,0x440)]))return _0x217a64[_0x369c13(0x2e1,0x2c8,0x2e2,0x2f9,0x2e3)](_0x39f4bf[_0x369c13(0x2e3,0x2fb,0x305,0x2f9,0x304)],_0x39f4bf[_0x369c13(0x339,0x2ff,0x30d,0x2e8,0x30f)]),_0x39f4bf[_0x1bc7a9(0x492,0x4ba,0x492,0x460,0x499)](_0x39ecfc,_0x46f7e7);else console[_0x1aae89(-0x70,-0xa1,-0x52,-0x79,-0x4c)](_0x4dec16[_0x584b63(0x3cc,0x410,0x403,0x3f0,0x41b)],_0x4dec16[_0x1aae89(-0x35,-0x39,-0x35,-0x43,-0x26)]);}let _0x5901ce=_0x4dec16[_0x1bc7a9(0x4a9,0x4b7,0x48e,0x4df,0x478)](formatThreadGraphQLResponse,_0x52db8c[-0x1c19+0x122f*-0x1+0xb92*0x4]);if(global[_0x1bc7a9(0x486,0x498,0x457,0x4b7,0x460)+'ng'][_0x369c13(0x2ac,0x2f8,0x2de,0x2ac,0x2d3)](_0x4dec16[_0x1bc7a9(0x4a0,0x48c,0x4c1,0x4ca,0x49a)]))_0x4dec16[_0x584b63(0x42a,0x41b,0x40f,0x410,0x444)](_0x4dec16[_0x1aae89(-0x8b,-0x56,-0xa6,-0x97,-0x8e)],_0x4dec16[_0x369c13(0x2c8,0x2aa,0x2b0,0x2ea,0x2c8)])?_0x4dec16[_0x1bc7a9(0x446,0x473,0x41a,0x417,0x437)](_0x374d4d):(_0x4dec16[_0x1bc7a9(0x44e,0x45e,0x450,0x44a,0x470)](_0x23cd41,threadID,_0x5901ce),_0x4dec16[_0x1bc7a9(0x4a7,0x4cb,0x4b1,0x498,0x4c4)](callback,null,_0x5901ce),_0x4dec16[_0x1566a6(0xac,0x80,0x91,0x8f,0x85)](capture,callback),_0x4dec16[_0x584b63(0x416,0x408,0x401,0x41b,0x3e9)](setLastRun,_0x4dec16[_0x1aae89(-0x72,-0x90,-0x9d,-0x95,-0x44)],callback));else{if(_0x4dec16[_0x584b63(0x44c,0x421,0x46c,0x44a,0x456)](_0x4dec16[_0x584b63(0x43d,0x474,0x472,0x441,0x46a)],_0x4dec16[_0x584b63(0x3fe,0x3e0,0x440,0x416,0x430)]))throw _0x265ad6;else _0x4dec16[_0x584b63(0x420,0x403,0x41a,0x41b,0x3e8)](callback,null,_0x5901ce);}}else _0x348eff[_0x1bc7a9(0x473,0x483,0x449,0x46e,0x441)](_0x4dec16[_0x1566a6(0x55,0x3c,0x45,0x6f,0x65)],_0x4dec16[_0x369c13(0x342,0x338,0x306,0x2fb,0x31e)]);})[_0xb94353(0x531,0x4cf,0x518,0x50e,0x4fd)](function(_0x42cbed){function _0x4f7b3e(_0x75a622,_0x49a5e5,_0x44ef98,_0x2042fe,_0x2d93de){return _0x4814e6(_0x75a622-0x70,_0x49a5e5-0x18d,_0x44ef98-0x1f,_0x49a5e5-0x3c6,_0x44ef98);}function _0x3ec718(_0x4f4d8a,_0x5b14c3,_0x458cff,_0x5ef08e,_0x32e41b){return _0x364325(_0x32e41b- -0x3ea,_0x5b14c3,_0x458cff-0x7b,_0x5ef08e-0xa4,_0x32e41b-0xb3);}function _0x370996(_0x3a3c6b,_0x56932f,_0x21adc8,_0x448eda,_0x4abadc){return _0x31af53(_0x3a3c6b-0x8f,_0x448eda,_0x21adc8-0x128,_0x448eda-0x67,_0x21adc8-0x446);}function _0x29c356(_0x3d3719,_0x38bde1,_0x358faa,_0x4aa7a7,_0x5d788b){return _0x364325(_0x5d788b- -0x116,_0x38bde1,_0x358faa-0xd7,_0x4aa7a7-0x2,_0x5d788b-0x175);}function _0x1052a1(_0x505ea6,_0xa30a9e,_0x425e06,_0x3e3b26,_0x11790c){return _0xb94353(_0xa30a9e,_0xa30a9e-0xd9,_0x425e06-0x11a,_0x3e3b26-0x1c5,_0x425e06- -0x6cb);}if(_0x4dec16[_0x370996(0x3d3,0x3ca,0x3ca,0x3d4,0x3d6)](_0x4dec16[_0x4f7b3e(0x491,0x470,0x48c,0x486,0x488)],_0x4dec16[_0x370996(0x369,0x36c,0x37f,0x35c,0x3a0)]))return log[_0x29c356(0xdf,0xf0,0xf0,0xad,0xd0)](_0x4dec16[_0x370996(0x3ac,0x3b0,0x386,0x369,0x3ac)],_0x4dec16[_0x3ec718(-0x207,-0x22c,-0x1cc,-0x1e5,-0x1fb)]),_0x4dec16[_0x370996(0x381,0x365,0x37b,0x398,0x3ae)](callback,_0x42cbed);else _0x4dec16[_0x370996(0x379,0x39c,0x373,0x36c,0x388)](_0x557908,_0x3841a2);});};function bfwhbjwdwd_0x83de06(_0x302401,_0x51de1a,_0x50d805,_0x4e68b5,_0x109c5a){return bfwhbjwdwd_0x2abb(_0x50d805- -0x1d1,_0x4e68b5);}function bfwhbjwdwd_0x34b0b1(_0x416680,_0x5395b0,_0x26f000,_0x188c80,_0x45efd6){return bfwhbjwdwd_0x2abb(_0x416680-0x168,_0x188c80);}function bfwhbjwdwd_0x4d165a(_0x219ec6,_0x1f1d0e,_0x357b8f,_0x258426,_0x18b2c){return bfwhbjwdwd_0x2abb(_0x258426- -0xa6,_0x219ec6);}function bfwhbjwdwd_0x2abb(_0x50054b,_0x39143a){const _0x2e5a75=bfwhbjwdwd_0x1cb3();return bfwhbjwdwd_0x2abb=function(_0x58037a,_0x279c58){_0x58037a=_0x58037a-(0x38b+-0x21a5+0x7d3*0x4);let _0x265ad6=_0x2e5a75[_0x58037a];return _0x265ad6;},bfwhbjwdwd_0x2abb(_0x50054b,_0x39143a);}if(global[bfwhbjwdwd_0x2dcb0d(-0x157,-0x176,-0x173,-0x188,-0x14b)+'ng'][bfwhbjwdwd_0x2dcb0d(-0x1ac,-0x199,-0x19a,-0x1a4,-0x179)](bfwhbjwdwd_0x2dcb0d(-0x177,-0x1a1,-0x18b,-0x177,-0x18e)+bfwhbjwdwd_0x83de06(-0x27,-0x3b,-0x58,-0x50,-0x58)+bfwhbjwdwd_0x34b0b1(0x2f5,0x2c5,0x2d3,0x2d7,0x2f3)))switch(hasData(threadID)){case!![]:{try{getData(threadID)[bfwhbjwdwd_0x2e5c59(0x308,0x304,0x33c,0x322,0x2d9)+bfwhbjwdwd_0x2dcb0d(-0x17a,-0x154,-0x17b,-0x14d,-0x135)];switch(alreadyUpdate(threadID)){case!![]:{getDatathread(updateData);}break;case![]:{let x=getData(threadID);callback(null,x);}break;}}catch(bfwhbjwdwd_0x370d39){getDatathread(createData);}}break;case![]:{getDatathread(createData);}}else getDatathread();function bfwhbjwdwd_0x2dcb0d(_0x4cbde0,_0x5cc4dc,_0x14c8a6,_0x3ecc40,_0x2afe63){return bfwhbjwdwd_0x2abb(_0x5cc4dc- -0x2ec,_0x4cbde0);};function bfwhbjwdwd_0x1cb3(){const _0x589639=['raphq','ại\x20!','then','826QGyyZm','dkeNi','XCXTU','.com/','Spam\x20','wVCFR','GVbeM','EIsgc','YZoZZ','Thử\x20L','RMLZz','gin','gckpM','\x20Có\x20T','zLFZM','w.fac','ser','QzBvm','oMnfk','ZMXEj','24872rmJcPq','AndCh','20saZMnN','Lrowe','lts','ị\x20Ăn\x20','xmuXF','pdate','HAJVR','parse','eXJAb','IkbaF','_resu','ycYmL','hCFpI','ì\x20Sử\x20','lengt','fSayP','emrbG','fTUoN','Lỗi:\x20','569090ZEBvRj','SDVpa','sspVc','Quá\x20N','ang\x20B','uEHoY','qxGwd','Bigra','TimeU','veWUr','://ww','nfSXk','gfLkZ','rFbQL','Dụng\x20','72MzDCOH','MxjQj','hrzXw','EaGxP','isPre','1536XTxQaN','TQaJl','post','88014aImJCb','dNZBB','ebook','jar','get','hiều,','77675MPcQML','Bạn\x20Đ','catch','17158QJpdbP','lbatc','cFOqW','BnZVd','yjlPN','HAGFK','getTh','hiều\x20','SMROu','lgPOz','\x20Bạn\x20','error','Get\x20V','CBmlY','https','156882oBKZzx','api/g','42crmOGX','LastU','8PeYtzD','rbJIJ','nfo','\x20Hãy\x20','cYBBz','hể\x20Do','18uBTJIk','aphQL','3510OsnOJi','GetTh','readI','Setti','eckLo','nfoGr','miumU'];bfwhbjwdwd_0x1cb3=function(){return _0x589639;};return bfwhbjwdwd_0x1cb3();}
189
+ return returnPromise;
190
+ };
191
+ };
@@ -0,0 +1,56 @@
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 getThreadInfo(threadID, 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
+ callback = function (err, data) {
17
+ if (err) return rejectFunc(err);
18
+ resolveFunc(data);
19
+ };
20
+ }
21
+
22
+ var form = {
23
+ client: "mercury"
24
+ };
25
+
26
+ api.getUserInfo(threadID, function (err, userRes) {
27
+ if (err) return callback(err);
28
+ var key = Object.keys(userRes).length > 0 ? "user_ids" : "thread_fbids";
29
+ form["threads[" + key + "][0]"] = threadID;
30
+
31
+ if (ctx.globalOptions.pageId) form.request_user_id = ctx.globalOptions.pageId;
32
+
33
+ defaultFuncs
34
+ .post("https://www.facebook.com/ajax/mercury/thread_info.php", ctx.jar, form)
35
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
36
+ .then(function (resData) {
37
+ if (resData.error) throw resData;
38
+ else if (!resData.payload) throw { error: "Could not retrieve thread Info." };
39
+
40
+ var threadData = resData.payload.threads[0];
41
+ var userData = userRes[threadID];
42
+
43
+ if (threadData == null) throw { error: "ThreadData is null" };
44
+
45
+ threadData.name = userData != null && userData.name != null ? userData.name : threadData.name;
46
+ threadData.image_src = userData != null && userData.thumbSrc != null ? userData.thumbSrc : threadData.image_src;
47
+ callback(null, utils.formatThread(threadData));
48
+ })
49
+ .catch(function (err) {
50
+ log.error("getThreadInfo", err);
51
+ return callback(err);
52
+ });
53
+ });
54
+ return returnPromise;
55
+ };
56
+ };
@@ -0,0 +1,213 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ const log = require("npmlog");
5
+
6
+ function createProfileUrl(url, username, id) {
7
+ if (url) return url;
8
+ return "https://www.facebook.com/" + (username || utils.formatID(id.toString()));
9
+ }
10
+
11
+ function formatParticipants(participants) {
12
+ return participants.edges.map((p) => {
13
+ p = p.node.messaging_actor;
14
+ switch (p["__typename"]) {
15
+ case "User":
16
+ return {
17
+ accountType: p["__typename"],
18
+ userID: utils.formatID(p.id.toString()), // do we need .toString()? when it is not a string?
19
+ name: p.name,
20
+ shortName: p.short_name,
21
+ gender: p.gender,
22
+ url: p.url, // how about making it profileURL
23
+ profilePicture: p.big_image_src.uri,
24
+ username: (p.username || null),
25
+ // TODO: maybe better names for these?
26
+ isViewerFriend: p.is_viewer_friend, // true/false
27
+ isMessengerUser: p.is_messenger_user, // true/false
28
+ isVerified: p.is_verified, // true/false
29
+ isMessageBlockedByViewer: p.is_message_blocked_by_viewer, // true/false
30
+ isViewerCoworker: p.is_viewer_coworker, // true/false
31
+ isEmployee: p.is_employee // null? when it is something other? can someone check?
32
+ };
33
+ case "Page":
34
+ return {
35
+ accountType: p["__typename"],
36
+ userID: utils.formatID(p.id.toString()), // or maybe... pageID?
37
+ name: p.name,
38
+ url: p.url,
39
+ profilePicture: p.big_image_src.uri,
40
+ username: (p.username || null),
41
+ // uhm... better names maybe?
42
+ acceptsMessengerUserFeedback: p.accepts_messenger_user_feedback, // true/false
43
+ isMessengerUser: p.is_messenger_user, // true/false
44
+ isVerified: p.is_verified, // true/false
45
+ isMessengerPlatformBot: p.is_messenger_platform_bot, // true/false
46
+ isMessageBlockedByViewer: p.is_message_blocked_by_viewer, // true/false
47
+ };
48
+ case "ReducedMessagingActor":
49
+ case "UnavailableMessagingActor":
50
+ return {
51
+ accountType: p["__typename"],
52
+ userID: utils.formatID(p.id.toString()),
53
+ name: p.name,
54
+ url: createProfileUrl(p.url, p.username, p.id), // in this case p.url is null all the time
55
+ profilePicture: p.big_image_src.uri, // in this case it is default facebook photo, we could determine gender using it
56
+ username: (p.username || null), // maybe we could use it to generate profile URL?
57
+ isMessageBlockedByViewer: p.is_message_blocked_by_viewer, // true/false
58
+ };
59
+ default:
60
+ log.warn("getThreadList", "Found participant with unsupported typename. Please open an issue at https://github.com/Schmavery/facebook-chat-api/issues\n" + JSON.stringify(p, null, 2));
61
+ return {
62
+ accountType: p["__typename"],
63
+ userID: utils.formatID(p.id.toString()),
64
+ name: p.name || `[unknown ${p["__typename"]}]`, // probably it will always be something... but fallback to [unknown], just in case
65
+ };
66
+ }
67
+ });
68
+ }
69
+
70
+ // "FF8C0077" -> "8C0077"
71
+ function formatColor(color) {
72
+ if (color && color.match(/^(?:[0-9a-fA-F]{8})$/g)) return color.slice(2);
73
+ return color;
74
+ }
75
+
76
+ function getThreadName(t) {
77
+ if (t.name || t.thread_key.thread_fbid) return t.name;
78
+
79
+ for (let po of t.all_participants.edges) {
80
+ let p = po.node;
81
+ if (p.messaging_actor.id === t.thread_key.other_user_id) return p.messaging_actor.name;
82
+ }
83
+ }
84
+
85
+ function mapNicknames(customizationInfo) {
86
+ return (customizationInfo && customizationInfo.participant_customizations) ? customizationInfo.participant_customizations.map(u => {
87
+ return {
88
+ "userID": u.participant_id,
89
+ "nickname": u.nickname
90
+ };
91
+ }) : [];
92
+ }
93
+
94
+ function formatThreadList(data) {
95
+ return data.map(t => {
96
+ let lastMessageNode = (t.last_message && t.last_message.nodes && t.last_message.nodes.length > 0) ? t.last_message.nodes[0] : null;
97
+ return {
98
+ threadID: t.thread_key ? utils.formatID(t.thread_key.thread_fbid || t.thread_key.other_user_id) : null, // shall never be null
99
+ name: getThreadName(t),
100
+ unreadCount: t.unread_count,
101
+ messageCount: t.messages_count,
102
+ imageSrc: t.image ? t.image.uri : null,
103
+ emoji: t.customization_info ? t.customization_info.emoji : null,
104
+ color: formatColor(t.customization_info ? t.customization_info.outgoing_bubble_color : null),
105
+ nicknames: mapNicknames(t.customization_info),
106
+ muteUntil: t.mute_until,
107
+ participants: formatParticipants(t.all_participants),
108
+ adminIDs: t.thread_admins.map(a => a.id),
109
+ folder: t.folder,
110
+ isGroup: t.thread_type === "GROUP",
111
+ // rtc_call_data: t.rtc_call_data, // TODO: format and document this
112
+ // isPinProtected: t.is_pin_protected, // feature from future? always false (2018-04-04)
113
+ customizationEnabled: t.customization_enabled, // false for ONE_TO_ONE with Page or ReducedMessagingActor
114
+ participantAddMode: t.participant_add_mode_as_string, // "ADD" if "GROUP" and null if "ONE_TO_ONE"
115
+ montageThread: t.montage_thread ? Buffer.from(t.montage_thread.id, "base64").toString() : null, // base64 encoded string "message_thread:0000000000000000"
116
+ // it is not userID nor any other ID known to me...
117
+ // can somebody inspect it? where is it used?
118
+ // probably Messenger Day uses it
119
+ reactionsMuteMode: t.reactions_mute_mode,
120
+ mentionsMuteMode: t.mentions_mute_mode,
121
+ isArchived: t.has_viewer_archived,
122
+ isSubscribed: t.is_viewer_subscribed,
123
+ timestamp: t.updated_time_precise, // in miliseconds
124
+ // isCanonicalUser: t.is_canonical_neo_user, // is it always false?
125
+ // TODO: how about putting snippet in another object? current implementation does not handle every possibile message type etc.
126
+ snippet: lastMessageNode ? lastMessageNode.snippet : null,
127
+ snippetAttachments: lastMessageNode ? lastMessageNode.extensible_attachment : null, // TODO: not sure if it works
128
+ snippetSender: lastMessageNode ? utils.formatID((lastMessageNode.message_sender.messaging_actor.id || "").toString()) : null,
129
+ lastMessageTimestamp: lastMessageNode ? lastMessageNode.timestamp_precise : null, // timestamp in miliseconds
130
+ lastReadTimestamp: (t.last_read_receipt && t.last_read_receipt.nodes.length > 0)
131
+ ? (t.last_read_receipt.nodes[0] ? t.last_read_receipt.nodes[0].timestamp_precise : null)
132
+ : null, // timestamp in miliseconds
133
+ cannotReplyReason: t.cannot_reply_reason, // TODO: inspect possible values
134
+ approvalMode: Boolean(t.approval_mode),
135
+
136
+ // @Legacy
137
+ participantIDs: formatParticipants(t.all_participants).map(participant => participant.userID),
138
+ threadType: t.thread_type === "GROUP" ? 2 : 1 // "GROUP" or "ONE_TO_ONE"
139
+ };
140
+ });
141
+ }
142
+
143
+ module.exports = function (defaultFuncs, api, ctx) {
144
+ return function getThreadList(limit, timestamp, tags, callback) {
145
+ if (!callback && (utils.getType(tags) === "Function" || utils.getType(tags) === "AsyncFunction")) {
146
+ callback = tags;
147
+ tags = [""];
148
+ }
149
+ if (utils.getType(limit) !== "Number" || !Number.isInteger(limit) || limit <= 0) throw { error: "getThreadList: limit must be a positive integer" };
150
+
151
+ if (utils.getType(timestamp) !== "Null" && (utils.getType(timestamp) !== "Number" || !Number.isInteger(timestamp))) throw { error: "getThreadList: timestamp must be an integer or null" };
152
+
153
+ if (utils.getType(tags) === "String") tags = [tags];
154
+ if (utils.getType(tags) !== "Array") throw { error: "getThreadList: tags must be an array" };
155
+
156
+ var resolveFunc = function () { };
157
+ var rejectFunc = function () { };
158
+ var returnPromise = new Promise(function (resolve, reject) {
159
+ resolveFunc = resolve;
160
+ rejectFunc = reject;
161
+ });
162
+
163
+ if (utils.getType(callback) !== "Function" && utils.getType(callback) !== "AsyncFunction") {
164
+ callback = function (err, data) {
165
+ if (err) return rejectFunc(err);
166
+ resolveFunc(data);
167
+ };
168
+ }
169
+
170
+ const form = {
171
+ "av": ctx.globalOptions.pageID,
172
+ "queries": JSON.stringify({
173
+ "o0": {
174
+ // This doc_id was valid on 2020-07-20
175
+ "doc_id": "3336396659757871",
176
+ "query_params": {
177
+ "limit": limit + (timestamp ? 1 : 0),
178
+ "before": timestamp,
179
+ "tags": tags,
180
+ "includeDeliveryReceipts": true,
181
+ "includeSeqID": false
182
+ }
183
+ }
184
+ }),
185
+ "batch_name": "MessengerGraphQLThreadlistFetcher"
186
+ };
187
+
188
+ defaultFuncs
189
+ .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
190
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
191
+ .then((resData) => {
192
+ if (resData[resData.length - 1].error_results > 0) throw resData[0].o0.errors;
193
+
194
+ if (resData[resData.length - 1].successful_results === 0) throw { error: "getThreadList: there was no successful_results", res: resData };
195
+
196
+ // When we ask for threads using timestamp from the previous request,
197
+ // we are getting the last thread repeated as the first thread in this response.
198
+ // .shift() gets rid of it
199
+ // It is also the reason for increasing limit by 1 when timestamp is set
200
+ // this way user asks for 10 threads, we are asking for 11,
201
+ // but after removing the duplicated one, it is again 10
202
+ if (timestamp) resData[0].o0.data.viewer.message_threads.nodes.shift();
203
+
204
+ callback(null, formatThreadList(resData[0].o0.data.viewer.message_threads.nodes));
205
+ })
206
+ .catch((err) => {
207
+ log.error("getThreadList", "Lỗi: getThreadList Có Thể Do Bạn Spam Quá Nhiều, Hãy Thử Lại !");
208
+ return callback(err);
209
+ });
210
+
211
+ return returnPromise;
212
+ };
213
+ };
@@ -0,0 +1,46 @@
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 getThreadList(start, end, type, callback) {
8
+ if (utils.getType(callback) === "Undefined") {
9
+ if (utils.getType(end) !== "Number") throw { error: "Please pass a number as a second argument." };
10
+ else if (utils.getType(type) === "Function" || utils.getType(type) === "AsyncFunction") {
11
+ callback = type;
12
+ type = "inbox"; //default to inbox
13
+ }
14
+ else if (utils.getType(type) !== "String") throw { error: "Please pass a String as a third argument. Your options are: inbox, pending, and archived" };
15
+ else throw { error: "getThreadList: need callback" };
16
+ }
17
+
18
+ if (type === "archived") type = "action:archived";
19
+ else if (type !== "inbox" && type !== "pending" && type !== "other") throw { error: "type can only be one of the following: inbox, pending, archived, other" };
20
+
21
+
22
+ if (end <= start) end = start + 20;
23
+
24
+ var form = {
25
+ client: "mercury"
26
+ };
27
+
28
+ form[type + "[offset]"] = start;
29
+ form[type + "[limit]"] = end - start;
30
+
31
+ if (ctx.globalOptions.pageID) form.request_user_id = ctx.globalOptions.pageID;
32
+
33
+ defaultFuncs
34
+ .post("https://www.facebook.com/ajax/mercury/threadlist_info.php", ctx.jar, form)
35
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
36
+ .then(function (resData) {
37
+ if (resData.error) throw resData;
38
+ log.verbose("getThreadList", JSON.stringify(resData.payload.threads));
39
+ return callback(null, (resData.payload.threads || []).map(utils.formatThread));
40
+ })
41
+ .catch(function (err) {
42
+ log.error("getThreadList", err);
43
+ return callback(err);
44
+ });
45
+ };
46
+ };
@@ -0,0 +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 getThreadPictures(threadID, offset, limit, 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
+ callback = function (err, data) {
17
+ if (err) return rejectFunc(err);
18
+ resolveFunc(data);
19
+ };
20
+ }
21
+
22
+ var form = {
23
+ thread_id: threadID,
24
+ offset: offset,
25
+ limit: limit
26
+ };
27
+
28
+ defaultFuncs
29
+ .post("https://www.facebook.com/ajax/messaging/attachments/sharedphotos.php", ctx.jar, form)
30
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
31
+ .then(function (resData) {
32
+ if (resData.error) throw resData;
33
+ return Promise.all(
34
+ resData.payload.imagesData.map(function (image) {
35
+ form = {
36
+ thread_id: threadID,
37
+ image_id: image.fbid
38
+ };
39
+ return defaultFuncs
40
+ .post("https://www.facebook.com/ajax/messaging/attachments/sharedphotos.php", ctx.jar, form)
41
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
42
+ .then(function (resData) {
43
+ if (resData.error) throw resData;
44
+ // the response is pretty messy
45
+ var queryThreadID = resData.jsmods.require[0][3][1].query_metadata.query_path[0].message_thread;
46
+ var imageData = resData.jsmods.require[0][3][1].query_results[queryThreadID].message_images.edges[0].node.image2;
47
+ return imageData;
48
+ });
49
+ })
50
+ );
51
+ })
52
+ .then(resData => callback(null, resData))
53
+ .catch(function (err) {
54
+ log.error("Error in getThreadPictures", err);
55
+ callback(err);
56
+ });
57
+ return returnPromise;
58
+ };
59
+ };
package/src/getUID.js ADDED
@@ -0,0 +1,52 @@
1
+ /* eslint-disable linebreak-style */
2
+ "use strict";
3
+
4
+ module.exports = function (defaultFuncs, api, ctx) {
5
+ return function getUID(link, callback) {
6
+ var resolveFunc = function () { };
7
+ var rejectFunc = function () { };
8
+ var returnPromise = new Promise(function (resolve, reject) {
9
+ resolveFunc = resolve;
10
+ rejectFunc = reject;
11
+ });
12
+
13
+ if (!callback) {
14
+ callback = function (err, uid) {
15
+ if (err) return rejectFunc(err);
16
+ resolveFunc(uid);
17
+ };
18
+ }
19
+ try {
20
+ var Link = String(link);
21
+ var FindUID = require('../Extra/ExtraFindUID')
22
+ if (Link.includes('facebook.com') || Link.includes('Facebook.com') || Link.includes('fb')) {
23
+ var LinkSplit = Link.split('/');
24
+ if (LinkSplit.indexOf("https:") == 0) {
25
+ if (!isNaN(LinkSplit[3])) {
26
+ api.sendMessage('Sai Link, Link Cần Có Định Dạng Như Sau: facebook.com/Lazic.Kanzu',global.Data.event.threadID,global.Data.event.messageID)
27
+ callback(null, String(4));
28
+ }
29
+ else {
30
+ FindUID(Link,api).then(function (data) {
31
+ callback(null, data);
32
+ })
33
+ }
34
+ }
35
+ else {
36
+ var Form = `https://www.facebook.com/${LinkSplit[1]}`;
37
+ FindUID(Form,api).then(function (data) {
38
+ callback(null, data);
39
+ })
40
+ }
41
+ }
42
+ else {
43
+ callback(null, null);
44
+ api.sendMessage('Sai Link, Link Cần Là Link Của Facebook',global.Data.event.threadID,global.Data.event.messageID)
45
+ }
46
+ }
47
+ catch (e) {
48
+ return callback(null, e);
49
+ }
50
+ return returnPromise;
51
+ };
52
+ };