@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
|
+
};
|