fca-orion-api 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 (57) hide show
  1. package/config.js +5 -0
  2. package/data/fcaVersion.json +0 -0
  3. package/index.js +417 -0
  4. package/instantUpdate.js +40 -0
  5. package/package.json +30 -0
  6. package/src/addExternalModule.js +19 -0
  7. package/src/addUserToGroup.js +113 -0
  8. package/src/changeAdminStatus.js +79 -0
  9. package/src/changeArchivedStatus.js +55 -0
  10. package/src/changeAvatar.js +126 -0
  11. package/src/changeBio.js +77 -0
  12. package/src/changeBlockedStatus.js +47 -0
  13. package/src/changeGroupImage.js +132 -0
  14. package/src/changeNickname.js +59 -0
  15. package/src/changeThreadColor.js +65 -0
  16. package/src/changeThreadEmoji.js +55 -0
  17. package/src/createNewGroup.js +86 -0
  18. package/src/createPoll.js +71 -0
  19. package/src/deleteMessage.js +56 -0
  20. package/src/deleteThread.js +56 -0
  21. package/src/forwardAttachment.js +60 -0
  22. package/src/getCurrentUserID.js +7 -0
  23. package/src/getEmojiUrl.js +29 -0
  24. package/src/getFriendsList.js +83 -0
  25. package/src/getMessage.js +796 -0
  26. package/src/getThreadHistory.js +666 -0
  27. package/src/getThreadInfo.js +232 -0
  28. package/src/getThreadList.js +241 -0
  29. package/src/getThreadPictures.js +79 -0
  30. package/src/getUserID.js +66 -0
  31. package/src/getUserInfo.js +74 -0
  32. package/src/handleFriendRequest.js +61 -0
  33. package/src/handleMessageRequest.js +65 -0
  34. package/src/httpGet.js +57 -0
  35. package/src/httpPost.js +57 -0
  36. package/src/httpPostFormData.js +63 -0
  37. package/src/listenMqtt.js +853 -0
  38. package/src/logout.js +75 -0
  39. package/src/markAsDelivered.js +58 -0
  40. package/src/markAsRead.js +80 -0
  41. package/src/markAsReadAll.js +50 -0
  42. package/src/markAsSeen.js +59 -0
  43. package/src/muteThread.js +52 -0
  44. package/src/refreshFb_dtsg.js +81 -0
  45. package/src/removeUserFromGroup.js +79 -0
  46. package/src/resolvePhotoUrl.js +45 -0
  47. package/src/searchForThread.js +53 -0
  48. package/src/sendMessage.js +477 -0
  49. package/src/sendTypingIndicator.js +103 -0
  50. package/src/setMessageReaction.js +121 -0
  51. package/src/setPostReaction.js +109 -0
  52. package/src/setTitle.js +86 -0
  53. package/src/threadColors.js +131 -0
  54. package/src/unfriend.js +52 -0
  55. package/src/unsendMessage.js +49 -0
  56. package/src/uploadAttachment.js +95 -0
  57. package/utils.js +1545 -0
