rapido-fca 0.0.1 → 0.0.2

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 +415 -419
  2. package/package.json +1 -1
  3. package/readme.md +39 -237
  4. package/src/addExternalModule.js +23 -19
  5. package/src/addUserToGroup.js +97 -99
  6. package/src/changeAdminStatus.js +62 -86
  7. package/src/changeArchivedStatus.js +49 -49
  8. package/src/changeAvatar.js +108 -118
  9. package/src/changeBio.js +64 -63
  10. package/src/changeBlockedStatus.js +38 -40
  11. package/src/changeGroupImage.js +126 -129
  12. package/src/changeNickname.js +49 -49
  13. package/src/changeThreadColor.js +53 -53
  14. package/src/changeThreadEmoji.js +45 -45
  15. package/src/createNewGroup.js +72 -74
  16. package/src/createPoll.js +59 -59
  17. package/src/deleteMessage.js +50 -50
  18. package/src/deleteThread.js +50 -50
  19. package/src/editMessage.js +49 -51
  20. package/src/forwardAttachment.js +54 -54
  21. package/src/getCurrentUserID.js +3 -3
  22. package/src/getEmojiUrl.js +17 -17
  23. package/src/getFriendsList.js +67 -67
  24. package/src/getMessage.js +767 -806
  25. package/src/getThreadHistory.js +642 -656
  26. package/src/getThreadInfo.js +1 -1
  27. package/src/getThreadList.js +227 -199
  28. package/src/getThreadPictures.js +71 -51
  29. package/src/getUserID.js +58 -53
  30. package/src/getUserInfo.js +60 -52
  31. package/src/handleFriendRequest.js +65 -41
  32. package/src/handleMessageRequest.js +60 -42
  33. package/src/httpGet.js +57 -49
  34. package/src/httpPost.js +57 -48
  35. package/src/httpPostFormData.js +63 -0
  36. package/src/listenMqtt.js +895 -827
  37. package/src/logout.js +61 -61
  38. package/src/markAsDelivered.js +53 -42
  39. package/src/markAsRead.js +69 -59
  40. package/src/markAsReadAll.js +42 -32
  41. package/src/markAsSeen.js +54 -43
  42. package/src/muteThread.js +47 -40
  43. package/src/refreshFb_dtsg.js +69 -77
  44. package/src/removeUserFromGroup.js +67 -67
  45. package/src/resolvePhotoUrl.js +34 -34
  46. package/src/searchForThread.js +43 -43
  47. package/src/sendMessage.js +228 -80
  48. package/src/sendTypingIndicator.js +88 -86
  49. package/src/setMessageReaction.js +109 -110
  50. package/src/setPostReaction.js +87 -90
  51. package/src/setTitle.js +72 -76
  52. package/src/threadColors.js +121 -121
  53. package/src/unfriend.js +43 -43
  54. package/src/unsendMessage.js +38 -34
  55. package/src/uploadAttachment.js +81 -79
  56. package/utils.js +1401 -2732
  57. package/src/changeAvatarV2.js +0 -86
  58. package/src/changeAvt.js +0 -85
  59. package/src/changeBlockedStatusMqtt.js +0 -80
  60. package/src/changeCover.js +0 -72
  61. package/src/changeName.js +0 -79
  62. package/src/changeUsername.js +0 -59
  63. package/src/createCommentPost.js +0 -230
  64. package/src/createPost.js +0 -276
  65. package/src/editMessageOld.js +0 -67
  66. package/src/follow.js +0 -74
  67. package/src/getAccess.js +0 -112
  68. package/src/getAvatarUser.js +0 -78
  69. package/src/getRegion.js +0 -7
  70. package/src/getThreadHistoryDeprecated.js +0 -71
  71. package/src/getThreadInfoDeprecated.js +0 -56
  72. package/src/getThreadListDeprecated.js +0 -46
  73. package/src/getUID.js +0 -119
  74. package/src/searchStickers.js +0 -53
  75. package/src/sendMessageMqtt.js +0 -322
  76. package/src/sendTypingIndicatorV2.js +0 -28
  77. package/src/setMessageReactionMqtt.js +0 -62
  78. package/src/setStoryReaction.js +0 -64
  79. package/src/shareContact.js +0 -110
  80. package/src/shareLink.js +0 -59
  81. package/src/stopListenMqtt.js +0 -23
@@ -1,49 +1,47 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
5
5
 
