zapo-js 0.1.1 → 0.2.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 (589) hide show
  1. package/README.md +20 -4
  2. package/dist/appstate/WaAppStateCrypto.js +19 -26
  3. package/dist/appstate/WaAppStateSyncClient.js +293 -181
  4. package/dist/appstate/WaAppStateSyncResponseParser.js +16 -5
  5. package/dist/appstate/constants.js +4 -3
  6. package/dist/appstate/{store/sqlite.js → encoding.js} +13 -8
  7. package/dist/appstate/index.js +8 -6
  8. package/dist/appstate/utils.js +9 -34
  9. package/dist/auth/WaAuthClient.js +43 -61
  10. package/dist/auth/flow/WaAuthCredentialsFlow.js +22 -15
  11. package/dist/auth/index.js +1 -8
  12. package/dist/auth/pairing/WaPairingCodeCrypto.js +6 -4
  13. package/dist/auth/pairing/WaPairingFlow.js +34 -26
  14. package/dist/auth/pairing/WaQrFlow.js +37 -24
  15. package/dist/client/WaClient.js +275 -324
  16. package/dist/client/WaClientFactory.js +500 -133
  17. package/dist/client/connection/WaConnectionManager.js +301 -0
  18. package/dist/client/connection/WaKeyShareCoordinator.js +63 -0
  19. package/dist/client/connection/WaReceiptQueue.js +51 -0
  20. package/dist/client/coordinators/WaAppStateMutationCoordinator.js +471 -0
  21. package/dist/client/coordinators/WaBusinessCoordinator.js +241 -0
  22. package/dist/client/coordinators/WaGroupCoordinator.js +30 -16
  23. package/dist/client/coordinators/WaIncomingNodeCoordinator.js +21 -27
  24. package/dist/client/coordinators/WaMessageDispatchCoordinator.js +439 -701
  25. package/dist/client/coordinators/WaPassiveTasksCoordinator.js +74 -31
  26. package/dist/client/coordinators/WaPrivacyCoordinator.js +134 -0
  27. package/dist/client/coordinators/WaProfileCoordinator.js +212 -0
  28. package/dist/client/coordinators/WaRetryCoordinator.js +242 -57
  29. package/dist/client/coordinators/WaStreamControlCoordinator.js +18 -11
  30. package/dist/client/coordinators/WaTrustedContactTokenCoordinator.js +166 -0
  31. package/dist/client/dirty.js +74 -48
  32. package/dist/client/events/chat.js +4 -3
  33. package/dist/client/events/devices.js +72 -0
  34. package/dist/client/events/group.js +62 -47
  35. package/dist/client/events/identity.js +22 -0
  36. package/dist/client/events/privacy-token.js +39 -0
  37. package/dist/client/history-sync.js +94 -63
  38. package/dist/client/incoming.js +60 -27
  39. package/dist/client/mailbox.js +24 -23
  40. package/dist/client/messages.js +107 -31
  41. package/dist/client/messaging/fanout.js +199 -0
  42. package/dist/client/messaging/key-protocol.js +130 -0
  43. package/dist/client/messaging/participants.js +193 -0
  44. package/dist/client/persistence/WriteBehindPersistence.js +129 -0
  45. package/dist/client/tokens/cs-token.js +50 -0
  46. package/dist/client/tokens/tc-token.js +25 -0
  47. package/dist/crypto/core/hkdf.js +3 -8
  48. package/dist/crypto/core/index.js +2 -5
  49. package/dist/crypto/core/keys.js +6 -7
  50. package/dist/crypto/core/nonce.js +2 -0
  51. package/dist/crypto/core/primitives.js +12 -23
  52. package/dist/crypto/core/random.js +26 -23
  53. package/dist/crypto/curves/Ed25519.js +7 -8
  54. package/dist/crypto/curves/X25519.js +38 -22
  55. package/dist/crypto/index.js +1 -3
  56. package/dist/crypto/math/constants.js +13 -36
  57. package/dist/crypto/math/edwards.js +171 -44
  58. package/dist/crypto/math/fe.js +706 -0
  59. package/dist/crypto/math/mod.js +10 -3
  60. package/dist/esm/appstate/WaAppStateCrypto.js +7 -14
  61. package/dist/esm/appstate/WaAppStateSyncClient.js +284 -172
  62. package/dist/esm/appstate/WaAppStateSyncResponseParser.js +17 -6
  63. package/dist/esm/appstate/constants.js +3 -2
  64. package/dist/esm/appstate/{store/sqlite.js → encoding.js} +13 -8
  65. package/dist/esm/appstate/index.js +2 -2
  66. package/dist/esm/appstate/utils.js +8 -30
  67. package/dist/esm/auth/WaAuthClient.js +43 -61
  68. package/dist/esm/auth/flow/WaAuthCredentialsFlow.js +22 -15
  69. package/dist/esm/auth/index.js +0 -3
  70. package/dist/esm/auth/pairing/WaPairingCodeCrypto.js +6 -4
  71. package/dist/esm/auth/pairing/WaPairingFlow.js +28 -20
  72. package/dist/esm/auth/pairing/WaQrFlow.js +37 -24
  73. package/dist/esm/client/WaClient.js +275 -324
  74. package/dist/esm/client/WaClientFactory.js +501 -134
  75. package/dist/esm/client/connection/WaConnectionManager.js +297 -0
  76. package/dist/esm/client/connection/WaKeyShareCoordinator.js +59 -0
  77. package/dist/esm/client/connection/WaReceiptQueue.js +47 -0
  78. package/dist/esm/client/coordinators/WaAppStateMutationCoordinator.js +467 -0
  79. package/dist/esm/client/coordinators/WaBusinessCoordinator.js +238 -0
  80. package/dist/esm/client/coordinators/WaGroupCoordinator.js +23 -9
  81. package/dist/esm/client/coordinators/WaIncomingNodeCoordinator.js +21 -27
  82. package/dist/esm/client/coordinators/WaMessageDispatchCoordinator.js +443 -705
  83. package/dist/esm/client/coordinators/WaPassiveTasksCoordinator.js +74 -31
  84. package/dist/esm/client/coordinators/WaPrivacyCoordinator.js +131 -0
  85. package/dist/esm/client/coordinators/WaProfileCoordinator.js +209 -0
  86. package/dist/esm/client/coordinators/WaRetryCoordinator.js +244 -59
  87. package/dist/esm/client/coordinators/WaStreamControlCoordinator.js +19 -12
  88. package/dist/esm/client/coordinators/WaTrustedContactTokenCoordinator.js +162 -0
  89. package/dist/esm/client/dirty.js +69 -43
  90. package/dist/esm/client/events/chat.js +4 -3
  91. package/dist/esm/client/events/devices.js +68 -0
  92. package/dist/esm/client/events/group.js +53 -39
  93. package/dist/esm/client/events/identity.js +19 -0
  94. package/dist/esm/client/events/privacy-token.js +36 -0
  95. package/dist/esm/client/history-sync.js +91 -60
  96. package/dist/esm/client/incoming.js +61 -28
  97. package/dist/esm/client/mailbox.js +24 -23
  98. package/dist/esm/client/messages.js +108 -32
  99. package/dist/esm/client/messaging/fanout.js +196 -0
  100. package/dist/esm/client/messaging/key-protocol.js +127 -0
  101. package/dist/esm/client/messaging/participants.js +190 -0
  102. package/dist/esm/client/persistence/WriteBehindPersistence.js +125 -0
  103. package/dist/esm/client/tokens/cs-token.js +46 -0
  104. package/dist/esm/client/tokens/tc-token.js +18 -0
  105. package/dist/esm/crypto/core/hkdf.js +3 -8
  106. package/dist/esm/crypto/core/index.js +2 -3
  107. package/dist/esm/crypto/core/keys.js +3 -4
  108. package/dist/esm/crypto/core/nonce.js +2 -0
  109. package/dist/esm/crypto/core/primitives.js +12 -22
  110. package/dist/esm/crypto/core/random.js +25 -23
  111. package/dist/esm/crypto/curves/Ed25519.js +4 -5
  112. package/dist/esm/crypto/curves/X25519.js +35 -19
  113. package/dist/esm/crypto/index.js +0 -1
  114. package/dist/esm/crypto/math/constants.js +12 -35
  115. package/dist/esm/crypto/math/edwards.js +174 -47
  116. package/dist/esm/crypto/math/fe.js +691 -0
  117. package/dist/esm/crypto/math/mod.js +10 -1
  118. package/dist/esm/index.js +1 -1
  119. package/dist/esm/infra/log/ConsoleLogger.js +18 -17
  120. package/dist/esm/infra/log/PinoLogger.js +15 -9
  121. package/dist/esm/infra/log/types.js +11 -1
  122. package/dist/esm/infra/perf/BackgroundQueue.js +478 -0
  123. package/dist/esm/infra/perf/BoundedTaskQueue.js +16 -18
  124. package/dist/esm/infra/perf/PromiseDedup.js +20 -0
  125. package/dist/esm/infra/perf/SharedExclusiveGate.js +109 -0
  126. package/dist/esm/infra/perf/StoreLock.js +77 -0
  127. package/dist/esm/media/WaMediaCrypto.js +96 -16
  128. package/dist/esm/media/WaMediaTransferClient.js +251 -91
  129. package/dist/esm/media/conn.js +10 -6
  130. package/dist/esm/media/constants.js +6 -2
  131. package/dist/esm/message/WaMessageClient.js +30 -32
  132. package/dist/esm/message/ack.js +6 -6
  133. package/dist/esm/message/addon-crypto.js +59 -0
  134. package/dist/esm/message/content.js +195 -9
  135. package/dist/esm/message/icdc.js +76 -0
  136. package/dist/esm/message/incoming.js +129 -122
  137. package/dist/esm/message/index.js +2 -0
  138. package/dist/esm/message/phash.js +3 -1
  139. package/dist/esm/message/reporting-token.js +425 -0
  140. package/dist/esm/message/use-case-secret.js +49 -0
  141. package/dist/esm/protocol/appstate.js +27 -0
  142. package/dist/esm/protocol/browser.js +10 -18
  143. package/dist/esm/protocol/constants.js +6 -3
  144. package/dist/esm/protocol/defaults.js +6 -0
  145. package/dist/esm/protocol/index.js +2 -11
  146. package/dist/esm/protocol/jid.js +133 -52
  147. package/dist/esm/protocol/media.js +3 -3
  148. package/dist/esm/protocol/message.js +61 -1
  149. package/dist/esm/protocol/nodes.js +4 -0
  150. package/dist/esm/protocol/notification.js +3 -1
  151. package/dist/esm/protocol/privacy-token.js +17 -0
  152. package/dist/esm/protocol/privacy.js +55 -0
  153. package/dist/esm/protocol/stream.js +26 -1
  154. package/dist/esm/protocol/usync.js +11 -0
  155. package/dist/esm/retry/codec.js +216 -0
  156. package/dist/esm/retry/constants.js +1 -1
  157. package/dist/esm/retry/index.js +3 -2
  158. package/dist/esm/retry/parse.js +88 -86
  159. package/dist/esm/retry/replay.js +54 -51
  160. package/dist/esm/retry/tracker.js +94 -0
  161. package/dist/esm/signal/api/SignalDeviceSyncApi.js +276 -92
  162. package/dist/esm/signal/api/SignalDigestSyncApi.js +17 -8
  163. package/dist/esm/signal/api/SignalIdentitySyncApi.js +67 -37
  164. package/dist/esm/signal/api/SignalMissingPreKeysSyncApi.js +86 -67
  165. package/dist/esm/signal/api/SignalRotateKeyApi.js +4 -2
  166. package/dist/esm/signal/api/SignalSessionSyncApi.js +36 -34
  167. package/dist/esm/signal/api/result-map.js +10 -0
  168. package/dist/esm/signal/constants.js +0 -4
  169. package/dist/esm/signal/crypto/WaAdvSignature.js +13 -9
  170. package/dist/esm/signal/{store/sqlite.js → encoding.js} +93 -60
  171. package/dist/esm/signal/group/SenderKeyChain.js +28 -23
  172. package/dist/esm/signal/group/SenderKeyCodec.js +5 -6
  173. package/dist/esm/signal/group/SenderKeyManager.js +144 -115
  174. package/dist/esm/signal/index.js +2 -0
  175. package/dist/esm/signal/registration/keygen.js +6 -2
  176. package/dist/esm/signal/registration/utils.js +1 -0
  177. package/dist/esm/signal/session/SignalProtocol.js +164 -53
  178. package/dist/esm/signal/session/SignalRatchet.js +24 -15
  179. package/dist/esm/signal/session/SignalSession.js +14 -9
  180. package/dist/esm/signal/session/resolver.js +221 -0
  181. package/dist/esm/store/contracts/privacy-token.store.js +1 -0
  182. package/dist/esm/store/createStore.js +100 -188
  183. package/dist/esm/store/index.js +1 -10
  184. package/dist/esm/store/locks/appstate.lock.js +26 -0
  185. package/dist/esm/store/locks/auth.lock.js +15 -0
  186. package/dist/esm/store/locks/contact.lock.js +20 -0
  187. package/dist/esm/store/locks/device-list.lock.js +20 -0
  188. package/dist/esm/store/locks/message.lock.js +21 -0
  189. package/dist/esm/store/locks/participants.lock.js +20 -0
  190. package/dist/esm/store/locks/privacy-token.lock.js +18 -0
  191. package/dist/esm/store/locks/retry.lock.js +29 -0
  192. package/dist/esm/store/locks/sender-key.lock.js +52 -0
  193. package/dist/esm/store/locks/signal.lock.js +63 -0
  194. package/dist/esm/store/locks/thread.lock.js +21 -0
  195. package/dist/esm/store/noop.store.js +4 -7
  196. package/dist/esm/store/providers/memory/appstate.store.js +38 -16
  197. package/dist/esm/store/providers/memory/contact.store.js +5 -0
  198. package/dist/esm/store/providers/memory/device-list.store.js +12 -34
  199. package/dist/esm/store/providers/memory/message.store.js +11 -5
  200. package/dist/esm/store/providers/memory/participants.store.js +1 -8
  201. package/dist/esm/store/providers/memory/privacy-token.store.js +43 -0
  202. package/dist/esm/store/providers/memory/retry.store.js +77 -2
  203. package/dist/esm/store/providers/memory/sender-key.store.js +11 -8
  204. package/dist/esm/store/providers/memory/signal.store.js +47 -18
  205. package/dist/esm/store/providers/memory/thread.store.js +5 -0
  206. package/dist/esm/transport/WaComms.js +28 -24
  207. package/dist/esm/transport/WaWebSocket.js +115 -18
  208. package/dist/esm/transport/binary/constants.js +0 -30
  209. package/dist/esm/transport/binary/decoder.js +8 -8
  210. package/dist/esm/transport/binary/encoder.js +10 -9
  211. package/dist/esm/transport/binary/index.js +0 -1
  212. package/dist/esm/transport/index.js +1 -0
  213. package/dist/esm/transport/keepalive/WaKeepAlive.js +2 -8
  214. package/dist/esm/transport/node/WaNodeOrchestrator.js +25 -21
  215. package/dist/esm/transport/node/WaNodeTransport.js +0 -3
  216. package/dist/esm/transport/node/builders/{accountSync.js → account-sync.js} +16 -36
  217. package/dist/esm/transport/node/builders/business.js +129 -0
  218. package/dist/esm/transport/node/builders/global.js +370 -0
  219. package/dist/esm/transport/node/builders/index.js +7 -3
  220. package/dist/esm/transport/node/builders/message.js +63 -230
  221. package/dist/esm/transport/node/builders/pairing.js +2 -27
  222. package/dist/esm/transport/node/builders/privacy-token.js +41 -0
  223. package/dist/esm/transport/node/builders/privacy.js +48 -0
  224. package/dist/esm/transport/node/builders/profile.js +70 -0
  225. package/dist/esm/transport/node/builders/retry.js +10 -22
  226. package/dist/esm/transport/node/builders/usync.js +45 -0
  227. package/dist/esm/transport/node/helpers.js +125 -5
  228. package/dist/esm/transport/node/usync.js +5 -0
  229. package/dist/esm/transport/node/xml.js +35 -14
  230. package/dist/esm/transport/noise/WaClientPayload.js +10 -10
  231. package/dist/esm/transport/noise/WaFrameCodec.js +48 -33
  232. package/dist/esm/transport/noise/WaNoiseCert.js +4 -7
  233. package/dist/esm/transport/noise/WaNoiseSession.js +77 -29
  234. package/dist/esm/transport/noise/WaNoiseSocket.js +8 -4
  235. package/dist/esm/transport/proxy.js +27 -0
  236. package/dist/esm/transport/stream/parse.js +17 -48
  237. package/dist/esm/util/bytes.js +67 -45
  238. package/dist/esm/util/coercion.js +6 -14
  239. package/dist/esm/util/index.js +5 -0
  240. package/dist/esm/util/primitives.js +40 -14
  241. package/dist/index.js +7 -1
  242. package/dist/infra/log/ConsoleLogger.js +18 -17
  243. package/dist/infra/log/PinoLogger.js +15 -9
  244. package/dist/infra/log/types.js +12 -0
  245. package/dist/infra/perf/BackgroundQueue.js +482 -0
  246. package/dist/infra/perf/BoundedTaskQueue.js +16 -18
  247. package/dist/infra/perf/PromiseDedup.js +24 -0
  248. package/dist/infra/perf/SharedExclusiveGate.js +113 -0
  249. package/dist/infra/perf/StoreLock.js +81 -0
  250. package/dist/media/WaMediaCrypto.js +95 -15
  251. package/dist/media/WaMediaTransferClient.js +284 -91
  252. package/dist/media/conn.js +10 -6
  253. package/dist/media/constants.js +6 -2
  254. package/dist/message/WaMessageClient.js +31 -33
  255. package/dist/message/ack.js +6 -6
  256. package/dist/message/addon-crypto.js +65 -0
  257. package/dist/message/content.js +198 -9
  258. package/dist/message/icdc.js +81 -0
  259. package/dist/message/incoming.js +127 -120
  260. package/dist/message/index.js +2 -0
  261. package/dist/message/phash.js +3 -1
  262. package/dist/message/reporting-token.js +429 -0
  263. package/dist/message/use-case-secret.js +55 -0
  264. package/dist/protocol/appstate.js +28 -1
  265. package/dist/protocol/browser.js +10 -18
  266. package/dist/protocol/constants.js +26 -1
  267. package/dist/protocol/defaults.js +6 -0
  268. package/dist/protocol/index.js +23 -42
  269. package/dist/protocol/jid.js +140 -52
  270. package/dist/protocol/media.js +3 -3
  271. package/dist/protocol/message.js +62 -2
  272. package/dist/protocol/nodes.js +4 -0
  273. package/dist/protocol/notification.js +3 -1
  274. package/dist/protocol/privacy-token.js +20 -0
  275. package/dist/protocol/privacy.js +58 -0
  276. package/dist/protocol/stream.js +27 -2
  277. package/dist/protocol/usync.js +14 -0
  278. package/dist/retry/codec.js +220 -0
  279. package/dist/retry/constants.js +1 -1
  280. package/dist/retry/index.js +7 -5
  281. package/dist/retry/parse.js +88 -85
  282. package/dist/retry/replay.js +52 -49
  283. package/dist/retry/tracker.js +97 -0
  284. package/dist/signal/api/SignalDeviceSyncApi.js +273 -89
  285. package/dist/signal/api/SignalDigestSyncApi.js +17 -8
  286. package/dist/signal/api/SignalIdentitySyncApi.js +66 -36
  287. package/dist/signal/api/SignalMissingPreKeysSyncApi.js +82 -63
  288. package/dist/signal/api/SignalRotateKeyApi.js +4 -2
  289. package/dist/signal/api/SignalSessionSyncApi.js +36 -34
  290. package/dist/signal/api/result-map.js +13 -0
  291. package/dist/signal/constants.js +1 -5
  292. package/dist/signal/crypto/WaAdvSignature.js +11 -7
  293. package/dist/signal/{store/sqlite.js → encoding.js} +94 -61
  294. package/dist/signal/group/SenderKeyChain.js +27 -22
  295. package/dist/signal/group/SenderKeyCodec.js +5 -6
  296. package/dist/signal/group/SenderKeyManager.js +144 -115
  297. package/dist/signal/index.js +15 -1
  298. package/dist/signal/registration/keygen.js +6 -2
  299. package/dist/signal/registration/utils.js +1 -0
  300. package/dist/signal/session/SignalProtocol.js +164 -53
  301. package/dist/signal/session/SignalRatchet.js +24 -15
  302. package/dist/signal/session/SignalSession.js +14 -9
  303. package/dist/signal/session/resolver.js +224 -0
  304. package/dist/store/contracts/privacy-token.store.js +2 -0
  305. package/dist/store/createStore.js +100 -188
  306. package/dist/store/index.js +15 -33
  307. package/dist/store/locks/appstate.lock.js +29 -0
  308. package/dist/store/locks/auth.lock.js +18 -0
  309. package/dist/store/locks/contact.lock.js +23 -0
  310. package/dist/store/locks/device-list.lock.js +23 -0
  311. package/dist/store/locks/message.lock.js +24 -0
  312. package/dist/store/locks/participants.lock.js +23 -0
  313. package/dist/store/locks/privacy-token.lock.js +21 -0
  314. package/dist/store/locks/retry.lock.js +32 -0
  315. package/dist/store/locks/sender-key.lock.js +55 -0
  316. package/dist/store/locks/signal.lock.js +66 -0
  317. package/dist/store/locks/thread.lock.js +24 -0
  318. package/dist/store/noop.store.js +4 -7
  319. package/dist/store/providers/memory/appstate.store.js +36 -14
  320. package/dist/store/providers/memory/contact.store.js +5 -0
  321. package/dist/store/providers/memory/device-list.store.js +12 -34
  322. package/dist/store/providers/memory/message.store.js +11 -5
  323. package/dist/store/providers/memory/participants.store.js +1 -8
  324. package/dist/store/providers/memory/privacy-token.store.js +47 -0
  325. package/dist/store/providers/memory/retry.store.js +77 -2
  326. package/dist/store/providers/memory/sender-key.store.js +14 -11
  327. package/dist/store/providers/memory/signal.store.js +54 -25
  328. package/dist/store/providers/memory/thread.store.js +5 -0
  329. package/dist/transport/WaComms.js +30 -26
  330. package/dist/transport/WaWebSocket.js +148 -18
  331. package/dist/transport/binary/constants.js +1 -31
  332. package/dist/transport/binary/decoder.js +8 -8
  333. package/dist/transport/binary/encoder.js +10 -9
  334. package/dist/transport/binary/index.js +0 -4
  335. package/dist/transport/index.js +7 -1
  336. package/dist/transport/keepalive/WaKeepAlive.js +1 -7
  337. package/dist/transport/node/WaNodeOrchestrator.js +25 -21
  338. package/dist/transport/node/WaNodeTransport.js +0 -3
  339. package/dist/transport/node/builders/{accountSync.js → account-sync.js} +15 -35
  340. package/dist/transport/node/builders/business.js +137 -0
  341. package/dist/transport/node/builders/global.js +375 -0
  342. package/dist/transport/node/builders/index.js +29 -17
  343. package/dist/transport/node/builders/message.js +64 -236
  344. package/dist/transport/node/builders/pairing.js +2 -29
  345. package/dist/transport/node/builders/privacy-token.js +46 -0
  346. package/dist/transport/node/builders/privacy.js +55 -0
  347. package/dist/transport/node/builders/profile.js +78 -0
  348. package/dist/transport/node/builders/retry.js +9 -21
  349. package/dist/transport/node/builders/usync.js +49 -0
  350. package/dist/transport/node/helpers.js +131 -4
  351. package/dist/transport/node/usync.js +8 -0
  352. package/dist/transport/node/xml.js +35 -14
  353. package/dist/transport/noise/WaClientPayload.js +13 -13
  354. package/dist/transport/noise/WaFrameCodec.js +47 -32
  355. package/dist/transport/noise/WaNoiseCert.js +5 -8
  356. package/dist/transport/noise/WaNoiseSession.js +77 -29
  357. package/dist/transport/noise/WaNoiseSocket.js +8 -4
  358. package/dist/transport/proxy.js +34 -0
  359. package/dist/transport/stream/parse.js +20 -52
  360. package/dist/types/appstate/WaAppStateCrypto.d.ts +0 -1
  361. package/dist/types/appstate/WaAppStateSyncClient.d.ts +5 -2
  362. package/dist/types/appstate/constants.d.ts +1 -0
  363. package/dist/types/appstate/encoding.d.ts +7 -0
  364. package/dist/types/appstate/index.d.ts +3 -3
  365. package/dist/types/appstate/utils.d.ts +0 -3
  366. package/dist/types/auth/WaAuthClient.d.ts +10 -12
  367. package/dist/types/auth/flow/WaAuthCredentialsFlow.d.ts +1 -1
  368. package/dist/types/auth/index.d.ts +0 -4
  369. package/dist/types/auth/pairing/WaQrFlow.d.ts +1 -1
  370. package/dist/types/auth/types.d.ts +7 -9
  371. package/dist/types/client/WaClient.d.ts +42 -25
  372. package/dist/types/client/WaClientFactory.d.ts +33 -26
  373. package/dist/types/client/connection/WaConnectionManager.d.ts +66 -0
  374. package/dist/types/client/connection/WaKeyShareCoordinator.d.ts +14 -0
  375. package/dist/types/client/connection/WaReceiptQueue.d.ts +13 -0
  376. package/dist/types/client/coordinators/WaAppStateMutationCoordinator.d.ts +46 -0
  377. package/dist/types/client/coordinators/WaBusinessCoordinator.d.ts +57 -0
  378. package/dist/types/client/coordinators/WaIncomingNodeCoordinator.d.ts +3 -2
  379. package/dist/types/client/coordinators/WaMessageDispatchCoordinator.d.ts +29 -38
  380. package/dist/types/client/coordinators/WaPassiveTasksCoordinator.d.ts +4 -0
  381. package/dist/types/client/coordinators/WaPrivacyCoordinator.d.ts +26 -0
  382. package/dist/types/client/coordinators/WaProfileCoordinator.d.ts +36 -0
  383. package/dist/types/client/coordinators/WaRetryCoordinator.d.ts +8 -0
  384. package/dist/types/client/coordinators/WaStreamControlCoordinator.d.ts +3 -2
  385. package/dist/types/client/coordinators/WaTrustedContactTokenCoordinator.d.ts +45 -0
  386. package/dist/types/client/dirty.d.ts +1 -0
  387. package/dist/types/client/events/devices.d.ts +20 -0
  388. package/dist/types/client/events/group.d.ts +2 -1
  389. package/dist/types/client/events/identity.d.ts +9 -0
  390. package/dist/types/client/events/privacy-token.d.ts +7 -0
  391. package/dist/types/client/history-sync.d.ts +9 -6
  392. package/dist/types/client/incoming.d.ts +3 -1
  393. package/dist/types/client/index.d.ts +1 -1
  394. package/dist/types/client/mailbox.d.ts +3 -5
  395. package/dist/types/client/messages.d.ts +1 -2
  396. package/dist/types/client/messaging/fanout.d.ts +14 -0
  397. package/dist/types/client/messaging/key-protocol.d.ts +18 -0
  398. package/dist/types/client/messaging/participants.d.ts +13 -0
  399. package/dist/types/client/persistence/WriteBehindPersistence.d.ts +34 -0
  400. package/dist/types/client/tokens/cs-token.d.ts +10 -0
  401. package/dist/types/client/tokens/tc-token.d.ts +5 -0
  402. package/dist/types/client/types.d.ts +75 -4
  403. package/dist/types/crypto/core/hkdf.d.ts +0 -6
  404. package/dist/types/crypto/core/index.d.ts +2 -3
  405. package/dist/types/crypto/core/nonce.d.ts +2 -0
  406. package/dist/types/crypto/core/primitives.d.ts +0 -1
  407. package/dist/types/crypto/core/random.d.ts +2 -7
  408. package/dist/types/crypto/index.d.ts +0 -1
  409. package/dist/types/crypto/math/constants.d.ts +4 -2
  410. package/dist/types/crypto/math/fe.d.ts +30 -0
  411. package/dist/types/crypto/math/mod.d.ts +0 -2
  412. package/dist/types/crypto/math/types.d.ts +11 -4
  413. package/dist/types/index.d.ts +5 -3
  414. package/dist/types/infra/log/ConsoleLogger.d.ts +2 -1
  415. package/dist/types/infra/log/PinoLogger.d.ts +1 -1
  416. package/dist/types/infra/log/types.d.ts +1 -0
  417. package/dist/types/infra/perf/BackgroundQueue.d.ts +58 -0
  418. package/dist/types/infra/perf/BoundedTaskQueue.d.ts +1 -1
  419. package/dist/types/infra/perf/PromiseDedup.d.ts +4 -0
  420. package/dist/types/infra/perf/SharedExclusiveGate.d.ts +17 -0
  421. package/dist/types/infra/perf/StoreLock.d.ts +10 -0
  422. package/dist/types/media/WaMediaCrypto.d.ts +3 -2
  423. package/dist/types/media/WaMediaTransferClient.d.ts +16 -15
  424. package/dist/types/media/constants.d.ts +1 -1
  425. package/dist/types/media/index.d.ts +1 -1
  426. package/dist/types/media/types.d.ts +15 -2
  427. package/dist/types/message/addon-crypto.d.ts +25 -0
  428. package/dist/types/message/content.d.ts +8 -0
  429. package/dist/types/message/icdc.d.ts +13 -0
  430. package/dist/types/message/index.d.ts +2 -0
  431. package/dist/types/message/reporting-token.d.ts +18 -0
  432. package/dist/types/message/types.d.ts +45 -6
  433. package/dist/types/message/use-case-secret.d.ts +20 -0
  434. package/dist/types/protocol/appstate.d.ts +47 -0
  435. package/dist/types/protocol/constants.d.ts +8 -3
  436. package/dist/types/protocol/defaults.d.ts +6 -0
  437. package/dist/types/protocol/index.d.ts +2 -11
  438. package/dist/types/protocol/jid.d.ts +22 -5
  439. package/dist/types/protocol/message.d.ts +60 -0
  440. package/dist/types/protocol/nodes.d.ts +4 -0
  441. package/dist/types/protocol/notification.d.ts +2 -0
  442. package/dist/types/protocol/privacy-token.d.ts +17 -0
  443. package/dist/types/protocol/privacy.d.ts +75 -0
  444. package/dist/types/protocol/stream.d.ts +30 -0
  445. package/dist/types/protocol/usync.d.ts +11 -0
  446. package/dist/types/retry/codec.d.ts +3 -0
  447. package/dist/types/retry/index.d.ts +4 -3
  448. package/dist/types/retry/parse.d.ts +5 -2
  449. package/dist/types/retry/replay.d.ts +0 -4
  450. package/dist/types/retry/tracker.d.ts +20 -0
  451. package/dist/types/retry/types.d.ts +10 -4
  452. package/dist/types/signal/api/SignalDeviceSyncApi.d.ts +15 -2
  453. package/dist/types/signal/api/SignalDigestSyncApi.d.ts +6 -0
  454. package/dist/types/signal/api/SignalIdentitySyncApi.d.ts +2 -0
  455. package/dist/types/signal/api/SignalRotateKeyApi.d.ts +4 -5
  456. package/dist/types/signal/api/SignalSessionSyncApi.d.ts +8 -6
  457. package/dist/types/signal/api/result-map.d.ts +1 -0
  458. package/dist/types/signal/constants.d.ts +0 -3
  459. package/dist/types/signal/{store/sqlite.d.ts → encoding.d.ts} +3 -3
  460. package/dist/types/signal/group/SenderKeyCodec.d.ts +4 -6
  461. package/dist/types/signal/group/SenderKeyManager.d.ts +10 -5
  462. package/dist/types/signal/index.d.ts +3 -0
  463. package/dist/types/signal/session/SignalProtocol.d.ts +19 -4
  464. package/dist/types/signal/session/resolver.d.ts +22 -0
  465. package/dist/types/store/contracts/appstate.store.d.ts +4 -1
  466. package/dist/types/store/contracts/contact.store.d.ts +1 -0
  467. package/dist/types/store/contracts/device-list.store.d.ts +0 -3
  468. package/dist/types/store/contracts/message.store.d.ts +1 -0
  469. package/dist/types/store/contracts/participants.store.d.ts +0 -1
  470. package/dist/types/store/contracts/privacy-token.store.d.ts +16 -0
  471. package/dist/types/store/contracts/retry.store.d.ts +7 -0
  472. package/dist/types/store/contracts/sender-key.store.d.ts +0 -1
  473. package/dist/types/store/contracts/signal.store.d.ts +13 -0
  474. package/dist/types/store/contracts/thread.store.d.ts +1 -0
  475. package/dist/types/store/createStore.d.ts +1 -1
  476. package/dist/types/store/index.d.ts +5 -13
  477. package/dist/types/store/locks/appstate.lock.d.ts +3 -0
  478. package/dist/types/store/locks/auth.lock.d.ts +3 -0
  479. package/dist/types/store/locks/contact.lock.d.ts +3 -0
  480. package/dist/types/store/locks/device-list.lock.d.ts +2 -0
  481. package/dist/types/store/locks/message.lock.d.ts +3 -0
  482. package/dist/types/store/locks/participants.lock.d.ts +2 -0
  483. package/dist/types/store/locks/privacy-token.lock.d.ts +2 -0
  484. package/dist/types/store/locks/retry.lock.d.ts +2 -0
  485. package/dist/types/store/locks/sender-key.lock.d.ts +3 -0
  486. package/dist/types/store/locks/signal.lock.d.ts +3 -0
  487. package/dist/types/store/locks/thread.lock.d.ts +3 -0
  488. package/dist/types/store/providers/memory/appstate.store.d.ts +3 -1
  489. package/dist/types/store/providers/memory/contact.store.d.ts +1 -0
  490. package/dist/types/store/providers/memory/device-list.store.d.ts +0 -3
  491. package/dist/types/store/providers/memory/message.store.d.ts +1 -0
  492. package/dist/types/store/providers/memory/participants.store.d.ts +0 -1
  493. package/dist/types/store/providers/memory/privacy-token.store.d.ts +13 -0
  494. package/dist/types/store/providers/memory/retry.store.d.ts +8 -0
  495. package/dist/types/store/providers/memory/sender-key.store.d.ts +0 -1
  496. package/dist/types/store/providers/memory/signal.store.d.ts +8 -1
  497. package/dist/types/store/providers/memory/thread.store.d.ts +1 -0
  498. package/dist/types/store/types.d.ts +49 -58
  499. package/dist/types/transport/WaWebSocket.d.ts +3 -1
  500. package/dist/types/transport/binary/constants.d.ts +0 -30
  501. package/dist/types/transport/binary/index.d.ts +0 -1
  502. package/dist/types/transport/index.d.ts +2 -1
  503. package/dist/types/transport/keepalive/WaKeepAlive.d.ts +0 -1
  504. package/dist/types/transport/node/WaNodeOrchestrator.d.ts +3 -4
  505. package/dist/types/transport/node/WaNodeTransport.d.ts +0 -9
  506. package/dist/types/transport/node/builders/business.d.ts +29 -0
  507. package/dist/types/transport/node/builders/global.d.ts +102 -0
  508. package/dist/types/transport/node/builders/group.d.ts +4 -6
  509. package/dist/types/transport/node/builders/index.d.ts +7 -3
  510. package/dist/types/transport/node/builders/message.d.ts +20 -30
  511. package/dist/types/transport/node/builders/pairing.d.ts +0 -2
  512. package/dist/types/transport/node/builders/privacy-token.d.ts +9 -0
  513. package/dist/types/transport/node/builders/privacy.d.ts +7 -0
  514. package/dist/types/transport/node/builders/profile.d.ts +8 -0
  515. package/dist/types/transport/node/builders/retry.d.ts +2 -5
  516. package/dist/types/transport/node/builders/usync.d.ts +21 -0
  517. package/dist/types/transport/node/helpers.d.ts +13 -0
  518. package/dist/types/transport/node/usync.d.ts +2 -0
  519. package/dist/types/transport/noise/WaFrameCodec.d.ts +3 -0
  520. package/dist/types/transport/noise/WaNoiseSession.d.ts +4 -2
  521. package/dist/types/transport/noise/WaNoiseSocket.d.ts +4 -2
  522. package/dist/types/transport/proxy.d.ts +6 -0
  523. package/dist/types/transport/stream/parse.d.ts +0 -1
  524. package/dist/types/transport/types.d.ts +18 -1
  525. package/dist/types/util/bytes.d.ts +5 -0
  526. package/dist/types/util/index.d.ts +5 -0
  527. package/dist/types/util/primitives.d.ts +2 -0
  528. package/dist/util/bytes.js +72 -46
  529. package/dist/util/coercion.js +6 -14
  530. package/dist/util/index.js +23 -0
  531. package/dist/util/primitives.js +42 -14
  532. package/package.json +52 -9
  533. package/proto/index.js +1 -1
  534. package/dist/crypto/core/constants.js +0 -4
  535. package/dist/crypto/core/encoding.js +0 -29
  536. package/dist/esm/crypto/core/constants.js +0 -1
  537. package/dist/esm/crypto/core/encoding.js +0 -25
  538. package/dist/esm/retry/outbound.js +0 -83
  539. package/dist/esm/store/providers/sqlite/BaseSqliteStore.js +0 -37
  540. package/dist/esm/store/providers/sqlite/appstate.store.js +0 -169
  541. package/dist/esm/store/providers/sqlite/auth.store.js +0 -176
  542. package/dist/esm/store/providers/sqlite/connection.js +0 -240
  543. package/dist/esm/store/providers/sqlite/contact.store.js +0 -61
  544. package/dist/esm/store/providers/sqlite/device-list.store.js +0 -155
  545. package/dist/esm/store/providers/sqlite/message.store.js +0 -119
  546. package/dist/esm/store/providers/sqlite/migrations.js +0 -347
  547. package/dist/esm/store/providers/sqlite/participants.store.js +0 -85
  548. package/dist/esm/store/providers/sqlite/retry.store.js +0 -144
  549. package/dist/esm/store/providers/sqlite/sender-key.store.js +0 -203
  550. package/dist/esm/store/providers/sqlite/signal.store.js +0 -353
  551. package/dist/esm/store/providers/sqlite/thread.store.js +0 -72
  552. package/dist/esm/util/base64.js +0 -18
  553. package/dist/esm/util/signal-address.js +0 -5
  554. package/dist/retry/outbound.js +0 -88
  555. package/dist/store/providers/sqlite/BaseSqliteStore.js +0 -41
  556. package/dist/store/providers/sqlite/appstate.store.js +0 -173
  557. package/dist/store/providers/sqlite/auth.store.js +0 -180
  558. package/dist/store/providers/sqlite/connection.js +0 -276
  559. package/dist/store/providers/sqlite/contact.store.js +0 -65
  560. package/dist/store/providers/sqlite/device-list.store.js +0 -159
  561. package/dist/store/providers/sqlite/message.store.js +0 -123
  562. package/dist/store/providers/sqlite/migrations.js +0 -350
  563. package/dist/store/providers/sqlite/participants.store.js +0 -89
  564. package/dist/store/providers/sqlite/retry.store.js +0 -148
  565. package/dist/store/providers/sqlite/sender-key.store.js +0 -207
  566. package/dist/store/providers/sqlite/signal.store.js +0 -357
  567. package/dist/store/providers/sqlite/thread.store.js +0 -76
  568. package/dist/types/appstate/store/sqlite.d.ts +0 -21
  569. package/dist/types/crypto/core/constants.d.ts +0 -1
  570. package/dist/types/crypto/core/encoding.d.ts +0 -11
  571. package/dist/types/retry/outbound.d.ts +0 -4
  572. package/dist/types/store/providers/sqlite/BaseSqliteStore.d.ts +0 -12
  573. package/dist/types/store/providers/sqlite/appstate.store.d.ts +0 -15
  574. package/dist/types/store/providers/sqlite/auth.store.d.ts +0 -10
  575. package/dist/types/store/providers/sqlite/connection.d.ts +0 -10
  576. package/dist/types/store/providers/sqlite/contact.store.d.ts +0 -10
  577. package/dist/types/store/providers/sqlite/device-list.store.d.ts +0 -18
  578. package/dist/types/store/providers/sqlite/message.store.d.ts +0 -11
  579. package/dist/types/store/providers/sqlite/migrations.d.ts +0 -3
  580. package/dist/types/store/providers/sqlite/participants.store.d.ts +0 -13
  581. package/dist/types/store/providers/sqlite/retry.store.d.ts +0 -16
  582. package/dist/types/store/providers/sqlite/sender-key.store.d.ts +0 -25
  583. package/dist/types/store/providers/sqlite/signal.store.d.ts +0 -46
  584. package/dist/types/store/providers/sqlite/thread.store.d.ts +0 -11
  585. package/dist/types/util/base64.d.ts +0 -4
  586. package/dist/types/util/signal-address.d.ts +0 -2
  587. package/dist/util/base64.js +0 -24
  588. package/dist/util/signal-address.js +0 -8
  589. /package/dist/types/transport/node/builders/{accountSync.d.ts → account-sync.d.ts} +0 -0
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.withRetryLock = withRetryLock;
4
+ const SharedExclusiveGate_1 = require("../../infra/perf/SharedExclusiveGate");
5
+ const StoreLock_1 = require("../../infra/perf/StoreLock");
6
+ const WA_RETRY_CLEANUP_KEY = 'retry:cleanup';
7
+ const WA_RETRY_CLEAR_KEY = 'retry:clear';
8
+ function withRetryLock(store) {
9
+ const lock = new StoreLock_1.StoreLock();
10
+ const gate = new SharedExclusiveGate_1.SharedExclusiveGate();
11
+ return {
12
+ getTtlMs: store.getTtlMs?.bind(store),
13
+ supportsRawReplayPayload: store.supportsRawReplayPayload?.bind(store),
14
+ destroy: async () => {
15
+ await gate.close();
16
+ await lock.shutdown();
17
+ await store.destroy?.();
18
+ },
19
+ getOutboundRequesterStatus: (messageId, requesterDeviceJid) => gate.runShared(() => store.getOutboundRequesterStatus(messageId, requesterDeviceJid)),
20
+ upsertOutboundMessage: (record) => gate.runShared(() => lock.run(`retry:outbound:${record.messageId}`, () => store.upsertOutboundMessage(record))),
21
+ deleteOutboundMessage: (messageId) => gate.runShared(() => lock.run(`retry:outbound:${messageId}`, () => store.deleteOutboundMessage(messageId))),
22
+ getOutboundMessage: (messageId) => gate.runShared(() => store.getOutboundMessage(messageId)),
23
+ updateOutboundMessageState: (messageId, state, updatedAtMs, expiresAtMs) => gate.runShared(() => lock.run(`retry:outbound:${messageId}`, () => store.updateOutboundMessageState(messageId, state, updatedAtMs, expiresAtMs))),
24
+ markOutboundRequesterDelivered: (messageId, requesterDeviceJid, updatedAtMs, expiresAtMs) => gate.runShared(() => lock.runMany([
25
+ `retry:outbound:${messageId}`,
26
+ `retry:outbound:${messageId}:${requesterDeviceJid}`
27
+ ], () => store.markOutboundRequesterDelivered(messageId, requesterDeviceJid, updatedAtMs, expiresAtMs))),
28
+ incrementInboundCounter: (messageId, requesterJid, updatedAtMs, expiresAtMs) => gate.runShared(() => lock.run(`retry:inbound:${messageId}:${requesterJid}`, () => store.incrementInboundCounter(messageId, requesterJid, updatedAtMs, expiresAtMs))),
29
+ cleanupExpired: (nowMs) => gate.runExclusive(() => lock.run(WA_RETRY_CLEANUP_KEY, () => store.cleanupExpired(nowMs))),
30
+ clear: () => gate.runExclusive(() => lock.run(WA_RETRY_CLEAR_KEY, () => store.clear()))
31
+ };
32
+ }
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.withSenderKeyLock = withSenderKeyLock;
4
+ const SharedExclusiveGate_1 = require("../../infra/perf/SharedExclusiveGate");
5
+ const StoreLock_1 = require("../../infra/perf/StoreLock");
6
+ const jid_1 = require("../../protocol/jid");
7
+ const WA_SENDER_KEY_CLEAR_KEY = 'senderKey:clear';
8
+ function senderKeyLockKey(groupId, sender) {
9
+ return `senderKey:${groupId}:${(0, jid_1.signalAddressKey)(sender)}`;
10
+ }
11
+ function senderDistributionLockKey(groupId, sender) {
12
+ return `senderKeyDistribution:${groupId}:${(0, jid_1.signalAddressKey)(sender)}`;
13
+ }
14
+ function senderAnyLockKey(sender) {
15
+ return `senderKey:any:${(0, jid_1.signalAddressKey)(sender)}`;
16
+ }
17
+ function withSenderKeyLock(store) {
18
+ const lock = new StoreLock_1.StoreLock();
19
+ const gate = new SharedExclusiveGate_1.SharedExclusiveGate();
20
+ const destroyStore = store;
21
+ return {
22
+ upsertSenderKey: (record) => gate.runShared(() => lock.runMany([
23
+ senderAnyLockKey(record.sender),
24
+ senderKeyLockKey(record.groupId, record.sender)
25
+ ], () => store.upsertSenderKey(record))),
26
+ upsertSenderKeyDistribution: (record) => gate.runShared(() => lock.runMany([
27
+ senderAnyLockKey(record.sender),
28
+ senderDistributionLockKey(record.groupId, record.sender)
29
+ ], () => store.upsertSenderKeyDistribution(record))),
30
+ upsertSenderKeyDistributions: (records) => gate.runShared(() => lock.runMany(records.flatMap((record) => [
31
+ senderAnyLockKey(record.sender),
32
+ senderDistributionLockKey(record.groupId, record.sender)
33
+ ]), () => store.upsertSenderKeyDistributions(records))),
34
+ getGroupSenderKeyList: (groupId) => gate.runShared(() => store.getGroupSenderKeyList(groupId)),
35
+ getDeviceSenderKey: (groupId, sender) => gate.runShared(() => store.getDeviceSenderKey(groupId, sender)),
36
+ getDeviceSenderKeyDistributions: (groupId, senders) => gate.runShared(() => store.getDeviceSenderKeyDistributions(groupId, senders)),
37
+ deleteDeviceSenderKey: (target, groupId) => gate.runShared(() => lock.runMany(groupId
38
+ ? [
39
+ senderAnyLockKey(target),
40
+ senderKeyLockKey(groupId, target),
41
+ senderDistributionLockKey(groupId, target)
42
+ ]
43
+ : [senderAnyLockKey(target)], () => store.deleteDeviceSenderKey(target, groupId))),
44
+ markForgetSenderKey: (groupId, participants) => gate.runShared(() => lock.runMany(participants.flatMap((participant) => [
45
+ senderAnyLockKey(participant),
46
+ senderKeyLockKey(groupId, participant)
47
+ ]), () => store.markForgetSenderKey(groupId, participants))),
48
+ clear: () => gate.runExclusive(() => lock.run(WA_SENDER_KEY_CLEAR_KEY, () => store.clear())),
49
+ destroy: async () => {
50
+ await gate.close();
51
+ await lock.shutdown();
52
+ await destroyStore.destroy?.();
53
+ }
54
+ };
55
+ }
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.withSignalLock = withSignalLock;
4
+ const SharedExclusiveGate_1 = require("../../infra/perf/SharedExclusiveGate");
5
+ const StoreLock_1 = require("../../infra/perf/StoreLock");
6
+ const WA_SIGNAL_REGISTRATION_KEY = 'signal:registration';
7
+ const WA_SIGNAL_SIGNED_PREKEY_KEY = 'signal:signedPreKey';
8
+ const WA_SIGNAL_PREKEYS_KEY = 'signal:prekeys';
9
+ const WA_SIGNAL_SERVER_HAS_PREKEYS_KEY = 'signal:serverHasPreKeys';
10
+ const WA_SIGNAL_CLEAR_KEY = 'signal:clear';
11
+ function withSignalLock(store) {
12
+ const lock = new StoreLock_1.StoreLock();
13
+ const gate = new SharedExclusiveGate_1.SharedExclusiveGate();
14
+ const destroyStore = store;
15
+ let cachedRegInfo;
16
+ return {
17
+ getRegistrationInfo: () => gate.runShared(async () => {
18
+ if (cachedRegInfo !== undefined) {
19
+ return cachedRegInfo;
20
+ }
21
+ const info = await store.getRegistrationInfo();
22
+ cachedRegInfo = info;
23
+ return info;
24
+ }),
25
+ setRegistrationInfo: (info) => gate.runShared(() => lock.run(WA_SIGNAL_REGISTRATION_KEY, async () => {
26
+ await store.setRegistrationInfo(info);
27
+ cachedRegInfo = info;
28
+ })),
29
+ getSignedPreKey: () => gate.runShared(() => store.getSignedPreKey()),
30
+ setSignedPreKey: (record) => gate.runShared(() => lock.run(WA_SIGNAL_SIGNED_PREKEY_KEY, () => store.setSignedPreKey(record))),
31
+ getSignedPreKeyById: (keyId) => gate.runShared(() => store.getSignedPreKeyById(keyId)),
32
+ setSignedPreKeyRotationTs: (value) => gate.runShared(() => lock.run(WA_SIGNAL_SIGNED_PREKEY_KEY, () => store.setSignedPreKeyRotationTs(value))),
33
+ getSignedPreKeyRotationTs: () => gate.runShared(() => store.getSignedPreKeyRotationTs()),
34
+ putPreKey: (record) => gate.runShared(() => lock.run(WA_SIGNAL_PREKEYS_KEY, () => store.putPreKey(record))),
35
+ getOrGenPreKeys: (count, generator) => gate.runShared(() => lock.run(WA_SIGNAL_PREKEYS_KEY, () => store.getOrGenPreKeys(count, generator))),
36
+ getPreKeyById: (keyId) => gate.runShared(() => store.getPreKeyById(keyId)),
37
+ getPreKeysById: (keyIds) => gate.runShared(() => store.getPreKeysById(keyIds)),
38
+ consumePreKeyById: (keyId) => gate.runShared(() => lock.run(WA_SIGNAL_PREKEYS_KEY, () => store.consumePreKeyById(keyId))),
39
+ getOrGenSinglePreKey: (generator) => gate.runShared(() => lock.run(WA_SIGNAL_PREKEYS_KEY, () => store.getOrGenSinglePreKey(generator))),
40
+ markKeyAsUploaded: (keyId) => gate.runShared(() => lock.run(WA_SIGNAL_PREKEYS_KEY, () => store.markKeyAsUploaded(keyId))),
41
+ setServerHasPreKeys: (value) => gate.runShared(() => lock.run(WA_SIGNAL_SERVER_HAS_PREKEYS_KEY, () => store.setServerHasPreKeys(value))),
42
+ getServerHasPreKeys: () => gate.runShared(() => store.getServerHasPreKeys()),
43
+ getSignalMeta: () => gate.runShared(() => store.getSignalMeta()),
44
+ hasSession: (address) => gate.runShared(() => store.hasSession(address)),
45
+ hasSessions: (addresses) => gate.runShared(() => store.hasSessions(addresses)),
46
+ getSession: (address) => gate.runShared(() => store.getSession(address)),
47
+ getSessionsBatch: (addresses) => gate.runShared(() => store.getSessionsBatch(addresses)),
48
+ // Session and identity read-modify-write semantics are serialized in SignalProtocol per address.
49
+ setSession: (address, session) => gate.runShared(() => store.setSession(address, session)),
50
+ setSessionsBatch: (entries) => gate.runShared(() => store.setSessionsBatch(entries)),
51
+ deleteSession: (address) => gate.runShared(() => store.deleteSession(address)),
52
+ getRemoteIdentity: (address) => gate.runShared(() => store.getRemoteIdentity(address)),
53
+ getRemoteIdentities: (addresses) => gate.runShared(() => store.getRemoteIdentities(addresses)),
54
+ setRemoteIdentity: (address, identityKey) => gate.runShared(() => store.setRemoteIdentity(address, identityKey)),
55
+ setRemoteIdentities: (entries) => gate.runShared(() => store.setRemoteIdentities(entries)),
56
+ clear: () => gate.runExclusive(() => lock.run(WA_SIGNAL_CLEAR_KEY, async () => {
57
+ await store.clear();
58
+ cachedRegInfo = undefined;
59
+ })),
60
+ destroy: async () => {
61
+ await gate.close();
62
+ await lock.shutdown();
63
+ await destroyStore.destroy?.();
64
+ }
65
+ };
66
+ }
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.withThreadLock = withThreadLock;
4
+ const SharedExclusiveGate_1 = require("../../infra/perf/SharedExclusiveGate");
5
+ const StoreLock_1 = require("../../infra/perf/StoreLock");
6
+ const WA_THREAD_CLEAR_KEY = 'thread:clear';
7
+ function withThreadLock(store) {
8
+ const lock = new StoreLock_1.StoreLock();
9
+ const gate = new SharedExclusiveGate_1.SharedExclusiveGate();
10
+ const destroyStore = store;
11
+ return {
12
+ upsert: (record) => gate.runShared(() => lock.run(`thread:${record.jid}`, () => store.upsert(record))),
13
+ upsertBatch: (records) => gate.runShared(() => lock.runMany(records.map((record) => `thread:${record.jid}`), () => store.upsertBatch(records))),
14
+ getByJid: (jid) => gate.runShared(() => store.getByJid(jid)),
15
+ list: (limit) => gate.runShared(() => store.list(limit)),
16
+ deleteByJid: (jid) => gate.runShared(() => lock.run(`thread:${jid}`, () => store.deleteByJid(jid))),
17
+ clear: () => gate.runExclusive(() => lock.run(WA_THREAD_CLEAR_KEY, () => store.clear())),
18
+ destroy: async () => {
19
+ await gate.close();
20
+ await lock.shutdown();
21
+ await destroyStore.destroy?.();
22
+ }
23
+ };
24
+ }
@@ -2,10 +2,9 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.NOOP_DEVICE_LIST_STORE = exports.NOOP_PARTICIPANTS_STORE = exports.NOOP_CONTACT_STORE = exports.NOOP_THREAD_STORE = exports.NOOP_MESSAGE_STORE = void 0;
4
4
  const EMPTY_STORE_LIST = Object.freeze([]);
