rapido-fca 0.0.1 → 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.
Files changed (79) hide show
  1. package/package.json +1 -1
  2. package/readme.md +39 -237
  3. package/src/addExternalModule.js +23 -19
  4. package/src/addUserToGroup.js +97 -99
  5. package/src/changeAdminStatus.js +62 -86
  6. package/src/changeArchivedStatus.js +49 -49
  7. package/src/changeAvatar.js +108 -118
  8. package/src/changeBio.js +64 -63
  9. package/src/changeBlockedStatus.js +38 -40
  10. package/src/changeGroupImage.js +126 -129
  11. package/src/changeNickname.js +49 -49
  12. package/src/changeThreadColor.js +53 -53
  13. package/src/changeThreadEmoji.js +45 -45
  14. package/src/createNewGroup.js +72 -74
  15. package/src/createPoll.js +59 -59
  16. package/src/deleteMessage.js +50 -50
  17. package/src/deleteThread.js +50 -50
  18. package/src/editMessage.js +49 -51
  19. package/src/forwardAttachment.js +54 -54
  20. package/src/getCurrentUserID.js +3 -3
  21. package/src/getEmojiUrl.js +17 -17
  22. package/src/getFriendsList.js +67 -67
  23. package/src/getMessage.js +767 -806
  24. package/src/getThreadHistory.js +642 -656
  25. package/src/getThreadInfo.js +1 -1
  26. package/src/getThreadList.js +227 -199
  27. package/src/getThreadPictures.js +71 -51
  28. package/src/getUserID.js +58 -53
  29. package/src/getUserInfo.js +60 -52
  30. package/src/handleFriendRequest.js +65 -41
  31. package/src/handleMessageRequest.js +60 -42
  32. package/src/httpGet.js +57 -49
  33. package/src/httpPost.js +57 -48
  34. package/src/httpPostFormData.js +63 -0
  35. package/src/listenMqtt.js +895 -827
  36. package/src/logout.js +61 -61
  37. package/src/markAsDelivered.js +53 -42
  38. package/src/markAsRead.js +69 -59
  39. package/src/markAsReadAll.js +42 -32
  40. package/src/markAsSeen.js +54 -43
  41. package/src/muteThread.js +47 -40
  42. package/src/refreshFb_dtsg.js +69 -77
  43. package/src/removeUserFromGroup.js +67 -67
  44. package/src/resolvePhotoUrl.js +34 -34
  45. package/src/searchForThread.js +43 -43
  46. package/src/sendMessage.js +228 -80
  47. package/src/sendTypingIndicator.js +88 -86
  48. package/src/setMessageReaction.js +109 -110
  49. package/src/setPostReaction.js +87 -90
  50. package/src/setTitle.js +72 -76
  51. package/src/threadColors.js +121 -121
  52. package/src/unfriend.js +43 -43
  53. package/src/unsendMessage.js +38 -34
  54. package/src/uploadAttachment.js +81 -79
  55. package/src/changeAvatarV2.js +0 -86
  56. package/src/changeAvt.js +0 -85
  57. package/src/changeBlockedStatusMqtt.js +0 -80
  58. package/src/changeCover.js +0 -72
  59. package/src/changeName.js +0 -79
  60. package/src/changeUsername.js +0 -59
  61. package/src/createCommentPost.js +0 -230
  62. package/src/createPost.js +0 -276
  63. package/src/editMessageOld.js +0 -67
  64. package/src/follow.js +0 -74
  65. package/src/getAccess.js +0 -112
  66. package/src/getAvatarUser.js +0 -78
  67. package/src/getRegion.js +0 -7
  68. package/src/getThreadHistoryDeprecated.js +0 -71
  69. package/src/getThreadInfoDeprecated.js +0 -56
  70. package/src/getThreadListDeprecated.js +0 -46
  71. package/src/getUID.js +0 -119
  72. package/src/searchStickers.js +0 -53
  73. package/src/sendMessageMqtt.js +0 -322
  74. package/src/sendTypingIndicatorV2.js +0 -28
  75. package/src/setMessageReactionMqtt.js +0 -62
  76. package/src/setStoryReaction.js +0 -64
  77. package/src/shareContact.js +0 -110
  78. package/src/shareLink.js +0 -59
  79. package/src/stopListenMqtt.js +0 -23