@@ -0,0 +1,109 @@
1
+ /**
2
+ * @fix by NTKhang
3
+ * update as Thursday, 10 February 2022
4
+ * do not remove the author name to get more updates
5
+ */
6
+
7
+ "use strict";
8
+
9
+ const utils = require("../utils");
10
+ const log = require("npmlog");
11
+
12
+ function formatData(resData) {
13
+ return {
14
+ viewer_feedback_reaction_info: resData.feedback_react.feedback.viewer_feedback_reaction_info,
15
+ supported_reactions: resData.feedback_react.feedback.supported_reactions,
16
+ top_reactions: resData.feedback_react.feedback.top_reactions.edges,
17
+ reaction_count: resData.feedback_react.feedback.reaction_count
18
+ };
19
+ }
20
+
21
+ module.exports = function (defaultFuncs, api, ctx) {
22
+ return function setPostReaction(postID, type, callback) {
23
+ let resolveFunc = function () { };
24
+ let rejectFunc = function () { };
25
+ const returnPromise = new Promise(function (resolve, reject) {
26
+ resolveFunc = resolve;
27
+ rejectFunc = reject;
28
+ });
29
+
30
+ if (!callback) {
31
+ if (utils.getType(type) === "Function" || utils.getType(type) === "AsyncFunction") {
32
+ callback = type;
33
+ type = 0;
34
+ }
35
+ else {
36
+ callback = function (err, data) {
37
+ if (err) {
38
+ return rejectFunc(err);
39
+ }
40
+ resolveFunc(data);
41
+ };
42
+ }
43
+ }
44
+
45
+ const map = {
46
+ unlike: 0,
47
+ like: 1,
48
+ heart: 2,
49
+ love: 16,
50
+ haha: 4,
51
+ wow: 3,
52
+ sad: 7,
53
+ angry: 8
54
+ };
55
+
56
+ if (utils.getType(type) !== "Number" && utils.getType(type) === "String") {
57
+ type = map[type.toLowerCase()];
58
+ }
59
+
60
+ if (utils.getType(type) !== "Number" && utils.getType(type) !== "String") {
61
+ throw {
62
+ error: "setPostReaction: Invalid reaction type"
63
+ };
64
+ }
65
+
66
+ if (type != 0 && !type) {
67
+ throw {
68
+ error: "setPostReaction: Invalid reaction type"
69
+ };
70
+ }
71
+
72
+ const form = {
73
+ av: ctx.i_userID || ctx.userID,
74
+ fb_api_caller_class: "RelayModern",
75
+ fb_api_req_friendly_name: "CometUFIFeedbackReactMutation",
76
+ doc_id: "4769042373179384",
77
+ variables: JSON.stringify({
78
+ input: {
79
+ actor_id: ctx.i_userID || ctx.userID,
80
+ feedback_id: (new Buffer("feedback:" + postID)).toString("base64"),
81
+ feedback_reaction: type,
82
+ feedback_source: "OBJECT",
83
+ is_tracking_encrypted: true,
84
+ tracking: [],
85
+ session_id: "f7dd50dd-db6e-4598-8cd9-561d5002b423",
86
+ client_mutation_id: Math.round(Math.random() * 19).toString()
87
+ },
88
+ useDefaultActor: false,
89
+ scale: 3
90
+ })
91
+ };
92
+
93
+ defaultFuncs
94
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
95
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
96
+ .then(function (resData) {
97
+ if (resData.errors) {
98
+ throw resData;
99
+ }
100
+ return callback(null, formatData(resData.data));
101
+ })
102
+ .catch(function (err) {
103
+ log.error("setPostReaction", err);
104
+ return callback(err);
105
+ });
106
+
107
+ return returnPromise;
108
+ };
109
+ };
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ const log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function setTitle(newTitle, threadID, callback) {
8
+ if (
9
+ !callback &&
10
+ (utils.getType(threadID) === "Function" ||
11
+ utils.getType(threadID) === "AsyncFunction")
12
+ ) {
13
+ throw { error: "please pass a threadID as a second argument." };
14
+ }
15
+
16
+ let resolveFunc = function () { };
17
+ let rejectFunc = function () { };
18
+ const returnPromise = new Promise(function (resolve, reject) {
19
+ resolveFunc = resolve;
20
+ rejectFunc = reject;
21
+ });
22
+
23
+ if (!callback) {
24
+ callback = function (err, friendList) {
25
+ if (err) {
26
+ return rejectFunc(err);
27
+ }
28
+ resolveFunc(friendList);
29
+ };
30
+ }
31
+
32
+ const messageAndOTID = utils.generateOfflineThreadingID();
33
+ const form = {
34
+ client: "mercury",
35
+ action_type: "ma-type:log-message",
36
+ author: "fbid:" + (ctx.i_userID || ctx.userID),
37
+ author_email: "",
38
+ coordinates: "",
39
+ timestamp: Date.now(),
40
+ timestamp_absolute: "Today",
41
+ timestamp_relative: utils.generateTimestampRelative(),
42
+ timestamp_time_passed: "0",
43
+ is_unread: false,
44
+ is_cleared: false,
45
+ is_forward: false,
46
+ is_filtered_content: false,
47
+ is_spoof_warning: false,
48
+ source: "source:chat:web",
49
+ "source_tags[0]": "source:chat",
50
+ status: "0",
51
+ offline_threading_id: messageAndOTID,
52
+ message_id: messageAndOTID,
53
+ threading_id: utils.generateThreadingID(ctx.clientID),
54
+ manual_retry_cnt: "0",
55
+ thread_fbid: threadID,
56
+ thread_name: newTitle,
57
+ thread_id: threadID,
58
+ log_message_type: "log:thread-name"
59
+ };
60
+
61
+ defaultFuncs
62
+ .post("https://www.facebook.com/messaging/set_thread_name/", ctx.jar, form)
63
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
64
+ .then(function (resData) {
65
+ if (resData.error && resData.error === 1545012) {
66
+ throw { error: "Cannot change chat title: Not member of chat." };
67
+ }
68
+
69
+ if (resData.error && resData.error === 1545003) {
70
+ throw { error: "Cannot set title of single-user chat." };
71
+ }
72
+
73
+ if (resData.error) {
74
+ throw resData;
75
+ }
76
+
77
+ return callback();
78
+ })
79
+ .catch(function (err) {
80
+ log.error("setTitle", err);
81
+ return callback(err);
82
+ });
83
+
84
+ return returnPromise;
85
+ };
86
+ };
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+
3
+ module.exports = function (_defaultFuncs, _api, _ctx) {
4
+ // Currently the only colors that can be passed to api.changeThreadColor(); may change if Facebook adds more
5
+ return {
6
+ //Old hex colors.
7
+ ////MessengerBlue: null,
8
+ ////Viking: "#44bec7",
9
+ ////GoldenPoppy: "#ffc300",
10
+ ////RadicalRed: "#fa3c4c",
11
+ ////Shocking: "#d696bb",
12
+ ////PictonBlue: "#6699cc",
13
+ ////FreeSpeechGreen: "#13cf13",
14
+ ////Pumpkin: "#ff7e29",
15
+ ////LightCoral: "#e68585",
16
+ ////MediumSlateBlue: "#7646ff",
17
+ ////DeepSkyBlue: "#20cef5",
18
+ ////Fern: "#67b868",
19
+ ////Cameo: "#d4a88c",
20
+ ////BrilliantRose: "#ff5ca1",
21
+ ////BilobaFlower: "#a695c7"
22
+
23
+ //#region This part is for backward compatibly
24
+ //trying to match the color one-by-one. kill me plz
25
+ MessengerBlue: "196241301102133", //DefaultBlue
26
+ Viking: "1928399724138152", //TealBlue
27
+ GoldenPoppy: "174636906462322", //Yellow
28
+ RadicalRed: "2129984390566328", //Red
29
+ Shocking: "2058653964378557", //LavenderPurple
30
+ FreeSpeechGreen: "2136751179887052", //Green
31
+ Pumpkin: "175615189761153", //Orange
32
+ LightCoral: "980963458735625", //CoralPink
33
+ MediumSlateBlue: "234137870477637", //BrightPurple
34
+ DeepSkyBlue: "2442142322678320", //AquaBlue
35
+ BrilliantRose: "169463077092846", //HotPink
36
+ //i've tried my best, everything else can't be mapped. (or is it?) -UIRI 2020
37
+ //#endregion
38
+
39
+ DefaultBlue: "196241301102133",
40
+ HotPink: "169463077092846",
41
+ AquaBlue: "2442142322678320",
42
+ BrightPurple: "234137870477637",
43
+ CoralPink: "980963458735625",
44
+ Orange: "175615189761153",
45
+ Green: "2136751179887052",
46
+ LavenderPurple: "2058653964378557",
47
+ Red: "2129984390566328",
48
+ Yellow: "174636906462322",
49
+ TealBlue: "1928399724138152",
50
+ Aqua: "417639218648241",
51
+ Mango: "930060997172551",
52
+ Berry: "164535220883264",
53
+ Citrus: "370940413392601",
54
+ Candy: "205488546921017",
55
+
56
+ /**
57
+ * July 06, 2022
58
+ * added by @NTKhang
59
+ */
60
+ Earth: "1833559466821043",
61
+ Support: "365557122117011",
62
+ Music: "339021464972092",
63
+ Pride: "1652456634878319",
64
+ DoctorStrange: "538280997628317",
65
+ LoFi: "1060619084701625",
66
+ Sky: "3190514984517598",
67
+ LunarNewYear: "357833546030778",
68
+ Celebration: "627144732056021",
69
+ Chill: "390127158985345",
70
+ StrangerThings: "1059859811490132",
71
+ Dune: "1455149831518874",
72
+ Care: "275041734441112",
73
+ Astrology: "3082966625307060",
74
+ JBalvin: "184305226956268",
75
+ Birthday: "621630955405500",
76
+ Cottagecore: "539927563794799",
77
+ Ocean: "736591620215564",
78
+ Love: "741311439775765",
79
+ TieDye: "230032715012014",
80
+ Monochrome: "788274591712841",
81
+ Default: "3259963564026002",
82
+ Rocket: "582065306070020",
83
+ Berry2: "724096885023603",
84
+ Candy2: "624266884847972",
85
+ Unicorn: "273728810607574",
86
+ Tropical: "262191918210707",
87
+ Maple: "2533652183614000",
88
+ Sushi: "909695489504566",
89
+ Citrus2: "557344741607350",
90
+ Lollipop: "280333826736184",
91
+ Shadow: "271607034185782",
92
+ Rose: "1257453361255152",
93
+ Lavender: "571193503540759",
94
+ Tulip: "2873642949430623",
95
+ Classic: "3273938616164733",
96
+ Peach: "3022526817824329",
97
+ Honey: "672058580051520",
98
+ Kiwi: "3151463484918004",
99
+ Grape: "193497045377796",
100
+
101
+ /**
102
+ * July 15, 2022
103
+ * added by @NTKhang
104
+ */
105
+ NonBinary: "737761000603635",
106
+
107
+ /**
108
+ * November 25, 2022
109
+ * added by @NTKhang
110
+ */
111
+ ThankfulForFriends: "1318983195536293",
112
+ Transgender: "504518465021637",
113
+ TaylorSwift: "769129927636836",
114
+ NationalComingOutDay: "788102625833584",
115
+ Autumn: "822549609168155",
116
+ Cyberpunk2077: "780962576430091",
117
+
118
+ /**
119
+ * May 13, 2023
120
+ */
121
+ MothersDay: "1288506208402340",
122
+ APAHM: "121771470870245",
123
+ Parenthood: "810978360551741",
124
+ StarWars: "1438011086532622",
125
+ GuardianOfTheGalaxy: "101275642962533",
126
+ Bloom: "158263147151440",
127
+ BubbleTea: "195296273246380",
128
+ Basketball: "6026716157422736",
129
+ ElephantsAndFlowers: "693996545771691"
130
+ };
131
+ };
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ const log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function unfriend(userID, 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, friendList) {
17
+ if (err) {
18
+ return rejectFunc(err);
19
+ }
20
+ resolveFunc(friendList);
21
+ };
22
+ }
23
+
24
+ const form = {
25
+ uid: userID,
26
+ unref: "bd_friends_tab",
27
+ floc: "friends_tab",
28
+ "nctr[_mod]": "pagelet_timeline_app_collection_" + (ctx.i_userID || ctx.userID) + ":2356318349:2"
29
+ };
30
+
31
+ defaultFuncs
32
+ .post(
33
+ "https://www.facebook.com/ajax/profile/removefriendconfirm.php",
34
+ ctx.jar,
35
+ form
36
+ )
37
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
38
+ .then(function (resData) {
39
+ if (resData.error) {
40
+ throw resData;
41
+ }
42
+
43
+ return callback(null, true);
44
+ })
45
+ .catch(function (err) {
46
+ log.error("unfriend", err);
47
+ return callback(err);
48
+ });
49
+
50
+ return returnPromise;
51
+ };
52
+ };
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ const log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function unsendMessage(messageID, 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, friendList) {
17
+ if (err) {
18
+ return rejectFunc(err);
19
+ }
20
+ resolveFunc(friendList);
21
+ };
22
+ }
23
+
24
+ const form = {
25
+ message_id: messageID
26
+ };
27
+
28
+ defaultFuncs
29
+ .post(
30
+ "https://www.facebook.com/messaging/unsend_message/",
31
+ ctx.jar,
32
+ form
33
+ )
34
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
35
+ .then(function (resData) {
36
+ if (resData.error) {
37
+ throw resData;
38
+ }
39
+
40
+ return callback();
41
+ })
42
+ .catch(function (err) {
43
+ log.error("unsendMessage", err);
44
+ return callback(err);
45
+ });
46
+
47
+ return returnPromise;
48
+ };
49
+ };
@@ -0,0 +1,95 @@
1
+ const utils = require("../utils");
2
+ const log = require("npmlog");
3
+
4
+ module.exports = function (defaultFuncs, api, ctx) {
5
+ function upload(attachments, callback) {
6
+ callback = callback || function () { };
7
+ const uploads = [];
8
+
9
+ // create an array of promises
10
+ for (let i = 0; i < attachments.length; i++) {
11
+ if (!utils.isReadableStream(attachments[i])) {
12
+ throw {
13
+ error:
14
+ "Attachment should be a readable stream and not " +
15
+ utils.getType(attachments[i]) +
16
+ "."
17
+ };
18
+ }
19
+
20
+ const form = {
21
+ upload_1024: attachments[i],
22
+ voice_clip: "true"
23
+ };
24
+
25
+ uploads.push(
26
+ defaultFuncs
27
+ .postFormData(
28
+ "https://upload.facebook.com/ajax/mercury/upload.php",
29
+ ctx.jar,
30
+ form,
31
+ {}
32
+ )
33
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
+ .then(function (resData) {
35
+ if (resData.error) {
36
+ throw resData;
37
+ }
38
+
39
+ // We have to return the data unformatted unless we want to change it
40
+ // back in sendMessage.
41
+ return resData.payload.metadata[0];
42
+ })
43
+ );
44
+ }
45
+
46
+ // resolve all promises
47
+ Promise
48
+ .all(uploads)
49
+ .then(function (resData) {
50
+ callback(null, resData);
51
+ })
52
+ .catch(function (err) {
53
+ log.error("uploadAttachment", err);
54
+ return callback(err);
55
+ });
56
+ }
57
+
58
+ return function uploadAttachment(attachments, callback) {
59
+ if (
60
+ !attachments &&
61
+ !utils.isReadableStream(attachments) &&
62
+ !utils.getType(attachments) === "Array" &&
63
+ (utils.getType(attachments) === "Array" && !attachments.length)
64
+ )
65
+ throw { error: "Please pass an attachment or an array of attachments." };
66
+
67
+ let resolveFunc = function () { };
68
+ let rejectFunc = function () { };
69
+ const returnPromise = new Promise(function (resolve, reject) {
70
+ resolveFunc = resolve;
71
+ rejectFunc = reject;
72
+ });
73
+
74
+ if (!callback) {
75
+ callback = function (err, info) {
76
+ if (err) {
77
+ return rejectFunc(err);
78
+ }
79
+ resolveFunc(info);
80
+ };
81
+ }
82
+
83
+ if (utils.getType(attachments) !== "Array")
84
+ attachments = [attachments];
85
+
86
+ upload(attachments, (err, info) => {
87
+ if (err) {
88
+ return callback(err);
89
+ }
90
+ callback(null, info);
91
+ });
92
+
93
+ return returnPromise;
94
+ };
95
+ };