rapido-fca 0.0.10 → 1.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.
Potentially problematic release.
This version of rapido-fca might be problematic. Click here for more details.
- package/LICENSE +21 -0
- package/index.js +4 -4
- package/package.json +15 -16
- package/readme.md +237 -39
- package/src/Screenshot.js +83 -0
- package/src/addExternalModule.js +19 -23
- package/src/addUserToGroup.js +99 -97
- package/src/changeAdminStatus.js +86 -62
- package/src/changeArchivedStatus.js +49 -49
- package/src/changeAvatar.js +118 -108
- package/src/changeBio.js +63 -64
- package/src/changeBlockedStatus.js +40 -38
- package/src/changeGroupImage.js +129 -126
- package/src/changeNickname.js +49 -49
- package/src/changeThreadColor.js +53 -53
- package/src/changeThreadEmoji.js +45 -45
- package/src/createNewGroup.js +74 -72
- package/src/createPoll.js +59 -59
- package/src/deleteMessage.js +50 -50
- package/src/deleteThread.js +50 -50
- package/src/editMessage.js +51 -49
- package/src/forwardAttachment.js +54 -54
- package/src/getCurrentUserID.js +3 -3
- package/src/getEmojiUrl.js +17 -17
- package/src/getFriendsList.js +67 -67
- package/src/getMessage.js +806 -767
- package/src/getThreadHistory.js +656 -642
- package/src/getThreadInfo.js +1 -1
- package/src/getThreadList.js +199 -227
- package/src/getThreadPictures.js +51 -71
- package/src/getUserID.js +53 -58
- package/src/getUserInfo.js +52 -60
- package/src/handleFriendRequest.js +41 -65
- package/src/handleMessageRequest.js +42 -60
- package/src/httpGet.js +49 -57
- package/src/httpPost.js +48 -57
- package/src/listenMqtt.js +827 -827
- package/src/listenMqtt.txt +827 -0
- package/src/logout.js +61 -61
- package/src/markAsDelivered.js +42 -53
- package/src/markAsRead.js +59 -69
- package/src/markAsReadAll.js +32 -42
- package/src/markAsSeen.js +43 -54
- package/src/muteThread.js +40 -47
- package/src/postFormData.txt +46 -0
- package/src/refreshFb_dtsg.js +77 -69
- package/src/removeUserFromGroup.js +67 -67
- package/src/resolvePhotoUrl.js +34 -34
- package/src/searchForThread.js +43 -43
- package/src/sendMessage.js +80 -228
- package/src/sendTypingIndicator.js +86 -88
- package/src/setPostReaction.js +90 -87
- package/src/setTitle.js +76 -72
- package/src/threadColors.js +121 -121
- package/src/unfriend.js +43 -43
- package/src/unsendMessage.js +34 -38
- package/src/uploadAttachment.js +80 -81
- package/src/httpPostFormData.js +0 -63
- package/src/setEmojiReaction.js +0 -59
- package/src/videoAttachment.js +0 -76
package/src/threadColors.js
CHANGED
|
@@ -1,131 +1,131 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
module.exports = function (_defaultFuncs, _api, _ctx) {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
4
|
+
// Currently the only colors that can be passed to api.changeThreadColor(); may change if Facebook adds more
|
|
5
|
+
return {
|
|
6
|
+
//Old hex colors.
|
|
7
|
+
////MessengerBlue: null,
|
|
8
|
+
////Viking: "#44bec7",
|
|
9
|
+
////GoldenPoppy: "#ffc300",
|
|
10
|
+
////RadicalRed: "#fa3c4c",
|
|
11
|
+
////Shocking: "#d696bb",
|
|
12
|
+
////PictonBlue: "#6699cc",
|
|
13
|
+
////FreeSpeechGreen: "#13cf13",
|
|
14
|
+
////Pumpkin: "#ff7e29",
|
|
15
|
+
////LightCoral: "#e68585",
|
|
16
|
+
////MediumSlateBlue: "#7646ff",
|
|
17
|
+
////DeepSkyBlue: "#20cef5",
|
|
18
|
+
////Fern: "#67b868",
|
|
19
|
+
////Cameo: "#d4a88c",
|
|
20
|
+
////BrilliantRose: "#ff5ca1",
|
|
21
|
+
////BilobaFlower: "#a695c7"
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
23
|
+
//#region This part is for backward compatibly
|
|
24
|
+
//trying to match the color one-by-one. kill me plz
|
|
25
|
+
MessengerBlue: "196241301102133", //DefaultBlue
|
|
26
|
+
Viking: "1928399724138152", //TealBlue
|
|
27
|
+
GoldenPoppy: "174636906462322", //Yellow
|
|
28
|
+
RadicalRed: "2129984390566328", //Red
|
|
29
|
+
Shocking: "2058653964378557", //LavenderPurple
|
|
30
|
+
FreeSpeechGreen: "2136751179887052", //Green
|
|
31
|
+
Pumpkin: "175615189761153", //Orange
|
|
32
|
+
LightCoral: "980963458735625", //CoralPink
|
|
33
|
+
MediumSlateBlue: "234137870477637", //BrightPurple
|
|
34
|
+
DeepSkyBlue: "2442142322678320", //AquaBlue
|
|
35
|
+
BrilliantRose: "169463077092846", //HotPink
|
|
36
|
+
//i've tried my best, everything else can't be mapped. (or is it?) -UIRI 2020
|
|
37
|
+
//#endregion
|
|
38
38
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
39
|
+
DefaultBlue: "196241301102133",
|
|
40
|
+
HotPink: "169463077092846",
|
|
41
|
+
AquaBlue: "2442142322678320",
|
|
42
|
+
BrightPurple: "234137870477637",
|
|
43
|
+
CoralPink: "980963458735625",
|
|
44
|
+
Orange: "175615189761153",
|
|
45
|
+
Green: "2136751179887052",
|
|
46
|
+
LavenderPurple: "2058653964378557",
|
|
47
|
+
Red: "2129984390566328",
|
|
48
|
+
Yellow: "174636906462322",
|
|
49
|
+
TealBlue: "1928399724138152",
|
|
50
|
+
Aqua: "417639218648241",
|
|
51
|
+
Mango: "930060997172551",
|
|
52
|
+
Berry: "164535220883264",
|
|
53
|
+
Citrus: "370940413392601",
|
|
54
|
+
Candy: "205488546921017",
|
|
55
55
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
56
|
+
/**
|
|
57
|
+
* July 06, 2022
|
|
58
|
+
* added by @NTKhang
|
|
59
|
+
*/
|
|
60
|
+
Earth: "1833559466821043",
|
|
61
|
+
Support: "365557122117011",
|
|
62
|
+
Music: "339021464972092",
|
|
63
|
+
Pride: "1652456634878319",
|
|
64
|
+
DoctorStrange: "538280997628317",
|
|
65
|
+
LoFi: "1060619084701625",
|
|
66
|
+
Sky: "3190514984517598",
|
|
67
|
+
LunarNewYear: "357833546030778",
|
|
68
|
+
Celebration: "627144732056021",
|
|
69
|
+
Chill: "390127158985345",
|
|
70
|
+
StrangerThings: "1059859811490132",
|
|
71
|
+
Dune: "1455149831518874",
|
|
72
|
+
Care: "275041734441112",
|
|
73
|
+
Astrology: "3082966625307060",
|
|
74
|
+
JBalvin: "184305226956268",
|
|
75
|
+
Birthday: "621630955405500",
|
|
76
|
+
Cottagecore: "539927563794799",
|
|
77
|
+
Ocean: "736591620215564",
|
|
78
|
+
Love: "741311439775765",
|
|
79
|
+
TieDye: "230032715012014",
|
|
80
|
+
Monochrome: "788274591712841",
|
|
81
|
+
Default: "3259963564026002",
|
|
82
|
+
Rocket: "582065306070020",
|
|
83
|
+
Berry2: "724096885023603",
|
|
84
|
+
Candy2: "624266884847972",
|
|
85
|
+
Unicorn: "273728810607574",
|
|
86
|
+
Tropical: "262191918210707",
|
|
87
|
+
Maple: "2533652183614000",
|
|
88
|
+
Sushi: "909695489504566",
|
|
89
|
+
Citrus2: "557344741607350",
|
|
90
|
+
Lollipop: "280333826736184",
|
|
91
|
+
Shadow: "271607034185782",
|
|
92
|
+
Rose: "1257453361255152",
|
|
93
|
+
Lavender: "571193503540759",
|
|
94
|
+
Tulip: "2873642949430623",
|
|
95
|
+
Classic: "3273938616164733",
|
|
96
|
+
Peach: "3022526817824329",
|
|
97
|
+
Honey: "672058580051520",
|
|
98
|
+
Kiwi: "3151463484918004",
|
|
99
|
+
Grape: "193497045377796",
|
|
100
100
|
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
101
|
+
/**
|
|
102
|
+
* July 15, 2022
|
|
103
|
+
* added by @NTKhang
|
|
104
|
+
*/
|
|
105
|
+
NonBinary: "737761000603635",
|
|
106
106
|
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
107
|
+
/**
|
|
108
|
+
* November 25, 2022
|
|
109
|
+
* added by @NTKhang
|
|
110
|
+
*/
|
|
111
|
+
ThankfulForFriends: "1318983195536293",
|
|
112
|
+
Transgender: "504518465021637",
|
|
113
|
+
TaylorSwift: "769129927636836",
|
|
114
|
+
NationalComingOutDay: "788102625833584",
|
|
115
|
+
Autumn: "822549609168155",
|
|
116
|
+
Cyberpunk2077: "780962576430091",
|
|
117
117
|
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
118
|
+
/**
|
|
119
|
+
* May 13, 2023
|
|
120
|
+
*/
|
|
121
|
+
MothersDay: "1288506208402340",
|
|
122
|
+
APAHM: "121771470870245",
|
|
123
|
+
Parenthood: "810978360551741",
|
|
124
|
+
StarWars: "1438011086532622",
|
|
125
|
+
GuardianOfTheGalaxy: "101275642962533",
|
|
126
|
+
Bloom: "158263147151440",
|
|
127
|
+
BubbleTea: "195296273246380",
|
|
128
|
+
Basketball: "6026716157422736",
|
|
129
|
+
ElephantsAndFlowers: "693996545771691",
|
|
130
|
+
};
|
|
131
131
|
};
|
package/src/unfriend.js
CHANGED
|
@@ -1,52 +1,52 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
3
|
+
var utils = require("../utils");
|
|
4
|
+
// @NethWs3Dev
|
|
5
5
|
|
|
6
|
-
module.exports = function
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
6
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
|
7
|
+
return function unFriend(userID, 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
14
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
15
|
+
if (!callback) {
|
|
16
|
+
callback = function (err, friendList) {
|
|
17
|
+
if (err) {
|
|
18
|
+
return rejectFunc(err);
|
|
19
|
+
}
|
|
20
|
+
resolveFunc(friendList);
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
23
|
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
24
|
+
var form = {
|
|
25
|
+
uid: userID,
|
|
26
|
+
unref: "bd_friends_tab",
|
|
27
|
+
floc: "friends_tab",
|
|
28
|
+
"nctr[_mod]": "pagelet_timeline_app_collection_" + ctx.userID + ":2356318349:2"
|
|
29
|
+
};
|
|
30
30
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
31
|
+
defaultFuncs
|
|
32
|
+
.post(
|
|
33
|
+
"https://www.facebook.com/ajax/profile/removefriendconfirm.php",
|
|
34
|
+
ctx.jar,
|
|
35
|
+
form
|
|
36
|
+
)
|
|
37
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
|
38
|
+
.then(function(resData) {
|
|
39
|
+
if (resData.error) {
|
|
40
|
+
throw resData;
|
|
41
|
+
}
|
|
42
42
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
43
|
+
return callback();
|
|
44
|
+
})
|
|
45
|
+
.catch(function(err) {
|
|
46
|
+
console.error("unfriend", err);
|
|
47
|
+
return callback(err);
|
|
48
|
+
});
|
|
49
49
|
|
|
50
|
-
|
|
51
|
-
|
|
50
|
+
return returnPromise;
|
|
51
|
+
};
|
|
52
52
|
};
|
package/src/unsendMessage.js
CHANGED
|
@@ -1,49 +1,45 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
const utils = require("../utils");
|
|
4
|
-
|
|
4
|
+
// @NethWs3Dev
|
|
5
5
|
|
|
6
6
|
module.exports = function (defaultFuncs, api, ctx) {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
7
|
+
return function unsendMessage(messageID, 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
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
15
|
+
if (!callback) {
|
|
16
|
+
callback = function (err, friendList) {
|
|
17
|
+
if (err) {
|
|
18
|
+
return rejectFunc(err);
|
|
19
|
+
}
|
|
20
|
+
resolveFunc(friendList);
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
23
|
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
24
|
+
const form = {
|
|
25
|
+
message_id: messageID,
|
|
26
|
+
};
|
|
27
27
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
.then(function (resData) {
|
|
36
|
-
if (resData.error) {
|
|
37
|
-
throw resData;
|
|
38
|
-
}
|
|
28
|
+
defaultFuncs
|
|
29
|
+
.post("https://www.facebook.com/messaging/unsend_message/", ctx.jar, form)
|
|
30
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
|
31
|
+
.then(function (resData) {
|
|
32
|
+
if (resData.error) {
|
|
33
|
+
throw resData;
|
|
34
|
+
}
|
|
39
35
|
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
36
|
+
return callback();
|
|
37
|
+
})
|
|
38
|
+
.catch(function (err) {
|
|
39
|
+
console.error("unsendMessage", err);
|
|
40
|
+
return callback(err);
|
|
41
|
+
});
|
|
46
42
|
|
|
47
|
-
|
|
48
|
-
|
|
43
|
+
return returnPromise;
|
|
44
|
+
};
|
|
49
45
|
};
|
package/src/uploadAttachment.js
CHANGED
|
@@ -1,95 +1,94 @@
|
|
|
1
1
|
const utils = require("../utils");
|
|
2
|
-
|
|
2
|
+
// @NethWs3Dev
|
|
3
3
|
|
|
4
4
|
module.exports = function (defaultFuncs, api, ctx) {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
function upload(attachments, callback) {
|
|
6
|
+
callback = callback || function () {};
|
|
7
|
+
const uploads = [];
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
9
|
+
// create an array of promises
|
|
10
|
+
for (let i = 0; i < attachments.length; i++) {
|
|
11
|
+
if (!utils.isReadableStream(attachments[i])) {
|
|
12
|
+
throw {
|
|
13
|
+
error:
|
|
14
|
+
"Attachment should be a readable stream and not " +
|
|
15
|
+
utils.getType(attachments[i]) +
|
|
16
|
+
".",
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
19
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
20
|
+
const form = {
|
|
21
|
+
upload_1024: attachments[i],
|
|
22
|
+
voice_clip: "true",
|
|
23
|
+
};
|
|
24
24
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
25
|
+
uploads.push(
|
|
26
|
+
defaultFuncs
|
|
27
|
+
.postFormData(
|
|
28
|
+
"https://upload.facebook.com/ajax/mercury/upload.php",
|
|
29
|
+
ctx.jar,
|
|
30
|
+
form,
|
|
31
|
+
{},
|
|
32
|
+
)
|
|
33
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
|
34
|
+
.then(function (resData) {
|
|
35
|
+
if (resData.error) {
|
|
36
|
+
throw resData;
|
|
37
|
+
}
|
|
38
38
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
39
|
+
// We have to return the data unformatted unless we want to change it
|
|
40
|
+
// back in sendMessage.
|
|
41
|
+
return resData.payload.metadata[0];
|
|
42
|
+
}),
|
|
43
|
+
);
|
|
44
|
+
}
|
|
45
45
|
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
}
|
|
46
|
+
// resolve all promises
|
|
47
|
+
Promise.all(uploads)
|
|
48
|
+
.then(function (resData) {
|
|
49
|
+
callback(null, resData);
|
|
50
|
+
})
|
|
51
|
+
.catch(function (err) {
|
|
52
|
+
console.error("uploadAttachment", err);
|
|
53
|
+
return callback(err);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
57
56
|
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
57
|
+
return function uploadAttachment(attachments, callback) {
|
|
58
|
+
if (
|
|
59
|
+
!attachments &&
|
|
60
|
+
!utils.isReadableStream(attachments) &&
|
|
61
|
+
!utils.getType(attachments) === "Array" &&
|
|
62
|
+
utils.getType(attachments) === "Array" &&
|
|
63
|
+
!attachments.length
|
|
64
|
+
)
|
|
65
|
+
throw { error: "Please pass an attachment or an array of attachments." };
|
|
66
66
|
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
67
|
+
let resolveFunc = function () {};
|
|
68
|
+
let rejectFunc = function () {};
|
|
69
|
+
const returnPromise = new Promise(function (resolve, reject) {
|
|
70
|
+
resolveFunc = resolve;
|
|
71
|
+
rejectFunc = reject;
|
|
72
|
+
});
|
|
73
73
|
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
74
|
+
if (!callback) {
|
|
75
|
+
callback = function (err, info) {
|
|
76
|
+
if (err) {
|
|
77
|
+
return rejectFunc(err);
|
|
78
|
+
}
|
|
79
|
+
resolveFunc(info);
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
82
|
|
|
83
|
-
|
|
84
|
-
attachments = [attachments];
|
|
83
|
+
if (utils.getType(attachments) !== "Array") attachments = [attachments];
|
|
85
84
|
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
85
|
+
upload(attachments, (err, info) => {
|
|
86
|
+
if (err) {
|
|
87
|
+
return callback(err);
|
|
88
|
+
}
|
|
89
|
+
callback(null, info);
|
|
90
|
+
});
|
|
92
91
|
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
};
|
|
92
|
+
return returnPromise;
|
|
93
|
+
};
|
|
94
|
+
};
|