@@ -1,103 +1,79 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
5
5
 
6
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
- }
7
+ return function changeAdminStatus(threadID, adminIDs, adminStatus, callback) {
8
+ if (utils.getType(threadID) !== "String") {
9
+ throw new utils.CustomError({ error: "changeAdminStatus: threadID must be a string" });
10
+ }
13
11
 
14
- if (utils.getType(adminIDs) === "String") {
15
- adminIDs = [adminIDs];
16
- }
12
+ if (utils.getType(adminIDs) === "String") {
13
+ adminIDs = [adminIDs];
14
+ }
17
15
 
18
- if (utils.getType(adminIDs) !== "Array") {
19
- throw new utils.CustomError({
20
- error: "changeAdminStatus: adminIDs must be an array or string",
21
- });
22
- }
16
+ if (utils.getType(adminIDs) !== "Array") {
17
+ throw new utils.CustomError({ error: "changeAdminStatus: adminIDs must be an array or string" });
18
+ }
23
19
 
24
- if (utils.getType(adminStatus) !== "Boolean") {
25
- throw new utils.CustomError({
26
- error: "changeAdminStatus: adminStatus must be a string",
27
- });
28
- }
20
+ if (utils.getType(adminStatus) !== "Boolean") {
21
+ throw new utils.CustomError({ error: "changeAdminStatus: adminStatus must be a string" });
22
+ }
29
23
 
30
- let resolveFunc = function () {};
31
- let rejectFunc = function () {};
32
- const returnPromise = new Promise(function (resolve, reject) {
33
- resolveFunc = resolve;
34
- rejectFunc = reject;
35
- });
24
+ let resolveFunc = function () { };
25
+ let rejectFunc = function () { };
26
+ const returnPromise = new Promise(function (resolve, reject) {
27
+ resolveFunc = resolve;
28
+ rejectFunc = reject;
29
+ });
36
30
 
37
- if (!callback) {
38
- callback = function (err) {
39
- if (err) {
40
- return rejectFunc(err);
41
- }
42
- resolveFunc();
43
- };
44
- }
31
+ if (!callback) {
32
+ callback = function (err) {
33
+ if (err) {
34
+ return rejectFunc(err);
35
+ }
36
+ resolveFunc();
37
+ };
38
+ }
45
39
 
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
- }
40
+ if (utils.getType(callback) !== "Function" && utils.getType(callback) !== "AsyncFunction") {
41
+ throw new utils.CustomError({ error: "changeAdminStatus: callback is not a function" });
42
+ }
54
43
 
55
- const form = {
56
- thread_fbid: threadID,
57
- };
44
+ const form = {
45
+ "thread_fbid": threadID
46
+ };
58
47
 
59
- let i = 0;
60
- for (const u of adminIDs) {
61
- form[`admin_ids[${i++}]`] = u;
62
- }
63
- form["add"] = adminStatus;
48
+ let i = 0;
49
+ for (const u of adminIDs) {
50
+ form[`admin_ids[${i++}]`] = u;
51
+ }
52
+ form["add"] = adminStatus;
64
53
 
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
- }
54
+ defaultFuncs
55
+ .post("https://www.facebook.com/messaging/save_admins/?dpr=1", ctx.jar, form)
56
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
57
+ .then(function (resData) {
58
+ if (resData.error) {
59
+ switch (resData.error) {
60
+ case 1976004:
61
+ throw new utils.CustomError({ error: "Cannot alter admin status: you are not an admin.", rawResponse: resData });
62
+ case 1357031:
63
+ throw new utils.CustomError({ error: "Cannot alter admin status: this thread is not a group chat.", rawResponse: resData });
64
+ default:
65
+ throw new utils.CustomError({ error: "Cannot alter admin status: unknown error.", rawResponse: resData });
66
+ }
67
+ }
93
68
 
94
- callback();
95
- })
96
- .catch(function (err) {
97
- console.error("changeAdminStatus", err);
98
- return callback(err);
99
- });
69
+ callback();
70
+ })
71
+ .catch(function (err) {
72
+ log.error("changeAdminStatus", err);
73
+ return callback(err);
74
+ });
100
75
 
