meta-horizonn 1.1.4 → 1.1.5

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.
@@ -0,0 +1,2192 @@
1
+ // /* eslint-disable no-redeclare */
2
+ // "use strict";
3
+ // const utils = require("../utils");
4
+ // const log = require("npmlog");
5
+ // const mqtt = require('mqtt');
6
+ // const Websocket = require('ws');
7
+ // const HttpsProxyAgent = require('https-proxy-agent');
8
+ // const EventEmitter = require('events');
9
+ // const Duplexify = require('duplexify');
10
+ // const Transform = require('readable-stream').Transform;
11
+ // var identity = function () { };
12
+ // var form = {};
13
+ // var getSeqID = function () { };
14
+
15
+
16
+ // var topics = ["/ls_req","/ls_resp","/legacy_web","/webrtc","/rtc_multi","/onevc","/br_sr","/sr_res","/t_ms","/thread_typing","/orca_typing_notifications","/notify_disconnect","/orca_presence","/inbox","/mercury", "/messaging_events", "/orca_message_notifications", "/pp","/webrtc_response"];
17
+
18
+ // /* [ Noti ? ]
19
+ // ! "/br_sr", //Notification
20
+ // * => Need to publish /br_sr right after this
21
+
22
+ // ! "/notify_disconnect",
23
+ // * => Need to publish /messenger_sync_create_queue right after this
24
+
25
+ // ! "/orca_presence",
26
+ // * => Will receive /sr_res right here.
27
+ // */
28
+
29
+ // var WebSocket_Global;
30
+
31
+ // function buildProxy() {
32
+ // var Proxy = new Transform({
33
+ // objectMode: false
34
+ // });
35
+
36
+ // Proxy._write = function socketWriteNode(chunk, enc, next) {
37
+ // if (WebSocket_Global.readyState !== WebSocket_Global.OPEN) {
38
+ // return next();
39
+ // }
40
+
41
+ // if (typeof chunk === 'string') {
42
+ // chunk = new Buffer.from(chunk, 'utf8');
43
+ // }
44
+ // WebSocket_Global.send(chunk, next);
45
+ // };
46
+
47
+ // Proxy._flush = function(done) {
48
+ // WebSocket_Global.close();
49
+ // done();
50
+ // };
51
+
52
+ // Proxy._writev = function(chunks, cb) {
53
+ // var buffers = new Array(chunks.length);
54
+ // for (var i = 0; i < chunks.length; i++) {
55
+ // if (typeof chunks[i].chunk === 'string') {
56
+ // buffers[i] = new Buffer.from(chunks[i], 'utf8');
57
+ // } else {
58
+ // buffers[i] = chunks[i].chunk;
59
+ // }
60
+ // }
61
+ // this._write(new Buffer.concat(buffers), 'binary', cb);
62
+ // };
63
+
64
+ // return Proxy;
65
+ // }
66
+
67
+ // function buildStream(options, WebSocket, Proxy) {
68
+ // const Stream = Duplexify(undefined, undefined, options);
69
+ // Stream.socket = WebSocket;
70
+
71
+ // WebSocket
72
+ // .onclose = function() {
73
+ // Stream.end();
74
+ // Stream.destroy();
75
+ // };
76
+ // WebSocket
77
+ // .onerror = function(err) {
78
+ // Stream.destroy(err);
79
+ // };
80
+ // WebSocket
81
+ // .onmessage = function(event) {
82
+ // var data = event.data;
83
+ // if (data instanceof ArrayBuffer) data = new Buffer.from(data);
84
+ // else data = new Buffer.from(data, 'utf8');
85
+ // Stream.push(data);
86
+ // };
87
+ // WebSocket
88
+ // .onopen = function() {
89
+ // Stream.setReadable(Proxy);
90
+ // Stream.setWritable(Proxy);
91
+ // Stream.emit('connect');
92
+ // };
93
+ // WebSocket_Global = WebSocket;
94
+ // Proxy.on('close', function() { WebSocket.close(); });
95
+ // return Stream;
96
+ // }
97
+
98
+
99
+ // function listenMqtt(defaultFuncs, api, ctx, globalCallback) {
100
+ // //Don't really know what this does but I think it's for the act`ive state?
101
+ // //TODO: Move to ctx when implemented
102
+ // var chatOn = ctx.globalOptions.online;
103
+ // var foreground = false;
104
+
105
+ // var sessionID = Math.floor((Math.random() * Number.MAX_SAFE_INTEGER)+1);
106
+ // var username = {u: ctx.userID,s: sessionID,chat_on: chatOn,fg: foreground,d: utils.getGUID(),ct: "websocket",aid: "219994525426954", mqtt_sid: "",cp: 3,ecp: 10,st: [],pm: [],dc: "",no_auto_fg: true,gas: null,pack: []};
107
+ // var cookies = ctx.jar.getCookies('https://www.facebook.com').join("; ");
108
+
109
+ // var host;
110
+ // if (ctx.mqttEndpoint) host = `${ctx.mqttEndpoint}&sid=${sessionID}`;
111
+ // else if (ctx.region) host = `wss://edge-chat.facebook.com/chat?region=${ctx.region.toLocaleLowerCase()}&sid=${sessionID}`;
112
+ // else host = `wss://edge-chat.facebook.com/chat?sid=${sessionID}`;
113
+
114
+ // var options = {
115
+ // clientId: "mqttwsclient",
116
+ // protocolId: 'MQIsdp',
117
+ // protocolVersion: 3,
118
+ // username: JSON.stringify(username),
119
+ // clean: true,
120
+ // wsOptions: {
121
+ // headers: {
122
+ // 'Cookie': cookies,
123
+ // 'Origin': 'https://www.facebook.com',
124
+ // 'User-Agent': (ctx.globalOptions.userAgent || 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.4951.64 Safari/537.36'),
125
+ // 'Referer': 'https://www.facebook.com/',
126
+ // 'Host': new URL(host).hostname //'edge-chat.facebook.com'
127
+ // },
128
+ // origin: 'https://www.facebook.com',
129
+ // protocolVersion: 13,
130
+ // binaryType: 'arraybuffer',
131
+ // },
132
+ // keepalive: 60,
133
+ // reschedulePings: true,
134
+ // reconnectPeriod: 3
135
+ // };
136
+
137
+ // if (typeof ctx.globalOptions.proxy != "undefined") {
138
+ // var agent = new HttpsProxyAgent(ctx.globalOptions.proxy);
139
+ // options.wsOptions.agent = agent;
140
+ // }
141
+ // ctx.mqttClient = new mqtt.Client(_ => buildStream(options, new Websocket(host, options.wsOptions), buildProxy()), options);
142
+ // global.mqttClient = ctx.mqttClient;
143
+
144
+ // global.mqttClient.on('error', function (err) {
145
+ // log.error("listenMqtt", err);
146
+ // global.mqttClient.end();
147
+
148
+ // if (ctx.globalOptions.autoReconnect) getSeqID();
149
+ // else {
150
+ // globalCallback({ type: "stop_listen", error: "Server Đã Sập - Auto Restart" }, null);
151
+ // return process.exit(1);
152
+ // }
153
+ // });
154
+
155
+ // global.mqttClient.on('connect', function () {
156
+ // if (!global.Fca.Data.Setup || global.Fca.Data.Setup == undefined) {
157
+ // if (global.Fca.Require.FastConfig.RestartMQTT_Minutes != 0 && global.Fca.Data.StopListening != true) {
158
+ // global.Fca.Data.Setup = true;
159
+ // setTimeout(() => {
160
+ // global.Fca.Require.logger.Warning("Closing MQTT Client...");
161
+ // ctx.mqttClient.end();
162
+ // global.Fca.Require.logger.Warning("Reconnecting MQTT Client...");
163
+ // global.Fca.Data.Setup = false;
164
+ // getSeqID();
165
+ // }, Number(global.Fca.Require.FastConfig.RestartMQTT_Minutes) * 60 * 1000);
166
+ // }
167
+ // }
168
+ // if (process.env.OnStatus == undefined) {
169
+ // global.Fca.Require.logger.Normal("Bạn Đang Sài Phiên Bản: Premium Access");
170
+ // if (Number(global.Fca.Require.FastConfig.AutoRestartMinutes) == 0) {
171
+ // // something
172
+ // }
173
+ // else if (Number(global.Fca.Require.FastConfig.AutoRestartMinutes < 10)) {
174
+ // log.warn("AutoRestartMinutes","The number of minutes to automatically restart must be more than 10 minutes");
175
+ // }
176
+ // else if (Number(global.Fca.Require.FastConfig.AutoRestartMinutes) < 0) {
177
+ // log.warn("AutoRestartMinutes","Invalid auto-restart minutes!");
178
+ // }
179
+ // else {
180
+ // global.Fca.Require.logger.Normal(global.Fca.getText(global.Fca.Require.Language.Src.AutoRestart,global.Fca.Require.FastConfig.AutoRestartMinutes));
181
+ // global.Fca.Require.logger.Normal("Auto Restart MQTT Client After: " + global.Fca.Require.FastConfig.RestartMQTT_Minutes + " Minutes");
182
+ // setInterval(() => {
183
+ // global.Fca.Require.logger.Normal(global.Fca.Require.Language.Src.OnRestart);
184
+ // process.exit(1);
185
+ // }, Number(global.Fca.Require.FastConfig.AutoRestartMinutes) * 60000);
186
+ // }
187
+ // require('../broadcast');
188
+ // process.env.OnStatus = true;
189
+ // }
190
+
191
+ // topics.forEach(topicsub => global.mqttClient.subscribe(topicsub));
192
+
193
+ // var topic;
194
+ // var queue = {
195
+ // sync_api_version: 11,
196
+ // max_deltas_able_to_process: 100,
197
+ // delta_batch_size: 500,
198
+ // encoding: "JSON",
199
+ // entity_fbid: ctx.userID,
200
+ // };
201
+
202
+ // topic = "/messenger_sync_create_queue";
203
+ // queue.initial_titan_sequence_id = ctx.lastSeqId;
204
+ // queue.device_params = null;
205
+
206
+ // global.mqttClient.publish(topic, JSON.stringify(queue), { qos: 1, retain: false });
207
+
208
+ // var rTimeout = setTimeout(function () {
209
+ // global.mqttClient.end();
210
+ // getSeqID();
211
+ // }, 3000);
212
+
213
+ // ctx.tmsWait = function () {
214
+ // clearTimeout(rTimeout);
215
+ // ctx.globalOptions.emitReady ? globalCallback({type: "ready",error: null}) : '';
216
+ // delete ctx.tmsWait;
217
+ // };
218
+ // });
219
+
220
+ // global.mqttClient.on('message', function (topic, message, _packet) {
221
+ // const jsonMessage = JSON.parse(message.toString());
222
+
223
+ // if (topic === "/t_ms") {
224
+ // if (ctx.tmsWait && typeof ctx.tmsWait == "function") ctx.tmsWait();
225
+
226
+ // if (jsonMessage.firstDeltaSeqId && jsonMessage.syncToken) {
227
+ // ctx.lastSeqId = jsonMessage.firstDeltaSeqId;
228
+ // ctx.syncToken = jsonMessage.syncToken;
229
+ // }
230
+
231
+ // if (jsonMessage.lastIssuedSeqId) ctx.lastSeqId = parseInt(jsonMessage.lastIssuedSeqId);
232
+ // //If it contains more than 1 delta
233
+ // for (var i in jsonMessage.deltas) {
234
+ // var delta = jsonMessage.deltas[i];
235
+ // parseDelta(defaultFuncs, api, ctx, globalCallback, { "delta": delta });
236
+ // }
237
+ // } else if (topic === "/thread_typing" || topic === "/orca_typing_notifications") {
238
+ // var typ = {
239
+ // type: "typ",
240
+ // isTyping: !!jsonMessage.state,
241
+ // from: jsonMessage.sender_fbid.toString(),
242
+ // threadID: utils.formatID((jsonMessage.thread || jsonMessage.sender_fbid).toString())
243
+ // };
244
+ // (function () { globalCallback(null, typ); })();
245
+ // } else if (topic === "/orca_presence") {
246
+ // if (!ctx.globalOptions.updatePresence) {
247
+ // for (var i in jsonMessage.list) {
248
+ // var data = jsonMessage.list[i];
249
+ // var userID = data["u"];
250
+
251
+ // var presence = {
252
+ // type: "presence",
253
+ // userID: userID.toString(),
254
+ // //Convert to ms
255
+ // timestamp: data["l"] * 1000,
256
+ // statuses: data["p"]
257
+ // };
258
+ // (function () { globalCallback(null, presence); })();
259
+ // }
260
+ // }
261
+ // }
262
+
263
+ // });
264
+
265
+ // process.on('SIGINT', function () {
266
+ // LogUptime();process.kill(process.pid);
267
+ // });
268
+
269
+ // process.on('exit', () => {
270
+ // LogUptime();
271
+ // });
272
+
273
+ // }
274
+
275
+ // function LogUptime() {
276
+ // var uptime = process.uptime();
277
+ // var { join } = require('path');
278
+ // if (global.Fca.Require.fs.existsSync(join(__dirname, '../CountTime.json'))) {
279
+ // var Time1 = (Number(global.Fca.Require.fs.readFileSync(join(__dirname, '../CountTime.json'), 'utf8')) || 0);
280
+ // global.Fca.Require.fs.writeFileSync(join(__dirname, '../CountTime.json'), String(Number(uptime) + Time1), 'utf8');
281
+ // }
282
+ // else {
283
+ // var Time1 = 0;
284
+ // global.Fca.Require.fs.writeFileSync(join(__dirname, '../CountTime.json'), String(Number(uptime) + Time1), 'utf8');
285
+ // }
286
+ // }
287
+ // function parseDelta(defaultFuncs, api, ctx, globalCallback, v) {
288
+ // if (v.delta.class == "NewMessage") {
289
+ // //Not tested for pages
290
+ // if (ctx.globalOptions.pageID && ctx.globalOptions.pageID != v.queue) return;
291
+
292
+ // (function resolveAttachmentUrl(i) {
293
+ // if (v.delta.attachments && (i == v.delta.attachments.length) || utils.getType(v.delta.attachments) !== "Array") {
294
+ // var fmtMsg;
295
+ // try {
296
+ // fmtMsg = utils.formatDeltaMessage(v);
297
+ // } catch (err) {
298
+ // return log.error("Lỗi Nhẹ", err);
299
+ // }
300
+ // global.Fca.Data.event = fmtMsg;
301
+ // try {
302
+ // var { updateMessageCount,getData,hasData } = require('../Extra/ExtraGetThread');
303
+ // if (hasData(fmtMsg.threadID)) {
304
+ // var x = getData(fmtMsg.threadID);
305
+ // x.messageCount+=1;
306
+ // updateMessageCount(fmtMsg.threadID,x);
307
+ // }
308
+ // }
309
+ // catch (e) {
310
+ // //temp
311
+ // }
312
+ // if (fmtMsg)
313
+ // if (ctx.globalOptions.autoMarkDelivery) markDelivery(ctx, api, fmtMsg.threadID, fmtMsg.messageID);
314
+
315
+ // return !ctx.globalOptions.selfListen && fmtMsg.senderID === ctx.userID ? undefined : (function () { globalCallback(null, fmtMsg); })();
316
+ // } else {
317
+ // if (v.delta.attachments && (v.delta.attachments[i].mercury.attach_type == "photo")) {
318
+ // api.resolvePhotoUrl(v.delta.attachments[i].fbid, (err, url) => {
319
+ // if (!err) v.delta.attachments[i].mercury.metadata.url = url;
320
+ // return resolveAttachmentUrl(i + 1);
321
+ // });
322
+ // } else return resolveAttachmentUrl(i + 1);
323
+ // }
324
+ // })(0);
325
+ // }
326
+
327
+ // if (v.delta.class == "ClientPayload") {
328
+ // var clientPayload = utils.decodeClientPayload(v.delta.payload);
329
+ // if (clientPayload && clientPayload.deltas) {
330
+ // for (var i in clientPayload.deltas) {
331
+ // var delta = clientPayload.deltas[i];
332
+ // if (delta.deltaMessageReaction && !!ctx.globalOptions.listenEvents) {
333
+ // (function () {
334
+ // globalCallback(null, {
335
+ // type: "message_reaction",
336
+ // threadID: (delta.deltaMessageReaction.threadKey.threadFbId ? delta.deltaMessageReaction.threadKey.threadFbId : delta.deltaMessageReaction.threadKey.otherUserFbId).toString(),
337
+ // messageID: delta.deltaMessageReaction.messageId,
338
+ // reaction: delta.deltaMessageReaction.reaction,
339
+ // senderID: delta.deltaMessageReaction.senderId.toString(),
340
+ // userID: delta.deltaMessageReaction.userId.toString()
341
+ // });
342
+ // })();
343
+ // } else if (delta.deltaRecallMessageData && !!ctx.globalOptions.listenEvents) {
344
+ // (function () {
345
+ // globalCallback(null, {
346
+ // type: "message_unsend",
347
+ // threadID: (delta.deltaRecallMessageData.threadKey.threadFbId ? delta.deltaRecallMessageData.threadKey.threadFbId : delta.deltaRecallMessageData.threadKey.otherUserFbId).toString(),
348
+ // messageID: delta.deltaRecallMessageData.messageID,
349
+ // senderID: delta.deltaRecallMessageData.senderID.toString(),
350
+ // deletionTimestamp: delta.deltaRecallMessageData.deletionTimestamp,
351
+ // timestamp: delta.deltaRecallMessageData.timestamp
352
+ // });
353
+ // })();
354
+ // } else if (delta.deltaMessageReply) {
355
+ // //Mention block - #1
356
+ // var mdata =
357
+ // delta.deltaMessageReply.message === undefined ? [] :
358
+ // delta.deltaMessageReply.message.data === undefined ? [] :
359
+ // delta.deltaMessageReply.message.data.prng === undefined ? [] :
360
+ // JSON.parse(delta.deltaMessageReply.message.data.prng);
361
+ // var m_id = mdata.map(u => u.i);
362
+ // var m_offset = mdata.map(u => u.o);
363
+ // var m_length = mdata.map(u => u.l);
364
+
365
+ // var mentions = {};
366
+
367
+ // for (var i = 0; i < m_id.length; i++) mentions[m_id[i]] = (delta.deltaMessageReply.message.body || "").substring(m_offset[i], m_offset[i] + m_length[i]);
368
+ // //Mention block - 1#
369
+ // var callbackToReturn = {
370
+ // type: "message_reply",
371
+ // threadID: (delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId ? delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId : delta.deltaMessageReply.message.messageMetadata.threadKey.otherUserFbId).toString(),
372
+ // messageID: delta.deltaMessageReply.message.messageMetadata.messageId,
373
+ // senderID: delta.deltaMessageReply.message.messageMetadata.actorFbId.toString(),
374
+ // attachments: delta.deltaMessageReply.message.attachments.map(function (att) {
375
+ // var mercury = JSON.parse(att.mercuryJSON);
376
+ // Object.assign(att, mercury);
377
+ // return att;
378
+ // }).map(att => {
379
+ // var x;
380
+ // try {
381
+ // x = utils._formatAttachment(att);
382
+ // } catch (ex) {
383
+ // x = att;
384
+ // x.error = ex;
385
+ // x.type = "unknown";
386
+ // }
387
+ // return x;
388
+ // }),
389
+ // args: (delta.deltaMessageReply.message.body || "").trim().split(/\s+/),
390
+ // body: (delta.deltaMessageReply.message.body || ""),
391
+ // isGroup: !!delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId,
392
+ // mentions: mentions,
393
+ // timestamp: delta.deltaMessageReply.message.messageMetadata.timestamp,
394
+ // participantIDs: (delta.deltaMessageReply.message.participants || []).map(e => e.toString())
395
+ // };
396
+
397
+ // if (delta.deltaMessageReply.repliedToMessage) {
398
+ // //Mention block - #2
399
+ // mdata =
400
+ // delta.deltaMessageReply.repliedToMessage === undefined ? [] :
401
+ // delta.deltaMessageReply.repliedToMessage.data === undefined ? [] :
402
+ // delta.deltaMessageReply.repliedToMessage.data.prng === undefined ? [] :
403
+ // JSON.parse(delta.deltaMessageReply.repliedToMessage.data.prng);
404
+ // m_id = mdata.map(u => u.i);
405
+ // m_offset = mdata.map(u => u.o);
406
+ // m_length = mdata.map(u => u.l);
407
+
408
+ // var rmentions = {};
409
+
410
+ // for (var i = 0; i < m_id.length; i++) rmentions[m_id[i]] = (delta.deltaMessageReply.repliedToMessage.body || "").substring(m_offset[i], m_offset[i] + m_length[i]);
411
+ // //Mention block - 2#
412
+ // callbackToReturn.messageReply = {
413
+ // threadID: (delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId ? delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId : delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.otherUserFbId).toString(),
414
+ // messageID: delta.deltaMessageReply.repliedToMessage.messageMetadata.messageId,
415
+ // senderID: delta.deltaMessageReply.repliedToMessage.messageMetadata.actorFbId.toString(),
416
+ // attachments: delta.deltaMessageReply.repliedToMessage.attachments.map(function (att) {
417
+ // var mercury = JSON.parse(att.mercuryJSON);
418
+ // Object.assign(att, mercury);
419
+ // return att;
420
+ // }).map(att => {
421
+ // var x;
422
+ // try {
423
+ // x = utils._formatAttachment(att);
424
+ // } catch (ex) {
425
+ // x = att;
426
+ // x.error = ex;
427
+ // x.type = "unknown";
428
+ // }
429
+ // return x;
430
+ // }),
431
+ // args: (delta.deltaMessageReply.repliedToMessage.body || "").trim().split(/\s+/),
432
+ // body: delta.deltaMessageReply.repliedToMessage.body || "",
433
+ // isGroup: !!delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId,
434
+ // mentions: rmentions,
435
+ // timestamp: delta.deltaMessageReply.repliedToMessage.messageMetadata.timestamp,
436
+ // participantIDs: (delta.deltaMessageReply.repliedToMessage.participants || []).map(e => e.toString())
437
+ // };
438
+ // } else if (delta.deltaMessageReply.replyToMessageId) {
439
+ // return defaultFuncs
440
+ // .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, {
441
+ // "av": ctx.globalOptions.pageID,
442
+ // "queries": JSON.stringify({
443
+ // "o0": {
444
+ // //Using the same doc_id as forcedFetch
445
+ // "doc_id": "2848441488556444",
446
+ // "query_params": {
447
+ // "thread_and_message_id": {
448
+ // "thread_id": callbackToReturn.threadID,
449
+ // "message_id": delta.deltaMessageReply.replyToMessageId.id,
450
+ // }
451
+ // }
452
+ // }
453
+ // })
454
+ // })
455
+ // .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
456
+ // .then((resData) => {
457
+ // if (resData[resData.length - 1].error_results > 0) throw resData[0].o0.errors;
458
+ // if (resData[resData.length - 1].successful_results === 0) throw { error: "forcedFetch: there was no successful_results", res: resData };
459
+ // var fetchData = resData[0].o0.data.message;
460
+ // var mobj = {};
461
+ // for (var n in fetchData.message.ranges) mobj[fetchData.message.ranges[n].entity.id] = (fetchData.message.text || "").substr(fetchData.message.ranges[n].offset, fetchData.message.ranges[n].length);
462
+
463
+ // callbackToReturn.messageReply = {
464
+ // type: "Message",
465
+ // threadID: callbackToReturn.threadID,
466
+ // messageID: fetchData.message_id,
467
+ // senderID: fetchData.message_sender.id.toString(),
468
+ // attachments: fetchData.message.blob_attachment.map(att => {
469
+ // var x;
470
+ // try {
471
+ // x = utils._formatAttachment({ blob_attachment: att });
472
+ // } catch (ex) {
473
+ // x = att;
474
+ // x.error = ex;
475
+ // x.type = "unknown";
476
+ // }
477
+ // return x;
478
+ // }),
479
+ // args: (fetchData.message.text || "").trim().split(/\s+/) || [],
480
+ // body: fetchData.message.text || "",
481
+ // isGroup: callbackToReturn.isGroup,
482
+ // mentions: mobj,
483
+ // timestamp: parseInt(fetchData.timestamp_precise)
484
+ // };
485
+ // })
486
+ // .catch(err => log.error("forcedFetch", err))
487
+ // .finally(function () {
488
+ // if (ctx.globalOptions.autoMarkDelivery) markDelivery(ctx, api, callbackToReturn.threadID, callbackToReturn.messageID);
489
+ // !ctx.globalOptions.selfListen && callbackToReturn.senderID === ctx.userID ? undefined : (function () { globalCallback(null, callbackToReturn); })();
490
+ // });
491
+ // } else callbackToReturn.delta = delta;
492
+
493
+ // if (ctx.globalOptions.autoMarkDelivery) markDelivery(ctx, api, callbackToReturn.threadID, callbackToReturn.messageID);
494
+
495
+ // return !ctx.globalOptions.selfListen && callbackToReturn.senderID === ctx.userID ? undefined : (function () { globalCallback(null, callbackToReturn); })();
496
+ // }
497
+ // }
498
+ // return;
499
+ // }
500
+ // }
501
+ // switch (v.delta.class) {
502
+ // case "ReadReceipt": {
503
+ // var fmtMsg;
504
+ // try {
505
+ // fmtMsg = utils.formatDeltaReadReceipt(v.delta);
506
+ // } catch (err) {
507
+ // return log.error("Lỗi Nhẹ", err);
508
+ // }
509
+ // return (function () { globalCallback(null, fmtMsg); })();
510
+ // }
511
+ // case "AdminTextMessage": {
512
+ // switch (v.delta.type) {
513
+ // case "joinable_group_link_mode_change":
514
+ // case "magic_words":
515
+ // case "pin_messages_v2":
516
+ // case "change_thread_theme":
517
+ // case "change_thread_icon":
518
+ // case "change_thread_nickname":
519
+ // case "change_thread_admins":
520
+ // case "change_thread_approval_mode":
521
+ // case "group_poll":
522
+ // case "messenger_call_log":
523
+ // case "participant_joined_group_call":
524
+ // var fmtMsg;
525
+ // try {
526
+ // fmtMsg = utils.formatDeltaEvent(v.delta);
527
+ // } catch (err) {
528
+ // console.log(v.delta)
529
+ // return log.error("Lỗi Nhẹ", err);
530
+ // }
531
+ // return (function () { globalCallback(null, fmtMsg); })();
532
+ // }
533
+ // break;
534
+ // }
535
+ // //For group images
536
+ // case "ForcedFetch": {
537
+ // if (!v.delta.threadKey) return;
538
+ // var mid = v.delta.messageId;
539
+ // var tid = v.delta.threadKey.threadFbId;
540
+ // if (mid && tid) {
541
+ // const form = {
542
+ // "av": ctx.globalOptions.pageID,
543
+ // "queries": JSON.stringify({
544
+ // "o0": {
545
+ // //This doc_id is valid as of March 25, 2020
546
+ // "doc_id": "2848441488556444",
547
+ // "query_params": {
548
+ // "thread_and_message_id": {
549
+ // "thread_id": tid.toString(),
550
+ // "message_id": mid,
551
+ // }
552
+ // }
553
+ // }
554
+ // })
555
+ // };
556
+
557
+ // defaultFuncs
558
+ // .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
559
+ // .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
560
+ // .then((resData) => {
561
+ // if (resData[resData.length - 1].error_results > 0) throw resData[0].o0.errors;
562
+
563
+ // if (resData[resData.length - 1].successful_results === 0) throw { error: "forcedFetch: there was no successful_results", res: resData };
564
+
565
+ // var fetchData = resData[0].o0.data.message;
566
+
567
+ // if (utils.getType(fetchData) == "Object") {
568
+ // log.info("forcedFetch", fetchData);
569
+ // switch (fetchData.__typename) {
570
+ // case "ThreadImageMessage":
571
+ // (!ctx.globalOptions.selfListen &&
572
+ // fetchData.message_sender.id.toString() === ctx.userID) ||
573
+ // !ctx.loggedIn ?
574
+ // undefined :
575
+ // (function () {
576
+ // globalCallback(null, {
577
+ // type: "change_thread_image",
578
+ // threadID: utils.formatID(tid.toString()),
579
+ // snippet: fetchData.snippet,
580
+ // timestamp: fetchData.timestamp_precise,
581
+ // author: fetchData.message_sender.id,
582
+ // image: {
583
+ // attachmentID: fetchData.image_with_metadata && fetchData.image_with_metadata.legacy_attachment_id,
584
+ // width: fetchData.image_with_metadata && fetchData.image_with_metadata.original_dimensions.x,
585
+ // height: fetchData.image_with_metadata && fetchData.image_with_metadata.original_dimensions.y,
586
+ // url: fetchData.image_with_metadata && fetchData.image_with_metadata.preview.uri
587
+ // }
588
+ // });
589
+ // })();
590
+ // break;
591
+ // case "UserMessage":
592
+ // log.info("ff-Return", {
593
+ // type: "message",
594
+ // senderID: utils.formatID(fetchData.message_sender.id),
595
+ // body: fetchData.message.text || "",
596
+ // threadID: utils.formatID(tid.toString()),
597
+ // messageID: fetchData.message_id,
598
+ // attachments: [{
599
+ // type: "share",
600
+ // ID: fetchData.extensible_attachment.legacy_attachment_id,
601
+ // url: fetchData.extensible_attachment.story_attachment.url,
602
+
603
+ // title: fetchData.extensible_attachment.story_attachment.title_with_entities.text,
604
+ // description: fetchData.extensible_attachment.story_attachment.description.text,
605
+ // source: fetchData.extensible_attachment.story_attachment.source,
606
+
607
+ // image: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).uri,
608
+ // width: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).width,
609
+ // height: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).height,
610
+ // playable: (fetchData.extensible_attachment.story_attachment.media || {}).is_playable || false,
611
+ // duration: (fetchData.extensible_attachment.story_attachment.media || {}).playable_duration_in_ms || 0,
612
+
613
+ // subattachments: fetchData.extensible_attachment.subattachments,
614
+ // properties: fetchData.extensible_attachment.story_attachment.properties,
615
+ // }],
616
+ // mentions: {},
617
+ // timestamp: parseInt(fetchData.timestamp_precise),
618
+ // isGroup: (fetchData.message_sender.id != tid.toString())
619
+ // });
620
+ // globalCallback(null, {
621
+ // type: "message",
622
+ // senderID: utils.formatID(fetchData.message_sender.id),
623
+ // body: fetchData.message.text || "",
624
+ // threadID: utils.formatID(tid.toString()),
625
+ // messageID: fetchData.message_id,
626
+ // attachments: [{
627
+ // type: "share",
628
+ // ID: fetchData.extensible_attachment.legacy_attachment_id,
629
+ // url: fetchData.extensible_attachment.story_attachment.url,
630
+
631
+ // title: fetchData.extensible_attachment.story_attachment.title_with_entities.text,
632
+ // description: fetchData.extensible_attachment.story_attachment.description.text,
633
+ // source: fetchData.extensible_attachment.story_attachment.source,
634
+
635
+ // image: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).uri,
636
+ // width: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).width,
637
+ // height: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).height,
638
+ // playable: (fetchData.extensible_attachment.story_attachment.media || {}).is_playable || false,
639
+ // duration: (fetchData.extensible_attachment.story_attachment.media || {}).playable_duration_in_ms || 0,
640
+
641
+ // subattachments: fetchData.extensible_attachment.subattachments,
642
+ // properties: fetchData.extensible_attachment.story_attachment.properties,
643
+ // }],
644
+ // mentions: {},
645
+ // timestamp: parseInt(fetchData.timestamp_precise),
646
+ // isGroup: (fetchData.message_sender.id != tid.toString())
647
+ // });
648
+ // }
649
+ // } else log.error("forcedFetch", fetchData);
650
+ // })
651
+ // .catch((err) => log.error("forcedFetch", err));
652
+ // }
653
+ // }
654
+ // break;
655
+ // case "ThreadName":
656
+ // case "ParticipantsAddedToGroupThread":
657
+ // case "ParticipantLeftGroupThread": {
658
+ // var formattedEvent;
659
+ // try {
660
+ // formattedEvent = utils.formatDeltaEvent(v.delta);
661
+ // } catch (err) {
662
+ // console.log(err)
663
+ // return log.error("Lỗi Nhẹ", err);
664
+ // }
665
+ // return (!ctx.globalOptions.selfListen && formattedEvent.author.toString() === ctx.userID) || !ctx.loggedIn ? undefined : (function () { globalCallback(null, formattedEvent); })();
666
+ // }
667
+ // case "NewMessage": {
668
+ // if (v.delta.attachments != undefined && v.delta.attachments.length == 1 && v.delta.attachments[0].mercury.extensible_attachment != undefined && v.delta.attachments[0].mercury.extensible_attachment.story_attachment.style_list.includes("message_live_location")) {
669
+ // v.delta.class = "UserLocation";
670
+ // var fmtMsg;
671
+ // try {
672
+ // fmtMsg = utils.formatDeltaEvent(v.delta);
673
+ // } catch (err) {
674
+ // console.log(v.delta);
675
+ // return log.error("Lỗi Nhẹ", err);
676
+ // }
677
+ // return (function () { globalCallback(null, fmtMsg); })();
678
+ // }
679
+ // }
680
+ // break;
681
+ // }
682
+ // }
683
+
684
+
685
+ // function markDelivery(ctx, api, threadID, messageID) {
686
+ // if (threadID && messageID) {
687
+ // api.markAsDelivered(threadID, messageID, (err) => {
688
+ // if (err) log.error("markAsDelivered", err);
689
+ // else {
690
+ // if (ctx.globalOptions.autoMarkRead) {
691
+ // api.markAsRead(threadID, (err) => {
692
+ // if (err) log.error("markAsDelivered", err);
693
+ // });
694
+ // }
695
+ // }
696
+ // });
697
+ // }
698
+ // }
699
+
700
+ // module.exports = function (defaultFuncs, api, ctx) {
701
+ // var globalCallback = identity;
702
+ // getSeqID = function getSeqID() {
703
+ // ctx.t_mqttCalled = false;
704
+ // defaultFuncs
705
+ // .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
706
+ // .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
707
+ // .then((resData) => {
708
+ // if (utils.getType(resData) != "Array") {
709
+ // if (global.Fca.Require.FastConfig.AutoLogin) {
710
+ // return global.Fca.Require.logger.Warning(global.Fca.Require.Language.Index.AutoLogin, function() {
711
+ // return global.Fca.Action('AutoLogin');
712
+ // });
713
+ // }
714
+ // else if (!global.Fca.Require.FastConfig.AutoLogin) {
715
+ // return global.Fca.Require.logger.Error(global.Fca.Require.Language.Index.ErrAppState);
716
+ // }
717
+ // return;
718
+ // }
719
+ // else {
720
+ // if (resData && resData[resData.length - 1].error_results > 0) throw resData[0].o0.errors;
721
+ // if (resData[resData.length - 1].successful_results === 0) throw { error: "getSeqId: there was no successful_results", res: resData };
722
+ // if (resData[0].o0.data.viewer.message_threads.sync_sequence_id) {
723
+ // ctx.lastSeqId = resData[0].o0.data.viewer.message_threads.sync_sequence_id;
724
+ // listenMqtt(defaultFuncs, api, ctx, globalCallback);
725
+ // }
726
+ // else throw { error: "getSeqId: no sync_sequence_id found.", res: resData };
727
+ // }
728
+ // })
729
+ // .catch((err) => {
730
+ // log.error("getSeqId", err);
731
+ // if (utils.getType(err) == "Object" && err.error === global.Fca.Require.Language.Index.ErrAppState) ctx.loggedIn = false;
732
+ // return globalCallback(err);
733
+ // });
734
+ // };
735
+
736
+ // return function (callback) {
737
+ // class MessageEmitter extends EventEmitter {
738
+ // stopListening(callback) {
739
+ // callback = callback || (() => { });
740
+ // globalCallback = identity;
741
+ // if (ctx.mqttClient) {
742
+ // ctx.mqttClient.unsubscribe("/webrtc");
743
+ // ctx.mqttClient.unsubscribe("/rtc_multi");
744
+ // ctx.mqttClient.unsubscribe("/onevc");
745
+ // ctx.mqttClient.publish("/browser_close", "{}");
746
+ // ctx.mqttClient.end(false, function (...data) {
747
+ // ctx.mqttClient = undefined;
748
+ // });
749
+ // }
750
+ // global.Fca.Data.StopListening = true;
751
+ // }
752
+ // }
753
+
754
+ // var msgEmitter = new MessageEmitter();
755
+ // globalCallback = (callback || function (error, message) {
756
+ // if (error) return msgEmitter.emit("error", error);
757
+ // msgEmitter.emit("message", message);
758
+ // });
759
+
760
+ // //Reset some stuff
761
+ // if (!ctx.firstListen) ctx.lastSeqId = null;
762
+ // ctx.syncToken = undefined;
763
+ // ctx.t_mqttCalled = false;
764
+
765
+ // //Same request as getThreadList
766
+ // form = {
767
+ // "av": ctx.globalOptions.pageID,
768
+ // "queries": JSON.stringify({
769
+ // "o0": {
770
+ // "doc_id": "3336396659757871",
771
+ // "query_params": {
772
+ // "limit": 1,
773
+ // "before": null,
774
+ // "tags": ["INBOX"],
775
+ // "includeDeliveryReceipts": false,
776
+ // "includeSeqID": true
777
+ // }
778
+ // }
779
+ // })
780
+ // };
781
+
782
+ // if (!ctx.firstListen || !ctx.lastSeqId) getSeqID();
783
+ // else listenMqtt(defaultFuncs, api, ctx, globalCallback);
784
+ // ctx.firstListen = false;
785
+ // return msgEmitter;
786
+ // };
787
+ // };
788
+
789
+ // // "use strict";
790
+ // // var utils = require("../utils");
791
+ // // var log = require("npmlog");
792
+ // // var mqtt = require('mqtt');
793
+ // // var websocket = require('websocket-stream');
794
+
795
+ // // var identity = function () {};
796
+ // // var chatOn = true;
797
+ // // var foreground = false;
798
+
799
+ // // var topics = [
800
+ // // "/t_ms",
801
+ // // "/thread_typing",
802
+ // // "/orca_typing_notifications",
803
+ // // "/orca_presence",
804
+ // // "/legacy_web",
805
+ // // "/br_sr",
806
+ // // "/sr_res",
807
+ // // "/webrtc",
808
+ // // "/onevc",
809
+ // // "/notify_disconnect",
810
+ // // "/inbox",
811
+ // // "/mercury",
812
+ // // "/messaging_events",
813
+ // // "/orca_message_notifications",
814
+ // // "/pp",
815
+ // // "/webrtc_response",
816
+ // // ];
817
+
818
+ // // function listenMqtt(defaultFuncs, api, ctx, globalCallback) {
819
+ // // var sessionID = Math.floor(Math.random() * 9007199254740991) + 1;
820
+ // // var username = {
821
+ // // u: ctx.userID,
822
+ // // s: sessionID,
823
+ // // chat_on: chatOn,
824
+ // // fg: foreground,
825
+ // // d: utils.getGUID(),
826
+ // // ct: "websocket",
827
+ // // aid: "219994525426954",
828
+ // // mqtt_sid: "",
829
+ // // cp: 3,
830
+ // // ecp: 10,
831
+ // // st: topics,
832
+ // // pm: [],
833
+ // // dc: "",
834
+ // // no_auto_fg: true,
835
+ // // gas: null
836
+ // // };
837
+ // // var cookies = ctx.jar.getCookies("https://www.facebook.com").join("; ");
838
+ // // var host = 'wss://edge-chat.facebook.com/chat?sid=' + sessionID;
839
+
840
+ // // var options = {
841
+ // // clientId: "mqttwsclient",
842
+ // // protocolId: 'MQIsdp',
843
+ // // protocolVersion: 3,
844
+ // // username: JSON.stringify(username),
845
+ // // clean: true,
846
+ // // wsOptions: {
847
+ // // headers: {
848
+ // // 'Cookie': cookies,
849
+ // // 'Origin': 'https://www.facebook.com',
850
+ // // 'User-Agent': ctx.globalOptions.userAgent,
851
+ // // 'Referer': 'https://www.facebook.com',
852
+ // // 'Host': 'edge-chat.facebook.com'
853
+ // // },
854
+ // // origin: 'https://www.facebook.com',
855
+ // // protocolVersion: 13
856
+ // // }
857
+ // // };
858
+
859
+ // // ctx.mqttClient = new mqtt.Client(_ => websocket(host, options.wsOptions), options);
860
+
861
+ // // var mqttClient = ctx.mqttClient;
862
+
863
+ // // mqttClient.on('error', function(err) {
864
+ // // log.error(err);
865
+ // // mqttClient.end();
866
+ // // globalCallback("Connection refused: Server unavailable", null);
867
+ // // });
868
+
869
+ // // mqttClient.on('connect', function() {
870
+ // // var topic;
871
+ // // var queue = {
872
+ // // sync_api_version: 10,
873
+ // // max_deltas_able_to_process: 1000,
874
+ // // delta_batch_size: 500,
875
+ // // encoding: "JSON",
876
+ // // entity_fbid: ctx.userID,
877
+ // // };
878
+
879
+ // // if(ctx.globalOptions.pageID) {
880
+ // // queue.entity_fbid = ctx.globalOptions.pageID;
881
+ // // }
882
+
883
+ // // if(ctx.syncToken) {
884
+ // // topic = "/messenger_sync_get_diffs";
885
+ // // queue.last_seq_id = ctx.lastSeqId;
886
+ // // queue.sync_token = ctx.syncToken;
887
+ // // } else {
888
+ // // topic = "/messenger_sync_create_queue";
889
+ // // queue.initial_titan_sequence_id = ctx.lastSeqId;
890
+ // // queue.device_params = null;
891
+ // // }
892
+
893
+ // // mqttClient.publish(topic, JSON.stringify(queue), {qos: 1, retain: false});
894
+ // // });
895
+
896
+ // // mqttClient.on('message', function(topic, message, packet) {
897
+ // // var jsonMessage = JSON.parse(message);
898
+ // // if(topic === "/t_ms") {
899
+ // // if(jsonMessage.firstDeltaSeqId && jsonMessage.syncToken) {
900
+ // // ctx.lastSeqId = jsonMessage.firstDeltaSeqId;
901
+ // // ctx.syncToken = jsonMessage.syncToken;
902
+ // // }
903
+
904
+ // // if(jsonMessage.lastIssuedSeqId) {
905
+ // // ctx.lastSeqId = parseInt(jsonMessage.lastIssuedSeqId);
906
+ // // }
907
+
908
+ // // if(jsonMessage.queueEntityId && ctx.globalOptions.pageID &&
909
+ // // ctx.globalOptions.pageID != jsonMessage.queueEntityId) {
910
+ // // return;
911
+ // // }
912
+
913
+ // // //If it contains more than 1 delta
914
+ // // for (var i in jsonMessage.deltas) {
915
+ // // var delta = jsonMessage.deltas[i];
916
+ // // parseDelta(defaultFuncs, api, ctx, globalCallback, { "delta": delta });
917
+ // // }
918
+ // // } else if (topic === "/thread_typing" || topic === "/orca_typing_notifications") {
919
+ // // var typ = {
920
+ // // type: "typ",
921
+ // // isTyping: !!jsonMessage.state,
922
+ // // from: jsonMessage.sender_fbid.toString(),
923
+ // // threadID: utils.formatID((jsonMessage.thread || jsonMessage.sender_fbid).toString())
924
+ // // };
925
+ // // (function () { globalCallback(null, typ); })();
926
+ // // } else if (topic === "/orca_presence") {
927
+ // // if (!ctx.globalOptions.updatePresence) {
928
+ // // for (var i in jsonMessage.list) {
929
+ // // var data = jsonMessage.list[i];
930
+ // // var userID = data["u"];
931
+
932
+ // // var presence = {
933
+ // // type: "presence",
934
+ // // userID: userID.toString(),
935
+ // // //Convert to ms
936
+ // // timestamp: data["l"] * 1000,
937
+ // // statuses: data["p"]
938
+ // // };
939
+ // // (function () { globalCallback(null, presence); })();
940
+ // // }
941
+ // // }
942
+ // // }
943
+
944
+ // // });
945
+
946
+ // // mqttClient.on('close', function() {
947
+ // // // client.end();
948
+ // // });
949
+ // // }
950
+
951
+ // // function parseDelta(defaultFuncs, api, ctx, globalCallback, v) {
952
+ // // if(v.delta.class == "NewMessage") {
953
+ // // (function resolveAttachmentUrl(i) {
954
+ // // // sometimes, with sticker message in group, delta does not contain 'attachments' property.
955
+ // // if (v.delta.attachments && (i == v.delta.attachments.length)) {
956
+ // // var fmtMsg;
957
+ // // try {
958
+ // // fmtMsg = utils.formatDeltaMessage(v);
959
+ // // } catch (err) {
960
+ // // return globalCallback({
961
+ // // error: "Problem parsing message object. Please open an issue at https://github.com/Schmavery/facebook-chat-api/issues.",
962
+ // // detail: err,
963
+ // // res: v,
964
+ // // type: "parse_error"
965
+ // // });
966
+ // // }
967
+ // // if (fmtMsg) {
968
+ // // if (ctx.globalOptions.autoMarkDelivery) {
969
+ // // markDelivery(ctx, api, fmtMsg.threadID, fmtMsg.messageID);
970
+ // // }
971
+ // // }
972
+ // // return !ctx.globalOptions.selfListen &&
973
+ // // fmtMsg.senderID === ctx.userID ?
974
+ // // undefined :
975
+ // // (function () { globalCallback(null, fmtMsg); })();
976
+ // // } else {
977
+ // // if (
978
+ // // v.delta.attachments && (v.delta.attachments[i].mercury.attach_type == "photo")
979
+ // // ) {
980
+ // // api.resolvePhotoUrl(
981
+ // // v.delta.attachments[i].fbid,
982
+ // // (err, url) => {
983
+ // // if (!err)
984
+ // // v.delta.attachments[
985
+ // // i
986
+ // // ].mercury.metadata.url = url;
987
+ // // return resolveAttachmentUrl(i + 1);
988
+ // // }
989
+ // // );
990
+ // // } else {
991
+ // // return resolveAttachmentUrl(i + 1);
992
+ // // }
993
+ // // }
994
+ // // })(0);
995
+ // // }
996
+
997
+ // // if (v.delta.class == "ClientPayload") {
998
+ // // var clientPayload = utils.decodeClientPayload(
999
+ // // v.delta.payload
1000
+ // // );
1001
+ // // if (clientPayload && clientPayload.deltas) {
1002
+ // // for (var i in clientPayload.deltas) {
1003
+ // // var delta = clientPayload.deltas[i];
1004
+
1005
+ // // if (delta.deltaMessageReaction && !!ctx.globalOptions.listenEvents) {
1006
+ // // (function () { globalCallback(null, {
1007
+ // // type: "message_reaction",
1008
+ // // threadID: (delta.deltaMessageReaction.threadKey
1009
+ // // .threadFbId ?
1010
+ // // delta.deltaMessageReaction.threadKey.threadFbId : delta.deltaMessageReaction.threadKey
1011
+ // // .otherUserFbId).toString(),
1012
+ // // messageID: delta.deltaMessageReaction.messageId,
1013
+ // // reaction: delta.deltaMessageReaction.reaction,
1014
+ // // senderID: delta.deltaMessageReaction.senderId.toString(),
1015
+ // // userID: delta.deltaMessageReaction.userId.toString()
1016
+ // // }); })();
1017
+ // // } else if (delta.deltaRecallMessageData && !!ctx.globalOptions.listenEvents) {
1018
+ // // (function () { globalCallback(null, {
1019
+ // // type: "message_unsend",
1020
+ // // threadID: (delta.deltaRecallMessageData.threadKey.threadFbId ?
1021
+ // // delta.deltaRecallMessageData.threadKey.threadFbId : delta.deltaRecallMessageData.threadKey
1022
+ // // .otherUserFbId).toString(),
1023
+ // // messageID: delta.deltaRecallMessageData.messageID,
1024
+ // // senderID: delta.deltaRecallMessageData.senderID.toString(),
1025
+ // // deletionTimestamp: delta.deltaRecallMessageData.deletionTimestamp,
1026
+ // // timestamp: delta.deltaRecallMessageData.timestamp
1027
+ // // }); })();
1028
+ // // } else if (delta.deltaMessageReply) {
1029
+ // // //Mention block - #1
1030
+ // // var mdata =
1031
+ // // delta.deltaMessageReply.message === undefined ? [] :
1032
+ // // delta.deltaMessageReply.message.data === undefined ? [] :
1033
+ // // delta.deltaMessageReply.message.data.prng === undefined ? [] :
1034
+ // // JSON.parse(delta.deltaMessageReply.message.data.prng);
1035
+ // // var m_id = mdata.map(u => u.i);
1036
+ // // var m_offset = mdata.map(u => u.o);
1037
+ // // var m_length = mdata.map(u => u.l);
1038
+
1039
+ // // var mentions = {};
1040
+
1041
+ // // for (var i = 0; i < m_id.length; i++) {
1042
+ // // mentions[m_id[i]] = (delta.deltaMessageReply.message.body || "").substring(
1043
+ // // m_offset[i],
1044
+ // // m_offset[i] + m_length[i]
1045
+ // // );
1046
+ // // }
1047
+ // // //Mention block - 1#
1048
+ // // var callbackToReturn = {
1049
+ // // type: "message_reply",
1050
+ // // threadID: (delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId ?
1051
+ // // delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId : delta.deltaMessageReply.message.messageMetadata.threadKey
1052
+ // // .otherUserFbId).toString(),
1053
+ // // messageID: delta.deltaMessageReply.message.messageMetadata.messageId,
1054
+ // // senderID: delta.deltaMessageReply.message.messageMetadata.actorFbId.toString(),
1055
+ // // attachments: delta.deltaMessageReply.message.attachments.map(function (att) {
1056
+ // // var mercury = JSON.parse(att.mercuryJSON);
1057
+ // // Object.assign(att, mercury);
1058
+ // // return att;
1059
+ // // }).map(att => {
1060
+ // // var x;
1061
+ // // try {
1062
+ // // x = utils._formatAttachment(att);
1063
+ // // } catch (ex) {
1064
+ // // x = att;
1065
+ // // x.error = ex;
1066
+ // // x.type = "unknown";
1067
+ // // }
1068
+ // // return x;
1069
+ // // }),
1070
+ // // args: (delta.deltaMessageReply.message.body || '').split(' '),
1071
+ // // body: delta.deltaMessageReply.message.body || "",
1072
+ // // participantIDs: delta.deltaMessageReply.message.participants,
1073
+ // // isGroup: !!delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId,
1074
+ // // mentions: mentions,
1075
+ // // timestamp: delta.deltaMessageReply.message.messageMetadata.timestamp,
1076
+ // // };
1077
+
1078
+ // // if (delta.deltaMessageReply.repliedToMessage) {
1079
+ // // //Mention block - #2
1080
+ // // mdata =
1081
+ // // delta.deltaMessageReply.repliedToMessage === undefined ? [] :
1082
+ // // delta.deltaMessageReply.repliedToMessage.data === undefined ? [] :
1083
+ // // delta.deltaMessageReply.repliedToMessage.data.prng === undefined ? [] :
1084
+ // // JSON.parse(delta.deltaMessageReply.repliedToMessage.data.prng);
1085
+ // // m_id = mdata.map(u => u.i);
1086
+ // // m_offset = mdata.map(u => u.o);
1087
+ // // m_length = mdata.map(u => u.l);
1088
+
1089
+ // // var rmentions = {};
1090
+
1091
+ // // for (var i = 0; i < m_id.length; i++) {
1092
+ // // rmentions[m_id[i]] = (delta.deltaMessageReply.repliedToMessage.body || "").substring(
1093
+ // // m_offset[i],
1094
+ // // m_offset[i] + m_length[i]
1095
+ // // );
1096
+ // // }
1097
+ // // //Mention block - 2#
1098
+ // // callbackToReturn.messageReply = {
1099
+ // // threadID: (delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId ?
1100
+ // // delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId : delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey
1101
+ // // .otherUserFbId).toString(),
1102
+ // // messageID: delta.deltaMessageReply.repliedToMessage.messageMetadata.messageId,
1103
+ // // senderID: delta.deltaMessageReply.repliedToMessage.messageMetadata.actorFbId.toString(),
1104
+ // // attachments: delta.deltaMessageReply.repliedToMessage.attachments.map(function (att) {
1105
+ // // var mercury = JSON.parse(att.mercuryJSON);
1106
+ // // Object.assign(att, mercury);
1107
+ // // return att;
1108
+ // // }).map(att => {
1109
+ // // var x;
1110
+ // // try {
1111
+ // // x = utils._formatAttachment(att);
1112
+ // // } catch (ex) {
1113
+ // // x = att;
1114
+ // // x.error = ex;
1115
+ // // x.type = "unknown";
1116
+ // // }
1117
+ // // return x;
1118
+ // // }),
1119
+ // // args: (delta.deltaMessageReply.repliedToMessage.body || "").split(' '),
1120
+ // // body: delta.deltaMessageReply.repliedToMessage.body || "",
1121
+ // // isGroup: !!delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId,
1122
+ // // mentions: rmentions,
1123
+ // // timestamp: delta.deltaMessageReply.repliedToMessage.messageMetadata.timestamp,
1124
+ // // };
1125
+ // // }
1126
+
1127
+ // // if (ctx.globalOptions.autoMarkDelivery) {
1128
+ // // markDelivery(ctx, api, callbackToReturn.threadID, callbackToReturn.messageID);
1129
+ // // }
1130
+
1131
+ // // return !ctx.globalOptions.selfListen &&
1132
+ // // callbackToReturn.senderID === ctx.userID ?
1133
+ // // undefined :
1134
+ // // (function () { globalCallback(null, callbackToReturn); })();
1135
+ // // }
1136
+ // // }
1137
+ // // return;
1138
+ // // }
1139
+ // // }
1140
+
1141
+ // // if (v.delta.class !== "NewMessage" &&
1142
+ // // !ctx.globalOptions.listenEvents
1143
+ // // )
1144
+ // // return;
1145
+
1146
+ // // switch (v.delta.class) {
1147
+ // // case "ReadReceipt":
1148
+ // // var fmtMsg;
1149
+ // // try {
1150
+ // // fmtMsg = utils.formatDeltaReadReceipt(v.delta);
1151
+ // // } catch (err) {
1152
+ // // return globalCallback({
1153
+ // // error: "Problem parsing message object. Please open an issue at https://github.com/Schmavery/facebook-chat-api/issues.",
1154
+ // // detail: err,
1155
+ // // res: v.delta,
1156
+ // // type: "parse_error"
1157
+ // // });
1158
+ // // }
1159
+ // // return (function () { globalCallback(null, fmtMsg); })();
1160
+ // // case "AdminTextMessage":
1161
+ // // switch (v.delta.type) {
1162
+ // // case "change_thread_theme":
1163
+ // // case "change_thread_nickname":
1164
+ // // case "change_thread_icon":
1165
+ // // break;
1166
+ // // case "group_poll":
1167
+ // // var fmtMsg;
1168
+ // // try {
1169
+ // // fmtMsg = utils.formatDeltaEvent(v.delta);
1170
+ // // } catch (err) {
1171
+ // // return globalCallback({
1172
+ // // error: "Problem parsing message object. Please open an issue at https://github.com/Schmavery/facebook-chat-api/issues.",
1173
+ // // detail: err,
1174
+ // // res: v.delta,
1175
+ // // type: "parse_error"
1176
+ // // });
1177
+ // // }
1178
+ // // return (function () { globalCallback(null, fmtMsg); })();
1179
+ // // default:
1180
+ // // return;
1181
+ // // }
1182
+ // // break;
1183
+ // // //For group images
1184
+ // // case "ForcedFetch":
1185
+ // // if (!v.delta.threadKey) return;
1186
+ // // var mid = v.delta.messageId;
1187
+ // // var tid = v.delta.threadKey.threadFbId;
1188
+ // // if (mid && tid) {
1189
+ // // const form = {
1190
+ // // "av": ctx.globalOptions.pageID,
1191
+ // // "queries": JSON.stringify({
1192
+ // // "o0": {
1193
+ // // //This doc_id is valid as of ? (prob January 18, 2020)
1194
+ // // "doc_id": "1768656253222505",
1195
+ // // "query_params": {
1196
+ // // "thread_and_message_id": {
1197
+ // // "thread_id": tid.toString(),
1198
+ // // "message_id": mid.toString(),
1199
+ // // }
1200
+ // // }
1201
+ // // }
1202
+ // // })
1203
+ // // };
1204
+
1205
+ // // defaultFuncs
1206
+ // // .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
1207
+ // // .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
1208
+ // // .then((resData) => {
1209
+ // // if (resData[resData.length - 1].error_results > 0) {
1210
+ // // throw resData[0].o0.errors;
1211
+ // // }
1212
+
1213
+ // // if (resData[resData.length - 1].successful_results === 0) {
1214
+ // // throw { error: "forcedFetch: there was no successful_results", res: resData };
1215
+ // // }
1216
+
1217
+ // // var fetchData = resData[0].o0.data.message;
1218
+ // // if (fetchData && fetchData.__typename === "ThreadImageMessage") {
1219
+ // // (!ctx.globalOptions.selfListen &&
1220
+ // // fetchData.message_sender.id.toString() === ctx.userID) ||
1221
+ // // !ctx.loggedIn ?
1222
+ // // undefined :
1223
+ // // (function () { globalCallback(null, {
1224
+ // // type: "change_thread_image",
1225
+ // // threadID: utils.formatID(tid.toString()),
1226
+ // // snippet: fetchData.snippet,
1227
+ // // timestamp: fetchData.timestamp_precise,
1228
+ // // author: fetchData.message_sender.id,
1229
+ // // image: {
1230
+ // // attachmentID: fetchData.image_with_metadata && fetchData.image_with_metadata.legacy_attachment_id,
1231
+ // // width: fetchData.image_with_metadata && fetchData.image_with_metadata.original_dimensions.x,
1232
+ // // height: fetchData.image_with_metadata && fetchData.image_with_metadata.original_dimensions.y,
1233
+ // // url: fetchData.image_with_metadata && fetchData.image_with_metadata.preview.uri
1234
+ // // }
1235
+ // // }); })();
1236
+ // // }
1237
+ // // })
1238
+ // // .catch((err) => {
1239
+ // // log.error("forcedFetch", err);
1240
+ // // });
1241
+ // // }
1242
+ // // break;
1243
+ // // case "ThreadName":
1244
+ // // case "ParticipantsAddedToGroupThread":
1245
+ // // case "ParticipantLeftGroupThread":
1246
+ // // var formattedEvent;
1247
+ // // try {
1248
+ // // formattedEvent = utils.formatDeltaEvent(v.delta);
1249
+ // // } catch (err) {
1250
+ // // return globalCallback({
1251
+ // // error: "Problem parsing message object. Please open an issue at https://github.com/Schmavery/facebook-chat-api/issues.",
1252
+ // // detail: err,
1253
+ // // res: v.delta,
1254
+ // // type: "parse_error"
1255
+ // // });
1256
+ // // }
1257
+ // // return (!ctx.globalOptions.selfListen &&
1258
+ // // formattedEvent.author.toString() === ctx.userID) ||
1259
+ // // !ctx.loggedIn ?
1260
+ // // undefined :
1261
+ // // (function () { globalCallback(null, formattedEvent); })();
1262
+ // // }
1263
+ // // }
1264
+
1265
+ // // function markDelivery(ctx, api, threadID, messageID) {
1266
+ // // if (threadID && messageID) {
1267
+ // // api.markAsDelivered(threadID, messageID, (err) => {
1268
+ // // if (err) {
1269
+ // // log.error(err);
1270
+ // // } else {
1271
+ // // if (ctx.globalOptions.autoMarkRead) {
1272
+ // // api.markAsRead(threadID, (err) => {
1273
+ // // if (err) {
1274
+ // // log.error(err);
1275
+ // // }
1276
+ // // });
1277
+ // // }
1278
+ // // }
1279
+ // // });
1280
+ // // }
1281
+ // // }
1282
+
1283
+ // // module.exports = function (defaultFuncs, api, ctx) {
1284
+ // // var globalCallback = identity;
1285
+ // // return function (callback) {
1286
+ // // globalCallback = callback;
1287
+
1288
+ // // //Reset some stuff
1289
+ // // ctx.lastSeqId = 0;
1290
+ // // ctx.syncToken = undefined;
1291
+
1292
+ // // //Same request as getThreadList
1293
+ // // const form = {
1294
+ // // "av": ctx.globalOptions.pageID,
1295
+ // // "queries": JSON.stringify({
1296
+ // // "o0": {
1297
+ // // "doc_id": "1349387578499440",
1298
+ // // "query_params": {
1299
+ // // "limit": 1,
1300
+ // // "before": null,
1301
+ // // "tags": ["INBOX"],
1302
+ // // "includeDeliveryReceipts": false,
1303
+ // // "includeSeqID": true
1304
+ // // }
1305
+ // // }
1306
+ // // })
1307
+ // // };
1308
+
1309
+ // // defaultFuncs
1310
+ // // .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
1311
+ // // .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
1312
+ // // .then((resData) => {
1313
+ // // if (resData && resData.length > 0 && resData[resData.length - 1].error_results > 0) {
1314
+ // // throw resData[0].o0.errors;
1315
+ // // }
1316
+
1317
+ // // if (resData[resData.length - 1].successful_results === 0) {
1318
+ // // throw { error: "getSeqId: there was no successful_results", res: resData };
1319
+ // // }
1320
+
1321
+ // // if (resData[0].o0.data.viewer.message_threads.sync_sequence_id) {
1322
+ // // ctx.lastSeqId = resData[0].o0.data.viewer.message_threads.sync_sequence_id;
1323
+ // // listenMqtt(defaultFuncs, api, ctx, globalCallback);
1324
+ // // }
1325
+
1326
+ // // })
1327
+ // // .catch((err) => {
1328
+ // // log.error("getSeqId", err);
1329
+ // // return callback(err);
1330
+ // // });
1331
+ // // var stopListening = function () {
1332
+ // // globalCallback = identity;
1333
+
1334
+ // // if(ctx.mqttClient)
1335
+ // // {
1336
+ // // ctx.mqttClient.end();
1337
+ // // ctx.mqttClient = undefined;
1338
+ // // }
1339
+ // // };
1340
+
1341
+ // // return stopListening;
1342
+ // // };
1343
+ // // };
1344
+
1345
+
1346
+ // V1 - 07/05/2024 Kem
1347
+ /* eslint-disable no-redeclare */
1348
+ "use strict";
1349
+ const utils = require("../utils");
1350
+ const log = require("npmlog");
1351
+ const mqtt = require('mqtt');
1352
+ const Websocket = require('ws');
1353
+ const HttpsProxyAgent = require('https-proxy-agent');
1354
+ const EventEmitter = require('events');
1355
+ const Duplexify = require('duplexify');
1356
+ const Transform = require('readable-stream').Transform;
1357
+ var identity = function () { };
1358
+ var form = {};
1359
+ var getSeqID = function () { };
1360
+
1361
+
1362
+ var topics = ["/ls_req","/ls_resp","/legacy_web","/webrtc","/rtc_multi","/onevc","/br_sr","/sr_res","/t_ms","/thread_typing","/orca_typing_notifications","/notify_disconnect","/orca_presence","/inbox","/mercury", "/messaging_events", "/orca_message_notifications", "/pp","/webrtc_response"];
1363
+
1364
+ /* [ Noti ? ]
1365
+ ! "/br_sr", //Notification
1366
+ * => Need to publish /br_sr right after this
1367
+
1368
+ ! "/notify_disconnect",
1369
+ * => Need to publish /messenger_sync_create_queue right after this
1370
+
1371
+ ! "/orca_presence",
1372
+ * => Will receive /sr_res right here.
1373
+ */
1374
+
1375
+ var WebSocket_Global;
1376
+
1377
+ function buildProxy() {
1378
+ var Proxy = new Transform({
1379
+ objectMode: false
1380
+ });
1381
+
1382
+ Proxy._write = function socketWriteNode(chunk, enc, next) {
1383
+ if (WebSocket_Global.readyState !== WebSocket_Global.OPEN) {
1384
+ return next();
1385
+ }
1386
+
1387
+ if (typeof chunk === 'string') {
1388
+ chunk = new Buffer.from(chunk, 'utf8');
1389
+ }
1390
+ WebSocket_Global.send(chunk, next);
1391
+ };
1392
+
1393
+ Proxy._flush = function(done) {
1394
+ WebSocket_Global.close();
1395
+ done();
1396
+ };
1397
+
1398
+ Proxy._writev = function(chunks, cb) {
1399
+ var buffers = new Array(chunks.length);
1400
+ for (var i = 0; i < chunks.length; i++) {
1401
+ if (typeof chunks[i].chunk === 'string') {
1402
+ buffers[i] = new Buffer.from(chunks[i], 'utf8');
1403
+ } else {
1404
+ buffers[i] = chunks[i].chunk;
1405
+ }
1406
+ }
1407
+ this._write(new Buffer.concat(buffers), 'binary', cb);
1408
+ };
1409
+
1410
+ return Proxy;
1411
+ }
1412
+
1413
+ function buildStream(options, WebSocket, Proxy) {
1414
+ const Stream = Duplexify(undefined, undefined, options);
1415
+ Stream.socket = WebSocket;
1416
+
1417
+ WebSocket
1418
+ .onclose = function() {
1419
+ Stream.end();
1420
+ Stream.destroy();
1421
+ };
1422
+ WebSocket
1423
+ .onerror = function(err) {
1424
+ Stream.destroy(err);
1425
+ };
1426
+ WebSocket
1427
+ .onmessage = function(event) {
1428
+ var data = event.data;
1429
+ if (data instanceof ArrayBuffer) data = new Buffer.from(data);
1430
+ else data = new Buffer.from(data, 'utf8');
1431
+ Stream.push(data);
1432
+ };
1433
+ WebSocket
1434
+ .onopen = function() {
1435
+ Stream.setReadable(Proxy);
1436
+ Stream.setWritable(Proxy);
1437
+ Stream.emit('connect');
1438
+ };
1439
+ WebSocket_Global = WebSocket;
1440
+ Proxy.on('close', function() { WebSocket.close(); });
1441
+ return Stream;
1442
+ }
1443
+
1444
+
1445
+ function listenMqtt(defaultFuncs, api, ctx, globalCallback) {
1446
+ //Don't really know what this does but I think it's for the act`ive state?
1447
+ //TODO: Move to ctx when implemented
1448
+ var chatOn = ctx.globalOptions.online;
1449
+ var foreground = false;
1450
+
1451
+ var sessionID = Math.floor((Math.random() * Number.MAX_SAFE_INTEGER)+1);
1452
+ var username = {u: ctx.userID,s: sessionID,chat_on: chatOn,fg: foreground,d: utils.getGUID(),ct: "websocket",aid: "219994525426954", mqtt_sid: "",cp: 3,ecp: 10,st: [],pm: [],dc: "",no_auto_fg: true,gas: null,pack: []};
1453
+ var cookies = ctx.jar.getCookies('https://www.facebook.com').join("; ");
1454
+
1455
+ var host;
1456
+ if (ctx.mqttEndpoint) host = `${ctx.mqttEndpoint}&sid=${sessionID}`;
1457
+ else if (ctx.region) host = `wss://edge-chat.facebook.com/chat?region=${ctx.region.toLocaleLowerCase()}&sid=${sessionID}`;
1458
+ else host = `wss://edge-chat.facebook.com/chat?sid=${sessionID}`;
1459
+
1460
+ var options = {
1461
+ clientId: "mqttwsclient",
1462
+ protocolId: 'MQIsdp',
1463
+ protocolVersion: 3,
1464
+ username: JSON.stringify(username),
1465
+ clean: true,
1466
+ wsOptions: {
1467
+ headers: {
1468
+ 'Cookie': cookies,
1469
+ 'Origin': 'https://www.facebook.com',
1470
+ 'User-Agent': (ctx.globalOptions.userAgent || 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.4951.64 Safari/537.36'),
1471
+ 'Referer': 'https://www.facebook.com/',
1472
+ 'Host': new URL(host).hostname //'edge-chat.facebook.com'
1473
+ },
1474
+ origin: 'https://www.facebook.com',
1475
+ protocolVersion: 13,
1476
+ binaryType: 'arraybuffer',
1477
+ },
1478
+ keepalive: 60,
1479
+ reschedulePings: true,
1480
+ reconnectPeriod: 3
1481
+ };
1482
+
1483
+ if (typeof ctx.globalOptions.proxy != "undefined") {
1484
+ var agent = new HttpsProxyAgent(ctx.globalOptions.proxy);
1485
+ options.wsOptions.agent = agent;
1486
+ }
1487
+ ctx.mqttClient = new mqtt.Client(_ => buildStream(options, new Websocket(host, options.wsOptions), buildProxy()), options);
1488
+ global.mqttClient = ctx.mqttClient;
1489
+
1490
+ global.mqttClient.on('error', function (err) {
1491
+ log.error("listenMqtt", err);
1492
+ global.mqttClient.end();
1493
+
1494
+ if (ctx.globalOptions.autoReconnect) getSeqID();
1495
+ else {
1496
+ globalCallback({ type: "stop_listen", error: "Server Đã Sập - Auto Restart" }, null);
1497
+ return process.exit(1);
1498
+ }
1499
+ });
1500
+
1501
+ global.mqttClient.on('connect', function () {
1502
+ if (!global.Fca.Data.Setup || global.Fca.Data.Setup == undefined) {
1503
+ if (global.Fca.Require.FastConfig.RestartMQTT_Minutes != 0 && global.Fca.Data.StopListening != true) {
1504
+ global.Fca.Data.Setup = true;
1505
+ setTimeout(() => {
1506
+ global.Fca.Require.logger.Warning("Closing MQTT Client...");
1507
+ ctx.mqttClient.end();
1508
+ global.Fca.Require.logger.Warning("Reconnecting MQTT Client...");
1509
+ global.Fca.Data.Setup = false;
1510
+ getSeqID();
1511
+ }, Number(global.Fca.Require.FastConfig.RestartMQTT_Minutes) * 60 * 1000);
1512
+ }
1513
+ }
1514
+ if (process.env.OnStatus == undefined) {
1515
+ global.Fca.Require.logger.Normal("Bạn Đang Sài Phiên Bản: Premium Access");
1516
+ if (Number(global.Fca.Require.FastConfig.AutoRestartMinutes) == 0) {
1517
+ // something
1518
+ }
1519
+ else if (Number(global.Fca.Require.FastConfig.AutoRestartMinutes < 10)) {
1520
+ log.warn("AutoRestartMinutes","The number of minutes to automatically restart must be more than 10 minutes");
1521
+ }
1522
+ else if (Number(global.Fca.Require.FastConfig.AutoRestartMinutes) < 0) {
1523
+ log.warn("AutoRestartMinutes","Invalid auto-restart minutes!");
1524
+ }
1525
+ else {
1526
+ global.Fca.Require.logger.Normal(global.Fca.getText(global.Fca.Require.Language.Src.AutoRestart,global.Fca.Require.FastConfig.AutoRestartMinutes));
1527
+ global.Fca.Require.logger.Normal("Auto Restart MQTT Client After: " + global.Fca.Require.FastConfig.RestartMQTT_Minutes + " Minutes");
1528
+ setInterval(() => {
1529
+ global.Fca.Require.logger.Normal(global.Fca.Require.Language.Src.OnRestart);
1530
+ process.exit(1);
1531
+ }, Number(global.Fca.Require.FastConfig.AutoRestartMinutes) * 60000);
1532
+ }
1533
+ require('../broadcast').startBroadcasting();
1534
+ const MemoryManager = require('../Extra/Src/Release_Memory');
1535
+ const path = require('path');
1536
+
1537
+ const memoryManager = new MemoryManager({
1538
+ warningThreshold: 0.6,
1539
+ releaseThreshold: 0.7,
1540
+ maxThreshold: 0.8,
1541
+ interval: 30 * 1000,
1542
+ logLevel: 'warn',
1543
+ logFile: path.join(__dirname, 'memory.log'),
1544
+ smartReleaseEnabled: true,
1545
+ });
1546
+
1547
+
1548
+ memoryManager.autoStart(60 * 60 * 1000);
1549
+
1550
+ process.env.OnStatus = true;
1551
+ }
1552
+
1553
+ topics.forEach(topicsub => global.mqttClient.subscribe(topicsub));
1554
+
1555
+ var topic;
1556
+ var queue = {
1557
+ sync_api_version: 11,
1558
+ max_deltas_able_to_process: 100,
1559
+ delta_batch_size: 500,
1560
+ encoding: "JSON",
1561
+ entity_fbid: ctx.userID,
1562
+ };
1563
+
1564
+ topic = "/messenger_sync_create_queue";
1565
+ queue.initial_titan_sequence_id = ctx.lastSeqId;
1566
+ queue.device_params = null;
1567
+
1568
+ global.mqttClient.publish(topic, JSON.stringify(queue), { qos: 1, retain: false });
1569
+
1570
+ var rTimeout = setTimeout(function () {
1571
+ global.mqttClient.end();
1572
+ getSeqID();
1573
+ }, 3000);
1574
+
1575
+ ctx.tmsWait = function () {
1576
+ clearTimeout(rTimeout);
1577
+ ctx.globalOptions.emitReady ? globalCallback({type: "ready",error: null}) : '';
1578
+ delete ctx.tmsWait;
1579
+ };
1580
+ });
1581
+
1582
+ global.mqttClient.on('message', function (topic, message, _packet) {
1583
+ const jsonMessage = JSON.parse(message.toString());
1584
+ console.log(message.toString())
1585
+ if (topic === "/t_ms") {
1586
+ if (ctx.tmsWait && typeof ctx.tmsWait == "function") ctx.tmsWait();
1587
+
1588
+ if (jsonMessage.firstDeltaSeqId && jsonMessage.syncToken) {
1589
+ ctx.lastSeqId = jsonMessage.firstDeltaSeqId;
1590
+ ctx.syncToken = jsonMessage.syncToken;
1591
+ }
1592
+
1593
+ if (jsonMessage.lastIssuedSeqId) ctx.lastSeqId = parseInt(jsonMessage.lastIssuedSeqId);
1594
+ //If it contains more than 1 delta
1595
+ for (var i in jsonMessage.deltas) {
1596
+ var delta = jsonMessage.deltas[i];
1597
+ parseDelta(defaultFuncs, api, ctx, globalCallback, { "delta": delta });
1598
+ }
1599
+ }
1600
+ else if (topic === "/ls_resp") {
1601
+ console.log((jsonMessage.payload));
1602
+ const payload = JSON.parse(jsonMessage.payload); //'{"name":null,"step":[1,[1,[4,0,1,[5,"taskExists",[19,"415"]]],[23,[2,0],[1,[5,"replaceOptimsiticMessage","7192532113093667880","mid.$gABfX5li9LA6VdUymnWPRAdlkiawo"]]]],[1,[4,0,1,[5,"taskExists",[19,"415"]]],[23,[2,0],[1,[5,"mailboxTaskCompletionApiOnTaskCompletion",[19,"415"],true]]]],[1,[4,0,1,[5,"taskExists",[19,"415"]]],[23,[2,0],[1,[5,"removeTask",[19,"415"],[9]]]]]]}'
1603
+ const request_ID = jsonMessage.request_id;
1604
+ if (ctx.callback_Task[request_ID] != undefined) {
1605
+ const { callback, type } = ctx.callback_Task[request_ID];
1606
+ const Data = new getRespData(type, payload);
1607
+
1608
+ if (!Data) {
1609
+ callback("Something went wrong 🐳", null);
1610
+ }
1611
+ else {
1612
+ callback(null, Data);
1613
+ }
1614
+ }
1615
+ }
1616
+ else if (topic === "/thread_typing" || topic === "/orca_typing_notifications") {
1617
+ var typ = {
1618
+ type: "typ",
1619
+ isTyping: !!jsonMessage.state,
1620
+ from: jsonMessage.sender_fbid.toString(),
1621
+ threadID: utils.formatID((jsonMessage.thread || jsonMessage.sender_fbid).toString())
1622
+ };
1623
+ (function () { globalCallback(null, typ); })();
1624
+ } else if (topic === "/orca_presence") {
1625
+ if (!ctx.globalOptions.updatePresence) {
1626
+ for (var i in jsonMessage.list) {
1627
+ var data = jsonMessage.list[i];
1628
+ var userID = data["u"];
1629
+
1630
+ var presence = {
1631
+ type: "presence",
1632
+ userID: userID.toString(),
1633
+ //Convert to ms
1634
+ timestamp: data["l"] * 1000,
1635
+ statuses: data["p"]
1636
+ };
1637
+ (function () { globalCallback(null, presence); })();
1638
+ }
1639
+ }
1640
+ }
1641
+
1642
+ });
1643
+
1644
+ process.on('SIGINT', function () {
1645
+ LogUptime();
1646
+ process.kill(process.pid);
1647
+ });
1648
+
1649
+ process.on('exit', () => {
1650
+ LogUptime();
1651
+ });
1652
+
1653
+ }
1654
+
1655
+ function getRespData(Type, payload) {
1656
+ try {
1657
+ switch (Type) {
1658
+ case "sendMqttMessage": {
1659
+ return {
1660
+ type: Type,
1661
+ threadID: payload.step[1][2][2][1][2], //this is sick bro
1662
+ messageID: payload.step[1][2][2][1][3],
1663
+ payload: payload.step[1][2]
1664
+ };
1665
+ }
1666
+ default: { //!very LAZY :> cook yourself
1667
+ return {
1668
+ Data: payload.step[1][2][2][1],
1669
+ type: Type,
1670
+ payload: payload.step[1][2]
1671
+ };
1672
+ }
1673
+ }
1674
+ }
1675
+ catch (e) {
1676
+ return null;
1677
+ }
1678
+ }
1679
+
1680
+ function LogUptime() {
1681
+ var uptime = process.uptime();
1682
+ var { join } = require('path');
1683
+ if (global.Fca.Require.fs.existsSync(join(__dirname, '../CountTime.json'))) {
1684
+ var Time1 = (Number(global.Fca.Require.fs.readFileSync(join(__dirname, '../CountTime.json'), 'utf8')) || 0);
1685
+ global.Fca.Require.fs.writeFileSync(join(__dirname, '../CountTime.json'), String(Number(uptime) + Time1), 'utf8');
1686
+ }
1687
+ else {
1688
+ var Time1 = 0;
1689
+ global.Fca.Require.fs.writeFileSync(join(__dirname, '../CountTime.json'), String(Number(uptime) + Time1), 'utf8');
1690
+ }
1691
+ }
1692
+ function parseDelta(defaultFuncs, api, ctx, globalCallback, v) {
1693
+ if (v.delta.class == "NewMessage") {
1694
+ //Not tested for pages
1695
+ if (ctx.globalOptions.pageID && ctx.globalOptions.pageID != v.queue) return;
1696
+
1697
+ (function resolveAttachmentUrl(i) {
1698
+ if (v.delta.attachments && (i == v.delta.attachments.length) || utils.getType(v.delta.attachments) !== "Array") {
1699
+ var fmtMsg;
1700
+ try {
1701
+ fmtMsg = utils.formatDeltaMessage(v);
1702
+ } catch (err) {
1703
+ return log.error("Lỗi Nhẹ", err);
1704
+ }
1705
+ global.Fca.Data.event = fmtMsg;
1706
+ try {
1707
+ var { updateMessageCount,getData,hasData } = require('../Extra/ExtraGetThread');
1708
+ if (hasData(fmtMsg.threadID)) {
1709
+ var x = getData(fmtMsg.threadID);
1710
+ x.messageCount+=1;
1711
+ updateMessageCount(fmtMsg.threadID,x);
1712
+ }
1713
+ }
1714
+ catch (e) {
1715
+ //temp
1716
+ }
1717
+ if (fmtMsg)
1718
+ if (ctx.globalOptions.autoMarkDelivery) markDelivery(ctx, api, fmtMsg.threadID, fmtMsg.messageID);
1719
+
1720
+ return !ctx.globalOptions.selfListen && fmtMsg.senderID === ctx.userID ? undefined : (function () { globalCallback(null, fmtMsg); })();
1721
+ } else {
1722
+ if (v.delta.attachments && (v.delta.attachments[i].mercury.attach_type == "photo")) {
1723
+ api.resolvePhotoUrl(v.delta.attachments[i].fbid, (err, url) => {
1724
+ if (!err) v.delta.attachments[i].mercury.metadata.url = url;
1725
+ return resolveAttachmentUrl(i + 1);
1726
+ });
1727
+ } else return resolveAttachmentUrl(i + 1);
1728
+ }
1729
+ })(0);
1730
+ }
1731
+
1732
+ if (v.delta.class == "ClientPayload") {
1733
+ var clientPayload = utils.decodeClientPayload(v.delta.payload);
1734
+ if (clientPayload && clientPayload.deltas) {
1735
+ for (var i in clientPayload.deltas) {
1736
+ var delta = clientPayload.deltas[i];
1737
+ if (delta.deltaMessageReaction && !!ctx.globalOptions.listenEvents) {
1738
+ (function () {
1739
+ globalCallback(null, {
1740
+ type: "message_reaction",
1741
+ threadID: (delta.deltaMessageReaction.threadKey.threadFbId ? delta.deltaMessageReaction.threadKey.threadFbId : delta.deltaMessageReaction.threadKey.otherUserFbId).toString(),
1742
+ messageID: delta.deltaMessageReaction.messageId,
1743
+ reaction: delta.deltaMessageReaction.reaction,
1744
+ senderID: delta.deltaMessageReaction.senderId.toString(),
1745
+ userID: delta.deltaMessageReaction.userId.toString()
1746
+ });
1747
+ })();
1748
+ } else if (delta.deltaRecallMessageData && !!ctx.globalOptions.listenEvents) {
1749
+ (function () {
1750
+ globalCallback(null, {
1751
+ type: "message_unsend",
1752
+ threadID: (delta.deltaRecallMessageData.threadKey.threadFbId ? delta.deltaRecallMessageData.threadKey.threadFbId : delta.deltaRecallMessageData.threadKey.otherUserFbId).toString(),
1753
+ messageID: delta.deltaRecallMessageData.messageID,
1754
+ senderID: delta.deltaRecallMessageData.senderID.toString(),
1755
+ deletionTimestamp: delta.deltaRecallMessageData.deletionTimestamp,
1756
+ timestamp: delta.deltaRecallMessageData.timestamp
1757
+ });
1758
+ })();
1759
+ } else if (delta.deltaMessageReply) {
1760
+ //Mention block - #1
1761
+ var mdata =
1762
+ delta.deltaMessageReply.message === undefined ? [] :
1763
+ delta.deltaMessageReply.message.data === undefined ? [] :
1764
+ delta.deltaMessageReply.message.data.prng === undefined ? [] :
1765
+ JSON.parse(delta.deltaMessageReply.message.data.prng);
1766
+ var m_id = mdata.map(u => u.i);
1767
+ var m_offset = mdata.map(u => u.o);
1768
+ var m_length = mdata.map(u => u.l);
1769
+
1770
+ var mentions = {};
1771
+
1772
+ for (var i = 0; i < m_id.length; i++) mentions[m_id[i]] = (delta.deltaMessageReply.message.body || "").substring(m_offset[i], m_offset[i] + m_length[i]);
1773
+ //Mention block - 1#
1774
+ var callbackToReturn = {
1775
+ type: "message_reply",
1776
+ threadID: (delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId ? delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId : delta.deltaMessageReply.message.messageMetadata.threadKey.otherUserFbId).toString(),
1777
+ messageID: delta.deltaMessageReply.message.messageMetadata.messageId,
1778
+ senderID: delta.deltaMessageReply.message.messageMetadata.actorFbId.toString(),
1779
+ attachments: delta.deltaMessageReply.message.attachments.map(function (att) {
1780
+ var mercury = JSON.parse(att.mercuryJSON);
1781
+ Object.assign(att, mercury);
1782
+ return att;
1783
+ }).map(att => {
1784
+ var x;
1785
+ try {
1786
+ x = utils._formatAttachment(att);
1787
+ } catch (ex) {
1788
+ x = att;
1789
+ x.error = ex;
1790
+ x.type = "unknown";
1791
+ }
1792
+ return x;
1793
+ }),
1794
+ args: (delta.deltaMessageReply.message.body || "").trim().split(/\s+/),
1795
+ body: (delta.deltaMessageReply.message.body || ""),
1796
+ isGroup: !!delta.deltaMessageReply.message.messageMetadata.threadKey.threadFbId,
1797
+ mentions: mentions,
1798
+ timestamp: delta.deltaMessageReply.message.messageMetadata.timestamp,
1799
+ participantIDs: (delta.deltaMessageReply.message.participants || []).map(e => e.toString())
1800
+ };
1801
+
1802
+ if (delta.deltaMessageReply.repliedToMessage) {
1803
+ //Mention block - #2
1804
+ mdata =
1805
+ delta.deltaMessageReply.repliedToMessage === undefined ? [] :
1806
+ delta.deltaMessageReply.repliedToMessage.data === undefined ? [] :
1807
+ delta.deltaMessageReply.repliedToMessage.data.prng === undefined ? [] :
1808
+ JSON.parse(delta.deltaMessageReply.repliedToMessage.data.prng);
1809
+ m_id = mdata.map(u => u.i);
1810
+ m_offset = mdata.map(u => u.o);
1811
+ m_length = mdata.map(u => u.l);
1812
+
1813
+ var rmentions = {};
1814
+
1815
+ for (var i = 0; i < m_id.length; i++) rmentions[m_id[i]] = (delta.deltaMessageReply.repliedToMessage.body || "").substring(m_offset[i], m_offset[i] + m_length[i]);
1816
+ //Mention block - 2#
1817
+ callbackToReturn.messageReply = {
1818
+ threadID: (delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId ? delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId : delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.otherUserFbId).toString(),
1819
+ messageID: delta.deltaMessageReply.repliedToMessage.messageMetadata.messageId,
1820
+ senderID: delta.deltaMessageReply.repliedToMessage.messageMetadata.actorFbId.toString(),
1821
+ attachments: delta.deltaMessageReply.repliedToMessage.attachments.map(function (att) {
1822
+ var mercury = JSON.parse(att.mercuryJSON);
1823
+ Object.assign(att, mercury);
1824
+ return att;
1825
+ }).map(att => {
1826
+ var x;
1827
+ try {
1828
+ x = utils._formatAttachment(att);
1829
+ } catch (ex) {
1830
+ x = att;
1831
+ x.error = ex;
1832
+ x.type = "unknown";
1833
+ }
1834
+ return x;
1835
+ }),
1836
+ args: (delta.deltaMessageReply.repliedToMessage.body || "").trim().split(/\s+/),
1837
+ body: delta.deltaMessageReply.repliedToMessage.body || "",
1838
+ isGroup: !!delta.deltaMessageReply.repliedToMessage.messageMetadata.threadKey.threadFbId,
1839
+ mentions: rmentions,
1840
+ timestamp: delta.deltaMessageReply.repliedToMessage.messageMetadata.timestamp,
1841
+ participantIDs: (delta.deltaMessageReply.repliedToMessage.participants || []).map(e => e.toString())
1842
+ };
1843
+ } else if (delta.deltaMessageReply.replyToMessageId) {
1844
+ return defaultFuncs
1845
+ .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, {
1846
+ "av": ctx.globalOptions.pageID,
1847
+ "queries": JSON.stringify({
1848
+ "o0": {
1849
+ //Using the same doc_id as forcedFetch
1850
+ "doc_id": "2848441488556444",
1851
+ "query_params": {
1852
+ "thread_and_message_id": {
1853
+ "thread_id": callbackToReturn.threadID,
1854
+ "message_id": delta.deltaMessageReply.replyToMessageId.id,
1855
+ }
1856
+ }
1857
+ }
1858
+ })
1859
+ })
1860
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
1861
+ .then((resData) => {
1862
+ if (resData[resData.length - 1].error_results > 0) throw resData[0].o0.errors;
1863
+ if (resData[resData.length - 1].successful_results === 0) throw { error: "forcedFetch: there was no successful_results", res: resData };
1864
+ var fetchData = resData[0].o0.data.message;
1865
+ var mobj = {};
1866
+ for (var n in fetchData.message.ranges) mobj[fetchData.message.ranges[n].entity.id] = (fetchData.message.text || "").substr(fetchData.message.ranges[n].offset, fetchData.message.ranges[n].length);
1867
+
1868
+ callbackToReturn.messageReply = {
1869
+ type: "Message",
1870
+ threadID: callbackToReturn.threadID,
1871
+ messageID: fetchData.message_id,
1872
+ senderID: fetchData.message_sender.id.toString(),
1873
+ attachments: fetchData.message.blob_attachment.map(att => {
1874
+ var x;
1875
+ try {
1876
+ x = utils._formatAttachment({ blob_attachment: att });
1877
+ } catch (ex) {
1878
+ x = att;
1879
+ x.error = ex;
1880
+ x.type = "unknown";
1881
+ }
1882
+ return x;
1883
+ }),
1884
+ args: (fetchData.message.text || "").trim().split(/\s+/) || [],
1885
+ body: fetchData.message.text || "",
1886
+ isGroup: callbackToReturn.isGroup,
1887
+ mentions: mobj,
1888
+ timestamp: parseInt(fetchData.timestamp_precise)
1889
+ };
1890
+ })
1891
+ .catch(err => log.error("forcedFetch", err))
1892
+ .finally(function () {
1893
+ if (ctx.globalOptions.autoMarkDelivery) markDelivery(ctx, api, callbackToReturn.threadID, callbackToReturn.messageID);
1894
+ !ctx.globalOptions.selfListen && callbackToReturn.senderID === ctx.userID ? undefined : (function () { globalCallback(null, callbackToReturn); })();
1895
+ });
1896
+ } else callbackToReturn.delta = delta;
1897
+
1898
+ if (ctx.globalOptions.autoMarkDelivery) markDelivery(ctx, api, callbackToReturn.threadID, callbackToReturn.messageID);
1899
+
1900
+ return !ctx.globalOptions.selfListen && callbackToReturn.senderID === ctx.userID ? undefined : (function () { globalCallback(null, callbackToReturn); })();
1901
+ }
1902
+ }
1903
+ return;
1904
+ }
1905
+ }
1906
+ switch (v.delta.class) {
1907
+ case "ReadReceipt": {
1908
+ var fmtMsg;
1909
+ try {
1910
+ fmtMsg = utils.formatDeltaReadReceipt(v.delta);
1911
+ } catch (err) {
1912
+ return log.error("Lỗi Nhẹ", err);
1913
+ }
1914
+ return (function () { globalCallback(null, fmtMsg); })();
1915
+ }
1916
+ case "AdminTextMessage": {
1917
+ switch (v.delta.type) {
1918
+ case "joinable_group_link_mode_change":
1919
+ case "magic_words":
1920
+ case "pin_messages_v2":
1921
+ case "change_thread_theme":
1922
+ case "change_thread_icon":
1923
+ case "change_thread_nickname":
1924
+ case "change_thread_admins":
1925
+ case "change_thread_approval_mode":
1926
+ case "group_poll":
1927
+ case "messenger_call_log":
1928
+ case "participant_joined_group_call":
1929
+ var fmtMsg;
1930
+ try {
1931
+ fmtMsg = utils.formatDeltaEvent(v.delta);
1932
+ } catch (err) {
1933
+ console.log(v.delta);
1934
+ return log.error("Lỗi Nhẹ", err);
1935
+ }
1936
+ return (function () { globalCallback(null, fmtMsg); })();
1937
+ }
1938
+ break;
1939
+ }
1940
+ //For group images
1941
+ case "ForcedFetch": {
1942
+ if (!v.delta.threadKey) return;
1943
+ var mid = v.delta.messageId;
1944
+ var tid = v.delta.threadKey.threadFbId;
1945
+ if (mid && tid) {
1946
+ const form = {
1947
+ "av": ctx.globalOptions.pageID,
1948
+ "queries": JSON.stringify({
1949
+ "o0": {
1950
+ //This doc_id is valid as of March 25, 2020
1951
+ "doc_id": "2848441488556444",
1952
+ "query_params": {
1953
+ "thread_and_message_id": {
1954
+ "thread_id": tid.toString(),
1955
+ "message_id": mid,
1956
+ }
1957
+ }
1958
+ }
1959
+ })
1960
+ };
1961
+
1962
+ defaultFuncs
1963
+ .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
1964
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
1965
+ .then((resData) => {
1966
+ if (resData[resData.length - 1].error_results > 0) throw resData[0].o0.errors;
1967
+
1968
+ if (resData[resData.length - 1].successful_results === 0) throw { error: "forcedFetch: there was no successful_results", res: resData };
1969
+
1970
+ var fetchData = resData[0].o0.data.message;
1971
+
1972
+ if (utils.getType(fetchData) == "Object") {
1973
+ log.info("forcedFetch", fetchData);
1974
+ switch (fetchData.__typename) {
1975
+ case "ThreadImageMessage":
1976
+ (!ctx.globalOptions.selfListen &&
1977
+ fetchData.message_sender.id.toString() === ctx.userID) ||
1978
+ !ctx.loggedIn ?
1979
+ undefined :
1980
+ (function () {
1981
+ globalCallback(null, {
1982
+ type: "change_thread_image",
1983
+ threadID: utils.formatID(tid.toString()),
1984
+ snippet: fetchData.snippet,
1985
+ timestamp: fetchData.timestamp_precise,
1986
+ author: fetchData.message_sender.id,
1987
+ image: {
1988
+ attachmentID: fetchData.image_with_metadata && fetchData.image_with_metadata.legacy_attachment_id,
1989
+ width: fetchData.image_with_metadata && fetchData.image_with_metadata.original_dimensions.x,
1990
+ height: fetchData.image_with_metadata && fetchData.image_with_metadata.original_dimensions.y,
1991
+ url: fetchData.image_with_metadata && fetchData.image_with_metadata.preview.uri
1992
+ }
1993
+ });
1994
+ })();
1995
+ break;
1996
+ case "UserMessage":
1997
+ log.info("ff-Return", {
1998
+ type: "message",
1999
+ senderID: utils.formatID(fetchData.message_sender.id),
2000
+ body: fetchData.message.text || "",
2001
+ threadID: utils.formatID(tid.toString()),
2002
+ messageID: fetchData.message_id,
2003
+ attachments: [{
2004
+ type: "share",
2005
+ ID: fetchData.extensible_attachment.legacy_attachment_id,
2006
+ url: fetchData.extensible_attachment.story_attachment.url,
2007
+
2008
+ title: fetchData.extensible_attachment.story_attachment.title_with_entities.text,
2009
+ description: fetchData.extensible_attachment.story_attachment.description.text,
2010
+ source: fetchData.extensible_attachment.story_attachment.source,
2011
+
2012
+ image: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).uri,
2013
+ width: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).width,
2014
+ height: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).height,
2015
+ playable: (fetchData.extensible_attachment.story_attachment.media || {}).is_playable || false,
2016
+ duration: (fetchData.extensible_attachment.story_attachment.media || {}).playable_duration_in_ms || 0,
2017
+
2018
+ subattachments: fetchData.extensible_attachment.subattachments,
2019
+ properties: fetchData.extensible_attachment.story_attachment.properties,
2020
+ }],
2021
+ mentions: {},
2022
+ timestamp: parseInt(fetchData.timestamp_precise),
2023
+ isGroup: (fetchData.message_sender.id != tid.toString())
2024
+ });
2025
+ globalCallback(null, {
2026
+ type: "message",
2027
+ senderID: utils.formatID(fetchData.message_sender.id),
2028
+ body: fetchData.message.text || "",
2029
+ threadID: utils.formatID(tid.toString()),
2030
+ messageID: fetchData.message_id,
2031
+ attachments: [{
2032
+ type: "share",
2033
+ ID: fetchData.extensible_attachment.legacy_attachment_id,
2034
+ url: fetchData.extensible_attachment.story_attachment.url,
2035
+
2036
+ title: fetchData.extensible_attachment.story_attachment.title_with_entities.text,
2037
+ description: fetchData.extensible_attachment.story_attachment.description.text,
2038
+ source: fetchData.extensible_attachment.story_attachment.source,
2039
+
2040
+ image: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).uri,
2041
+ width: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).width,
2042
+ height: ((fetchData.extensible_attachment.story_attachment.media || {}).image || {}).height,
2043
+ playable: (fetchData.extensible_attachment.story_attachment.media || {}).is_playable || false,
2044
+ duration: (fetchData.extensible_attachment.story_attachment.media || {}).playable_duration_in_ms || 0,
2045
+
2046
+ subattachments: fetchData.extensible_attachment.subattachments,
2047
+ properties: fetchData.extensible_attachment.story_attachment.properties,
2048
+ }],
2049
+ mentions: {},
2050
+ timestamp: parseInt(fetchData.timestamp_precise),
2051
+ isGroup: (fetchData.message_sender.id != tid.toString())
2052
+ });
2053
+ }
2054
+ } else log.error("forcedFetch", fetchData);
2055
+ })
2056
+ .catch((err) => log.error("forcedFetch", err));
2057
+ }
2058
+ }
2059
+ break;
2060
+ case "ThreadName":
2061
+ case "ParticipantsAddedToGroupThread":
2062
+ case "ParticipantLeftGroupThread": {
2063
+ var formattedEvent;
2064
+ try {
2065
+ formattedEvent = utils.formatDeltaEvent(v.delta);
2066
+ } catch (err) {
2067
+ console.log(err);
2068
+ return log.error("Lỗi Nhẹ", err);
2069
+ }
2070
+ return (!ctx.globalOptions.selfListen && formattedEvent.author.toString() === ctx.userID) || !ctx.loggedIn ? undefined : (function () { globalCallback(null, formattedEvent); })();
2071
+ }
2072
+ case "NewMessage": {
2073
+ if (v.delta.attachments != undefined && v.delta.attachments.length == 1 && v.delta.attachments[0].mercury.extensible_attachment != undefined && v.delta.attachments[0].mercury.extensible_attachment.story_attachment.style_list.includes("message_live_location")) {
2074
+ v.delta.class = "UserLocation";
2075
+ var fmtMsg;
2076
+ try {
2077
+ fmtMsg = utils.formatDeltaEvent(v.delta);
2078
+ } catch (err) {
2079
+ console.log(v.delta);
2080
+ return log.error("Lỗi Nhẹ", err);
2081
+ }
2082
+ return (function () { globalCallback(null, fmtMsg); })();
2083
+ }
2084
+ }
2085
+ break;
2086
+ }
2087
+ }
2088
+
2089
+
2090
+ function markDelivery(ctx, api, threadID, messageID) {
2091
+ if (threadID && messageID) {
2092
+ api.markAsDelivered(threadID, messageID, (err) => {
2093
+ if (err) log.error("markAsDelivered", err);
2094
+ else {
2095
+ if (ctx.globalOptions.autoMarkRead) {
2096
+ api.markAsRead(threadID, (err) => {
2097
+ if (err) log.error("markAsDelivered", err);
2098
+ });
2099
+ }
2100
+ }
2101
+ });
2102
+ }
2103
+ }
2104
+
2105
+ module.exports = function (defaultFuncs, api, ctx) {
2106
+ var globalCallback = identity;
2107
+ getSeqID = function getSeqID() {
2108
+ ctx.t_mqttCalled = false;
2109
+ defaultFuncs
2110
+ .post("https://www.facebook.com/api/graphqlbatch/", ctx.jar, form)
2111
+ .then(utils.parseAndCheckLogin(ctx, defaultFuncs))
2112
+ .then((resData) => {
2113
+ if (utils.getType(resData) != "Array") {
2114
+ if (global.Fca.Require.FastConfig.AutoLogin) {
2115
+ return global.Fca.Require.logger.Warning(global.Fca.Require.Language.Index.AutoLogin, function() {
2116
+ return global.Fca.Action('AutoLogin');
2117
+ });
2118
+ }
2119
+ else if (!global.Fca.Require.FastConfig.AutoLogin) {
2120
+ return global.Fca.Require.logger.Error(global.Fca.Require.Language.Index.ErrAppState);
2121
+ }
2122
+ return;
2123
+ }
2124
+ else {
2125
+ if (resData && resData[resData.length - 1].error_results > 0) throw resData[0].o0.errors;
2126
+ if (resData[resData.length - 1].successful_results === 0) throw { error: "getSeqId: there was no successful_results", res: resData };
2127
+ if (resData[0].o0.data.viewer.message_threads.sync_sequence_id) {
2128
+ ctx.lastSeqId = resData[0].o0.data.viewer.message_threads.sync_sequence_id;
2129
+ listenMqtt(defaultFuncs, api, ctx, globalCallback);
2130
+ }
2131
+ else throw { error: "getSeqId: no sync_sequence_id found.", res: resData };
2132
+ }
2133
+ })
2134
+ .catch((err) => {
2135
+ log.error("getSeqId", err);
2136
+ if (utils.getType(err) == "Object" && err.error === global.Fca.Require.Language.Index.ErrAppState) ctx.loggedIn = false;
2137
+ return globalCallback(err);
2138
+ });
2139
+ };
2140
+
2141
+ return function (callback) {
2142
+ class MessageEmitter extends EventEmitter {
2143
+ stopListening(callback) {
2144
+ callback = callback || (() => { });
2145
+ globalCallback = identity;
2146
+ if (ctx.mqttClient) {
2147
+ ctx.mqttClient.unsubscribe("/webrtc");
2148
+ ctx.mqttClient.unsubscribe("/rtc_multi");
2149
+ ctx.mqttClient.unsubscribe("/onevc");
2150
+ ctx.mqttClient.publish("/browser_close", "{}");
2151
+ ctx.mqttClient.end(false, function (...data) {
2152
+ ctx.mqttClient = undefined;
2153
+ });
2154
+ }
2155
+ global.Fca.Data.StopListening = true;
2156
+ }
2157
+ }
2158
+
2159
+ var msgEmitter = new MessageEmitter();
2160
+ globalCallback = (callback || function (error, message) {
2161
+ if (error) return msgEmitter.emit("error", error);
2162
+ msgEmitter.emit("message", message);
2163
+ });
2164
+
2165
+ //Reset some stuff
2166
+ if (!ctx.firstListen) ctx.lastSeqId = null;
2167
+ ctx.syncToken = undefined;
2168
+ ctx.t_mqttCalled = false;
2169
+
2170
+ //Same request as getThreadList
2171
+ form = {
2172
+ "av": ctx.globalOptions.pageID,
2173
+ "queries": JSON.stringify({
2174
+ "o0": {
2175
+ "doc_id": "3336396659757871",
2176
+ "query_params": {
2177
+ "limit": 1,
2178
+ "before": null,
2179
+ "tags": ["INBOX"],
2180
+ "includeDeliveryReceipts": false,
2181
+ "includeSeqID": true
2182
+ }
2183
+ }
2184
+ })
2185
+ };
2186
+
2187
+ if (!ctx.firstListen || !ctx.lastSeqId) getSeqID();
2188
+ else listenMqtt(defaultFuncs, api, ctx, globalCallback);
2189
+ ctx.firstListen = false;
2190
+ return msgEmitter;
2191
+ };
2192
+ };