chatbot-fca 0.0.3

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.

Potentially problematic release.


This version of chatbot-fca might be problematic. Click here for more details.

Files changed (97) hide show
  1. package/.cache/nix/binary-cache-v6.sqlite +0 -0
  2. package/.cache/nix/binary-cache-v6.sqlite-journal +0 -0
  3. package/.cache/replit/env/latest +125 -0
  4. package/.cache/replit/env/latest.json +1 -0
  5. package/.cache/replit/modules/nix.res +1 -0
  6. package/.cache/replit/modules/nodejs-20.res +1 -0
  7. package/.cache/replit/modules/replit.res +1 -0
  8. package/.cache/replit/modules.stamp +0 -0
  9. package/.cache/replit/nix/env.json +1 -0
  10. package/.replit +8 -0
  11. package/LICENSE +21 -0
  12. package/index.js +460 -0
  13. package/package.json +46 -0
  14. package/replit.nix +3 -0
  15. package/src/Screenshot.js +83 -0
  16. package/src/addExternalModule.js +25 -0
  17. package/src/addUserToGroup.js +115 -0
  18. package/src/changeAdminStatus.js +103 -0
  19. package/src/changeArchivedStatus.js +55 -0
  20. package/src/changeAvatar.js +136 -0
  21. package/src/changeAvatarV2.js +86 -0
  22. package/src/changeAvt.js +85 -0
  23. package/src/changeBio.js +76 -0
  24. package/src/changeBlockedStatus.js +49 -0
  25. package/src/changeBlockedStatusMqtt.js +80 -0
  26. package/src/changeCover.js +72 -0
  27. package/src/changeGroupImage.js +135 -0
  28. package/src/changeName.js +79 -0
  29. package/src/changeNickname.js +59 -0
  30. package/src/changeThreadColor.js +65 -0
  31. package/src/changeThreadEmoji.js +55 -0
  32. package/src/changeUsername.js +59 -0
  33. package/src/createCommentPost.js +230 -0
  34. package/src/createNewGroup.js +88 -0
  35. package/src/createPoll.js +71 -0
  36. package/src/createPost.js +276 -0
  37. package/src/deleteMessage.js +56 -0
  38. package/src/deleteThread.js +56 -0
  39. package/src/editMessage.js +68 -0
  40. package/src/editMessageOld.js +67 -0
  41. package/src/follow.js +74 -0
  42. package/src/forwardAttachment.js +60 -0
  43. package/src/getAccess.js +112 -0
  44. package/src/getAvatarUser.js +78 -0
  45. package/src/getCurrentUserID.js +7 -0
  46. package/src/getEmojiUrl.js +29 -0
  47. package/src/getFriendsList.js +83 -0
  48. package/src/getMessage.js +835 -0
  49. package/src/getRegion.js +7 -0
  50. package/src/getThreadHistory.js +680 -0
  51. package/src/getThreadHistoryDeprecated.js +71 -0
  52. package/src/getThreadInfo.js +232 -0
  53. package/src/getThreadInfoDeprecated.js +56 -0
  54. package/src/getThreadList.js +213 -0
  55. package/src/getThreadListDeprecated.js +46 -0
  56. package/src/getThreadPictures.js +59 -0
  57. package/src/getUID.js +119 -0
  58. package/src/getUserID.js +61 -0
  59. package/src/getUserInfo.js +66 -0
  60. package/src/handleFriendRequest.js +46 -0
  61. package/src/handleMessageRequest.js +47 -0
  62. package/src/httpGet.js +49 -0
  63. package/src/httpPost.js +48 -0
  64. package/src/listenMqtt.js +827 -0
  65. package/src/listenMqtt.txt +827 -0
  66. package/src/logout.js +75 -0
  67. package/src/markAsDelivered.js +47 -0
  68. package/src/markAsRead.js +70 -0
  69. package/src/markAsReadAll.js +40 -0
  70. package/src/markAsSeen.js +48 -0
  71. package/src/muteThread.js +45 -0
  72. package/src/postFormData.txt +46 -0
  73. package/src/refreshFb_dtsg.js +89 -0
  74. package/src/removeUserFromGroup.js +79 -0
  75. package/src/resolvePhotoUrl.js +45 -0
  76. package/src/searchForThread.js +53 -0
  77. package/src/searchStickers.js +53 -0
  78. package/src/sendMessage.js +329 -0
  79. package/src/sendMessageMqtt.js +322 -0
  80. package/src/sendTypingIndicator.js +101 -0
  81. package/src/sendTypingIndicatorV2.js +28 -0
  82. package/src/setMessageReaction.js +122 -0
  83. package/src/setMessageReactionMqtt.js +62 -0
  84. package/src/setPostReaction.js +112 -0
  85. package/src/setStoryReaction.js +64 -0
  86. package/src/setTitle.js +90 -0
  87. package/src/shareContact.js +110 -0
  88. package/src/shareLink.js +59 -0
  89. package/src/stopListenMqtt.js +23 -0
  90. package/src/threadColors.js +131 -0
  91. package/src/unfriend.js +52 -0
  92. package/src/unsendMessage.js +45 -0
  93. package/src/uploadAttachment.js +94 -0
  94. package/test/example-config.json +18 -0
  95. package/test/test-page.js +140 -0
  96. package/test/test.js +385 -0
  97. package/utils.js +2876 -0
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function addUserToGroup(userID, threadID, 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 (
16
+ !callback &&
17
+ (utils.getType(threadID) === "Function" ||
18
+ utils.getType(threadID) === "AsyncFunction")
19
+ ) {
20
+ throw new utils.CustomError({
21
+ error: "please pass a threadID as a second argument.",
22
+ });
23
+ }
24
+
25
+ if (!callback) {
26
+ callback = function (err) {
27
+ if (err) {
28
+ return rejectFunc(err);
29
+ }
30
+ resolveFunc();
31
+ };
32
+ }
33
+
34
+ if (
35
+ utils.getType(threadID) !== "Number" &&
36
+ utils.getType(threadID) !== "String"
37
+ ) {
38
+ throw new utils.CustomError({
39
+ error:
40
+ "ThreadID should be of type Number or String and not " +
41
+ utils.getType(threadID) +
42
+ ".",
43
+ });
44
+ }
45
+
46
+ if (utils.getType(userID) !== "Array") {
47
+ userID = [userID];
48
+ }
49
+
50
+ const messageAndOTID = utils.generateOfflineThreadingID();
51
+ const form = {
52
+ client: "mercury",
53
+ action_type: "ma-type:log-message",
54
+ author: "fbid:" + (ctx.userID),
55
+ thread_id: "",
56
+ timestamp: Date.now(),
57
+ timestamp_absolute: "Today",
58
+ timestamp_relative: utils.generateTimestampRelative(),
59
+ timestamp_time_passed: "0",
60
+ is_unread: false,
61
+ is_cleared: false,
62
+ is_forward: false,
63
+ is_filtered_content: false,
64
+ is_filtered_content_bh: false,
65
+ is_filtered_content_account: false,
66
+ is_spoof_warning: false,
67
+ source: "source:chat:web",
68
+ "source_tags[0]": "source:chat",
69
+ log_message_type: "log:subscribe",
70
+ status: "0",
71
+ offline_threading_id: messageAndOTID,
72
+ message_id: messageAndOTID,
73
+ threading_id: utils.generateThreadingID(ctx.clientID),
74
+ manual_retry_cnt: "0",
75
+ thread_fbid: threadID,
76
+ };
77
+
78
+ for (let i = 0; i < userID.length; i++) {
79
+ if (
80
+ utils.getType(userID[i]) !== "Number" &&
81
+ utils.getType(userID[i]) !== "String"
82
+ ) {
83
+ throw new utils.CustomError({
84
+ error:
85
+ "Elements of userID should be of type Number or String and not " +
86
+ utils.getType(userID[i]) +
87
+ ".",
88
+ });
89
+ }
90
+
91
+ form["log_message_data[added_participants][" + i + "]"] =
92
+ "fbid:" + userID[i];
93
+ }
94
+
95
+ defaultFuncs
96
+ .post("https://www.facebook.com/messaging/send/", ctx.jar, form)
97
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
98
+ .then(function (resData) {
99
+ if (!resData) {
100
+ throw new utils.CustomError({ error: "Add to group failed." });
101
+ }
102
+ if (resData.error) {
103
+ throw new utils.CustomError(resData);
104
+ }
105
+
106
+ return callback();
107
+ })
108
+ .catch(function (err) {
109
+ console.error("addUserToGroup", err);
110
+ return callback(err);
111
+ });
112
+
113
+ return returnPromise;
114
+ };
115
+ };
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function changeAdminStatus(threadID, adminIDs, adminStatus, callback) {
8
+ if (utils.getType(threadID) !== "String") {
9
+ throw new utils.CustomError({
10
+ error: "changeAdminStatus: threadID must be a string",
11
+ });
12
+ }
13
+
14
+ if (utils.getType(adminIDs) === "String") {
15
+ adminIDs = [adminIDs];
16
+ }
17
+
18
+ if (utils.getType(adminIDs) !== "Array") {
19
+ throw new utils.CustomError({
20
+ error: "changeAdminStatus: adminIDs must be an array or string",
21
+ });
22
+ }
23
+
24
+ if (utils.getType(adminStatus) !== "Boolean") {
25
+ throw new utils.CustomError({
26
+ error: "changeAdminStatus: adminStatus must be a string",
27
+ });
28
+ }
29
+
30
+ let resolveFunc = function () {};
31
+ let rejectFunc = function () {};
32
+ const returnPromise = new Promise(function (resolve, reject) {
33
+ resolveFunc = resolve;
34
+ rejectFunc = reject;
35
+ });
36
+
37
+ if (!callback) {
38
+ callback = function (err) {
39
+ if (err) {
40
+ return rejectFunc(err);
41
+ }
42
+ resolveFunc();
43
+ };
44
+ }
45
+
46
+ if (
47
+ utils.getType(callback) !== "Function" &&
48
+ utils.getType(callback) !== "AsyncFunction"
49
+ ) {
50
+ throw new utils.CustomError({
51
+ error: "changeAdminStatus: callback is not a function",
52
+ });
53
+ }
54
+
55
+ const form = {
56
+ thread_fbid: threadID,
57
+ };
58
+
59
+ let i = 0;
60
+ for (const u of adminIDs) {
61
+ form[`admin_ids[${i++}]`] = u;
62
+ }
63
+ form["add"] = adminStatus;
64
+
65
+ defaultFuncs
66
+ .post(
67
+ "https://www.facebook.com/messaging/save_admins/?dpr=1",
68
+ ctx.jar,
69
+ form,
70
+ )
71
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
72
+ .then(function (resData) {
73
+ if (resData.error) {
74
+ switch (resData.error) {
75
+ case 1976004:
76
+ throw new utils.CustomError({
77
+ error: "Cannot alter admin status: you are not an admin.",
78
+ rawResponse: resData,
79
+ });
80
+ case 1357031:
81
+ throw new utils.CustomError({
82
+ error:
83
+ "Cannot alter admin status: this thread is not a group chat.",
84
+ rawResponse: resData,
85
+ });
86
+ default:
87
+ throw new utils.CustomError({
88
+ error: "Cannot alter admin status: unknown error.",
89
+ rawResponse: resData,
90
+ });
91
+ }
92
+ }
93
+
94
+ callback();
95
+ })
96
+ .catch(function (err) {
97
+ console.error("changeAdminStatus", err);
98
+ return callback(err);
99
+ });
100
+
101
+ return returnPromise;
102
+ };
103
+ };
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function changeArchivedStatus(threadOrThreads, archive, 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) {
17
+ if (err) {
18
+ return rejectFunc(err);
19
+ }
20
+ resolveFunc();
21
+ };
22
+ }
23
+
24
+ const form = {};
25
+
26
+ if (utils.getType(threadOrThreads) === "Array") {
27
+ for (let i = 0; i < threadOrThreads.length; i++) {
28
+ form["ids[" + threadOrThreads[i] + "]"] = archive;
29
+ }
30
+ } else {
31
+ form["ids[" + threadOrThreads + "]"] = archive;
32
+ }
33
+
34
+ defaultFuncs
35
+ .post(
36
+ "https://www.facebook.com/ajax/mercury/change_archived_status.php",
37
+ ctx.jar,
38
+ form,
39
+ )
40
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
41
+ .then(function (resData) {
42
+ if (resData.error) {
43
+ throw resData;
44
+ }
45
+
46
+ return callback();
47
+ })
48
+ .catch(function (err) {
49
+ console.error("changeArchivedStatus", err);
50
+ return callback(err);
51
+ });
52
+
53
+ return returnPromise;
54
+ };
55
+ };
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ function handleUpload(image, callback) {
8
+ const uploads = [];
9
+
10
+ const form = {
11
+ profile_id: ctx.userID,
12
+ photo_source: 57,
13
+ av: ctx.userID,
14
+ file: image,
15
+ };
16
+
17
+ uploads.push(
18
+ defaultFuncs
19
+ .postFormData(
20
+ "https://www.facebook.com/profile/picture/upload/",
21
+ ctx.jar,
22
+ form,
23
+ {},
24
+ )
25
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
26
+ .then(function (resData) {
27
+ if (resData.error) {
28
+ throw resData;
29
+ }
30
+ return resData;
31
+ }),
32
+ );
33
+
34
+ // resolve all promises
35
+ Promise.all(uploads)
36
+ .then(function (resData) {
37
+ callback(null, resData);
38
+ })
39
+ .catch(function (err) {
40
+ console.error("handleUpload", err);
41
+ return callback(err);
42
+ });
43
+ }
44
+
45
+ return function changeAvatar(
46
+ image,
47
+ caption = "",
48
+ timestamp = null,
49
+ callback,
50
+ ) {
51
+ let resolveFunc = function () {};
52
+ let rejectFunc = function () {};
53
+ const returnPromise = new Promise(function (resolve, reject) {
54
+ resolveFunc = resolve;
55
+ rejectFunc = reject;
56
+ });
57
+
58
+ if (!timestamp && utils.getType(caption) === "Number") {
59
+ timestamp = caption;
60
+ caption = "";
61
+ }
62
+
63
+ if (
64
+ !timestamp &&
65
+ !callback &&
66
+ (utils.getType(caption) == "Function" ||
67
+ utils.getType(caption) == "AsyncFunction")
68
+ ) {
69
+ callback = caption;
70
+ caption = "";
71
+ timestamp = null;
72
+ }
73
+
74
+ if (!callback)
75
+ callback = function (err, data) {
76
+ if (err) {
77
+ return rejectFunc(err);
78
+ }
79
+ resolveFunc(data);
80
+ };
81
+
82
+ if (!utils.isReadableStream(image))
83
+ return callback("Image is not a readable stream");
84
+
85
+ handleUpload(image, function (err, payload) {
86
+ if (err) {
87
+ return callback(err);
88
+ }
89
+
90
+ const form = {
91
+ av: ctx.userID,
92
+ fb_api_req_friendly_name: "ProfileCometProfilePictureSetMutation",
93
+ fb_api_caller_class: "RelayModern",
94
+ doc_id: "5066134240065849",
95
+ variables: JSON.stringify({
96
+ input: {
97
+ caption,
98
+ existing_photo_id: payload[0].payload.fbid,
99
+ expiration_time: timestamp,
100
+ profile_id: ctx.userID,
101
+ profile_pic_method: "EXISTING",
102
+ profile_pic_source: "TIMELINE",
103
+ scaled_crop_rect: {
104
+ height: 1,
105
+ width: 1,
106
+ x: 0,
107
+ y: 0,
108
+ },
109
+ skip_cropping: true,
110
+ actor_id: ctx.userID,
111
+ client_mutation_id: Math.round(Math.random() * 19).toString(),
112
+ },
113
+ isPage: false,
114
+ isProfile: true,
115
+ scale: 3,
116
+ }),
117
+ };
118
+
119
+ defaultFuncs
120
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
121
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
122
+ .then(function (resData) {
123
+ if (resData.errors) {
124
+ throw resData;
125
+ }
126
+ return callback(null, resData[0].data.profile_picture_set);
127
+ })
128
+ .catch(function (err) {
129
+ console.error("changeAvatar", err);
130
+ return callback(err);
131
+ });
132
+ });
133
+
134
+ return returnPromise;
135
+ };
136
+ };
@@ -0,0 +1,86 @@
1
+
2
+ "use strict";
3
+
4
+ var utils = require("../utils");
5
+ // @NethWs3Dev
6
+ /**
7
+ * It posts an image to a Facebook profile
8
+ * @param Api - The API object
9
+ * @param BotID - The ID of the bot you want to post the image to.
10
+ * @param form - The form data that you want to send.
11
+ * @returns The JSON.parse(Data.split("for (;;);")[1]); is returning the following:
12
+ * {"__ar":1,"payload":null,"jsmods":{"require":[["ImageUploader","uploadPhoto",[{"__m":"__elem_0"},{"__m":"__elem_1"},{"__m":"__elem_2"},{"__m":"__
13
+ */
14
+ async function postImage(Api, BotID, form) {
15
+ var Data = await Api.httpPostFormData(`https://www.facebook.com/profile/picture/upload/?profile_id=${BotID}&photo_source=57&av=${BotID}`, form);
16
+ return JSON.parse(Data.split("for (;;);")[1]);
17
+ }
18
+
19
+ module.exports = function(defaultFuncs, api, ctx) {
20
+ /* Changing the profile picture of the bot. */
21
+ return function changeAvt(link, caption, callback) {
22
+ var resolveFunc = function() {};
23
+ var rejectFunc = function() {};
24
+ var returnPromise = new Promise(function(resolve, reject) {
25
+ resolveFunc = resolve;
26
+ rejectFunc = reject;
27
+ });
28
+
29
+ if (!callback) {
30
+ callback = function(err, data) {
31
+ if (err) return rejectFunc(err);
32
+ resolveFunc(data);
33
+ };
34
+ }
35
+ try {
36
+ var Fetch = require('axios')
37
+ Fetch.get(link, { responseType: "stream" }).then(data => {
38
+ postImage(api, ctx.userID, { file: data.data }).then(data => {
39
+ if (data.error) throw new Error({ error: data.error, des: data.error.errorDescription });
40
+ var form = {
41
+ av: ctx.userID,
42
+ fb_api_req_friendly_name: "ProfileCometProfilePictureSetMutation",
43
+ fb_api_caller_class: "RelayModern",
44
+ doc_id: "5066134240065849",
45
+ variables: JSON.stringify({
46
+ input: {
47
+ caption: (caption || ""),
48
+ existing_photo_id: data.payload.fbid,
49
+ expiration_time: null,
50
+ profile_id: ctx.userID,
51
+ profile_pic_method: "EXISTING",
52
+ profile_pic_source: "TIMELINE",
53
+ scaled_crop_rect: {
54
+ height: 1,
55
+ width: 1,
56
+ x: 0,
57
+ y: 0
58
+ },
59
+ skip_cropping: true,
60
+ actor_id: ctx.userID,
61
+ client_mutation_id: Math.round(Math.random() * 19).toString()
62
+ },
63
+ isPage: false,
64
+ isProfile: true,
65
+ scale: 3,
66
+ })
67
+ };
68
+ defaultFuncs
69
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
70
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
71
+ .then(function(resData) {
72
+ if (resData.error) throw resData;
73
+ else return callback(null,true)
74
+ })
75
+ .catch(function(err) {
76
+ return callback(err);
77
+ });
78
+ })
79
+ })
80
+ }
81
+ catch (e) {
82
+ throw e;
83
+ }
84
+ return returnPromise;
85
+ };
86
+ };
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+
3
+ var utils = require("../utils");
4
+ var log = require("npmlog");
5
+ /**
6
+ * It posts an image to a Facebook profile
7
+ * @param Api - The API object
8
+ * @param BotID - The ID of the bot you want to post the image to.
9
+ * @param form - The form data that you want to send.
10
+ * @returns The JSON.parse(Data.split("for (;;);")[1]); is returning the following:
11
+ * {"__ar":1,"payload":null,"jsmods":{"require":[["ImageUploader","uploadPhoto",[{"__m":"__elem_0"},{"__m":"__elem_1"},{"__m":"__elem_2"},{"__m":"__
12
+ */
13
+ async function postImage(Api,BotID,form) {
14
+ var Data = await Api.httpPostFormData(`https://www.facebook.com/profile/picture/upload/?profile_id=${BotID}&photo_source=57&av=${BotID}`, form);
15
+ return JSON.parse(Data.split("for (;;);")[1]);
16
+ }
17
+
18
+ module.exports = function(defaultFuncs, api, ctx) {
19
+ /* Changing the profile picture of the bot. */
20
+ return function changeAvt(link, caption, callback) {
21
+ var resolveFunc = function() {};
22
+ var rejectFunc = function() {};
23
+ var returnPromise = new Promise(function(resolve, reject) {
24
+ resolveFunc = resolve;
25
+ rejectFunc = reject;
26
+ });
27
+
28
+ if (!callback) {
29
+ callback = function(err, data) {
30
+ if (err) return rejectFunc(err);
31
+ resolveFunc(data);
32
+ };
33
+ }
34
+ try {
35
+ var Fetch = require('axios')
36
+ Fetch.get(link, { responseType: "stream" }).then(data => {
37
+ postImage(api, ctx.userID, { file: data.data }).then(data => {
38
+ if (data.error) throw new Error({ error: data.error, des: data.error.errorDescription });
39
+ var form = {
40
+ av: ctx.userID,
41
+ fb_api_req_friendly_name: "ProfileCometProfilePictureSetMutation",
42
+ fb_api_caller_class: "RelayModern",
43
+ doc_id: "5066134240065849",
44
+ variables: JSON.stringify({
45
+ input: {
46
+ caption: (caption || ""),
47
+ existing_photo_id: data.payload.fbid,
48
+ expiration_time: null,
49
+ profile_id: ctx.userID,
50
+ profile_pic_method: "EXISTING",
51
+ profile_pic_source: "TIMELINE",
52
+ scaled_crop_rect: {
53
+ height: 1,
54
+ width: 1,
55
+ x: 0,
56
+ y: 0
57
+ },
58
+ skip_cropping: true,
59
+ actor_id: ctx.userID,
60
+ client_mutation_id: Math.round(Math.random() * 19).toString()
61
+ },
62
+ isPage: false,
63
+ isProfile: true,
64
+ scale: 3,
65
+ })
66
+ };
67
+ defaultFuncs
68
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
69
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
70
+ .then(function(resData) {
71
+ if (resData.error) throw resData;
72
+ else return callback(null,true)
73
+ })
74
+ .catch(function(err) {
75
+ return callback(err);
76
+ });
77
+ })
78
+ })
79
+ }
80
+ catch (e) {
81
+ throw e;
82
+ }
83
+ return returnPromise;
84
+ };
85
+ };
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+
3
+ const utils = require("../utils");
4
+ // @NethWs3Dev
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ return function changeBio(bio, publish, 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
+ utils.getType(publish) == "Function" ||
18
+ utils.getType(publish) == "AsyncFunction"
19
+ ) {
20
+ callback = publish;
21
+ } else {
22
+ callback = function (err) {
23
+ if (err) {
24
+ return rejectFunc(err);
25
+ }
26
+ resolveFunc();
27
+ };
28
+ }
29
+ }
30
+
31
+ if (utils.getType(publish) != "Boolean") {
32
+ publish = false;
33
+ }
34
+
35
+ if (utils.getType(bio) != "String") {
36
+ bio = "";
37
+ publish = false;
38
+ }
39
+
40
+ const form = {
41
+ fb_api_caller_class: "RelayModern",
42
+ fb_api_req_friendly_name: "ProfileCometSetBioMutation",
43
+ // This doc_is is valid as of May 23, 2020
44
+ doc_id: "2725043627607610",
45
+ variables: JSON.stringify({
46
+ input: {
47
+ bio: bio,
48
+ publish_bio_feed_story: publish,
49
+ actor_id: ctx.userID,
50
+ client_mutation_id: Math.round(Math.random() * 1024).toString(),
51
+ },
52
+ hasProfileTileViewID: false,
53
+ profileTileViewID: null,
54
+ scale: 1,
55
+ }),
56
+ av: ctx.userID,
57
+ };
58
+
59
+ defaultFuncs
60
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
61
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
62
+ .then(function (resData) {
63
+ if (resData.errors) {
64
+ throw resData;
65
+ }
66
+
67
+ return callback();
68
+ })
69
+ .catch(function (err) {
70
+ console.error("changeBio", err);
71
+ return callback(err);
72
+ });
73
+
74
+ return returnPromise;
75
+ };
76
+ };