6
6
  module.exports = function (defaultFuncs, api, ctx) {
7
- return function changeBlockedStatus(userID, block, callback) {
8
- let resolveFunc = function () {};
9
- let rejectFunc = function () {};
10
- const returnPromise = new Promise(function (resolve, reject) {
11
- resolveFunc = resolve;
12
- rejectFunc = reject;
13
- });
7
+ return function changeBlockedStatus(userID, block, 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
14
 
15
- if (!callback) {
16
- callback = function (err) {
17
- if (err) {
18
- return rejectFunc(err);
19
- }
20
- resolveFunc();
21
- };
22
- }
15
+ if (!callback) {
16
+ callback = function (err) {
17
+ if (err) {
18
+ return rejectFunc(err);
19
+ }
20
+ resolveFunc();
21
+ };
22
+ }
23
23
 
24
- defaultFuncs
25
- .post(
26
- `https://www.facebook.com/messaging/${
27
- block ? "" : "un"
28
- }block_messages/`,
29
- ctx.jar,
30
- {
31
- fbid: userID,
32
- },
33
- )
34
- .then(utils.saveCookies(ctx.jar))
35
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
36
- .then(function (resData) {
37
- if (resData.error) {
38
- throw resData;
39
- }
24
+ defaultFuncs
25
+ .post(
26
+ `https://www.facebook.com/messaging/${block ? "" : "un"}block_messages/`,
27
+ ctx.jar,
28
+ {
29
+ fbid: userID
30
+ }
31
+ )
32
+ .then(utils.saveCookies(ctx.jar))
33
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
+ .then(function (resData) {
35
+ if (resData.error) {
36
+ throw resData;
37
+ }
40
38
 
41
- return callback();
42
- })
43
- .catch(function (err) {
44
- console.error("changeBlockedStatus", err);
45
- return callback(err);
46
- });
47
- return returnPromise;
48
- };
39
+ return callback();
40
+ })
41
+ .catch(function (err) {
42
+ log.error("changeBlockedStatus", err);
43
+ return callback(err);
44
+ });
45
+ return returnPromise;
46
+ };
49
47
  };
@@ -1,135 +1,132 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
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.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
- };
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
+ };
135
132
  };
@@ -1,59 +1,59 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
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
- console.error("changeNickname", err);
54
- return callback(err);
55
- });
50
+ return callback();
51
+ })
52
+ .catch(function (err) {
53
+ log.error("changeNickname", err);
54
+ return callback(err);
55
+ });
56
56
 
57
- return returnPromise;
58
- };
57
+ return returnPromise;
58
+ };
59
59
  };
@@ -1,65 +1,65 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
5
5
 
6
6
  module.exports = function (defaultFuncs, api, ctx) {
7
- return function changeThreadColor(color, threadID, callback) {
8
- let resolveFunc = function () {};
9
- let rejectFunc = function () {};
10
- const returnPromise = new Promise(function (resolve, reject) {
11
- resolveFunc = resolve;
12
- rejectFunc = reject;
13
- });
7
+ return function changeThreadColor(color, threadID, 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
14
 
15
- if (!callback) {
16
- callback = function (err) {
17
- if (err) {
18
- return rejectFunc(err);
19
- }
20
- resolveFunc(err);
21
- };
22
- }
15
+ if (!callback) {
16
+ callback = function (err) {
17
+ if (err) {
18
+ return rejectFunc(err);
19
+ }
20
+ resolveFunc(err);
21
+ };
22
+ }
23
23
 
24
- if (!isNaN(color)) {
25
- color = color.toString();
26
- }
27
- const validatedColor = color !== null ? color.toLowerCase() : color; // API only accepts lowercase letters in hex string
24
+ if (!isNaN(color)) {
25
+ color = color.toString();
26
+ }
27
+ const validatedColor = color !== null ? color.toLowerCase() : color; // API only accepts lowercase letters in hex string
28
28
 
29
- const form = {
30
- dpr: 1,
31
- queries: JSON.stringify({
32
- o0: {
33
- //This doc_id is valid as of January 31, 2020
34
- doc_id: "1727493033983591",
35
- query_params: {
36
- data: {
37
- actor_id: ctx.userID,
38
- client_mutation_id: "0",
39
- source: "SETTINGS",
40
- theme_id: validatedColor,
41
- thread_id: threadID,
42
- },
43
- },
44
- },
45
- }),
46
- };
29
+ const form = {
30
+ dpr: 1,
31
+ queries: JSON.stringify({
32
+ o0: {
33
+ //This doc_id is valid as of January 31, 2020
34
+ doc_id: "1727493033983591",
35
+ query_params: {
36
+ data: {
37
+ actor_id: ctx.i_userID || ctx.userID,
38
+ client_mutation_id: "0",
39
+ source: "SETTINGS",
40
+ theme_id: validatedColor,
41
+ thread_id: threadID
42
+ }
43
+ }
44
+ }
45
+ })
46
+ };
47
47
 
48
- defaultFuncs
49
- .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
50
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
51
- .then(function (resData) {
52
- if (resData[resData.length - 1].error_results > 0) {
53
- throw new utils.CustomError(resData[0].o0.errors);
54
- }
48
+ defaultFuncs
49
+ .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
50
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
51
+ .then(function (resData) {
52
+ if (resData[resData.length - 1].error_results > 0) {
53
+ throw new utils.CustomError(resData[0].o0.errors);
54
+ }
55
55
 
56
- return callback();
57
- })
58
- .catch(function (err) {
59
- console.error("changeThreadColor", err);
60
- return callback(err);
61
- });
56
+ return callback();
57
+ })
58
+ .catch(function (err) {
59
+ log.error("changeThreadColor", err);
60
+ return callback(err);
61
+ });
62
62
 
63
- return returnPromise;
64
- };
63
+ return returnPromise;
64
+ };
65
65
  };