@dongdev/fca-unofficial 1.0.19 → 2.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.
- package/.gitattributes +1 -0
- package/CHANGELOG.md +30 -27
- package/DOCS.md +727 -592
- package/README.md +94 -97
- package/func/logger.js +112 -0
- package/html.html +474 -0
- package/index.js +1 -379
- package/module/config.js +26 -0
- package/module/login.js +45 -0
- package/module/loginHelper.js +634 -0
- package/module/options.js +49 -0
- package/package.json +6 -39
- package/src/api/action/addExternalModule.js +25 -0
- package/src/api/action/changeAvatar.js +136 -0
- package/src/api/action/changeBio.js +76 -0
- package/src/api/action/getCurrentUserID.js +7 -0
- package/src/api/action/handleFriendRequest.js +57 -0
- package/src/api/action/logout.js +75 -0
- package/src/{refreshFb_dtsg.js → api/action/refreshFb_dtsg.js} +8 -8
- package/src/api/action/setPostReaction.js +107 -0
- package/src/api/action/unfriend.js +55 -0
- package/src/api/http/httpGet.js +65 -0
- package/src/api/http/httpPost.js +65 -0
- package/src/{postFormData.js → api/http/postFormData.js} +10 -10
- package/src/api/messaging/addUserToGroup.js +69 -0
- package/src/api/messaging/changeAdminStatus.js +103 -0
- package/src/api/messaging/changeArchivedStatus.js +55 -0
- package/src/api/messaging/changeBlockedStatus.js +49 -0
- package/src/api/messaging/changeGroupImage.js +135 -0
- package/src/api/messaging/changeNickname.js +59 -0
- package/src/api/messaging/changeThreadColor.js +65 -0
- package/src/api/messaging/createNewGroup.js +88 -0
- package/src/api/messaging/createPoll.js +70 -0
- package/src/api/messaging/deleteMessage.js +56 -0
- package/src/api/messaging/deleteThread.js +56 -0
- package/src/api/messaging/forwardAttachment.js +60 -0
- package/src/api/messaging/getEmojiUrl.js +29 -0
- package/src/api/messaging/getFriendsList.js +83 -0
- package/src/api/messaging/getMessage.js +834 -0
- package/src/api/messaging/getThreadHistory.js +681 -0
- package/src/api/messaging/handleMessageRequest.js +65 -0
- package/src/api/messaging/markAsDelivered.js +57 -0
- package/src/api/messaging/markAsRead.js +88 -0
- package/src/api/messaging/markAsReadAll.js +50 -0
- package/src/api/messaging/markAsSeen.js +61 -0
- package/src/api/messaging/muteThread.js +51 -0
- package/src/api/messaging/removeUserFromGroup.js +79 -0
- package/src/api/messaging/resolvePhotoUrl.js +44 -0
- package/src/api/messaging/searchForThread.js +53 -0
- package/src/api/messaging/sendMessage.js +306 -0
- package/src/api/messaging/sendMessageMqtt.js +321 -0
- package/src/api/messaging/sendTypingIndicator.js +110 -0
- package/src/{setMessageReaction.js → api/messaging/setMessageReaction.js} +20 -20
- package/src/api/messaging/setTitle.js +90 -0
- package/src/api/messaging/shareContact.js +51 -0
- package/src/api/messaging/threadColors.js +131 -0
- package/src/api/messaging/unsendMessage.js +44 -0
- package/src/api/messaging/uploadAttachment.js +93 -0
- package/src/api/socket/detail/buildStream.js +100 -0
- package/src/{listenMqtt.js → api/socket/listenMqtt.js} +172 -256
- package/src/api/threads/changeThreadEmoji.js +55 -0
- package/src/api/threads/getThreadInfo.js +572 -0
- package/src/{getThreadList.js → api/threads/getThreadList.js} +110 -54
- package/src/api/threads/getThreadPictures.js +79 -0
- package/src/api/users/getUserID.js +66 -0
- package/src/api/users/getUserInfo.js +88 -0
- package/src/core/sendReqMqtt.js +63 -0
- package/{lib → src}/database/models/index.js +12 -10
- package/{lib → src}/database/models/thread.js +5 -5
- package/{lib → src}/database/threadData.js +19 -14
- package/src/utils/client.js +159 -0
- package/src/utils/constants.js +13 -0
- package/src/utils/format.js +60 -0
- package/src/utils/headers.js +41 -0
- package/src/utils/index.js +1497 -0
- package/src/utils/request.js +147 -0
- package/lib/logger.js +0 -96
- package/src/addExternalModule.js +0 -19
- package/src/addUserToGroup.js +0 -113
- package/src/changeAdminStatus.js +0 -79
- package/src/changeArchivedStatus.js +0 -55
- package/src/changeAvatar.js +0 -126
- package/src/changeBio.js +0 -77
- package/src/changeBlockedStatus.js +0 -47
- package/src/changeGroupImage.js +0 -132
- package/src/changeNickname.js +0 -59
- package/src/changeThreadColor.js +0 -65
- package/src/changeThreadEmoji.js +0 -55
- package/src/createNewGroup.js +0 -86
- package/src/createPoll.js +0 -71
- package/src/deleteMessage.js +0 -56
- package/src/deleteThread.js +0 -56
- package/src/forwardAttachment.js +0 -60
- package/src/getCurrentUserID.js +0 -7
- package/src/getEmojiUrl.js +0 -29
- package/src/getFriendsList.js +0 -83
- package/src/getMessage.js +0 -796
- package/src/getThreadHistory.js +0 -666
- package/src/getThreadInfo.js +0 -535
- package/src/getThreadPictures.js +0 -79
- package/src/getUserID.js +0 -66
- package/src/getUserInfo.js +0 -80
- package/src/handleFriendRequest.js +0 -61
- package/src/handleMessageRequest.js +0 -65
- package/src/httpGet.js +0 -57
- package/src/httpPost.js +0 -57
- package/src/httpPostFormData.js +0 -63
- package/src/logout.js +0 -75
- package/src/markAsDelivered.js +0 -58
- package/src/markAsRead.js +0 -80
- package/src/markAsReadAll.js +0 -50
- package/src/markAsSeen.js +0 -59
- package/src/muteThread.js +0 -52
- package/src/removeUserFromGroup.js +0 -79
- package/src/resolvePhotoUrl.js +0 -45
- package/src/searchForThread.js +0 -53
- package/src/sendMessage.js +0 -328
- package/src/sendMessageMqtt.js +0 -316
- package/src/sendTypingIndicator.js +0 -103
- package/src/setPostReaction.js +0 -109
- package/src/setTitle.js +0 -86
- package/src/shareContact.js +0 -49
- package/src/threadColors.js +0 -131
- package/src/unfriend.js +0 -52
- package/src/unsendMessage.js +0 -49
- package/src/uploadAttachment.js +0 -95
- package/utils.js +0 -1387
- /package/{lib → func}/login.js +0 -0
@@ -0,0 +1,110 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
const utils = require("../../utils");
|
4
|
+
const log = require("npmlog");
|
5
|
+
|
6
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
7
|
+
function makeTypingIndicator(typ, threadID, callback, isGroup) {
|
8
|
+
const form = {
|
9
|
+
typ: +typ,
|
10
|
+
to: "",
|
11
|
+
source: "mercury-chat",
|
12
|
+
thread: threadID
|
13
|
+
};
|
14
|
+
|
15
|
+
// Check if thread is a single person chat or a group chat
|
16
|
+
// More info on this is in api.sendMessage
|
17
|
+
if (utils.getType(isGroup) == "Boolean") {
|
18
|
+
if (!isGroup) {
|
19
|
+
form.to = threadID;
|
20
|
+
}
|
21
|
+
defaultFuncs
|
22
|
+
.post("https://www.facebook.com/ajax/messaging/typ.php", ctx.jar, form)
|
23
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
24
|
+
.then(function(resData) {
|
25
|
+
if (resData.error) {
|
26
|
+
throw resData;
|
27
|
+
}
|
28
|
+
|
29
|
+
return callback();
|
30
|
+
})
|
31
|
+
.catch(function(err) {
|
32
|
+
log.error("sendTypingIndicator", err);
|
33
|
+
if (utils.getType(err) == "Object" && err.error === "Not logged in") {
|
34
|
+
ctx.loggedIn = false;
|
35
|
+
}
|
36
|
+
return callback(err);
|
37
|
+
});
|
38
|
+
} else {
|
39
|
+
api.getUserInfo(threadID, function(err, res) {
|
40
|
+
if (err) {
|
41
|
+
return callback(err);
|
42
|
+
}
|
43
|
+
|
44
|
+
// If id is single person chat
|
45
|
+
if (Object.keys(res).length > 0) {
|
46
|
+
form.to = threadID;
|
47
|
+
}
|
48
|
+
|
49
|
+
defaultFuncs
|
50
|
+
.post(
|
51
|
+
"https://www.facebook.com/ajax/messaging/typ.php",
|
52
|
+
ctx.jar,
|
53
|
+
form
|
54
|
+
)
|
55
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
56
|
+
.then(function(resData) {
|
57
|
+
if (resData.error) {
|
58
|
+
throw resData;
|
59
|
+
}
|
60
|
+
|
61
|
+
return callback();
|
62
|
+
})
|
63
|
+
.catch(function(err) {
|
64
|
+
log.error("sendTypingIndicator", err);
|
65
|
+
if (
|
66
|
+
utils.getType(err) == "Object" &&
|
67
|
+
err.error === "Not logged in."
|
68
|
+
) {
|
69
|
+
ctx.loggedIn = false;
|
70
|
+
}
|
71
|
+
return callback(err);
|
72
|
+
});
|
73
|
+
});
|
74
|
+
}
|
75
|
+
}
|
76
|
+
|
77
|
+
return function sendTypingIndicator(threadID, callback, isGroup) {
|
78
|
+
if (
|
79
|
+
utils.getType(callback) !== "Function" &&
|
80
|
+
utils.getType(callback) !== "AsyncFunction"
|
81
|
+
) {
|
82
|
+
if (callback) {
|
83
|
+
log.warn(
|
84
|
+
"sendTypingIndicator",
|
85
|
+
"callback is not a function - ignoring."
|
86
|
+
);
|
87
|
+
}
|
88
|
+
callback = () => {};
|
89
|
+
}
|
90
|
+
|
91
|
+
makeTypingIndicator(true, threadID, callback, isGroup);
|
92
|
+
|
93
|
+
return function end(cb) {
|
94
|
+
if (
|
95
|
+
utils.getType(cb) !== "Function" &&
|
96
|
+
utils.getType(cb) !== "AsyncFunction"
|
97
|
+
) {
|
98
|
+
if (cb) {
|
99
|
+
log.warn(
|
100
|
+
"sendTypingIndicator",
|
101
|
+
"callback is not a function - ignoring."
|
102
|
+
);
|
103
|
+
}
|
104
|
+
cb = () => {};
|
105
|
+
}
|
106
|
+
|
107
|
+
makeTypingIndicator(false, threadID, cb, isGroup);
|
108
|
+
};
|
109
|
+
};
|
110
|
+
};
|
@@ -1,19 +1,19 @@
|
|
1
1
|
"use strict";
|
2
2
|
|
3
|
-
|
3
|
+
const utils = require("../../utils");
|
4
4
|
var log = require("npmlog");
|
5
|
-
const { generateOfflineThreadingID } = require("
|
5
|
+
const { generateOfflineThreadingID } = require("../../utils");
|
6
6
|
|
7
|
-
module.exports = function
|
7
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
8
8
|
function setMessageReactionNoMqtt(reaction, messageID, callback) {
|
9
|
-
var resolveFunc = function
|
10
|
-
var rejectFunc = function
|
11
|
-
var returnPromise = new Promise(function
|
9
|
+
var resolveFunc = function() {};
|
10
|
+
var rejectFunc = function() {};
|
11
|
+
var returnPromise = new Promise(function(resolve, reject) {
|
12
12
|
resolveFunc = resolve;
|
13
13
|
rejectFunc = reject;
|
14
14
|
});
|
15
15
|
if (!callback) {
|
16
|
-
callback = function
|
16
|
+
callback = function(err, friendList) {
|
17
17
|
if (err) {
|
18
18
|
return rejectFunc(err);
|
19
19
|
}
|
@@ -26,23 +26,23 @@ module.exports = function (defaultFuncs, api, ctx) {
|
|
26
26
|
actor_id: ctx.userID,
|
27
27
|
action: reaction == "" ? "REMOVE_REACTION" : "ADD_REACTION",
|
28
28
|
message_id: messageID,
|
29
|
-
reaction: reaction
|
30
|
-
}
|
29
|
+
reaction: reaction
|
30
|
+
}
|
31
31
|
};
|
32
32
|
var qs = {
|
33
33
|
doc_id: "1491398900900362",
|
34
34
|
variables: JSON.stringify(variables),
|
35
|
-
dpr: 1
|
35
|
+
dpr: 1
|
36
36
|
};
|
37
37
|
defaultFuncs
|
38
38
|
.postFormData(
|
39
39
|
"https://www.facebook.com/webgraphql/mutation/",
|
40
40
|
ctx.jar,
|
41
41
|
{},
|
42
|
-
qs
|
42
|
+
qs
|
43
43
|
)
|
44
44
|
.then(utils.parseAndCheckLogin(ctx.jar, defaultFuncs))
|
45
|
-
.then(function
|
45
|
+
.then(function(resData) {
|
46
46
|
if (!resData) {
|
47
47
|
throw { error: "setReaction returned empty object." };
|
48
48
|
}
|
@@ -51,7 +51,7 @@ module.exports = function (defaultFuncs, api, ctx) {
|
|
51
51
|
}
|
52
52
|
callback(null);
|
53
53
|
})
|
54
|
-
.catch(function
|
54
|
+
.catch(function(err) {
|
55
55
|
log.error("setReaction", err);
|
56
56
|
return callback(err);
|
57
57
|
});
|
@@ -73,14 +73,14 @@ module.exports = function (defaultFuncs, api, ctx) {
|
|
73
73
|
actor_id: ctx.userID,
|
74
74
|
reaction_style: null,
|
75
75
|
sync_group: 1,
|
76
|
-
send_attribution: Math.random() < 0.5 ? 65537 : 524289
|
76
|
+
send_attribution: Math.random() < 0.5 ? 65537 : 524289
|
77
77
|
};
|
78
78
|
const task = {
|
79
79
|
failure_count: null,
|
80
80
|
label: "29",
|
81
81
|
payload: JSON.stringify(taskPayload),
|
82
82
|
queue_name: JSON.stringify(["reaction", messageID]),
|
83
|
-
task_id: taskNumber
|
83
|
+
task_id: taskNumber
|
84
84
|
};
|
85
85
|
const content = {
|
86
86
|
app_id: "2220391788200892",
|
@@ -88,20 +88,20 @@ module.exports = function (defaultFuncs, api, ctx) {
|
|
88
88
|
data_trace_id: null,
|
89
89
|
epoch_id: parseInt(generateOfflineThreadingID()),
|
90
90
|
tasks: [task],
|
91
|
-
version_id: "7158486590867448"
|
91
|
+
version_id: "7158486590867448"
|
92
92
|
}),
|
93
93
|
request_id: ctx.wsReqNumber,
|
94
|
-
type: 3
|
94
|
+
type: 3
|
95
95
|
};
|
96
96
|
if (typeof callback === "function") {
|
97
97
|
ctx["tasks"].set(taskNumber, {
|
98
98
|
type: "set_message_reaction",
|
99
|
-
callback: callback
|
99
|
+
callback: callback
|
100
100
|
});
|
101
101
|
}
|
102
102
|
ctx.mqttClient.publish("/ls_req", JSON.stringify(content), {
|
103
103
|
qos: 1,
|
104
|
-
retain: false
|
104
|
+
retain: false
|
105
105
|
});
|
106
106
|
}
|
107
107
|
return function setMessageReaction(reaction, messageID, threadID, callback) {
|
@@ -116,4 +116,4 @@ module.exports = function (defaultFuncs, api, ctx) {
|
|
116
116
|
setMessageReactionNoMqtt(reaction, messageID, callback);
|
117
117
|
}
|
118
118
|
};
|
119
|
-
};
|
119
|
+
};
|
@@ -0,0 +1,90 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
const utils = require("../../utils");
|
4
|
+
const log = require("npmlog");
|
5
|
+
|
6
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
7
|
+
return function setTitle(newTitle, threadID, callback) {
|
8
|
+
if (
|
9
|
+
!callback &&
|
10
|
+
(utils.getType(threadID) === "Function" ||
|
11
|
+
utils.getType(threadID) === "AsyncFunction")
|
12
|
+
) {
|
13
|
+
throw { error: "please pass a threadID as a second argument." };
|
14
|
+
}
|
15
|
+
|
16
|
+
let resolveFunc = function() {};
|
17
|
+
let rejectFunc = function() {};
|
18
|
+
const returnPromise = new Promise(function(resolve, reject) {
|
19
|
+
resolveFunc = resolve;
|
20
|
+
rejectFunc = reject;
|
21
|
+
});
|
22
|
+
|
23
|
+
if (!callback) {
|
24
|
+
callback = function(err, friendList) {
|
25
|
+
if (err) {
|
26
|
+
return rejectFunc(err);
|
27
|
+
}
|
28
|
+
resolveFunc(friendList);
|
29
|
+
};
|
30
|
+
}
|
31
|
+
|
32
|
+
const messageAndOTID = utils.generateOfflineThreadingID();
|
33
|
+
const form = {
|
34
|
+
client: "mercury",
|
35
|
+
action_type: "ma-type:log-message",
|
36
|
+
author: "fbid:" + (ctx.i_userID || ctx.userID),
|
37
|
+
author_email: "",
|
38
|
+
coordinates: "",
|
39
|
+
timestamp: Date.now(),
|
40
|
+
timestamp_absolute: "Today",
|
41
|
+
timestamp_relative: utils.generateTimestampRelative(),
|
42
|
+
timestamp_time_passed: "0",
|
43
|
+
is_unread: false,
|
44
|
+
is_cleared: false,
|
45
|
+
is_forward: false,
|
46
|
+
is_filtered_content: false,
|
47
|
+
is_spoof_warning: false,
|
48
|
+
source: "source:chat:web",
|
49
|
+
"source_tags[0]": "source:chat",
|
50
|
+
status: "0",
|
51
|
+
offline_threading_id: messageAndOTID,
|
52
|
+
message_id: messageAndOTID,
|
53
|
+
threading_id: utils.generateThreadingID(ctx.clientID),
|
54
|
+
manual_retry_cnt: "0",
|
55
|
+
thread_fbid: threadID,
|
56
|
+
thread_name: newTitle,
|
57
|
+
thread_id: threadID,
|
58
|
+
log_message_type: "log:thread-name"
|
59
|
+
};
|
60
|
+
|
61
|
+
defaultFuncs
|
62
|
+
.post(
|
63
|
+
"https://www.facebook.com/messaging/set_thread_name/",
|
64
|
+
ctx.jar,
|
65
|
+
form
|
66
|
+
)
|
67
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
68
|
+
.then(function(resData) {
|
69
|
+
if (resData.error && resData.error === 1545012) {
|
70
|
+
throw { error: "Cannot change chat title: Not member of chat." };
|
71
|
+
}
|
72
|
+
|
73
|
+
if (resData.error && resData.error === 1545003) {
|
74
|
+
throw { error: "Cannot set title of single-user chat." };
|
75
|
+
}
|
76
|
+
|
77
|
+
if (resData.error) {
|
78
|
+
throw resData;
|
79
|
+
}
|
80
|
+
|
81
|
+
return callback();
|
82
|
+
})
|
83
|
+
.catch(function(err) {
|
84
|
+
log.error("setTitle", err);
|
85
|
+
return callback(err);
|
86
|
+
});
|
87
|
+
|
88
|
+
return returnPromise;
|
89
|
+
};
|
90
|
+
};
|
@@ -0,0 +1,51 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
const utils = require("../../utils");
|
4
|
+
var log = require("npmlog");
|
5
|
+
|
6
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
7
|
+
return function shareContact(text, senderID, threadID, callback) {
|
8
|
+
if (!text) {
|
9
|
+
text = "";
|
10
|
+
}
|
11
|
+
var resolveFunc = function() {};
|
12
|
+
var rejectFunc = function() {};
|
13
|
+
var returnPromise = new Promise(function(resolve, reject) {
|
14
|
+
resolveFunc = resolve;
|
15
|
+
rejectFunc = reject;
|
16
|
+
});
|
17
|
+
if (!callback) {
|
18
|
+
callback = function(err, data) {
|
19
|
+
if (err) return rejectFunc(err);
|
20
|
+
resolveFunc(data);
|
21
|
+
data;
|
22
|
+
};
|
23
|
+
}
|
24
|
+
let count_req = 0;
|
25
|
+
var form = JSON.stringify({
|
26
|
+
app_id: "2220391788200892",
|
27
|
+
payload: JSON.stringify({
|
28
|
+
tasks: [
|
29
|
+
{
|
30
|
+
label: "359",
|
31
|
+
payload: JSON.stringify({
|
32
|
+
contact_id: senderID,
|
33
|
+
sync_group: 1,
|
34
|
+
text: text || "",
|
35
|
+
thread_id: threadID
|
36
|
+
}),
|
37
|
+
queue_name: "messenger_contact_sharing",
|
38
|
+
task_id: (Math.random() * 1001) << 0,
|
39
|
+
failure_count: null
|
40
|
+
}
|
41
|
+
],
|
42
|
+
epoch_id: utils.generateOfflineThreadingID(),
|
43
|
+
version_id: "7214102258676893"
|
44
|
+
}),
|
45
|
+
request_id: ++count_req,
|
46
|
+
type: 3
|
47
|
+
});
|
48
|
+
mqttClient.publish("/ls_req", form);
|
49
|
+
return returnPromise;
|
50
|
+
};
|
51
|
+
};
|
@@ -0,0 +1,131 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
module.exports = function(_defaultFuncs, _api, _ctx) {
|
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
|
+
|
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
|
+
|
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
|
+
|
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
|
+
|
101
|
+
/**
|
102
|
+
* July 15, 2022
|
103
|
+
* added by @NTKhang
|
104
|
+
*/
|
105
|
+
NonBinary: "737761000603635",
|
106
|
+
|
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
|
+
|
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
|
+
};
|
@@ -0,0 +1,44 @@
|
|
1
|
+
"use strict";
|
2
|
+
const utils = require("../../utils");
|
3
|
+
const log = require("npmlog");
|
4
|
+
|
5
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
6
|
+
return function unsendMessage(messageID, callback) {
|
7
|
+
let resolveFunc = function() {};
|
8
|
+
let rejectFunc = function() {};
|
9
|
+
const returnPromise = new Promise(function(resolve, reject) {
|
10
|
+
resolveFunc = resolve;
|
11
|
+
rejectFunc = reject;
|
12
|
+
});
|
13
|
+
|
14
|
+
if (!callback) {
|
15
|
+
callback = function(err, friendList) {
|
16
|
+
if (err) {
|
17
|
+
return rejectFunc(err);
|
18
|
+
}
|
19
|
+
resolveFunc(friendList);
|
20
|
+
};
|
21
|
+
}
|
22
|
+
|
23
|
+
const form = {
|
24
|
+
message_id: messageID
|
25
|
+
};
|
26
|
+
|
27
|
+
defaultFuncs
|
28
|
+
.post("https://www.facebook.com/messaging/unsend_message/", ctx.jar, form)
|
29
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
30
|
+
.then(function(resData) {
|
31
|
+
if (resData.error) {
|
32
|
+
throw resData;
|
33
|
+
}
|
34
|
+
|
35
|
+
return callback();
|
36
|
+
})
|
37
|
+
.catch(function(err) {
|
38
|
+
log.error("unsendMessage", err);
|
39
|
+
return callback(err);
|
40
|
+
});
|
41
|
+
|
42
|
+
return returnPromise;
|
43
|
+
};
|
44
|
+
};
|
@@ -0,0 +1,93 @@
|
|
1
|
+
const utils = require("../../utils");
|
2
|
+
const log = require("npmlog");
|
3
|
+
|
4
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
5
|
+
function upload(attachments, callback) {
|
6
|
+
callback = callback || function() {};
|
7
|
+
const uploads = [];
|
8
|
+
|
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
|
+
|
20
|
+
const form = {
|
21
|
+
upload_1024: attachments[i],
|
22
|
+
voice_clip: "true"
|
23
|
+
};
|
24
|
+
|
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
|
+
|
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
|
+
|
46
|
+
// resolve all promises
|
47
|
+
Promise.all(uploads)
|
48
|
+
.then(function(resData) {
|
49
|
+
callback(null, resData);
|
50
|
+
})
|
51
|
+
.catch(function(err) {
|
52
|
+
log.error("uploadAttachment", err);
|
53
|
+
return callback(err);
|
54
|
+
});
|
55
|
+
}
|
56
|
+
|
57
|
+
return function uploadAttachment(attachments, callback) {
|
58
|
+
if (
|
59
|
+
!attachments &&
|
60
|
+
!utils.isReadableStream(attachments) &&
|
61
|
+
!utils.getType(attachments) === "Array" &&
|
62
|
+
utils.getType(attachments) === "Array" && !attachments.length
|
63
|
+
)
|
64
|
+
throw { error: "Please pass an attachment or an array of attachments." };
|
65
|
+
|
66
|
+
let resolveFunc = function() {};
|
67
|
+
let rejectFunc = function() {};
|
68
|
+
const returnPromise = new Promise(function(resolve, reject) {
|
69
|
+
resolveFunc = resolve;
|
70
|
+
rejectFunc = reject;
|
71
|
+
});
|
72
|
+
|
73
|
+
if (!callback) {
|
74
|
+
callback = function(err, info) {
|
75
|
+
if (err) {
|
76
|
+
return rejectFunc(err);
|
77
|
+
}
|
78
|
+
resolveFunc(info);
|
79
|
+
};
|
80
|
+
}
|
81
|
+
|
82
|
+
if (utils.getType(attachments) !== "Array") attachments = [attachments];
|
83
|
+
|
84
|
+
upload(attachments, (err, info) => {
|
85
|
+
if (err) {
|
86
|
+
return callback(err);
|
87
|
+
}
|
88
|
+
callback(null, info);
|
89
|
+
});
|
90
|
+
|
91
|
+
return returnPromise;
|
92
|
+
};
|
93
|
+
};
|