@dongdev/fca-unofficial 2.0.6 → 2.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/CHANGELOG.md +6 -1
  2. package/func/checkUpdate.js +9 -9
  3. package/func/logger.js +40 -104
  4. package/module/login.js +4 -4
  5. package/module/loginHelper.js +3 -3
  6. package/module/options.js +5 -9
  7. package/package.json +6 -6
  8. package/src/api/action/addExternalModule.js +5 -5
  9. package/src/api/action/changeAvatar.js +11 -10
  10. package/src/api/action/changeBio.js +7 -8
  11. package/src/api/action/getCurrentUserID.js +1 -1
  12. package/src/api/action/handleFriendRequest.js +5 -5
  13. package/src/api/action/logout.js +9 -8
  14. package/src/api/action/refreshFb_dtsg.js +17 -12
  15. package/src/api/action/setPostReaction.js +10 -11
  16. package/src/api/action/unfriend.js +3 -4
  17. package/src/api/http/httpGet.js +7 -8
  18. package/src/api/http/httpPost.js +7 -8
  19. package/src/api/http/postFormData.js +6 -5
  20. package/src/api/messaging/addUserToGroup.js +0 -1
  21. package/src/api/messaging/changeAdminStatus.js +108 -89
  22. package/src/api/messaging/changeArchivedStatus.js +6 -6
  23. package/src/api/messaging/changeBlockedStatus.js +3 -4
  24. package/src/api/messaging/changeGroupImage.js +72 -117
  25. package/src/api/messaging/changeNickname.js +59 -48
  26. package/src/api/messaging/changeThreadColor.js +61 -47
  27. package/src/api/messaging/changeThreadEmoji.js +106 -0
  28. package/src/api/messaging/createNewGroup.js +5 -5
  29. package/src/api/messaging/createPoll.js +36 -63
  30. package/src/api/messaging/deleteMessage.js +4 -4
  31. package/src/api/messaging/deleteThread.js +4 -4
  32. package/src/api/messaging/forwardAttachment.js +38 -47
  33. package/src/api/messaging/getFriendsList.js +5 -6
  34. package/src/api/messaging/getMessage.js +4 -9
  35. package/src/api/messaging/handleMessageRequest.js +5 -5
  36. package/src/api/messaging/markAsDelivered.js +5 -5
  37. package/src/api/messaging/markAsRead.js +7 -7
  38. package/src/api/messaging/markAsReadAll.js +3 -4
  39. package/src/api/messaging/markAsSeen.js +7 -7
  40. package/src/api/messaging/muteThread.js +3 -4
  41. package/src/api/messaging/removeUserFromGroup.js +82 -56
  42. package/src/api/messaging/resolvePhotoUrl.js +2 -3
  43. package/src/api/messaging/searchForThread.js +2 -3
  44. package/src/api/messaging/sendMessage.js +171 -101
  45. package/src/api/messaging/sendMessageMqtt.js +14 -12
  46. package/src/api/messaging/sendTypingIndicator.js +11 -11
  47. package/src/api/messaging/setMessageReaction.js +68 -82
  48. package/src/api/messaging/setTitle.js +77 -48
  49. package/src/api/messaging/shareContact.js +2 -4
  50. package/src/api/messaging/threadColors.js +0 -3
  51. package/src/api/messaging/unsendMessage.js +74 -37
  52. package/src/api/messaging/uploadAttachment.js +11 -9
  53. package/src/api/socket/core/connectMqtt.js +180 -0
  54. package/src/api/socket/core/getSeqID.js +25 -0
  55. package/src/api/socket/core/getTaskResponseData.js +22 -0
  56. package/src/api/socket/core/markDelivery.js +12 -0
  57. package/src/api/socket/core/parseDelta.js +351 -0
  58. package/src/api/socket/detail/buildStream.js +176 -68
  59. package/src/api/socket/detail/constants.js +24 -0
  60. package/src/api/socket/listenMqtt.js +80 -1005
  61. package/src/api/{messaging → threads}/getThreadHistory.js +5 -22
  62. package/src/api/threads/getThreadInfo.js +35 -248
  63. package/src/api/threads/getThreadList.js +20 -20
  64. package/src/api/threads/getThreadPictures.js +3 -4
  65. package/src/api/users/getUserID.js +5 -6
  66. package/src/api/users/getUserInfo.js +305 -73
  67. package/src/api/users/getUserInfoV2.js +134 -0
  68. package/src/database/models/user.js +32 -0
  69. package/src/database/userData.js +89 -0
  70. package/src/utils/constants.js +12 -2
  71. package/src/utils/format.js +1051 -0
  72. package/src/utils/request.js +75 -7
  73. package/src/api/threads/changeThreadEmoji.js +0 -55
  74. package/src/utils/index.js +0 -1497
