rapido-fca 0.0.6 → 0.0.10

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 (55) hide show
  1. package/index.js +24 -17
  2. package/package.json +1 -1
  3. package/src/addExternalModule.js +23 -19
  4. package/src/addUserToGroup.js +97 -99
  5. package/src/changeAdminStatus.js +62 -86
  6. package/src/changeArchivedStatus.js +49 -49
  7. package/src/changeAvatar.js +108 -118
  8. package/src/changeBio.js +64 -63
  9. package/src/changeBlockedStatus.js +38 -40
  10. package/src/changeGroupImage.js +126 -129
  11. package/src/changeNickname.js +49 -49
  12. package/src/changeThreadColor.js +53 -53
  13. package/src/changeThreadEmoji.js +45 -45
  14. package/src/createNewGroup.js +72 -74
  15. package/src/createPoll.js +59 -59
  16. package/src/deleteMessage.js +50 -50
  17. package/src/deleteThread.js +50 -50
  18. package/src/editMessage.js +49 -51
  19. package/src/forwardAttachment.js +54 -54
  20. package/src/getCurrentUserID.js +3 -3
  21. package/src/getEmojiUrl.js +17 -17
  22. package/src/getFriendsList.js +67 -67
  23. package/src/getMessage.js +767 -806
  24. package/src/getThreadHistory.js +642 -656
  25. package/src/getThreadInfo.js +1 -1
  26. package/src/getThreadList.js +227 -199
  27. package/src/getThreadPictures.js +71 -51
  28. package/src/getUserID.js +58 -53
  29. package/src/getUserInfo.js +60 -52
  30. package/src/handleFriendRequest.js +65 -41
  31. package/src/handleMessageRequest.js +60 -42
  32. package/src/httpGet.js +57 -49
  33. package/src/httpPost.js +57 -48
  34. package/src/httpPostFormData.js +63 -0
  35. package/src/listenMqtt.js +827 -827
  36. package/src/logout.js +61 -61
  37. package/src/markAsDelivered.js +53 -42
  38. package/src/markAsRead.js +69 -59
  39. package/src/markAsReadAll.js +42 -32
  40. package/src/markAsSeen.js +54 -43
  41. package/src/muteThread.js +47 -40
  42. package/src/refreshFb_dtsg.js +69 -77
  43. package/src/removeUserFromGroup.js +67 -67
  44. package/src/resolvePhotoUrl.js +34 -34
  45. package/src/searchForThread.js +43 -43
  46. package/src/sendMessage.js +228 -80
  47. package/src/sendTypingIndicator.js +88 -86
  48. package/src/setEmojiReaction.js +59 -0
  49. package/src/setPostReaction.js +87 -90
  50. package/src/setTitle.js +72 -76
  51. package/src/threadColors.js +121 -121
  52. package/src/unfriend.js +43 -43
  53. package/src/unsendMessage.js +38 -34
  54. package/src/uploadAttachment.js +81 -79
  55. package/src/videoAttachment.js +76 -0
