fca-project-orion 1.1.2 → 1.1.4

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 (108) hide show
  1. package/.gitattributes +2 -2
  2. package/Extra/Database/index.js +468 -468
  3. package/Extra/ExtraAddons.js +81 -81
  4. package/Extra/ExtraFindUID.js +61 -61
  5. package/Extra/ExtraGetThread.js +339 -339
  6. package/Extra/ExtraScreenShot.js +430 -430
  7. package/Extra/ExtraUptimeRobot.js +37 -37
  8. package/Extra/Html/Classic/script.js +118 -118
  9. package/Extra/Html/Classic/style.css +7 -7
  10. package/Extra/Security/Base/Step_1.js +5 -5
  11. package/Extra/Security/Base/Step_2.js +22 -22
  12. package/Extra/Security/Base/Step_3.js +22 -22
  13. package/Extra/Security/Base/index.js +172 -172
  14. package/Extra/Security/Index.js +4 -4
  15. package/Extra/Security/Step_1.js +5 -5
  16. package/Extra/Security/Step_2.js +22 -22
  17. package/Extra/Security/Step_3.js +22 -22
  18. package/Extra/Src/Change_Environment.js +23 -23
  19. package/Extra/Src/Check_Update.js +65 -65
  20. package/Extra/Src/History.js +114 -114
  21. package/Extra/Src/Instant_Update.js +64 -64
  22. package/Extra/Src/Last-Run.js +64 -64
  23. package/Extra/Src/Premium.js +80 -80
  24. package/Extra/Src/Release_Memory.js +40 -40
  25. package/Extra/Src/Websocket.js +212 -212
  26. package/Extra/Src/uuid.js +137 -137
  27. package/Func/AcceptAgreement.js +31 -31
  28. package/Func/ClearCache.js +64 -64
  29. package/Func/ReportV1.js +54 -54
  30. package/LICENSE +21 -21
  31. package/Language/index.json +216 -216
  32. package/Main.js +1215 -1215
  33. package/README.md +138 -138
  34. package/SECURITY.md +18 -18
  35. package/broadcast.js +39 -39
  36. package/index.js +385 -385
  37. package/logger.js +66 -66
  38. package/package.json +93 -93
  39. package/src/Dev_Horizon_Data.js +124 -124
  40. package/src/Premium.js +24 -24
  41. package/src/Screenshot.js +82 -82
  42. package/src/addExternalModule.js +16 -16
  43. package/src/addUserToGroup.js +79 -79
  44. package/src/changeAdminStatus.js +79 -79
  45. package/src/changeArchivedStatus.js +41 -41
  46. package/src/changeAvt.js +84 -84
  47. package/src/changeBio.js +65 -65
  48. package/src/changeBlockedStatus.js +36 -36
  49. package/src/changeGroupImage.js +106 -106
  50. package/src/changeNickname.js +45 -45
  51. package/src/changeThreadColor.js +62 -62
  52. package/src/changeThreadEmoji.js +42 -42
  53. package/src/createNewGroup.js +70 -70
  54. package/src/createPoll.js +60 -60
  55. package/src/deleteMessage.js +45 -45
  56. package/src/deleteThread.js +43 -43
  57. package/src/forwardAttachment.js +48 -48
  58. package/src/getAccessToken.js +27 -27
  59. package/src/getCurrentUserID.js +7 -7
  60. package/src/getEmojiUrl.js +27 -27
  61. package/src/getFriendsList.js +73 -73
  62. package/src/getMessage.js +79 -79
  63. package/src/getThreadHistory.js +537 -537
  64. package/src/getThreadInfo.js +424 -424
  65. package/src/getThreadList.js +213 -213
  66. package/src/getThreadMain.js +219 -219
  67. package/src/getThreadPictures.js +59 -59
  68. package/src/getUID.js +58 -58
  69. package/src/getUserID.js +62 -62
  70. package/src/getUserInfo.js +113 -113
  71. package/src/getUserInfoMain.js +64 -64
  72. package/src/getUserInfoV2.js +31 -31
  73. package/src/getUserInfoV3.js +62 -62
  74. package/src/getUserInfoV4.js +54 -54
  75. package/src/getUserInfoV5.js +60 -60
  76. package/src/handleFriendRequest.js +46 -46
  77. package/src/handleMessageRequest.js +49 -49
  78. package/src/httpGet.js +49 -49
  79. package/src/httpPost.js +48 -48
  80. package/src/httpPostFormData.js +40 -40
  81. package/src/listenMqtt.js +786 -786
  82. package/src/logout.js +68 -68
  83. package/src/markAsDelivered.js +48 -48
  84. package/src/markAsRead.js +70 -70
  85. package/src/markAsReadAll.js +42 -42
  86. package/src/markAsSeen.js +51 -51
  87. package/src/muteThread.js +47 -47
  88. package/src/removeUserFromGroup.js +49 -49
  89. package/src/resolvePhotoUrl.js +37 -37
  90. package/src/searchForThread.js +43 -43
  91. package/src/sendMessage.js +378 -378
  92. package/src/sendTypingIndicator.js +80 -80
  93. package/src/setMessageReaction.js +109 -109
  94. package/src/setPostReaction.js +101 -101
  95. package/src/setTitle.js +74 -74
  96. package/src/threadColors.js +38 -38
  97. package/src/unfriend.js +43 -43
  98. package/src/unsendMessage.js +40 -40
  99. package/test/Database_Test.js +3 -3
  100. package/test/Db2.js +529 -529
  101. package/test/data/shareAttach.js +146 -146
  102. package/test/data/test.txt +7 -7
  103. package/test/example-config.json +18 -18
  104. package/test/memoryleak.js +18 -18
  105. package/test/test-page.js +140 -140
  106. package/test/test.js +385 -385
  107. package/test/testv2.js +17 -17
  108. package/utils.js +1682 -1682
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
+ };