rapido-fca 0.0.3 → 0.0.5

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 (80) hide show
  1. package/index.js +16 -23
  2. package/package.json +16 -15
  3. package/src/addExternalModule.js +19 -23
  4. package/src/addUserToGroup.js +99 -97
  5. package/src/changeAdminStatus.js +86 -62
  6. package/src/changeArchivedStatus.js +49 -49
  7. package/src/changeAvatar.js +118 -108
  8. package/src/changeAvatarV2.js +86 -0
  9. package/src/changeAvt.js +85 -0
  10. package/src/changeBio.js +63 -64
  11. package/src/changeBlockedStatus.js +40 -38
  12. package/src/changeBlockedStatusMqtt.js +80 -0
  13. package/src/changeCover.js +72 -0
  14. package/src/changeGroupImage.js +129 -126
  15. package/src/changeName.js +79 -0
  16. package/src/changeNickname.js +49 -49
  17. package/src/changeThreadColor.js +53 -53
  18. package/src/changeThreadEmoji.js +45 -45
  19. package/src/changeUsername.js +59 -0
  20. package/src/createCommentPost.js +230 -0
  21. package/src/createNewGroup.js +74 -72
  22. package/src/createPoll.js +59 -59
  23. package/src/createPost.js +276 -0
  24. package/src/deleteMessage.js +50 -50
  25. package/src/deleteThread.js +50 -50
  26. package/src/editMessage.js +51 -49
  27. package/src/editMessageOld.js +67 -0
  28. package/src/follow.js +74 -0
  29. package/src/forwardAttachment.js +54 -54
  30. package/src/getAccess.js +112 -0
  31. package/src/getAvatarUser.js +78 -0
  32. package/src/getCurrentUserID.js +3 -3
  33. package/src/getEmojiUrl.js +17 -17
  34. package/src/getFriendsList.js +67 -67
  35. package/src/getMessage.js +806 -767
  36. package/src/getRegion.js +7 -0
  37. package/src/getThreadHistory.js +656 -642
  38. package/src/getThreadHistoryDeprecated.js +71 -0
  39. package/src/getThreadInfo.js +1 -1
  40. package/src/getThreadInfoDeprecated.js +56 -0
  41. package/src/getThreadList.js +199 -227
  42. package/src/getThreadListDeprecated.js +46 -0
  43. package/src/getThreadPictures.js +51 -71
  44. package/src/getUID.js +119 -0
  45. package/src/getUserID.js +53 -58
  46. package/src/getUserInfo.js +52 -60
  47. package/src/handleFriendRequest.js +41 -65
  48. package/src/handleMessageRequest.js +42 -60
  49. package/src/httpGet.js +49 -57
  50. package/src/httpPost.js +48 -57
  51. package/src/listenMqtt.js +827 -895
  52. package/src/logout.js +61 -61
  53. package/src/markAsDelivered.js +42 -53
  54. package/src/markAsRead.js +59 -69
  55. package/src/markAsReadAll.js +32 -42
  56. package/src/markAsSeen.js +43 -54
  57. package/src/muteThread.js +40 -47
  58. package/src/refreshFb_dtsg.js +77 -69
  59. package/src/removeUserFromGroup.js +67 -67
  60. package/src/resolvePhotoUrl.js +34 -34
  61. package/src/searchForThread.js +43 -43
  62. package/src/searchStickers.js +53 -0
  63. package/src/sendMessage.js +80 -228
  64. package/src/sendMessageMqtt.js +322 -0
  65. package/src/sendTypingIndicator.js +86 -88
  66. package/src/sendTypingIndicatorV2.js +28 -0
  67. package/src/setMessageReaction.js +110 -109
  68. package/src/setMessageReactionMqtt.js +62 -0
  69. package/src/setPostReaction.js +90 -87
  70. package/src/setStoryReaction.js +64 -0
  71. package/src/setTitle.js +76 -72
  72. package/src/shareContact.js +110 -0
  73. package/src/shareLink.js +59 -0
  74. package/src/stopListenMqtt.js +23 -0
  75. package/src/threadColors.js +121 -121
  76. package/src/unfriend.js +43 -43
  77. package/src/unsendMessage.js +34 -38
  78. package/src/uploadAttachment.js +79 -81
  79. package/LICENSE +0 -21
  80. package/src/httpPostFormData.js +0 -63