@@ -1,55 +1,55 @@
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 changeArchivedStatus(threadOrThreads, archive, 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
-
15
- if (!callback) {
16
- callback = function (err) {
17
- if (err) {
18
- return rejectFunc(err);
19
- }
20
- resolveFunc();
21
- };
22
- }
23
-
24
- const form = {};
25
-
26
- if (utils.getType(threadOrThreads) === "Array") {
27
- for (let i = 0; i < threadOrThreads.length; i++) {
28
- form["ids[" + threadOrThreads[i] + "]"] = archive;
29
- }
30
- } else {
31
- form["ids[" + threadOrThreads + "]"] = archive;
32
- }
33
-
34
- defaultFuncs
35
- .post(
36
- "https://www.facebook.com/ajax/mercury/change_archived_status.php",
37
- ctx.jar,
38
- form,
39
- )
40
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
41
- .then(function (resData) {
42
- if (resData.error) {
43
- throw resData;
44
- }
45
-
46
- return callback();
47
- })
48
- .catch(function (err) {
49
- console.error("changeArchivedStatus", err);
50
- return callback(err);
51
- });
52
-
53
- return returnPromise;
54
- };
7
+ return function changeArchivedStatus(threadOrThreads, archive, 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
+
15
+ if (!callback) {
16
+ callback = function (err) {
17
+ if (err) {
18
+ return rejectFunc(err);
19
+ }
20
+ resolveFunc();
21
+ };
22
+ }
23
+
24
+ const form = {};
25
+
26
+ if (utils.getType(threadOrThreads) === "Array") {
27
+ for (let i = 0; i < threadOrThreads.length; i++) {
28
+ form["ids[" + threadOrThreads[i] + "]"] = archive;
29
+ }
30
+ } else {
31
+ form["ids[" + threadOrThreads + "]"] = archive;
32
+ }
33
+
34
+ defaultFuncs
35
+ .post(
36
+ "https://www.facebook.com/ajax/mercury/change_archived_status.php",
37
+ ctx.jar,
38
+ form
39
+ )
40
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
41
+ .then(function (resData) {
42
+ if (resData.error) {
43
+ throw resData;
44
+ }
45
+
46
+ return callback();
47
+ })
48
+ .catch(function (err) {
49
+ log.error("changeArchivedStatus", err);
50
+ return callback(err);
51
+ });
52
+
53
+ return returnPromise;
54
+ };
55
55
  };
@@ -1,136 +1,126 @@
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 = [];
7
+ function handleUpload(image, callback) {
8
+ const uploads = [];
9
9
 
10
- const form = {
11
- profile_id: ctx.userID,
12
- photo_source: 57,
13
- av: ctx.userID,
14
- file: image,
15
- };
10
+ const form = {
11
+ profile_id: ctx.i_userID || ctx.userID,
12
+ photo_source: 57,
13
+ av: ctx.i_userID || ctx.userID,
14
+ file: image
15
+ };
16
16
 
17
- uploads.push(
18
- defaultFuncs
19
- .postFormData(
20
- "https://www.facebook.com/profile/picture/upload/",
21
- ctx.jar,
22
- form,
23
- {},
24
- )
25
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
26
- .then(function (resData) {
27
- if (resData.error) {
28
- throw resData;
29
- }
30
- return resData;
31
- }),
32
- );
17
+ uploads.push(
18
+ defaultFuncs
19
+ .postFormData(
20
+ "https://www.facebook.com/profile/picture/upload/",
21
+ ctx.jar,
22
+ form,
23
+ {}
24
+ )
25
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
26
+ .then(function (resData) {
27
+ if (resData.error) {
28
+ throw resData;
29
+ }
30
+ return resData;
31
+ })
32
+ );
33
33
 
34
- // resolve all promises
35
- Promise.all(uploads)
36
- .then(function (resData) {
37
- callback(null, resData);
38
- })
39
- .catch(function (err) {
40
- console.error("handleUpload", err);
41
- return callback(err);
42
- });
43
- }
34
+ // resolve all promises
35
+ Promise
36
+ .all(uploads)
37
+ .then(function (resData) {
38
+ callback(null, resData);
39
+ })
40
+ .catch(function (err) {
41
+ log.error("handleUpload", err);
42
+ return callback(err);
43
+ });
44
+ }
44
45
 
