@dongdev/fca-unofficial 0.0.3 → 0.0.5

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 (76) hide show
  1. package/.travis.yml +6 -6
  2. package/CHANGELOG.md +1 -1
  3. package/DOCS.md +1738 -1738
  4. package/LICENSE-MIT +21 -21
  5. package/README.md +219 -219
  6. package/index.js +267 -569
  7. package/lib/login.js +0 -0
  8. package/package.json +3 -3
  9. package/src/addExternalModule.js +19 -15
  10. package/src/addUserToGroup.js +113 -77
  11. package/src/changeAdminStatus.js +79 -47
  12. package/src/changeArchivedStatus.js +55 -41
  13. package/src/changeAvatar.js +126 -0
  14. package/src/changeBio.js +66 -54
  15. package/src/changeBlockedStatus.js +40 -29
  16. package/src/changeGroupImage.js +127 -101
  17. package/src/changeNickname.js +50 -36
  18. package/src/changeThreadColor.js +65 -61
  19. package/src/changeThreadEmoji.js +55 -41
  20. package/src/createNewGroup.js +86 -70
  21. package/src/createPoll.js +71 -59
  22. package/src/deleteMessage.js +56 -44
  23. package/src/deleteThread.js +56 -42
  24. package/src/forwardAttachment.js +60 -47
  25. package/src/getCurrentUserID.js +7 -7
  26. package/src/getEmojiUrl.js +29 -27
  27. package/src/getFriendsList.js +83 -73
  28. package/src/getMessage.js +796 -0
  29. package/src/getThreadHistory.js +666 -537
  30. package/src/getThreadInfo.js +232 -171
  31. package/src/getThreadList.js +241 -213
  32. package/src/getThreadPictures.js +79 -59
  33. package/src/getUserID.js +66 -61
  34. package/src/getUserInfo.js +74 -66
  35. package/src/handleFriendRequest.js +61 -46
  36. package/src/handleMessageRequest.js +65 -47
  37. package/src/httpGet.js +52 -44
  38. package/src/httpPost.js +52 -43
  39. package/src/httpPostFormData.js +63 -0
  40. package/src/listenMqtt.js +877 -709
  41. package/src/logout.js +62 -55
  42. package/src/markAsDelivered.js +58 -47
  43. package/src/markAsRead.js +80 -70
  44. package/src/markAsReadAll.js +49 -39
  45. package/src/markAsSeen.js +59 -48
  46. package/src/muteThread.js +52 -45
  47. package/src/postFormData.js +46 -0
  48. package/src/refreshFb_dtsg.js +81 -0
  49. package/src/removeUserFromGroup.js +79 -45
  50. package/src/resolvePhotoUrl.js +45 -36
  51. package/src/searchForThread.js +53 -42
  52. package/src/sendMessage.js +328 -328
  53. package/src/sendMessageMqtt.js +316 -0
  54. package/src/sendTypingIndicator.js +103 -70
  55. package/src/setMessageReaction.js +106 -98
  56. package/src/setPostReaction.js +102 -95
  57. package/src/setTitle.js +86 -70
  58. package/src/threadColors.js +131 -41
  59. package/src/unfriend.js +52 -42
  60. package/src/unsendMessage.js +49 -39
  61. package/src/uploadAttachment.js +95 -0
  62. package/utils.js +1470 -1196
  63. package/.gitattributes +0 -2
  64. package/src/Screenshot.js +0 -83
  65. package/src/changeAvt.js +0 -85
  66. package/src/getThreadHistoryDeprecated.js +0 -71
  67. package/src/getThreadInfoDeprecated.js +0 -56
  68. package/src/getThreadListDeprecated.js +0 -46
  69. package/src/shareContact.js +0 -46
  70. package/test/data/shareAttach.js +0 -146
  71. package/test/data/something.mov +0 -0
  72. package/test/data/test.png +0 -0
  73. package/test/data/test.txt +0 -7
  74. package/test/example-config.json +0 -18
  75. package/test/test-page.js +0 -140
  76. package/test/test.js +0 -385
