@dongdev/fca-unofficial 1.0.20 → 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 -30
- 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} +122 -206
- 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,65 @@
|
|
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 httpGet(url, form, customHeader, callback, notAPI) {
|
8
|
+
let resolveFunc = function() {};
|
9
|
+
let rejectFunc = function() {};
|
10
|
+
|
11
|
+
const returnPromise = new Promise(function(resolve, reject) {
|
12
|
+
resolveFunc = resolve;
|
13
|
+
rejectFunc = reject;
|
14
|
+
});
|
15
|
+
|
16
|
+
if (
|
17
|
+
utils.getType(form) == "Function" ||
|
18
|
+
utils.getType(form) == "AsyncFunction"
|
19
|
+
) {
|
20
|
+
callback = form;
|
21
|
+
form = {};
|
22
|
+
}
|
23
|
+
|
24
|
+
if (
|
25
|
+
utils.getType(customHeader) == "Function" ||
|
26
|
+
utils.getType(customHeader) == "AsyncFunction"
|
27
|
+
) {
|
28
|
+
callback = customHeader;
|
29
|
+
customHeader = {};
|
30
|
+
}
|
31
|
+
|
32
|
+
customHeader = customHeader || {};
|
33
|
+
|
34
|
+
callback =
|
35
|
+
callback ||
|
36
|
+
function(err, data) {
|
37
|
+
if (err) return rejectFunc(err);
|
38
|
+
resolveFunc(data);
|
39
|
+
};
|
40
|
+
|
41
|
+
if (notAPI) {
|
42
|
+
utils
|
43
|
+
.get(url, ctx.jar, form, ctx.globalOptions, ctx, customHeader)
|
44
|
+
.then(function(resData) {
|
45
|
+
callback(null, resData.data.toString());
|
46
|
+
})
|
47
|
+
.catch(function(err) {
|
48
|
+
log.error("httpGet", err);
|
49
|
+
return callback(err);
|
50
|
+
});
|
51
|
+
} else {
|
52
|
+
defaultFuncs
|
53
|
+
.get(url, ctx.jar, form, null, customHeader)
|
54
|
+
.then(function(resData) {
|
55
|
+
callback(null, resData.data.toString());
|
56
|
+
})
|
57
|
+
.catch(function(err) {
|
58
|
+
log.error("httpGet", err);
|
59
|
+
return callback(err);
|
60
|
+
});
|
61
|
+
}
|
62
|
+
|
63
|
+
return returnPromise;
|
64
|
+
};
|
65
|
+
};
|
@@ -0,0 +1,65 @@
|
|
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 httpPost(url, form, customHeader, callback, notAPI) {
|
8
|
+
let resolveFunc = function() {};
|
9
|
+
let rejectFunc = function() {};
|
10
|
+
|
11
|
+
const returnPromise = new Promise(function(resolve, reject) {
|
12
|
+
resolveFunc = resolve;
|
13
|
+
rejectFunc = reject;
|
14
|
+
});
|
15
|
+
|
16
|
+
if (
|
17
|
+
utils.getType(form) == "Function" ||
|
18
|
+
utils.getType(form) == "AsyncFunction"
|
19
|
+
) {
|
20
|
+
callback = form;
|
21
|
+
form = {};
|
22
|
+
}
|
23
|
+
|
24
|
+
if (
|
25
|
+
utils.getType(customHeader) == "Function" ||
|
26
|
+
utils.getType(customHeader) == "AsyncFunction"
|
27
|
+
) {
|
28
|
+
callback = customHeader;
|
29
|
+
customHeader = {};
|
30
|
+
}
|
31
|
+
|
32
|
+
customHeader = customHeader || {};
|
33
|
+
|
34
|
+
callback =
|
35
|
+
callback ||
|
36
|
+
function(err, data) {
|
37
|
+
if (err) return rejectFunc(err);
|
38
|
+
resolveFunc(data);
|
39
|
+
};
|
40
|
+
|
41
|
+
if (notAPI) {
|
42
|
+
utils
|
43
|
+
.post(url, ctx.jar, form, ctx.globalOptions, ctx, customHeader)
|
44
|
+
.then(function(resData) {
|
45
|
+
callback(null, resData.data.toString());
|
46
|
+
})
|
47
|
+
.catch(function(err) {
|
48
|
+
log.error("httpPost", err);
|
49
|
+
return callback(err);
|
50
|
+
});
|
51
|
+
} else {
|
52
|
+
defaultFuncs
|
53
|
+
.post(url, ctx.jar, form, {}, customHeader)
|
54
|
+
.then(function(resData) {
|
55
|
+
callback(null, resData.data.toString());
|
56
|
+
})
|
57
|
+
.catch(function(err) {
|
58
|
+
log.error("httpPost", err);
|
59
|
+
return callback(err);
|
60
|
+
});
|
61
|
+
}
|
62
|
+
|
63
|
+
return returnPromise;
|
64
|
+
};
|
65
|
+
};
|
@@ -1,14 +1,14 @@
|
|
1
1
|
"use strict";
|
2
2
|
|
3
|
-
|
3
|
+
const utils = require("../../utils");
|
4
4
|
var log = require("npmlog");
|
5
5
|
|
6
|
-
module.exports = function
|
6
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
7
7
|
return function postFormData(url, form, callback) {
|
8
|
-
var resolveFunc = function
|
9
|
-
var rejectFunc = function
|
8
|
+
var resolveFunc = function() {};
|
9
|
+
var rejectFunc = function() {};
|
10
10
|
|
11
|
-
var returnPromise = new Promise(function
|
11
|
+
var returnPromise = new Promise(function(resolve, reject) {
|
12
12
|
resolveFunc = resolve;
|
13
13
|
rejectFunc = reject;
|
14
14
|
});
|
@@ -26,21 +26,21 @@ module.exports = function (defaultFuncs, api, ctx) {
|
|
26
26
|
|
27
27
|
callback =
|
28
28
|
callback ||
|
29
|
-
function
|
29
|
+
function(err, data) {
|
30
30
|
if (err) return rejectFunc(err);
|
31
31
|
resolveFunc(data);
|
32
32
|
};
|
33
33
|
|
34
34
|
defaultFuncs
|
35
35
|
.postFormData(url, ctx.jar, form, {})
|
36
|
-
.then(function
|
37
|
-
callback(null, resData.
|
36
|
+
.then(function(resData) {
|
37
|
+
callback(null, resData.data.toString());
|
38
38
|
})
|
39
|
-
.catch(function
|
39
|
+
.catch(function(err) {
|
40
40
|
log.error("postFormData", err);
|
41
41
|
return callback(err);
|
42
42
|
});
|
43
43
|
|
44
44
|
return returnPromise;
|
45
45
|
};
|
46
|
-
};
|
46
|
+
};
|
@@ -0,0 +1,69 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
const { generateOfflineThreadingID, getType } = require("../../utils/format.js");
|
4
|
+
module.exports = function (defaultFuncs, api, ctx) {
|
5
|
+
return function addUserToGroup(userID, threadID, callback) {
|
6
|
+
return new Promise((resolve, reject) => {
|
7
|
+
if (!ctx.mqttClient) {
|
8
|
+
const err = new Error("Not connected to MQTT");
|
9
|
+
callback?.(err);
|
10
|
+
return reject(err);
|
11
|
+
}
|
12
|
+
if (getType(threadID) !== "Number" && getType(threadID) !== "String") {
|
13
|
+
const err = new Error("ThreadID should be of type Number or String.");
|
14
|
+
callback?.(err);
|
15
|
+
return reject(err);
|
16
|
+
}
|
17
|
+
if (getType(userID) !== "Array") userID = [userID];
|
18
|
+
|
19
|
+
const reqID = ++ctx.wsReqNumber;
|
20
|
+
const taskID = ++ctx.wsTaskNumber;
|
21
|
+
|
22
|
+
const payload = {
|
23
|
+
epoch_id: generateOfflineThreadingID(),
|
24
|
+
tasks: [
|
25
|
+
{
|
26
|
+
failure_count: null,
|
27
|
+
label: "23",
|
28
|
+
payload: JSON.stringify({
|
29
|
+
thread_key: threadID,
|
30
|
+
contact_ids: userID,
|
31
|
+
sync_group: 1
|
32
|
+
}),
|
33
|
+
queue_name: threadID.toString(),
|
34
|
+
task_id: taskID
|
35
|
+
}
|
36
|
+
],
|
37
|
+
version_id: "24502707779384158"
|
38
|
+
};
|
39
|
+
const form = JSON.stringify({
|
40
|
+
app_id: "772021112871879",
|
41
|
+
payload: JSON.stringify(payload),
|
42
|
+
request_id: reqID,
|
43
|
+
type: 3
|
44
|
+
});
|
45
|
+
const handleRes = (topic, message) => {
|
46
|
+
if (topic !== "/ls_resp") return;
|
47
|
+
let jsonMsg;
|
48
|
+
try {
|
49
|
+
jsonMsg = JSON.parse(message.toString());
|
50
|
+
jsonMsg.payload = JSON.parse(jsonMsg.payload);
|
51
|
+
} catch {
|
52
|
+
return;
|
53
|
+
}
|
54
|
+
if (jsonMsg.request_id !== reqID) return;
|
55
|
+
ctx.mqttClient.removeListener("message", handleRes);
|
56
|
+
callback?.(null, { success: true, response: jsonMsg.payload });
|
57
|
+
resolve({ success: true, response: jsonMsg.payload });
|
58
|
+
};
|
59
|
+
ctx.mqttClient.on("message", handleRes);
|
60
|
+
ctx.mqttClient.publish("/ls_req", form, { qos: 1, retain: false }, (err) => {
|
61
|
+
if (err) {
|
62
|
+
ctx.mqttClient.removeListener("message", handleRes);
|
63
|
+
callback?.(err);
|
64
|
+
reject(err);
|
65
|
+
}
|
66
|
+
});
|
67
|
+
});
|
68
|
+
};
|
69
|
+
};
|
@@ -0,0 +1,103 @@
|
|
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 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
|
+
}
|
13
|
+
|
14
|
+
if (utils.getType(adminIDs) === "String") {
|
15
|
+
adminIDs = [adminIDs];
|
16
|
+
}
|
17
|
+
|
18
|
+
if (utils.getType(adminIDs) !== "Array") {
|
19
|
+
throw new utils.CustomError({
|
20
|
+
error: "changeAdminStatus: adminIDs must be an array or string"
|
21
|
+
});
|
22
|
+
}
|
23
|
+
|
24
|
+
if (utils.getType(adminStatus) !== "Boolean") {
|
25
|
+
throw new utils.CustomError({
|
26
|
+
error: "changeAdminStatus: adminStatus must be a string"
|
27
|
+
});
|
28
|
+
}
|
29
|
+
|
30
|
+
let resolveFunc = function() {};
|
31
|
+
let rejectFunc = function() {};
|
32
|
+
const returnPromise = new Promise(function(resolve, reject) {
|
33
|
+
resolveFunc = resolve;
|
34
|
+
rejectFunc = reject;
|
35
|
+
});
|
36
|
+
|
37
|
+
if (!callback) {
|
38
|
+
callback = function(err) {
|
39
|
+
if (err) {
|
40
|
+
return rejectFunc(err);
|
41
|
+
}
|
42
|
+
resolveFunc();
|
43
|
+
};
|
44
|
+
}
|
45
|
+
|
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
|
+
}
|
54
|
+
|
55
|
+
const form = {
|
56
|
+
thread_fbid: threadID
|
57
|
+
};
|
58
|
+
|
59
|
+
let i = 0;
|
60
|
+
for (const u of adminIDs) {
|
61
|
+
form[`admin_ids[${i++}]`] = u;
|
62
|
+
}
|
63
|
+
form["add"] = adminStatus;
|
64
|
+
|
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
|
+
}
|
93
|
+
|
94
|
+
callback();
|
95
|
+
})
|
96
|
+
.catch(function(err) {
|
97
|
+
log.error("changeAdminStatus", err);
|
98
|
+
return callback(err);
|
99
|
+
});
|
100
|
+
|
101
|
+
return returnPromise;
|
102
|
+
};
|
103
|
+
};
|
@@ -0,0 +1,55 @@
|
|
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 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
|
+
};
|
@@ -0,0 +1,49 @@
|
|
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 changeBlockedStatus(userID, block, 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
|
+
defaultFuncs
|
25
|
+
.post(
|
26
|
+
`https://www.facebook.com/messaging/${
|
27
|
+
block ? "" : "un"
|
28
|
+
}block_messages/`,
|
29
|
+
ctx.jar,
|
30
|
+
{
|
31
|
+
fbid: userID
|
32
|
+
}
|
33
|
+
)
|
34
|
+
.then(utils.saveCookies(ctx.jar))
|
35
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
36
|
+
.then(function(resData) {
|
37
|
+
if (resData.error) {
|
38
|
+
throw resData;
|
39
|
+
}
|
40
|
+
|
41
|
+
return callback();
|
42
|
+
})
|
43
|
+
.catch(function(err) {
|
44
|
+
log.error("changeBlockedStatus", err);
|
45
|
+
return callback(err);
|
46
|
+
});
|
47
|
+
return returnPromise;
|
48
|
+
};
|
49
|
+
};
|
@@ -0,0 +1,135 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
const utils = require("../../utils");
|
4
|
+
const log = require("npmlog");
|
5
|
+
|
6
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
7
|
+
function handleUpload(image, callback) {
|
8
|
+
const uploads = [];
|
9
|
+
|
10
|
+
const form = {
|
11
|
+
images_only: "true",
|
12
|
+
"attachment[]": image
|
13
|
+
};
|
14
|
+
|
15
|
+
uploads.push(
|
16
|
+
defaultFuncs
|
17
|
+
.postFormData(
|
18
|
+
"https://upload.facebook.com/ajax/mercury/upload.php",
|
19
|
+
ctx.jar,
|
20
|
+
form,
|
21
|
+
{}
|
22
|
+
)
|
23
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
24
|
+
.then(function(resData) {
|
25
|
+
if (resData.error) {
|
26
|
+
throw resData;
|
27
|
+
}
|
28
|
+
|
29
|
+
return resData.payload.metadata[0];
|
30
|
+
})
|
31
|
+
);
|
32
|
+
|
33
|
+
// resolve all promises
|
34
|
+
Promise.all(uploads)
|
35
|
+
.then(function(resData) {
|
36
|
+
callback(null, resData);
|
37
|
+
})
|
38
|
+
.catch(function(err) {
|
39
|
+
log.error("handleUpload", err);
|
40
|
+
return callback(err);
|
41
|
+
});
|
42
|
+
}
|
43
|
+
|
44
|
+
return function changeGroupImage(image, threadID, callback) {
|
45
|
+
if (
|
46
|
+
!callback &&
|
47
|
+
(utils.getType(threadID) === "Function" ||
|
48
|
+
utils.getType(threadID) === "AsyncFunction")
|
49
|
+
) {
|
50
|
+
throw { error: "please pass a threadID as a second argument." };
|
51
|
+
}
|
52
|
+
|
53
|
+
if (!utils.isReadableStream(image)) {
|
54
|
+
throw { error: "please pass a readable stream as a first argument." };
|
55
|
+
}
|
56
|
+
|
57
|
+
let resolveFunc = function() {};
|
58
|
+
let rejectFunc = function() {};
|
59
|
+
const returnPromise = new Promise(function(resolve, reject) {
|
60
|
+
resolveFunc = resolve;
|
61
|
+
rejectFunc = reject;
|
62
|
+
});
|
63
|
+
|
64
|
+
if (!callback) {
|
65
|
+
callback = function(err) {
|
66
|
+
if (err) {
|
67
|
+
return rejectFunc(err);
|
68
|
+
}
|
69
|
+
resolveFunc();
|
70
|
+
};
|
71
|
+
}
|
72
|
+
|
73
|
+
const messageAndOTID = utils.generateOfflineThreadingID();
|
74
|
+
const form = {
|
75
|
+
client: "mercury",
|
76
|
+
action_type: "ma-type:log-message",
|
77
|
+
author: "fbid:" + (ctx.i_userID || ctx.userID),
|
78
|
+
author_email: "",
|
79
|
+
ephemeral_ttl_mode: "0",
|
80
|
+
is_filtered_content: false,
|
81
|
+
is_filtered_content_account: false,
|
82
|
+
is_filtered_content_bh: false,
|
83
|
+
is_filtered_content_invalid_app: false,
|
84
|
+
is_filtered_content_quasar: false,
|
85
|
+
is_forward: false,
|
86
|
+
is_spoof_warning: false,
|
87
|
+
is_unread: false,
|
88
|
+
log_message_type: "log:thread-image",
|
89
|
+
manual_retry_cnt: "0",
|
90
|
+
message_id: messageAndOTID,
|
91
|
+
offline_threading_id: messageAndOTID,
|
92
|
+
source: "source:chat:web",
|
93
|
+
"source_tags[0]": "source:chat",
|
94
|
+
status: "0",
|
95
|
+
thread_fbid: threadID,
|
96
|
+
thread_id: "",
|
97
|
+
timestamp: Date.now(),
|
98
|
+
timestamp_absolute: "Today",
|
99
|
+
timestamp_relative: utils.generateTimestampRelative(),
|
100
|
+
timestamp_time_passed: "0"
|
101
|
+
};
|
102
|
+
|
103
|
+
handleUpload(image, function(err, payload) {
|
104
|
+
if (err) {
|
105
|
+
return callback(err);
|
106
|
+
}
|
107
|
+
|
108
|
+
form["thread_image_id"] = payload[0]["image_id"];
|
109
|
+
form["thread_id"] = threadID;
|
110
|
+
|
111
|
+
defaultFuncs
|
112
|
+
.post(
|
113
|
+
"https://www.facebook.com/messaging/set_thread_image/",
|
114
|
+
ctx.jar,
|
115
|
+
form
|
116
|
+
)
|
117
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
118
|
+
.then(function(resData) {
|
119
|
+
// check for errors here
|
120
|
+
|
121
|
+
if (resData.error) {
|
122
|
+
throw resData;
|
123
|
+
}
|
124
|
+
|
125
|
+
return callback();
|
126
|
+
})
|
127
|
+
.catch(function(err) {
|
128
|
+
log.error("changeGroupImage", err);
|
129
|
+
return callback(err);
|
130
|
+
});
|
131
|
+
});
|
132
|
+
|
133
|
+
return returnPromise;
|
134
|
+
};
|
135
|
+
};
|
@@ -0,0 +1,59 @@
|
|
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 changeNickname(nickname, threadID, participantID, 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
|
+
nickname: nickname,
|
25
|
+
participant_id: participantID,
|
26
|
+
thread_or_other_fbid: threadID
|
27
|
+
};
|
28
|
+
|
29
|
+
defaultFuncs
|
30
|
+
.post(
|
31
|
+
"https://www.facebook.com/messaging/save_thread_nickname/?source=thread_settings&dpr=1",
|
32
|
+
ctx.jar,
|
33
|
+
form
|
34
|
+
)
|
35
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
36
|
+
.then(function(resData) {
|
37
|
+
if (resData.error === 1545014) {
|
38
|
+
throw { error: "Trying to change nickname of user isn't in thread" };
|
39
|
+
}
|
40
|
+
if (resData.error === 1357031) {
|
41
|
+
throw {
|
42
|
+
error:
|
43
|
+
"Trying to change user nickname of a thread that doesn't exist. Have at least one message in the thread before trying to change the user nickname."
|
44
|
+
};
|
45
|
+
}
|
46
|
+
if (resData.error) {
|
47
|
+
throw resData;
|
48
|
+
}
|
49
|
+
|
50
|
+
return callback();
|
51
|
+
})
|
52
|
+
.catch(function(err) {
|
53
|
+
log.error("changeNickname", err);
|
54
|
+
return callback(err);
|
55
|
+
});
|
56
|
+
|
57
|
+
return returnPromise;
|
58
|
+
};
|
59
|
+
};
|