45
- return function changeAvatar(
46
- image,
47
- caption = "",
48
- timestamp = null,
49
- callback,
50
- ) {
51
- let resolveFunc = function () {};
52
- let rejectFunc = function () {};
53
- const returnPromise = new Promise(function (resolve, reject) {
54
- resolveFunc = resolve;
55
- rejectFunc = reject;
56
- });
46
+ return function changeAvatar(image, caption = "", timestamp = null, callback) {
47
+ let resolveFunc = function () { };
48
+ let rejectFunc = function () { };
49
+ const returnPromise = new Promise(function (resolve, reject) {
50
+ resolveFunc = resolve;
51
+ rejectFunc = reject;
52
+ });
57
53
 
58
- if (!timestamp && utils.getType(caption) === "Number") {
59
- timestamp = caption;
60
- caption = "";
61
- }
54
+ if (!timestamp && utils.getType(caption) === "Number") {
55
+ timestamp = caption;
56
+ caption = "";
57
+ }
62
58
 
63
- if (
64
- !timestamp &&
65
- !callback &&
66
- (utils.getType(caption) == "Function" ||
67
- utils.getType(caption) == "AsyncFunction")
68
- ) {
69
- callback = caption;
70
- caption = "";
71
- timestamp = null;
72
- }
59
+ if (!timestamp && !callback && (utils.getType(caption) == "Function" || utils.getType(caption) == "AsyncFunction")) {
60
+ callback = caption;
61
+ caption = "";
62
+ timestamp = null;
63
+ }
73
64
 
74
- if (!callback)
75
- callback = function (err, data) {
76
- if (err) {
77
- return rejectFunc(err);
78
- }
79
- resolveFunc(data);
80
- };
65
+ if (!callback) callback = function (err, data) {
66
+ if (err) {
67
+ return rejectFunc(err);
68
+ }
69
+ resolveFunc(data);
70
+ };
81
71
 
82
- if (!utils.isReadableStream(image))
83
- return callback("Image is not a readable stream");
72
+ if (!utils.isReadableStream(image))
73
+ return callback("Image is not a readable stream");
84
74
 
85
- handleUpload(image, function (err, payload) {
86
- if (err) {
87
- return callback(err);
88
- }
75
+ handleUpload(image, function (err, payload) {
76
+ if (err) {
77
+ return callback(err);
78
+ }
89
79
 
90
- const form = {
91
- av: ctx.userID,
92
- fb_api_req_friendly_name: "ProfileCometProfilePictureSetMutation",
93
- fb_api_caller_class: "RelayModern",
94
- doc_id: "5066134240065849",
95
- variables: JSON.stringify({
96
- input: {
97
- caption,
98
- existing_photo_id: payload[0].payload.fbid,
99
- expiration_time: timestamp,
100
- profile_id: ctx.userID,
101
- profile_pic_method: "EXISTING",
102
- profile_pic_source: "TIMELINE",
103
- scaled_crop_rect: {
104
- height: 1,
105
- width: 1,
106
- x: 0,
107
- y: 0,
108
- },
109
- skip_cropping: true,
110
- actor_id: ctx.userID,
111
- client_mutation_id: Math.round(Math.random() * 19).toString(),
112
- },
113
- isPage: false,
114
- isProfile: true,
115
- scale: 3,
116
- }),
117
- };
80
+ const form = {
81
+ av: ctx.i_userID || ctx.userID,
82
+ fb_api_req_friendly_name: "ProfileCometProfilePictureSetMutation",
83
+ fb_api_caller_class: "RelayModern",
84
+ doc_id: "5066134240065849",
85
+ variables: JSON.stringify({
86
+ input: {
87
+ caption,
88
+ existing_photo_id: payload[0].payload.fbid,
89
+ expiration_time: timestamp,
90
+ profile_id: ctx.i_userID || ctx.userID,
91
+ profile_pic_method: "EXISTING",
92
+ profile_pic_source: "TIMELINE",
93
+ scaled_crop_rect: {
94
+ height: 1,
95
+ width: 1,
96
+ x: 0,
97
+ y: 0
98
+ },
99
+ skip_cropping: true,
100
+ actor_id: ctx.i_userID || ctx.userID,
101
+ client_mutation_id: Math.round(Math.random() * 19).toString()
102
+ },
103
+ isPage: false,
104
+ isProfile: true,
105
+ scale: 3
106
+ })
107
+ };
118
108
 
119
- defaultFuncs
120
- .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
121
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
122
- .then(function (resData) {
123
- if (resData.errors) {
124
- throw resData;
125
- }
126
- return callback(null, resData[0].data.profile_picture_set);
127
- })
128
- .catch(function (err) {
129
- console.error("changeAvatar", err);
130
- return callback(err);
131
- });
132
- });
109
+ defaultFuncs
110
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
111
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
112
+ .then(function (resData) {
113
+ if (resData.errors) {
114
+ throw resData;
115
+ }
116
+ return callback(null, resData[0].data.profile_picture_set);
117
+ })
118
+ .catch(function (err) {
119
+ log.error("changeAvatar", err);
120
+ return callback(err);
121
+ });
122
+ });
133
123
 
134
- return returnPromise;
135
- };
124
+ return returnPromise;
125
+ };
136
126
  };
