@skyzopedia/baileys-mod 3.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (104) hide show
  1. package/LICENSE +21 -0
  2. package/WAProto/WAProto.proto +5311 -0
  3. package/WAProto/index.js +94091 -0
  4. package/lib/Defaults/index.js +123 -0
  5. package/lib/KeyDB/BinarySearch.js +20 -0
  6. package/lib/KeyDB/KeyedDB.js +167 -0
  7. package/lib/KeyDB/index.js +4 -0
  8. package/lib/Signal/Group/ciphertext-message.js +13 -0
  9. package/lib/Signal/Group/group-session-builder.js +32 -0
  10. package/lib/Signal/Group/group_cipher.js +84 -0
  11. package/lib/Signal/Group/index.js +13 -0
  12. package/lib/Signal/Group/keyhelper.js +20 -0
  13. package/lib/Signal/Group/sender-chain-key.js +28 -0
  14. package/lib/Signal/Group/sender-key-distribution-message.js +65 -0
  15. package/lib/Signal/Group/sender-key-message.js +68 -0
  16. package/lib/Signal/Group/sender-key-name.js +52 -0
  17. package/lib/Signal/Group/sender-key-record.js +43 -0
  18. package/lib/Signal/Group/sender-key-state.js +86 -0
  19. package/lib/Signal/Group/sender-message-key.js +28 -0
  20. package/lib/Signal/libsignal.js +324 -0
  21. package/lib/Signal/lid-mapping.js +155 -0
  22. package/lib/Socket/Client/index.js +4 -0
  23. package/lib/Socket/Client/types.js +13 -0
  24. package/lib/Socket/Client/websocket.js +52 -0
  25. package/lib/Socket/business.js +377 -0
  26. package/lib/Socket/chats.js +881 -0
  27. package/lib/Socket/communities.js +413 -0
  28. package/lib/Socket/groups.js +312 -0
  29. package/lib/Socket/index.js +16 -0
  30. package/lib/Socket/messages-recv.js +1163 -0
  31. package/lib/Socket/messages-send.js +1082 -0
  32. package/lib/Socket/mex.js +45 -0
  33. package/lib/Socket/newsletter.js +259 -0
  34. package/lib/Socket/socket.js +781 -0
  35. package/lib/Store/index.js +6 -0
  36. package/lib/Store/make-cache-manager-store.js +75 -0
  37. package/lib/Store/make-in-memory-store.js +290 -0
  38. package/lib/Store/make-ordered-dictionary.js +79 -0
  39. package/lib/Store/object-repository.js +25 -0
  40. package/lib/Types/Auth.js +3 -0
  41. package/lib/Types/Bussines.js +3 -0
  42. package/lib/Types/Call.js +3 -0
  43. package/lib/Types/Chat.js +9 -0
  44. package/lib/Types/Contact.js +3 -0
  45. package/lib/Types/Events.js +3 -0
  46. package/lib/Types/GroupMetadata.js +3 -0
  47. package/lib/Types/Label.js +25 -0
  48. package/lib/Types/LabelAssociation.js +7 -0
  49. package/lib/Types/Message.js +12 -0
  50. package/lib/Types/Newsletter.js +33 -0
  51. package/lib/Types/Newsletter.js.bak +33 -0
  52. package/lib/Types/Product.js +3 -0
  53. package/lib/Types/Signal.js +3 -0
  54. package/lib/Types/Socket.js +4 -0
  55. package/lib/Types/State.js +11 -0
  56. package/lib/Types/USync.js +3 -0
  57. package/lib/Types/index.js +28 -0
  58. package/lib/Utils/auth-utils.js +219 -0
  59. package/lib/Utils/baileys-event-stream.js +44 -0
  60. package/lib/Utils/browser-utils.js +17 -0
  61. package/lib/Utils/business.js +233 -0
  62. package/lib/Utils/chat-utils.js +752 -0
  63. package/lib/Utils/crypto.js +130 -0
  64. package/lib/Utils/decode-wa-message.js +267 -0
  65. package/lib/Utils/event-buffer.js +528 -0
  66. package/lib/Utils/generics.js +355 -0
  67. package/lib/Utils/history.js +87 -0
  68. package/lib/Utils/index.js +21 -0
  69. package/lib/Utils/link-preview.js +81 -0
  70. package/lib/Utils/logger.js +5 -0
  71. package/lib/Utils/lt-hash.js +45 -0
  72. package/lib/Utils/make-mutex.js +36 -0
  73. package/lib/Utils/message-retry-manager.js +113 -0
  74. package/lib/Utils/messages-media.js +601 -0
  75. package/lib/Utils/messages.js +776 -0
  76. package/lib/Utils/noise-handler.js +144 -0
  77. package/lib/Utils/pre-key-manager.js +85 -0
  78. package/lib/Utils/process-message.js +341 -0
  79. package/lib/Utils/signal.js +161 -0
  80. package/lib/Utils/use-multi-file-auth-state.js +111 -0
  81. package/lib/Utils/validate-connection.js +200 -0
  82. package/lib/WABinary/constants.js +1303 -0
  83. package/lib/WABinary/decode.js +240 -0
  84. package/lib/WABinary/encode.js +218 -0
  85. package/lib/WABinary/generic-utils.js +113 -0
  86. package/lib/WABinary/index.js +7 -0
  87. package/lib/WABinary/jid-utils.js +93 -0
  88. package/lib/WABinary/types.js +3 -0
  89. package/lib/WAM/BinaryInfo.js +11 -0
  90. package/lib/WAM/constants.js +22853 -0
  91. package/lib/WAM/encode.js +154 -0
  92. package/lib/WAM/index.js +5 -0
  93. package/lib/WAUSync/Protocols/USyncContactProtocol.js +30 -0
  94. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +53 -0
  95. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +29 -0
  96. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +39 -0
  97. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
  98. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +30 -0
  99. package/lib/WAUSync/Protocols/index.js +6 -0
  100. package/lib/WAUSync/USyncQuery.js +90 -0
  101. package/lib/WAUSync/USyncUser.js +24 -0
  102. package/lib/WAUSync/index.js +5 -0
  103. package/lib/index.js +15 -0
  104. package/package.json +102 -0