@@ -1,41 +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
-
7
- //#region This part is for backward compatibly
8
- //trying to match the color one-by-one. kill me plz
9
- MessengerBlue: "196241301102133", //DefaultBlue
10
- Viking: "1928399724138152", //TealBlue
11
- GoldenPoppy: "174636906462322", //Yellow
12
- RadicalRed: "2129984390566328", //Red
13
- Shocking: "2058653964378557", //LavenderPurple
14
- FreeSpeechGreen: "2136751179887052", //Green
15
- Pumpkin: "175615189761153", //Orange
16
- LightCoral: "980963458735625", //CoralPink
17
- MediumSlateBlue: "234137870477637", //BrightPurple
18
- DeepSkyBlue: "2442142322678320", //AquaBlue
19
- BrilliantRose: "169463077092846", //HotPink
20
- //i've tried my best, everything else can't be mapped. (or is it?) -UIRI 2020
21
- //#endregion
22
-
23
- DefaultBlue: "196241301102133",
24
- HotPink: "169463077092846",
25
- AquaBlue: "2442142322678320",
26
- BrightPurple: "234137870477637",
27
- CoralPink: "980963458735625",
28
- Orange: "175615189761153",
29
- Green: "2136751179887052",
30
- LavenderPurple: "2058653964378557",
31
- Red: "2129984390566328",
32
- Yellow: "174636906462322",
33
- TealBlue: "1928399724138152",
34
- Aqua: "417639218648241",
35
- Mango: "930060997172551",
36
- Berry: "164535220883264",
37
- Citrus: "370940413392601",
38
- Candy: "205488546921017",
39
- //StarWars: "809305022860427" Removed.
40
- };
41
- };
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
+ };
package/src/unfriend.js CHANGED
@@ -1,42 +1,52 @@
1
- "use strict";
2
-
3
- var utils = require("../utils");
4
- var log = require("npmlog");
5
-
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- return function unfriend(userID, callback) {
8
- var resolveFunc = function () { };
9
- var rejectFunc = function () { };
10
- var 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) return rejectFunc(err);
18
- resolveFunc(friendList);
19
- };
20
- }
21
-
22
- var form = {
23
- uid: userID,
24
- unref: "bd_friends_tab",
25
- floc: "friends_tab",
26
- "nctr[_mod]": "pagelet_timeline_app_collection_" + ctx.userID + ":2356318349:2"
27
- };
28
-
29
- defaultFuncs
30
- .post("https://www.facebook.com/ajax/profile/removefriendconfirm.php", ctx.jar, form)
31
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
32
- .then(function (resData) {
33
- if (resData.error) throw resData;
34
- return callback();
35
- })
36
- .catch(function (err) {
37
- log.error("unfriend", err);
38
- return callback(err);
39
- });
40
- return returnPromise;
41
- };
42
- };
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
+ };
@@ -1,39 +1,49 @@
1
- "use strict";
2
-
3
- var utils = require("../utils");
4
- var log = require("npmlog");
5
-
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- return function unsendMessage(messageID, callback) {
8
- var resolveFunc = function () { };
9
- var rejectFunc = function () { };
10
- var 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) return rejectFunc(err);
18
- resolveFunc(friendList);
19
- };
20
- }
21
-
22
- var form = {
23
- message_id: messageID
24
- };
25
-
26
- defaultFuncs
27
- .post("https://www.facebook.com/messaging/unsend_message/", ctx.jar, form)
28
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
29
- .then(function (resData) {
30
- if (resData.error) throw resData;
31
- return callback();
32
- })
33
- .catch(function (err) {
34
- log.error("unsendMessage", err);
35
- return callback(err);
36
- });
37
- return returnPromise;
38
- };
39
- };
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
+ };