fca-priyansh 19.0.0 → 20.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 (135) hide show
  1. package/.gitlab-ci.yml +22 -0
  2. package/CountTime.json +1 -0
  3. package/Extra/Balancer.js +49 -49
  4. package/Extra/BroadcastSystem.js +1 -0
  5. package/Extra/Bypass/956/index.js +233 -233
  6. package/Extra/Bypass/test/aaaa.json +169 -169
  7. package/Extra/Bypass/test/index.js +187 -187
  8. package/Extra/Database/index.js +468 -468
  9. package/Extra/ExtraAddons.js +82 -82
  10. package/Extra/ExtraFindUID.js +61 -61
  11. package/Extra/ExtraGetThread.js +365 -365
  12. package/Extra/ExtraScreenShot.js +430 -430
  13. package/Extra/ExtraUptimeRobot.js +142 -38
  14. package/Extra/Html/Classic/script.js +118 -118
  15. package/Extra/Html/Classic/style.css +7 -7
  16. package/Extra/Security/Base/Step_1.js +5 -5
  17. package/Extra/Security/Base/Step_2.js +22 -22
  18. package/Extra/Security/Base/Step_3.js +22 -22
  19. package/Extra/Security/Base/index.js +190 -190
  20. package/Extra/Security/Index.js +4 -4
  21. package/Extra/Security/Step_1.js +5 -5
  22. package/Extra/Security/Step_2.js +22 -22
  23. package/Extra/Security/Step_3.js +22 -22
  24. package/Extra/Src/Change_Environment.js +24 -24
  25. package/Extra/Src/Check_Update.js +66 -66
  26. package/Extra/Src/History.js +114 -114
  27. package/Extra/Src/Instant_Update.js +64 -64
  28. package/Extra/Src/Last-Run.js +64 -64
  29. package/Extra/Src/Premium.js +81 -81
  30. package/Extra/Src/Websocket.js +212 -212
  31. package/Extra/Src/uuid.js +137 -137
  32. package/Func/AcceptAgreement.js +31 -31
  33. package/Func/ClearCache.js +64 -64
  34. package/Func/ReportV1.js +54 -54
  35. package/LICENSE +21 -21
  36. package/Language/index.json +228 -228
  37. package/Main.js +1 -1290
  38. package/README.md +198 -198
  39. package/broadcast.js +1 -44
  40. package/errorHandler.js +151 -0
  41. package/index.js +1 -448
  42. package/logger.js +69 -66
  43. package/package.json +99 -98
  44. package/src/Dev_Horizon_Data.js +124 -124
  45. package/src/Dev_getThreadInfoOLD.js +421 -421
  46. package/src/Dev_shareTest2.js +68 -68
  47. package/src/Dev_shareTest3.js +71 -71
  48. package/src/Premium.js +24 -24
  49. package/src/Screenshot.js +82 -82
  50. package/src/addExternalModule.js +16 -16
  51. package/src/addUserToGroup.js +79 -79
  52. package/src/changeAdminStatus.js +79 -79
  53. package/src/changeArchivedStatus.js +41 -41
  54. package/src/changeAvt.js +84 -84
  55. package/src/changeBio.js +65 -65
  56. package/src/changeBlockedStatus.js +36 -36
  57. package/src/changeGroupImage.js +106 -106
  58. package/src/changeNickname.js +45 -45
  59. package/src/changeThreadColor.js +62 -62
  60. package/src/changeThreadEmoji.js +42 -42
  61. package/src/changeThreadTheme.js +263 -0
  62. package/src/comment.js +244 -0
  63. package/src/createNewGroup.js +70 -70
  64. package/src/createPoll.js +60 -60
  65. package/src/deleteMessage.js +45 -45
  66. package/src/deleteThread.js +43 -43
  67. package/src/editMessage.js +71 -53
  68. package/src/follow.js +119 -0
  69. package/src/forwardAttachment.js +48 -48
  70. package/src/friend.js +383 -0
  71. package/src/getAccessToken.js +27 -27
  72. package/src/getCurrentUserID.js +7 -7
  73. package/src/getEmojiUrl.js +27 -27
  74. package/src/getFriendsList.js +73 -73
  75. package/src/getMessage.js +102 -102
  76. package/src/getPendingFriendRequests.js +45 -0
  77. package/src/getThreadHistory.js +537 -537
  78. package/src/getThreadInfo.js +424 -423
  79. package/src/getThreadInfoOLD.js +421 -421
  80. package/src/getThreadList.js +213 -213
  81. package/src/getThreadMain.js +219 -219
  82. package/src/getThreadPictures.js +59 -59
  83. package/src/getUID.js +58 -58
  84. package/src/getUserID.js +62 -62
  85. package/src/getUserInfo.js +112 -112
  86. package/src/getUserInfoMain.js +64 -64
  87. package/src/getUserInfoV2.js +31 -31
  88. package/src/getUserInfoV3.js +62 -62
  89. package/src/getUserInfoV4.js +54 -54
  90. package/src/getUserInfoV5.js +60 -60
  91. package/src/handleFriendRequest.js +46 -46
  92. package/src/handleMessageRequest.js +49 -49
  93. package/src/httpGet.js +49 -49
  94. package/src/httpPost.js +48 -48
  95. package/src/httpPostFormData.js +40 -40
  96. package/src/listenMqtt.js +1 -956
  97. package/src/listenMqttV1.js +832 -846
  98. package/src/logout.js +68 -68
  99. package/src/markAsDelivered.js +48 -48
  100. package/src/markAsRead.js +70 -70
  101. package/src/markAsReadAll.js +42 -42
  102. package/src/markAsSeen.js +51 -51
  103. package/src/muteThread.js +47 -47
  104. package/src/notes.js +279 -0
  105. package/src/removeUserFromGroup.js +49 -49
  106. package/src/resolvePhotoUrl.js +37 -37
  107. package/src/searchForThread.js +43 -43
  108. package/src/sendMention.js +325 -0
  109. package/src/sendMessage.js +1 -386
  110. package/src/sendMqttMessage.js +70 -70
  111. package/src/sendTypingIndicator.js +79 -80
  112. package/src/setMessageReaction.js +109 -109
  113. package/src/setPostReaction.js +101 -101
  114. package/src/setTitle.js +74 -74
  115. package/src/share.js +98 -0
  116. package/src/shareContact.js +55 -55
  117. package/src/shareLink.js +58 -58
  118. package/src/stickers.js +525 -0
  119. package/src/story.js +267 -0
  120. package/src/threadColors.js +38 -38
  121. package/src/unfriend.js +43 -43
  122. package/src/unsendMessage.js +47 -47
  123. package/src/unsendMqttMessage.js +65 -65
  124. package/test/data/shareAttach.js +146 -146
  125. package/test/data/test.txt +7 -7
  126. package/test/example-config.json +18 -18
  127. package/test/test-page.js +140 -140
  128. package/test/test.js +385 -385
  129. package/test/testv2.js +2 -2
  130. package/userAgentManager.js +129 -0
  131. package/utils.js +1 -3077
  132. package/.github/workflows/publish.yml +0 -20
  133. package/Extra/Src/Release_Memory.js +0 -160
  134. package/Extra/Src/test.js +0 -28
  135. package/SECURITY.md +0 -17
