ws-rapido 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.
Files changed (84) hide show
  1. package/index.js +477 -0
  2. package/package.json +46 -0
  3. package/src/addExternalModule.js +25 -0
  4. package/src/addUserToGroup.js +115 -0
  5. package/src/changeAdminStatus.js +103 -0
  6. package/src/changeArchivedStatus.js +55 -0
  7. package/src/changeAvatar.js +136 -0
  8. package/src/changeAvatarV2.js +86 -0
  9. package/src/changeBio.js +76 -0
  10. package/src/changeBlockedStatus.js +49 -0
  11. package/src/changeBlockedStatusMqtt.js +80 -0
  12. package/src/changeCover.js +72 -0
  13. package/src/changeGroupImage.js +135 -0
  14. package/src/changeName.js +78 -0
  15. package/src/changeNickname.js +59 -0
  16. package/src/changeThreadColor.js +65 -0
  17. package/src/changeThreadEmoji.js +55 -0
  18. package/src/changeUsername.js +58 -0
  19. package/src/createCommentPost.js +229 -0
  20. package/src/createNewGroup.js +88 -0
  21. package/src/createPoll.js +71 -0
  22. package/src/createPost.js +275 -0
  23. package/src/data/getThreadInfo.json +1 -0
  24. package/src/deleteMessage.js +56 -0
  25. package/src/deleteThread.js +56 -0
  26. package/src/editMessage.js +76 -0
  27. package/src/follow.js +74 -0
  28. package/src/forwardAttachment.js +60 -0
  29. package/src/getAccess.js +111 -0
  30. package/src/getAvatarUser.js +78 -0
  31. package/src/getBotInitialData.js +43 -0
  32. package/src/getCtx.js +5 -0
  33. package/src/getCurrentUserID.js +7 -0
  34. package/src/getEmojiUrl.js +29 -0
  35. package/src/getFriendsList.js +83 -0
  36. package/src/getMessage.js +835 -0
  37. package/src/getOptions.js +5 -0
  38. package/src/getRegion.js +7 -0
  39. package/src/getThreadHistory.js +680 -0
  40. package/src/getThreadHistoryDeprecated.js +93 -0
  41. package/src/getThreadInfo.js +227 -0
  42. package/src/getThreadInfoDeprecated.js +80 -0
  43. package/src/getThreadList.js +269 -0
  44. package/src/getThreadListDeprecated.js +75 -0
  45. package/src/getThreadPictures.js +79 -0
  46. package/src/getUID.js +122 -0
  47. package/src/getUserID.js +66 -0
  48. package/src/getUserInfo.js +82 -0
  49. package/src/handleFriendRequest.js +57 -0
  50. package/src/handleMessageRequest.js +65 -0
  51. package/src/httpGet.js +64 -0
  52. package/src/httpPost.js +64 -0
  53. package/src/httpPostFormData.js +70 -0
  54. package/src/listenMqtt.js +674 -0
  55. package/src/listenNotification.js +85 -0
  56. package/src/logout.js +75 -0
  57. package/src/markAsDelivered.js +55 -0
  58. package/src/markAsRead.js +85 -0
  59. package/src/markAsReadAll.js +50 -0
  60. package/src/markAsSeen.js +61 -0
  61. package/src/muteThread.js +52 -0
  62. package/src/pinMessage.js +59 -0
  63. package/src/refreshFb_dtsg.js +89 -0
  64. package/src/removeUserFromGroup.js +79 -0
  65. package/src/resolvePhotoUrl.js +45 -0
  66. package/src/searchForThread.js +53 -0
  67. package/src/searchStickers.js +53 -0
  68. package/src/sendMessage.js +442 -0
  69. package/src/sendMessageMqtt.js +316 -0
  70. package/src/sendTypingIndicator.js +28 -0
  71. package/src/setMessageReaction.js +122 -0
  72. package/src/setMessageReactionMqtt.js +62 -0
  73. package/src/setPostReaction.js +108 -0
  74. package/src/setProfileGuard.js +44 -0
  75. package/src/setStoryReaction.js +64 -0
  76. package/src/setTitle.js +90 -0
  77. package/src/shareContact.js +110 -0
  78. package/src/shareLink.js +59 -0
  79. package/src/stopListenMqtt.js +23 -0
  80. package/src/threadColors.js +131 -0
  81. package/src/unfriend.js +52 -0
  82. package/src/unsendMessage.js +45 -0
  83. package/src/uploadAttachment.js +94 -0
  84. package/utils.js +1441 -0
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function forwardAttachment(attachmentID, userOrUsers, 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
+
23
+ const form = {
24
+ attachment_id: attachmentID,
25
+ };
26
+
27
+ if (utils.getType(userOrUsers) !== "Array") {
28
+ userOrUsers = [userOrUsers];
29
+ }
30
+
31
+ const timestamp = Math.floor(Date.now() / 1000);
32
+
33
+ for (let i = 0; i < userOrUsers.length; i++) {
34
+ //That's good, the key of the array is really timestmap in seconds + index
35
+ //Probably time when the attachment will be sent?
36
+ form["recipient_map[" + (timestamp + i) + "]"] = userOrUsers[i];
37
+ }
38
+
39
+ defaultFuncs
40
+ .post(
41
+ "https://www.facebook.com/mercury/attachments/forward/",
42
+ ctx.jar,
43
+ form,
44
+ )
45
+ .then(utils.parseAndCheckLogin(ctx.jar, defaultFuncs))
46
+ .then(function (resData) {
47
+ if (resData.error) {
48
+ throw resData;
49
+ }
50
+
51
+ return callback();
52
+ })
53
+ .catch(function (err) {
54
+ utils.error("forwardAttachment", err);
55
+ return callback(err);
56
+ });
57
+
58
+ return returnPromise;
59
+ };
60
+ };
@@ -0,0 +1,111 @@
1
+ 'use strict';
2
+
3
+ var utils = require('../utils');
4
+
5
+ module.exports = function (defaultFuncs, api, ctx) {
6
+ return function getAccess(authCode = '', callback) {
7
+ var cb;
8
+ var url = 'https://business.facebook.com/';
9
+ var Referer = url + 'security/twofactor/reauth/?twofac_next=' + encodeURIComponent(url + 'content_management') + '&type=avoid_bypass&app_id=0&save_device=0';
10
+ var rt = new Promise(function (resolve, reject) {
11
+ cb = (error, token) => token ? resolve(token) : reject(error);
12
+ });
13
+
14
+ if (typeof authCode == 'function') {
15
+ callback = authCode;
16
+ authCode = '';
17
+ }
18
+ if (typeof callback == 'function') cb = callback;
19
+ if (!!ctx.access_token)
20
+ cb(null, ctx.access_token);
21
+ else
22
+ utils
23
+ .get(url + 'content_management', ctx.jar, null, ctx.globalOptions, null, {
24
+ noRef: true,
25
+ Origin: url
26
+ })
27
+ .then(function (res) {
28
+ var html = res.body;
29
+ var lsd = utils.getFrom(html, "[\"LSD\",[],{\"token\":\"", "\"}");
30
+ return lsd;
31
+ })
32
+ .then(function (lsd) {
33
+ function submitCode(code) {
34
+ var pCb;
35
+ var rtPromise = new Promise(function (resolve) {
36
+ pCb = (error, token) => resolve(cb(error, token));
37
+ });
38
+ if (typeof code != 'string')
39
+ pCb({
40
+ error: 'submitCode',
41
+ lerror: 'code must be string',
42
+ continue: submitCode
43
+ });
44
+ else
45
+ defaultFuncs
46
+ .post(url + 'security/twofactor/reauth/enter/', ctx.jar, {
47
+ approvals_code: code,
48
+ save_device: true,
49
+ lsd
50
+ }, ctx.globalOptions, null, {
51
+ Referer,
52
+ Origin: url
53
+ })
54
+ .then(function (res) {
55
+ var { payload } = JSON.parse(res.body.split(';').pop() || '{}');
56
+ if (payload && !payload.codeConfirmed)
57
+ throw {
58
+ error: 'submitCode',
59
+ lerror: payload.message,
60
+ continue: submitCode
61
+ }
62
+
63
+ return;
64
+ })
65
+ .then(function () {
66
+ return utils
67
+ .get(url + 'content_management', ctx.jar, null, ctx.globalOptions, null, { noRef: true })
68
+ .then(function (res) {
69
+ var html = res.body;
70
+ var token = /"accessToken":"(\S+)","clientID":/g.exec(html);
71
+
72
+ return [html, token];
73
+ });
74
+ })
75
+ .then(function (res) {
76
+ if (!res[1])
77
+ throw {
78
+ error: 'token-undefined',
79
+ htmlData: res[0]
80
+ }
81
+ ctx.access_token = res[1][1];
82
+ return pCb(null, res[1][1]);
83
+ })
84
+ .catch(function (err) {
85
+ utils.error('getAccess', err.error || err);
86
+ return pCb(err);
87
+ });
88
+
89
+ return rtPromise;
90
+ }
91
+
92
+ if (authCode.length == 6 && !isNaN(authCode))
93
+ submitCode(authCode.toString());
94
+ else if (typeof callback == 'function')
95
+ throw {
96
+ error: 'submitCode',
97
+ continue: submitCode
98
+ }
99
+ else
100
+ throw {
101
+ error: 'authentication code must be string or number or callback must be a function to continue'
102
+ }
103
+ })
104
+ .catch(function (err) {
105
+ utils.error('getAccess', typeof callback == 'function' ? (err.error || err) : err);
106
+ return cb(err);
107
+ });
108
+
109
+ return rt;
110
+ }
111
+ }
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+
3
+ var utils = require('../utils');
4
+ //NethWs3Dev
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
+ utils.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
+ utils.error('getAvatarUser', err);
73
+ return cb(err);
74
+ });
75
+
76
+ return rtPromise;
77
+ }
78
+ }
@@ -0,0 +1,43 @@
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
+ utils.log("Fetching account info...");
23
+ api.httpGet(`https://www.facebook.com/profile.php?id=${ctx.userID}`, null, {
24
+ customUserAgent: utils.windowsUserAgent
25
+ }, (err, data) => {
26
+ if (err) throw err;
27
+ const profileMatch = data.match(/"CurrentUserInitialData",\[\],\{(.*?)\},(.*?)\]/);
28
+ if (profileMatch && profileMatch[1]){
29
+ const accountJson = JSON.parse(`{${profileMatch[1]}}`);
30
+ accountJson.name = accountJson.NAME;
31
+ accountJson.uid = accountJson.USER_ID;
32
+ delete accountJson.NAME;
33
+ delete accountJson.USER_ID;
34
+ return callback(null, {
35
+ ...accountJson
36
+ });
37
+ } 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." });
38
+ }, true);
39
+ return returnPromise;
40
+ };
41
+ };
42
+
43
+
package/src/getCtx.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ module.exports = function (defaultFuncs, api, ctx) {
4
+ return (str) => ctx[str];
5
+ };
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+
3
+ module.exports = (defaultFuncs, api, ctx) => {
4
+ return () => {
5
+ return ctx.userID;
6
+ };
7
+ };
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ const util = require("util");
4
+
5
+ module.exports = function () {
6
+ return function getEmojiUrl(c, size, pixelRatio) {
7
+ /*
8
+ Resolves Facebook Messenger emoji image asset URL for an emoji character.
9
+ Supported sizes are 32, 64, and 128.
10
+ Supported pixel ratios are '1.0' and '1.5' (possibly more; haven't tested)
11
+ */
12
+ const baseUrl = "https://static.xx.fbcdn.net/images/emoji.php/v8/z%s/%s";
13
+ pixelRatio = pixelRatio || "1.0";
14
+
15
+ const ending = util.format(
16
+ "%s/%s/%s.png",
17
+ pixelRatio,
18
+ size,
19
+ c.codePointAt(0).toString(16),
20
+ );
21
+ let base = 317426846;
22
+ for (let i = 0; i < ending.length; i++) {
23
+ base = (base << 5) - base + ending.charCodeAt(i);
24
+ }
25
+
26
+ const hashed = (base & 255).toString(16);
27
+ return util.format(baseUrl, hashed, ending);
28
+ };
29
+ };
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ // [almost] copy pasted from one of FB's minified file (GenderConst)
7
+ const GENDERS = {
8
+ 0: "unknown",
9
+ 1: "female_singular",
10
+ 2: "male_singular",
11
+ 3: "female_singular_guess",
12
+ 4: "male_singular_guess",
13
+ 5: "mixed",
14
+ 6: "neuter_singular",
15
+ 7: "unknown_singular",
16
+ 8: "female_plural",
17
+ 9: "male_plural",
18
+ 10: "neuter_plural",
19
+ 11: "unknown_plural",
20
+ };
21
+
22
+ function formatData(obj) {
23
+ return Object.keys(obj).map(function (key) {
24
+ const user = obj[key];
25
+ return {
26
+ alternateName: user.alternateName,
27
+ firstName: user.firstName,
28
+ gender: GENDERS[user.gender],
29
+ userID: utils.formatID(user.id.toString()),
30
+ isFriend: user.is_friend != null && user.is_friend ? true : false,
31
+ fullName: user.name,
32
+ profilePicture: user.thumbSrc,
33
+ type: user.type,
34
+ profileUrl: user.uri,
35
+ vanity: user.vanity,
36
+ isBirthday: !!user.is_birthday,
37
+ };
38
+ });
39
+ }
40
+
41
+ module.exports = function (defaultFuncs, api, ctx) {
42
+ return function getFriendsList(callback) {
43
+ let resolveFunc = function () {};
44
+ let rejectFunc = function () {};
45
+ const returnPromise = new Promise(function (resolve, reject) {
46
+ resolveFunc = resolve;
47
+ rejectFunc = reject;
48
+ });
49
+
50
+ if (!callback) {
51
+ callback = function (err, friendList) {
52
+ if (err) {
53
+ return rejectFunc(err);
54
+ }
55
+ resolveFunc(friendList);
56
+ };
57
+ }
58
+
59
+ defaultFuncs
60
+ .postFormData(
61
+ "https://www.facebook.com/chat/user_info_all",
62
+ ctx.jar,
63
+ {},
64
+ { viewer: ctx.userID },
65
+ )
66
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
67
+ .then(function (resData) {
68
+ if (!resData) {
69
+ throw { error: "getFriendsList returned empty object." };
70
+ }
71
+ if (resData.error) {
72
+ throw resData;
73
+ }
74
+ callback(null, formatData(resData.payload));
75
+ })
76
+ .catch(function (err) {
77
+ utils.error("getFriendsList", err);
78
+ return callback(err);
79
+ });
80
+
81
+ return returnPromise;
82
+ };
83
+ };