@@ -0,0 +1,528 @@
1
+ //=======================================================//
2
+ import { updateMessageWithReaction, updateMessageWithReceipt } from "./messages.js";
3
+ import { isRealMessage, shouldIncrementChatUnread } from "./process-message.js";
4
+ import { WAMessageStatus } from "../Types/index.js";
5
+ import { trimUndefined } from "./generics.js";
6
+ import EventEmitter from "events";
7
+ //=======================================================//
8
+ const BUFFERABLE_EVENT = [
9
+ "messaging-history.set",
10
+ "chats.upsert",
11
+ "chats.update",
12
+ "chats.delete",
13
+ "contacts.upsert",
14
+ "contacts.update",
15
+ "messages.upsert",
16
+ "messages.update",
17
+ "messages.delete",
18
+ "messages.reaction",
19
+ "message-receipt.update",
20
+ "groups.update"
21
+ ];
22
+ //=======================================================//
23
+ const BUFFERABLE_EVENT_SET = new Set(BUFFERABLE_EVENT);
24
+ //=======================================================//
25
+ export const makeEventBuffer = (logger) => {
26
+ const ev = new EventEmitter();
27
+ const historyCache = new Set();
28
+ let data = makeBufferData();
29
+ let isBuffering = false;
30
+ let bufferTimeout = null;
31
+ let bufferCount = 0;
32
+ const MAX_HISTORY_CACHE_SIZE = 10000;
33
+ const BUFFER_TIMEOUT_MS = 30000;
34
+ ev.on("event", (map) => {
35
+ for (const event in map) {
36
+ ev.emit(event, map[event]);
37
+ }
38
+ });
39
+ function buffer() {
40
+ if (!isBuffering) {
41
+ logger.debug("Event buffer activated");
42
+ isBuffering = true;
43
+ bufferCount++;
44
+ if (bufferTimeout) {
45
+ clearTimeout(bufferTimeout);
46
+ }
47
+ bufferTimeout = setTimeout(() => {
48
+ if (isBuffering) {
49
+ logger.warn("Buffer timeout reached, auto-flushing");
50
+ flush();
51
+ }
52
+ }, BUFFER_TIMEOUT_MS);
53
+ }
54
+ else {
55
+ bufferCount++;
56
+ }
57
+ }
58
+ function flush() {
59
+ if (!isBuffering) {
60
+ return false;
61
+ }
62
+ logger.debug({ bufferCount }, "Flushing event buffer");
63
+ isBuffering = false;
64
+ bufferCount = 0;
65
+ if (bufferTimeout) {
66
+ clearTimeout(bufferTimeout);
67
+ bufferTimeout = null;
68
+ }
69
+ if (historyCache.size > MAX_HISTORY_CACHE_SIZE) {
70
+ logger.debug({ cacheSize: historyCache.size }, "Clearing history cache");
71
+ historyCache.clear();
72
+ }
73
+ const newData = makeBufferData();
74
+ const chatUpdates = Object.values(data.chatUpdates);
75
+ let conditionalChatUpdatesLeft = 0;
76
+ for (const update of chatUpdates) {
77
+ if (update.conditional) {
78
+ conditionalChatUpdatesLeft += 1;
79
+ newData.chatUpdates[update.id] = update;
80
+ delete data.chatUpdates[update.id];
81
+ }
82
+ }
83
+ const consolidatedData = consolidateEvents(data);
84
+ if (Object.keys(consolidatedData).length) {
85
+ ev.emit("event", consolidatedData);
86
+ }
87
+ data = newData;
88
+ logger.trace({ conditionalChatUpdatesLeft }, "released buffered events");
89
+ return true;
90
+ }
91
+ return {
92
+ process(handler) {
93
+ const listener = (map) => {
94
+ handler(map);
95
+ };
96
+ ev.on("event", listener);
97
+ return () => {
98
+ ev.off("event", listener);
99
+ };
100
+ },
101
+ emit(event, evData) {
102
+ if (isBuffering && BUFFERABLE_EVENT_SET.has(event)) {
103
+ append(data, historyCache, event, evData, logger);
104
+ return true;
105
+ }
106
+ return ev.emit("event", { [event]: evData });
107
+ },
108
+ isBuffering() {
109
+ return isBuffering;
110
+ },
111
+ buffer,
112
+ flush,
113
+ createBufferedFunction(work) {
114
+ return async (...args) => {
115
+ buffer();
116
+ try {
117
+ const result = await work(...args);
118
+ if (bufferCount === 1) {
119
+ setTimeout(() => {
120
+ if (isBuffering && bufferCount === 1) {
121
+ flush();
122
+ }
123
+ }, 100);
124
+ }
125
+ return result;
126
+ }
127
+ catch (error) {
128
+ throw error;
129
+ }
130
+ finally {
131
+ bufferCount = Math.max(0, bufferCount - 1);
132
+ if (bufferCount === 0) {
133
+ setTimeout(flush, 100);
134
+ }
135
+ }
136
+ };
137
+ },
138
+ on: (...args) => ev.on(...args),
139
+ off: (...args) => ev.off(...args),
140
+ removeAllListeners: (...args) => ev.removeAllListeners(...args)
141
+ };
142
+ };
143
+ //=======================================================//
144
+ const makeBufferData = () => {
145
+ return {
146
+ "historySets": {
147
+ "chats": {},
148
+ "messages": {},
149
+ "contacts": {},
150
+ "isLatest": false,
151
+ "empty": true
152
+ },
153
+ "chatUpserts": {},
154
+ "chatUpdates": {},
155
+ "chatDeletes": new Set(),
156
+ "contactUpserts": {},
157
+ "contactUpdates": {},
158
+ "messageUpserts": {},
159
+ "messageUpdates": {},
160
+ "messageReactions": {},
161
+ "messageDeletes": {},
162
+ "messageReceipts": {},
163
+ "groupUpdates": {}
164
+ };
165
+ };
166
+ //=======================================================//
167
+ function append(data, historyCache, event, eventData, logger) {
168
+ switch (event) {
169
+ case "messaging-history.set":
170
+ for (const chat of eventData.chats) {
171
+ const id = chat.id || "";
172
+ const existingChat = data.historySets.chats[id];
173
+ if (existingChat) {
174
+ existingChat.endOfHistoryTransferType = chat.endOfHistoryTransferType;
175
+ }
176
+ if (!existingChat && !historyCache.has(id)) {
177
+ data.historySets.chats[id] = chat;
178
+ historyCache.add(id);
179
+ absorbingChatUpdate(chat);
180
+ }
181
+ }
182
+ for (const contact of eventData.contacts) {
183
+ const existingContact = data.historySets.contacts[contact.id];
184
+ if (existingContact) {
185
+ Object.assign(existingContact, trimUndefined(contact));
186
+ }
187
+ else {
188
+ const historyContactId = `c:${contact.id}`;
189
+ const hasAnyName = contact.notify || contact.name || contact.verifiedName;
190
+ if (!historyCache.has(historyContactId) || hasAnyName) {
191
+ data.historySets.contacts[contact.id] = contact;
192
+ historyCache.add(historyContactId);
193
+ }
194
+ }
195
+ }
196
+ for (const message of eventData.messages) {
197
+ const key = stringifyMessageKey(message.key);
198
+ const existingMsg = data.historySets.messages[key];
199
+ if (!existingMsg && !historyCache.has(key)) {
200
+ data.historySets.messages[key] = message;
201
+ historyCache.add(key);
202
+ }
203
+ }
204
+ data.historySets.empty = false;
205
+ data.historySets.syncType = eventData.syncType;
206
+ data.historySets.progress = eventData.progress;
207
+ data.historySets.peerDataRequestSessionId = eventData.peerDataRequestSessionId;
208
+ data.historySets.isLatest = eventData.isLatest || data.historySets.isLatest;
209
+ break;
210
+ case "chats.upsert":
211
+ for (const chat of eventData) {
212
+ const id = chat.id || "";
213
+ let upsert = data.chatUpserts[id];
214
+ if (id && !upsert) {
215
+ upsert = data.historySets.chats[id];
216
+ if (upsert) {
217
+ logger.debug({ chatId: id }, "absorbed chat upsert in chat set");
218
+ }
219
+ }
220
+ if (upsert) {
221
+ upsert = concatChats(upsert, chat);
222
+ }
223
+ else {
224
+ upsert = chat;
225
+ data.chatUpserts[id] = upsert;
226
+ }
227
+ absorbingChatUpdate(upsert);
228
+ if (data.chatDeletes.has(id)) {
229
+ data.chatDeletes.delete(id);
230
+ }
231
+ }
232
+ break;
233
+ case "chats.update":
234
+ for (const update of eventData) {
235
+ const chatId = update.id;
236
+ const conditionMatches = update.conditional ? update.conditional(data) : true;
237
+ if (conditionMatches) {
238
+ delete update.conditional;
239
+ const upsert = data.historySets.chats[chatId] || data.chatUpserts[chatId];
240
+ if (upsert) {
241
+ concatChats(upsert, update);
242
+ }
243
+ else {
244
+ const chatUpdate = data.chatUpdates[chatId] || {};
245
+ data.chatUpdates[chatId] = concatChats(chatUpdate, update);
246
+ }
247
+ }
248
+ else if (conditionMatches === undefined) {
249
+ data.chatUpdates[chatId] = update;
250
+ }
251
+ if (data.chatDeletes.has(chatId)) {
252
+ data.chatDeletes.delete(chatId);
253
+ }
254
+ }
255
+ break;
256
+ case "chats.delete":
257
+ for (const chatId of eventData) {
258
+ if (!data.chatDeletes.has(chatId)) {
259
+ data.chatDeletes.add(chatId);
260
+ }
261
+ if (data.chatUpdates[chatId]) {
262
+ delete data.chatUpdates[chatId];
263
+ }
264
+ if (data.chatUpserts[chatId]) {
265
+ delete data.chatUpserts[chatId];
266
+ }
267
+ if (data.historySets.chats[chatId]) {
268
+ delete data.historySets.chats[chatId];
269
+ }
270
+ }
271
+ break;
272
+ case "contacts.upsert":
273
+ for (const contact of eventData) {
274
+ let upsert = data.contactUpserts[contact.id];
275
+ if (!upsert) {
276
+ upsert = data.historySets.contacts[contact.id];
277
+ if (upsert) {
278
+ logger.debug({ contactId: contact.id }, "absorbed contact upsert in contact set");
279
+ }
280
+ }
281
+ if (upsert) {
282
+ upsert = Object.assign(upsert, trimUndefined(contact));
283
+ }
284
+ else {
285
+ upsert = contact;
286
+ data.contactUpserts[contact.id] = upsert;
287
+ }
288
+ if (data.contactUpdates[contact.id]) {
289
+ upsert = Object.assign(data.contactUpdates[contact.id], trimUndefined(contact));
290
+ delete data.contactUpdates[contact.id];
291
+ }
292
+ }
293
+ break;
294
+ case "contacts.update":
295
+ const contactUpdates = eventData;
296
+ for (const update of contactUpdates) {
297
+ const id = update.id;
298
+ const upsert = data.historySets.contacts[id] || data.contactUpserts[id];
299
+ if (upsert) {
300
+ Object.assign(upsert, update);
301
+ }
302
+ else {
303
+ const contactUpdate = data.contactUpdates[id] || {};
304
+ data.contactUpdates[id] = Object.assign(contactUpdate, update);
305
+ }
306
+ }
307
+ break;
308
+ case "messages.upsert":
309
+ const { messages, type } = eventData;
310
+ for (const message of messages) {
311
+ const key = stringifyMessageKey(message.key);
312
+ let existing = data.messageUpserts[key]?.message;
313
+ if (!existing) {
314
+ existing = data.historySets.messages[key];
315
+ if (existing) {
316
+ logger.debug({ messageId: key }, "absorbed message upsert in message set");
317
+ }
318
+ }
319
+ if (existing) {
320
+ message.messageTimestamp = existing.messageTimestamp;
321
+ }
322
+ if (data.messageUpdates[key]) {
323
+ logger.debug("absorbed prior message update in message upsert");
324
+ Object.assign(message, data.messageUpdates[key].update);
325
+ delete data.messageUpdates[key];
326
+ }
327
+ if (data.historySets.messages[key]) {
328
+ data.historySets.messages[key] = message;
329
+ }
330
+ else {
331
+ data.messageUpserts[key] = {
332
+ message,
333
+ type: type === "notify" || data.messageUpserts[key]?.type === "notify" ? "notify" : type
334
+ };
335
+ }
336
+ }
337
+ break;
338
+ case "messages.update":
339
+ const msgUpdates = eventData;
340
+ for (const { key, update } of msgUpdates) {
341
+ const keyStr = stringifyMessageKey(key);
342
+ const existing = data.historySets.messages[keyStr] || data.messageUpserts[keyStr]?.message;
343
+ if (existing) {
344
+ Object.assign(existing, update);
345
+ if (update.status === WAMessageStatus.READ && !key.fromMe) {
346
+ decrementChatReadCounterIfMsgDidUnread(existing);
347
+ }
348
+ }
349
+ else {
350
+ const msgUpdate = data.messageUpdates[keyStr] || { key, update: {} };
351
+ Object.assign(msgUpdate.update, update);
352
+ data.messageUpdates[keyStr] = msgUpdate;
353
+ }
354
+ }
355
+ break;
356
+ case "messages.delete":
357
+ const deleteData = eventData;
358
+ if ("keys" in deleteData) {
359
+ const { keys } = deleteData;
360
+ for (const key of keys) {
361
+ const keyStr = stringifyMessageKey(key);
362
+ if (!data.messageDeletes[keyStr]) {
363
+ data.messageDeletes[keyStr] = key;
364
+ }
365
+ if (data.messageUpserts[keyStr]) {
366
+ delete data.messageUpserts[keyStr];
367
+ }
368
+ if (data.messageUpdates[keyStr]) {
369
+ delete data.messageUpdates[keyStr];
370
+ }
371
+ }
372
+ }
373
+ else {
374
+ }
375
+ break;
376
+ case "messages.reaction":
377
+ const reactions = eventData;
378
+ for (const { key, reaction } of reactions) {
379
+ const keyStr = stringifyMessageKey(key);
380
+ const existing = data.messageUpserts[keyStr];
381
+ if (existing) {
382
+ updateMessageWithReaction(existing.message, reaction);
383
+ }
384
+ else {
385
+ data.messageReactions[keyStr] = data.messageReactions[keyStr] || { key, reactions: [] };
386
+ updateMessageWithReaction(data.messageReactions[keyStr], reaction);
387
+ }
388
+ }
389
+ break;
390
+ case "message-receipt.update":
391
+ const receipts = eventData;
392
+ for (const { key, receipt } of receipts) {
393
+ const keyStr = stringifyMessageKey(key);
394
+ const existing = data.messageUpserts[keyStr];
395
+ if (existing) {
396
+ updateMessageWithReceipt(existing.message, receipt);
397
+ }
398
+ else {
399
+ data.messageReceipts[keyStr] = data.messageReceipts[keyStr] || { key, userReceipt: [] };
400
+ updateMessageWithReceipt(data.messageReceipts[keyStr], receipt);
401
+ }
402
+ }
403
+ break;
404
+ case "groups.update":
405
+ const groupUpdates = eventData;
406
+ for (const update of groupUpdates) {
407
+ const id = update.id;
408
+ const groupUpdate = data.groupUpdates[id] || {};
409
+ if (!data.groupUpdates[id]) {
410
+ data.groupUpdates[id] = Object.assign(groupUpdate, update);
411
+ }
412
+ }
413
+ break;
414
+ default:
415
+ throw new Error(`"${event}" cannot be buffered`);
416
+ }
417
+ function absorbingChatUpdate(existing) {
418
+ const chatId = existing.id || "";
419
+ const update = data.chatUpdates[chatId];
420
+ if (update) {
421
+ const conditionMatches = update.conditional ? update.conditional(data) : true;
422
+ if (conditionMatches) {
423
+ delete update.conditional;
424
+ logger.debug({ chatId }, "absorbed chat update in existing chat");
425
+ Object.assign(existing, concatChats(update, existing));
426
+ delete data.chatUpdates[chatId];
427
+ }
428
+ else if (conditionMatches === false) {
429
+ logger.debug({ chatId }, "chat update condition fail, removing");
430
+ delete data.chatUpdates[chatId];
431
+ }
432
+ }
433
+ }
434
+ function decrementChatReadCounterIfMsgDidUnread(message) {
435
+ const chatId = message.key.remoteJid;
436
+ const chat = data.chatUpdates[chatId] || data.chatUpserts[chatId];
437
+ if (isRealMessage(message) &&
438
+ shouldIncrementChatUnread(message) &&
439
+ typeof chat?.unreadCount === "number" &&
440
+ chat.unreadCount > 0) {
441
+ logger.debug({ chatId: chat.id }, "decrementing chat counter");
442
+ chat.unreadCount -= 1;
443
+ if (chat.unreadCount === 0) {
444
+ delete chat.unreadCount;
445
+ }
446
+ }
447
+ }
448
+ }
449
+ function consolidateEvents(data) {
450
+ const map = {};
451
+ if (!data.historySets.empty) {
452
+ map["messaging-history.set"] = {
453
+ chats: Object.values(data.historySets.chats),
454
+ messages: Object.values(data.historySets.messages),
455
+ contacts: Object.values(data.historySets.contacts),
456
+ syncType: data.historySets.syncType,
457
+ progress: data.historySets.progress,
458
+ isLatest: data.historySets.isLatest,
459
+ peerDataRequestSessionId: data.historySets.peerDataRequestSessionId
460
+ };
461
+ }
462
+ const chatUpsertList = Object.values(data.chatUpserts);
463
+ if (chatUpsertList.length) {
464
+ map["chats.upsert"] = chatUpsertList;
465
+ }
466
+ const chatUpdateList = Object.values(data.chatUpdates);
467
+ if (chatUpdateList.length) {
468
+ map["chats.update"] = chatUpdateList;
469
+ }
470
+ const chatDeleteList = Array.from(data.chatDeletes);
471
+ if (chatDeleteList.length) {
472
+ map["chats.delete"] = chatDeleteList;
473
+ }
474
+ const messageUpsertList = Object.values(data.messageUpserts);
475
+ if (messageUpsertList.length) {
476
+ const type = messageUpsertList[0].type;
477
+ map["messages.upsert"] = {
478
+ messages: messageUpsertList.map(m => m.message),
479
+ type
480
+ };
481
+ }
482
+ const messageUpdateList = Object.values(data.messageUpdates);
483
+ if (messageUpdateList.length) {
484
+ map["messages.update"] = messageUpdateList;
485
+ }
486
+ const messageDeleteList = Object.values(data.messageDeletes);
487
+ if (messageDeleteList.length) {
488
+ map["messages.delete"] = { keys: messageDeleteList };
489
+ }
490
+ const messageReactionList = Object.values(data.messageReactions).flatMap(({ key, reactions }) => reactions.flatMap(reaction => ({ key, reaction })));
491
+ if (messageReactionList.length) {
492
+ map["messages.reaction"] = messageReactionList;
493
+ }
494
+ const messageReceiptList = Object.values(data.messageReceipts).flatMap(({ key, userReceipt }) => userReceipt.flatMap(receipt => ({ key, receipt })));
495
+ if (messageReceiptList.length) {
496
+ map["message-receipt.update"] = messageReceiptList;
497
+ }
498
+ const contactUpsertList = Object.values(data.contactUpserts);
499
+ if (contactUpsertList.length) {
500
+ map["contacts.upsert"] = contactUpsertList;
501
+ }
502
+ const contactUpdateList = Object.values(data.contactUpdates);
503
+ if (contactUpdateList.length) {
504
+ map["contacts.update"] = contactUpdateList;
505
+ }
506
+ const groupUpdateList = Object.values(data.groupUpdates);
507
+ if (groupUpdateList.length) {
508
+ map["groups.update"] = groupUpdateList;
509
+ }
510
+ return map;
511
+ }
512
+ //=======================================================//
513
+ function concatChats(a, b) {
514
+ if (b.unreadCount === null &&
515
+ a.unreadCount < 0) {
516
+ a.unreadCount = undefined;
517
+ b.unreadCount = undefined;
518
+ }
519
+ if (typeof a.unreadCount === "number" && typeof b.unreadCount === "number") {
520
+ b = { ...b };
521
+ if (b.unreadCount >= 0) {
522
+ b.unreadCount = Math.max(b.unreadCount, 0) + Math.max(a.unreadCount, 0);
523
+ }
524
+ }
525
+ return Object.assign(a, b);
526
+ }
527
+ const stringifyMessageKey = (key) => `${key.remoteJid},${key.id},${key.fromMe ? "1" : "0"}`;
528
+ //=======================================================//