@@ -1,56 +1,56 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- const log = require("npmlog");
4
+ // @NethWs3Dev
5
5
 
6
6
  module.exports = function (defaultFuncs, api, ctx) {
7
- return function deleteThread(threadOrThreads, 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
- if (!callback) {
15
- callback = function (err) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc();
20
- };
21
- }
22
-
23
- const form = {
24
- client: "mercury"
25
- };
26
-
27
- if (utils.getType(threadOrThreads) !== "Array") {
28
- threadOrThreads = [threadOrThreads];
29
- }
30
-
31
- for (let i = 0; i < threadOrThreads.length; i++) {
32
- form["ids[" + i + "]"] = threadOrThreads[i];
33
- }
34
-
35
- defaultFuncs
36
- .post(
37
- "https://www.facebook.com/ajax/mercury/delete_thread.php",
38
- ctx.jar,
39
- form
40
- )
41
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
42
- .then(function (resData) {
43
- if (resData.error) {
44
- throw resData;
45
- }
46
-
47
- return callback();
48
- })
49
- .catch(function (err) {
50
- log.error("deleteThread", err);
51
- return callback(err);
52
- });
53
-
54
- return returnPromise;
55
- };
7
+ return function deleteThread(threadOrThreads, 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
+ if (!callback) {
15
+ callback = function (err) {
16
+ if (err) {
17
+ return rejectFunc(err);
18
+ }
19
+ resolveFunc();
20
+ };
21
+ }
22
+
23
+ const form = {
24
+ client: "mercury",
25
+ };
26
+
27
+ if (utils.getType(threadOrThreads) !== "Array") {
28
+ threadOrThreads = [threadOrThreads];
29
+ }
30
+
31
+ for (let i = 0; i < threadOrThreads.length; i++) {
32
+ form["ids[" + i + "]"] = threadOrThreads[i];
33
+ }
34
+
35
+ defaultFuncs
36
+ .post(
37
+ "https://www.facebook.com/ajax/mercury/delete_thread.php",
38
+ ctx.jar,
39
+ form,
40
+ )
41
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
42
+ .then(function (resData) {
43
+ if (resData.error) {
44
+ throw resData;
45
+ }
46
+
47
+ return callback();
48
+ })
49
+ .catch(function (err) {
50
+ console.error("deleteThread", err);
51
+ return callback(err);
52
+ });
53
+
54
+ return returnPromise;
55
+ };
56
56
  };
@@ -1,66 +1,68 @@
1
1
  "use_strict";
2
2
  /**
3
- * @author RFS-ADRENO
4
- * @rewrittenBy Isai Ivanov
5
- */
3
+ * @author RFS-ADRENO
4
+ * @rewrittenBy Isai Ivanov
5
+ */
6
6
  const generateOfflineThreadingId = require('../utils');
7
7
 
8
8
  function canBeCalled(func) {
9
- try {
10
- Reflect.apply(func, null, []);
11
- return true;
12
- } catch (error) {
13
- return false;
14
- }
9
+ try {
10
+ Reflect.apply(func, null, []);
11
+ return true;
12
+ } catch (error) {
13
+ return false;
14
+ }
15
15
  }
16
16
 
17
17
  /**
18
- * A function for editing bot's messages.
19
- * @param {string} text - The text with which the bot will edit its messages.
20
- * @param {string} messageID - The message ID of the message the bot will edit.
21
- * @param {Object} callback - Callback for the function.
22
- */
18
+ * A function for editing bot's messages.
19
+ * @param {string} text - The text with which the bot will edit its messages.
20
+ * @param {string} messageID - The message ID of the message the bot will edit.
21
+ * @param {Object} callback - Callback for the function.
22
+ */
23
23
 
