rapido-fca 0.0.2 → 0.0.4

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 (81) hide show
  1. package/index.js +419 -415
  2. package/package.json +16 -15
  3. package/src/addExternalModule.js +19 -23
  4. package/src/addUserToGroup.js +99 -97
  5. package/src/changeAdminStatus.js +86 -62
  6. package/src/changeArchivedStatus.js +49 -49
  7. package/src/changeAvatar.js +118 -108
  8. package/src/changeAvatarV2.js +86 -0
  9. package/src/changeAvt.js +85 -0
  10. package/src/changeBio.js +63 -64
  11. package/src/changeBlockedStatus.js +40 -38
  12. package/src/changeBlockedStatusMqtt.js +80 -0
  13. package/src/changeCover.js +72 -0
  14. package/src/changeGroupImage.js +129 -126
  15. package/src/changeName.js +79 -0
  16. package/src/changeNickname.js +49 -49
  17. package/src/changeThreadColor.js +53 -53
  18. package/src/changeThreadEmoji.js +45 -45
  19. package/src/changeUsername.js +59 -0
  20. package/src/createCommentPost.js +230 -0
  21. package/src/createNewGroup.js +74 -72
  22. package/src/createPoll.js +59 -59
  23. package/src/createPost.js +276 -0
  24. package/src/deleteMessage.js +50 -50
  25. package/src/deleteThread.js +50 -50
  26. package/src/editMessage.js +51 -49
  27. package/src/editMessageOld.js +67 -0
  28. package/src/follow.js +74 -0
  29. package/src/forwardAttachment.js +54 -54
  30. package/src/getAccess.js +112 -0
  31. package/src/getAvatarUser.js +78 -0
  32. package/src/getCurrentUserID.js +3 -3
  33. package/src/getEmojiUrl.js +17 -17
  34. package/src/getFriendsList.js +67 -67
  35. package/src/getMessage.js +806 -767
  36. package/src/getRegion.js +7 -0
  37. package/src/getThreadHistory.js +656 -642
  38. package/src/getThreadHistoryDeprecated.js +71 -0
  39. package/src/getThreadInfo.js +1 -1
  40. package/src/getThreadInfoDeprecated.js +56 -0
  41. package/src/getThreadList.js +199 -227
  42. package/src/getThreadListDeprecated.js +46 -0
  43. package/src/getThreadPictures.js +51 -71
  44. package/src/getUID.js +119 -0
  45. package/src/getUserID.js +53 -58
  46. package/src/getUserInfo.js +52 -60
  47. package/src/handleFriendRequest.js +41 -65
  48. package/src/handleMessageRequest.js +42 -60
  49. package/src/httpGet.js +49 -57
  50. package/src/httpPost.js +48 -57
  51. package/src/listenMqtt.js +827 -895
  52. package/src/logout.js +61 -61
  53. package/src/markAsDelivered.js +42 -53
  54. package/src/markAsRead.js +59 -69
  55. package/src/markAsReadAll.js +32 -42
  56. package/src/markAsSeen.js +43 -54
  57. package/src/muteThread.js +40 -47
  58. package/src/refreshFb_dtsg.js +77 -69
  59. package/src/removeUserFromGroup.js +67 -67
  60. package/src/resolvePhotoUrl.js +34 -34
  61. package/src/searchForThread.js +43 -43
  62. package/src/searchStickers.js +53 -0
  63. package/src/sendMessage.js +80 -228
  64. package/src/sendMessageMqtt.js +322 -0
  65. package/src/sendTypingIndicator.js +86 -88
  66. package/src/sendTypingIndicatorV2.js +28 -0
  67. package/src/setMessageReaction.js +110 -109
  68. package/src/setMessageReactionMqtt.js +62 -0
  69. package/src/setPostReaction.js +90 -87
  70. package/src/setStoryReaction.js +64 -0
  71. package/src/setTitle.js +76 -72
  72. package/src/shareContact.js +110 -0
  73. package/src/shareLink.js +59 -0
  74. package/src/stopListenMqtt.js +23 -0
  75. package/src/threadColors.js +121 -121
  76. package/src/unfriend.js +43 -43
  77. package/src/unsendMessage.js +34 -38
  78. package/src/uploadAttachment.js +79 -81
  79. package/utils.js +2732 -1401
  80. package/LICENSE +0 -21
  81. package/src/httpPostFormData.js +0 -63