@@ -1,135 +1,90 @@
1
1
  "use strict";
2
2
 
3
- const utils = require("../../utils");
3
+ const { generateOfflineThreadingID } = require("../../utils/format.js");
4
4
  const log = require("npmlog");
5
5
 
6
- module.exports = function(defaultFuncs, api, ctx) {
7
- function handleUpload(image, callback) {
8
- const uploads = [];
9
-
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ function handleUpload(image) {
10
8
  const form = {
11
9
  images_only: "true",
12
10
  "attachment[]": image
13
11
  };
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);
12
+ return defaultFuncs
13
+ .postFormData("https://upload.facebook.com/ajax/mercury/upload.php", ctx.jar, form, {})
14
+ .then(parseAndCheckLogin(ctx, defaultFuncs))
15
+ .then(resData => {
16
+ if (resData.error) throw resData;
17
+ return resData.payload.metadata[0];
41
18
  });
42
19
  }
43
-
44
20
  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);
21
+ return new Promise((resolve, reject) => {
22
+ if (!ctx.mqttClient) {
23
+ const err = new Error("Not connected to MQTT");
24
+ callback?.(err);
25
+ return reject(err);
26
+ }
27
+ if (!threadID || typeof threadID !== "string") {
28
+ const err = new Error("Invalid threadID");
29
+ callback?.(err);
30
+ return reject(err);
31
+ }
32
+ const reqID = ++ctx.wsReqNumber;
33
+ const taskID = ++ctx.wsTaskNumber;
34
+ const onResponse = (topic, message) => {
35
+ if (topic !== "/ls_resp") return;
36
+ let jsonMsg;
37
+ try {
38
+ jsonMsg = JSON.parse(message.toString());
39
+ jsonMsg.payload = JSON.parse(jsonMsg.payload);
40
+ } catch (err) {
41
+ return;
68
42
  }
69
- resolveFunc();
43
+ if (jsonMsg.request_id !== reqID) return;
44
+ ctx.mqttClient.removeListener("message", onResponse);
45
+ callback?.(null, { success: true, response: jsonMsg.payload });
46
+ return resolve({ success: true, response: jsonMsg.payload });
70
47
  };
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();
48
+ ctx.mqttClient.on("message", onResponse);
49
+ handleUpload(image)
50
+ .then(payload => {
51
+ const imageID = payload.image_id;
52
+ const taskPayload = {
53
+ thread_key: threadID,
54
+ image_id: imageID,
55
+ sync_group: 1
56
+ };
57
+
58
+ const mqttPayload = {
59
+ epoch_id: generateOfflineThreadingID(),
60
+ tasks: [
61
+ {
62
+ failure_count: null,
63
+ label: "37",
64
+ payload: JSON.stringify(taskPayload),
65
+ queue_name: "thread_image",
66
+ task_id: taskID
67
+ }
68
+ ],
69
+ version_id: "8798795233522156"
70
+ };
71
+ const request = {
72
+ app_id: "2220391788200892",
73
+ payload: JSON.stringify(mqttPayload),
74
+ request_id: reqID,
75
+ type: 3
76
+ };
77
+ ctx.mqttClient.publish("/ls_req", JSON.stringify(request), {
78
+ qos: 1,
79
+ retain: false
80
+ });
126
81
  })
127
- .catch(function(err) {
128
- log.error("changeGroupImage", err);
129
- return callback(err);
82
+ .catch(err => {
83
+ ctx.mqttClient.removeListener("message", onResponse);
84
+ log.error("changeGroupImageMqtt", err);
85
+ callback?.(err);
86
+ reject(err);
130
87
  });
131
88
  });
132
-
133
- return returnPromise;
134
89
  };
135
90
  };