5
- const DEFAULT_PARTICIPANTS_CACHE_TTL_MS = 5 * 60 * 1000;
6
- const DEFAULT_DEVICE_LIST_CACHE_TTL_MS = 5 * 60 * 1000;
7
5
  exports.NOOP_MESSAGE_STORE = Object.freeze({
8
6
  upsert: async (_record) => { },
7
+ upsertBatch: async (_records) => { },
9
8
  getById: async (_id) => null,
10
9
  listByThread: async (_threadJid, _limit, _beforeTimestampMs) => EMPTY_STORE_LIST,
11
10
  deleteById: async (_id) => 0,
@@ -13,6 +12,7 @@ exports.NOOP_MESSAGE_STORE = Object.freeze({
13
12
  });
14
13
  exports.NOOP_THREAD_STORE = Object.freeze({
15
14
  upsert: async (_record) => { },
15
+ upsertBatch: async (_records) => { },
16
16
  getByJid: async (_jid) => null,
17
17
  list: async (_limit) => EMPTY_STORE_LIST,
18
18
  deleteByJid: async (_jid) => 0,
@@ -20,12 +20,12 @@ exports.NOOP_THREAD_STORE = Object.freeze({
20
20
  });
21
21
  exports.NOOP_CONTACT_STORE = Object.freeze({
22
22
  upsert: async (_record) => { },
23
+ upsertBatch: async (_records) => { },
23
24
  getByJid: async (_jid) => null,
24
25
  deleteByJid: async (_jid) => 0,
25
26
  clear: async () => { }
26
27
  });
27
28
  exports.NOOP_PARTICIPANTS_STORE = Object.freeze({
28
- getTtlMs: () => DEFAULT_PARTICIPANTS_CACHE_TTL_MS,
29
29
  upsertGroupParticipants: async (_snapshot) => { },
30
30
  getGroupParticipants: async (_groupJid, _nowMs) => null,
31
31
  deleteGroupParticipants: async (_groupJid) => 0,
@@ -34,11 +34,8 @@ exports.NOOP_PARTICIPANTS_STORE = Object.freeze({
34
34
  destroy: async () => { }
35
35
  });
36
36
  exports.NOOP_DEVICE_LIST_STORE = Object.freeze({
37
- getTtlMs: () => DEFAULT_DEVICE_LIST_CACHE_TTL_MS,
38
- upsertUserDevices: async (_snapshot) => { },
39
37
  upsertUserDevicesBatch: async (_snapshots) => { },
40
- getUserDevices: async (_userJid, _nowMs) => null,
41
- getUserDevicesBatch: async (userJids, _nowMs) => userJids.map(() => null),
38
+ getUserDevicesBatch: async (userJids, _nowMs) => new Array(userJids.length).fill(null),
42
39
  deleteUserDevices: async (_userJid) => 0,
43
40
  cleanupExpired: async (_nowMs) => 0,
44
41
  clear: async () => { },
@@ -10,13 +10,6 @@ const DEFAULT_APPSTATE_MEMORY_STORE_LIMITS = Object.freeze({
10
10
  syncKeys: 4096,
11
11
  collectionEntries: 50000
12
12
  });
13
- function toBoundedMap(entries, maxEntries) {
14
- const map = new Map();
15
- for (const [key, value] of entries) {
16
- (0, collections_1.setBoundedMapEntry)(map, key, value, maxEntries);
17
- }
18
- return map;
19
- }
20
13
  class WaAppStateMemoryStore {
21
14
  constructor(initial, options = {}) {
22
15
  this.keys = new Map();
@@ -25,16 +18,21 @@ class WaAppStateMemoryStore {
25
18
  this.maxCollectionEntries = (0, coercion_1.resolvePositive)(options.maxCollectionEntries, DEFAULT_APPSTATE_MEMORY_STORE_LIMITS.collectionEntries, 'WaAppStateMemoryStoreOptions.maxCollectionEntries');
26
19
  if (initial) {
27
20
  for (const key of initial.keys) {
28
- (0, collections_1.setBoundedMapEntry)(this.keys, (0, utils_1.keyIdToHex)(key.keyId), key, this.maxSyncKeys);
21
+ (0, collections_1.setBoundedMapEntry)(this.keys, (0, bytes_1.bytesToHex)(key.keyId), key, this.maxSyncKeys);
29
22
  }
30
23
  for (const [collectionName, collection] of Object.entries(initial.collections)) {
31
24
  if (!collection) {
32
25
  continue;
33
26
  }
27
+ const indexValueMap = new Map();
28
+ for (const [key, value] of Object.entries(collection.indexValueMap)) {
29
+ (0, collections_1.setBoundedMapEntry)(indexValueMap, key, value, this.maxCollectionEntries);
30
+ }
34
31
  this.collections.set(collectionName, {
32
+ initialized: true,
35
33
  version: collection.version,
36
34
  hash: collection.hash,
37
- indexValueMap: toBoundedMap(Object.entries(collection.indexValueMap), this.maxCollectionEntries)
35
+ indexValueMap
38
36
  });
39
37
  }
40
38
  }
@@ -57,7 +55,7 @@ class WaAppStateMemoryStore {
57
55
  async upsertSyncKeys(keys) {
58
56
  let inserted = 0;
59
57
  for (const key of keys) {
60
- const keyHex = (0, utils_1.keyIdToHex)(key.keyId);
58
+ const keyHex = (0, bytes_1.bytesToHex)(key.keyId);
61
59
  const existing = this.keys.get(keyHex);
62
60
  if (existing && (0, bytes_1.uint8Equal)(existing.keyData, key.keyData)) {
63
61
  continue;
@@ -67,11 +65,22 @@ class WaAppStateMemoryStore {
67
65
  }
68
66
  return inserted;
69
67
  }
70
- async getSyncKey(keyId) {
71
- return this.keys.get((0, utils_1.keyIdToHex)(keyId)) ?? null;
68
+ async getSyncKeysBatch(keyIds) {
69
+ const keys = new Array(keyIds.length);
70
+ for (let index = 0; index < keyIds.length; index += 1) {
71
+ keys[index] = this.keys.get((0, bytes_1.bytesToHex)(keyIds[index])) ?? null;
72
+ }
73
+ return keys;
72
74
  }
73
75
  async getSyncKeyData(keyId) {
74
- return this.keys.get((0, utils_1.keyIdToHex)(keyId))?.keyData ?? null;
76
+ return this.keys.get((0, bytes_1.bytesToHex)(keyId))?.keyData ?? null;
77
+ }
78
+ async getSyncKeyDataBatch(keyIds) {
79
+ const keys = new Array(keyIds.length);
80
+ for (let index = 0; index < keyIds.length; index += 1) {
81
+ keys[index] = this.keys.get((0, bytes_1.bytesToHex)(keyIds[index]))?.keyData ?? null;
82
+ }
83
+ return keys;
75
84
  }
76
85
  async getActiveSyncKey() {
77
86
  return (0, utils_1.pickActiveSyncKey)(this.keys.values());
@@ -80,6 +89,7 @@ class WaAppStateMemoryStore {
80
89
  let state = this.collections.get(collection);
81
90
  if (!state) {
82
91
  state = {
92
+ initialized: false,
83
93
  version: 0,
84
94
  hash: constants_1.APP_STATE_EMPTY_LT_HASH,
85
95
  indexValueMap: new Map()
@@ -88,12 +98,24 @@ class WaAppStateMemoryStore {
88
98
  }
89
99
  return state;
90
100
  }
101
+ async getCollectionStates(collections) {
102
+ const result = new Array(collections.length);
103
+ for (let index = 0; index < collections.length; index += 1) {
104
+ result[index] = await this.getCollectionState(collections[index]);
105
+ }
106
+ return result;
107
+ }
91
108
  async setCollectionStates(updates) {
92
109
  for (const update of updates) {
110
+ const indexValueMap = new Map();
111
+ for (const [key, value] of update.indexValueMap.entries()) {
112
+ (0, collections_1.setBoundedMapEntry)(indexValueMap, key, value, this.maxCollectionEntries);
113
+ }
93
114
  this.collections.set(update.collection, {
115
+ initialized: true,
94
116
  version: update.version,
95
117
  hash: update.hash,
96
- indexValueMap: toBoundedMap(update.indexValueMap.entries(), this.maxCollectionEntries)
118
+ indexValueMap
97
119
  });
98
120
  }
99
121
  }
@@ -14,6 +14,11 @@ class WaContactMemoryStore {
14
14
  async upsert(record) {
15
15
  (0, collections_1.setBoundedMapEntry)(this.contacts, record.jid, record, this.maxContacts);
16
16
  }
17
+ async upsertBatch(records) {
18
+ for (const record of records) {
19
+ (0, collections_1.setBoundedMapEntry)(this.contacts, record.jid, record, this.maxContacts);
20
+ }
21
+ }
17
22
  async getByJid(jid) {
18
23
  return this.contacts.get(jid) ?? null;
19
24
  }
@@ -17,54 +17,32 @@ class WaDeviceListMemoryStore {
17
17
  }, (0, collections_1.resolveCleanupIntervalMs)(ttlMs));
18
18
  this.cleanupTimer.unref();
19
19
  }
20
- getTtlMs() {
21
- return this.ttlMs;
22
- }
23
- async upsertUserDevices(snapshot) {
24
- (0, collections_1.setBoundedMapEntry)(this.records, snapshot.userJid, {
25
- ...snapshot,
26
- expiresAtMs: snapshot.updatedAtMs + this.ttlMs
27
- }, this.maxUsers);
28
- }
29
20
  async upsertUserDevicesBatch(snapshots) {
30
- for (const snapshot of snapshots) {
21
+ for (let index = 0; index < snapshots.length; index += 1) {
22
+ const snapshot = snapshots[index];
31
23
  (0, collections_1.setBoundedMapEntry)(this.records, snapshot.userJid, {
32
24
  ...snapshot,
33
25
  expiresAtMs: snapshot.updatedAtMs + this.ttlMs
34
26
  }, this.maxUsers);
35
27
  }
36
28
  }
37
- async getUserDevices(userJid, nowMs = Date.now()) {
38
- const record = this.records.get(userJid);
39
- if (!record) {
40
- return null;
41
- }
42
- if (record.expiresAtMs <= nowMs) {
43
- this.records.delete(userJid);
44
- return null;
45
- }
46
- return {
47
- userJid: record.userJid,
48
- deviceJids: record.deviceJids,
49
- updatedAtMs: record.updatedAtMs
50
- };
51
- }
52
29
  async getUserDevicesBatch(userJids, nowMs = Date.now()) {
53
- return userJids.map((userJid) => {
30
+ const snapshots = new Array(userJids.length);
31
+ for (let index = 0; index < userJids.length; index += 1) {
32
+ const userJid = userJids[index];
54
33
  const record = this.records.get(userJid);
55
34
  if (!record) {
56
- return null;
35
+ snapshots[index] = null;
36
+ continue;
57
37
  }
58
38
  if (record.expiresAtMs <= nowMs) {
59
39
  this.records.delete(userJid);
60
- return null;
40
+ snapshots[index] = null;
41
+ continue;
61
42
  }
62
- return {
63
- userJid: record.userJid,
64
- deviceJids: record.deviceJids,
65
- updatedAtMs: record.updatedAtMs
66
- };
67
- });
43
+ snapshots[index] = record;
44
+ }
45
+ return snapshots;
68
46
  }
69
47
  async deleteUserDevices(userJid) {
70
48
  return this.records.delete(userJid) ? 1 : 0;
@@ -3,7 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.WaMessageMemoryStore = void 0;
4
4
  const coercion_1 = require("../../../util/coercion");
5
5
  const collections_1 = require("../../../util/collections");
6
- const collections_2 = require("../../../util/collections");
7
6
  const DEFAULT_MESSAGE_MEMORY_STORE_LIMITS = Object.freeze({
8
7
  messages: 50000
9
8
  });
@@ -13,7 +12,12 @@ class WaMessageMemoryStore {
13
12
  this.maxMessages = (0, coercion_1.resolvePositive)(options.maxMessages, DEFAULT_MESSAGE_MEMORY_STORE_LIMITS.messages, 'WaMessageMemoryStoreOptions.maxMessages');
14
13
  }
15
14
  async upsert(record) {
16
- (0, collections_2.setBoundedMapEntry)(this.messages, record.id, record, this.maxMessages);
15
+ (0, collections_1.setBoundedMapEntry)(this.messages, record.id, record, this.maxMessages);
16
+ }
17
+ async upsertBatch(records) {
18
+ for (const record of records) {
19
+ (0, collections_1.setBoundedMapEntry)(this.messages, record.id, record, this.maxMessages);
20
+ }
17
21
  }
18
22
  async getById(id) {
19
23
  return this.messages.get(id) ?? null;
@@ -22,9 +26,8 @@ class WaMessageMemoryStore {
22
26
  const normalizedLimit = (0, collections_1.normalizeQueryLimit)(limit, 50);
23
27
  const records = [];
24
28
  for (const record of this.messages.values()) {
25
- if (record.threadJid !== threadJid) {
29
+ if (record.threadJid !== threadJid)
26
30
  continue;
27
- }
28
31
  if (beforeTimestampMs !== undefined &&
29
32
  (record.timestampMs === undefined || record.timestampMs >= beforeTimestampMs)) {
30
33
  continue;
@@ -32,7 +35,10 @@ class WaMessageMemoryStore {
32
35
  records.push(record);
33
36
  }
34
37
  records.sort((left, right) => (right.timestampMs ?? 0) - (left.timestampMs ?? 0));
35
- return records.length <= normalizedLimit ? records : records.slice(0, normalizedLimit);
38
+ if (records.length > normalizedLimit) {
39
+ records.length = normalizedLimit;
40
+ }
41
+ return records;
36
42
  }
37
43
  async deleteById(id) {
38
44
  return this.messages.delete(id) ? 1 : 0;
@@ -17,9 +17,6 @@ class WaParticipantsMemoryStore {
17
17
  }, (0, collections_1.resolveCleanupIntervalMs)(ttlMs));
18
18
  this.cleanupTimer.unref();
19
19
  }
20
- getTtlMs() {
21
- return this.ttlMs;
22
- }
23
20
  async upsertGroupParticipants(snapshot) {
24
21
  (0, collections_1.setBoundedMapEntry)(this.records, snapshot.groupJid, {
25
22
  ...snapshot,
@@ -35,11 +32,7 @@ class WaParticipantsMemoryStore {
35
32
  this.records.delete(groupJid);
36
33
  return null;
37
34
  }
38
- return {
39
- groupJid: record.groupJid,
40
- participants: record.participants,
41
- updatedAtMs: record.updatedAtMs
42
- };
35
+ return record;
43
36
  }
44
37
  async deleteGroupParticipants(groupJid) {
45
38
  return this.records.delete(groupJid) ? 1 : 0;
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WaPrivacyTokenMemoryStore = void 0;
4
+ const collections_1 = require("../../../util/collections");
5
+ const DEFAULT_MAX_ENTRIES = 10000;
6
+ class WaPrivacyTokenMemoryStore {
7
+ constructor(maxEntries = DEFAULT_MAX_ENTRIES) {
8
+ this.records = new Map();
9
+ this.maxEntries = maxEntries;
10
+ }
11
+ async upsert(record) {
12
+ const existing = this.records.get(record.jid);
13
+ const merged = existing ? this.mergeRecord(existing, record) : record;
14
+ (0, collections_1.setBoundedMapEntry)(this.records, record.jid, merged, this.maxEntries);
15
+ }
16
+ async upsertBatch(records) {
17
+ for (let i = 0; i < records.length; i += 1) {
18
+ const record = records[i];
19
+ const existing = this.records.get(record.jid);
20
+ const merged = existing ? this.mergeRecord(existing, record) : record;
21
+ (0, collections_1.setBoundedMapEntry)(this.records, record.jid, merged, this.maxEntries);
22
+ }
23
+ }
24
+ async getByJid(jid) {
25
+ return this.records.get(jid) ?? null;
26
+ }
27
+ async deleteByJid(jid) {
28
+ return this.records.delete(jid) ? 1 : 0;
29
+ }
30
+ async clear() {
31
+ this.records.clear();
32
+ }
33
+ async destroy() {
34
+ this.records.clear();
35
+ }
36
+ mergeRecord(existing, incoming) {
37
+ return {
38
+ jid: incoming.jid,
39
+ tcToken: incoming.tcToken ?? existing.tcToken,
40
+ tcTokenTimestamp: incoming.tcTokenTimestamp ?? existing.tcTokenTimestamp,
41
+ tcTokenSenderTimestamp: incoming.tcTokenSenderTimestamp ?? existing.tcTokenSenderTimestamp,
42
+ nctSalt: incoming.nctSalt ?? existing.nctSalt,
43
+ updatedAtMs: incoming.updatedAtMs
44
+ };
45
+ }
46
+ }
47
+ exports.WaPrivacyTokenMemoryStore = WaPrivacyTokenMemoryStore;
@@ -2,10 +2,11 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.WaRetryMemoryStore = void 0;
4
4
  const collections_1 = require("../../../util/collections");
5
- const DEFAULT_RETRY_TTL_MS = 7 * 24 * 60 * 60 * 1000;
5
+ const DEFAULT_RETRY_TTL_MS = 60 * 1000;
6
6
  class WaRetryMemoryStore {
7
7
  constructor(ttlMs = DEFAULT_RETRY_TTL_MS) {
8
8
  this.outboundMessages = new Map();
9
+ this.eligibleSets = new Map();
9
10
  this.inboundCounters = new Map();
10
11
  this.ttlMs = ttlMs;
11
12
  this.cleanupTimer = setInterval(() => {
@@ -16,8 +17,66 @@ class WaRetryMemoryStore {
16
17
  getTtlMs() {
17
18
  return this.ttlMs;
18
19
  }
20
+ supportsRawReplayPayload() {
21
+ return true;
22
+ }
23
+ async getOutboundRequesterStatus(messageId, requesterDeviceJid) {
24
+ const current = this.outboundMessages.get(messageId);
25
+ if (!current) {
26
+ return null;
27
+ }
28
+ const eligible = current.eligibleRequesterDeviceJids;
29
+ if (!eligible || eligible.length === 0) {
30
+ return null;
31
+ }
32
+ const eligibleSet = this.eligibleSets.get(current.messageId);
33
+ let isEligible = false;
34
+ if (eligibleSet) {
35
+ isEligible = eligibleSet.has(requesterDeviceJid);
36
+ }
37
+ else {
38
+ for (let index = 0; index < eligible.length; index += 1) {
39
+ if (eligible[index] === requesterDeviceJid) {
40
+ isEligible = true;
41
+ break;
42
+ }
43
+ }
44
+ }
45
+ if (!isEligible) {
46
+ return { eligible: false, delivered: false };
47
+ }
48
+ const delivered = current.deliveredRequesterDeviceJids;
49
+ if (!delivered || delivered.length === 0) {
50
+ return { eligible: true, delivered: false };
51
+ }
52
+ for (let index = 0; index < delivered.length; index += 1) {
53
+ if (delivered[index] === requesterDeviceJid) {
54
+ return { eligible: true, delivered: true };
55
+ }
56
+ }
57
+ return { eligible: true, delivered: false };
58
+ }
19
59
  async upsertOutboundMessage(record) {
20
- this.outboundMessages.set(record.messageId, record);
60
+ this.outboundMessages.set(record.messageId, {
61
+ ...record,
62
+ eligibleRequesterDeviceJids: record.eligibleRequesterDeviceJids
63
+ ? [...record.eligibleRequesterDeviceJids]
64
+ : undefined,
65
+ deliveredRequesterDeviceJids: record.deliveredRequesterDeviceJids
66
+ ? [...record.deliveredRequesterDeviceJids]
67
+ : undefined
68
+ });
69
+ if (record.eligibleRequesterDeviceJids && record.eligibleRequesterDeviceJids.length > 0) {
70
+ this.eligibleSets.set(record.messageId, new Set(record.eligibleRequesterDeviceJids));
71
+ }
72
+ else {
73
+ this.eligibleSets.delete(record.messageId);
74
+ }
75
+ }
76
+ async deleteOutboundMessage(messageId) {
77
+ const existed = this.outboundMessages.delete(messageId);
78
+ this.eligibleSets.delete(messageId);
79
+ return existed ? 1 : 0;
21
80
  }
22
81
  async getOutboundMessage(messageId) {
23
82
  return this.outboundMessages.get(messageId) ?? null;
@@ -34,6 +93,20 @@ class WaRetryMemoryStore {
34
93
  expiresAtMs
35
94
  });
36
95
  }
96
+ async markOutboundRequesterDelivered(messageId, requesterDeviceJid, updatedAtMs, expiresAtMs) {
97
+ const current = this.outboundMessages.get(messageId);
98
+ if (!current) {
99
+ return;
100
+ }
101
+ const delivered = new Set(current.deliveredRequesterDeviceJids ?? []);
102
+ delivered.add(requesterDeviceJid);
103
+ this.outboundMessages.set(messageId, {
104
+ ...current,
105
+ deliveredRequesterDeviceJids: Array.from(delivered),
106
+ updatedAtMs,
107
+ expiresAtMs
108
+ });
109
+ }
37
110
  async incrementInboundCounter(messageId, requesterJid, _updatedAtMs, expiresAtMs) {
38
111
  const key = this.counterKey(messageId, requesterJid);
39
112
  const current = this.inboundCounters.get(key);
@@ -50,6 +123,7 @@ class WaRetryMemoryStore {
50
123
  if (record.expiresAtMs > nowMs)
51
124
  continue;
52
125
  this.outboundMessages.delete(messageId);
126
+ this.eligibleSets.delete(messageId);
53
127
  removed += 1;
54
128
  }
55
129
  for (const [key, record] of this.inboundCounters) {
@@ -62,6 +136,7 @@ class WaRetryMemoryStore {
62
136
  }
63
137
  async clear() {
64
138
  this.outboundMessages.clear();
139
+ this.eligibleSets.clear();
65
140
  this.inboundCounters.clear();
66
141
  }
67
142
  async destroy() {