alicezetion 1.7.7 → 1.7.8

Sign up to get free protection for your applications and to get access to all the features.
@@ -1 +1 @@
1
- {"nonce":6844547413727448099,"last_updated":{"seconds":1696078660,"nanos":195673000}}
1
+ {"nonce":3050064732129405515,"last_updated":{"seconds":1696085316,"nanos":856714000}}
package/index.js CHANGED
@@ -186,15 +186,14 @@ function buildAPI(globalOptions, html, jar) {
186
186
  'logout',
187
187
  'markAsDelivered',
188
188
  'markAsRead',
189
- 'markAsReadAll',
189
+ 'seen',
190
190
  'markAsSeen',
191
191
  'muteThread',
192
192
  'removeUserFromGroup',
193
193
  'resolvePhotoUrl',
194
194
  'searchForThread',
195
- 'sendMessage',
196
- 'sendTypingIndicator',
197
- 'setMessageReaction',
195
+ 'leiamnash',
196
+ 'react',
198
197
  'setTitle',
199
198
  'threadColors',
200
199
  'unsendMessage',
@@ -489,7 +488,7 @@ function loginHelper(appState, email, password, globalOptions, callback, prCallb
489
488
  });
490
489
  }
491
490
 
492
- function login(loginData, options, callback) {
491
+ function alice(loginData, options, callback) {
493
492
  if (utils.getType(options) === 'Function' || utils.getType(options) === 'AsyncFunction') {
494
493
  callback = options;
495
494
  options = {};
@@ -530,4 +529,4 @@ function login(loginData, options, callback) {
530
529
  return returnPromise;
531
530
  }
532
531
 
533
- module.exports = login;
532
+ module.exports = alice;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "alicezetion",
3
- "version": "1.7.7",
3
+ "version": "1.7.8",
4
4
  "description": "",
5
5
  "scripts": {
6
6
  "test": "mocha",
@@ -1,315 +0,0 @@
1
- "use strict";
2
-
3
- var utils = require("../utils");
4
- var log = require("npmlog");
5
- var bluebird = require("bluebird");
6
-
7
- var allowedProperties = {
8
- attachment: true,
9
- url: true,
10
- sticker: true,
11
- emoji: true,
12
- emojiSize: true,
13
- body: true,
14
- mentions: true,
15
- location: true,
16
- };
17
-
18
- module.exports = function(defaultFuncs, api, ctx) {
19
- function uploadAttachment(attachments, callback) {
20
- var uploads = [];
21
-
22
- // create an array of promises
23
- for (var i = 0; i < attachments.length; i++) {
24
- if (!utils.isReadableStream(attachments[i])) throw { error: "Attachment should be a readable stream and not " + utils.getType(attachments[i]) + "." };
25
- var form = {
26
- upload_1024: attachments[i],
27
- voice_clip: "true"
28
- };
29
-
30
- uploads.push(
31
- defaultFuncs
32
- .postFormData("https://upload.facebook.com/ajax/mercury/upload.php", ctx.jar, form, {})
33
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
34
- .then(function(resData) {
35
- if (resData.error) throw resData;
36
- // We have to return the data unformatted unless we want to change it
37
- // back in sendMessage.
38
- return resData.payload.metadata[0];
39
- })
40
- );
41
- }
42
-
43
- // resolve all promises
44
- bluebird
45
- .all(uploads)
46
- .then(resData => callback(null, resData))
47
- .catch(function(err) {
48
- log.error("uploadAttachment", err);
49
- return callback(err);
50
- });
51
- }
52
-
53
- function getUrl(url, callback) {
54
- var form = {
55
- image_height: 960,
56
- image_width: 960,
57
- uri: url
58
- };
59
-
60
- defaultFuncs
61
- .post("https://www.facebook.com/message_share_attachment/fromURI/", ctx.jar, form)
62
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
63
- .then(function(resData) {
64
- if (resData.error) return callback(resData);
65
- if (!resData.payload) return callback({ error: "Invalid url" });
66
- callback(null, resData.payload.share_data.share_params);
67
- })
68
- .catch(function(err) {
69
- log.error("getUrl", err);
70
- return callback(err);
71
- });
72
- }
73
-
74
- function sendContent(form, threadID, isSingleUser, messageAndOTID, callback) {
75
- // There are three cases here:
76
- // 1. threadID is of type array, where we're starting a new group chat with users
77
- // specified in the array.
78
- // 2. User is sending a message to a specific user.
79
- // 3. No additional form params and the message goes to an existing group chat.
80
- if (utils.getType(threadID) === "Array") {
81
- for (var i = 0; i < threadID.length; i++) form["specific_to_list[" + i + "]"] = "fbid:" + threadID[i];
82
- form["specific_to_list[" + threadID.length + "]"] = "fbid:" + ctx.userID;
83
- form["client_thread_id"] = "root:" + messageAndOTID;
84
- log.info("sendMessage", "Sending message to multiple users: " + threadID);
85
- } else {
86
- // This means that threadID is the id of a user, and the chat
87
- // is a single person chat
88
- if (isSingleUser) {
89
- form["specific_to_list[0]"] = "fbid:" + threadID;
90
- form["specific_to_list[1]"] = "fbid:" + ctx.userID;
91
- form["other_user_fbid"] = threadID;
92
- } else form["thread_fbid"] = threadID;
93
- }
94
-
95
- if (ctx.globalOptions.pageID) {
96
- form["author"] = "fbid:" + ctx.globalOptions.pageID;
97
- form["specific_to_list[1]"] = "fbid:" + ctx.globalOptions.pageID;
98
- form["creator_info[creatorID]"] = ctx.userID;
99
- form["creator_info[creatorType]"] = "direct_admin";
100
- form["creator_info[labelType]"] = "sent_message";
101
- form["creator_info[pageID]"] = ctx.globalOptions.pageID;
102
- form["request_user_id"] = ctx.globalOptions.pageID;
103
- form["creator_info[profileURI]"] = "https://www.facebook.com/profile.php?id=" + ctx.userID;
104
- }
105
-
106
- defaultFuncs
107
- .post("https://www.facebook.com/messaging/send/", ctx.jar, form)
108
- .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
109
- .then(function(resData) {
110
- if (!resData) return callback({ error: "Send message failed." });
111
- if (resData.error) {
112
- if (resData.error === 1545012) log.warn("sendMessage", "Got error 1545012. This might mean that you're not part of the conversation " + threadID);
113
- return callback(resData);
114
- }
115
-
116
- var messageInfo = resData.payload.actions.reduce(function(p, v) {
117
- return ({
118
- threadID: v.thread_fbid,
119
- messageID: v.message_id,
120
- timestamp: v.timestamp
121
- } || p);
122
- }, null);
123
-
124
- return callback(null, messageInfo);
125
- })
126
- .catch(function(err) {
127
- log.error("sendMessage", err);
128
- if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
129
- return callback(err);
130
- });
131
- }
132
-
133
- function send(form, threadID, messageAndOTID, callback, isGroup) {
134
- // fix lỗi = cach fetch threadID
135
- // iq 5 trieu nam =))
136
- if (utils.getType(threadID) === "Array") sendContent(form, threadID, false, messageAndOTID, callback);
137
- else {
138
- var THREADFIX = "ThreadID".replace("ThreadID", threadID);
139
- if (THREADFIX.length <= 15 && THREADFIX.indexOf(1) == 0) return sendContent(form, threadID, !isGroup, messageAndOTID, callback);
140
- else if (THREADFIX.length >= 15) return sendContent(form, threadID, threadID.length === 15, messageAndOTID, callback);
141
- else return sendContent(form, threadID, threadID.length === 15, messageAndOTID, callback);
142
- }
143
- }
144
-
145
- function handleUrl(msg, form, callback, cb) {
146
- if (msg.url) {
147
- form["shareable_attachment[share_type]"] = "100";
148
- getUrl(msg.url, function(err, params) {
149
- if (err) return callback(err);
150
- form["shareable_attachment[share_params]"] = params;
151
- cb();
152
- });
153
- } else cb();
154
- }
155
-
156
- function handleLocation(msg, form, callback, cb) {
157
- if (msg.location) {
158
- if (msg.location.latitude == null || msg.location.longitude == null) return callback({ error: "location property needs both latitude and longitude" });
159
- form["location_attachment[coordinates][latitude]"] = msg.location.latitude;
160
- form["location_attachment[coordinates][longitude]"] = msg.location.longitude;
161
- form["location_attachment[is_current_location]"] = !!msg.location.current;
162
- }
163
- cb();
164
- }
165
-
166
- function handleSticker(msg, form, callback, cb) {
167
- if (msg.sticker) form["sticker_id"] = msg.sticker;
168
- cb();
169
- }
170
-
171
- function handleEmoji(msg, form, callback, cb) {
172
- if (msg.emojiSize != null && msg.emoji == null) return callback({ error: "emoji property is empty" });
173
- if (msg.emoji) {
174
- if (msg.emojiSize == null) msg.emojiSize = "medium";
175
- if (msg.emojiSize != "small" && msg.emojiSize != "medium" && msg.emojiSize != "large") return callback({ error: "emojiSize property is invalid" });
176
- if (form["body"] != null && form["body"] != "") return callback({ error: "body is not empty" });
177
- form["body"] = msg.emoji;
178
- form["tags[0]"] = "hot_emoji_size:" + msg.emojiSize;
179
- }
180
- cb();
181
- }
182
-
183
- function handleAttachment(msg, form, callback, cb) {
184
- if (msg.attachment) {
185
- form["image_ids"] = [];
186
- form["gif_ids"] = [];
187
- form["file_ids"] = [];
188
- form["video_ids"] = [];
189
- form["audio_ids"] = [];
190
-
191
- if (utils.getType(msg.attachment) !== "Array") msg.attachment = [msg.attachment];
192
-
193
- uploadAttachment(msg.attachment, function(err, files) {
194
- if (err) return callback(err);
195
- files.forEach(function(file) {
196
- var key = Object.keys(file);
197
- var type = key[0]; // image_id, file_id, etc
198
- form["" + type + "s"].push(file[type]); // push the id
199
- });
200
- cb();
201
- });
202
- } else cb();
203
- }
204
-
205
- function handleMention(msg, form, callback, cb) {
206
- if (msg.mentions) {
207
- for (let i = 0; i < msg.mentions.length; i++) {
208
- const mention = msg.mentions[i];
209
- const tag = mention.tag;
210
- if (typeof tag !== "string") return callback({ error: "Mention tags must be strings." });
211
- const offset = msg.body.indexOf(tag, mention.fromIndex || 0);
212
- if (offset < 0) log.warn("handleMention", 'Mention for "' + tag + '" not found in message string.');
213
- if (mention.id == null) log.warn("handleMention", "Mention id should be non-null.");
214
-
215
- const id = mention.id || 0;
216
- const emptyChar = '\u200E';
217
- form["body"] = emptyChar + msg.body;
218
- form["profile_xmd[" + i + "][offset]"] = offset + 1;
219
- form["profile_xmd[" + i + "][length]"] = tag.length;
220
- form["profile_xmd[" + i + "][id]"] = id;
221
- form["profile_xmd[" + i + "][type]"] = "p";
222
- }
223
- }
224
- cb();
225
- }
226
-
227
- return function sendMessage(msg, threadID, callback, replyToMessage, isGroup) {
228
- typeof isGroup == "undefined" ? isGroup = null : "";
229
- if (!callback && (utils.getType(threadID) === "Function" || utils.getType(threadID) === "AsyncFunction")) return threadID({ error: "Pass a threadID as a second argument." });
230
- if (!replyToMessage && utils.getType(callback) === "String") {
231
- replyToMessage = callback;
232
- callback = function() {};
233
- }
234
-
235
- var resolveFunc = function() {};
236
- var rejectFunc = function() {};
237
- var returnPromise = new Promise(function(resolve, reject) {
238
- resolveFunc = resolve;
239
- rejectFunc = reject;
240
- });
241
-
242
- if (!callback) {
243
- callback = function(err, data) {
244
- if (err) return rejectFunc(err);
245
- resolveFunc(data);
246
- };
247
- }
248
-
249
- var msgType = utils.getType(msg);
250
- var threadIDType = utils.getType(threadID);
251
- var messageIDType = utils.getType(replyToMessage);
252
-
253
- if (msgType !== "String" && msgType !== "Object") return callback({ error: "Message should be of type string or object and not " + msgType + "." });
254
-
255
- // Changing this to accomodate an array of users
256
- if (threadIDType !== "Array" && threadIDType !== "Number" && threadIDType !== "String") return callback({ error: "ThreadID should be of type number, string, or array and not " + threadIDType + "." });
257
-
258
- if (replyToMessage && messageIDType !== 'String') return callback({ error: "MessageID should be of type string and not " + threadIDType + "." });
259
-
260
- if (msgType === "String") msg = { body: msg };
261
- var disallowedProperties = Object.keys(msg).filter(prop => !allowedProperties[prop]);
262
- if (disallowedProperties.length > 0) return callback({ error: "Dissallowed props: `" + disallowedProperties.join(", ") + "`" });
263
-
264
- var messageAndOTID = utils.generateOfflineThreadingID();
265
-
266
- var form = {
267
- client: "mercury",
268
- action_type: "ma-type:user-generated-message",
269
- author: "fbid:" + ctx.userID,
270
- timestamp: Date.now(),
271
- timestamp_absolute: "Today",
272
- timestamp_relative: utils.generateTimestampRelative(),
273
- timestamp_time_passed: "0",
274
- is_unread: false,
275
- is_cleared: false,
276
- is_forward: false,
277
- is_filtered_content: false,
278
- is_filtered_content_bh: false,
279
- is_filtered_content_account: false,
280
- is_filtered_content_quasar: false,
281
- is_filtered_content_invalid_app: false,
282
- is_spoof_warning: false,
283
- source: "source:chat:web",
284
- "source_tags[0]": "source:chat",
285
- body: msg.body ? msg.body.toString() : "",
286
- html_body: false,
287
- ui_push_phase: "V3",
288
- status: "0",
289
- offline_threading_id: messageAndOTID,
290
- message_id: messageAndOTID,
291
- threading_id: utils.generateThreadingID(ctx.clientID),
292
- "ephemeral_ttl_mode:": "0",
293
- manual_retry_cnt: "0",
294
- has_attachment: !!(msg.attachment || msg.url || msg.sticker),
295
- signatureID: utils.getSignatureID(),
296
- replied_to_message_id: replyToMessage
297
- };
298
-
299
- handleLocation(msg, form, callback, () =>
300
- handleSticker(msg, form, callback, () =>
301
- handleAttachment(msg, form, callback, () =>
302
- handleUrl(msg, form, callback, () =>
303
- handleEmoji(msg, form, callback, () =>
304
- handleMention(msg, form, callback, () =>
305
- send(form, threadID, messageAndOTID, callback, isGroup)
306
- )
307
- )
308
- )
309
- )
310
- )
311
- );
312
-
313
- return returnPromise;
314
- };
315
- };
File without changes
File without changes
File without changes