anya-bail 1.0.1

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 (550) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +316 -0
  3. package/WAProto/GenerateStatics.sh +3 -0
  4. package/WAProto/WAProto/GenerateStatics.sh +3 -0
  5. package/WAProto/WAProto/WAProto.proto +5479 -0
  6. package/WAProto/WAProto/fix-imports.js +81 -0
  7. package/WAProto/WAProto/index.d.ts +14017 -0
  8. package/WAProto/WAProto/index.js +97687 -0
  9. package/WAProto/WAProto.proto +5479 -0
  10. package/WAProto/fix-imports.js +85 -0
  11. package/WAProto/index.d.ts +14017 -0
  12. package/WAProto/index.js +97691 -0
  13. package/engine-requirements.js +10 -0
  14. package/lib/Defaults/index.d.ts +86 -0
  15. package/lib/Defaults/index.d.ts.map +1 -0
  16. package/lib/Defaults/index.js +145 -0
  17. package/lib/Defaults/index.js.map +1 -0
  18. package/lib/Signal/Group/ciphertext-message.d.ts +10 -0
  19. package/lib/Signal/Group/ciphertext-message.d.ts.map +1 -0
  20. package/lib/Signal/Group/ciphertext-message.js +12 -0
  21. package/lib/Signal/Group/ciphertext-message.js.map +1 -0
  22. package/lib/Signal/Group/group-session-builder.d.ts +15 -0
  23. package/lib/Signal/Group/group-session-builder.d.ts.map +1 -0
  24. package/lib/Signal/Group/group-session-builder.js +30 -0
  25. package/lib/Signal/Group/group-session-builder.js.map +1 -0
  26. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  27. package/lib/Signal/Group/group_cipher.d.ts.map +1 -0
  28. package/lib/Signal/Group/group_cipher.js +82 -0
  29. package/lib/Signal/Group/group_cipher.js.map +1 -0
  30. package/lib/Signal/Group/index.d.ts +12 -0
  31. package/lib/Signal/Group/index.d.ts.map +1 -0
  32. package/lib/Signal/Group/index.js +12 -0
  33. package/lib/Signal/Group/index.js.map +1 -0
  34. package/lib/Signal/Group/keyhelper.d.ts +11 -0
  35. package/lib/Signal/Group/keyhelper.d.ts.map +1 -0
  36. package/lib/Signal/Group/keyhelper.js +18 -0
  37. package/lib/Signal/Group/keyhelper.js.map +1 -0
  38. package/lib/Signal/Group/sender-chain-key.d.ts +14 -0
  39. package/lib/Signal/Group/sender-chain-key.d.ts.map +1 -0
  40. package/lib/Signal/Group/sender-chain-key.js +26 -0
  41. package/lib/Signal/Group/sender-chain-key.js.map +1 -0
  42. package/lib/Signal/Group/sender-key-distribution-message.d.ts +17 -0
  43. package/lib/Signal/Group/sender-key-distribution-message.d.ts.map +1 -0
  44. package/lib/Signal/Group/sender-key-distribution-message.js +63 -0
  45. package/lib/Signal/Group/sender-key-distribution-message.js.map +1 -0
  46. package/lib/Signal/Group/sender-key-message.d.ts +19 -0
  47. package/lib/Signal/Group/sender-key-message.d.ts.map +1 -0
  48. package/lib/Signal/Group/sender-key-message.js +66 -0
  49. package/lib/Signal/Group/sender-key-message.js.map +1 -0
  50. package/lib/Signal/Group/sender-key-name.d.ts +18 -0
  51. package/lib/Signal/Group/sender-key-name.d.ts.map +1 -0
  52. package/lib/Signal/Group/sender-key-name.js +48 -0
  53. package/lib/Signal/Group/sender-key-name.js.map +1 -0
  54. package/lib/Signal/Group/sender-key-record.d.ts +31 -0
  55. package/lib/Signal/Group/sender-key-record.d.ts.map +1 -0
  56. package/lib/Signal/Group/sender-key-record.js +41 -0
  57. package/lib/Signal/Group/sender-key-record.js.map +1 -0
  58. package/lib/Signal/Group/sender-key-state.d.ts +39 -0
  59. package/lib/Signal/Group/sender-key-state.d.ts.map +1 -0
  60. package/lib/Signal/Group/sender-key-state.js +84 -0
  61. package/lib/Signal/Group/sender-key-state.js.map +1 -0
  62. package/lib/Signal/Group/sender-message-key.d.ts +12 -0
  63. package/lib/Signal/Group/sender-message-key.d.ts.map +1 -0
  64. package/lib/Signal/Group/sender-message-key.js +26 -0
  65. package/lib/Signal/Group/sender-message-key.js.map +1 -0
  66. package/lib/Signal/libsignal.d.ts +5 -0
  67. package/lib/Signal/libsignal.d.ts.map +1 -0
  68. package/lib/Signal/libsignal.js +431 -0
  69. package/lib/Signal/libsignal.js.map +1 -0
  70. package/lib/Signal/lid-mapping.d.ts +23 -0
  71. package/lib/Signal/lid-mapping.d.ts.map +1 -0
  72. package/lib/Signal/lid-mapping.js +277 -0
  73. package/lib/Signal/lid-mapping.js.map +1 -0
  74. package/lib/Socket/Client/index.d.ts +3 -0
  75. package/lib/Socket/Client/index.d.ts.map +1 -0
  76. package/lib/Socket/Client/index.js +3 -0
  77. package/lib/Socket/Client/index.js.map +1 -0
  78. package/lib/Socket/Client/types.d.ts +16 -0
  79. package/lib/Socket/Client/types.d.ts.map +1 -0
  80. package/lib/Socket/Client/types.js +11 -0
  81. package/lib/Socket/Client/types.js.map +1 -0
  82. package/lib/Socket/Client/websocket.d.ts +13 -0
  83. package/lib/Socket/Client/websocket.d.ts.map +1 -0
  84. package/lib/Socket/Client/websocket.js +54 -0
  85. package/lib/Socket/Client/websocket.js.map +1 -0
  86. package/lib/Socket/business.d.ts +217 -0
  87. package/lib/Socket/business.d.ts.map +1 -0
  88. package/lib/Socket/business.js +379 -0
  89. package/lib/Socket/business.js.map +1 -0
  90. package/lib/Socket/chats.d.ts +124 -0
  91. package/lib/Socket/chats.d.ts.map +1 -0
  92. package/lib/Socket/chats.js +1192 -0
  93. package/lib/Socket/chats.js.map +1 -0
  94. package/lib/Socket/communities.d.ts +273 -0
  95. package/lib/Socket/communities.d.ts.map +1 -0
  96. package/lib/Socket/communities.js +431 -0
  97. package/lib/Socket/communities.js.map +1 -0
  98. package/lib/Socket/groups.d.ts +161 -0
  99. package/lib/Socket/groups.d.ts.map +1 -0
  100. package/lib/Socket/groups.js +347 -0
  101. package/lib/Socket/groups.js.map +1 -0
  102. package/lib/Socket/index.d.ts +260 -0
  103. package/lib/Socket/index.d.ts.map +1 -0
  104. package/lib/Socket/index.js +12 -0
  105. package/lib/Socket/index.js.map +1 -0
  106. package/lib/Socket/messages-recv.d.ts +203 -0
  107. package/lib/Socket/messages-recv.d.ts.map +1 -0
  108. package/lib/Socket/messages-recv.js +1772 -0
  109. package/lib/Socket/messages-recv.js.map +1 -0
  110. package/lib/Socket/messages-send.d.ts +199 -0
  111. package/lib/Socket/messages-send.d.ts.map +1 -0
  112. package/lib/Socket/messages-send.js +1157 -0
  113. package/lib/Socket/messages-send.js.map +1 -0
  114. package/lib/Socket/mex.d.ts +3 -0
  115. package/lib/Socket/mex.d.ts.map +1 -0
  116. package/lib/Socket/mex.js +42 -0
  117. package/lib/Socket/mex.js.map +1 -0
  118. package/lib/Socket/newsletter.d.ts +170 -0
  119. package/lib/Socket/newsletter.d.ts.map +1 -0
  120. package/lib/Socket/newsletter.js +181 -0
  121. package/lib/Socket/newsletter.js.map +1 -0
  122. package/lib/Socket/rich-messages.d.ts +7 -0
  123. package/lib/Socket/rich-messages.d.ts.map +1 -0
  124. package/lib/Socket/rich-messages.js +6 -0
  125. package/lib/Socket/rich-messages.js.map +1 -0
  126. package/lib/Socket/socket.d.ts +59 -0
  127. package/lib/Socket/socket.d.ts.map +1 -0
  128. package/lib/Socket/socket.js +1040 -0
  129. package/lib/Socket/socket.js.map +1 -0
  130. package/lib/Socket/usync.d.ts +49 -0
  131. package/lib/Socket/usync.d.ts.map +1 -0
  132. package/lib/Socket/usync.js +42 -0
  133. package/lib/Socket/usync.js.map +1 -0
  134. package/lib/Types/Auth.d.ts +117 -0
  135. package/lib/Types/Auth.d.ts.map +1 -0
  136. package/lib/Types/Auth.js +2 -0
  137. package/lib/Types/Auth.js.map +1 -0
  138. package/lib/Types/Bussines.d.ts +25 -0
  139. package/lib/Types/Bussines.d.ts.map +1 -0
  140. package/lib/Types/Bussines.js +2 -0
  141. package/lib/Types/Bussines.js.map +1 -0
  142. package/lib/Types/Call.d.ts +23 -0
  143. package/lib/Types/Call.d.ts.map +1 -0
  144. package/lib/Types/Call.js +2 -0
  145. package/lib/Types/Call.js.map +1 -0
  146. package/lib/Types/Chat.d.ts +123 -0
  147. package/lib/Types/Chat.d.ts.map +1 -0
  148. package/lib/Types/Chat.js +8 -0
  149. package/lib/Types/Chat.js.map +1 -0
  150. package/lib/Types/Contact.d.ts +26 -0
  151. package/lib/Types/Contact.d.ts.map +1 -0
  152. package/lib/Types/Contact.js +2 -0
  153. package/lib/Types/Contact.js.map +1 -0
  154. package/lib/Types/Events.d.ts +256 -0
  155. package/lib/Types/Events.d.ts.map +1 -0
  156. package/lib/Types/Events.js +2 -0
  157. package/lib/Types/Events.js.map +1 -0
  158. package/lib/Types/GroupMetadata.d.ts +71 -0
  159. package/lib/Types/GroupMetadata.d.ts.map +1 -0
  160. package/lib/Types/GroupMetadata.js +2 -0
  161. package/lib/Types/GroupMetadata.js.map +1 -0
  162. package/lib/Types/Label.d.ts +47 -0
  163. package/lib/Types/Label.d.ts.map +1 -0
  164. package/lib/Types/Label.js +25 -0
  165. package/lib/Types/Label.js.map +1 -0
  166. package/lib/Types/LabelAssociation.d.ts +30 -0
  167. package/lib/Types/LabelAssociation.d.ts.map +1 -0
  168. package/lib/Types/LabelAssociation.js +7 -0
  169. package/lib/Types/LabelAssociation.js.map +1 -0
  170. package/lib/Types/Message.d.ts +355 -0
  171. package/lib/Types/Message.d.ts.map +1 -0
  172. package/lib/Types/Message.js +18 -0
  173. package/lib/Types/Message.js.map +1 -0
  174. package/lib/Types/Mex.d.ts +141 -0
  175. package/lib/Types/Mex.d.ts.map +1 -0
  176. package/lib/Types/Mex.js +37 -0
  177. package/lib/Types/Mex.js.map +1 -0
  178. package/lib/Types/MexUpdates.d.ts +9 -0
  179. package/lib/Types/MexUpdates.d.ts.map +1 -0
  180. package/lib/Types/MexUpdates.js +11 -0
  181. package/lib/Types/MexUpdates.js.map +1 -0
  182. package/lib/Types/Newsletter.d.ts +135 -0
  183. package/lib/Types/Newsletter.d.ts.map +1 -0
  184. package/lib/Types/Newsletter.js +31 -0
  185. package/lib/Types/Newsletter.js.map +1 -0
  186. package/lib/Types/Product.d.ts +79 -0
  187. package/lib/Types/Product.d.ts.map +1 -0
  188. package/lib/Types/Product.js +2 -0
  189. package/lib/Types/Product.js.map +1 -0
  190. package/lib/Types/Signal.d.ts +87 -0
  191. package/lib/Types/Signal.d.ts.map +1 -0
  192. package/lib/Types/Signal.js +2 -0
  193. package/lib/Types/Signal.js.map +1 -0
  194. package/lib/Types/Socket.d.ts +136 -0
  195. package/lib/Types/Socket.d.ts.map +1 -0
  196. package/lib/Types/Socket.js +3 -0
  197. package/lib/Types/Socket.js.map +1 -0
  198. package/lib/Types/State.d.ts +97 -0
  199. package/lib/Types/State.d.ts.map +1 -0
  200. package/lib/Types/State.js +56 -0
  201. package/lib/Types/State.js.map +1 -0
  202. package/lib/Types/USync.d.ts +26 -0
  203. package/lib/Types/USync.d.ts.map +1 -0
  204. package/lib/Types/USync.js +2 -0
  205. package/lib/Types/USync.js.map +1 -0
  206. package/lib/Types/index.d.ts +67 -0
  207. package/lib/Types/index.d.ts.map +1 -0
  208. package/lib/Types/index.js +26 -0
  209. package/lib/Types/index.js.map +1 -0
  210. package/lib/Utils/anti-delete.d.ts +3 -0
  211. package/lib/Utils/anti-delete.d.ts.map +1 -0
  212. package/lib/Utils/anti-delete.js +3 -0
  213. package/lib/Utils/anti-delete.js.map +1 -0
  214. package/lib/Utils/auth-utils.d.ts +24 -0
  215. package/lib/Utils/auth-utils.d.ts.map +1 -0
  216. package/lib/Utils/auth-utils.js +302 -0
  217. package/lib/Utils/auth-utils.js.map +1 -0
  218. package/lib/Utils/auto-reply.d.ts +50 -0
  219. package/lib/Utils/auto-reply.d.ts.map +1 -0
  220. package/lib/Utils/auto-reply.js +118 -0
  221. package/lib/Utils/auto-reply.js.map +1 -0
  222. package/lib/Utils/baileys-event-stream.d.ts +3 -0
  223. package/lib/Utils/baileys-event-stream.d.ts.map +1 -0
  224. package/lib/Utils/baileys-event-stream.js +3 -0
  225. package/lib/Utils/baileys-event-stream.js.map +1 -0
  226. package/lib/Utils/browser-utils.d.ts +11 -0
  227. package/lib/Utils/browser-utils.d.ts.map +1 -0
  228. package/lib/Utils/browser-utils.js +52 -0
  229. package/lib/Utils/browser-utils.js.map +1 -0
  230. package/lib/Utils/business.d.ts +23 -0
  231. package/lib/Utils/business.d.ts.map +1 -0
  232. package/lib/Utils/business.js +231 -0
  233. package/lib/Utils/business.js.map +1 -0
  234. package/lib/Utils/chat-control.d.ts +55 -0
  235. package/lib/Utils/chat-control.d.ts.map +1 -0
  236. package/lib/Utils/chat-control.js +128 -0
  237. package/lib/Utils/chat-control.js.map +1 -0
  238. package/lib/Utils/chat-utils.d.ts +100 -0
  239. package/lib/Utils/chat-utils.d.ts.map +1 -0
  240. package/lib/Utils/chat-utils.js +872 -0
  241. package/lib/Utils/chat-utils.js.map +1 -0
  242. package/lib/Utils/companion-reg-client-utils.d.ts +17 -0
  243. package/lib/Utils/companion-reg-client-utils.d.ts.map +1 -0
  244. package/lib/Utils/companion-reg-client-utils.js +34 -0
  245. package/lib/Utils/companion-reg-client-utils.js.map +1 -0
  246. package/lib/Utils/crypto.d.ts +37 -0
  247. package/lib/Utils/crypto.d.ts.map +1 -0
  248. package/lib/Utils/crypto.js +118 -0
  249. package/lib/Utils/crypto.js.map +1 -0
  250. package/lib/Utils/decode-wa-message.d.ts +66 -0
  251. package/lib/Utils/decode-wa-message.d.ts.map +1 -0
  252. package/lib/Utils/decode-wa-message.js +311 -0
  253. package/lib/Utils/decode-wa-message.js.map +1 -0
  254. package/lib/Utils/event-buffer.d.ts +36 -0
  255. package/lib/Utils/event-buffer.d.ts.map +1 -0
  256. package/lib/Utils/event-buffer.js +622 -0
  257. package/lib/Utils/event-buffer.js.map +1 -0
  258. package/lib/Utils/generics.d.ts +98 -0
  259. package/lib/Utils/generics.d.ts.map +1 -0
  260. package/lib/Utils/generics.js +410 -0
  261. package/lib/Utils/generics.js.map +1 -0
  262. package/lib/Utils/history.d.ts +24 -0
  263. package/lib/Utils/history.d.ts.map +1 -0
  264. package/lib/Utils/history.js +134 -0
  265. package/lib/Utils/history.js.map +1 -0
  266. package/lib/Utils/identity-change-handler.d.ts +44 -0
  267. package/lib/Utils/identity-change-handler.d.ts.map +1 -0
  268. package/lib/Utils/identity-change-handler.js +50 -0
  269. package/lib/Utils/identity-change-handler.js.map +1 -0
  270. package/lib/Utils/index.d.ts +23 -0
  271. package/lib/Utils/index.d.ts.map +1 -0
  272. package/lib/Utils/index.js +23 -0
  273. package/lib/Utils/index.js.map +1 -0
  274. package/lib/Utils/interactive-message.d.ts +201 -0
  275. package/lib/Utils/interactive-message.d.ts.map +1 -0
  276. package/lib/Utils/interactive-message.js +256 -0
  277. package/lib/Utils/interactive-message.js.map +1 -0
  278. package/lib/Utils/jid-plotting.d.ts +3 -0
  279. package/lib/Utils/jid-plotting.d.ts.map +1 -0
  280. package/lib/Utils/jid-plotting.js +3 -0
  281. package/lib/Utils/jid-plotting.js.map +1 -0
  282. package/lib/Utils/link-preview.d.ts +21 -0
  283. package/lib/Utils/link-preview.d.ts.map +1 -0
  284. package/lib/Utils/link-preview.js +85 -0
  285. package/lib/Utils/link-preview.js.map +1 -0
  286. package/lib/Utils/logger.d.ts +13 -0
  287. package/lib/Utils/logger.d.ts.map +1 -0
  288. package/lib/Utils/logger.js +3 -0
  289. package/lib/Utils/logger.js.map +1 -0
  290. package/lib/Utils/lt-hash.d.ts +8 -0
  291. package/lib/Utils/lt-hash.d.ts.map +1 -0
  292. package/lib/Utils/lt-hash.js +8 -0
  293. package/lib/Utils/lt-hash.js.map +1 -0
  294. package/lib/Utils/make-mutex.d.ts +9 -0
  295. package/lib/Utils/make-mutex.d.ts.map +1 -0
  296. package/lib/Utils/make-mutex.js +33 -0
  297. package/lib/Utils/make-mutex.js.map +1 -0
  298. package/lib/Utils/message-composer.d.ts +7 -0
  299. package/lib/Utils/message-composer.d.ts.map +1 -0
  300. package/lib/Utils/message-composer.js +6 -0
  301. package/lib/Utils/message-composer.js.map +1 -0
  302. package/lib/Utils/message-retry-manager.d.ts +115 -0
  303. package/lib/Utils/message-retry-manager.d.ts.map +1 -0
  304. package/lib/Utils/message-retry-manager.js +265 -0
  305. package/lib/Utils/message-retry-manager.js.map +1 -0
  306. package/lib/Utils/message-search.d.ts +37 -0
  307. package/lib/Utils/message-search.d.ts.map +1 -0
  308. package/lib/Utils/message-search.js +149 -0
  309. package/lib/Utils/message-search.js.map +1 -0
  310. package/lib/Utils/messages-media.d.ts +191 -0
  311. package/lib/Utils/messages-media.d.ts.map +1 -0
  312. package/lib/Utils/messages-media.js +786 -0
  313. package/lib/Utils/messages-media.js.map +1 -0
  314. package/lib/Utils/messages.d.ts +94 -0
  315. package/lib/Utils/messages.d.ts.map +1 -0
  316. package/lib/Utils/messages.js +1375 -0
  317. package/lib/Utils/messages.js.map +1 -0
  318. package/lib/Utils/noise-handler.d.ts +20 -0
  319. package/lib/Utils/noise-handler.d.ts.map +1 -0
  320. package/lib/Utils/noise-handler.js +201 -0
  321. package/lib/Utils/noise-handler.js.map +1 -0
  322. package/lib/Utils/offline-node-processor.d.ts +17 -0
  323. package/lib/Utils/offline-node-processor.d.ts.map +1 -0
  324. package/lib/Utils/offline-node-processor.js +40 -0
  325. package/lib/Utils/offline-node-processor.js.map +1 -0
  326. package/lib/Utils/pre-key-manager.d.ts +28 -0
  327. package/lib/Utils/pre-key-manager.d.ts.map +1 -0
  328. package/lib/Utils/pre-key-manager.js +106 -0
  329. package/lib/Utils/pre-key-manager.js.map +1 -0
  330. package/lib/Utils/process-message.d.ts +60 -0
  331. package/lib/Utils/process-message.d.ts.map +1 -0
  332. package/lib/Utils/process-message.js +597 -0
  333. package/lib/Utils/process-message.js.map +1 -0
  334. package/lib/Utils/reporting-utils.d.ts +11 -0
  335. package/lib/Utils/reporting-utils.d.ts.map +1 -0
  336. package/lib/Utils/reporting-utils.js +258 -0
  337. package/lib/Utils/reporting-utils.js.map +1 -0
  338. package/lib/Utils/scheduling.d.ts +40 -0
  339. package/lib/Utils/scheduling.d.ts.map +1 -0
  340. package/lib/Utils/scheduling.js +105 -0
  341. package/lib/Utils/scheduling.js.map +1 -0
  342. package/lib/Utils/signal.d.ts +47 -0
  343. package/lib/Utils/signal.d.ts.map +1 -0
  344. package/lib/Utils/signal.js +201 -0
  345. package/lib/Utils/signal.js.map +1 -0
  346. package/lib/Utils/stanza-ack.d.ts +11 -0
  347. package/lib/Utils/stanza-ack.d.ts.map +1 -0
  348. package/lib/Utils/stanza-ack.js +38 -0
  349. package/lib/Utils/stanza-ack.js.map +1 -0
  350. package/lib/Utils/status-posting.d.ts +79 -0
  351. package/lib/Utils/status-posting.d.ts.map +1 -0
  352. package/lib/Utils/status-posting.js +69 -0
  353. package/lib/Utils/status-posting.js.map +1 -0
  354. package/lib/Utils/sync-action-utils.d.ts +19 -0
  355. package/lib/Utils/sync-action-utils.d.ts.map +1 -0
  356. package/lib/Utils/sync-action-utils.js +49 -0
  357. package/lib/Utils/sync-action-utils.js.map +1 -0
  358. package/lib/Utils/tc-token-utils.d.ts +37 -0
  359. package/lib/Utils/tc-token-utils.d.ts.map +1 -0
  360. package/lib/Utils/tc-token-utils.js +163 -0
  361. package/lib/Utils/tc-token-utils.js.map +1 -0
  362. package/lib/Utils/templates.d.ts +48 -0
  363. package/lib/Utils/templates.d.ts.map +1 -0
  364. package/lib/Utils/templates.js +119 -0
  365. package/lib/Utils/templates.js.map +1 -0
  366. package/lib/Utils/use-mongo-file-auth-state.d.ts +16 -0
  367. package/lib/Utils/use-mongo-file-auth-state.d.ts.map +1 -0
  368. package/lib/Utils/use-mongo-file-auth-state.js +60 -0
  369. package/lib/Utils/use-mongo-file-auth-state.js.map +1 -0
  370. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  371. package/lib/Utils/use-multi-file-auth-state.d.ts.map +1 -0
  372. package/lib/Utils/use-multi-file-auth-state.js +121 -0
  373. package/lib/Utils/use-multi-file-auth-state.js.map +1 -0
  374. package/lib/Utils/use-single-file-auth-state.d.ts +6 -0
  375. package/lib/Utils/use-single-file-auth-state.d.ts.map +1 -0
  376. package/lib/Utils/use-single-file-auth-state.js +88 -0
  377. package/lib/Utils/use-single-file-auth-state.js.map +1 -0
  378. package/lib/Utils/validate-connection.d.ts +11 -0
  379. package/lib/Utils/validate-connection.d.ts.map +1 -0
  380. package/lib/Utils/validate-connection.js +209 -0
  381. package/lib/Utils/validate-connection.js.map +1 -0
  382. package/lib/Utils/vcard.d.ts +53 -0
  383. package/lib/Utils/vcard.d.ts.map +1 -0
  384. package/lib/Utils/vcard.js +81 -0
  385. package/lib/Utils/vcard.js.map +1 -0
  386. package/lib/WABinary/constants.d.ts +28 -0
  387. package/lib/WABinary/constants.d.ts.map +1 -0
  388. package/lib/WABinary/constants.js +1301 -0
  389. package/lib/WABinary/constants.js.map +1 -0
  390. package/lib/WABinary/decode.d.ts +7 -0
  391. package/lib/WABinary/decode.d.ts.map +1 -0
  392. package/lib/WABinary/decode.js +262 -0
  393. package/lib/WABinary/decode.js.map +1 -0
  394. package/lib/WABinary/encode.d.ts +3 -0
  395. package/lib/WABinary/encode.d.ts.map +1 -0
  396. package/lib/WABinary/encode.js +220 -0
  397. package/lib/WABinary/encode.js.map +1 -0
  398. package/lib/WABinary/generic-utils.d.ts +15 -0
  399. package/lib/WABinary/generic-utils.d.ts.map +1 -0
  400. package/lib/WABinary/generic-utils.js +113 -0
  401. package/lib/WABinary/generic-utils.js.map +1 -0
  402. package/lib/WABinary/index.d.ts +6 -0
  403. package/lib/WABinary/index.d.ts.map +1 -0
  404. package/lib/WABinary/index.js +6 -0
  405. package/lib/WABinary/index.js.map +1 -0
  406. package/lib/WABinary/jid-utils.d.ts +48 -0
  407. package/lib/WABinary/jid-utils.d.ts.map +1 -0
  408. package/lib/WABinary/jid-utils.js +96 -0
  409. package/lib/WABinary/jid-utils.js.map +1 -0
  410. package/lib/WABinary/types.d.ts +19 -0
  411. package/lib/WABinary/types.d.ts.map +1 -0
  412. package/lib/WABinary/types.js +2 -0
  413. package/lib/WABinary/types.js.map +1 -0
  414. package/lib/WAM/BinaryInfo.d.ts +9 -0
  415. package/lib/WAM/BinaryInfo.d.ts.map +1 -0
  416. package/lib/WAM/BinaryInfo.js +10 -0
  417. package/lib/WAM/BinaryInfo.js.map +1 -0
  418. package/lib/WAM/constants.d.ts +40 -0
  419. package/lib/WAM/constants.d.ts.map +1 -0
  420. package/lib/WAM/constants.js +22853 -0
  421. package/lib/WAM/constants.js.map +1 -0
  422. package/lib/WAM/encode.d.ts +3 -0
  423. package/lib/WAM/encode.d.ts.map +1 -0
  424. package/lib/WAM/encode.js +150 -0
  425. package/lib/WAM/encode.js.map +1 -0
  426. package/lib/WAM/index.d.ts +4 -0
  427. package/lib/WAM/index.d.ts.map +1 -0
  428. package/lib/WAM/index.js +4 -0
  429. package/lib/WAM/index.js.map +1 -0
  430. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +10 -0
  431. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts.map +1 -0
  432. package/lib/WAUSync/Protocols/USyncContactProtocol.js +52 -0
  433. package/lib/WAUSync/Protocols/USyncContactProtocol.js.map +1 -0
  434. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +23 -0
  435. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts.map +1 -0
  436. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +54 -0
  437. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js.map +1 -0
  438. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +13 -0
  439. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts.map +1 -0
  440. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -0
  441. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js.map +1 -0
  442. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +13 -0
  443. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts.map +1 -0
  444. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +38 -0
  445. package/lib/WAUSync/Protocols/USyncStatusProtocol.js.map +1 -0
  446. package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +10 -0
  447. package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts.map +1 -0
  448. package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +25 -0
  449. package/lib/WAUSync/Protocols/USyncUsernameProtocol.js.map +1 -0
  450. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +26 -0
  451. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts.map +1 -0
  452. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +51 -0
  453. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js.map +1 -0
  454. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +10 -0
  455. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts.map +1 -0
  456. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +29 -0
  457. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js.map +1 -0
  458. package/lib/WAUSync/Protocols/index.d.ts +8 -0
  459. package/lib/WAUSync/Protocols/index.d.ts.map +1 -0
  460. package/lib/WAUSync/Protocols/index.js +8 -0
  461. package/lib/WAUSync/Protocols/index.js.map +1 -0
  462. package/lib/WAUSync/USyncQuery.d.ts +30 -0
  463. package/lib/WAUSync/USyncQuery.d.ts.map +1 -0
  464. package/lib/WAUSync/USyncQuery.js +98 -0
  465. package/lib/WAUSync/USyncQuery.js.map +1 -0
  466. package/lib/WAUSync/USyncUser.d.ts +17 -0
  467. package/lib/WAUSync/USyncUser.d.ts.map +1 -0
  468. package/lib/WAUSync/USyncUser.js +31 -0
  469. package/lib/WAUSync/USyncUser.js.map +1 -0
  470. package/lib/WAUSync/index.d.ts +4 -0
  471. package/lib/WAUSync/index.d.ts.map +1 -0
  472. package/lib/WAUSync/index.js +4 -0
  473. package/lib/WAUSync/index.js.map +1 -0
  474. package/lib/addons/anti-delete.d.ts +62 -0
  475. package/lib/addons/anti-delete.d.ts.map +1 -0
  476. package/lib/addons/anti-delete.js +145 -0
  477. package/lib/addons/anti-delete.js.map +1 -0
  478. package/lib/addons/auto-reply.d.ts +57 -0
  479. package/lib/addons/auto-reply.d.ts.map +1 -0
  480. package/lib/addons/auto-reply.js +150 -0
  481. package/lib/addons/auto-reply.js.map +1 -0
  482. package/lib/addons/baileys-event-stream.d.ts +12 -0
  483. package/lib/addons/baileys-event-stream.d.ts.map +1 -0
  484. package/lib/addons/baileys-event-stream.js +45 -0
  485. package/lib/addons/baileys-event-stream.js.map +1 -0
  486. package/lib/addons/chat-control.d.ts +63 -0
  487. package/lib/addons/chat-control.d.ts.map +1 -0
  488. package/lib/addons/chat-control.js +121 -0
  489. package/lib/addons/chat-control.js.map +1 -0
  490. package/lib/addons/index.d.ts +40 -0
  491. package/lib/addons/index.d.ts.map +1 -0
  492. package/lib/addons/index.js +44 -0
  493. package/lib/addons/index.js.map +1 -0
  494. package/lib/addons/interactive-message.d.ts +293 -0
  495. package/lib/addons/interactive-message.d.ts.map +1 -0
  496. package/lib/addons/interactive-message.js +72 -0
  497. package/lib/addons/interactive-message.js.map +1 -0
  498. package/lib/addons/jid-plotting.d.ts +57 -0
  499. package/lib/addons/jid-plotting.d.ts.map +1 -0
  500. package/lib/addons/jid-plotting.js +152 -0
  501. package/lib/addons/jid-plotting.js.map +1 -0
  502. package/lib/addons/message-search.d.ts +41 -0
  503. package/lib/addons/message-search.d.ts.map +1 -0
  504. package/lib/addons/message-search.js +162 -0
  505. package/lib/addons/message-search.js.map +1 -0
  506. package/lib/addons/rich-message-composer.d.ts +94 -0
  507. package/lib/addons/rich-message-composer.d.ts.map +1 -0
  508. package/lib/addons/rich-message-composer.js +183 -0
  509. package/lib/addons/rich-message-composer.js.map +1 -0
  510. package/lib/addons/rich-message-utils.d.ts +144 -0
  511. package/lib/addons/rich-message-utils.d.ts.map +1 -0
  512. package/lib/addons/rich-message-utils.js +323 -0
  513. package/lib/addons/rich-message-utils.js.map +1 -0
  514. package/lib/addons/rich-types.d.ts +28 -0
  515. package/lib/addons/rich-types.d.ts.map +1 -0
  516. package/lib/addons/rich-types.js +127 -0
  517. package/lib/addons/rich-types.js.map +1 -0
  518. package/lib/addons/scheduling.d.ts +47 -0
  519. package/lib/addons/scheduling.d.ts.map +1 -0
  520. package/lib/addons/scheduling.js +109 -0
  521. package/lib/addons/scheduling.js.map +1 -0
  522. package/lib/addons/status-helpers.d.ts +75 -0
  523. package/lib/addons/status-helpers.d.ts.map +1 -0
  524. package/lib/addons/status-helpers.js +100 -0
  525. package/lib/addons/status-helpers.js.map +1 -0
  526. package/lib/addons/templates.d.ts +67 -0
  527. package/lib/addons/templates.d.ts.map +1 -0
  528. package/lib/addons/templates.js +137 -0
  529. package/lib/addons/templates.js.map +1 -0
  530. package/lib/addons/use-cache-manager-auth-state.d.ts +14 -0
  531. package/lib/addons/use-cache-manager-auth-state.d.ts.map +1 -0
  532. package/lib/addons/use-cache-manager-auth-state.js +71 -0
  533. package/lib/addons/use-cache-manager-auth-state.js.map +1 -0
  534. package/lib/addons/use-mongo-auth-state.d.ts +12 -0
  535. package/lib/addons/use-mongo-auth-state.d.ts.map +1 -0
  536. package/lib/addons/use-mongo-auth-state.js +64 -0
  537. package/lib/addons/use-mongo-auth-state.js.map +1 -0
  538. package/lib/addons/use-single-file-auth-state.d.ts +6 -0
  539. package/lib/addons/use-single-file-auth-state.d.ts.map +1 -0
  540. package/lib/addons/use-single-file-auth-state.js +155 -0
  541. package/lib/addons/use-single-file-auth-state.js.map +1 -0
  542. package/lib/addons/vcard.d.ts +61 -0
  543. package/lib/addons/vcard.d.ts.map +1 -0
  544. package/lib/addons/vcard.js +103 -0
  545. package/lib/addons/vcard.js.map +1 -0
  546. package/lib/index.d.ts +13 -0
  547. package/lib/index.d.ts.map +1 -0
  548. package/lib/index.js +14 -0
  549. package/lib/index.js.map +1 -0
  550. package/package.json +126 -0
