@dongdev/fca-unofficial 3.0.30 → 4.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 (104) hide show
  1. package/LICENSE +191 -0
  2. package/README.md +224 -406
  3. package/dist/index.d.mts +1241 -0
  4. package/dist/index.d.ts +1241 -0
  5. package/dist/index.js +27749 -0
  6. package/dist/index.mjs +27713 -0
  7. package/docs/ARCHITECTURE.md +467 -0
  8. package/docs/DOCS.md +686 -0
  9. package/fca-config.example.json +33 -0
  10. package/package.json +33 -22
  11. package/test/fca.test.cjs +533 -0
  12. package/CHANGELOG.md +0 -293
  13. package/DOCS.md +0 -2712
  14. package/func/checkUpdate.js +0 -222
  15. package/func/logAdapter.js +0 -33
  16. package/func/logger.js +0 -48
  17. package/index.d.ts +0 -751
  18. package/index.js +0 -8
  19. package/module/config.js +0 -40
  20. package/module/login.js +0 -133
  21. package/module/loginHelper.js +0 -1296
  22. package/module/options.js +0 -44
  23. package/src/api/action/addExternalModule.js +0 -25
  24. package/src/api/action/changeAvatar.js +0 -137
  25. package/src/api/action/changeBio.js +0 -75
  26. package/src/api/action/enableAutoSaveAppState.js +0 -73
  27. package/src/api/action/getCurrentUserID.js +0 -7
  28. package/src/api/action/handleFriendRequest.js +0 -57
  29. package/src/api/action/logout.js +0 -76
  30. package/src/api/action/refreshFb_dtsg.js +0 -48
  31. package/src/api/action/setPostReaction.js +0 -106
  32. package/src/api/action/unfriend.js +0 -54
  33. package/src/api/http/httpGet.js +0 -46
  34. package/src/api/http/httpPost.js +0 -52
  35. package/src/api/http/postFormData.js +0 -47
  36. package/src/api/messaging/addUserToGroup.js +0 -68
  37. package/src/api/messaging/changeAdminStatus.js +0 -126
  38. package/src/api/messaging/changeArchivedStatus.js +0 -55
  39. package/src/api/messaging/changeBlockedStatus.js +0 -48
  40. package/src/api/messaging/changeGroupImage.js +0 -91
  41. package/src/api/messaging/changeNickname.js +0 -70
  42. package/src/api/messaging/changeThreadColor.js +0 -79
  43. package/src/api/messaging/changeThreadEmoji.js +0 -111
  44. package/src/api/messaging/createNewGroup.js +0 -88
  45. package/src/api/messaging/createPoll.js +0 -46
  46. package/src/api/messaging/createThemeAI.js +0 -98
  47. package/src/api/messaging/deleteMessage.js +0 -136
  48. package/src/api/messaging/deleteThread.js +0 -56
  49. package/src/api/messaging/editMessage.js +0 -68
  50. package/src/api/messaging/forwardAttachment.js +0 -57
  51. package/src/api/messaging/getEmojiUrl.js +0 -29
  52. package/src/api/messaging/getFriendsList.js +0 -82
  53. package/src/api/messaging/getMessage.js +0 -829
  54. package/src/api/messaging/getThemePictures.js +0 -62
  55. package/src/api/messaging/handleMessageRequest.js +0 -65
  56. package/src/api/messaging/markAsDelivered.js +0 -57
  57. package/src/api/messaging/markAsRead.js +0 -88
  58. package/src/api/messaging/markAsReadAll.js +0 -49
  59. package/src/api/messaging/markAsSeen.js +0 -61
  60. package/src/api/messaging/muteThread.js +0 -50
  61. package/src/api/messaging/removeUserFromGroup.js +0 -62
  62. package/src/api/messaging/resolvePhotoUrl.js +0 -43
  63. package/src/api/messaging/scheduler.js +0 -264
  64. package/src/api/messaging/searchForThread.js +0 -52
  65. package/src/api/messaging/sendMessage.js +0 -270
  66. package/src/api/messaging/sendTypingIndicator.js +0 -74
  67. package/src/api/messaging/setMessageReaction.js +0 -91
  68. package/src/api/messaging/setTitle.js +0 -124
  69. package/src/api/messaging/shareContact.js +0 -49
  70. package/src/api/messaging/threadColors.js +0 -128
  71. package/src/api/messaging/unsendMessage.js +0 -81
  72. package/src/api/messaging/uploadAttachment.js +0 -492
  73. package/src/api/socket/core/connectMqtt.js +0 -258
  74. package/src/api/socket/core/emitAuth.js +0 -103
  75. package/src/api/socket/core/getSeqID.js +0 -320
  76. package/src/api/socket/core/getTaskResponseData.js +0 -25
  77. package/src/api/socket/core/parseDelta.js +0 -377
  78. package/src/api/socket/detail/buildStream.js +0 -215
  79. package/src/api/socket/detail/constants.js +0 -28
  80. package/src/api/socket/listenMqtt.js +0 -377
  81. package/src/api/socket/middleware/index.js +0 -216
  82. package/src/api/threads/getThreadHistory.js +0 -664
  83. package/src/api/threads/getThreadInfo.js +0 -295
  84. package/src/api/threads/getThreadList.js +0 -293
  85. package/src/api/threads/getThreadPictures.js +0 -78
  86. package/src/api/users/getUserID.js +0 -65
  87. package/src/api/users/getUserInfo.js +0 -399
  88. package/src/api/users/getUserInfoV2.js +0 -134
  89. package/src/core/sendReqMqtt.js +0 -96
  90. package/src/database/models/index.js +0 -87
  91. package/src/database/models/thread.js +0 -50
  92. package/src/database/models/user.js +0 -46
  93. package/src/database/threadData.js +0 -98
  94. package/src/database/userData.js +0 -89
  95. package/src/remote/remoteClient.js +0 -123
  96. package/src/utils/broadcast.js +0 -51
  97. package/src/utils/client.js +0 -10
  98. package/src/utils/constants.js +0 -23
  99. package/src/utils/cookies.js +0 -68
  100. package/src/utils/format.js +0 -1174
  101. package/src/utils/headers.js +0 -115
  102. package/src/utils/loginParser.js +0 -365
  103. package/src/utils/messageFormat.js +0 -1173
  104. package/src/utils/request.js +0 -332