@@ -0,0 +1,80 @@
1
+
2
+ 'use strict';
3
+
4
+ const { generateOfflineThreadingID, getCurrentTimestamp, getGUID } = require('../utils.js');
5
+
6
+ function isCallable(func) {
7
+ try {
8
+ Reflect.apply(func, null, []);
9
+ return true;
10
+ } catch (error) {
11
+ return false;
12
+ }
13
+ }
14
+
15
+ module.exports = function (defaultFuncs, api, ctx) {
16
+ return function changeBlockedStatusMqtt(userID, status, type, callback) {
17
+ if (!ctx.mqttClient) {
18
+ throw new Error('Not connected to MQTT');
19
+ }
20
+
21
+ ctx.wsReqNumber += 1;
22
+ ctx.wsTaskNumber += 1;
23
+
24
+ const label = '334';
25
+ let userBlockAction = 0;
26
+
27
+ switch (type) {
28
+ case 'messenger':
29
+ if (status) {
30
+ userBlockAction = 1; // Block
31
+ } else {
32
+ userBlockAction = 0; // Unblock
33
+ }
34
+ break;
35
+ case 'facebook':
36
+ if (status) {
37
+ userBlockAction = 3; // Block
38
+ } else {
39
+ userBlockAction = 2; // Unblock
40
+ }
41
+ break;
42
+ default:
43
+ throw new Error('Invalid type');
44
+ }
45
+
46
+ const taskPayload = {
47
+ blockee_id: userID,
48
+ request_id: getGUID(),
49
+ user_block_action: userBlockAction,
50
+ };
51
+
52
+ const payload = JSON.stringify(taskPayload);
53
+ const version = '25393437286970779';
54
+
55
+ const task = {
56
+ failure_count: null,
57
+ label: label,
58
+ payload: payload,
59
+ queue_name: 'native_sync_block',
60
+ task_id: ctx.wsTaskNumber,
61
+ };
62
+
63
+ const content = {
64
+ app_id: '2220391788200892',
65
+ payload: JSON.stringify({
66
+ tasks: [task],
67
+ epoch_id: parseInt(generateOfflineThreadingID()),
68
+ version_id: version,
69
+ }),
70
+ request_id: ctx.wsReqNumber,
71
+ type: 3,
72
+ };
73
+
74
+ if (isCallable(callback)) {
75
+ ctx.reqCallbacks[ctx.wsReqNumber] = callback;
76
+ }
77
+
78
+ ctx.mqttClient.publish('/ls_req', JSON.stringify(content), { qos: 1, retain: false });
79
+ };
80
+ };
@@ -0,0 +1,72 @@
1
+ 'use strict';
2
+
3
+ var utils = require('../utils');
4
+
5
+ module.exports = function (defaultFuncs, api, ctx) {
6
+ return function changeCover(image, callback) {
7
+ var cb;
8
+ var rt = new Promise(function (resolve, reject) {
9
+ cb = (error, url) => error ? reject(error) : resolve(url);
10
+ });
11
+
12
+ if (typeof image == 'function') {
13
+ callback = image;
14
+ image = null;
15
+ }
16
+ if (typeof callback == 'function') cb = callback;
17
+ if (!utils.isReadableStream(image)) {
18
+ var error = 'image should be a readable stream, not ' + utils.getType(image);
19
+ console.error('changeCover', error);
20
+ cb(error);
21
+ }
22
+ else {
23
+ defaultFuncs
24
+ .postFormData('https://www.facebook.com/profile/picture/upload/', ctx.jar, {
25
+ profile_id: ctx.userID,
26
+ photo_source: 57,
27
+ av: ctx.userID,
28
+ file: image
29
+ })
30
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
31
+ .then(function (res) {
32
+ if (res.error || res.errors || !res.payload)
33
+ throw res;
34
+
35
+ var vari = {
36
+ input: {
37
+ attribution_id_v2: `ProfileCometCollectionRoot.react,comet.profile.collection.photos_by,unexpected,${Date.now()},770083,,;ProfileCometCollectionRoot.react,comet.profile.collection.photos_albums,unexpected,${Date.now()},470774,,;ProfileCometCollectionRoot.react,comet.profile.collection.photos,unexpected,${Date.now()},94740,,;ProfileCometCollectionRoot.react,comet.profile.collection.saved_reels_on_profile,unexpected,${Date.now()},89669,,;ProfileCometCollectionRoot.react,comet.profile.collection.reels_tab,unexpected,${Date.now()},152201,,`,
38
+ cover_photo_id: res.payload.fbid,
39
+ focus: {
40
+ x: 0.5,
41
+ y: 1
42
+ },
43
+ target_user_id: ctx.userID,
44
+ actor_id: ctx.userID,
45
+ client_mutation_id: Math.round(Math.random() * 19).toString()
46
+ },
47
+ scale: 1,
48
+ contextualProfileContext: null
49
+ }
50
+ return defaultFuncs
51
+ .post('https://www.facebook.com/api/graphql', ctx.jar, {
52
+ doc_id: 8247793861913071,
53
+ server_timestamps: true,
54
+ fb_api_req_friendly_name: 'ProfileCometCoverPhotoUpdateMutation',
55
+ variables: JSON.stringify(vari)
56
+ })
57
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs));
58
+ })
59
+ .then(function (res) {
60
+ if (res.errors)
61
+ throw res;
62
+ return cb(null, res.data.user_update_cover_photo.user.cover_photo.photo.url);
63
+ })
64
+ .catch(function (err) {
65
+ console.error('changeCover', err);
66
+ return cb(err);
67
+ });
68
+ }
69
+
70
+ return rt;
71
+ }
72
+ }
@@ -1,132 +1,135 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- const log = require("npmlog");
4
+ // @NethWs3Dev
5
5
 