package/src/changeBio.js CHANGED
@@ -1,76 +1,77 @@
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 changeBio(bio, publish, 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 changeBio(bio, publish, 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
- if (
17
- utils.getType(publish) == "Function" ||
18
- utils.getType(publish) == "AsyncFunction"
19
- ) {
20
- callback = publish;
21
- } else {
22
- callback = function (err) {
23
- if (err) {
24
- return rejectFunc(err);
25
- }
26
- resolveFunc();
27
- };
28
- }
29
- }
15
+ if (!callback) {
16
+ if (utils.getType(publish) == "Function" || utils.getType(publish) == "AsyncFunction") {
17
+ callback = publish;
18
+ } else {
19
+ callback = function (err) {
20
+ if (err) {
21
+ return rejectFunc(err);
22
+ }
23
+ resolveFunc();
24
+ };
25
+ }
26
+ }
30
27
 
31
- if (utils.getType(publish) != "Boolean") {
32
- publish = false;
33
- }
28
+ if (utils.getType(publish) != "Boolean") {
29
+ publish = false;
30
+ }
34
31
 
35
- if (utils.getType(bio) != "String") {
36
- bio = "";
37
- publish = false;
38
- }
32
+ if (utils.getType(bio) != "String") {
33
+ bio = "";
34
+ publish = false;
35
+ }
39
36
 
40
- const form = {
41
- fb_api_caller_class: "RelayModern",
42
- fb_api_req_friendly_name: "ProfileCometSetBioMutation",
43
- // This doc_is is valid as of May 23, 2020
44
- doc_id: "2725043627607610",
45
- variables: JSON.stringify({
46
- input: {
47
- bio: bio,
48
- publish_bio_feed_story: publish,
49
- actor_id: ctx.userID,
50
- client_mutation_id: Math.round(Math.random() * 1024).toString(),
51
- },
52
- hasProfileTileViewID: false,
53
- profileTileViewID: null,
54
- scale: 1,
55
- }),
56
- av: ctx.userID,
57
- };
37
+ const form = {
38
+ fb_api_caller_class: "RelayModern",
39
+ fb_api_req_friendly_name: "ProfileCometSetBioMutation",
40
+ // This doc_is is valid as of May 23, 2020
41
+ doc_id: "2725043627607610",
42
+ variables: JSON.stringify({
43
+ input: {
44
+ bio: bio,
45
+ publish_bio_feed_story: publish,
46
+ actor_id: ctx.i_userID || ctx.userID,
47
+ client_mutation_id: Math.round(Math.random() * 1024).toString()
48
+ },
49
+ hasProfileTileViewID: false,
50
+ profileTileViewID: null,
51
+ scale: 1
52
+ }),
53
+ av: ctx.i_userID || ctx.userID
54
+ };
58
55
 
59
- defaultFuncs
60
- .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
61
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
62
- .then(function (resData) {
63
- if (resData.errors) {
64
- throw resData;
65
- }
56
+ defaultFuncs
57
+ .post(
58
+ "https://www.facebook.com/api/graphql/",
59
+ ctx.jar,
60
+ form
61
+ )
62
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
63
+ .then(function (resData) {
64
+ if (resData.errors) {
65
+ throw resData;
66
+ }
66
67
 
67
- return callback();
68
- })
69
- .catch(function (err) {
70
- console.error("changeBio", err);
71
- return callback(err);
72
- });
68
+ return callback();
69
+ })
70
+ .catch(function (err) {
71
+ log.error("changeBio", err);
72
+ return callback(err);
73
+ });
73
74
 
74
- return returnPromise;
75
- };
75
+ return returnPromise;
76
+ };
76
77
  };
@@ -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
  };