@@ -0,0 +1,872 @@
1
+ import { Boom } from '@hapi/boom';
2
+ import { expandAppStateKeys } from 'whatsapp-rust-bridge';
3
+ import { proto } from '../../WAProto/index.js';
4
+ import { LabelAssociationType } from '../Types/LabelAssociation.js';
5
+ import { getBinaryNodeChild, getBinaryNodeChildren, isJidGroup, jidNormalizedUser } from '../WABinary/index.js';
6
+ import { aesDecrypt, aesEncrypt, hmacSign } from './crypto.js';
7
+ import { toNumber } from './generics.js';
8
+ import { LT_HASH_ANTI_TAMPERING } from './lt-hash.js';
9
+ import { downloadContentFromMessage } from './messages-media.js';
10
+ import { emitSyncActionResults, processContactAction } from './sync-action-utils.js';
11
+ const mutationKeys = (keydata) => {
12
+ const keys = expandAppStateKeys(keydata);
13
+ return {
14
+ indexKey: keys.indexKey,
15
+ valueEncryptionKey: keys.valueEncryptionKey,
16
+ valueMacKey: keys.valueMacKey,
17
+ snapshotMacKey: keys.snapshotMacKey,
18
+ patchMacKey: keys.patchMacKey
19
+ };
20
+ };
21
+ const generateMac = (operation, data, keyId, key) => {
22
+ const opByte = operation === proto.SyncdMutation.SyncdOperation.SET ? 0x01 : 0x02;
23
+ const keyIdBuffer = typeof keyId === 'string' ? Buffer.from(keyId, 'base64') : keyId;
24
+ const keyData = new Uint8Array(1 + keyIdBuffer.length);
25
+ keyData[0] = opByte;
26
+ keyData.set(keyIdBuffer, 1);
27
+ const last = new Uint8Array(8);
28
+ last[7] = keyData.length;
29
+ const total = new Uint8Array(keyData.length + data.length + last.length);
30
+ total.set(keyData, 0);
31
+ total.set(data, keyData.length);
32
+ total.set(last, keyData.length + data.length);
33
+ const hmac = hmacSign(total, key, 'sha512');
34
+ return hmac.subarray(0, 32);
35
+ };
36
+ const to64BitNetworkOrder = (e) => {
37
+ const buff = Buffer.alloc(8);
38
+ buff.writeUint32BE(e, 4);
39
+ return buff;
40
+ };
41
+ export const makeLtHashGenerator = ({ indexValueMap, hash }) => {
42
+ indexValueMap = { ...indexValueMap };
43
+ const addBuffs = [];
44
+ const subBuffs = [];
45
+ return {
46
+ mix: ({ indexMac, valueMac, operation }) => {
47
+ const indexMacBase64 = Buffer.from(indexMac).toString('base64');
48
+ const prevOp = indexValueMap[indexMacBase64];
49
+ if (operation === proto.SyncdMutation.SyncdOperation.REMOVE) {
50
+ if (!prevOp) {
51
+ // WA Web does not throw here — it logs a warning and skips the subtract.
52
+ // The missing REMOVE will cause an LTHash mismatch, which is handled
53
+ // by the MAC validation layer (snapshot recovery or retry).
54
+ return;
55
+ }
56
+ // remove from index value mac, since this mutation is erased
57
+ delete indexValueMap[indexMacBase64];
58
+ }
59
+ else {
60
+ addBuffs.push(valueMac);
61
+ // add this index into the history map
62
+ indexValueMap[indexMacBase64] = { valueMac };
63
+ }
64
+ if (prevOp) {
65
+ subBuffs.push(prevOp.valueMac);
66
+ }
67
+ },
68
+ finish: () => {
69
+ const result = LT_HASH_ANTI_TAMPERING.subtractThenAdd(hash, subBuffs, addBuffs);
70
+ return {
71
+ hash: Buffer.from(result),
72
+ indexValueMap
73
+ };
74
+ }
75
+ };
76
+ };
77
+ const generateSnapshotMac = (lthash, version, name, key) => {
78
+ const total = Buffer.concat([lthash, to64BitNetworkOrder(version), Buffer.from(name, 'utf-8')]);
79
+ return hmacSign(total, key, 'sha256');
80
+ };
81
+ const generatePatchMac = (snapshotMac, valueMacs, version, type, key) => {
82
+ const total = Buffer.concat([snapshotMac, ...valueMacs, to64BitNetworkOrder(version), Buffer.from(type, 'utf-8')]);
83
+ return hmacSign(total, key);
84
+ };
85
+ export const newLTHashState = () => ({ version: 0, hash: Buffer.alloc(128), indexValueMap: {} });
86
+ export const ensureLTHashStateVersion = (state) => {
87
+ if (typeof state.version !== 'number' || isNaN(state.version)) {
88
+ state.version = 0;
89
+ }
90
+ return state;
91
+ };
92
+ export const MAX_SYNC_ATTEMPTS = 2;
93
+ /**
94
+ * Check if an error is a missing app state sync key.
95
+ * WA Web treats these as "Blocked" (waits for key arrival), not fatal.
96
+ * In Baileys we retry with a snapshot which may use a different key.
97
+ */
98
+ export const isMissingKeyError = (error) => {
99
+ return error?.data?.isMissingKey === true;
100
+ };
101
+ /**
102
+ * Determines if an app state sync error is unrecoverable.
103
+ * TypeError indicates a WASM crash; otherwise we give up after MAX_SYNC_ATTEMPTS.
104
+ * Missing keys are NOT checked here — they are handled separately as "Blocked".
105
+ */
106
+ export const isAppStateSyncIrrecoverable = (error, attempts) => {
107
+ return attempts >= MAX_SYNC_ATTEMPTS || error?.name === 'TypeError';
108
+ };
109
+ export const encodeSyncdPatch = async ({ type, index, syncAction, apiVersion, operation }, myAppStateKeyId, state, getAppStateSyncKey) => {
110
+ const key = !!myAppStateKeyId ? await getAppStateSyncKey(myAppStateKeyId) : undefined;
111
+ if (!key) {
112
+ throw new Boom(`myAppStateKey ("${myAppStateKeyId}") not present`, { data: { isMissingKey: true } });
113
+ }
114
+ const encKeyId = Buffer.from(myAppStateKeyId, 'base64');
115
+ state = { ...state, indexValueMap: { ...state.indexValueMap } };
116
+ const indexBuffer = Buffer.from(JSON.stringify(index));
117
+ const dataProto = proto.SyncActionData.fromObject({
118
+ index: indexBuffer,
119
+ value: syncAction,
120
+ padding: new Uint8Array(0),
121
+ version: apiVersion
122
+ });
123
+ const encoded = proto.SyncActionData.encode(dataProto).finish();
124
+ const keyValue = mutationKeys(key.keyData);
125
+ const encValue = aesEncrypt(encoded, keyValue.valueEncryptionKey);
126
+ const valueMac = generateMac(operation, encValue, encKeyId, keyValue.valueMacKey);
127
+ const indexMac = hmacSign(indexBuffer, keyValue.indexKey);
128
+ // update LT hash
129
+ const generator = makeLtHashGenerator(state);
130
+ generator.mix({ indexMac, valueMac, operation });
131
+ Object.assign(state, generator.finish());
132
+ state.version += 1;
133
+ const snapshotMac = generateSnapshotMac(state.hash, state.version, type, keyValue.snapshotMacKey);
134
+ const patch = {
135
+ patchMac: generatePatchMac(snapshotMac, [valueMac], state.version, type, keyValue.patchMacKey),
136
+ snapshotMac: snapshotMac,
137
+ keyId: { id: encKeyId },
138
+ mutations: [
139
+ {
140
+ operation: operation,
141
+ record: {
142
+ index: {
143
+ blob: indexMac
144
+ },
145
+ value: {
146
+ blob: Buffer.concat([encValue, valueMac])
147
+ },
148
+ keyId: { id: encKeyId }
149
+ }
150
+ }
151
+ ]
152
+ };
153
+ const base64Index = indexMac.toString('base64');
154
+ state.indexValueMap[base64Index] = { valueMac };
155
+ return { patch, state };
156
+ };
157
+ export const decodeSyncdMutations = async (msgMutations, initialState, getAppStateSyncKey, onMutation, validateMacs) => {
158
+ const ltGenerator = makeLtHashGenerator(initialState);
159
+ const derivedKeyCache = new Map();
160
+ // indexKey used to HMAC sign record.index.blob
161
+ // valueEncryptionKey used to AES-256-CBC encrypt record.value.blob[0:-32]
162
+ // the remaining record.value.blob[0:-32] is the mac, it the HMAC sign of key.keyId + decoded proto data + length of bytes in keyId
163
+ for (const msgMutation of msgMutations) {
164
+ // if it's a syncdmutation, get the operation property
165
+ // otherwise, if it's only a record -- it'll be a SET mutation
166
+ const operation = 'operation' in msgMutation ? msgMutation.operation : proto.SyncdMutation.SyncdOperation.SET;
167
+ const record = 'record' in msgMutation && !!msgMutation.record ? msgMutation.record : msgMutation;
168
+ let key;
169
+ try {
170
+ key = await getKey(record.keyId.id);
171
+ }
172
+ catch (err) {
173
+ // Missing-key errors must propagate so the orchestrator can park the
174
+ // collection (Blocked) and retry when APP_STATE_SYNC_KEY_SHARE arrives.
175
+ // Other errors → individual record corruption, skip and keep going.
176
+ if (isMissingKeyError(err))
177
+ throw err;
178
+ continue;
179
+ }
180
+ const content = record.value.blob;
181
+ const encContent = content.subarray(0, -32);
182
+ const ogValueMac = content.subarray(-32);
183
+ if (validateMacs) {
184
+ const contentHmac = generateMac(operation, encContent, record.keyId.id, key.valueMacKey);
185
+ if (Buffer.compare(contentHmac, ogValueMac) !== 0) {
186
+ // HMAC verification failed — skip this record
187
+ continue;
188
+ }
189
+ }
190
+ let result;
191
+ try {
192
+ result = aesDecrypt(encContent, key.valueEncryptionKey);
193
+ }
194
+ catch {
195
+ // decrypt failed — skip this record instead of aborting
196
+ continue;
197
+ }
198
+ const syncAction = proto.SyncActionData.decode(result);
199
+ if (validateMacs) {
200
+ const hmac = hmacSign(syncAction.index, key.indexKey);
201
+ if (Buffer.compare(hmac, record.index.blob) !== 0) {
202
+ throw new Boom('HMAC index verification failed');
203
+ }
204
+ }
205
+ const indexStr = Buffer.from(syncAction.index).toString();
206
+ onMutation({ syncAction, index: JSON.parse(indexStr) });
207
+ ltGenerator.mix({
208
+ indexMac: record.index.blob,
209
+ valueMac: ogValueMac,
210
+ operation: operation
211
+ });
212
+ }
213
+ return ltGenerator.finish();
214
+ async function getKey(keyId) {
215
+ const base64Key = Buffer.from(keyId).toString('base64');
216
+ const cached = derivedKeyCache.get(base64Key);
217
+ if (cached) {
218
+ return cached;
219
+ }
220
+ const keyEnc = await getAppStateSyncKey(base64Key);
221
+ if (!keyEnc) {
222
+ throw new Boom(`failed to find key "${base64Key}" to decode mutation`, {
223
+ data: { isMissingKey: true, msgMutations }
224
+ });
225
+ }
226
+ const keys = mutationKeys(keyEnc.keyData);
227
+ derivedKeyCache.set(base64Key, keys);
228
+ return keys;
229
+ }
230
+ };
231
+ export const decodeSyncdPatch = async (msg, name, initialState, getAppStateSyncKey, onMutation, validateMacs) => {
232
+ if (validateMacs) {
233
+ const base64Key = Buffer.from(msg.keyId.id).toString('base64');
234
+ const mainKeyObj = await getAppStateSyncKey(base64Key);
235
+ if (!mainKeyObj) {
236
+ throw new Boom(`failed to find key "${base64Key}" to decode patch`, { data: { isMissingKey: true, msg } });
237
+ }
238
+ const mainKey = mutationKeys(mainKeyObj.keyData);
239
+ const mutationmacs = msg.mutations.map(mutation => mutation.record.value.blob.slice(-32));
240
+ const patchMac = generatePatchMac(msg.snapshotMac, mutationmacs, toNumber(msg.version.version), name, mainKey.patchMacKey);
241
+ if (Buffer.compare(patchMac, msg.patchMac) !== 0) {
242
+ throw new Boom('Invalid patch mac');
243
+ }
244
+ }
245
+ const result = await decodeSyncdMutations(msg.mutations, initialState, getAppStateSyncKey, onMutation, validateMacs);
246
+ return result;
247
+ };
248
+ export const extractSyncdPatches = async (result, options) => {
249
+ const syncNode = getBinaryNodeChild(result, 'sync');
250
+ const collectionNodes = getBinaryNodeChildren(syncNode, 'collection');
251
+ const final = {};
252
+ await Promise.all(collectionNodes.map(async (collectionNode) => {
253
+ const patchesNode = getBinaryNodeChild(collectionNode, 'patches');
254
+ const patches = getBinaryNodeChildren(patchesNode || collectionNode, 'patch');
255
+ const snapshotNode = getBinaryNodeChild(collectionNode, 'snapshot');
256
+ const syncds = [];
257
+ const name = collectionNode.attrs.name;
258
+ const hasMorePatches = collectionNode.attrs.has_more_patches === 'true';
259
+ let snapshot = undefined;
260
+ if (snapshotNode && !!snapshotNode.content) {
261
+ if (!Buffer.isBuffer(snapshotNode)) {
262
+ snapshotNode.content = Buffer.from(Object.values(snapshotNode.content));
263
+ }
264
+ const blobRef = proto.ExternalBlobReference.decode(snapshotNode.content);
265
+ const data = await downloadExternalBlob(blobRef, options);
266
+ snapshot = proto.SyncdSnapshot.decode(data);
267
+ }
268
+ for (let { content } of patches) {
269
+ if (content) {
270
+ if (!Buffer.isBuffer(content)) {
271
+ content = Buffer.from(Object.values(content));
272
+ }
273
+ const syncd = proto.SyncdPatch.decode(content);
274
+ if (!syncd.version) {
275
+ syncd.version = { version: +collectionNode.attrs.version + 1 };
276
+ }
277
+ syncds.push(syncd);
278
+ }
279
+ }
280
+ final[name] = { patches: syncds, hasMorePatches, snapshot };
281
+ }));
282
+ return final;
283
+ };
284
+ export const downloadExternalBlob = async (blob, options) => {
285
+ const stream = await downloadContentFromMessage(blob, 'md-app-state', { options });
286
+ const bufferArray = [];
287
+ for await (const chunk of stream) {
288
+ bufferArray.push(chunk);
289
+ }
290
+ return Buffer.concat(bufferArray);
291
+ };
292
+ export const downloadExternalPatch = async (blob, options) => {
293
+ const buffer = await downloadExternalBlob(blob, options);
294
+ const syncData = proto.SyncdMutations.decode(buffer);
295
+ return syncData;
296
+ };
297
+ export const decodeSyncdSnapshot = async (name, snapshot, getAppStateSyncKey, minimumVersionNumber, validateMacs = true, logger) => {
298
+ const newState = newLTHashState();
299
+ newState.version = toNumber(snapshot.version.version);
300
+ const mutationMap = {};
301
+ const areMutationsRequired = typeof minimumVersionNumber === 'undefined' || newState.version > minimumVersionNumber;
302
+ const { hash, indexValueMap } = await decodeSyncdMutations(snapshot.records, newState, getAppStateSyncKey, areMutationsRequired
303
+ ? mutation => {
304
+ const index = mutation.syncAction.index?.toString();
305
+ mutationMap[index] = mutation;
306
+ }
307
+ : () => { }, validateMacs);
308
+ newState.hash = hash;
309
+ newState.indexValueMap = indexValueMap;
310
+ if (validateMacs) {
311
+ const base64Key = Buffer.from(snapshot.keyId.id).toString('base64');
312
+ const keyEnc = await getAppStateSyncKey(base64Key);
313
+ if (!keyEnc) {
314
+ throw new Boom(`failed to find key "${base64Key}" to decode mutation`, { data: { isMissingKey: true } });
315
+ }
316
+ const result = mutationKeys(keyEnc.keyData);
317
+ const computedSnapshotMac = generateSnapshotMac(newState.hash, newState.version, name, result.snapshotMacKey);
318
+ if (Buffer.compare(snapshot.mac, computedSnapshotMac) !== 0) {
319
+ // LTHash verification may fail when decodeSyncdMutations skipped undecryptable
320
+ // records (poisoned server-side snapshot); the aggregate client hash diverges
321
+ // from the server-computed mac. Fall through with a warning so the session stays
322
+ // alive with partial state, symmetric to how decodePatches handles its own
323
+ // LTHash mismatch a few lines below.
324
+ logger?.warn({ name, version: newState.version }, 'LTHash verification failed on snapshot, continuing with partial state');
325
+ }
326
+ }
327
+ return {
328
+ state: newState,
329
+ mutationMap
330
+ };
331
+ };
332
+ export const decodePatches = async (name, syncds, initial, getAppStateSyncKey, options, minimumVersionNumber, logger, validateMacs = true) => {
333
+ const newState = {
334
+ ...initial,
335
+ indexValueMap: { ...initial.indexValueMap }
336
+ };
337
+ const mutationMap = {};
338
+ for (const syncd of syncds) {
339
+ const { version, keyId, snapshotMac } = syncd;
340
+ if (syncd.externalMutations) {
341
+ logger?.trace({ name, version }, 'downloading external patch');
342
+ const ref = await downloadExternalPatch(syncd.externalMutations, options);
343
+ logger?.debug({ name, version, mutations: ref.mutations.length }, 'downloaded external patch');
344
+ syncd.mutations?.push(...ref.mutations);
345
+ }
346
+ const patchVersion = toNumber(version.version);
347
+ newState.version = patchVersion;
348
+ const shouldMutate = typeof minimumVersionNumber === 'undefined' || patchVersion > minimumVersionNumber;
349
+ let decodeResult;
350
+ try {
351
+ decodeResult = await decodeSyncdPatch(syncd, name, newState, getAppStateSyncKey, shouldMutate
352
+ ? mutation => {
353
+ const index = mutation.syncAction.index?.toString();
354
+ mutationMap[index] = mutation;
355
+ }
356
+ : () => { }, validateMacs);
357
+ }
358
+ catch (err) {
359
+ if (isMissingKeyError(err))
360
+ throw err;
361
+ logger?.warn({ name, version: patchVersion, error: err.message }, 'failed to decode patch, skipping');
362
+ continue;
363
+ }
364
+ newState.hash = decodeResult.hash;
365
+ newState.indexValueMap = decodeResult.indexValueMap;
366
+ if (validateMacs) {
367
+ const base64Key = Buffer.from(keyId.id).toString('base64');
368
+ const keyEnc = await getAppStateSyncKey(base64Key);
369
+ if (!keyEnc) {
370
+ throw new Boom(`failed to find key "${base64Key}" to decode mutation`, { data: { isMissingKey: true } });
371
+ }
372
+ const result = mutationKeys(keyEnc.keyData);
373
+ const computedSnapshotMac = generateSnapshotMac(newState.hash, newState.version, name, result.snapshotMacKey);
374
+ if (Buffer.compare(snapshotMac, computedSnapshotMac) !== 0) {
375
+ logger?.warn({ name, version: newState.version }, 'LTHash verification failed, skipping remaining patches');
376
+ break;
377
+ }
378
+ }
379
+ // clear memory used up by the mutations
380
+ syncd.mutations = [];
381
+ }
382
+ return { state: newState, mutationMap };
383
+ };
384
+ export const chatModificationToAppPatch = (mod, jid) => {
385
+ const OP = proto.SyncdMutation.SyncdOperation;
386
+ const getMessageRange = (lastMessages) => {
387
+ let messageRange;
388
+ if (Array.isArray(lastMessages)) {
389
+ const lastMsg = lastMessages[lastMessages.length - 1];
390
+ messageRange = {
391
+ lastMessageTimestamp: lastMsg?.messageTimestamp,
392
+ messages: lastMessages?.length
393
+ ? lastMessages.map(m => {
394
+ if (!m.key?.id || !m.key?.remoteJid) {
395
+ throw new Boom('Incomplete key', { statusCode: 400, data: m });
396
+ }
397
+ if (isJidGroup(m.key.remoteJid) && !m.key.fromMe && !m.key.participant) {
398
+ throw new Boom('Expected not from me message to have participant', { statusCode: 400, data: m });
399
+ }
400
+ if (!m.messageTimestamp || !toNumber(m.messageTimestamp)) {
401
+ throw new Boom('Missing timestamp in last message list', { statusCode: 400, data: m });
402
+ }
403
+ if (m.key.participant) {
404
+ m.key.participant = jidNormalizedUser(m.key.participant);
405
+ }
406
+ return m;
407
+ })
408
+ : undefined
409
+ };
410
+ }
411
+ else {
412
+ messageRange = lastMessages;
413
+ }
414
+ return messageRange;
415
+ };
416
+ let patch;
417
+ if ('mute' in mod) {
418
+ patch = {
419
+ syncAction: {
420
+ muteAction: {
421
+ muted: !!mod.mute,
422
+ muteEndTimestamp: mod.mute || undefined
423
+ }
424
+ },
425
+ index: ['mute', jid],
426
+ type: 'regular_high',
427
+ apiVersion: 2,
428
+ operation: OP.SET
429
+ };
430
+ }
431
+ else if ('archive' in mod) {
432
+ patch = {
433
+ syncAction: {
434
+ archiveChatAction: {
435
+ archived: !!mod.archive,
436
+ messageRange: getMessageRange(mod.lastMessages)
437
+ }
438
+ },
439
+ index: ['archive', jid],
440
+ type: 'regular_low',
441
+ apiVersion: 3,
442
+ operation: OP.SET
443
+ };
444
+ }
445
+ else if ('markRead' in mod) {
446
+ patch = {
447
+ syncAction: {
448
+ markChatAsReadAction: {
449
+ read: mod.markRead,
450
+ messageRange: getMessageRange(mod.lastMessages)
451
+ }
452
+ },
453
+ index: ['markChatAsRead', jid],
454
+ type: 'regular_low',
455
+ apiVersion: 3,
456
+ operation: OP.SET
457
+ };
458
+ }
459
+ else if ('deleteForMe' in mod) {
460
+ const { timestamp, key, deleteMedia } = mod.deleteForMe;
461
+ patch = {
462
+ syncAction: {
463
+ deleteMessageForMeAction: {
464
+ deleteMedia,
465
+ messageTimestamp: timestamp
466
+ }
467
+ },
468
+ index: ['deleteMessageForMe', jid, key.id, key.fromMe ? '1' : '0', '0'],
469
+ type: 'regular_high',
470
+ apiVersion: 3,
471
+ operation: OP.SET
472
+ };
473
+ }
474
+ else if ('clear' in mod) {
475
+ patch = {
476
+ syncAction: {
477
+ clearChatAction: {
478
+ messageRange: getMessageRange(mod.lastMessages)
479
+ }
480
+ },
481
+ index: ['clearChat', jid, '1' /*the option here is 0 when keep starred messages is enabled*/, '0'],
482
+ type: 'regular_high',
483
+ apiVersion: 6,
484
+ operation: OP.SET
485
+ };
486
+ }
487
+ else if ('pin' in mod) {
488
+ patch = {
489
+ syncAction: {
490
+ pinAction: {
491
+ pinned: !!mod.pin
492
+ }
493
+ },
494
+ index: ['pin_v1', jid],
495
+ type: 'regular_low',
496
+ apiVersion: 5,
497
+ operation: OP.SET
498
+ };
499
+ }
500
+ else if ('contact' in mod) {
501
+ patch = {
502
+ syncAction: {
503
+ contactAction: mod.contact || {}
504
+ },
505
+ index: ['contact', jid],
506
+ type: 'critical_unblock_low',
507
+ apiVersion: 2,
508
+ operation: mod.contact ? OP.SET : OP.REMOVE
509
+ };
510
+ }
511
+ else if ('disableLinkPreviews' in mod) {
512
+ patch = {
513
+ syncAction: {
514
+ privacySettingDisableLinkPreviewsAction: mod.disableLinkPreviews || {}
515
+ },
516
+ index: ['setting_disableLinkPreviews'],
517
+ type: 'regular',
518
+ apiVersion: 8,
519
+ operation: OP.SET
520
+ };
521
+ }
522
+ else if ('star' in mod) {
523
+ const key = mod.star.messages[0];
524
+ patch = {
525
+ syncAction: {
526
+ starAction: {
527
+ starred: !!mod.star.star
528
+ }
529
+ },
530
+ index: ['star', jid, key.id, key.fromMe ? '1' : '0', '0'],
531
+ type: 'regular_low',
532
+ apiVersion: 2,
533
+ operation: OP.SET
534
+ };
535
+ }
536
+ else if ('delete' in mod) {
537
+ patch = {
538
+ syncAction: {
539
+ deleteChatAction: {
540
+ messageRange: getMessageRange(mod.lastMessages)
541
+ }
542
+ },
543
+ index: ['deleteChat', jid, '1'],
544
+ type: 'regular_high',
545
+ apiVersion: 6,
546
+ operation: OP.SET
547
+ };
548
+ }
549
+ else if ('pushNameSetting' in mod) {
550
+ patch = {
551
+ syncAction: {
552
+ pushNameSetting: {
553
+ name: mod.pushNameSetting
554
+ }
555
+ },
556
+ index: ['setting_pushName'],
557
+ type: 'critical_block',
558
+ apiVersion: 1,
559
+ operation: OP.SET
560
+ };
561
+ }
562
+ else if ('quickReply' in mod) {
563
+ patch = {
564
+ syncAction: {
565
+ quickReplyAction: {
566
+ count: 0,
567
+ deleted: mod.quickReply.deleted || false,
568
+ keywords: [],
569
+ message: mod.quickReply.message || '',
570
+ shortcut: mod.quickReply.shortcut || ''
571
+ }
572
+ },
573
+ index: ['quick_reply', mod.quickReply.timestamp || String(Math.floor(Date.now() / 1000))],
574
+ type: 'regular',
575
+ apiVersion: 2,
576
+ operation: OP.SET
577
+ };
578
+ }
579
+ else if ('addLabel' in mod) {
580
+ patch = {
581
+ syncAction: {
582
+ labelEditAction: {
583
+ name: mod.addLabel.name,
584
+ color: mod.addLabel.color,
585
+ predefinedId: mod.addLabel.predefinedId,
586
+ deleted: mod.addLabel.deleted
587
+ }
588
+ },
589
+ index: ['label_edit', mod.addLabel.id],
590
+ type: 'regular',
591
+ apiVersion: 3,
592
+ operation: OP.SET
593
+ };
594
+ }
595
+ else if ('addChatLabel' in mod) {
596
+ patch = {
597
+ syncAction: {
598
+ labelAssociationAction: {
599
+ labeled: true
600
+ }
601
+ },
602
+ index: [LabelAssociationType.Chat, mod.addChatLabel.labelId, jid],
603
+ type: 'regular',
604
+ apiVersion: 3,
605
+ operation: OP.SET
606
+ };
607
+ }
608
+ else if ('removeChatLabel' in mod) {
609
+ patch = {
610
+ syncAction: {
611
+ labelAssociationAction: {
612
+ labeled: false
613
+ }
614
+ },
615
+ index: [LabelAssociationType.Chat, mod.removeChatLabel.labelId, jid],
616
+ type: 'regular',
617
+ apiVersion: 3,
618
+ operation: OP.SET
619
+ };
620
+ }
621
+ else if ('addMessageLabel' in mod) {
622
+ patch = {
623
+ syncAction: {
624
+ labelAssociationAction: {
625
+ labeled: true
626
+ }
627
+ },
628
+ index: [LabelAssociationType.Message, mod.addMessageLabel.labelId, jid, mod.addMessageLabel.messageId, '0', '0'],
629
+ type: 'regular',
630
+ apiVersion: 3,
631
+ operation: OP.SET
632
+ };
633
+ }
634
+ else if ('removeMessageLabel' in mod) {
635
+ patch = {
636
+ syncAction: {
637
+ labelAssociationAction: {
638
+ labeled: false
639
+ }
640
+ },
641
+ index: [
642
+ LabelAssociationType.Message,
643
+ mod.removeMessageLabel.labelId,
644
+ jid,
645
+ mod.removeMessageLabel.messageId,
646
+ '0',
647
+ '0'
648
+ ],
649
+ type: 'regular',
650
+ apiVersion: 3,
651
+ operation: OP.SET
652
+ };
653
+ }
654
+ else {
655
+ throw new Boom('not supported');
656
+ }
657
+ patch.syncAction.timestamp = Date.now();
658
+ return patch;
659
+ };
660
+ export const processSyncAction = (syncAction, ev, me, initialSyncOpts, logger) => {
661
+ const isInitialSync = !!initialSyncOpts;
662
+ const accountSettings = initialSyncOpts?.accountSettings;
663
+ logger?.trace({ syncAction, initialSync: !!initialSyncOpts }, 'processing sync action');
664
+ const { syncAction: { value: action }, index: [type, id, msgId, fromMe] } = syncAction;
665
+ if (action?.muteAction) {
666
+ ev.emit('chats.update', [
667
+ {
668
+ id,
669
+ muteEndTime: action.muteAction?.muted ? toNumber(action.muteAction.muteEndTimestamp) : null,
670
+ conditional: getChatUpdateConditional(id, undefined)
671
+ }
672
+ ]);
673
+ }
674
+ else if (action?.archiveChatAction || type === 'archive' || type === 'unarchive') {
675
+ // okay so we've to do some annoying computation here
676
+ // when we're initially syncing the app state
677
+ // there are a few cases we need to handle
678
+ // 1. if the account unarchiveChats setting is true
679
+ // a. if the chat is archived, and no further messages have been received -- simple, keep archived
680
+ // b. if the chat was archived, and the user received messages from the other person afterwards
681
+ // then the chat should be marked unarchved --
682
+ // we compare the timestamp of latest message from the other person to determine this
683
+ // 2. if the account unarchiveChats setting is false -- then it doesn't matter,
684
+ // it'll always take an app state action to mark in unarchived -- which we'll get anyway
685
+ const archiveAction = action?.archiveChatAction;
686
+ const isArchived = archiveAction ? archiveAction.archived : type === 'archive';
687
+ // // basically we don't need to fire an "archive" update if the chat is being marked unarchvied
688
+ // // this only applies for the initial sync
689
+ // if(isInitialSync && !isArchived) {
690
+ // isArchived = false
691
+ // }
692
+ const msgRange = !accountSettings?.unarchiveChats ? undefined : archiveAction?.messageRange;
693
+ // logger?.debug({ chat: id, syncAction }, 'message range archive')
694
+ ev.emit('chats.update', [
695
+ {
696
+ id,
697
+ archived: isArchived,
698
+ conditional: getChatUpdateConditional(id, msgRange)
699
+ }
700
+ ]);
701
+ }
702
+ else if (action?.markChatAsReadAction) {
703
+ const markReadAction = action.markChatAsReadAction;
704
+ // basically we don't need to fire an "read" update if the chat is being marked as read
705
+ // because the chat is read by default
706
+ // this only applies for the initial sync
707
+ const isNullUpdate = isInitialSync && markReadAction.read;
708
+ ev.emit('chats.update', [
709
+ {
710
+ id,
711
+ unreadCount: isNullUpdate ? null : !!markReadAction?.read ? 0 : -1,
712
+ conditional: getChatUpdateConditional(id, markReadAction?.messageRange)
713
+ }
714
+ ]);
715
+ }
716
+ else if (action?.deleteMessageForMeAction || type === 'deleteMessageForMe') {
717
+ ev.emit('messages.delete', {
718
+ keys: [
719
+ {
720
+ remoteJid: id,
721
+ id: msgId,
722
+ fromMe: fromMe === '1'
723
+ }
724
+ ]
725
+ });
726
+ }
727
+ else if (action?.contactAction) {
728
+ const results = processContactAction(action.contactAction, id, logger);
729
+ emitSyncActionResults(ev, results);
730
+ }
731
+ else if (action?.pushNameSetting) {
732
+ const name = action?.pushNameSetting?.name;
733
+ if (name && me?.name !== name) {
734
+ ev.emit('creds.update', { me: { ...me, name } });
735
+ }
736
+ }
737
+ else if (action?.pinAction) {
738
+ ev.emit('chats.update', [
739
+ {
740
+ id,
741
+ pinned: action.pinAction?.pinned ? toNumber(action.timestamp) : null,
742
+ conditional: getChatUpdateConditional(id, undefined)
743
+ }
744
+ ]);
745
+ }
746
+ else if (action?.unarchiveChatsSetting) {
747
+ const unarchiveChats = !!action.unarchiveChatsSetting.unarchiveChats;
748
+ ev.emit('creds.update', { accountSettings: { unarchiveChats } });
749
+ logger?.info(`archive setting updated => '${action.unarchiveChatsSetting.unarchiveChats}'`);
750
+ if (accountSettings) {
751
+ accountSettings.unarchiveChats = unarchiveChats;
752
+ }
753
+ }
754
+ else if (action?.starAction || type === 'star') {
755
+ let starred = action?.starAction?.starred;
756
+ if (typeof starred !== 'boolean') {
757
+ starred = syncAction.index[syncAction.index.length - 1] === '1';
758
+ }
759
+ ev.emit('messages.update', [
760
+ {
761
+ key: { remoteJid: id, id: msgId, fromMe: fromMe === '1' },
762
+ update: { starred }
763
+ }
764
+ ]);
765
+ }
766
+ else if (action?.deleteChatAction || type === 'deleteChat') {
767
+ if (!isInitialSync) {
768
+ ev.emit('chats.delete', [id]);
769
+ }
770
+ }
771
+ else if (action?.labelEditAction) {
772
+ const { name, color, deleted, predefinedId } = action.labelEditAction;
773
+ ev.emit('labels.edit', {
774
+ id: id,
775
+ name: name,
776
+ color: color,
777
+ deleted: deleted,
778
+ predefinedId: predefinedId ? String(predefinedId) : undefined
779
+ });
780
+ }
781
+ else if (action?.labelAssociationAction) {
782
+ ev.emit('labels.association', {
783
+ type: action.labelAssociationAction.labeled ? 'add' : 'remove',
784
+ association: type === LabelAssociationType.Chat
785
+ ? {
786
+ type: LabelAssociationType.Chat,
787
+ chatId: syncAction.index[2],
788
+ labelId: syncAction.index[1]
789
+ }
790
+ : {
791
+ type: LabelAssociationType.Message,
792
+ chatId: syncAction.index[2],
793
+ messageId: syncAction.index[3],
794
+ labelId: syncAction.index[1]
795
+ }
796
+ });
797
+ }
798
+ else if (action?.localeSetting?.locale) {
799
+ ev.emit('settings.update', { setting: 'locale', value: action.localeSetting.locale });
800
+ }
801
+ else if (action?.timeFormatAction) {
802
+ ev.emit('settings.update', { setting: 'timeFormat', value: action.timeFormatAction });
803
+ }
804
+ else if (action?.pnForLidChatAction) {
805
+ if (action.pnForLidChatAction.pnJid) {
806
+ ev.emit('lid-mapping.update', { lid: id, pn: action.pnForLidChatAction.pnJid });
807
+ }
808
+ }
809
+ else if (action?.privacySettingRelayAllCalls) {
810
+ ev.emit('settings.update', {
811
+ setting: 'privacySettingRelayAllCalls',
812
+ value: action.privacySettingRelayAllCalls
813
+ });
814
+ }
815
+ else if (action?.statusPrivacy) {
816
+ ev.emit('settings.update', { setting: 'statusPrivacy', value: action.statusPrivacy });
817
+ }
818
+ else if (action?.lockChatAction) {
819
+ ev.emit('chats.lock', { id: id, locked: !!action.lockChatAction.locked });
820
+ }
821
+ else if (action?.privacySettingDisableLinkPreviewsAction) {
822
+ ev.emit('settings.update', {
823
+ setting: 'disableLinkPreviews',
824
+ value: action.privacySettingDisableLinkPreviewsAction
825
+ });
826
+ }
827
+ else if (action?.notificationActivitySettingAction?.notificationActivitySetting) {
828
+ ev.emit('settings.update', {
829
+ setting: 'notificationActivitySetting',
830
+ value: action.notificationActivitySettingAction.notificationActivitySetting
831
+ });
832
+ }
833
+ else if (action?.lidContactAction) {
834
+ ev.emit('contacts.upsert', [
835
+ {
836
+ id: id,
837
+ name: action.lidContactAction.fullName ||
838
+ action.lidContactAction.firstName ||
839
+ action.lidContactAction.username ||
840
+ undefined,
841
+ username: action.lidContactAction.username || undefined,
842
+ lid: id,
843
+ phoneNumber: undefined
844
+ }
845
+ ]);
846
+ }
847
+ else if (action?.privacySettingChannelsPersonalisedRecommendationAction) {
848
+ ev.emit('settings.update', {
849
+ setting: 'channelsPersonalisedRecommendation',
850
+ value: action.privacySettingChannelsPersonalisedRecommendationAction
851
+ });
852
+ }
853
+ else {
854
+ logger?.debug({ syncAction, id }, 'unprocessable update');
855
+ }
856
+ function getChatUpdateConditional(id, msgRange) {
857
+ return isInitialSync
858
+ ? data => {
859
+ const chat = data.historySets.chats[id] || data.chatUpserts[id];
860
+ if (chat) {
861
+ return msgRange ? isValidPatchBasedOnMessageRange(chat, msgRange) : true;
862
+ }
863
+ }
864
+ : undefined;
865
+ }
866
+ function isValidPatchBasedOnMessageRange(chat, msgRange) {
867
+ const lastMsgTimestamp = Number(msgRange?.lastMessageTimestamp || msgRange?.lastSystemMessageTimestamp || 0);
868
+ const chatLastMsgTimestamp = Number(chat?.lastMessageRecvTimestamp || 0);
869
+ return lastMsgTimestamp >= chatLastMsgTimestamp;
870
+ }
871
+ };
872
+ //# sourceMappingURL=chat-utils.js.map