101
- return returnPromise;
102
- };
76
+ return returnPromise;
77
+ };
103
78
  };
79
+
@@ -1,55 +1,55 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
5
5
 
6
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
- };
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
+ log.error("changeArchivedStatus", err);
50
+ return callback(err);
51
+ });
52
+
53
+ return returnPromise;
54
+ };
55
55
  };
@@ -1,136 +1,126 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
5
5
 
6
6
  module.exports = function (defaultFuncs, api, ctx) {
7
- function handleUpload(image, callback) {
8
- const uploads = [];
7
+ function handleUpload(image, callback) {
8
+ const uploads = [];
9
9
 
10
- const form = {
11
- profile_id: ctx.userID,
12
- photo_source: 57,
13
- av: ctx.userID,
14
- file: image,
15
- };
10
+ const form = {
11
+ profile_id: ctx.i_userID || ctx.userID,
12
+ photo_source: 57,
13
+ av: ctx.i_userID || ctx.userID,
14
+ file: image
15
+ };
16
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
- );
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
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
- }
34
+ // resolve all promises
35
+ Promise
36
+ .all(uploads)
37
+ .then(function (resData) {
38
+ callback(null, resData);
39
+ })
40
+ .catch(function (err) {
41
+ log.error("handleUpload", err);
42
+ return callback(err);
43
+ });
44
+ }
44
45
 
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
- });
46
+ return function changeAvatar(image, caption = "", timestamp = null, callback) {
47
+ let resolveFunc = function () { };
48
+ let rejectFunc = function () { };
49
+ const returnPromise = new Promise(function (resolve, reject) {
50
+ resolveFunc = resolve;
51
+ rejectFunc = reject;
52
+ });
57
53
 
58
- if (!timestamp && utils.getType(caption) === "Number") {
59
- timestamp = caption;
60
- caption = "";
61
- }
54
+ if (!timestamp && utils.getType(caption) === "Number") {
55
+ timestamp = caption;
56
+ caption = "";
57
+ }
62
58
 
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
- }
59
+ if (!timestamp && !callback && (utils.getType(caption) == "Function" || utils.getType(caption) == "AsyncFunction")) {
60
+ callback = caption;
61
+ caption = "";
62
+ timestamp = null;
63
+ }
73
64
 
74
- if (!callback)
75
- callback = function (err, data) {
76
- if (err) {
77
- return rejectFunc(err);
78
- }
79
- resolveFunc(data);
80
- };
65
+ if (!callback) callback = function (err, data) {
66
+ if (err) {
67
+ return rejectFunc(err);
68
+ }
69
+ resolveFunc(data);
70
+ };
81
71
 
82
- if (!utils.isReadableStream(image))
83
- return callback("Image is not a readable stream");
72
+ if (!utils.isReadableStream(image))
73
+ return callback("Image is not a readable stream");
84
74
 
