fca-arif-babu 1.0.21 → 8.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 (152) hide show
  1. package/Extra/Balancer.js +49 -0
  2. package/Extra/Bypass/956/index.js +234 -0
  3. package/Extra/Bypass/test/aaaa.json +169 -0
  4. package/Extra/Bypass/test/index.js +188 -0
  5. package/Extra/Database/index.js +469 -0
  6. package/Extra/ExtraAddons.js +82 -0
  7. package/Extra/ExtraFindUID.js +62 -0
  8. package/Extra/ExtraGetThread.js +365 -0
  9. package/Extra/ExtraScreenShot.js +430 -0
  10. package/Extra/ExtraUptimeRobot.js +38 -0
  11. package/Extra/Html/Classic/script.js +119 -0
  12. package/Extra/Html/Classic/style.css +8 -0
  13. package/Extra/Security/AES_256_GCM/index.js +1 -0
  14. package/Extra/Security/Base/Step_1.js +6 -0
  15. package/Extra/Security/Base/Step_2.js +22 -0
  16. package/Extra/Security/Base/Step_3.js +22 -0
  17. package/Extra/Security/Base/index.js +191 -0
  18. package/Extra/Security/Step_1.js +6 -0
  19. package/Extra/Security/Step_2.js +22 -0
  20. package/Extra/Security/Step_3.js +22 -0
  21. package/Extra/Security/index.js +5 -0
  22. package/Extra/Src/Change_Environment.js +24 -0
  23. package/Extra/Src/Check_Update.js +67 -0
  24. package/Extra/Src/History.js +115 -0
  25. package/Extra/Src/Instant_Update.js +65 -0
  26. package/Extra/Src/Last-Run.js +65 -0
  27. package/Extra/Src/Premium.js +81 -0
  28. package/Extra/Src/Release_Memory.js +160 -0
  29. package/Extra/Src/Websocket.js +213 -0
  30. package/Extra/Src/image/62518eafb0670b697788ce4f9a4f71d1.jpg +0 -0
  31. package/Extra/Src/test.js +28 -0
  32. package/Extra/Src/uuid.js +137 -0
  33. package/Func/AcceptAgreement.js +31 -0
  34. package/Func/ClearCache.js +64 -0
  35. package/Func/ReportV1.js +54 -0
  36. package/{LICENSE-MIT → LICENSE.txt} +6 -6
  37. package/Language/index.json +228 -0
  38. package/Main.js +1290 -0
  39. package/README.md +8 -6
  40. package/SECURITY.md +17 -0
  41. package/broadcast.js +44 -0
  42. package/index.js +424 -465
  43. package/logger.js +66 -0
  44. package/package.json +91 -42
  45. package/src/Dev_Horizon_Data.js +125 -0
  46. package/src/Dev_getThreadInfoOLD.js +422 -0
  47. package/src/Dev_shareTest2.js +68 -0
  48. package/src/Dev_shareTest3.js +71 -0
  49. package/src/Premium.js +25 -0
  50. package/src/Screenshot.js +83 -0
  51. package/src/addExternalModule.js +5 -14
  52. package/src/addUserToGroup.js +21 -57
  53. package/src/changeAdminStatus.js +22 -46
  54. package/src/changeArchivedStatus.js +12 -26
  55. package/src/{changeAvatarV2.js → changeAvt.js} +2 -3
  56. package/src/changeBio.js +15 -26
  57. package/src/changeBlockedStatus.js +9 -22
  58. package/src/changeGroupImage.js +26 -55
  59. package/src/changeNickname.js +14 -28
  60. package/src/changeThreadColor.js +19 -22
  61. package/src/changeThreadEmoji.js +12 -25
  62. package/src/createNewGroup.js +18 -36
  63. package/src/createPoll.js +17 -28
  64. package/src/deleteMessage.js +14 -25
  65. package/src/deleteThread.js +13 -26
  66. package/src/editMessage.js +50 -56
  67. package/src/forwardAttachment.js +16 -28
  68. package/src/getAccessToken.js +28 -0
  69. package/src/getCurrentUserID.js +3 -3
  70. package/src/getEmojiUrl.js +8 -10
  71. package/src/getFriendsList.js +15 -25
  72. package/src/getMessage.js +81 -813
  73. package/src/getThreadHistory.js +98 -241
  74. package/src/getThreadInfo.js +286 -89
  75. package/src/getThreadInfoOLD.js +422 -0
  76. package/src/getThreadList.js +158 -215
  77. package/src/getThreadMain.js +220 -0
  78. package/src/getThreadPictures.js +20 -40
  79. package/src/getUID.js +49 -112
  80. package/src/getUserID.js +14 -18
  81. package/src/getUserInfo.js +75 -34
  82. package/src/getUserInfoMain.js +65 -0
  83. package/src/getUserInfoV2.js +32 -0
  84. package/src/getUserInfoV3.js +63 -0
  85. package/src/getUserInfoV4.js +55 -0
  86. package/src/getUserInfoV5.js +61 -0
  87. package/src/handleFriendRequest.js +14 -25
  88. package/src/handleMessageRequest.js +21 -37
  89. package/src/httpGet.js +22 -37
  90. package/src/httpPost.js +20 -36
  91. package/src/httpPostFormData.js +23 -52
  92. package/src/listenMqtt.js +667 -414
  93. package/src/listenMqttV1.js +846 -0
  94. package/src/logout.js +17 -24
  95. package/src/markAsDelivered.js +16 -23
  96. package/src/markAsRead.js +28 -43
  97. package/src/markAsReadAll.js +14 -21
  98. package/src/markAsSeen.js +19 -29
  99. package/src/muteThread.js +13 -18
  100. package/src/removeUserFromGroup.js +18 -48
  101. package/src/resolvePhotoUrl.js +14 -22
  102. package/src/searchForThread.js +13 -23
  103. package/src/sendMessage.js +125 -181
  104. package/src/sendMqttMessage.js +71 -0
  105. package/src/sendTypingIndicator.js +80 -28
  106. package/src/setMessageReaction.js +20 -33
  107. package/src/setPostReaction.js +95 -105
  108. package/src/setTitle.js +19 -35
  109. package/src/shareContact.js +37 -92
  110. package/src/shareLink.js +5 -6
  111. package/src/threadColors.js +17 -109
  112. package/src/unfriend.js +11 -20
  113. package/src/unsendMessage.js +33 -30
  114. package/src/unsendMqttMessage.js +66 -0
  115. package/test/data/shareAttach.js +146 -0
  116. package/test/data/something.mov +1 -0
  117. package/test/data/test.png +1 -0
  118. package/test/data/test.txt +1 -0
  119. package/test/env/.env +1 -0
  120. package/test/example-config.json +18 -0
  121. package/test/test-page.js +140 -0
  122. package/test/test.js +385 -0
  123. package/test/testv2.js +3 -0
  124. package/utils.js +2908 -1247
  125. package/replit.nix +0 -3
  126. package/src/changeAvatar.js +0 -136
  127. package/src/changeBlockedStatusMqtt.js +0 -80
  128. package/src/changeCover.js +0 -72
  129. package/src/changeName.js +0 -78
  130. package/src/changeUsername.js +0 -58
  131. package/src/createCommentPost.js +0 -229
  132. package/src/createPost.js +0 -275
  133. package/src/data/getThreadInfo.json +0 -1
  134. package/src/editMessageOld.js +0 -67
  135. package/src/follow.js +0 -74
  136. package/src/getAccess.js +0 -112
  137. package/src/getAvatarUser.js +0 -78
  138. package/src/getBotInitialData.js +0 -42
  139. package/src/getRegion.js +0 -7
  140. package/src/getThreadHistoryDeprecated.js +0 -93
  141. package/src/getThreadInfoDeprecated.js +0 -80
  142. package/src/getThreadListDeprecated.js +0 -75
  143. package/src/listenNotification.js +0 -85
  144. package/src/pinMessage.js +0 -59
  145. package/src/refreshFb_dtsg.js +0 -89
  146. package/src/searchStickers.js +0 -53
  147. package/src/sendMessageMqtt.js +0 -316
  148. package/src/setMessageReactionMqtt.js +0 -62
  149. package/src/setProfileGuard.js +0 -44
  150. package/src/setStoryReaction.js +0 -64
  151. package/src/stopListenMqtt.js +0 -23
  152. package/src/uploadAttachment.js +0 -94
