rapido-fca 0.0.10 → 1.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.

Potentially problematic release.


This version of rapido-fca might be problematic. Click here for more details.

Files changed (60) hide show
  1. package/LICENSE +21 -0
  2. package/index.js +4 -4
  3. package/package.json +15 -16
  4. package/readme.md +237 -39
  5. package/src/Screenshot.js +83 -0
  6. package/src/addExternalModule.js +19 -23
  7. package/src/addUserToGroup.js +99 -97
  8. package/src/changeAdminStatus.js +86 -62
  9. package/src/changeArchivedStatus.js +49 -49
  10. package/src/changeAvatar.js +118 -108
  11. package/src/changeBio.js +63 -64
  12. package/src/changeBlockedStatus.js +40 -38
  13. package/src/changeGroupImage.js +129 -126
  14. package/src/changeNickname.js +49 -49
  15. package/src/changeThreadColor.js +53 -53
  16. package/src/changeThreadEmoji.js +45 -45
  17. package/src/createNewGroup.js +74 -72
  18. package/src/createPoll.js +59 -59
  19. package/src/deleteMessage.js +50 -50
  20. package/src/deleteThread.js +50 -50
  21. package/src/editMessage.js +51 -49
  22. package/src/forwardAttachment.js +54 -54
  23. package/src/getCurrentUserID.js +3 -3
  24. package/src/getEmojiUrl.js +17 -17
  25. package/src/getFriendsList.js +67 -67
  26. package/src/getMessage.js +806 -767
  27. package/src/getThreadHistory.js +656 -642
  28. package/src/getThreadInfo.js +1 -1
  29. package/src/getThreadList.js +199 -227
  30. package/src/getThreadPictures.js +51 -71
  31. package/src/getUserID.js +53 -58
  32. package/src/getUserInfo.js +52 -60
  33. package/src/handleFriendRequest.js +41 -65
  34. package/src/handleMessageRequest.js +42 -60
  35. package/src/httpGet.js +49 -57
  36. package/src/httpPost.js +48 -57
  37. package/src/listenMqtt.js +827 -827
  38. package/src/listenMqtt.txt +827 -0
  39. package/src/logout.js +61 -61
  40. package/src/markAsDelivered.js +42 -53
  41. package/src/markAsRead.js +59 -69
  42. package/src/markAsReadAll.js +32 -42
  43. package/src/markAsSeen.js +43 -54
  44. package/src/muteThread.js +40 -47
  45. package/src/postFormData.txt +46 -0
  46. package/src/refreshFb_dtsg.js +77 -69
  47. package/src/removeUserFromGroup.js +67 -67
  48. package/src/resolvePhotoUrl.js +34 -34
  49. package/src/searchForThread.js +43 -43
  50. package/src/sendMessage.js +80 -228
  51. package/src/sendTypingIndicator.js +86 -88
  52. package/src/setPostReaction.js +90 -87
  53. package/src/setTitle.js +76 -72
  54. package/src/threadColors.js +121 -121
  55. package/src/unfriend.js +43 -43
  56. package/src/unsendMessage.js +34 -38
  57. package/src/uploadAttachment.js +80 -81
  58. package/src/httpPostFormData.js +0 -63
  59. package/src/setEmojiReaction.js +0 -59
  60. package/src/videoAttachment.js +0 -76
@@ -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
  };
@@ -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
  };
@@ -1,65 +1,65 @@
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 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.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
- };
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
+ };
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
- log.error("changeThreadColor", err);
60
- return callback(err);
61
- });
56
+ return callback();
57
+ })
58
+ .catch(function (err) {
59
+ console.error("changeThreadColor", err);
60
+ return callback(err);
61
+ });
62
62
 
63
- return returnPromise;
64
- };
63
+ return returnPromise;
64
+ };
65
65
  };
@@ -1,55 +1,55 @@
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 changeThreadEmoji(emoji, 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 changeThreadEmoji(emoji, 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();
21
- };
22
- }
23
- const form = {
24
- emoji_choice: emoji,
25
- thread_or_other_fbid: threadID
26
- };
15
+ if (!callback) {
16
+ callback = function (err) {
17
+ if (err) {
18
+ return rejectFunc(err);
19
+ }
20
+ resolveFunc();
21
+ };
22
+ }
23
+ const form = {
24
+ emoji_choice: emoji,
25
+ thread_or_other_fbid: threadID,
26
+ };
27
27
 
28
- defaultFuncs
29
- .post(
30
- "https://www.facebook.com/messaging/save_thread_emoji/?source=thread_settings&__pc=EXP1%3Amessengerdotcom_pkg",
31
- ctx.jar,
32
- form
33
- )
34
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
35
- .then(function (resData) {
36
- if (resData.error === 1357031) {
37
- throw {
38
- error:
39
- "Trying to change emoji of a chat that doesn't exist. Have at least one message in the thread before trying to change the emoji."
40
- };
41
- }
42
- if (resData.error) {
43
- throw resData;
44
- }
28
+ defaultFuncs
29
+ .post(
30
+ "https://www.facebook.com/messaging/save_thread_emoji/?source=thread_settings&__pc=EXP1%3Amessengerdotcom_pkg",
31
+ ctx.jar,
32
+ form,
33
+ )
34
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
35
+ .then(function (resData) {
36
+ if (resData.error === 1357031) {
37
+ throw {
38
+ error:
39
+ "Trying to change emoji of a chat that doesn't exist. Have at least one message in the thread before trying to change the emoji.",
40
+ };
41
+ }
42
+ if (resData.error) {
43
+ throw resData;
44
+ }
45
45
 
46
- return callback();
47
- })
48
- .catch(function (err) {
49
- log.error("changeThreadEmoji", err);
50
- return callback(err);
51
- });
46
+ return callback();
47
+ })
48
+ .catch(function (err) {
49
+ console.error("changeThreadEmoji", err);
50
+ return callback(err);
51
+ });
52
52
 
53
- return returnPromise;
54
- };
53
+ return returnPromise;
54
+ };
55
55
  };