package/src/logout.js CHANGED
@@ -1,68 +1,68 @@
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 logout(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
-
19
- resolveFunc(friendList);
20
- };
21
- }
22
-
23
- var form = {
24
- pmid: "0"
25
- };
26
-
27
- defaultFuncs
28
- .post("https://www.facebook.com/bluebar/modern_settings_menu/?help_type=364455653583099&show_contextual_help=1", ctx.jar, form)
29
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
30
- .then(function (resData) {
31
- var elem = resData.jsmods.instances[0][2][0].filter(function (v) {
32
- return v.value === "logout";
33
- })[0];
34
-
35
- var html = resData.jsmods.markup.filter(function (v) {
36
- return v[0] === elem.markup.__m;
37
- })[0][1].__html;
38
-
39
- var form = {
40
- fb_dtsg: utils.getFrom(html, '"fb_dtsg" value="', '"'),
41
- ref: utils.getFrom(html, '"ref" value="', '"'),
42
- h: utils.getFrom(html, '"h" value="', '"')
43
- };
44
-
45
- return defaultFuncs
46
- .post("https://www.facebook.com/logout.php", ctx.jar, form)
47
- .then(utils.saveCookies(ctx.jar));
48
- })
49
- .then(function (res) {
50
- if (!res.headers) throw { error: "An error occurred when logging out." };
51
-
52
- return defaultFuncs
53
- .get(res.headers.location, ctx.jar)
54
- .then(utils.saveCookies(ctx.jar));
55
- })
56
- .then(function () {
57
- ctx.loggedIn = false;
58
- log.info("logout", "Logged out successfully.");
59
- callback();
60
- })
61
- .catch(function (err) {
62
- log.error("logout", err);
63
- return callback(err);
64
- });
65
-
66
- return returnPromise;
67
- };
68
- };
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 logout(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
+
19
+ resolveFunc(friendList);
20
+ };
21
+ }
22
+
23
+ var form = {
24
+ pmid: "0"
25
+ };
26
+
27
+ defaultFuncs
28
+ .post("https://www.facebook.com/bluebar/modern_settings_menu/?help_type=364455653583099&show_contextual_help=1", ctx.jar, form)
29
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
30
+ .then(function (resData) {
31
+ var elem = resData.jsmods.instances[0][2][0].filter(function (v) {
32
+ return v.value === "logout";
33
+ })[0];
34
+
35
+ var html = resData.jsmods.markup.filter(function (v) {
36
+ return v[0] === elem.markup.__m;
37
+ })[0][1].__html;
38
+
39
+ var form = {
40
+ fb_dtsg: utils.getFrom(html, '"fb_dtsg" value="', '"'),
41
+ ref: utils.getFrom(html, '"ref" value="', '"'),
42
+ h: utils.getFrom(html, '"h" value="', '"')
43
+ };
44
+
45
+ return defaultFuncs
46
+ .post("https://www.facebook.com/logout.php", ctx.jar, form)
47
+ .then(utils.saveCookies(ctx.jar));
48
+ })
49
+ .then(function (res) {
50
+ if (!res.headers) throw { error: "An error occurred when logging out." };
51
+
52
+ return defaultFuncs
53
+ .get(res.headers.location, ctx.jar)
54
+ .then(utils.saveCookies(ctx.jar));
55
+ })
56
+ .then(function () {
57
+ ctx.loggedIn = false;
58
+ log.info("logout", "Logged out successfully.");
59
+ callback();
60
+ })
61
+ .catch(function (err) {
62
+ log.error("logout", err);
63
+ return callback(err);
64
+ });
65
+
66
+ return returnPromise;
67
+ };
68
+ };
@@ -1,48 +1,48 @@
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 markAsDelivered(threadID, 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, data) {
17
- if (err) return rejectFunc(err);
18
-
19
- resolveFunc(data);
20
- };
21
- }
22
-
23
- if (!threadID || !messageID) return callback("Error: messageID or threadID is not defined");
24
-
25
- var form = {};
26
-
27
- form["message_ids[0]"] = messageID;
28
- form["thread_ids[" + threadID + "][0]"] = messageID;
29
-
30
- defaultFuncs
31
- .post("https://www.facebook.com/ajax/mercury/delivery_receipts.php", ctx.jar, form)
32
- .then(utils.saveCookies(ctx.jar))
33
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
- .then(function (resData) {
35
- if (resData.error) throw resData;
36
-
37
- return callback();
38
- })
39
- .catch(function (err) {
40
- log.error("markAsDelivered", err);
41
- if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
42
-
43
- return callback(err);
44
- });
45
-
46
- return returnPromise;
47
- };
48
- };
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 markAsDelivered(threadID, 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, data) {
17
+ if (err) return rejectFunc(err);
18
+
19
+ resolveFunc(data);
20
+ };
21
+ }
22
+
23
+ if (!threadID || !messageID) return callback("Error: messageID or threadID is not defined");
24
+
25
+ var form = {};
26
+
27
+ form["message_ids[0]"] = messageID;
28
+ form["thread_ids[" + threadID + "][0]"] = messageID;
29
+
30
+ defaultFuncs
31
+ .post("https://www.facebook.com/ajax/mercury/delivery_receipts.php", ctx.jar, form)
32
+ .then(utils.saveCookies(ctx.jar))
33
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
+ .then(function (resData) {
35
+ if (resData.error) throw resData;
36
+
37
+ return callback();
38
+ })
39
+ .catch(function (err) {
40
+ log.error("markAsDelivered", err);
41
+ if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
42
+
43
+ return callback(err);
44
+ });
45
+
46
+ return returnPromise;
47
+ };
48
+ };
package/src/markAsRead.js CHANGED
@@ -1,70 +1,70 @@
1
- "use strict";
2
-
3
- var utils = require("../utils");
4
- var log = require("npmlog");
5
-
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- return async function markAsRead(threadID, read, callback) {
8
- if (utils.getType(read) === 'Function' || utils.getType(read) === 'AsyncFunction') {
9
- callback = read;
10
- read = true;
11
- }
12
- if (read == undefined) read = true;
13
-
14
- if (!callback) callback = () => { };
15
-
16
- var form = {};
17
-
18
- if (typeof ctx.globalOptions.pageID !== 'undefined') {
19
- form["source"] = "PagesManagerMessagesInterface";
20
- form["request_user_id"] = ctx.globalOptions.pageID;
21
- form["ids[" + threadID + "]"] = read;
22
- form["watermarkTimestamp"] = new Date().getTime();
23
- form["shouldSendReadReceipt"] = true;
24
- form["commerce_last_message_type"] = "";
25
- //form["titanOriginatedThreadId"] = utils.generateThreadingID(ctx.clientID);
26
-
27
- let resData;
28
- try {
29
- resData = await (
30
- defaultFuncs
31
- .post("https://www.facebook.com/ajax/mercury/change_read_status.php", ctx.jar, form)
32
- .then(utils.saveCookies(ctx.jar))
33
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
- );
35
- }
36
- catch (e) {
37
- callback(e);
38
- return e;
39
- }
40
-
41
- if (resData.error) {
42
- let err = resData.error;
43
- log.error("markAsRead", err);
44
- if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
45
- callback(err);
46
- return err;
47
- }
48
-
49
- callback();
50
- return null;
51
- }
52
- else {
53
- try {
54
- if (ctx.mqttClient) {
55
- let err = await new Promise(r => ctx.mqttClient.publish("/mark_thread", JSON.stringify({
56
- threadID,
57
- mark: "read",
58
- state: read
59
- }), { qos: 1, retain: false }, r));
60
- if (err) throw err;
61
- }
62
- else throw { error: "You can only use this function after you start listening." };
63
- }
64
- catch (e) {
65
- callback(e);
66
- return e;
67
- }
68
- }
69
- };
70
- };
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return async function markAsRead(threadID, read, callback) {
8
+ if (utils.getType(read) === 'Function' || utils.getType(read) === 'AsyncFunction') {
9
+ callback = read;
10
+ read = true;
11
+ }
12
+ if (read == undefined) read = true;
13
+
14
+ if (!callback) callback = () => { };
15
+
16
+ var form = {};
17
+
18
+ if (typeof ctx.globalOptions.pageID !== 'undefined') {
19
+ form["source"] = "PagesManagerMessagesInterface";
20
+ form["request_user_id"] = ctx.globalOptions.pageID;
21
+ form["ids[" + threadID + "]"] = read;
22
+ form["watermarkTimestamp"] = new Date().getTime();
23
+ form["shouldSendReadReceipt"] = true;
24
+ form["commerce_last_message_type"] = "";
25
+ //form["titanOriginatedThreadId"] = utils.generateThreadingID(ctx.clientID);
26
+
27
+ let resData;
28
+ try {
29
+ resData = await (
30
+ defaultFuncs
31
+ .post("https://www.facebook.com/ajax/mercury/change_read_status.php", ctx.jar, form)
32
+ .then(utils.saveCookies(ctx.jar))
33
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
+ );
35
+ }
36
+ catch (e) {
37
+ callback(e);
38
+ return e;
39
+ }
40
+
41
+ if (resData.error) {
42
+ let err = resData.error;
43
+ log.error("markAsRead", err);
44
+ if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
45
+ callback(err);
46
+ return err;
47
+ }
48
+
49
+ callback();
50
+ return null;
51
+ }
52
+ else {
53
+ try {
54
+ if (ctx.mqttClient) {
55
+ let err = await new Promise(r => ctx.mqttClient.publish("/mark_thread", JSON.stringify({
56
+ threadID,
57
+ mark: "read",
58
+ state: read
59
+ }), { qos: 1, retain: false }, r));
60
+ if (err) throw err;
61
+ }
62
+ else throw { error: "You can only use this function after you start listening." };
63
+ }
64
+ catch (e) {
65
+ callback(e);
66
+ return e;
67
+ }
68
+ }
69
+ };
70
+ };
@@ -1,43 +1,43 @@
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 markAsReadAll(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, data) {
17
- if (err) return rejectFunc(err);
18
-
19
- resolveFunc(data);
20
- };
21
- }
22
-
23
- var form = {
24
- folder: 'inbox'
25
- };
26
-
27
- defaultFuncs
28
- .post("https://www.facebook.com/ajax/mercury/mark_folder_as_read.php", ctx.jar, form)
29
- .then(utils.saveCookies(ctx.jar))
30
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
31
- .then(function (resData) {
32
- if (resData.error) throw resData;
33
-
34
- return callback();
35
- })
36
- .catch(function (err) {
37
- log.error("markAsReadAll", err);
38
- return callback(err);
39
- });
40
-
41
- return returnPromise;
42
- };
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 markAsReadAll(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, data) {
17
+ if (err) return rejectFunc(err);
18
+
19
+ resolveFunc(data);
20
+ };
21
+ }
22
+
23
+ var form = {
24
+ folder: 'inbox'
25
+ };
26
+
27
+ defaultFuncs
28
+ .post("https://www.facebook.com/ajax/mercury/mark_folder_as_read.php", ctx.jar, form)
29
+ .then(utils.saveCookies(ctx.jar))
30
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
31
+ .then(function (resData) {
32
+ if (resData.error) throw resData;
33
+
34
+ return callback();
35
+ })
36
+ .catch(function (err) {
37
+ log.error("markAsReadAll", err);
38
+ return callback(err);
39
+ });
40
+
41
+ return returnPromise;
42
+ };
43
43
  };
