@dongdev/fca-unofficial 3.0.31 → 4.0.1

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 (128) hide show
  1. package/LICENSE +191 -0
  2. package/README.md +238 -398
  3. package/dist/cjs.cjs +9 -0
  4. package/dist/index.d.mts +1250 -0
  5. package/dist/index.d.ts +1250 -0
  6. package/dist/index.js +27772 -0
  7. package/dist/index.mjs +27735 -0
  8. package/docs/ARCHITECTURE.md +467 -0
  9. package/docs/DOCS.md +709 -0
  10. package/fca-config.example.json +33 -0
  11. package/package.json +32 -22
  12. package/test/fca.test.cjs +540 -0
  13. package/CHANGELOG.md +0 -296
  14. package/DOCS.md +0 -2712
  15. package/func/checkUpdate.js +0 -222
  16. package/func/logAdapter.js +0 -33
  17. package/func/logger.js +0 -48
  18. package/index.d.ts +0 -751
  19. package/index.js +0 -8
  20. package/module/config.js +0 -40
  21. package/module/login.js +0 -133
  22. package/module/loginHelper.js +0 -1296
  23. package/module/options.js +0 -44
  24. package/src/api/action/addExternalModule.js +0 -25
  25. package/src/api/action/changeAvatar.js +0 -137
  26. package/src/api/action/changeBio.js +0 -75
  27. package/src/api/action/enableAutoSaveAppState.js +0 -73
  28. package/src/api/action/getCurrentUserID.js +0 -7
  29. package/src/api/action/handleFriendRequest.js +0 -57
  30. package/src/api/action/logout.js +0 -76
  31. package/src/api/action/refreshFb_dtsg.js +0 -48
  32. package/src/api/action/setPostReaction.js +0 -106
  33. package/src/api/action/unfriend.js +0 -54
  34. package/src/api/http/httpGet.js +0 -46
  35. package/src/api/http/httpPost.js +0 -52
  36. package/src/api/http/postFormData.js +0 -47
  37. package/src/api/messaging/addUserToGroup.js +0 -68
  38. package/src/api/messaging/changeAdminStatus.js +0 -126
  39. package/src/api/messaging/changeArchivedStatus.js +0 -55
  40. package/src/api/messaging/changeBlockedStatus.js +0 -48
  41. package/src/api/messaging/changeGroupImage.js +0 -91
  42. package/src/api/messaging/changeNickname.js +0 -70
  43. package/src/api/messaging/changeThreadColor.js +0 -79
  44. package/src/api/messaging/changeThreadEmoji.js +0 -111
  45. package/src/api/messaging/createNewGroup.js +0 -88
  46. package/src/api/messaging/createPoll.js +0 -46
  47. package/src/api/messaging/createThemeAI.js +0 -98
  48. package/src/api/messaging/deleteMessage.js +0 -136
  49. package/src/api/messaging/deleteThread.js +0 -56
  50. package/src/api/messaging/editMessage.js +0 -68
  51. package/src/api/messaging/forwardAttachment.js +0 -57
  52. package/src/api/messaging/getEmojiUrl.js +0 -29
  53. package/src/api/messaging/getFriendsList.js +0 -82
  54. package/src/api/messaging/getMessage.js +0 -829
  55. package/src/api/messaging/getThemePictures.js +0 -62
  56. package/src/api/messaging/handleMessageRequest.js +0 -65
  57. package/src/api/messaging/markAsDelivered.js +0 -57
  58. package/src/api/messaging/markAsRead.js +0 -88
  59. package/src/api/messaging/markAsReadAll.js +0 -49
  60. package/src/api/messaging/markAsSeen.js +0 -61
  61. package/src/api/messaging/muteThread.js +0 -50
  62. package/src/api/messaging/removeUserFromGroup.js +0 -62
  63. package/src/api/messaging/resolvePhotoUrl.js +0 -43
  64. package/src/api/messaging/scheduler.js +0 -264
  65. package/src/api/messaging/searchForThread.js +0 -53
  66. package/src/api/messaging/sendMessage.js +0 -270
  67. package/src/api/messaging/sendTypingIndicator.js +0 -74
  68. package/src/api/messaging/setMessageReaction.js +0 -90
  69. package/src/api/messaging/setTitle.js +0 -124
  70. package/src/api/messaging/shareContact.js +0 -49
  71. package/src/api/messaging/threadColors.js +0 -128
  72. package/src/api/messaging/unsendMessage.js +0 -81
  73. package/src/api/messaging/uploadAttachment.js +0 -492
  74. package/src/api/socket/core/connectMqtt.js +0 -258
  75. package/src/api/socket/core/emitAuth.js +0 -103
  76. package/src/api/socket/core/getSeqID.js +0 -320
  77. package/src/api/socket/core/getTaskResponseData.js +0 -25
  78. package/src/api/socket/core/parseDelta.js +0 -377
  79. package/src/api/socket/detail/buildStream.js +0 -215
  80. package/src/api/socket/detail/constants.js +0 -28
  81. package/src/api/socket/listenMqtt.js +0 -377
  82. package/src/api/socket/middleware/index.js +0 -216
  83. package/src/api/threads/getThreadHistory.js +0 -664
  84. package/src/api/threads/getThreadInfo.js +0 -296
  85. package/src/api/threads/getThreadList.js +0 -293
  86. package/src/api/threads/getThreadPictures.js +0 -78
  87. package/src/api/users/getUserID.js +0 -65
  88. package/src/api/users/getUserInfo.js +0 -402
  89. package/src/api/users/getUserInfoV2.js +0 -134
  90. package/src/core/sendReqMqtt.js +0 -96
  91. package/src/database/helpers.js +0 -53
  92. package/src/database/models/index.js +0 -88
  93. package/src/database/models/thread.js +0 -50
  94. package/src/database/models/user.js +0 -46
  95. package/src/database/threadData.js +0 -94
  96. package/src/database/userData.js +0 -98
  97. package/src/remote/remoteClient.js +0 -123
  98. package/src/utils/broadcast.js +0 -51
  99. package/src/utils/client.js +0 -10
  100. package/src/utils/constants.js +0 -23
  101. package/src/utils/cookies.js +0 -68
  102. package/src/utils/format/attachment.js +0 -357
  103. package/src/utils/format/cookie.js +0 -9
  104. package/src/utils/format/date.js +0 -50
  105. package/src/utils/format/decode.js +0 -44
  106. package/src/utils/format/delta.js +0 -194
  107. package/src/utils/format/ids.js +0 -64
  108. package/src/utils/format/index.js +0 -64
  109. package/src/utils/format/message.js +0 -88
  110. package/src/utils/format/presence.js +0 -132
  111. package/src/utils/format/readTyp.js +0 -44
  112. package/src/utils/format/thread.js +0 -42
  113. package/src/utils/format/utils.js +0 -141
  114. package/src/utils/headers.js +0 -115
  115. package/src/utils/loginParser/autoLogin.js +0 -125
  116. package/src/utils/loginParser/helpers.js +0 -43
  117. package/src/utils/loginParser/index.js +0 -10
  118. package/src/utils/loginParser/parseAndCheckLogin.js +0 -220
  119. package/src/utils/loginParser/textUtils.js +0 -28
  120. package/src/utils/request/client.js +0 -26
  121. package/src/utils/request/config.js +0 -23
  122. package/src/utils/request/defaults.js +0 -46
  123. package/src/utils/request/helpers.js +0 -46
  124. package/src/utils/request/index.js +0 -17
  125. package/src/utils/request/methods.js +0 -163
  126. package/src/utils/request/proxy.js +0 -21
  127. package/src/utils/request/retry.js +0 -77
  128. package/src/utils/request/sanitize.js +0 -49
@@ -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
- };