@@ -1,59 +1,70 @@
1
1
  "use strict";
2
2
 
3
- const utils = require("../../utils");
3
+ const { generateOfflineThreadingID } = require("../../utils/format.js");
4
4
  const log = require("npmlog");
5
5
 
6
- module.exports = function(defaultFuncs, api, ctx) {
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
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();
8
+ return new Promise((resolve, reject) => {
9
+ if (!ctx.mqttClient) {
10
+ const err = new Error("Not connected to MQTT");
11
+ callback?.(err);
12
+ return reject(err);
13
+ }
14
+ if (!threadID || !participantID) {
15
+ const err = new Error("Missing required parameters");
16
+ callback?.(err);
17
+ return reject(err);
18
+ }
19
+ const reqID = ++ctx.wsReqNumber;
20
+ const taskID = ++ctx.wsTaskNumber;
21
+ const payload = {
22
+ epoch_id: generateOfflineThreadingID(),
23
+ tasks: [
24
+ {
25
+ failure_count: null,
26
+ label: "44",
27
+ payload: JSON.stringify({
28
+ thread_key: threadID,
29
+ contact_id: participantID,
30
+ nickname: nickname || "",
31
+ sync_group: 1
32
+ }),
33
+ queue_name: "thread_participant_nickname",
34
+ task_id: taskID
35
+ }
36
+ ],
37
+ version_id: "8798795233522156"
20
38
  };
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
- };
39
+ const request = {
40
+ app_id: "2220391788200892",
41
+ payload: JSON.stringify(payload),
42
+ request_id: reqID,
43
+ type: 3
44
+ };
45
+ const onResponse = (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 (err) {
52
+ return;
45
53
  }
46
- if (resData.error) {
47
- throw resData;
54
+ if (jsonMsg.request_id !== reqID) return;
55
+ ctx.mqttClient.removeListener("message", onResponse);
56
+ callback?.(null, { success: true, response: jsonMsg.payload });
57
+ return resolve({ success: true, response: jsonMsg.payload });
58
+ };
59
+ ctx.mqttClient.on("message", onResponse);
60
+ ctx.mqttClient.publish("/ls_req", JSON.stringify(request), { qos: 1, retain: false }, (err) => {
61
+ if (err) {
62
+ ctx.mqttClient.removeListener("message", onResponse);
63
+ log.error("changeNicknameMqtt", err);
64
+ callback?.(err);
65
+ return reject(err);
48
66
  }
49
-
50
- return callback();
51
- })
52
- .catch(function(err) {
53
- log.error("changeNickname", err);
54
- return callback(err);
55
67
  });
56
-
57
- return returnPromise;
68
+ });
58
69
  };
59
70
  };
@@ -1,65 +1,79 @@
1
1
  "use strict";
2
2
 