@@ -1,62 +0,0 @@
1
- "use strict";
2
-
3
- const log = require("../../../func/logAdapter");
4
- const { parseAndCheckLogin } = require("../../utils/client");
5
- const { getType } = require("../../utils/format");
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- return function getThemePictures(id, 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
- if (
17
- getType(callback) == "Function" ||
18
- getType(callback) == "AsyncFunction"
19
- ) {
20
- callback = callback;
21
- } else {
22
- callback = function (err, data) {
23
- if (err) {
24
- return rejectFunc(err);
25
- }
26
- resolveFunc(data);
27
- };
28
- }
29
- }
30
-
31
- if (getType(id) != "String") {
32
- id = "";
33
- }
34
-
35
- const form = {
36
- fb_api_caller_class: "RelayModern",
37
- fb_api_req_friendly_name: "MWPThreadThemeProviderQuery",
38
- doc_id: "9734829906576883",
39
- server_timestamps: true,
40
- variables: JSON.stringify({
41
- id
42
- }),
43
- av: ctx.userID
44
- };
45
- defaultFuncs
46
- .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
47
- .then(parseAndCheckLogin(ctx, defaultFuncs))
48
- .then(function (resData) {
49
- if (resData.errors) {
50
- throw resData;
51
- }
52
-
53
- return callback(null, resData);
54
- })
55
- .catch(function (err) {
56
- log.error("getThemePictures", err);
57
- return callback(err);
58
- });
59
-
60
- return returnPromise;
61
- };
62
- };
@@ -1,65 +0,0 @@
1
- "use strict";
2
-
3
- const log = require("../../../func/logAdapter");
4
- const { parseAndCheckLogin } = require("../../utils/client");
5
- const { getType } = require("../../utils/format");
6
- module.exports = function(defaultFuncs, api, ctx) {
7
- return function handleMessageRequest(threadID, accept, callback) {
8
- if (getType(accept) !== "Boolean") {
9
- throw {
10
- error: "Please pass a boolean as a second argument."
11
- };
12
- }
13
-
14
- let resolveFunc = function() {};
15
- let rejectFunc = function() {};
16
- const returnPromise = new Promise(function(resolve, reject) {
17
- resolveFunc = resolve;
18
- rejectFunc = reject;
19
- });
20
-
21
- if (!callback) {
22
- callback = function(err, friendList) {
23
- if (err) {
24
- return rejectFunc(err);
25
- }
26
- resolveFunc(friendList);
27
- };
28
- }
29
-
30
- const form = {
31
- client: "mercury"
32
- };
33
-
34
- if (getType(threadID) !== "Array") {
35
- threadID = [threadID];
36
- }
37
-
38
- const messageBox = accept ? "inbox" : "other";
39
-
40
- for (let i = 0; i < threadID.length; i++) {
41
- form[messageBox + "[" + i + "]"] = threadID[i];
42
- }
43
-
44
- defaultFuncs
45
- .post(
46
- "https://www.facebook.com/ajax/mercury/move_thread.php",
47
- ctx.jar,
48
- form
49
- )
50
- .then(parseAndCheckLogin(ctx, defaultFuncs))
51
- .then(function(resData) {
52
- if (resData.error) {
53
- throw resData;
54
- }
55
-
56
- return callback();
57
- })
58
- .catch(function(err) {
59
- log.error("handleMessageRequest", err);
60
- return callback(err);
61
- });
62
-
63
- return returnPromise;
64
- };
65
- };
@@ -1,57 +0,0 @@
1
- "use strict";
2
- const log = require("../../../func/logAdapter");
3
- const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
4
- const { getType } = require("../../utils/format");
5
- module.exports = function(defaultFuncs, api, ctx) {
6
- return function markAsDelivered(threadID, messageID, callback) {
7
- let resolveFunc = function() {};
8
- let rejectFunc = function() {};
9
- const returnPromise = new Promise(function(resolve, reject) {
10
- resolveFunc = resolve;
11
- rejectFunc = reject;
12
- });
13
-
14
- if (!callback) {
15
- callback = function(err, friendList) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc(friendList);
20
- };
21
- }
22
-
23
- if (!threadID || !messageID) {
24
- return callback("Error: messageID or threadID is not defined");
25
- }
26
-
27
- const form = {};
28
-
29
- form["message_ids[0]"] = messageID;
30
- form["thread_ids[" + threadID + "][0]"] = messageID;
31
-
32
- defaultFuncs
33
- .post(
34
- "https://www.facebook.com/ajax/mercury/delivery_receipts.php",
35
- ctx.jar,
36
- form
37
- )
38
- .then(saveCookies(ctx.jar))
39
- .then(parseAndCheckLogin(ctx, defaultFuncs))
40
- .then(function(resData) {
41
- if (resData.error) {
42
- throw resData;
43
- }
44
-
45
- return callback();
46
- })
47
- .catch(function(err) {
48
- log.error("markAsDelivered", err);
49
- if (getType(err) == "Object" && err.error === "Not logged in.") {
50
- ctx.loggedIn = false;
51
- }
52
- return callback(err);
53
- });
54
-
55
- return returnPromise;
56
- };
57
- };
@@ -1,88 +0,0 @@
1
- "use strict";
2
-
3
- const log = require("../../../func/logAdapter");
4
- const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
5
- const { getType } = require("../../utils/format");
6
- module.exports = function(defaultFuncs, api, ctx) {
7
- return async function markAsRead(threadID, read, callback) {
8
- if (
9
- getType(read) === "Function" ||
10
- getType(read) === "AsyncFunction"
11
- ) {
12
- callback = read;
13
- read = true;
14
- }
15
- if (read == undefined) {
16
- read = true;
17
- }
18
-
19
- if (!callback) {
20
- callback = () => {};
21
- }
22
-
23
- const form = {};
24
-
25
- if (typeof ctx.globalOptions.pageID !== "undefined") {
26
- form["source"] = "PagesManagerMessagesInterface";
27
- form["request_user_id"] = ctx.globalOptions.pageID;
28
- form["ids[" + threadID + "]"] = read;
29
- form["watermarkTimestamp"] = new Date().getTime();
30
- form["shouldSendReadReceipt"] = true;
31
- form["commerce_last_message_type"] = "";
32
- //form["titanOriginatedThreadId"] = utils.generateThreadingID(ctx.clientID);
33
-
34
- let resData;
35
- try {
36
- resData = await defaultFuncs
37
- .post(
38
- "https://www.facebook.com/ajax/mercury/change_read_status.php",
39
- ctx.jar,
40
- form
41
- )
42
- .then(saveCookies(ctx.jar))
43
- .then(parseAndCheckLogin(ctx, defaultFuncs));
44
- } catch (e) {
45
- callback(e);
46
- return e;
47
- }
48
-
49
- if (resData.error) {
50
- const err = resData.error;
51
- log.error("markAsRead", err);
52
- if (getType(err) == "Object" && err.error === "Not logged in.") {
53
- ctx.loggedIn = false;
54
- }
55
- callback(err);
56
- return err;
57
- }
58
-
59
- callback();
60
- return null;
61
- } else {
62
- try {
63
- if (ctx.mqttClient) {
64
- const err = await new Promise(r =>
65
- ctx.mqttClient.publish(
66
- "/mark_thread",
67
- JSON.stringify({
68
- threadID,
69
- mark: "read",
70
- state: read
71
- }),
72
- { qos: 1, retain: false },
73
- r
74
- )
75
- );
76
- if (err) throw err;
77
- } else {
78
- throw {
79
- error: "You can only use this function after you start listening."
80
- };
81
- }
82
- } catch (e) {
83
- callback(e);
84
- return e;
85
- }
86
- }
87
- };
88
- };
@@ -1,49 +0,0 @@
1
- "use strict";
2
-
3
- const log = require("../../../func/logAdapter");
4
- const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
5
- module.exports = function(defaultFuncs, api, ctx) {
6
- return function markAsReadAll(callback) {
7
- let resolveFunc = function() {};
8
- let rejectFunc = function() {};
9
- const returnPromise = new Promise(function(resolve, reject) {
10
- resolveFunc = resolve;
11
- rejectFunc = reject;
12
- });
13
-
14
- if (!callback) {
15
- callback = function(err, friendList) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc(friendList);
20
- };
21
- }
22
-
23
- const form = {
24
- folder: "inbox"
25
- };
26
-
27
- defaultFuncs
28
- .post(
29
- "https://www.facebook.com/ajax/mercury/mark_folder_as_read.php",
30
- ctx.jar,
31
- form
32
- )
33
- .then(saveCookies(ctx.jar))
34
- .then(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("markAsReadAll", err);
44
- return callback(err);
45
- });
46
-
47
- return returnPromise;
48
- };
49
- };
@@ -1,61 +0,0 @@
1
- "use strict";
2
-
3
- const log = require("../../../func/logAdapter");
4
- const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
5
- const { getType } = require("../../utils/format");
6
- module.exports = function(defaultFuncs, api, ctx) {
7
- return function markAsRead(seen_timestamp, callback) {
8
- if (
9
- getType(seen_timestamp) == "Function" ||
10
- getType(seen_timestamp) == "AsyncFunction"
11
- ) {
12
- callback = seen_timestamp;
13
- seen_timestamp = Date.now();
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 form = {
33
- seen_timestamp: seen_timestamp
34
- };
35
-
36
- defaultFuncs
37
- .post(
38
- "https://www.facebook.com/ajax/mercury/mark_seen.php",
39
- ctx.jar,
40
- form
41
- )
42
- .then(saveCookies(ctx.jar))
43
- .then(parseAndCheckLogin(ctx, defaultFuncs))
44
- .then(function(resData) {
45
- if (resData.error) {
46
- throw resData;
47
- }
48
-
49
- return callback();
50
- })
51
- .catch(function(err) {
52
- log.error("markAsSeen", err);
53
- if (getType(err) == "Object" && err.error === "Not logged in.") {
54
- ctx.loggedIn = false;
55
- }
56
- return callback(err);
57
- });
58
-
59
- return returnPromise;
60
- };
61
- };
@@ -1,50 +0,0 @@
1
- "use strict";
2
- const log = require("../../../func/logAdapter");
3
- const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
4
- module.exports = function(defaultFuncs, api, ctx) {
5
- // muteSecond: -1=permanent mute, 0=unmute, 60=one minute, 3600=one hour, etc.
6
- return function muteThread(threadID, muteSeconds, callback) {
7
- let resolveFunc = function() {};
8
- let rejectFunc = function() {};
9
- const returnPromise = new Promise(function(resolve, reject) {
10
- resolveFunc = resolve;
11
- rejectFunc = reject;
12
- });
13
-
14
- if (!callback) {
15
- callback = function(err, friendList) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc(friendList);
20
- };
21
- }
22
-
23
- const form = {
24
- thread_fbid: threadID,
25
- mute_settings: muteSeconds
26
- };
27
-
28
- defaultFuncs
29
- .post(
30
- "https://www.facebook.com/ajax/mercury/change_mute_thread.php",
31
- ctx.jar,
32
- form
33
- )
34
- .then(saveCookies(ctx.jar))
35
- .then(parseAndCheckLogin(ctx, defaultFuncs))
36
- .then(function(resData) {
37
- if (resData.error) {
38
- throw resData;
39
- }
40
-
41
- return callback();
42
- })
43
- .catch(function(err) {
44
- log.error("muteThread", err);
45
- return callback(err);
46
- });
47
-
48
- return returnPromise;
49
- };
50
- };
@@ -1,62 +0,0 @@
1
- "use strict";
2
-
3
- const { getType, generateOfflineThreadingID } = require("../../utils/format");
4
-
5
- module.exports = function (defaultFuncs, api, ctx) {
6
- return function removeUserFromGroup(userID, threadID, callback) {
7
- if (!ctx.mqttClient) {
8
- const err = new Error("Not connected to MQTT");
9
- if (callback) return callback(err);
10
- return Promise.reject(err);
11
- }
12
- if (!callback && (getType(threadID) === "Function" || getType(threadID) === "AsyncFunction")) throw { error: "please pass a threadID as a second argument." };
13
- if (getType(threadID) !== "Number" && getType(threadID) !== "String") throw { error: "threadID should be of type Number or String and not " + getType(threadID) + "." };
14
- if (getType(userID) !== "Number" && getType(userID) !== "String") throw { error: "userID should be of type Number or String and not " + getType(userID) + "." };
15
- var resolveFunc = function () { };
16
- var rejectFunc = function () { };
17
- var returnPromise = new Promise(function (resolve, reject) {
18
- resolveFunc = resolve;
19
- rejectFunc = reject;
20
- });
21
- if (!callback) {
22
- callback = function (err, data) {
23
- if (err) return rejectFunc(err);
24
- resolveFunc(data);
25
- };
26
- }
27
- if (typeof ctx.wsReqNumber !== "number") ctx.wsReqNumber = 0;
28
- const reqID = ++ctx.wsReqNumber;
29
- var form = JSON.stringify({
30
- "app_id": "2220391788200892",
31
- "payload": JSON.stringify({
32
- epoch_id: generateOfflineThreadingID(),
33
- tasks: [
34
- {
35
- failure_count: null,
36
- label: '140',
37
- payload: JSON.stringify({
38
- "thread_id": threadID,
39
- "contact_id": userID,
40
- "sync_group": 1
41
- }),
42
- queue_name: 'remove_participant_v2',
43
- task_id: Math.random() * 1001 << 0
44
- }
45
- ],
46
- version_id: '25002366262773827'
47
- }),
48
- "request_id": reqID,
49
- "type": 3
50
- });
51
- ctx.mqttClient.publish('/ls_req', form, (err, data) => {
52
- if (err) {
53
- callback(err, null);
54
- rejectFunc(err);
55
- } else {
56
- callback(null, true);
57
- resolveFunc(true);
58
- }
59
- });
60
- return returnPromise;
61
- };
62
- };
@@ -1,43 +0,0 @@
1
- "use strict";
2
- const log = require("../../../func/logAdapter");
3
- const { parseAndCheckLogin, saveCookies } = require("../../utils/client");
4
- module.exports = function(defaultFuncs, api, ctx) {
5
- return function resolvePhotoUrl(photoID, callback) {
6
- let resolveFunc = function() {};
7
- let rejectFunc = function() {};
8
- const returnPromise = new Promise(function(resolve, reject) {
9
- resolveFunc = resolve;
10
- rejectFunc = reject;
11
- });
12
-
13
- if (!callback) {
14
- callback = function(err, friendList) {
15
- if (err) {
16
- return rejectFunc(err);
17
- }
18
- resolveFunc(friendList);
19
- };
20
- }
21
-
22
- defaultFuncs
23
- .get("https://www.facebook.com/mercury/attachments/photo", ctx.jar, {
24
- photo_id: photoID
25
- })
26
- .then(parseAndCheckLogin(ctx, defaultFuncs))
27
- .then(resData => {
28
- if (resData.error) {
29
- throw resData;
30
- }
31
-
32
- const photoUrl = resData.jsmods.require[0][3][0];
33
-
34
- return callback(null, photoUrl);
35
- })
36
- .catch(err => {
37
- log.error("resolvePhotoUrl", err);
38
- return callback(err);
39
- });
40
-
41
- return returnPromise;
42
- };
43
- };