@bellachu/xteambail 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (413) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +13 -0
  3. package/WAProto/GenerateStatics.sh +3 -0
  4. package/WAProto/WAProto.proto +5479 -0
  5. package/WAProto/fix-imports.js +38 -0
  6. package/WAProto/index.d.ts +14017 -0
  7. package/WAProto/index.js +2213 -0
  8. package/engine-requirements.js +10 -0
  9. package/lib/Defaults/index.d.ts +75 -0
  10. package/lib/Defaults/index.d.ts.map +1 -0
  11. package/lib/Defaults/index.js +139 -0
  12. package/lib/Defaults/index.js.map +1 -0
  13. package/lib/Signal/Group/ciphertext-message.d.ts +10 -0
  14. package/lib/Signal/Group/ciphertext-message.d.ts.map +1 -0
  15. package/lib/Signal/Group/ciphertext-message.js +19 -0
  16. package/lib/Signal/Group/ciphertext-message.js.map +1 -0
  17. package/lib/Signal/Group/group-session-builder.d.ts +15 -0
  18. package/lib/Signal/Group/group-session-builder.d.ts.map +1 -0
  19. package/lib/Signal/Group/group-session-builder.js +38 -0
  20. package/lib/Signal/Group/group-session-builder.js.map +1 -0
  21. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  22. package/lib/Signal/Group/group_cipher.d.ts.map +1 -0
  23. package/lib/Signal/Group/group_cipher.js +87 -0
  24. package/lib/Signal/Group/group_cipher.js.map +1 -0
  25. package/lib/Signal/Group/index.d.ts +12 -0
  26. package/lib/Signal/Group/index.d.ts.map +1 -0
  27. package/lib/Signal/Group/index.js +79 -0
  28. package/lib/Signal/Group/index.js.map +1 -0
  29. package/lib/Signal/Group/keyhelper.d.ts +11 -0
  30. package/lib/Signal/Group/keyhelper.d.ts.map +1 -0
  31. package/lib/Signal/Group/keyhelper.js +27 -0
  32. package/lib/Signal/Group/keyhelper.js.map +1 -0
  33. package/lib/Signal/Group/sender-chain-key.d.ts +14 -0
  34. package/lib/Signal/Group/sender-chain-key.d.ts.map +1 -0
  35. package/lib/Signal/Group/sender-chain-key.js +33 -0
  36. package/lib/Signal/Group/sender-chain-key.js.map +1 -0
  37. package/lib/Signal/Group/sender-key-distribution-message.d.ts +17 -0
  38. package/lib/Signal/Group/sender-key-distribution-message.d.ts.map +1 -0
  39. package/lib/Signal/Group/sender-key-distribution-message.js +62 -0
  40. package/lib/Signal/Group/sender-key-distribution-message.js.map +1 -0
  41. package/lib/Signal/Group/sender-key-message.d.ts +19 -0
  42. package/lib/Signal/Group/sender-key-message.d.ts.map +1 -0
  43. package/lib/Signal/Group/sender-key-message.js +68 -0
  44. package/lib/Signal/Group/sender-key-message.js.map +1 -0
  45. package/lib/Signal/Group/sender-key-name.d.ts +18 -0
  46. package/lib/Signal/Group/sender-key-name.d.ts.map +1 -0
  47. package/lib/Signal/Group/sender-key-name.js +54 -0
  48. package/lib/Signal/Group/sender-key-name.js.map +1 -0
  49. package/lib/Signal/Group/sender-key-record.d.ts +31 -0
  50. package/lib/Signal/Group/sender-key-record.d.ts.map +1 -0
  51. package/lib/Signal/Group/sender-key-record.js +48 -0
  52. package/lib/Signal/Group/sender-key-record.js.map +1 -0
  53. package/lib/Signal/Group/sender-key-state.d.ts +39 -0
  54. package/lib/Signal/Group/sender-key-state.d.ts.map +1 -0
  55. package/lib/Signal/Group/sender-key-state.js +88 -0
  56. package/lib/Signal/Group/sender-key-state.js.map +1 -0
  57. package/lib/Signal/Group/sender-message-key.d.ts +12 -0
  58. package/lib/Signal/Group/sender-message-key.d.ts.map +1 -0
  59. package/lib/Signal/Group/sender-message-key.js +33 -0
  60. package/lib/Signal/Group/sender-message-key.js.map +1 -0
  61. package/lib/Signal/libsignal.d.ts +5 -0
  62. package/lib/Signal/libsignal.d.ts.map +1 -0
  63. package/lib/Signal/libsignal.js +575 -0
  64. package/lib/Signal/libsignal.js.map +1 -0
  65. package/lib/Signal/lid-mapping.d.ts +23 -0
  66. package/lib/Signal/lid-mapping.d.ts.map +1 -0
  67. package/lib/Signal/lid-mapping.js +309 -0
  68. package/lib/Signal/lid-mapping.js.map +1 -0
  69. package/lib/Socket/Client/index.d.ts +3 -0
  70. package/lib/Socket/Client/index.d.ts.map +1 -0
  71. package/lib/Socket/Client/index.js +27 -0
  72. package/lib/Socket/Client/index.js.map +1 -0
  73. package/lib/Socket/Client/types.d.ts +16 -0
  74. package/lib/Socket/Client/types.d.ts.map +1 -0
  75. package/lib/Socket/Client/types.js +18 -0
  76. package/lib/Socket/Client/types.js.map +1 -0
  77. package/lib/Socket/Client/websocket.d.ts +13 -0
  78. package/lib/Socket/Client/websocket.d.ts.map +1 -0
  79. package/lib/Socket/Client/websocket.js +62 -0
  80. package/lib/Socket/Client/websocket.js.map +1 -0
  81. package/lib/Socket/business.d.ts +217 -0
  82. package/lib/Socket/business.d.ts.map +1 -0
  83. package/lib/Socket/business.js +368 -0
  84. package/lib/Socket/business.js.map +1 -0
  85. package/lib/Socket/chats.d.ts +124 -0
  86. package/lib/Socket/chats.d.ts.map +1 -0
  87. package/lib/Socket/chats.js +1340 -0
  88. package/lib/Socket/chats.js.map +1 -0
  89. package/lib/Socket/communities.d.ts +273 -0
  90. package/lib/Socket/communities.d.ts.map +1 -0
  91. package/lib/Socket/communities.js +522 -0
  92. package/lib/Socket/communities.js.map +1 -0
  93. package/lib/Socket/groups.d.ts +161 -0
  94. package/lib/Socket/groups.d.ts.map +1 -0
  95. package/lib/Socket/groups.js +430 -0
  96. package/lib/Socket/groups.js.map +1 -0
  97. package/lib/Socket/index.d.ts +260 -0
  98. package/lib/Socket/index.d.ts.map +1 -0
  99. package/lib/Socket/index.js +11 -0
  100. package/lib/Socket/index.js.map +1 -0
  101. package/lib/Socket/luxu.js +422 -0
  102. package/lib/Socket/messages-recv.d.ts +203 -0
  103. package/lib/Socket/messages-recv.d.ts.map +1 -0
  104. package/lib/Socket/messages-recv.js +2374 -0
  105. package/lib/Socket/messages-recv.js.map +1 -0
  106. package/lib/Socket/messages-send.d.ts +199 -0
  107. package/lib/Socket/messages-send.d.ts.map +1 -0
  108. package/lib/Socket/messages-send.js +1502 -0
  109. package/lib/Socket/messages-send.js.map +1 -0
  110. package/lib/Socket/mex.d.ts +3 -0
  111. package/lib/Socket/mex.d.ts.map +1 -0
  112. package/lib/Socket/mex.js +55 -0
  113. package/lib/Socket/mex.js.map +1 -0
  114. package/lib/Socket/newsletter.d.ts +170 -0
  115. package/lib/Socket/newsletter.d.ts.map +1 -0
  116. package/lib/Socket/newsletter.js +238 -0
  117. package/lib/Socket/newsletter.js.map +1 -0
  118. package/lib/Socket/socket.d.ts +59 -0
  119. package/lib/Socket/socket.d.ts.map +1 -0
  120. package/lib/Socket/socket.js +1022 -0
  121. package/lib/Socket/socket.js.map +1 -0
  122. package/lib/Store/index.d.ts +3 -0
  123. package/lib/Store/index.js +10 -0
  124. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  125. package/lib/Store/make-cache-manager-store.js +82 -0
  126. package/lib/Store/make-in-memory-store.d.ts +118 -0
  127. package/lib/Store/make-in-memory-store.js +429 -0
  128. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  129. package/lib/Store/make-ordered-dictionary.js +81 -0
  130. package/lib/Store/object-repository.d.ts +10 -0
  131. package/lib/Store/object-repository.js +27 -0
  132. package/lib/Types/Auth.d.ts +117 -0
  133. package/lib/Types/Auth.d.ts.map +1 -0
  134. package/lib/Types/Auth.js +5 -0
  135. package/lib/Types/Auth.js.map +1 -0
  136. package/lib/Types/Bussines.d.ts +25 -0
  137. package/lib/Types/Bussines.d.ts.map +1 -0
  138. package/lib/Types/Bussines.js +5 -0
  139. package/lib/Types/Bussines.js.map +1 -0
  140. package/lib/Types/Call.d.ts +15 -0
  141. package/lib/Types/Call.d.ts.map +1 -0
  142. package/lib/Types/Call.js +5 -0
  143. package/lib/Types/Call.js.map +1 -0
  144. package/lib/Types/Chat.d.ts +124 -0
  145. package/lib/Types/Chat.d.ts.map +1 -0
  146. package/lib/Types/Chat.js +8 -0
  147. package/lib/Types/Chat.js.map +1 -0
  148. package/lib/Types/Contact.d.ts +26 -0
  149. package/lib/Types/Contact.d.ts.map +1 -0
  150. package/lib/Types/Contact.js +5 -0
  151. package/lib/Types/Contact.js.map +1 -0
  152. package/lib/Types/Events.d.ts +256 -0
  153. package/lib/Types/Events.d.ts.map +1 -0
  154. package/lib/Types/Events.js +3 -0
  155. package/lib/Types/Events.js.map +1 -0
  156. package/lib/Types/GroupMetadata.d.ts +71 -0
  157. package/lib/Types/GroupMetadata.d.ts.map +1 -0
  158. package/lib/Types/GroupMetadata.js +5 -0
  159. package/lib/Types/GroupMetadata.js.map +1 -0
  160. package/lib/Types/Label.d.ts +47 -0
  161. package/lib/Types/Label.d.ts.map +1 -0
  162. package/lib/Types/Label.js +31 -0
  163. package/lib/Types/Label.js.map +1 -0
  164. package/lib/Types/LabelAssociation.d.ts +30 -0
  165. package/lib/Types/LabelAssociation.d.ts.map +1 -0
  166. package/lib/Types/LabelAssociation.js +13 -0
  167. package/lib/Types/LabelAssociation.js.map +1 -0
  168. package/lib/Types/Message.d.ts +320 -0
  169. package/lib/Types/Message.d.ts.map +1 -0
  170. package/lib/Types/Message.js +23 -0
  171. package/lib/Types/Message.js.map +1 -0
  172. package/lib/Types/Mex.d.ts +141 -0
  173. package/lib/Types/Mex.d.ts.map +1 -0
  174. package/lib/Types/Mex.js +43 -0
  175. package/lib/Types/Mex.js.map +1 -0
  176. package/lib/Types/Product.d.ts +79 -0
  177. package/lib/Types/Product.d.ts.map +1 -0
  178. package/lib/Types/Product.js +5 -0
  179. package/lib/Types/Product.js.map +1 -0
  180. package/lib/Types/Signal.d.ts +87 -0
  181. package/lib/Types/Signal.d.ts.map +1 -0
  182. package/lib/Types/Signal.js +3 -0
  183. package/lib/Types/Signal.js.map +1 -0
  184. package/lib/Types/Socket.d.ts +136 -0
  185. package/lib/Types/Socket.d.ts.map +1 -0
  186. package/lib/Types/Socket.js +4 -0
  187. package/lib/Types/Socket.js.map +1 -0
  188. package/lib/Types/State.d.ts +97 -0
  189. package/lib/Types/State.d.ts.map +1 -0
  190. package/lib/Types/State.js +62 -0
  191. package/lib/Types/State.js.map +1 -0
  192. package/lib/Types/USync.d.ts +26 -0
  193. package/lib/Types/USync.d.ts.map +1 -0
  194. package/lib/Types/USync.js +3 -0
  195. package/lib/Types/USync.js.map +1 -0
  196. package/lib/Types/index.d.ts +65 -0
  197. package/lib/Types/index.d.ts.map +1 -0
  198. package/lib/Types/index.js +167 -0
  199. package/lib/Types/index.js.map +1 -0
  200. package/lib/Utils/auth-utils.d.ts +24 -0
  201. package/lib/Utils/auth-utils.d.ts.map +1 -0
  202. package/lib/Utils/auth-utils.js +332 -0
  203. package/lib/Utils/auth-utils.js.map +1 -0
  204. package/lib/Utils/browser-utils.d.ts +4 -0
  205. package/lib/Utils/browser-utils.d.ts.map +1 -0
  206. package/lib/Utils/browser-utils.js +35 -0
  207. package/lib/Utils/browser-utils.js.map +1 -0
  208. package/lib/Utils/business.d.ts +23 -0
  209. package/lib/Utils/business.d.ts.map +1 -0
  210. package/lib/Utils/business.js +247 -0
  211. package/lib/Utils/business.js.map +1 -0
  212. package/lib/Utils/chat-utils.d.ts +100 -0
  213. package/lib/Utils/chat-utils.d.ts.map +1 -0
  214. package/lib/Utils/chat-utils.js +971 -0
  215. package/lib/Utils/chat-utils.js.map +1 -0
  216. package/lib/Utils/companion-reg-client-utils.d.ts +17 -0
  217. package/lib/Utils/companion-reg-client-utils.d.ts.map +1 -0
  218. package/lib/Utils/companion-reg-client-utils.js +43 -0
  219. package/lib/Utils/companion-reg-client-utils.js.map +1 -0
  220. package/lib/Utils/crypto.d.ts +37 -0
  221. package/lib/Utils/crypto.d.ts.map +1 -0
  222. package/lib/Utils/crypto.js +160 -0
  223. package/lib/Utils/crypto.js.map +1 -0
  224. package/lib/Utils/decode-wa-message.d.ts +66 -0
  225. package/lib/Utils/decode-wa-message.d.ts.map +1 -0
  226. package/lib/Utils/decode-wa-message.js +380 -0
  227. package/lib/Utils/decode-wa-message.js.map +1 -0
  228. package/lib/Utils/event-buffer.d.ts +36 -0
  229. package/lib/Utils/event-buffer.d.ts.map +1 -0
  230. package/lib/Utils/event-buffer.js +666 -0
  231. package/lib/Utils/event-buffer.js.map +1 -0
  232. package/lib/Utils/generics.d.ts +91 -0
  233. package/lib/Utils/generics.d.ts.map +1 -0
  234. package/lib/Utils/generics.js +449 -0
  235. package/lib/Utils/generics.js.map +1 -0
  236. package/lib/Utils/history.d.ts +24 -0
  237. package/lib/Utils/history.d.ts.map +1 -0
  238. package/lib/Utils/history.js +160 -0
  239. package/lib/Utils/history.js.map +1 -0
  240. package/lib/Utils/identity-change-handler.d.ts +44 -0
  241. package/lib/Utils/identity-change-handler.d.ts.map +1 -0
  242. package/lib/Utils/identity-change-handler.js +94 -0
  243. package/lib/Utils/identity-change-handler.js.map +1 -0
  244. package/lib/Utils/index.d.ts +22 -0
  245. package/lib/Utils/index.d.ts.map +1 -0
  246. package/lib/Utils/index.js +236 -0
  247. package/lib/Utils/index.js.map +1 -0
  248. package/lib/Utils/link-preview.d.ts +21 -0
  249. package/lib/Utils/link-preview.d.ts.map +1 -0
  250. package/lib/Utils/link-preview.js +102 -0
  251. package/lib/Utils/link-preview.js.map +1 -0
  252. package/lib/Utils/logger.d.ts +12 -0
  253. package/lib/Utils/logger.d.ts.map +1 -0
  254. package/lib/Utils/logger.js +11 -0
  255. package/lib/Utils/logger.js.map +1 -0
  256. package/lib/Utils/lt-hash.d.ts +8 -0
  257. package/lib/Utils/lt-hash.d.ts.map +1 -0
  258. package/lib/Utils/lt-hash.js +14 -0
  259. package/lib/Utils/lt-hash.js.map +1 -0
  260. package/lib/Utils/make-mutex.d.ts +9 -0
  261. package/lib/Utils/make-mutex.d.ts.map +1 -0
  262. package/lib/Utils/make-mutex.js +43 -0
  263. package/lib/Utils/make-mutex.js.map +1 -0
  264. package/lib/Utils/message-retry-manager.d.ts +115 -0
  265. package/lib/Utils/message-retry-manager.d.ts.map +1 -0
  266. package/lib/Utils/message-retry-manager.js +283 -0
  267. package/lib/Utils/message-retry-manager.js.map +1 -0
  268. package/lib/Utils/messages-media.d.ts +133 -0
  269. package/lib/Utils/messages-media.d.ts.map +1 -0
  270. package/lib/Utils/messages-media.js +914 -0
  271. package/lib/Utils/messages-media.js.map +1 -0
  272. package/lib/Utils/messages.d.ts +91 -0
  273. package/lib/Utils/messages.d.ts.map +1 -0
  274. package/lib/Utils/messages.js +963 -0
  275. package/lib/Utils/messages.js.map +1 -0
  276. package/lib/Utils/noise-handler.d.ts +20 -0
  277. package/lib/Utils/noise-handler.d.ts.map +1 -0
  278. package/lib/Utils/noise-handler.js +238 -0
  279. package/lib/Utils/noise-handler.js.map +1 -0
  280. package/lib/Utils/offline-node-processor.d.ts +17 -0
  281. package/lib/Utils/offline-node-processor.d.ts.map +1 -0
  282. package/lib/Utils/offline-node-processor.js +54 -0
  283. package/lib/Utils/offline-node-processor.js.map +1 -0
  284. package/lib/Utils/pre-key-manager.d.ts +28 -0
  285. package/lib/Utils/pre-key-manager.d.ts.map +1 -0
  286. package/lib/Utils/pre-key-manager.js +109 -0
  287. package/lib/Utils/pre-key-manager.js.map +1 -0
  288. package/lib/Utils/process-message.d.ts +60 -0
  289. package/lib/Utils/process-message.d.ts.map +1 -0
  290. package/lib/Utils/process-message.js +710 -0
  291. package/lib/Utils/process-message.js.map +1 -0
  292. package/lib/Utils/reporting-utils.d.ts +11 -0
  293. package/lib/Utils/reporting-utils.d.ts.map +1 -0
  294. package/lib/Utils/reporting-utils.js +586 -0
  295. package/lib/Utils/reporting-utils.js.map +1 -0
  296. package/lib/Utils/signal.d.ts +47 -0
  297. package/lib/Utils/signal.d.ts.map +1 -0
  298. package/lib/Utils/signal.js +279 -0
  299. package/lib/Utils/signal.js.map +1 -0
  300. package/lib/Utils/stanza-ack.d.ts +11 -0
  301. package/lib/Utils/stanza-ack.d.ts.map +1 -0
  302. package/lib/Utils/stanza-ack.js +47 -0
  303. package/lib/Utils/stanza-ack.js.map +1 -0
  304. package/lib/Utils/sync-action-utils.d.ts +19 -0
  305. package/lib/Utils/sync-action-utils.d.ts.map +1 -0
  306. package/lib/Utils/sync-action-utils.js +61 -0
  307. package/lib/Utils/sync-action-utils.js.map +1 -0
  308. package/lib/Utils/tc-token-utils.d.ts +37 -0
  309. package/lib/Utils/tc-token-utils.d.ts.map +1 -0
  310. package/lib/Utils/tc-token-utils.js +176 -0
  311. package/lib/Utils/tc-token-utils.js.map +1 -0
  312. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  313. package/lib/Utils/use-multi-file-auth-state.d.ts.map +1 -0
  314. package/lib/Utils/use-multi-file-auth-state.js +124 -0
  315. package/lib/Utils/use-multi-file-auth-state.js.map +1 -0
  316. package/lib/Utils/validate-connection.d.ts +11 -0
  317. package/lib/Utils/validate-connection.d.ts.map +1 -0
  318. package/lib/Utils/validate-connection.js +229 -0
  319. package/lib/Utils/validate-connection.js.map +1 -0
  320. package/lib/WABinary/constants.d.ts +28 -0
  321. package/lib/WABinary/constants.d.ts.map +1 -0
  322. package/lib/WABinary/constants.js +42 -0
  323. package/lib/WABinary/constants.js.map +1 -0
  324. package/lib/WABinary/decode.d.ts +7 -0
  325. package/lib/WABinary/decode.d.ts.map +1 -0
  326. package/lib/WABinary/decode.js +271 -0
  327. package/lib/WABinary/decode.js.map +1 -0
  328. package/lib/WABinary/encode.d.ts +3 -0
  329. package/lib/WABinary/encode.d.ts.map +1 -0
  330. package/lib/WABinary/encode.js +226 -0
  331. package/lib/WABinary/encode.js.map +1 -0
  332. package/lib/WABinary/generic-utils.d.ts +15 -0
  333. package/lib/WABinary/generic-utils.d.ts.map +1 -0
  334. package/lib/WABinary/generic-utils.js +219 -0
  335. package/lib/WABinary/generic-utils.js.map +1 -0
  336. package/lib/WABinary/index.d.ts +6 -0
  337. package/lib/WABinary/index.d.ts.map +1 -0
  338. package/lib/WABinary/index.js +60 -0
  339. package/lib/WABinary/index.js.map +1 -0
  340. package/lib/WABinary/jid-utils.d.ts +48 -0
  341. package/lib/WABinary/jid-utils.d.ts.map +1 -0
  342. package/lib/WABinary/jid-utils.js +121 -0
  343. package/lib/WABinary/jid-utils.js.map +1 -0
  344. package/lib/WABinary/types.d.ts +19 -0
  345. package/lib/WABinary/types.d.ts.map +1 -0
  346. package/lib/WABinary/types.js +4 -0
  347. package/lib/WABinary/types.js.map +1 -0
  348. package/lib/WAM/BinaryInfo.d.ts +9 -0
  349. package/lib/WAM/BinaryInfo.d.ts.map +1 -0
  350. package/lib/WAM/BinaryInfo.js +17 -0
  351. package/lib/WAM/BinaryInfo.js.map +1 -0
  352. package/lib/WAM/constants.d.ts +40 -0
  353. package/lib/WAM/constants.d.ts.map +1 -0
  354. package/lib/WAM/constants.js +1 -0
  355. package/lib/WAM/constants.js.map +1 -0
  356. package/lib/WAM/encode.d.ts +3 -0
  357. package/lib/WAM/encode.d.ts.map +1 -0
  358. package/lib/WAM/encode.js +150 -0
  359. package/lib/WAM/encode.js.map +1 -0
  360. package/lib/WAM/index.d.ts +4 -0
  361. package/lib/WAM/index.d.ts.map +1 -0
  362. package/lib/WAM/index.js +38 -0
  363. package/lib/WAM/index.js.map +1 -0
  364. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +10 -0
  365. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts.map +1 -0
  366. package/lib/WAUSync/Protocols/USyncContactProtocol.js +63 -0
  367. package/lib/WAUSync/Protocols/USyncContactProtocol.js.map +1 -0
  368. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +23 -0
  369. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts.map +1 -0
  370. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +65 -0
  371. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js.map +1 -0
  372. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +13 -0
  373. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts.map +1 -0
  374. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +34 -0
  375. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js.map +1 -0
  376. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +13 -0
  377. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts.map +1 -0
  378. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +43 -0
  379. package/lib/WAUSync/Protocols/USyncStatusProtocol.js.map +1 -0
  380. package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +10 -0
  381. package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts.map +1 -0
  382. package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +32 -0
  383. package/lib/WAUSync/Protocols/USyncUsernameProtocol.js.map +1 -0
  384. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +26 -0
  385. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts.map +1 -0
  386. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +68 -0
  387. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js.map +1 -0
  388. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +10 -0
  389. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts.map +1 -0
  390. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +37 -0
  391. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js.map +1 -0
  392. package/lib/WAUSync/Protocols/index.d.ts +6 -0
  393. package/lib/WAUSync/Protocols/index.d.ts.map +1 -0
  394. package/lib/WAUSync/Protocols/index.js +60 -0
  395. package/lib/WAUSync/Protocols/index.js.map +1 -0
  396. package/lib/WAUSync/USyncQuery.d.ts +30 -0
  397. package/lib/WAUSync/USyncQuery.d.ts.map +1 -0
  398. package/lib/WAUSync/USyncQuery.js +103 -0
  399. package/lib/WAUSync/USyncQuery.js.map +1 -0
  400. package/lib/WAUSync/USyncUser.d.ts +17 -0
  401. package/lib/WAUSync/USyncUser.d.ts.map +1 -0
  402. package/lib/WAUSync/USyncUser.js +38 -0
  403. package/lib/WAUSync/USyncUser.js.map +1 -0
  404. package/lib/WAUSync/index.d.ts +4 -0
  405. package/lib/WAUSync/index.d.ts.map +1 -0
  406. package/lib/WAUSync/index.js +38 -0
  407. package/lib/WAUSync/index.js.map +1 -0
  408. package/lib/index.d.ts +13 -0
  409. package/lib/index.d.ts.map +1 -0
  410. package/lib/index.js +133 -0
  411. package/lib/index.js.map +1 -0
  412. package/package.json +72 -0
  413. package/scripts/patch-deps.js +35 -0