6
6
  module.exports = function (defaultFuncs, api, ctx) {
7
- function handleUpload(image, callback) {
8
- const uploads = [];
9
-
10
- const form = {
11
- images_only: "true",
12
- "attachment[]": image
13
- };
14
-
15
- uploads.push(
16
- defaultFuncs
17
- .postFormData(
18
- "https://upload.facebook.com/ajax/mercury/upload.php",
19
- ctx.jar,
20
- form,
21
- {}
22
- )
23
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
24
- .then(function (resData) {
25
- if (resData.error) {
26
- throw resData;
27
- }
28
-
29
- return resData.payload.metadata[0];
30
- })
31
- );
32
-
33
- // resolve all promises
34
- Promise
35
- .all(uploads)
36
- .then(function (resData) {
37
- callback(null, resData);
38
- })
39
- .catch(function (err) {
40
- log.error("handleUpload", err);
41
- return callback(err);
42
- });
43
- }
44
-
45
- return function changeGroupImage(image, threadID, callback) {
46
- if (
47
- !callback &&
48
- (utils.getType(threadID) === "Function" ||
49
- utils.getType(threadID) === "AsyncFunction")
50
- ) {
51
- throw { error: "please pass a threadID as a second argument." };
52
- }
53
-
54
- if (!utils.isReadableStream(image)) {
55
- throw { error: "please pass a readable stream as a first argument." };
56
- }
57
-
58
- let resolveFunc = function () { };
59
- let rejectFunc = function () { };
60
- const returnPromise = new Promise(function (resolve, reject) {
61
- resolveFunc = resolve;
62
- rejectFunc = reject;
63
- });
64
-
65
- if (!callback) {
66
- callback = function (err) {
67
- if (err) {
68
- return rejectFunc(err);
69
- }
70
- resolveFunc();
71
- };
72
- }
73
-
74
- const messageAndOTID = utils.generateOfflineThreadingID();
75
- const form = {
76
- client: "mercury",
77
- action_type: "ma-type:log-message",
78
- author: "fbid:" + (ctx.i_userID || ctx.userID),
79
- author_email: "",
80
- ephemeral_ttl_mode: "0",
81
- is_filtered_content: false,
82
- is_filtered_content_account: false,
83
- is_filtered_content_bh: false,
84
- is_filtered_content_invalid_app: false,
85
- is_filtered_content_quasar: false,
86
- is_forward: false,
87
- is_spoof_warning: false,
88
- is_unread: false,
89
- log_message_type: "log:thread-image",
90
- manual_retry_cnt: "0",
91
- message_id: messageAndOTID,
92
- offline_threading_id: messageAndOTID,
93
- source: "source:chat:web",
94
- "source_tags[0]": "source:chat",
95
- status: "0",
96
- thread_fbid: threadID,
97
- thread_id: "",
98
- timestamp: Date.now(),
99
- timestamp_absolute: "Today",
100
- timestamp_relative: utils.generateTimestampRelative(),
101
- timestamp_time_passed: "0"
102
- };
103
-
104
- handleUpload(image, function (err, payload) {
105
- if (err) {
106
- return callback(err);
107
- }
108
-
109
- form["thread_image_id"] = payload[0]["image_id"];
110
- form["thread_id"] = threadID;
111
-
112
- defaultFuncs
113
- .post("https://www.facebook.com/messaging/set_thread_image/", ctx.jar, form)
114
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
115
- .then(function (resData) {
116
- // check for errors here
117
-
118
- if (resData.error) {
119
- throw resData;
120
- }
121
-
122
- return callback();
123
- })
124
- .catch(function (err) {
125
- log.error("changeGroupImage", err);
126
- return callback(err);
127
- });
128
- });
129
-
130
- return returnPromise;
131
- };
7
+ function handleUpload(image, callback) {
8
+ const uploads = [];
9
+
10
+ const form = {
11
+ images_only: "true",
12
+ "attachment[]": image,
13
+ };
14
+
15
+ uploads.push(
16
+ defaultFuncs
17
+ .postFormData(
18
+ "https://upload.facebook.com/ajax/mercury/upload.php",
19
+ ctx.jar,
20
+ form,
21
+ {},
22
+ )
23
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
24
+ .then(function (resData) {
25
+ if (resData.error) {
26
+ throw resData;
27
+ }
28
+
29
+ return resData.payload.metadata[0];
30
+ }),
31
+ );
32
+
33
+ // resolve all promises
34
+ Promise.all(uploads)
35
+ .then(function (resData) {
36
+ callback(null, resData);
37
+ })
38
+ .catch(function (err) {
39
+ console.error("handleUpload", err);
40
+ return callback(err);
41
+ });
42
+ }
43
+
44
+ return function changeGroupImage(image, threadID, callback) {
45
+ if (
46
+ !callback &&
47
+ (utils.getType(threadID) === "Function" ||
48
+ utils.getType(threadID) === "AsyncFunction")
49
+ ) {
50
+ throw { error: "please pass a threadID as a second argument." };
51
+ }
52
+
53
+ if (!utils.isReadableStream(image)) {
54
+ throw { error: "please pass a readable stream as a first argument." };
55
+ }
56
+
57
+ let resolveFunc = function () {};
58
+ let rejectFunc = function () {};
59
+ const returnPromise = new Promise(function (resolve, reject) {
60
+ resolveFunc = resolve;
61
+ rejectFunc = reject;
62
+ });
63
+
64
+ if (!callback) {
65
+ callback = function (err) {
66
+ if (err) {
67
+ return rejectFunc(err);
68
+ }
69
+ resolveFunc();
70
+ };
71
+ }
72
+
73
+ const messageAndOTID = utils.generateOfflineThreadingID();
74
+ const form = {
75
+ client: "mercury",
76
+ action_type: "ma-type:log-message",
77
+ author: "fbid:" + (ctx.userID),
78
+ author_email: "",
79
+ ephemeral_ttl_mode: "0",
80
+ is_filtered_content: false,
81
+ is_filtered_content_account: false,
82
+ is_filtered_content_bh: false,
83
+ is_filtered_content_invalid_app: false,
84
+ is_filtered_content_quasar: false,
85
+ is_forward: false,
86
+ is_spoof_warning: false,
87
+ is_unread: false,
88
+ log_message_type: "log:thread-image",
89
+ manual_retry_cnt: "0",
90
+ message_id: messageAndOTID,
91
+ offline_threading_id: messageAndOTID,
92
+ source: "source:chat:web",
93
+ "source_tags[0]": "source:chat",
94
+ status: "0",
95
+ thread_fbid: threadID,
96
+ thread_id: "",
97
+ timestamp: Date.now(),
98
+ timestamp_absolute: "Today",
99
+ timestamp_relative: utils.generateTimestampRelative(),
100
+ timestamp_time_passed: "0",
101
+ };
102
+
103
+ handleUpload(image, function (err, payload) {
104
+ if (err) {
105
+ return callback(err);
106
+ }
107
+
108
+ form["thread_image_id"] = payload[0]["image_id"];
109
+ form["thread_id"] = threadID;
110
+
111
+ defaultFuncs
112
+ .post(
113
+ "https://www.facebook.com/messaging/set_thread_image/",
114
+ ctx.jar,
115
+ form,
116
+ )
117
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
118
+ .then(function (resData) {
119
+ // check for errors here
120
+
121
+ if (resData.error) {
122
+ throw resData;
123
+ }
124
+
125
+ return callback();
126
+ })
127
+ .catch(function (err) {
128
+ console.error("changeGroupImage", err);
129
+ return callback(err);
130
+ });
131
+ });
132
+
133
+ return returnPromise;
134
+ };
132
135
  };
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ var utils = require('./../utils.js');
4
+ var log = require('npmlog');
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function changeName(input, format, callback) {
8
+ var cb;
9
+ var rt = new Promise(function (resolve, reject) {
10
+ cb = error => error ? reject(error) : resolve();
11
+ });
12
+
13
+ if (typeof input == 'function') {
14
+ callback = input;
15
+ input = null;
16
+ }
17
+ if (typeof format == 'function') {
18
+ callback = format;
19
+ format = 'complete';
20
+ }
21
+ if (typeof callback == 'function') cb = callback;
22
+ if (utils.getType(input) != 'Object') {
23
+ var error = 'name must be an object, not ' + utils.getType(input);
24
+ log('changeName', error);
25
+ return cb(error);
26
+ }
27
+
28
+ var { first_name, middle_name, last_name } = input;
29
+ if (!first_name || !last_name) {
30
+ console.error('changeName', 'name is not be accepted');
31
+ return cb('name is not be accepted');
32
+ }
33
+
34
+ middle_name = middle_name || '';
35
+
36
+ var full_name =
37
+ format == 'complete' ? last_name + ' ' + (middle_name != '' ? middle_name + ' ' : '') + first_name :
38
+ format == 'standard' ? last_name + ' ' + first_name :
39
+ format == 'reversed' ? first_name + ' ' + (middle_name != '' ? middle_name + ' ' : '') + last_name :
40
+ last_name + ' ' + (middle_name != '' ? middle_name + ' ' : '') + first_name;
41
+
42
+ var form = {
43
+ fb_api_caller_class: 'RelayModern',
44
+ fb_api_req_friendly_name: 'useFXIMUpdateNameMutation',
45
+ variables: JSON.stringify({
46
+ client_mutation_id: utils.getGUID(),
47
+ family_device_id: "device_id_fetch_datr",
48
+ identity_ids: [ctx.userID],
49
+ full_name,
50
+ first_name,
51
+ middle_name,
52
+ last_name,
53
+ interface: 'FB_WEB'
54
+ }),
55
+ server_timestamps: true,
56
+ doc_id: '5763510853763960'
57
+ }
58
+
59
+ defaultFuncs
60
+ .post('https://accountscenter.facebook.com/api/graphql/', ctx.jar, form, null, null, {
61
+ Origin: 'https://accountscenter.facebook.com',
62
+ Referer: `https://accountscenter.facebook.com/profiles/${ctx.userID}/name`
63
+ })
64
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
65
+ .then(function (res) {
66
+ if (res.errors)
67
+ throw res;
68
+ else if (res.data.fxim_update_identity_name.error)
69
+ throw res.data.fxim_update_identity_name.error;
70
+ return cb();
71
+ })
72
+ .catch(function (err) {
73
+ console.error('changeName', err);
74
+ return cb(err);
75
+ });
76
+
77
+ return rt;
78
+ }
79
+ }
@@ -1,59 +1,59 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- const log = require("npmlog");
4
+ // @NethWs3Dev
5
5
 