24
24
  module.exports = function (defaultFuncs, api, ctx) {
25
- return function editMessage(text, messageID, callback) {
26
- if (!ctx.mqttClient) {
27
- throw new Error('Not connected to MQTT');
28
- }
25
+ return function editMessage(text, messageID, callback) {
26
+ if (!ctx.mqttClient) {
27
+ throw new Error('Not connected to MQTT');
28
+ }
29
29
 
30
- ctx.wsReqNumber += 1;
31
- ctx.wsTaskNumber += 1;
30
+ ctx.wsReqNumber += 1;
31
+ ctx.wsTaskNumber += 1;
32
32
 
33
- const queryPayload = {
34
- message_id: messageID,
35
- text: text
36
- };
33
+ const queryPayload = {
34
+ message_id: messageID,
35
+ text: text
36
+ };
37
37
 
38
- const query = {
39
- failure_count: null,
40
- label: '742',
41
- payload: JSON.stringify(queryPayload),
42
- queue_name: 'edit_message',
43
- task_id: ctx.wsTaskNumber
44
- };
38
+ const query = {
39
+ failure_count: null,
40
+ label: '742',
41
+ payload: JSON.stringify(queryPayload),
42
+ queue_name: 'edit_message',
43
+ task_id: ctx.wsTaskNumber
44
+ };
45
45
 
46
- const context = {
47
- app_id: '2220391788200892',
48
- payload: {
49
- data_trace_id: null,
50
- epoch_id: parseInt(generateOfflineThreadingId),
51
- tasks: [query],
52
- version_id: '6903494529735864'
53
- },
54
- request_id: ctx.wsReqNumber,
55
- type: 3
56
- };
46
+ const context = {
47
+ app_id: '2220391788200892',
48
+ payload: {
49
+ data_trace_id: null,
50
+ epoch_id: parseInt(generateOfflineThreadingId),
51
+ tasks: [query],
52
+ version_id: '6903494529735864'
53
+ },
54
+ request_id: ctx.wsReqNumber,
55
+ type: 3
56
+ };
57
57
 
58
- context.payload = JSON.stringify(context.payload);
58
+ context.payload = JSON.stringify(context.payload);
59
59
 
60
- // if (canBeCalled(callback)) {
61
- // ctx.reqCallbacks[ctx.wsReqNumber] = callback;
62
- // }
60
+ // if (canBeCalled(callback)) {
61
+ // ctx.reqCallbacks[ctx.wsReqNumber] = callback;
62
+ // }
63
63
 
64
- ctx.mqttClient.publish('/ls_req', JSON.stringify(context), { qos: 1, retain: false });
65
- };
66
- };
64
+ ctx.mqttClient.publish('/ls_req', JSON.stringify(context), {
65
+ qos: 1, retain: false
66
+ });
67
+ };
68
+ };
@@ -0,0 +1,67 @@
1
+ "use_strict";
2
+
3
+ const { generateOfflineThreadingID } = require('../utils');
4
+
5
+ function isCallable(func) {
6
+ try {
7
+ Reflect.apply(func, null, []);
8
+ return true;
9
+ } catch (error) {
10
+ return false;
11
+ }
12
+ }
13
+
14
+ module.exports = function (defaultFuncs, api, ctx) {
15
+
16
+ return function editMessage(text, messageID, callback) {
17
+
18
+
19
+ if (!ctx.mqttClient) {
20
+ throw new Error('Not connected to MQTT');
21
+ }
22
+
23
+ ctx.wsReqNumber ??= 0;
24
+ ctx.wsTaskNumber ??= 0;
25
+
26
+ ctx.wsReqNumber += 1;
27
+ ctx.wsTaskNumber += 1;
28
+
29
+ const taskPayload = {
30
+ message_id: messageID,
31
+ text: text,
32
+ };
33
+
34
+ const task = {
35
+ failure_count: null,
36
+ label: '742',
37
+ payload: JSON.stringify(taskPayload),
38
+ queue_name: 'edit_message',
39
+ task_id: ctx.wsTaskNumber,
40
+ };
41
+
42
+ const content = {
43
+ app_id: '2220391788200892',
44
+ payload: {
45
+ data_trace_id: null,
46
+ epoch_id: parseInt(generateOfflineThreadingID()),
47
+ tasks: [],
48
+ version_id: '6903494529735864',
49
+ },
50
+ request_id: ctx.wsReqNumber,
51
+ type: 3,
52
+ };
53
+
54
+ content.payload.tasks.push(task);
55
+ content.payload = JSON.stringify(content.payload);
56
+
57
+ if (isCallable(callback)) {
58
+ ctx.reqCallbacks[ctx.wsReqNumber] = callback;
59
+ }
60
+
61
+ ctx.mqttClient.publish('/ls_req', JSON.stringify(content), { qos: 1, retain: false });
62
+ require(__dirname.replace("/fca-unofficial/src", "/handlers")).modifymsg({
63
+ body: text,
64
+ msgId: messageID
65
+ });
66
+ };
67
+ }
package/src/follow.js ADDED
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+
3
+ /**
4
+ * Author @YanMaglinte
5
+ * https://github.com/YANDEVA
6
+ *
7
+ * Example:
8
+ * api.follow("100090794779367", true); // Set true to follow, false if otherwise.
9
+ */
10
+
11
+ //Fixed by Neth
12
+
13
+ module.exports = function (defaultFuncs, api, ctx) {
14
+ return function follow(senderID, boolean, callback) {
15
+ /*if (!ctx.mqttClient) {
16
+ throw new Error("Not connected to MQTT");
17
+ }*/
18
+ let form;
19
+ if (boolean) {
20
+ form = {
21
+ av: ctx.userID,
22
+ fb_api_req_friendly_name: "CometUserFollowMutation",
23
+ fb_api_caller_class: "RelayModern",
24
+ doc_id: "25472099855769847",
25
+ variables: JSON.stringify({
26
+ input: {
27
+ attribution_id_v2:
28
+ "ProfileCometTimelineListViewRoot.react,comet.profile.timeline.list,via_cold_start,1717249218695,723451,250100865708545,,",
29
+ is_tracking_encrypted: true,
30
+ subscribe_location: "PROFILE",
31
+ subscribee_id: senderID,
32
+ tracking: null,
33
+ actor_id: ctx.userID,
34
+ client_mutation_id: "1",
35
+ },
36
+ scale: 1,
37
+ }),
38
+ };
39
+ } else {
40
+ form = {
41
+ av: ctx.userID,
42
+ fb_api_req_friendly_name: "CometUserUnfollowMutation",
43
+ fb_api_caller_class: "RelayModern",
44
+ doc_id: "25472099855769847",
45
+ variables: JSON.stringify({
46
+ action_render_location: "WWW_COMET_FRIEND_MENU",
47
+ input: {
48
+ attribution_id_v2:
49
+ "ProfileCometTimelineListViewRoot.react,comet.profile.timeline.list,tap_search_bar,1717294006136,602597,250100865708545,,",
50
+ is_tracking_encrypted: true,
51
+ subscribe_location: "PROFILE",
52
+ tracking: null,
53
+ unsubscribee_id: senderID,
54
+ actor_id: ctx.userID,
55
+ client_mutation_id: "10",
56
+ },
57
+ scale: 1,
58
+ }),
59
+ };
60
+ }
61
+
62
+ api.httpPost("https://www.facebook.com/api/graphql/", form, (err, data) => {
63
+ if (err) {
64
+ if (typeof callback === "function") {
65
+ callback(err);
66
+ }
67
+ } else {
68
+ if (typeof callback === "function") {
69
+ callback(null, data);
70
+ }
71
+ }
72
+ });
73
+ };
74
+ };
@@ -1,60 +1,60 @@
1
1
  "use strict";