3
- const utils = require("../../utils");
4
- const log = require("npmlog");
5
-
6
- module.exports = function(defaultFuncs, api, ctx) {
7
- return function changeThreadColor(color, threadID, callback) {
8
- let resolveFunc = function() {};
9
- let rejectFunc = function() {};
10
- const returnPromise = new Promise(function(resolve, reject) {
3
+ const { generateOfflineThreadingID } = require("../../utils/format.js");
4
+ module.exports = (defaultFuncs, api, ctx) => {
5
+ return async (color, threadID, callback) => {
6
+ let reqID = ++ctx.wsReqNumber;
7
+ let resolveFunc = () => { };
8
+ let rejectFunc = () => { };
9
+ const returnPromise = new Promise((resolve, reject) => {
11
10
  resolveFunc = resolve;
12
11
  rejectFunc = reject;
13
12
  });
14
13
 
15
14
  if (!callback) {
16
- callback = function(err) {
17
- if (err) {
18
- return rejectFunc(err);
19
- }
20
- resolveFunc(err);
15
+ callback = (err, data) => {
16
+ if (err) return rejectFunc(err);
17
+ resolveFunc(data);
21
18
  };
22
19
  }
23
20
 
24
- if (!isNaN(color)) {
25
- color = color.toString();
26
- }
27
- const validatedColor = color !== null ? color.toLowerCase() : color; // API only accepts lowercase letters in hex string
28
-
29
- const form = {
30
- dpr: 1,
31
- queries: JSON.stringify({
32
- o0: {
33
- //This doc_id is valid as of January 31, 2020
34
- doc_id: "1727493033983591",
35
- query_params: {
36
- data: {
37
- actor_id: ctx.i_userID || ctx.userID,
38
- client_mutation_id: "0",
39
- source: "SETTINGS",
40
- theme_id: validatedColor,
41
- thread_id: threadID
42
- }
21
+ const content = {
22
+ app_id: "2220391788200892",
23
+ payload: JSON.stringify({
24
+ data_trace_id: null,
25
+ epoch_id: parseInt(generateOfflineThreadingID()),
26
+ tasks: [
27
+ {
28
+ failure_count: null,
29
+ label: "43",
30
+ payload: JSON.stringify({
31
+ thread_key: threadID,
32
+ theme_fbid: color,
33
+ source: null,
34
+ sync_group: 1,
35
+ payload: null
36
+ }),
37
+ queue_name: "thread_theme",
38
+ task_id: ++ctx.wsTaskNumber
43
39
  }
44
- }
45
- })
40
+ ],
41
+ version_id: "8798795233522156"
42
+ }),
43
+ request_id: reqID,
44
+ type: 3
46
45
  };
47
46
 
48
- defaultFuncs
49
- .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
50
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
51
- .then(function(resData) {
52
- if (resData[resData.length - 1].error_results > 0) {
53
- throw new utils.CustomError(resData[0].o0.errors);
54
- }
47
+ ctx.mqttClient.publish("/ls_req", JSON.stringify(content), {
48
+ qos: 1,
49
+ retain: false
50
+ });
55
51
 
56
- return callback();
57
- })
58
- .catch(function(err) {
59
- log.error("changeThreadColor", err);
60
- return callback(err);
61
- });
52
+ const handleRes = (topic, message) => {
53
+ if (topic !== "/ls_resp") return;
54
+ let jsonMsg;
55
+ try {
56
+ jsonMsg = JSON.parse(message.toString());
57
+ jsonMsg.payload = JSON.parse(jsonMsg.payload);
58
+ } catch (err) {
59
+ return;
60
+ }
61
+ if (jsonMsg.request_id !== reqID) return;
62
+ ctx.mqttClient.removeListener("message", handleRes);
63
+ try {
64
+ const msgID = jsonMsg.payload.step[1][2][2][1][2];
65
+ const msgReplace = jsonMsg.payload.step[1][2][2][1][4];
66
+ const bodies = {
67
+ body: msgReplace,
68
+ messageID: msgID
69
+ };
70
+ return callback(null, bodies);
71
+ } catch (err) {
72
+ return callback(null, { success: true });
73
+ }
74
+ };
62
75
 
76
+ ctx.mqttClient.on("message", handleRes);
63
77
  return returnPromise;
64
78
  };
65
79
  };
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+
3
+ const { generateOfflineThreadingID } = require("../../utils/format");
4
+ const log = require("npmlog");
5
+ const { parseAndCheckLogin } = require("../../utils/client");
6
+ module.exports = function (defaultFuncs, api, ctx) {
7
+ function changeThreadEmojiNoMqtt(emoji, threadID, 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
+ if (!callback) {
15
+ callback = function (err) {
16
+ if (err) {
17
+ return rejectFunc(err);
18
+ }
19
+ resolveFunc();
20
+ };
21
+ }
22
+ var form = {
23
+ emoji_choice: emoji,
24
+ thread_or_other_fbid: threadID,
25
+ };
26
+ defaultFuncs
27
+ .post(
28
+ "https://www.facebook.com/messaging/save_thread_emoji/?source=thread_settings&__pc=EXP1%3Amessengerdotcom_pkg",
29
+ ctx.jar,
30
+ form,
31
+ )
32
+ .then(parseAndCheckLogin(ctx, defaultFuncs))
33
+ .then(function (resData) {
34
+ if (resData.error === 1357031) {
35
+ throw {
36
+ error:
37
+ "Trying to change emoji of a chat that doesn't exist. Have at least one message in the thread before trying to change the emoji.",
38
+ };
39
+ }
40
+ if (resData.error) {
41
+ throw resData;
42
+ }
43
+ return callback();
44
+ })
45
+ .catch(function (err) {
46
+ log.error("changeThreadEmoji", err);
47
+ return callback(err);
48
+ });
49
+ return returnPromise;
50
+ };
51
+ function changeThreadEmojiMqtt(emoji, threadID, callback) {
52
+ if (!ctx.mqttClient) {
53
+ throw new Error("Not connected to MQTT");
54
+ }
55
+ var resolveFunc = function () { };
56
+ var rejectFunc = function () { };
57
+ var returnPromise = new Promise(function (resolve, reject) {
58
+ resolveFunc = resolve;
59
+ rejectFunc = reject;
60
+ });
61
+ if (!callback) {
62
+ callback = function (err, data) {
63
+ if (err) return rejectFunc(err);
64
+ resolveFunc(data);
65
+ data
66
+ };
67
+ }
68
+ let count_req = 0
69
+ var form = JSON.stringify({
70
+ "app_id": "2220391788200892",
71
+ "payload": JSON.stringify({
72
+ epoch_id: generateOfflineThreadingID(),
73
+ tasks: [
74
+ {
75
+ failure_count: null,
76
+ label: '100003',
77
+ payload: JSON.stringify({
78
+ "thread_key": threadID,
79
+ "custom_emoji": emoji,
80
+ "avatar_sticker_instruction_key_id": null,
81
+ "sync_group": 1
82
+ }),
83
+ queue_name: 'thread_quick_reaction',
84
+ task_id: Math.random() * 1001 << 0
85
+ }
86
+ ],
87
+ version_id: '8798795233522156'
88
+ }),
89
+ "request_id": ++count_req,
90
+ "type": 3
91
+ });
92
+ mqttClient.publish('/ls_req', form);
93
+ return returnPromise;
94
+ };
95
+ return function changeThreadEmoji(emoji, threadID, callback) {
96
+ if (ctx.mqttClient) {
97
+ try {
98
+ changeThreadEmojiMqtt(emoji, threadID, callback);
99
+ } catch (e) {
100
+ changeThreadEmojiNoMqtt(emoji, threadID, callback);
101
+ }
102
+ } else {
103
+ changeThreadEmojiNoMqtt(emoji, threadID, callback);
104
+ }
105
+ };
106
+ };
@@ -1,16 +1,16 @@
1
1
  "use strict";
2
2
 
3
- const utils = require("../../utils");
4
3
  const log = require("npmlog");
5
-
4
+ const { parseAndCheckLogin } = require("../../utils/client");
5
+ const { getType } = require("../../utils/format");
6
6
  module.exports = function(defaultFuncs, api, ctx) {
7
7
  return function createNewGroup(participantIDs, groupTitle, callback) {
8
- if (utils.getType(groupTitle) == "Function") {
8
+ if (getType(groupTitle) == "Function") {
9
9
  callback = groupTitle;
10
10
  groupTitle = null;
11
11
  }
12
12
 
13
- if (utils.getType(participantIDs) !== "Array") {
13
+ if (getType(participantIDs) !== "Array") {
14
14
  throw { error: "createNewGroup: participantIDs should be an array." };
15
15
  }
16
16
 
@@ -67,7 +67,7 @@ module.exports = function(defaultFuncs, api, ctx) {
67
67
 
68
68
  defaultFuncs
69
69
  .post("https://www.facebook.com/api/graphql/", ctx.jar, form)
70
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
70
+ .then(parseAndCheckLogin(ctx, defaultFuncs))
71
71
  .then(function(resData) {
72
72
  if (resData.errors) {
73
73
  throw resData;