6
6
  module.exports = function (defaultFuncs, api, ctx) {
7
- return function changeNickname(nickname, threadID, participantID, callback) {
8
- let resolveFunc = function () { };
9
- let rejectFunc = function () { };
10
- const returnPromise = new Promise(function (resolve, reject) {
11
- resolveFunc = resolve;
12
- rejectFunc = reject;
13
- });
14
- if (!callback) {
15
- callback = function (err) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc();
20
- };
21
- }
7
+ return function changeNickname(nickname, threadID, participantID, callback) {
8
+ let resolveFunc = function () {};
9
+ let rejectFunc = function () {};
10
+ const returnPromise = new Promise(function (resolve, reject) {
11
+ resolveFunc = resolve;
12
+ rejectFunc = reject;
13
+ });
14
+ if (!callback) {
15
+ callback = function (err) {
16
+ if (err) {
17
+ return rejectFunc(err);
18
+ }
19
+ resolveFunc();
20
+ };
21
+ }
22
22
 
23
- const form = {
24
- nickname: nickname,
25
- participant_id: participantID,
26
- thread_or_other_fbid: threadID
27
- };
23
+ const form = {
24
+ nickname: nickname,
25
+ participant_id: participantID,
26
+ thread_or_other_fbid: threadID,
27
+ };
28
28
 
29
- defaultFuncs
30
- .post(
31
- "https://www.facebook.com/messaging/save_thread_nickname/?source=thread_settings&dpr=1",
32
- ctx.jar,
33
- form
34
- )
35
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
36
- .then(function (resData) {
37
- if (resData.error === 1545014) {
38
- throw { error: "Trying to change nickname of user isn't in thread" };
39
- }
40
- if (resData.error === 1357031) {
41
- throw {
42
- error:
43
- "Trying to change user nickname of a thread that doesn't exist. Have at least one message in the thread before trying to change the user nickname."
44
- };
45
- }
46
- if (resData.error) {
47
- throw resData;
48
- }
29
+ defaultFuncs
30
+ .post(
31
+ "https://www.facebook.com/messaging/save_thread_nickname/?source=thread_settings&dpr=1",
32
+ ctx.jar,
33
+ form,
34
+ )
35
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
36
+ .then(function (resData) {
37
+ if (resData.error === 1545014) {
38
+ throw { error: "Trying to change nickname of user isn't in thread" };
39
+ }
40
+ if (resData.error === 1357031) {
41
+ throw {
42
+ error:
43
+ "Trying to change user nickname of a thread that doesn't exist. Have at least one message in the thread before trying to change the user nickname.",
44
+ };
45
+ }
46
+ if (resData.error) {
47
+ throw resData;
48
+ }
49
49
 
50
- return callback();
51
- })
52
- .catch(function (err) {
53
- log.error("changeNickname", err);
54
- return callback(err);
55
- });
50
+ return callback();
51
+ })
52
+ .catch(function (err) {
53
+ console.error("changeNickname", err);
54
+ return callback(err);
55
+ });
56
56
 
57
- return returnPromise;
58
- };
57
+ return returnPromise;
58
+ };
59
59
  };