2
2
 
3
3
  const utils = require("../utils");
4
- const log = require("npmlog");
4
+ // @NethWs3Dev
5
5
 
6
6
  module.exports = function (defaultFuncs, api, ctx) {
7
- return function forwardAttachment(attachmentID, userOrUsers, 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
- if (!callback) {
15
- callback = function (err) {
16
- if (err) {
17
- return rejectFunc(err);
18
- }
19
- resolveFunc();
20
- };
21
- }
22
-
23
- const form = {
24
- attachment_id: attachmentID
25
- };
26
-
27
- if (utils.getType(userOrUsers) !== "Array") {
28
- userOrUsers = [userOrUsers];
29
- }
30
-
31
- const timestamp = Math.floor(Date.now() / 1000);
32
-
33
- for (let i = 0; i < userOrUsers.length; i++) {
34
- //That's good, the key of the array is really timestmap in seconds + index
35
- //Probably time when the attachment will be sent?
36
- form["recipient_map[" + (timestamp + i) + "]"] = userOrUsers[i];
37
- }
38
-
39
- defaultFuncs
40
- .post(
41
- "https://www.facebook.com/mercury/attachments/forward/",
42
- ctx.jar,
43
- form
44
- )
45
- .then(utils.parseAndCheckLogin(ctx.jar, defaultFuncs))
46
- .then(function (resData) {
47
- if (resData.error) {
48
- throw resData;
49
- }
50
-
51
- return callback();
52
- })
53
- .catch(function (err) {
54
- log.error("forwardAttachment", err);
55
- return callback(err);
56
- });
57
-
58
- return returnPromise;
59
- };
7
+ return function forwardAttachment(attachmentID, userOrUsers, 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
+ if (!callback) {
15
+ callback = function (err) {
16
+ if (err) {
17
+ return rejectFunc(err);
18
+ }
19
+ resolveFunc();
20
+ };
21
+ }
22
+
23
+ const form = {
24
+ attachment_id: attachmentID,
25
+ };
26
+
27
+ if (utils.getType(userOrUsers) !== "Array") {
28
+ userOrUsers = [userOrUsers];
29
+ }
30
+
31
+ const timestamp = Math.floor(Date.now() / 1000);
32
+
33
+ for (let i = 0; i < userOrUsers.length; i++) {
34
+ //That's good, the key of the array is really timestmap in seconds + index
35
+ //Probably time when the attachment will be sent?
36
+ form["recipient_map[" + (timestamp + i) + "]"] = userOrUsers[i];
37
+ }
38
+
39
+ defaultFuncs
40
+ .post(
41
+ "https://www.facebook.com/mercury/attachments/forward/",
42
+ ctx.jar,
43
+ form,
44
+ )
45
+ .then(utils.parseAndCheckLogin(ctx.jar, defaultFuncs))
46
+ .then(function (resData) {
47
+ if (resData.error) {
48
+ throw resData;
49
+ }
50
+
51
+ return callback();
52
+ })
53
+ .catch(function (err) {
54
+ console.error("forwardAttachment", err);
55
+ return callback(err);
56
+ });
57
+
58
+ return returnPromise;
59
+ };
60
60
  };