package/src/markAsSeen.js CHANGED
@@ -1,51 +1,51 @@
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 markAsSeen(seen_timestamp, callback) {
8
- if (utils.getType(seen_timestamp) == "Function" ||
9
- utils.getType(seen_timestamp) == "AsyncFunction") {
10
- callback = seen_timestamp;
11
- seen_timestamp = Date.now();
12
- }
13
-
14
- var resolveFunc = function () { };
15
- var rejectFunc = function () { };
16
- var returnPromise = new Promise(function (resolve, reject) {
17
- resolveFunc = resolve;
18
- rejectFunc = reject;
19
- });
20
-
21
- if (!callback) {
22
- callback = function (err, data) {
23
- if (err) return rejectFunc(err);
24
-
25
- resolveFunc(data);
26
- };
27
- }
28
-
29
- var form = {
30
- seen_timestamp: seen_timestamp
31
- };
32
-
33
- defaultFuncs
34
- .post("https://www.facebook.com/ajax/mercury/mark_seen.php", ctx.jar, form)
35
- .then(utils.saveCookies(ctx.jar))
36
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
37
- .then(function (resData) {
38
- if (resData.error) throw resData;
39
-
40
- return callback();
41
- })
42
- .catch(function (err) {
43
- log.error("markAsSeen", err);
44
- if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
45
-
46
- return callback(err);
47
- });
48
-
49
- return returnPromise;
50
- };
51
- };
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 markAsSeen(seen_timestamp, callback) {
8
+ if (utils.getType(seen_timestamp) == "Function" ||
9
+ utils.getType(seen_timestamp) == "AsyncFunction") {
10
+ callback = seen_timestamp;
11
+ seen_timestamp = Date.now();
12
+ }
13
+
14
+ var resolveFunc = function () { };
15
+ var rejectFunc = function () { };
16
+ var returnPromise = new Promise(function (resolve, reject) {
17
+ resolveFunc = resolve;
18
+ rejectFunc = reject;
19
+ });
20
+
21
+ if (!callback) {
22
+ callback = function (err, data) {
23
+ if (err) return rejectFunc(err);
24
+
25
+ resolveFunc(data);
26
+ };
27
+ }
28
+
29
+ var form = {
30
+ seen_timestamp: seen_timestamp
31
+ };
32
+
33
+ defaultFuncs
34
+ .post("https://www.facebook.com/ajax/mercury/mark_seen.php", ctx.jar, form)
35
+ .then(utils.saveCookies(ctx.jar))
36
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
37
+ .then(function (resData) {
38
+ if (resData.error) throw resData;
39
+
40
+ return callback();
41
+ })
42
+ .catch(function (err) {
43
+ log.error("markAsSeen", err);
44
+ if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
45
+
46
+ return callback(err);
47
+ });
48
+
49
+ return returnPromise;
50
+ };
51
+ };
package/src/muteThread.js CHANGED
@@ -1,47 +1,47 @@
1
- "use strict";
2
-
3
- var utils = require("../utils");
4
- var log = require("npmlog");
5
-
6
- module.exports = function (defaultFuncs, api, ctx) {
7
- // muteSecond: -1=permanent mute, 0=unmute, 60=one minute, 3600=one hour, etc.
8
- return function muteThread(threadID, muteSeconds, callback) {
9
- var resolveFunc = function () { };
10
- var rejectFunc = function () { };
11
- var returnPromise = new Promise(function (resolve, reject) {
12
- resolveFunc = resolve;
13
- rejectFunc = reject;
14
- });
15
-
16
- if (!callback) {
17
- callback = function (err, data) {
18
- if (err) return rejectFunc(err);
19
-
20
- resolveFunc(data);
21
- };
22
- }
23
-
24
- var form = {
25
- thread_fbid: threadID,
26
- mute_settings: muteSeconds
27
- };
28
-
29
- defaultFuncs
30
- .post("https://www.facebook.com/ajax/mercury/change_mute_thread.php", ctx.jar, form)
31
- .then(utils.saveCookies(ctx.jar))
32
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
33
- .then(function (resData) {
34
- if (resData.error) {
35
- throw resData;
36
- }
37
-
38
- return callback();
39
- })
40
- .catch(function (err) {
41
- log.error("muteThread", err);
42
- return callback(err);
43
- });
44
-
45
- return returnPromise;
46
- };
47
- };
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ // muteSecond: -1=permanent mute, 0=unmute, 60=one minute, 3600=one hour, etc.
8
+ return function muteThread(threadID, muteSeconds, callback) {
9
+ var resolveFunc = function () { };
10
+ var rejectFunc = function () { };
11
+ var returnPromise = new Promise(function (resolve, reject) {
12
+ resolveFunc = resolve;
13
+ rejectFunc = reject;
14
+ });
15
+
16
+ if (!callback) {
17
+ callback = function (err, data) {
18
+ if (err) return rejectFunc(err);
19
+
20
+ resolveFunc(data);
21
+ };
22
+ }
23
+
24
+ var form = {
25
+ thread_fbid: threadID,
26
+ mute_settings: muteSeconds
27
+ };
28
+
29
+ defaultFuncs
30
+ .post("https://www.facebook.com/ajax/mercury/change_mute_thread.php", ctx.jar, form)
31
+ .then(utils.saveCookies(ctx.jar))
32
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
33
+ .then(function (resData) {
34
+ if (resData.error) {
35
+ throw resData;
36
+ }
37
+
38
+ return callback();
39
+ })
40
+ .catch(function (err) {
41
+ log.error("muteThread", err);
42
+ return callback(err);
43
+ });
44
+
45
+ return returnPromise;
46
+ };
47
+ };