@@ -0,0 +1,666 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.makeEventBuffer = void 0;
7
+ var _events = _interopRequireDefault(require("events"));
8
+ var _index = require("../Types/index.js");
9
+ var _generics = require("./generics.js");
10
+ var _messages = require("./messages.js");
11
+ var _processMessage = require("./process-message.js");
12
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
+ const BUFFERABLE_EVENT = ['messaging-history.set', 'chats.upsert', 'chats.update', 'chats.delete', 'contacts.upsert', 'contacts.update', 'messages.upsert', 'messages.update', 'messages.delete', 'messages.reaction', 'message-receipt.update', 'groups.update'];
14
+ const BUFFERABLE_EVENT_SET = new Set(BUFFERABLE_EVENT);
15
+ /**
16
+ * The event buffer logically consolidates different events into a single event
17
+ * making the data processing more efficient.
18
+ */
19
+ const makeEventBuffer = logger => {
20
+ const ev = new _events.default();
21
+ const historyCache = new Set();
22
+ let data = makeBufferData();
23
+ let isBuffering = false;
24
+ let bufferTimeout = null;
25
+ let flushPendingTimeout = null; // Add a specific timer for the debounced flush to prevent leak
26
+ let bufferCount = 0;
27
+ const MAX_HISTORY_CACHE_SIZE = 10000; // Limit the history cache size to prevent memory bloat
28
+ const BUFFER_TIMEOUT_MS = 30000; // 30 seconds
29
+ // take the generic event and fire it as a xrl event
30
+ ev.on('event', map => {
31
+ for (const event in map) {
32
+ ev.emit(event, map[event]);
33
+ }
34
+ });
35
+ function buffer() {
36
+ if (!isBuffering) {
37
+ logger.debug('Event buffer activated');
38
+ isBuffering = true;
39
+ bufferCount = 0;
40
+ if (bufferTimeout) {
41
+ clearTimeout(bufferTimeout);
42
+ }
43
+ bufferTimeout = setTimeout(() => {
44
+ if (isBuffering) {
45
+ logger.warn('Buffer timeout reached, auto-flushing');
46
+ flush();
47
+ }
48
+ }, BUFFER_TIMEOUT_MS);
49
+ }
50
+ // Always increment count when requested
51
+ bufferCount++;
52
+ }
53
+ function flush() {
54
+ if (!isBuffering) {
55
+ return false;
56
+ }
57
+ logger.debug({
58
+ bufferCount
59
+ }, 'Flushing event buffer');
60
+ isBuffering = false;
61
+ bufferCount = 0;
62
+ // Clear timeout
63
+ if (bufferTimeout) {
64
+ clearTimeout(bufferTimeout);
65
+ bufferTimeout = null;
66
+ }
67
+ if (flushPendingTimeout) {
68
+ clearTimeout(flushPendingTimeout);
69
+ flushPendingTimeout = null;
70
+ }
71
+ // Clear history cache if it exceeds the max size
72
+ if (historyCache.size > MAX_HISTORY_CACHE_SIZE) {
73
+ logger.debug({
74
+ cacheSize: historyCache.size
75
+ }, 'Clearing history cache');
76
+ historyCache.clear();
77
+ }
78
+ const newData = makeBufferData();
79
+ const chatUpdates = Object.values(data.chatUpdates);
80
+ let conditionalChatUpdatesLeft = 0;
81
+ for (const update of chatUpdates) {
82
+ if (update.conditional) {
83
+ conditionalChatUpdatesLeft += 1;
84
+ newData.chatUpdates[update.id] = update;
85
+ delete data.chatUpdates[update.id];
86
+ }
87
+ }
88
+ const consolidatedData = consolidateEvents(data);
89
+ if (Object.keys(consolidatedData).length) {
90
+ ev.emit('event', consolidatedData);
91
+ }
92
+ data = newData;
93
+ logger.trace({
94
+ conditionalChatUpdatesLeft
95
+ }, 'released buffered events');
96
+ return true;
97
+ }
98
+ return {
99
+ process(handler) {
100
+ const listener = async map => {
101
+ await handler(map);
102
+ };
103
+ ev.on('event', listener);
104
+ return () => {
105
+ ev.off('event', listener);
106
+ };
107
+ },
108
+ emit(event, evData) {
109
+ // Check if this is a messages.upsert with a different type than what's buffered
110
+ // If so, flush the buffered messages first to avoid type overshadowing
111
+ if (event === 'messages.upsert') {
112
+ const {
113
+ type
114
+ } = evData;
115
+ const existingUpserts = Object.values(data.messageUpserts);
116
+ if (existingUpserts.length > 0) {
117
+ const bufferedType = existingUpserts[0].type;
118
+ if (bufferedType !== type) {
119
+ logger.debug({
120
+ bufferedType,
121
+ newType: type
122
+ }, 'messages.upsert type mismatch, emitting buffered messages');
123
+ // Emit the buffered messages with their correct type
124
+ ev.emit('event', {
125
+ 'messages.upsert': {
126
+ messages: existingUpserts.map(m => m.message),
127
+ type: bufferedType
128
+ }
129
+ });
130
+ // Clear the message upserts from the buffer
131
+ data.messageUpserts = {};
132
+ }
133
+ }
134
+ }
135
+ if (isBuffering && BUFFERABLE_EVENT_SET.has(event)) {
136
+ append(data, historyCache, event, evData, logger);
137
+ return true;
138
+ }
139
+ return ev.emit('event', {
140
+ [event]: evData
141
+ });
142
+ },
143
+ isBuffering() {
144
+ return isBuffering;
145
+ },
146
+ buffer,
147
+ flush,
148
+ createBufferedFunction(work) {
149
+ return async (...args) => {
150
+ buffer();
151
+ try {
152
+ const result = await work(...args);
153
+ // If this is the only buffer, flush after a small delay
154
+ if (bufferCount === 1) {
155
+ setTimeout(() => {
156
+ if (isBuffering && bufferCount === 1) {
157
+ flush();
158
+ }
159
+ }, 100); // Small delay to allow nested buffers
160
+ }
161
+ return result;
162
+ } catch (error) {
163
+ throw error;
164
+ } finally {
165
+ bufferCount = Math.max(0, bufferCount - 1);
166
+ if (bufferCount === 0) {
167
+ // Only schedule ONE timeout, not 10,000
168
+ if (!flushPendingTimeout) {
169
+ flushPendingTimeout = setTimeout(flush, 100);
170
+ }
171
+ }
172
+ }
173
+ };
174
+ },
175
+ on: (...args) => ev.on(...args),
176
+ off: (...args) => ev.off(...args),
177
+ removeAllListeners: (...args) => ev.removeAllListeners(...args),
178
+ destroy() {
179
+ // Clear buffer timeout
180
+ if (bufferTimeout) {
181
+ clearTimeout(bufferTimeout);
182
+ bufferTimeout = null;
183
+ }
184
+ if (flushPendingTimeout) {
185
+ clearTimeout(flushPendingTimeout);
186
+ flushPendingTimeout = null;
187
+ }
188
+ // Clear history cache
189
+ historyCache.clear();
190
+ // Reset buffer data
191
+ data = makeBufferData();
192
+ isBuffering = false;
193
+ bufferCount = 0;
194
+ // Remove all listeners
195
+ ev.removeAllListeners();
196
+ logger.debug('Event buffer destroyed');
197
+ }
198
+ };
199
+ };
200
+ exports.makeEventBuffer = makeEventBuffer;
201
+ const makeBufferData = () => {
202
+ return {
203
+ historySets: {
204
+ chats: {},
205
+ messages: {},
206
+ contacts: {},
207
+ isLatest: false,
208
+ empty: true
209
+ },
210
+ chatUpserts: {},
211
+ chatUpdates: {},
212
+ chatDeletes: new Set(),
213
+ contactUpserts: {},
214
+ contactUpdates: {},
215
+ messageUpserts: {},
216
+ messageUpdates: {},
217
+ messageReactions: {},
218
+ messageDeletes: {},
219
+ messageReceipts: {},
220
+ groupUpdates: {}
221
+ };
222
+ };
223
+ function append(data, historyCache, event,
224
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
225
+ eventData, logger) {
226
+ switch (event) {
227
+ case 'messaging-history.set':
228
+ for (const chat of eventData.chats) {
229
+ const id = chat.id || '';
230
+ const existingChat = data.historySets.chats[id];
231
+ if (existingChat) {
232
+ existingChat.endOfHistoryTransferType = chat.endOfHistoryTransferType;
233
+ }
234
+ if (!existingChat && !historyCache.has(id)) {
235
+ data.historySets.chats[id] = chat;
236
+ historyCache.add(id);
237
+ absorbingChatUpdate(chat);
238
+ }
239
+ }
240
+ for (const contact of eventData.contacts) {
241
+ const existingContact = data.historySets.contacts[contact.id];
242
+ if (existingContact) {
243
+ Object.assign(existingContact, (0, _generics.trimUndefined)(contact));
244
+ } else {
245
+ const historyContactId = `c:${contact.id}`;
246
+ const hasAnyName = contact.notify || contact.name || contact.verifiedName;
247
+ if (!historyCache.has(historyContactId) || hasAnyName) {
248
+ data.historySets.contacts[contact.id] = contact;
249
+ historyCache.add(historyContactId);
250
+ }
251
+ }
252
+ }
253
+ for (const message of eventData.messages) {
254
+ const key = stringifyMessageKey(message.key);
255
+ const existingMsg = data.historySets.messages[key];
256
+ if (!existingMsg && !historyCache.has(key)) {
257
+ data.historySets.messages[key] = message;
258
+ historyCache.add(key);
259
+ }
260
+ }
261
+ data.historySets.empty = false;
262
+ data.historySets.syncType = eventData.syncType;
263
+ if (eventData.pastParticipants?.length) {
264
+ const merged = new Map();
265
+ const sigOf = p => `${p.userJid || ''}:${p.leaveTs || ''}:${p.leaveReason || ''}`;
266
+ const ingest = entry => {
267
+ const key = entry.groupJid ?? JSON.stringify(entry);
268
+ const existing = merged.get(key);
269
+ if (!existing) {
270
+ merged.set(key, {
271
+ ...entry,
272
+ pastParticipants: [...(entry.pastParticipants || [])]
273
+ });
274
+ return;
275
+ }
276
+ const seen = new Set((existing.pastParticipants || []).map(sigOf));
277
+ for (const p of entry.pastParticipants || []) {
278
+ const sig = sigOf(p);
279
+ if (!seen.has(sig)) {
280
+ existing.pastParticipants.push(p);
281
+ seen.add(sig);
282
+ }
283
+ }
284
+ };
285
+ for (const entry of data.historySets.pastParticipants || []) ingest(entry);
286
+ for (const entry of eventData.pastParticipants) ingest(entry);
287
+ data.historySets.pastParticipants = [...merged.values()];
288
+ }
289
+ data.historySets.progress = eventData.progress;
290
+ data.historySets.chunkOrder = eventData.chunkOrder;
291
+ data.historySets.peerDataRequestSessionId = eventData.peerDataRequestSessionId;
292
+ data.historySets.isLatest = eventData.isLatest || data.historySets.isLatest;
293
+ break;
294
+ case 'chats.upsert':
295
+ for (const chat of eventData) {
296
+ const id = chat.id || '';
297
+ let upsert = data.chatUpserts[id];
298
+ if (id && !upsert) {
299
+ upsert = data.historySets.chats[id];
300
+ if (upsert) {
301
+ logger.debug({
302
+ chatId: id
303
+ }, 'absorbed chat upsert in chat set');
304
+ }
305
+ }
306
+ if (upsert) {
307
+ upsert = concatChats(upsert, chat);
308
+ } else {
309
+ upsert = chat;
310
+ data.chatUpserts[id] = upsert;
311
+ }
312
+ absorbingChatUpdate(upsert);
313
+ if (data.chatDeletes.has(id)) {
314
+ data.chatDeletes.delete(id);
315
+ }
316
+ }
317
+ break;
318
+ case 'chats.update':
319
+ for (const update of eventData) {
320
+ const chatId = update.id;
321
+ const conditionMatches = update.conditional ? update.conditional(data) : true;
322
+ if (conditionMatches) {
323
+ delete update.conditional;
324
+ // if there is an existing upsert, merge the update into it
325
+ const upsert = data.historySets.chats[chatId] || data.chatUpserts[chatId];
326
+ if (upsert) {
327
+ concatChats(upsert, update);
328
+ } else {
329
+ // merge the update into the existing update
330
+ const chatUpdate = data.chatUpdates[chatId] || {};
331
+ data.chatUpdates[chatId] = concatChats(chatUpdate, update);
332
+ }
333
+ } else if (conditionMatches === undefined) {
334
+ // condition yet to be fulfilled
335
+ data.chatUpdates[chatId] = update;
336
+ }
337
+ // otherwise -- condition not met, update is invalid
338
+ // if the chat has been updated
339
+ // ignore any existing chat delete
340
+ if (data.chatDeletes.has(chatId)) {
341
+ data.chatDeletes.delete(chatId);
342
+ }
343
+ }
344
+ break;
345
+ case 'chats.delete':
346
+ for (const chatId of eventData) {
347
+ if (!data.chatDeletes.has(chatId)) {
348
+ data.chatDeletes.add(chatId);
349
+ }
350
+ // remove any prior updates & upserts
351
+ if (data.chatUpdates[chatId]) {
352
+ delete data.chatUpdates[chatId];
353
+ }
354
+ if (data.chatUpserts[chatId]) {
355
+ delete data.chatUpserts[chatId];
356
+ }
357
+ if (data.historySets.chats[chatId]) {
358
+ delete data.historySets.chats[chatId];
359
+ }
360
+ }
361
+ break;
362
+ case 'contacts.upsert':
363
+ for (const contact of eventData) {
364
+ let upsert = data.contactUpserts[contact.id];
365
+ if (!upsert) {
366
+ upsert = data.historySets.contacts[contact.id];
367
+ if (upsert) {
368
+ logger.debug({
369
+ contactId: contact.id
370
+ }, 'absorbed contact upsert in contact set');
371
+ }
372
+ }
373
+ if (upsert) {
374
+ upsert = Object.assign(upsert, (0, _generics.trimUndefined)(contact));
375
+ } else {
376
+ upsert = contact;
377
+ data.contactUpserts[contact.id] = upsert;
378
+ }
379
+ if (data.contactUpdates[contact.id]) {
380
+ upsert = Object.assign(data.contactUpdates[contact.id], (0, _generics.trimUndefined)(contact));
381
+ delete data.contactUpdates[contact.id];
382
+ }
383
+ }
384
+ break;
385
+ case 'contacts.update':
386
+ const contactUpdates = eventData;
387
+ for (const update of contactUpdates) {
388
+ const id = update.id;
389
+ // merge into prior upsert
390
+ const upsert = data.historySets.contacts[id] || data.contactUpserts[id];
391
+ if (upsert) {
392
+ Object.assign(upsert, update);
393
+ } else {
394
+ // merge into prior update
395
+ const contactUpdate = data.contactUpdates[id] || {};
396
+ data.contactUpdates[id] = Object.assign(contactUpdate, update);
397
+ }
398
+ }
399
+ break;
400
+ case 'messages.upsert':
401
+ const {
402
+ messages,
403
+ type
404
+ } = eventData;
405
+ for (const message of messages) {
406
+ const key = stringifyMessageKey(message.key);
407
+ let existing = data.messageUpserts[key]?.message;
408
+ if (!existing) {
409
+ existing = data.historySets.messages[key];
410
+ if (existing) {
411
+ logger.debug({
412
+ messageId: key
413
+ }, 'absorbed message upsert in message set');
414
+ }
415
+ }
416
+ if (existing) {
417
+ message.messageTimestamp = existing.messageTimestamp;
418
+ }
419
+ if (data.messageUpdates[key]) {
420
+ logger.debug('absorbed prior message update in message upsert');
421
+ Object.assign(message, data.messageUpdates[key].update);
422
+ delete data.messageUpdates[key];
423
+ }
424
+ if (data.historySets.messages[key]) {
425
+ data.historySets.messages[key] = message;
426
+ } else {
427
+ data.messageUpserts[key] = {
428
+ message,
429
+ type: type === 'notify' || data.messageUpserts[key]?.type === 'notify' ? 'notify' : type
430
+ };
431
+ }
432
+ }
433
+ break;
434
+ case 'messages.update':
435
+ const msgUpdates = eventData;
436
+ for (const {
437
+ key,
438
+ update
439
+ } of msgUpdates) {
440
+ const keyStr = stringifyMessageKey(key);
441
+ const existing = data.historySets.messages[keyStr] || data.messageUpserts[keyStr]?.message;
442
+ if (existing) {
443
+ Object.assign(existing, update);
444
+ // if the message was received & read by us
445
+ // the chat counter must have been incremented
446
+ // so we need to decrement it
447
+ if (update.status === _index.WAMessageStatus.READ && !key.fromMe) {
448
+ decrementChatReadCounterIfMsgDidUnread(existing);
449
+ }
450
+ } else {
451
+ const msgUpdate = data.messageUpdates[keyStr] || {
452
+ key,
453
+ update: {}
454
+ };
455
+ Object.assign(msgUpdate.update, update);
456
+ data.messageUpdates[keyStr] = msgUpdate;
457
+ }
458
+ }
459
+ break;
460
+ case 'messages.delete':
461
+ const deleteData = eventData;
462
+ if ('keys' in deleteData) {
463
+ const {
464
+ keys
465
+ } = deleteData;
466
+ for (const key of keys) {
467
+ const keyStr = stringifyMessageKey(key);
468
+ if (!data.messageDeletes[keyStr]) {
469
+ data.messageDeletes[keyStr] = key;
470
+ }
471
+ if (data.messageUpserts[keyStr]) {
472
+ delete data.messageUpserts[keyStr];
473
+ }
474
+ if (data.messageUpdates[keyStr]) {
475
+ delete data.messageUpdates[keyStr];
476
+ }
477
+ }
478
+ } else {
479
+ // TODO: add support
480
+ }
481
+ break;
482
+ case 'messages.reaction':
483
+ const reactions = eventData;
484
+ for (const {
485
+ key,
486
+ reaction
487
+ } of reactions) {
488
+ const keyStr = stringifyMessageKey(key);
489
+ const existing = data.messageUpserts[keyStr];
490
+ if (existing) {
491
+ (0, _messages.updateMessageWithReaction)(existing.message, reaction);
492
+ } else {
493
+ data.messageReactions[keyStr] = data.messageReactions[keyStr] || {
494
+ key,
495
+ reactions: []
496
+ };
497
+ (0, _messages.updateMessageWithReaction)(data.messageReactions[keyStr], reaction);
498
+ }
499
+ }
500
+ break;
501
+ case 'message-receipt.update':
502
+ const receipts = eventData;
503
+ for (const {
504
+ key,
505
+ receipt
506
+ } of receipts) {
507
+ const keyStr = stringifyMessageKey(key);
508
+ const existing = data.messageUpserts[keyStr];
509
+ if (existing) {
510
+ (0, _messages.updateMessageWithReceipt)(existing.message, receipt);
511
+ } else {
512
+ data.messageReceipts[keyStr] = data.messageReceipts[keyStr] || {
513
+ key,
514
+ userReceipt: []
515
+ };
516
+ (0, _messages.updateMessageWithReceipt)(data.messageReceipts[keyStr], receipt);
517
+ }
518
+ }
519
+ break;
520
+ case 'groups.update':
521
+ const groupUpdates = eventData;
522
+ for (const update of groupUpdates) {
523
+ const id = update.id;
524
+ const groupUpdate = data.groupUpdates[id] || {};
525
+ if (!data.groupUpdates[id]) {
526
+ data.groupUpdates[id] = Object.assign(groupUpdate, update);
527
+ }
528
+ }
529
+ break;
530
+ default:
531
+ throw new Error(`"${event}" cannot be buffered`);
532
+ }
533
+ function absorbingChatUpdate(existing) {
534
+ const chatId = existing.id || '';
535
+ const update = data.chatUpdates[chatId];
536
+ if (update) {
537
+ const conditionMatches = update.conditional ? update.conditional(data) : true;
538
+ if (conditionMatches) {
539
+ delete update.conditional;
540
+ logger.debug({
541
+ chatId
542
+ }, 'absorbed chat update in existing chat');
543
+ Object.assign(existing, concatChats(update, existing));
544
+ delete data.chatUpdates[chatId];
545
+ } else if (conditionMatches === false) {
546
+ logger.debug({
547
+ chatId
548
+ }, 'chat update condition fail, removing');
549
+ delete data.chatUpdates[chatId];
550
+ }
551
+ }
552
+ }
553
+ function decrementChatReadCounterIfMsgDidUnread(message) {
554
+ // decrement chat unread counter
555
+ // if the message has already been marked read by us
556
+ const chatId = message.key.remoteJid;
557
+ const chat = data.chatUpdates[chatId] || data.chatUpserts[chatId];
558
+ if ((0, _processMessage.isRealMessage)(message) && (0, _processMessage.shouldIncrementChatUnread)(message) && typeof chat?.unreadCount === 'number' && chat.unreadCount > 0) {
559
+ logger.debug({
560
+ chatId: chat.id
561
+ }, 'decrementing chat counter');
562
+ chat.unreadCount -= 1;
563
+ if (chat.unreadCount === 0) {
564
+ delete chat.unreadCount;
565
+ }
566
+ }
567
+ }
568
+ }
569
+ function consolidateEvents(data) {
570
+ const map = {};
571
+ if (!data.historySets.empty) {
572
+ map['messaging-history.set'] = {
573
+ chats: Object.values(data.historySets.chats),
574
+ messages: Object.values(data.historySets.messages),
575
+ contacts: Object.values(data.historySets.contacts),
576
+ pastParticipants: data.historySets.pastParticipants,
577
+ syncType: data.historySets.syncType,
578
+ progress: data.historySets.progress,
579
+ isLatest: data.historySets.isLatest,
580
+ chunkOrder: data.historySets.chunkOrder,
581
+ peerDataRequestSessionId: data.historySets.peerDataRequestSessionId
582
+ };
583
+ }
584
+ const chatUpsertList = Object.values(data.chatUpserts);
585
+ if (chatUpsertList.length) {
586
+ map['chats.upsert'] = chatUpsertList;
587
+ }
588
+ const chatUpdateList = Object.values(data.chatUpdates);
589
+ if (chatUpdateList.length) {
590
+ map['chats.update'] = chatUpdateList;
591
+ }
592
+ const chatDeleteList = Array.from(data.chatDeletes);
593
+ if (chatDeleteList.length) {
594
+ map['chats.delete'] = chatDeleteList;
595
+ }
596
+ const messageUpsertList = Object.values(data.messageUpserts);
597
+ if (messageUpsertList.length) {
598
+ const type = messageUpsertList[0].type;
599
+ map['messages.upsert'] = {
600
+ messages: messageUpsertList.map(m => m.message),
601
+ type
602
+ };
603
+ }
604
+ const messageUpdateList = Object.values(data.messageUpdates);
605
+ if (messageUpdateList.length) {
606
+ map['messages.update'] = messageUpdateList;
607
+ }
608
+ const messageDeleteList = Object.values(data.messageDeletes);
609
+ if (messageDeleteList.length) {
610
+ map['messages.delete'] = {
611
+ keys: messageDeleteList
612
+ };
613
+ }
614
+ const messageReactionList = Object.values(data.messageReactions).flatMap(({
615
+ key,
616
+ reactions
617
+ }) => reactions.flatMap(reaction => ({
618
+ key,
619
+ reaction
620
+ })));
621
+ if (messageReactionList.length) {
622
+ map['messages.reaction'] = messageReactionList;
623
+ }
624
+ const messageReceiptList = Object.values(data.messageReceipts).flatMap(({
625
+ key,
626
+ userReceipt
627
+ }) => userReceipt.flatMap(receipt => ({
628
+ key,
629
+ receipt
630
+ })));
631
+ if (messageReceiptList.length) {
632
+ map['message-receipt.update'] = messageReceiptList;
633
+ }
634
+ const contactUpsertList = Object.values(data.contactUpserts);
635
+ if (contactUpsertList.length) {
636
+ map['contacts.upsert'] = contactUpsertList;
637
+ }
638
+ const contactUpdateList = Object.values(data.contactUpdates);
639
+ if (contactUpdateList.length) {
640
+ map['contacts.update'] = contactUpdateList;
641
+ }
642
+ const groupUpdateList = Object.values(data.groupUpdates);
643
+ if (groupUpdateList.length) {
644
+ map['groups.update'] = groupUpdateList;
645
+ }
646
+ return map;
647
+ }
648
+ function concatChats(a, b) {
649
+ if (b.unreadCount === null &&
650
+ // neutralize unread counter
651
+ a.unreadCount < 0) {
652
+ a.unreadCount = undefined;
653
+ b.unreadCount = undefined;
654
+ }
655
+ if (typeof a.unreadCount === 'number' && typeof b.unreadCount === 'number') {
656
+ b = {
657
+ ...b
658
+ };
659
+ if (b.unreadCount >= 0) {
660
+ b.unreadCount = Math.max(b.unreadCount, 0) + Math.max(a.unreadCount, 0);
661
+ }
662
+ }
663
+ return Object.assign(a, b);
664
+ }
665
+ const stringifyMessageKey = key => `${key.remoteJid},${key.id},${key.fromMe ? '1' : '0'}`;
666
+ //# sourceMappingURL=event-buffer.js.map