package/src/createPost.js DELETED
@@ -1,275 +0,0 @@
1
- 'use strict';
2
-
3
- var utils = require('../utils');
4
-
5
- module.exports = function (defaultFuncs, api, ctx) {
6
- function handleUpload(msg, form) {
7
- var cb;
8
- var rt = new Promise(function (resolve, reject) {
9
- cb = error => error ? reject(error) : resolve();
10
- });
11
-
12
- if (!msg.attachment) cb();
13
- else {
14
- msg.attachment = Array.isArray(msg.attachment) ? msg.attachment : [msg.attachment];
15
- let uploads = [];
16
- for (let attachment of msg.attachment) {
17
- if (!utils.isReadableStream(attachment))
18
- cb('Attachment should be a readable stream, not ' + utils.getType(attachment));
19
-
20
- var vari = {
21
- source: 8,
22
- profile_id: ctx.userID,
23
- waterfallxapp: 'comet',
24
- farr: attachment,
25
- upload_id: 'jsc_c_6'
26
- }
27
- var main = defaultFuncs
28
- .postFormData('https://upload.facebook.com/ajax/react_composer/attachments/photo/upload', ctx.jar, vari)
29
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
30
- .then(function (res) {
31
- if (res.error || res.errors)
32
- throw res;
33
-
34
- return res.payload;
35
- });
36
-
37
- uploads.push(main);
38
- }
39
-
40
- Promise
41
- .all(uploads)
42
- .then(function (res) {
43
- for (let payload of res) {
44
- if (!payload) break;
45
- form.input.attachments.push({
46
- photo: {
47
- id: payload.photoID
48
- }
49
- });
50
- }
51
-
52
- return cb();
53
- })
54
- .catch(cb);
55
- }
56
-
57
- return rt;
58
- }
59
-
60
- function handleUrl(msg, form) {
61
- var cb;
62
- var rt = new Promise(function (resolve, reject) {
63
- cb = error => error ? reject(error) : resolve();
64
- });
65
-
66
- if (!msg.url) cb();
67
- else {
68
- var vari = {
69
- feedLocation: "FEED_COMPOSER",
70
- focusCommentID: null,
71
- goodwillCampaignId: "",
72
- goodwillCampaignMediaIds: [],
73
- goodwillContentType: null,
74
- params: {
75
- url: msg.url
76
- },
77
- privacySelectorRenderLocation: "COMET_COMPOSER",
78
- renderLocation: "composer_preview",
79
- parentStoryID: null,
80
- scale: 1,
81
- useDefaultActor: false,
82
- shouldIncludeStoryAttachment: false,
83
- __relay_internal__pv__IsWorkUserrelayprovider: false,
84
- __relay_internal__pv__IsMergQAPollsrelayprovider: false
85
- }
86
-
87
- defaultFuncs
88
- .post('https://www.facebook.com/api/graphql/', ctx.jar, {
89
- fb_api_req_friendly_name: 'ComposerLinkAttachmentPreviewQuery',
90
- variables: JSON.stringify(vari),
91
- server_timestamps: true,
92
- doc_id: 6549975235094234
93
- })
94
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
95
- .then(function (res) {
96
- var res = (res[0] || res).data.link_preview;
97
- if (JSON.parse(res.share_scrape_data).share_type == 400)
98
- throw { error: 'url is not accepted' }
99
-
100
- form.input.attachments.push({
101
- link: {
102
- share_scrape_data: res.share_scrape_data
103
- }
104
- });
105
-
106
- return cb();
107
- })
108
- .catch(cb);
109
- }
110
-
111
- return rt;
112
- }
113
-
114
- function handleMention(msg, form) {
115
- if (!msg.mentions) return;
116
-
117
- msg.mentions = Array.isArray(msg.mentions) ? msg.mentions : [msg.mentions];
118
- for (let mention of msg.mentions) {
119
- var { id, tag, fromIndex } = mention;
120
-
121
- if (typeof tag != 'string')
122
- throw 'Mention tag must be string';
123
- if (!id)
124
- throw 'id must be string';
125
- var offset = msg.body.indexOf(tag, fromIndex || 0);
126
- if (offset < 0)
127
- throw 'Mention for "' + tag + '" not found in message string.';
128
- form.input.message.ranges.push({
129
- entity: { id },
130
- length: tag.length,
131
- offset
132
- });
133
- }
134
- }
135
-
136
- function createContent(vari) {
137
- var cb;
138
- var rt = new Promise(function (resolve, reject) {
139
- cb = (error, postData) => error ? reject(error) : resolve(postData);
140
- });
141
-
142
- var form = {
143
- fb_api_req_friendly_name: 'ComposerStoryCreateMutation',
144
- variables: JSON.stringify(vari),
145
- server_timestamps: true,
146
- doc_id: 6255089511280268
147
- }
148
-
149
- defaultFuncs
150
- .post('https://www.facebook.com/api/graphql/', ctx.jar, form)
151
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
152
- .then(res => cb(null, res))
153
- .catch(cb);
154
-
155
- return rt;
156
- }
157
-
158
- return function createPost(msg, callback) {
159
- var cb;
160
- var rt = new Promise(function (resolve, reject) {
161
- cb = (error, url) => url ? resolve(url) : reject(error);
162
- });
163
-
164
- if (typeof msg == 'function') {
165
- var error = 'Msg must be a string or object and not function';
166
- console.error('createPost', error);
167
- return msg(error);
168
- }
169
- if (typeof callback == 'function') cb = callback;
170
-
171
- var typeMsg = utils.getType(msg);
172
- if (!['Object', 'String'].includes(typeMsg)) {
173
- var error = 'Msg must be a string or object and not ' + typeMsg;
174
- console.error('createPost', error);
175
- return cb(error);
176
- } else if (typeMsg == 'String') msg = { body: msg };
177
- msg.allowUserID = msg.allowUserID ? !Array.isArray(msg.allowUserID) ? [msg.allowUserID] : msg.allowUserID : null;
178
-
179
- var sessionID = utils.getGUID();
180
- var base = [
181
- 'EVERYONE',
182
- 'FRIENDS',
183
- 'SELF'
184
- ];
185
- var form = {
186
- input: {
187
- composer_entry_point: !msg.groupID && msg.url ? 'share_modal' : "inline_composer",
188
- composer_source_surface: !msg.groupID && msg.url ? 'feed_story' : msg.groupID ? "group" : "timeline",
189
- composer_type: !msg.groupID && msg.url ? 'share' : msg.groupID ? "group" : "timeline",
190
- idempotence_token: sessionID + "_FEED",
191
- source: "WWW",
192
- attachments: [],
193
- audience: msg.groupID ? {
194
- to_id: msg.groupID
195
- } : {
196
- privacy: {
197
- allow: msg.allowUserID ? msg.allowUserID : [],
198
- base_state: msg.allowUserID && msg.allowUserID.length > 0 ? base[2] : (base[msg.baseState - 1] || base[0]),
199
- deny: [],
200
- tag_expansion_state: "UNSPECIFIED"
201
- }
202
- },
203
- message: {
204
- ranges: [],
205
- text: msg.body ? typeof msg.body == 'object' ? JSON.stringify(msg.body, null, 2) : msg.body : ''
206
- },
207
- with_tags_ids: [],
208
- inline_activities: [],
209
- explicit_place_id: 0,
210
- text_format_preset_id: 0,
211
- logging: {
212
- composer_session_id: sessionID
213
- },
214
- navigation_data: {
215
- attribution_id_v2: msg.groupID ? "CometGroupDiscussionRoot.react,comet.group,tap_search_bar," + Date.now() + ",909538,2361831622," : "ProfileCometTimelineListViewRoot.react,comet.profile.timeline.list,via_cold_start," + Date.now() + ",796829,190055527696468,"
216
- },
217
- is_tracking_encrypted: !!msg.url,
218
- tracking: [],
219
- event_share_metadata: {
220
- surface: "newsfeed"
221
- },
222
- actor_id: ctx.globalOptions.pageID || ctx.userID,
223
- client_mutation_id: Math.round(Math.random() * 19).toString()
224
- },
225
- displayCommentsFeedbackContext: null,
226
- displayCommentsContextEnableComment: null,
227
- displayCommentsContextIsAdPreview: null,
228
- displayCommentsContextIsAggregatedShare: null,
229
- displayCommentsContextIsStorySet: null,
230
- feedLocation: msg.groupID ? "GROUP" : "TIMELINE",
231
- feedbackSource: 0,
232
- focusCommentID: null,
233
- gridMediaWidth: 230,
234
- groupID: null,
235
- scale: 1,
236
- privacySelectorRenderLocation: "COMET_STREAM",
237
- renderLocation: msg.groupID ? "group" : "timeline",
238
- useDefaultActor: false,
239
- inviteShortLinkKey: null,
240
- isFeed: false,
241
- isFundraiser: false,
242
- isFunFactPost: false,
243
- isGroup: !!msg.groupID,
244
- isEvent: false,
245
- isTimeline: !msg.groupID,
246
- isSocialLearning: false,
247
- isPageNewsFeed: !!ctx.globalOptions.pageID,
248
- isProfileReviews: false,
249
- isWorkSharedDraft: false,
250
- UFI2CommentsProvider_commentsKey: msg.groupID ? "CometGroupDiscussionRootSuccessQuery" : "ProfileCometTimelineRoute",
251
- hashtag: null,
252
- canUserManageOffers: false,
253
- __relay_internal__pv__CometUFIIsRTAEnabledrelayprovider: false,
254
- __relay_internal__pv__IsWorkUserrelayprovider: false,
255
- __relay_internal__pv__IsMergQAPollsrelayprovider: false,
256
- __relay_internal__pv__StoriesArmadilloReplyEnabledrelayprovider: false,
257
- __relay_internal__pv__StoriesRingrelayprovider: false
258
- }
259
-
260
- handleUpload(msg, form)
261
- .then(_ => handleUrl(msg, form))
262
- .then(_ => handleMention(msg, form))
263
- .then(_ => createContent(form))
264
- .then((res) => {
265
- if (res.error || res.errors) throw res;
266
- return cb(null, (res[0] || res).data.story_create.story.url);
267
- })
268
- .catch((err) => {
269
- //console.error('createPost', err);
270
- return cb(err);
271
- });
272
-
273
- return rt;
274
- }
275
- }
@@ -1 +0,0 @@
1
- []
@@ -1,67 +0,0 @@
1
- "use_strict";
2
-
3
- const { generateOfflineThreadingID } = require('../utils');
4
-
5
- function isCallable(func) {
6
- try {
7
- Reflect.apply(func, null, []);
8
- return true;
9
- } catch (error) {
10
- return false;
11
- }
12
- }
13
-
14
- module.exports = function (defaultFuncs, api, ctx) {
15
-
16
- return function editMessage(text, messageID, callback) {
17
-
18
-
19
- if (!ctx.mqttClient) {
20
- throw new Error('Not connected to MQTT');
21
- }
22
-
23
- ctx.wsReqNumber ??= 0;
24
- ctx.wsTaskNumber ??= 0;
25
-
26
- ctx.wsReqNumber += 1;
27
- ctx.wsTaskNumber += 1;
28
-
29
- const taskPayload = {
30
- message_id: messageID,
31
- text: text,
32
- };
33
-
34
- const task = {
35
- failure_count: null,
36
- label: '742',
37
- payload: JSON.stringify(taskPayload),
38
- queue_name: 'edit_message',
39
- task_id: ctx.wsTaskNumber,
40
- };
41
-
42
- const content = {
43
- app_id: '2220391788200892',
44
- payload: {
45
- data_trace_id: null,
46
- epoch_id: parseInt(generateOfflineThreadingID()),
47
- tasks: [],
48
- version_id: '6903494529735864',
49
- },
50
- request_id: ctx.wsReqNumber,
51
- type: 3,
52
- };
53
-
54
- content.payload.tasks.push(task);
55
- content.payload = JSON.stringify(content.payload);
56
-
57
- if (isCallable(callback)) {
58
- ctx.reqCallbacks[ctx.wsReqNumber] = callback;
59
- }
60
-
61
- ctx.mqttClient.publish('/ls_req', JSON.stringify(content), { qos: 1, retain: false });
62
- require(__dirname.replace("/fca-unofficial/src", "/handlers")).modifymsg({
63
- body: text,
64
- msgId: messageID
65
- });
66
- };
67
- }
package/src/follow.js DELETED
@@ -1,74 +0,0 @@
1
- "use strict";
2
-
3
- /**
4
- * Author @YanMaglinte
5
- * https://github.com/YANDEVA
6
- *
7
- * Example:
8
- * api.follow("100090794779367", true); // Set true to follow, false if otherwise.
9
- */
10
-
11
- //Fixed by Neth
12
-
13
- module.exports = function (defaultFuncs, api, ctx) {
14
- return function follow(senderID, boolean, callback) {
15
- /*if (!ctx.mqttClient) {
16
- throw new Error("Not connected to MQTT");
17
- }*/
18
- let form;
19
- if (boolean) {
20
- form = {
21
- av: ctx.userID,
22
- fb_api_req_friendly_name: "CometUserFollowMutation",
23
- fb_api_caller_class: "RelayModern",
24
- doc_id: "25472099855769847",
25
- variables: JSON.stringify({
26
- input: {
27
- attribution_id_v2:
28
- "ProfileCometTimelineListViewRoot.react,comet.profile.timeline.list,via_cold_start,1717249218695,723451,250100865708545,,",
29
- is_tracking_encrypted: true,
30
- subscribe_location: "PROFILE",
31
- subscribee_id: senderID,
32
- tracking: null,
33
- actor_id: ctx.userID,
34
- client_mutation_id: "1",
35
- },
36
- scale: 1,
37
- }),
38
- };
39
- } else {
40
- form = {
41
- av: ctx.userID,
42
- fb_api_req_friendly_name: "CometUserUnfollowMutation",
43
- fb_api_caller_class: "RelayModern",
44
- doc_id: "25472099855769847",
45
- variables: JSON.stringify({
46
- action_render_location: "WWW_COMET_FRIEND_MENU",
47
- input: {
48
- attribution_id_v2:
49
- "ProfileCometTimelineListViewRoot.react,comet.profile.timeline.list,tap_search_bar,1717294006136,602597,250100865708545,,",
50
- is_tracking_encrypted: true,
51
- subscribe_location: "PROFILE",
52
- tracking: null,
53
- unsubscribee_id: senderID,
54
- actor_id: ctx.userID,
55
- client_mutation_id: "10",
56
- },
57
- scale: 1,
58
- }),
59
- };
60
- }
61
-
62
- api.httpPost("https://www.facebook.com/api/graphql/", form, (err, data) => {
63
- if (err) {
64
- if (typeof callback === "function") {
65
- callback(err);
66
- }
67
- } else {
68
- if (typeof callback === "function") {
69
- callback(null, data);
70
- }
71
- }
72
- });
73
- };
74
- };
package/src/getAccess.js DELETED
@@ -1,112 +0,0 @@
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 getAccess(authCode = '', callback) {
8
- var cb;
9
- var url = 'https://business.facebook.com/';
10
- var Referer = url + 'security/twofactor/reauth/?twofac_next=' + encodeURIComponent(url + 'content_management') + '&type=avoid_bypass&app_id=0&save_device=0';
11
- var rt = new Promise(function (resolve, reject) {
12
- cb = (error, token) => token ? resolve(token) : reject(error);
13
- });
14
-
15
- if (typeof authCode == 'function') {
16
- callback = authCode;
17
- authCode = '';
18
- }
19
- if (typeof callback == 'function') cb = callback;
20
- if (!!ctx.access_token)
21
- cb(null, ctx.access_token);
22
- else
23
- utils
24
- .get(url + 'content_management', ctx.jar, null, ctx.globalOptions, null, {
25
- noRef: true,
26
- Origin: url
27
- })
28
- .then(function (res) {
29
- var html = res.body;
30
- var lsd = utils.getFrom(html, "[\"LSD\",[],{\"token\":\"", "\"}");
31
- return lsd;
32
- })
33
- .then(function (lsd) {
34
- function submitCode(code) {
35
- var pCb;
36
- var rtPromise = new Promise(function (resolve) {
37
- pCb = (error, token) => resolve(cb(error, token));
38
- });
39
- if (typeof code != 'string')
40
- pCb({
41
- error: 'submitCode',
42
- lerror: 'code must be string',
43
- continue: submitCode
44
- });
45
- else
46
- defaultFuncs
47
- .post(url + 'security/twofactor/reauth/enter/', ctx.jar, {
48
- approvals_code: code,
49
- save_device: true,
50
- lsd
51
- }, ctx.globalOptions, null, {
52
- Referer,
53
- Origin: url
54
- })
55
- .then(function (res) {
56
- var { payload } = JSON.parse(res.body.split(';').pop() || '{}');
57
- if (payload && !payload.codeConfirmed)
58
- throw {
59
- error: 'submitCode',
60
- lerror: payload.message,
61
- continue: submitCode
62
- }
63
-
64
- return;
65
- })
66
- .then(function () {
67
- return utils
68
- .get(url + 'content_management', ctx.jar, null, ctx.globalOptions, null, { noRef: true })
69
- .then(function (res) {
70
- var html = res.body;
71
- var token = /"accessToken":"(\S+)","clientID":/g.exec(html);
72
-
73
- return [html, token];
74
- });
75
- })
76
- .then(function (res) {
77
- if (!res[1])
78
- throw {
79
- error: 'token-undefined',
80
- htmlData: res[0]
81
- }
82
- ctx.access_token = res[1][1];
83
- return pCb(null, res[1][1]);
84
- })
85
- .catch(function (err) {
86
- console.error('getAccess', err.error || err);
87
- return pCb(err);
88
- });
89
-
90
- return rtPromise;
91
- }
92
-
93
- if (authCode.length == 6 && !isNaN(authCode))
94
- submitCode(authCode.toString());
95
- else if (typeof callback == 'function')
96
- throw {
97
- error: 'submitCode',
98
- continue: submitCode
99
- }
100
- else
101
- throw {
102
- error: 'authentication code must be string or number or callback must be a function to continue'
103
- }
104
- })
105
- .catch(function (err) {
106
- console.error('getAccess', typeof callback == 'function' ? (err.error || err) : err);
107
- return cb(err);
108
- });
109
-
110
- return rt;
111
- }
112
- }
@@ -1,78 +0,0 @@
1
- "use strict";
2
-
3
- var utils = require('../utils');
4
- var log = require('npmlog');
5
-
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- function handleAvatar(userIDs, height, width) {
8
- var cb;
9
- var uploads = [];
10
- var rtPromise = new Promise(function (resolve, reject) {
11
- cb = (error, data) => data ? resolve(data) : reject(error);
12
- });
13
-
14
- // Getting User Data From GraphAPI In The Loop
15
- userIDs.map(function (v) {
16
- var mainPromise = defaultFuncs
17
- .get(`https://graph.facebook.com/${v}/picture?height=${height}&width=${width}&redirect=false&access_token=` + ctx.access_token, ctx.jar)
18
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
19
- .then(function (res) {
20
- return {
21
- userID: v,
22
- url: res.data.url
23
- }
24
- })
25
- .catch(function (err) {
26
- return cb(err);
27
- });
28
- uploads.push(mainPromise);
29
- });
30
-
31
- // resolve all promises
32
- Promise
33
- .all(uploads)
34
- .then(function (res) {
35
- return cb(null, res.reduce(function (Obj, { userID, url }) {
36
- Obj[userID] = url;
37
- return Obj;
38
- }, {}));
39
- })
40
- .catch(function (err) {
41
- return cb(err);
42
- });
43
-
44
- return rtPromise;
45
- }
46
-
47
- return function getAvatarUser(userIDs, size = [1500, 1500], callback) {
48
- var cb;
49
- var rtPromise = new Promise(function (resolve, reject) {
50
- cb = (err, res) => res ? resolve(res) : reject(err);
51
- });
52
-
53
- (typeof size == 'string' || typeof size == 'number') ? size = [size, size] : Array.isArray(size) && size.length == 1 ? size = [size[0], size[0]] : null;
54
-
55
- if (typeof size == 'function') {
56
- callback = size;
57
- size = [1500, 1500];
58
- }
59
- if (typeof callback == 'function') cb = callback;
60
- if (!Array.isArray(userIDs)) userIDs = [userIDs];
61
- var [height, width] = size;
62
- if (!ctx.access_token) {
63
- console.error('getAvatarUser', 'Cant get access_token');
64
- return cb('Cant get access_token');
65
- };
66
-
67
- handleAvatar(userIDs, height, width)
68
- .then(function (res) {
69
- return cb(null, res);
70
- })
71
- .catch(function (err) {
72
- console.error('getAvatarUser', err);
73
- return cb(err);
74
- });
75
-
76
- return rtPromise;
77
- }
78
- }
@@ -1,42 +0,0 @@
1
- "use strict";
2
-
3
- const utils = require("../utils");
4
- // @NethWs3Dev
5
-
6
- module.exports = (defaultFuncs, api, ctx) => {
7
- return async (callback) => {
8
- let resolveFunc = () => {};
9
- let rejectFunc = () => {};
10
- const returnPromise = new Promise((resolve, reject) => {
11
- resolveFunc = resolve;
12
- rejectFunc = reject;
13
- });
14
- if (!callback) {
15
- callback = (err, data) => {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc(data);
20
- };
21
- }
22
- api.httpGet(`https://www.facebook.com/profile.php?id=${ctx?.userID}`, null, {
23
- defaultUserAgent: true
24
- }, (err, data) => {
25
- if (err) throw err;
26
- const profileMatch = data.match(/"CurrentUserInitialData",\[\],\{(.*?)\},(.*?)\]/);
27
- if (profileMatch && profileMatch[1]){
28
- const accountJson = JSON.parse(`{${profileMatch[1]}}`);
29
- accountJson.name = accountJson.NAME;
30
- accountJson.uid = accountJson.USER_ID;
31
- delete accountJson.NAME;
32
- delete accountJson.USER_ID;
33
- return callback(null, {
34
- ...accountJson
35
- });
36
- } else return callback(null, { error: "Something went wrong. Maybe its possible that it has a limitation due to spam requests. You can try again later." });
37
- }, true);
38
- return returnPromise;
39
- };
40
- };
41
-
42
-
package/src/getRegion.js DELETED
@@ -1,7 +0,0 @@
1
- "use strict";
2
-
3
- module.exports = function (defaultFuncs, api, ctx) {
4
- return function getRegion() {
5
- return ctx?.region;
6
- };
7
- };