85
- handleUpload(image, function (err, payload) {
86
- if (err) {
87
- return callback(err);
88
- }
75
+ handleUpload(image, function (err, payload) {
76
+ if (err) {
77
+ return callback(err);
78
+ }
89
79
 
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
- };
80
+ const form = {
81
+ av: ctx.i_userID || ctx.userID,
82
+ fb_api_req_friendly_name: "ProfileCometProfilePictureSetMutation",
83
+ fb_api_caller_class: "RelayModern",
84
+ doc_id: "5066134240065849",
85
+ variables: JSON.stringify({
86
+ input: {
87
+ caption,
88
+ existing_photo_id: payload[0].payload.fbid,
89
+ expiration_time: timestamp,
90
+ profile_id: ctx.i_userID || ctx.userID,
91
+ profile_pic_method: "EXISTING",
92
+ profile_pic_source: "TIMELINE",
93
+ scaled_crop_rect: {
94
+ height: 1,
95
+ width: 1,
96
+ x: 0,
97
+ y: 0
98
+ },
99
+ skip_cropping: true,
100
+ actor_id: ctx.i_userID || ctx.userID,
101
+ client_mutation_id: Math.round(Math.random() * 19).toString()
102
+ },
103
+ isPage: false,
104
+ isProfile: true,
105
+ scale: 3
106
+ })
107
+ };
118
108
 
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
- });
109
+ defaultFuncs
110
+ .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
111
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
112
+ .then(function (resData) {
113
+ if (resData.errors) {
114
+ throw resData;
115
+ }
116
+ return callback(null, resData[0].data.profile_picture_set);
117
+ })
118
+ .catch(function (err) {
119
+ log.error("changeAvatar", err);
120
+ return callback(err);
121
+ });
122
+ });
133
123
 
134
- return returnPromise;
135
- };
124
+ return returnPromise;
125
+ };
136
126
  };
package/src/changeBio.js CHANGED
@@ -1,76 +1,77 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- // @NethWs3Dev
4
+ const log = require("npmlog");
5
5
 
6
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
- });
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
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
- }
15
+ if (!callback) {
16
+ if (utils.getType(publish) == "Function" || utils.getType(publish) == "AsyncFunction") {
17
+ callback = publish;
18
+ } else {
19
+ callback = function (err) {
20
+ if (err) {
21
+ return rejectFunc(err);
22
+ }
23
+ resolveFunc();
24
+ };
25
+ }
26
+ }
30
27
 
31
- if (utils.getType(publish) != "Boolean") {
32
- publish = false;
33
- }
28
+ if (utils.getType(publish) != "Boolean") {
29
+ publish = false;
30
+ }
34
31
 
35
- if (utils.getType(bio) != "String") {
36
- bio = "";
37
- publish = false;
38
- }
32
+ if (utils.getType(bio) != "String") {
33
+ bio = "";
34
+ publish = false;
35
+ }
39
36
 
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
- };
37
+ const form = {
38
+ fb_api_caller_class: "RelayModern",
39
+ fb_api_req_friendly_name: "ProfileCometSetBioMutation",
40
+ // This doc_is is valid as of May 23, 2020
41
+ doc_id: "2725043627607610",
42
+ variables: JSON.stringify({
43
+ input: {
44
+ bio: bio,
45
+ publish_bio_feed_story: publish,
46
+ actor_id: ctx.i_userID || ctx.userID,
47
+ client_mutation_id: Math.round(Math.random() * 1024).toString()
48
+ },
49
+ hasProfileTileViewID: false,
50
+ profileTileViewID: null,
51
+ scale: 1
52
+ }),
53
+ av: ctx.i_userID || ctx.userID
54
+ };
58
55
 
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
- }
56
+ defaultFuncs
57
+ .post(
58
+ "https://www.facebook.com/api/graphql/",
59
+ ctx.jar,
60
+ form
61
+ )
62
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
63
+ .then(function (resData) {
64
+ if (resData.errors) {
65
+ throw resData;
66
+ }
66
67
 
67
- return callback();
68
- })
69
- .catch(function (err) {
70
- console.error("changeBio", err);
71
- return callback(err);
72
- });
68
+ return callback();
69
+ })
70
+ .catch(function (err) {
71
+ log.error("changeBio", err);
72
+ return callback(err);
73
+ });
73
74
 
74
- return returnPromise;
75
- };
75
+ return returnPromise;
76
+ };
76
77
  };