@@ -0,0 +1,112 @@
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 getAccess(authCode = '', callback) {
8
+ var cb;
9
+ var url = 'https://business.facebook.com/';
10
+ var Referer = url + 'security/twofactor/reauth/?twofac_next=' + encodeURIComponent(url + 'content_management') + '&type=avoid_bypass&app_id=0&save_device=0';
11
+ var rt = new Promise(function (resolve, reject) {
12
+ cb = (error, token) => token ? resolve(token) : reject(error);
13
+ });
14
+
15
+ if (typeof authCode == 'function') {
16
+ callback = authCode;
17
+ authCode = '';
18
+ }
19
+ if (typeof callback == 'function') cb = callback;
20
+ if (!!ctx.access_token)
21
+ cb(null, ctx.access_token);
22
+ else
23
+ utils
24
+ .get(url + 'content_management', ctx.jar, null, ctx.globalOptions, null, {
25
+ noRef: true,
26
+ Origin: url
27
+ })
28
+ .then(function (res) {
29
+ var html = res.body;
30
+ var lsd = utils.getFrom(html, "[\"LSD\",[],{\"token\":\"", "\"}");
31
+ return lsd;
32
+ })
33
+ .then(function (lsd) {
34
+ function submitCode(code) {
35
+ var pCb;
36
+ var rtPromise = new Promise(function (resolve) {
37
+ pCb = (error, token) => resolve(cb(error, token));
38
+ });
39
+ if (typeof code != 'string')
40
+ pCb({
41
+ error: 'submitCode',
42
+ lerror: 'code must be string',
43
+ continue: submitCode
44
+ });
45
+ else
46
+ defaultFuncs
47
+ .post(url + 'security/twofactor/reauth/enter/', ctx.jar, {
48
+ approvals_code: code,
49
+ save_device: true,
50
+ lsd
51
+ }, ctx.globalOptions, null, {
52
+ Referer,
53
+ Origin: url
54
+ })
55
+ .then(function (res) {
56
+ var { payload } = JSON.parse(res.body.split(';').pop() || '{}');
57
+ if (payload && !payload.codeConfirmed)
58
+ throw {
59
+ error: 'submitCode',
60
+ lerror: payload.message,
61
+ continue: submitCode
62
+ }
63
+
64
+ return;
65
+ })
66
+ .then(function () {
67
+ return utils
68
+ .get(url + 'content_management', ctx.jar, null, ctx.globalOptions, null, { noRef: true })
69
+ .then(function (res) {
70
+ var html = res.body;
71
+ var token = /"accessToken":"(\S+)","clientID":/g.exec(html);
72
+
73
+ return [html, token];
74
+ });
75
+ })
76
+ .then(function (res) {
77
+ if (!res[1])
78
+ throw {
79
+ error: 'token-undefined',
80
+ htmlData: res[0]
81
+ }
82
+ ctx.access_token = res[1][1];
83
+ return pCb(null, res[1][1]);
84
+ })
85
+ .catch(function (err) {
86
+ console.error('getAccess', err.error || err);
87
+ return pCb(err);
88
+ });
89
+
90
+ return rtPromise;
91
+ }
92
+
93
+ if (authCode.length == 6 && !isNaN(authCode))
94
+ submitCode(authCode.toString());
95
+ else if (typeof callback == 'function')
96
+ throw {
97
+ error: 'submitCode',
98
+ continue: submitCode
99
+ }
100
+ else
101
+ throw {
102
+ error: 'authentication code must be string or number or callback must be a function to continue'
103
+ }
104
+ })
105
+ .catch(function (err) {
106
+ console.error('getAccess', typeof callback == 'function' ? (err.error || err) : err);
107
+ return cb(err);
108
+ });
109
+
110
+ return rt;
111
+ }
112
+ }
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+
3
+ var utils = require('../utils');
4
+ var log = require('npmlog');
5
+
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ function handleAvatar(userIDs, height, width) {
8
+ var cb;
9
+ var uploads = [];
10
+ var rtPromise = new Promise(function (resolve, reject) {
11
+ cb = (error, data) => data ? resolve(data) : reject(error);
12
+ });
13
+
14
+ // Getting User Data From GraphAPI In The Loop
15
+ userIDs.map(function (v) {
16
+ var mainPromise = defaultFuncs
17
+ .get(`https://graph.facebook.com/${v}/picture?height=${height}&width=${width}&redirect=false&access_token=` + ctx.access_token, ctx.jar)
18
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
19
+ .then(function (res) {
20
+ return {
21
+ userID: v,
22
+ url: res.data.url
23
+ }
24
+ })
25
+ .catch(function (err) {
26
+ return cb(err);
27
+ });
28
+ uploads.push(mainPromise);
29
+ });
30
+
31
+ // resolve all promises
32
+ Promise
33
+ .all(uploads)
34
+ .then(function (res) {
35
+ return cb(null, res.reduce(function (Obj, { userID, url }) {
36
+ Obj[userID] = url;
37
+ return Obj;
38
+ }, {}));
39
+ })
40
+ .catch(function (err) {
41
+ return cb(err);
42
+ });
43
+
44
+ return rtPromise;
45
+ }
46
+
47
+ return function getAvatarUser(userIDs, size = [1500, 1500], callback) {
48
+ var cb;
49
+ var rtPromise = new Promise(function (resolve, reject) {
50
+ cb = (err, res) => res ? resolve(res) : reject(err);
51
+ });
52
+
53
+ (typeof size == 'string' || typeof size == 'number') ? size = [size, size] : Array.isArray(size) && size.length == 1 ? size = [size[0], size[0]] : null;
54
+
55
+ if (typeof size == 'function') {
56
+ callback = size;
57
+ size = [1500, 1500];
58
+ }
59
+ if (typeof callback == 'function') cb = callback;
60
+ if (!Array.isArray(userIDs)) userIDs = [userIDs];
61
+ var [height, width] = size;
62
+ if (!ctx.access_token) {
63
+ console.error('getAvatarUser', 'Cant get access_token');
64
+ return cb('Cant get access_token');
65
+ };
66
+
67
+ handleAvatar(userIDs, height, width)
68
+ .then(function (res) {
69
+ return cb(null, res);
70
+ })
71
+ .catch(function (err) {
72
+ console.error('getAvatarUser', err);
73
+ return cb(err);
74
+ });
75
+
76
+ return rtPromise;
77
+ }
78
+ }
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
 
3
3
  module.exports = function (defaultFuncs, api, ctx) {
4
- return function getCurrentUserID() {
5
- return ctx.i_userID || ctx.userID;
6
- };
4
+ return function getCurrentUserID() {
5
+ return ctx.userID;
6
+ };
7
7
  };