@neelegirl/baileys 1.5.6 → 1.5.8

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 (421) hide show
  1. package/README.md +24 -27
  2. package/WAProto/WAProto.proto +665 -291
  3. package/WAProto/index.d.ts +48037 -2294
  4. package/WAProto/index.js +139804 -45203
  5. package/lib/Defaults/baileys-version.json +3 -0
  6. package/lib/Defaults/index.d.ts +64 -58
  7. package/lib/Defaults/index.js +96 -74
  8. package/lib/Defaults/phonenumber-mcc.json +223 -0
  9. package/lib/Signal/WASignalGroup/GroupProtocol.js +1909 -0
  10. package/lib/Signal/WASignalGroup/ciphertext_message.js +16 -0
  11. package/lib/Signal/WASignalGroup/generate-proto.sh +1 -0
  12. package/lib/Signal/WASignalGroup/group.proto +42 -0
  13. package/lib/Signal/WASignalGroup/group_cipher.js +120 -0
  14. package/lib/Signal/WASignalGroup/group_session_builder.js +46 -0
  15. package/lib/Signal/WASignalGroup/index.js +6 -0
  16. package/lib/Signal/WASignalGroup/keyhelper.js +21 -0
  17. package/lib/Signal/WASignalGroup/protobufs.js +3 -0
  18. package/lib/Signal/WASignalGroup/queue_job.js +69 -0
  19. package/lib/Signal/WASignalGroup/readme.md +6 -0
  20. package/lib/Signal/WASignalGroup/sender_chain_key.js +50 -0
  21. package/lib/Signal/WASignalGroup/sender_key_distribution_message.js +78 -0
  22. package/lib/Signal/WASignalGroup/sender_key_message.js +92 -0
  23. package/lib/Signal/WASignalGroup/sender_key_name.js +70 -0
  24. package/lib/Signal/WASignalGroup/sender_key_record.js +56 -0
  25. package/lib/Signal/WASignalGroup/sender_key_state.js +129 -0
  26. package/lib/Signal/{Group/sender-message-key.js → WASignalGroup/sender_message_key.js} +16 -3
  27. package/lib/Signal/libsignal.d.ts +4 -5
  28. package/lib/Signal/libsignal.js +112 -292
  29. package/lib/Socket/Client/abstract-socket-client.d.ts +15 -0
  30. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  31. package/lib/Socket/Client/index.d.ts +2 -3
  32. package/lib/Socket/Client/index.js +22 -3
  33. package/lib/Socket/Client/mobile-socket-client.d.ts +12 -0
  34. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  35. package/lib/Socket/Client/types.d.ts +15 -15
  36. package/lib/Socket/Client/types.js +15 -8
  37. package/lib/Socket/Client/websocket.d.ts +12 -12
  38. package/lib/Socket/Client/websocket.js +36 -24
  39. package/lib/Socket/business.d.ts +177 -178
  40. package/lib/Socket/business.js +71 -179
  41. package/lib/Socket/chats.d.ts +93 -93
  42. package/lib/Socket/chats.js +625 -474
  43. package/lib/Socket/communities.d.ts +62 -83
  44. package/lib/Socket/communities.js +414 -412
  45. package/lib/Socket/groups.d.ts +112 -118
  46. package/lib/Socket/groups.js +171 -146
  47. package/lib/Socket/index.d.ts +182 -222
  48. package/lib/Socket/index.js +17 -12
  49. package/lib/Socket/messages-recv.d.ts +169 -165
  50. package/lib/Socket/messages-recv.js +1721 -1185
  51. package/lib/Socket/messages-send.d.ts +160 -161
  52. package/lib/Socket/messages-send.js +992 -642
  53. package/lib/Socket/mex.d.ts +0 -1
  54. package/lib/Socket/mex.js +9 -4
  55. package/lib/Socket/newsletter.d.ts +139 -139
  56. package/lib/Socket/newsletter.js +258 -153
  57. package/lib/Socket/registration.d.ts +266 -0
  58. package/lib/Socket/registration.js +166 -0
  59. package/lib/Socket/socket.d.ts +36 -42
  60. package/lib/Socket/socket.js +615 -533
  61. package/lib/Socket/usync.d.ts +37 -0
  62. package/lib/Socket/usync.js +83 -0
  63. package/lib/Store/index.d.ts +4 -0
  64. package/lib/Store/index.js +24 -0
  65. package/lib/Store/make-cache-manager-store.d.ts +14 -0
  66. package/lib/Store/make-cache-manager-store.js +90 -0
  67. package/lib/Store/make-in-memory-store.d.ts +123 -0
  68. package/lib/Store/make-in-memory-store.js +429 -0
  69. package/lib/Store/make-ordered-dictionary.d.ts +12 -0
  70. package/lib/Store/make-ordered-dictionary.js +86 -0
  71. package/lib/Store/object-repository.d.ts +10 -0
  72. package/lib/Store/object-repository.js +31 -0
  73. package/lib/Types/Auth.d.ts +96 -87
  74. package/lib/Types/Auth.js +3 -2
  75. package/lib/Types/Call.d.ts +13 -13
  76. package/lib/Types/Call.js +3 -2
  77. package/lib/Types/Chat.d.ts +94 -79
  78. package/lib/Types/Chat.js +9 -8
  79. package/lib/Types/Contact.d.ts +9 -13
  80. package/lib/Types/Contact.js +3 -2
  81. package/lib/Types/Events.d.ts +179 -152
  82. package/lib/Types/Events.js +3 -2
  83. package/lib/Types/GroupMetadata.d.ts +48 -49
  84. package/lib/Types/GroupMetadata.js +3 -2
  85. package/lib/Types/Label.d.ts +14 -13
  86. package/lib/Types/Label.js +30 -24
  87. package/lib/Types/LabelAssociation.d.ts +20 -15
  88. package/lib/Types/LabelAssociation.js +12 -6
  89. package/lib/Types/Message.d.ts +404 -234
  90. package/lib/Types/Message.js +13 -11
  91. package/lib/Types/MexUpdates.d.ts +9 -0
  92. package/lib/Types/MexUpdates.js +18 -0
  93. package/lib/Types/Newsletter.d.ts +104 -130
  94. package/lib/Types/Newsletter.js +40 -31
  95. package/lib/Types/Product.d.ts +71 -58
  96. package/lib/Types/Product.js +3 -2
  97. package/lib/Types/Signal.d.ts +55 -63
  98. package/lib/Types/Signal.js +3 -2
  99. package/lib/Types/Socket.d.ts +66 -77
  100. package/lib/Types/Socket.js +3 -3
  101. package/lib/Types/State.d.ts +19 -17
  102. package/lib/Types/State.js +14 -13
  103. package/lib/Types/USync.d.ts +8 -8
  104. package/lib/Types/USync.js +3 -2
  105. package/lib/Types/index.d.ts +61 -47
  106. package/lib/Types/index.js +48 -26
  107. package/lib/Utils/auth-utils.d.ts +10 -8
  108. package/lib/Utils/auth-utils.js +154 -206
  109. package/lib/Utils/baileys-event-stream.d.ts +7 -6
  110. package/lib/Utils/baileys-event-stream.js +43 -29
  111. package/lib/Utils/business.d.ts +20 -14
  112. package/lib/Utils/business.js +134 -110
  113. package/lib/Utils/chat-utils.d.ts +69 -57
  114. package/lib/Utils/chat-utils.js +380 -362
  115. package/lib/Utils/check-npm-version.d.ts +15 -0
  116. package/lib/Utils/check-npm-version.js +52 -0
  117. package/lib/Utils/crypto.d.ts +45 -30
  118. package/lib/Utils/crypto.js +178 -141
  119. package/lib/Utils/decode-wa-message.d.ts +35 -42
  120. package/lib/Utils/decode-wa-message.js +150 -176
  121. package/lib/Utils/event-buffer.d.ts +17 -12
  122. package/lib/Utils/event-buffer.js +286 -269
  123. package/lib/Utils/generics.d.ts +99 -60
  124. package/lib/Utils/generics.js +481 -244
  125. package/lib/Utils/history.d.ts +22 -18
  126. package/lib/Utils/history.js +80 -54
  127. package/lib/Utils/index.d.ts +19 -20
  128. package/lib/Utils/index.js +41 -19
  129. package/lib/Utils/link-preview.d.ts +14 -12
  130. package/lib/Utils/link-preview.js +75 -40
  131. package/lib/Utils/logger.d.ts +11 -10
  132. package/lib/Utils/logger.js +7 -3
  133. package/lib/Utils/lt-hash.d.ts +13 -12
  134. package/lib/Utils/lt-hash.js +37 -27
  135. package/lib/Utils/make-mutex.d.ts +7 -6
  136. package/lib/Utils/make-mutex.js +29 -20
  137. package/lib/Utils/message-retry-manager.d.ts +6 -6
  138. package/lib/Utils/message-retry-manager.js +36 -8
  139. package/lib/Utils/messages-media.d.ts +102 -87
  140. package/lib/Utils/messages-media.js +570 -427
  141. package/lib/Utils/messages.d.ts +64 -37
  142. package/lib/Utils/messages.js +1270 -511
  143. package/lib/Utils/noise-handler.d.ts +18 -18
  144. package/lib/Utils/noise-handler.js +109 -101
  145. package/lib/Utils/process-message.d.ts +32 -25
  146. package/lib/Utils/process-message.js +281 -266
  147. package/lib/Utils/signal.d.ts +32 -24
  148. package/lib/Utils/signal.js +105 -98
  149. package/lib/Utils/use-mongo-file-auth-state.d.ts +6 -0
  150. package/lib/Utils/use-mongo-file-auth-state.js +84 -0
  151. package/lib/Utils/use-multi-file-auth-state.d.ts +10 -5
  152. package/lib/Utils/use-multi-file-auth-state.js +186 -69
  153. package/lib/Utils/use-single-file-auth-state.d.ts +13 -0
  154. package/lib/Utils/use-single-file-auth-state.js +80 -0
  155. package/lib/Utils/validate-connection.d.ts +13 -11
  156. package/lib/Utils/validate-connection.js +116 -124
  157. package/lib/WABinary/constants.d.ts +27 -25
  158. package/lib/WABinary/constants.js +1292 -1277
  159. package/lib/WABinary/decode.d.ts +9 -7
  160. package/lib/WABinary/decode.js +189 -139
  161. package/lib/WABinary/encode.d.ts +3 -3
  162. package/lib/WABinary/encode.js +154 -105
  163. package/lib/WABinary/generic-utils.d.ts +27 -14
  164. package/lib/WABinary/generic-utils.js +102 -62
  165. package/lib/WABinary/index.d.ts +5 -6
  166. package/lib/WABinary/index.js +25 -6
  167. package/lib/WABinary/jid-utils.d.ts +46 -41
  168. package/lib/WABinary/jid-utils.js +80 -84
  169. package/lib/WABinary/types.d.ts +13 -10
  170. package/lib/WABinary/types.js +3 -2
  171. package/lib/WAM/BinaryInfo.d.ts +15 -8
  172. package/lib/WAM/BinaryInfo.js +14 -7
  173. package/lib/WAM/constants.d.ts +37 -30
  174. package/lib/WAM/constants.js +11983 -19465
  175. package/lib/WAM/encode.d.ts +3 -3
  176. package/lib/WAM/encode.js +110 -95
  177. package/lib/WAM/index.d.ts +3 -4
  178. package/lib/WAM/index.js +23 -4
  179. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.d.ts +28 -0
  180. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.js +69 -0
  181. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -9
  182. package/lib/WAUSync/Protocols/USyncContactProtocol.js +19 -12
  183. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -19
  184. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +26 -18
  185. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -11
  186. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +20 -12
  187. package/lib/WAUSync/Protocols/USyncLIDProtocol.d.ts +9 -0
  188. package/lib/WAUSync/Protocols/USyncLIDProtocol.js +30 -0
  189. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -11
  190. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +24 -16
  191. package/lib/WAUSync/Protocols/index.d.ts +6 -5
  192. package/lib/WAUSync/Protocols/index.js +26 -5
  193. package/lib/WAUSync/USyncQuery.d.ts +28 -26
  194. package/lib/WAUSync/USyncQuery.js +62 -64
  195. package/lib/WAUSync/USyncUser.d.ts +10 -11
  196. package/lib/WAUSync/USyncUser.js +19 -12
  197. package/lib/WAUSync/index.d.ts +3 -4
  198. package/lib/WAUSync/index.js +23 -4
  199. package/lib/index.d.ts +11 -10
  200. package/lib/index.js +33 -11
  201. package/package.json +43 -48
  202. package/WAProto/GenerateStatics.sh +0 -3
  203. package/WAProto/fix-imports.js +0 -29
  204. package/engine-requirements.js +0 -10
  205. package/lib/Defaults/index.d.ts.map +0 -1
  206. package/lib/Defaults/index.js.map +0 -1
  207. package/lib/Signal/Group/ciphertext-message.d.ts +0 -10
  208. package/lib/Signal/Group/ciphertext-message.d.ts.map +0 -1
  209. package/lib/Signal/Group/ciphertext-message.js +0 -12
  210. package/lib/Signal/Group/ciphertext-message.js.map +0 -1
  211. package/lib/Signal/Group/group-session-builder.d.ts +0 -15
  212. package/lib/Signal/Group/group-session-builder.d.ts.map +0 -1
  213. package/lib/Signal/Group/group-session-builder.js +0 -30
  214. package/lib/Signal/Group/group-session-builder.js.map +0 -1
  215. package/lib/Signal/Group/group_cipher.d.ts +0 -17
  216. package/lib/Signal/Group/group_cipher.d.ts.map +0 -1
  217. package/lib/Signal/Group/group_cipher.js +0 -82
  218. package/lib/Signal/Group/group_cipher.js.map +0 -1
  219. package/lib/Signal/Group/index.d.ts +0 -12
  220. package/lib/Signal/Group/index.d.ts.map +0 -1
  221. package/lib/Signal/Group/index.js +0 -12
  222. package/lib/Signal/Group/index.js.map +0 -1
  223. package/lib/Signal/Group/keyhelper.d.ts +0 -11
  224. package/lib/Signal/Group/keyhelper.d.ts.map +0 -1
  225. package/lib/Signal/Group/keyhelper.js +0 -18
  226. package/lib/Signal/Group/keyhelper.js.map +0 -1
  227. package/lib/Signal/Group/sender-chain-key.d.ts +0 -14
  228. package/lib/Signal/Group/sender-chain-key.d.ts.map +0 -1
  229. package/lib/Signal/Group/sender-chain-key.js +0 -26
  230. package/lib/Signal/Group/sender-chain-key.js.map +0 -1
  231. package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -17
  232. package/lib/Signal/Group/sender-key-distribution-message.d.ts.map +0 -1
  233. package/lib/Signal/Group/sender-key-distribution-message.js +0 -63
  234. package/lib/Signal/Group/sender-key-distribution-message.js.map +0 -1
  235. package/lib/Signal/Group/sender-key-message.d.ts +0 -19
  236. package/lib/Signal/Group/sender-key-message.d.ts.map +0 -1
  237. package/lib/Signal/Group/sender-key-message.js +0 -66
  238. package/lib/Signal/Group/sender-key-message.js.map +0 -1
  239. package/lib/Signal/Group/sender-key-name.d.ts +0 -18
  240. package/lib/Signal/Group/sender-key-name.d.ts.map +0 -1
  241. package/lib/Signal/Group/sender-key-name.js +0 -48
  242. package/lib/Signal/Group/sender-key-name.js.map +0 -1
  243. package/lib/Signal/Group/sender-key-record.d.ts +0 -31
  244. package/lib/Signal/Group/sender-key-record.d.ts.map +0 -1
  245. package/lib/Signal/Group/sender-key-record.js +0 -41
  246. package/lib/Signal/Group/sender-key-record.js.map +0 -1
  247. package/lib/Signal/Group/sender-key-state.d.ts +0 -39
  248. package/lib/Signal/Group/sender-key-state.d.ts.map +0 -1
  249. package/lib/Signal/Group/sender-key-state.js +0 -84
  250. package/lib/Signal/Group/sender-key-state.js.map +0 -1
  251. package/lib/Signal/Group/sender-message-key.d.ts +0 -12
  252. package/lib/Signal/Group/sender-message-key.d.ts.map +0 -1
  253. package/lib/Signal/Group/sender-message-key.js.map +0 -1
  254. package/lib/Signal/libsignal.d.ts.map +0 -1
  255. package/lib/Signal/libsignal.js.map +0 -1
  256. package/lib/Signal/lid-mapping.d.ts +0 -23
  257. package/lib/Signal/lid-mapping.d.ts.map +0 -1
  258. package/lib/Signal/lid-mapping.js +0 -171
  259. package/lib/Signal/lid-mapping.js.map +0 -1
  260. package/lib/Socket/Client/index.d.ts.map +0 -1
  261. package/lib/Socket/Client/index.js.map +0 -1
  262. package/lib/Socket/Client/types.d.ts.map +0 -1
  263. package/lib/Socket/Client/types.js.map +0 -1
  264. package/lib/Socket/Client/websocket.d.ts.map +0 -1
  265. package/lib/Socket/Client/websocket.js.map +0 -1
  266. package/lib/Socket/business.d.ts.map +0 -1
  267. package/lib/Socket/business.js.map +0 -1
  268. package/lib/Socket/chats.d.ts.map +0 -1
  269. package/lib/Socket/chats.js.map +0 -1
  270. package/lib/Socket/communities.d.ts.map +0 -1
  271. package/lib/Socket/communities.js.map +0 -1
  272. package/lib/Socket/groups.d.ts.map +0 -1
  273. package/lib/Socket/groups.js.map +0 -1
  274. package/lib/Socket/index.d.ts.map +0 -1
  275. package/lib/Socket/index.js.map +0 -1
  276. package/lib/Socket/messages-recv.d.ts.map +0 -1
  277. package/lib/Socket/messages-recv.js.map +0 -1
  278. package/lib/Socket/messages-send.d.ts.map +0 -1
  279. package/lib/Socket/messages-send.js.map +0 -1
  280. package/lib/Socket/mex.d.ts.map +0 -1
  281. package/lib/Socket/mex.js.map +0 -1
  282. package/lib/Socket/newsletter.d.ts.map +0 -1
  283. package/lib/Socket/newsletter.js.map +0 -1
  284. package/lib/Socket/socket.d.ts.map +0 -1
  285. package/lib/Socket/socket.js.map +0 -1
  286. package/lib/Types/Auth.d.ts.map +0 -1
  287. package/lib/Types/Auth.js.map +0 -1
  288. package/lib/Types/Bussines.d.ts +0 -25
  289. package/lib/Types/Bussines.d.ts.map +0 -1
  290. package/lib/Types/Bussines.js +0 -2
  291. package/lib/Types/Bussines.js.map +0 -1
  292. package/lib/Types/Call.d.ts.map +0 -1
  293. package/lib/Types/Call.js.map +0 -1
  294. package/lib/Types/Chat.d.ts.map +0 -1
  295. package/lib/Types/Chat.js.map +0 -1
  296. package/lib/Types/Contact.d.ts.map +0 -1
  297. package/lib/Types/Contact.js.map +0 -1
  298. package/lib/Types/Events.d.ts.map +0 -1
  299. package/lib/Types/Events.js.map +0 -1
  300. package/lib/Types/GroupMetadata.d.ts.map +0 -1
  301. package/lib/Types/GroupMetadata.js.map +0 -1
  302. package/lib/Types/Label.d.ts.map +0 -1
  303. package/lib/Types/Label.js.map +0 -1
  304. package/lib/Types/LabelAssociation.d.ts.map +0 -1
  305. package/lib/Types/LabelAssociation.js.map +0 -1
  306. package/lib/Types/Message.d.ts.map +0 -1
  307. package/lib/Types/Message.js.map +0 -1
  308. package/lib/Types/Newsletter.d.ts.map +0 -1
  309. package/lib/Types/Newsletter.js.map +0 -1
  310. package/lib/Types/Product.d.ts.map +0 -1
  311. package/lib/Types/Product.js.map +0 -1
  312. package/lib/Types/Signal.d.ts.map +0 -1
  313. package/lib/Types/Signal.js.map +0 -1
  314. package/lib/Types/Socket.d.ts.map +0 -1
  315. package/lib/Types/Socket.js.map +0 -1
  316. package/lib/Types/State.d.ts.map +0 -1
  317. package/lib/Types/State.js.map +0 -1
  318. package/lib/Types/USync.d.ts.map +0 -1
  319. package/lib/Types/USync.js.map +0 -1
  320. package/lib/Types/index.d.ts.map +0 -1
  321. package/lib/Types/index.js.map +0 -1
  322. package/lib/Utils/auth-utils.d.ts.map +0 -1
  323. package/lib/Utils/auth-utils.js.map +0 -1
  324. package/lib/Utils/baileys-event-stream.d.ts.map +0 -1
  325. package/lib/Utils/baileys-event-stream.js.map +0 -1
  326. package/lib/Utils/browser-utils.d.ts +0 -4
  327. package/lib/Utils/browser-utils.d.ts.map +0 -1
  328. package/lib/Utils/browser-utils.js +0 -28
  329. package/lib/Utils/browser-utils.js.map +0 -1
  330. package/lib/Utils/business.d.ts.map +0 -1
  331. package/lib/Utils/business.js.map +0 -1
  332. package/lib/Utils/chat-utils.d.ts.map +0 -1
  333. package/lib/Utils/chat-utils.js.map +0 -1
  334. package/lib/Utils/crypto.d.ts.map +0 -1
  335. package/lib/Utils/crypto.js.map +0 -1
  336. package/lib/Utils/decode-wa-message.d.ts.map +0 -1
  337. package/lib/Utils/decode-wa-message.js.map +0 -1
  338. package/lib/Utils/event-buffer.d.ts.map +0 -1
  339. package/lib/Utils/event-buffer.js.map +0 -1
  340. package/lib/Utils/generics.d.ts.map +0 -1
  341. package/lib/Utils/generics.js.map +0 -1
  342. package/lib/Utils/history.d.ts.map +0 -1
  343. package/lib/Utils/history.js.map +0 -1
  344. package/lib/Utils/index.d.ts.map +0 -1
  345. package/lib/Utils/index.js.map +0 -1
  346. package/lib/Utils/link-preview.d.ts.map +0 -1
  347. package/lib/Utils/link-preview.js.map +0 -1
  348. package/lib/Utils/logger.d.ts.map +0 -1
  349. package/lib/Utils/logger.js.map +0 -1
  350. package/lib/Utils/lt-hash.d.ts.map +0 -1
  351. package/lib/Utils/lt-hash.js.map +0 -1
  352. package/lib/Utils/make-mutex.d.ts.map +0 -1
  353. package/lib/Utils/make-mutex.js.map +0 -1
  354. package/lib/Utils/message-retry-manager.d.ts.map +0 -1
  355. package/lib/Utils/message-retry-manager.js.map +0 -1
  356. package/lib/Utils/messages-media.d.ts.map +0 -1
  357. package/lib/Utils/messages-media.js.map +0 -1
  358. package/lib/Utils/messages.d.ts.map +0 -1
  359. package/lib/Utils/messages.js.map +0 -1
  360. package/lib/Utils/noise-handler.d.ts.map +0 -1
  361. package/lib/Utils/noise-handler.js.map +0 -1
  362. package/lib/Utils/pre-key-manager.d.ts +0 -28
  363. package/lib/Utils/pre-key-manager.d.ts.map +0 -1
  364. package/lib/Utils/pre-key-manager.js +0 -106
  365. package/lib/Utils/pre-key-manager.js.map +0 -1
  366. package/lib/Utils/process-message.d.ts.map +0 -1
  367. package/lib/Utils/process-message.js.map +0 -1
  368. package/lib/Utils/signal.d.ts.map +0 -1
  369. package/lib/Utils/signal.js.map +0 -1
  370. package/lib/Utils/use-multi-file-auth-state.d.ts.map +0 -1
  371. package/lib/Utils/use-multi-file-auth-state.js.map +0 -1
  372. package/lib/Utils/validate-connection.d.ts.map +0 -1
  373. package/lib/Utils/validate-connection.js.map +0 -1
  374. package/lib/WABinary/constants.d.ts.map +0 -1
  375. package/lib/WABinary/constants.js.map +0 -1
  376. package/lib/WABinary/decode.d.ts.map +0 -1
  377. package/lib/WABinary/decode.js.map +0 -1
  378. package/lib/WABinary/encode.d.ts.map +0 -1
  379. package/lib/WABinary/encode.js.map +0 -1
  380. package/lib/WABinary/generic-utils.d.ts.map +0 -1
  381. package/lib/WABinary/generic-utils.js.map +0 -1
  382. package/lib/WABinary/index.d.ts.map +0 -1
  383. package/lib/WABinary/index.js.map +0 -1
  384. package/lib/WABinary/jid-utils.d.ts.map +0 -1
  385. package/lib/WABinary/jid-utils.js.map +0 -1
  386. package/lib/WABinary/types.d.ts.map +0 -1
  387. package/lib/WABinary/types.js.map +0 -1
  388. package/lib/WAM/BinaryInfo.d.ts.map +0 -1
  389. package/lib/WAM/BinaryInfo.js.map +0 -1
  390. package/lib/WAM/constants.d.ts.map +0 -1
  391. package/lib/WAM/constants.js.map +0 -1
  392. package/lib/WAM/encode.d.ts.map +0 -1
  393. package/lib/WAM/encode.js.map +0 -1
  394. package/lib/WAM/index.d.ts.map +0 -1
  395. package/lib/WAM/index.js.map +0 -1
  396. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts.map +0 -1
  397. package/lib/WAUSync/Protocols/USyncContactProtocol.js.map +0 -1
  398. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts.map +0 -1
  399. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js.map +0 -1
  400. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts.map +0 -1
  401. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js.map +0 -1
  402. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts.map +0 -1
  403. package/lib/WAUSync/Protocols/USyncStatusProtocol.js.map +0 -1
  404. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -26
  405. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts.map +0 -1
  406. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +0 -51
  407. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js.map +0 -1
  408. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -10
  409. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts.map +0 -1
  410. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +0 -29
  411. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js.map +0 -1
  412. package/lib/WAUSync/Protocols/index.d.ts.map +0 -1
  413. package/lib/WAUSync/Protocols/index.js.map +0 -1
  414. package/lib/WAUSync/USyncQuery.d.ts.map +0 -1
  415. package/lib/WAUSync/USyncQuery.js.map +0 -1
  416. package/lib/WAUSync/USyncUser.d.ts.map +0 -1
  417. package/lib/WAUSync/USyncUser.js.map +0 -1
  418. package/lib/WAUSync/index.d.ts.map +0 -1
  419. package/lib/WAUSync/index.js.map +0 -1
  420. package/lib/index.d.ts.map +0 -1
  421. package/lib/index.js.map +0 -1
@@ -0,0 +1,16 @@
1
+ class CiphertextMessage {
2
+ UNSUPPORTED_VERSION = 1;
3
+
4
+ CURRENT_VERSION = 3;
5
+
6
+ WHISPER_TYPE = 2;
7
+
8
+ PREKEY_TYPE = 3;
9
+
10
+ SENDERKEY_TYPE = 4;
11
+
12
+ SENDERKEY_DISTRIBUTION_TYPE = 5;
13
+
14
+ ENCRYPTED_MESSAGE_OVERHEAD = 53;
15
+ }
16
+ module.exports = CiphertextMessage;
@@ -0,0 +1 @@
1
+ yarn pbjs -t static-module -w commonjs -o ./WASignalGroup/GroupProtocol.js ./WASignalGroup/group.proto
@@ -0,0 +1,42 @@
1
+ package groupproto;
2
+
3
+ message SenderKeyMessage {
4
+ optional uint32 id = 1;
5
+ optional uint32 iteration = 2;
6
+ optional bytes ciphertext = 3;
7
+ }
8
+
9
+ message SenderKeyDistributionMessage {
10
+ optional uint32 id = 1;
11
+ optional uint32 iteration = 2;
12
+ optional bytes chainKey = 3;
13
+ optional bytes signingKey = 4;
14
+ }
15
+
16
+ message SenderChainKey {
17
+ optional uint32 iteration = 1;
18
+ optional bytes seed = 2;
19
+ }
20
+
21
+ message SenderMessageKey {
22
+ optional uint32 iteration = 1;
23
+ optional bytes seed = 2;
24
+ }
25
+
26
+ message SenderSigningKey {
27
+ optional bytes public = 1;
28
+ optional bytes private = 2;
29
+ }
30
+
31
+ message SenderKeyStateStructure {
32
+
33
+
34
+ optional uint32 senderKeyId = 1;
35
+ optional SenderChainKey senderChainKey = 2;
36
+ optional SenderSigningKey senderSigningKey = 3;
37
+ repeated SenderMessageKey senderMessageKeys = 4;
38
+ }
39
+
40
+ message SenderKeyRecordStructure {
41
+ repeated SenderKeyStateStructure senderKeyStates = 1;
42
+ }
@@ -0,0 +1,120 @@
1
+ const queue_job = require('./queue_job');
2
+ const SenderKeyMessage = require('./sender_key_message');
3
+ const crypto = require('@neelegirl/libsignal/src/crypto');
4
+
5
+ class GroupCipher {
6
+ constructor(senderKeyStore, senderKeyName) {
7
+ this.senderKeyStore = senderKeyStore;
8
+ this.senderKeyName = senderKeyName;
9
+ }
10
+
11
+ queueJob(awaitable) {
12
+ return queue_job(this.senderKeyName.toString(), awaitable)
13
+ }
14
+
15
+ async encrypt(paddedPlaintext) {
16
+ return await this.queueJob(async () => {
17
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
18
+ if (!record) {
19
+ throw new Error("No SenderKeyRecord found for encryption")
20
+ }
21
+ const senderKeyState = record.getSenderKeyState();
22
+ if (!senderKeyState) {
23
+ throw new Error("No session to encrypt message");
24
+ }
25
+ const iteration = senderKeyState.getSenderChainKey().getIteration()
26
+ const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1)
27
+
28
+ const ciphertext = await this.getCipherText(
29
+ senderKey.getIv(),
30
+ senderKey.getCipherKey(),
31
+ paddedPlaintext
32
+ );
33
+
34
+ const senderKeyMessage = new SenderKeyMessage(
35
+ senderKeyState.getKeyId(),
36
+ senderKey.getIteration(),
37
+ ciphertext,
38
+ senderKeyState.getSigningKeyPrivate()
39
+ );
40
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
41
+ return senderKeyMessage.serialize()
42
+ })
43
+ }
44
+
45
+ async decrypt(senderKeyMessageBytes) {
46
+ return await this.queueJob(async () => {
47
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
48
+ if (!record) {
49
+ throw new Error("No SenderKeyRecord found for decryption")
50
+ }
51
+ const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
52
+ const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
53
+ if (!senderKeyState) {
54
+ throw new Error("No session found to decrypt message")
55
+ }
56
+
57
+ senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
58
+ const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
59
+ // senderKeyState.senderKeyStateStructure.senderSigningKey.private =
60
+
61
+ const plaintext = await this.getPlainText(
62
+ senderKey.getIv(),
63
+ senderKey.getCipherKey(),
64
+ senderKeyMessage.getCipherText()
65
+ );
66
+
67
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
68
+
69
+ return plaintext;
70
+ })
71
+ }
72
+
73
+ getSenderKey(senderKeyState, iteration) {
74
+ let senderChainKey = senderKeyState.getSenderChainKey();
75
+ if (senderChainKey.getIteration() > iteration) {
76
+ if (senderKeyState.hasSenderMessageKey(iteration)) {
77
+ return senderKeyState.removeSenderMessageKey(iteration);
78
+ }
79
+ throw new Error(
80
+ `Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`
81
+ );
82
+ }
83
+
84
+ if (iteration - senderChainKey.getIteration() > 2000) {
85
+ throw new Error('Over 2000 messages into the future!');
86
+ }
87
+
88
+ while (senderChainKey.getIteration() < iteration) {
89
+ senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
90
+ senderChainKey = senderChainKey.getNext();
91
+ }
92
+
93
+ senderKeyState.setSenderChainKey(senderChainKey.getNext());
94
+ return senderChainKey.getSenderMessageKey();
95
+ }
96
+
97
+ getPlainText(iv, key, ciphertext) {
98
+ try {
99
+ const plaintext = crypto.decrypt(key, ciphertext, iv);
100
+ return plaintext;
101
+ } catch (e) {
102
+ //console.log(e.stack);
103
+ throw new Error('InvalidMessageException');
104
+ }
105
+ }
106
+
107
+ getCipherText(iv, key, plaintext) {
108
+ try {
109
+ iv = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv;
110
+ key = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
111
+ const crypted = crypto.encrypt(key, Buffer.from(plaintext), iv);
112
+ return crypted;
113
+ } catch (e) {
114
+ //console.log(e.stack);
115
+ throw new Error('InvalidMessageException');
116
+ }
117
+ }
118
+ }
119
+
120
+ module.exports = GroupCipher;
@@ -0,0 +1,46 @@
1
+ //const utils = require('../../common/utils');
2
+ const SenderKeyDistributionMessage = require('./sender_key_distribution_message');
3
+
4
+ const keyhelper = require("./keyhelper");
5
+ class GroupSessionBuilder {
6
+ constructor(senderKeyStore) {
7
+ this.senderKeyStore = senderKeyStore;
8
+ }
9
+
10
+ async process(senderKeyName, senderKeyDistributionMessage) {
11
+ //console.log('GroupSessionBuilder process', senderKeyName, senderKeyDistributionMessage);
12
+ const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
13
+ senderKeyRecord.addSenderKeyState(
14
+ senderKeyDistributionMessage.getId(),
15
+ senderKeyDistributionMessage.getIteration(),
16
+ senderKeyDistributionMessage.getChainKey(),
17
+ senderKeyDistributionMessage.getSignatureKey()
18
+ );
19
+ await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
20
+ }
21
+
22
+ // [{"senderKeyId":1742199468,"senderChainKey":{"iteration":0,"seed":"yxMY9VFQcXEP34olRAcGCtsgx1XoKsHfDIh+1ea4HAQ="},"senderSigningKey":{"public":""}}]
23
+ async create(senderKeyName) {
24
+ const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
25
+ //console.log('GroupSessionBuilder create session', senderKeyName, senderKeyRecord);
26
+
27
+ if (senderKeyRecord.isEmpty()) {
28
+ const keyId = keyhelper.generateSenderKeyId();
29
+ const senderKey = keyhelper.generateSenderKey();
30
+ const signingKey = keyhelper.generateSenderSigningKey();
31
+
32
+ senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey);
33
+ await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
34
+ }
35
+
36
+ const state = senderKeyRecord.getSenderKeyState();
37
+
38
+ return new SenderKeyDistributionMessage(
39
+ state.getKeyId(),
40
+ state.getSenderChainKey().getIteration(),
41
+ state.getSenderChainKey().getSeed(),
42
+ state.getSigningKeyPublic()
43
+ );
44
+ }
45
+ }
46
+ module.exports = GroupSessionBuilder;
@@ -0,0 +1,6 @@
1
+ module.exports.GroupSessionBuilder = require('./group_session_builder')
2
+ module.exports.SenderKeyDistributionMessage = require('./sender_key_distribution_message')
3
+ module.exports.SenderKeyRecord = require('./sender_key_record')
4
+ module.exports.SenderKeyName = require('./sender_key_name')
5
+ module.exports.GroupCipher = require('./group_cipher')
6
+ // signal fixed
@@ -0,0 +1,21 @@
1
+ const curve = require('@neelegirl/libsignal/src/curve');
2
+ const nodeCrypto = require('crypto');
3
+
4
+ exports.generateSenderKey = function() {
5
+ return nodeCrypto.randomBytes(32);
6
+ }
7
+
8
+ exports.generateSenderKeyId = function() {
9
+ return nodeCrypto.randomInt(2147483647);
10
+ }
11
+
12
+ exports.generateSenderSigningKey = function(key) {
13
+ if (!key) {
14
+ key = curve.generateKeyPair();
15
+ }
16
+
17
+ return {
18
+ public: key.pubKey,
19
+ private: key.privKey,
20
+ };
21
+ }
@@ -0,0 +1,3 @@
1
+ const { groupproto } = require('./GroupProtocol')
2
+
3
+ module.exports = groupproto
@@ -0,0 +1,69 @@
1
+ // vim: ts=4:sw=4:expandtab
2
+
3
+ /*
4
+ * jobQueue manages multiple queues indexed by device to serialize
5
+ * session io ops on the database.
6
+ */
7
+ 'use strict';
8
+
9
+
10
+ const _queueAsyncBuckets = new Map();
11
+ const _gcLimit = 10000;
12
+
13
+ async function _asyncQueueExecutor(queue, cleanup) {
14
+ let offt = 0;
15
+ while (true) {
16
+ let limit = Math.min(queue.length, _gcLimit); // Break up thundering hurds for GC duty.
17
+ for (let i = offt; i < limit; i++) {
18
+ const job = queue[i];
19
+ try {
20
+ job.resolve(await job.awaitable());
21
+ } catch (e) {
22
+ job.reject(e);
23
+ }
24
+ }
25
+ if (limit < queue.length) {
26
+ /* Perform lazy GC of queue for faster iteration. */
27
+ if (limit >= _gcLimit) {
28
+ queue.splice(0, limit);
29
+ offt = 0;
30
+ } else {
31
+ offt = limit;
32
+ }
33
+ } else {
34
+ break;
35
+ }
36
+ }
37
+ cleanup();
38
+ }
39
+
40
+ module.exports = function (bucket, awaitable) {
41
+ /* Run the async awaitable only when all other async calls registered
42
+ * here have completed (or thrown). The bucket argument is a hashable
43
+ * key representing the task queue to use. */
44
+ if (!awaitable.name) {
45
+ // Make debuging easier by adding a name to this function.
46
+ Object.defineProperty(awaitable, 'name', { writable: true });
47
+ if (typeof bucket === 'string') {
48
+ awaitable.name = bucket;
49
+ } else {
50
+ console.warn("Unhandled bucket type (for naming):", typeof bucket, bucket);
51
+ }
52
+ }
53
+ let inactive;
54
+ if (!_queueAsyncBuckets.has(bucket)) {
55
+ _queueAsyncBuckets.set(bucket, []);
56
+ inactive = true;
57
+ }
58
+ const queue = _queueAsyncBuckets.get(bucket);
59
+ const job = new Promise((resolve, reject) => queue.push({
60
+ awaitable,
61
+ resolve,
62
+ reject
63
+ }));
64
+ if (inactive) {
65
+ /* An executor is not currently active; Start one now. */
66
+ _asyncQueueExecutor(queue, () => _queueAsyncBuckets.delete(bucket));
67
+ }
68
+ return job;
69
+ };
@@ -0,0 +1,6 @@
1
+ # Signal-Group
2
+
3
+ This contains the code to decrypt/encrypt WA group messages.
4
+ Originally from [pokearaujo/libsignal-node](https://github.com/pokearaujo/libsignal-node)
5
+
6
+ The code has been moved outside the signal package as I felt it didn't belong in ths signal package, as it isn't inherently a part of signal but of WA.
@@ -0,0 +1,50 @@
1
+ const SenderMessageKey = require('./sender_message_key');
2
+ //const HKDF = require('./hkdf');
3
+ const crypto = require('@neelegirl/libsignal/src/crypto');
4
+
5
+ class SenderChainKey {
6
+ MESSAGE_KEY_SEED = Buffer.from([0x01]);
7
+
8
+ CHAIN_KEY_SEED = Buffer.from([0x02]);
9
+
10
+ iteration = 0;
11
+
12
+ chainKey = Buffer.alloc(0);
13
+
14
+ constructor(iteration, chainKey) {
15
+ this.iteration = iteration;
16
+ this.chainKey = chainKey;
17
+ }
18
+
19
+ getIteration() {
20
+ return this.iteration;
21
+ }
22
+
23
+ getSenderMessageKey() {
24
+ return new SenderMessageKey(
25
+ this.iteration,
26
+ this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey)
27
+ );
28
+ }
29
+
30
+ getNext() {
31
+ return new SenderChainKey(
32
+ this.iteration + 1,
33
+ this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey)
34
+ );
35
+ }
36
+
37
+ getSeed() {
38
+ return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
39
+ }
40
+
41
+ getDerivative(seed, key) {
42
+ key = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
43
+ const hash = crypto.calculateMAC(key, seed);
44
+ //const hash = new Hash().hmac_hash(key, seed, 'sha256', '');
45
+
46
+ return hash;
47
+ }
48
+ }
49
+
50
+ module.exports = SenderChainKey;
@@ -0,0 +1,78 @@
1
+ const CiphertextMessage = require('./ciphertext_message');
2
+ const protobufs = require('./protobufs');
3
+
4
+ class SenderKeyDistributionMessage extends CiphertextMessage {
5
+ constructor(
6
+ id = null,
7
+ iteration = null,
8
+ chainKey = null,
9
+ signatureKey = null,
10
+ serialized = null
11
+ ) {
12
+ super();
13
+ if (serialized) {
14
+ try {
15
+ const version = serialized[0];
16
+ const message = serialized.slice(1);
17
+
18
+ const distributionMessage = protobufs.SenderKeyDistributionMessage.decode(
19
+ message
20
+ ).toJSON();
21
+ this.serialized = serialized;
22
+ this.id = distributionMessage.id;
23
+ this.iteration = distributionMessage.iteration;
24
+ this.chainKey = distributionMessage.chainKey;
25
+ this.signatureKey = distributionMessage.signingKey;
26
+ } catch (e) {
27
+ throw new Error(e);
28
+ }
29
+ } else {
30
+ const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
31
+ this.id = id;
32
+ this.iteration = iteration;
33
+ this.chainKey = chainKey;
34
+ this.signatureKey = signatureKey;
35
+ const message = protobufs.SenderKeyDistributionMessage.encode(
36
+ protobufs.SenderKeyDistributionMessage.create({
37
+ id,
38
+ iteration,
39
+ chainKey,
40
+ signingKey: this.signatureKey,
41
+ })
42
+ ).finish();
43
+ this.serialized = Buffer.concat([Buffer.from([version]), message]);
44
+ }
45
+ }
46
+
47
+ intsToByteHighAndLow(highValue, lowValue) {
48
+ return (((highValue << 4) | lowValue) & 0xff) % 256;
49
+ }
50
+
51
+ serialize() {
52
+ return this.serialized;
53
+ }
54
+
55
+ getType() {
56
+ return this.SENDERKEY_DISTRIBUTION_TYPE;
57
+ }
58
+
59
+ getIteration() {
60
+ return this.iteration;
61
+ }
62
+
63
+ getChainKey() {
64
+ return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
65
+ }
66
+
67
+ getSignatureKey() {
68
+ return typeof this.signatureKey === 'string'
69
+ ? Buffer.from(this.signatureKey, 'base64')
70
+ : this.signatureKey;
71
+ }
72
+
73
+ getId() {
74
+ return this.id;
75
+ }
76
+ }
77
+
78
+ module.exports = SenderKeyDistributionMessage;
@@ -0,0 +1,92 @@
1
+ const CiphertextMessage = require('./ciphertext_message');
2
+ const curve = require('@neelegirl/libsignal/src/curve');
3
+ const protobufs = require('./protobufs');
4
+
5
+ class SenderKeyMessage extends CiphertextMessage {
6
+ SIGNATURE_LENGTH = 64;
7
+
8
+ constructor(
9
+ keyId = null,
10
+ iteration = null,
11
+ ciphertext = null,
12
+ signatureKey = null,
13
+ serialized = null
14
+ ) {
15
+ super();
16
+ if (serialized) {
17
+ const version = serialized[0];
18
+ const message = serialized.slice(1, serialized.length - this.SIGNATURE_LENGTH);
19
+ const signature = serialized.slice(-1 * this.SIGNATURE_LENGTH);
20
+ const senderKeyMessage = protobufs.SenderKeyMessage.decode(message).toJSON();
21
+ senderKeyMessage.ciphertext = Buffer.from(senderKeyMessage.ciphertext, 'base64');
22
+
23
+ this.serialized = serialized;
24
+ this.messageVersion = (version & 0xff) >> 4;
25
+
26
+ this.keyId = senderKeyMessage.id;
27
+ this.iteration = senderKeyMessage.iteration;
28
+ this.ciphertext = senderKeyMessage.ciphertext;
29
+ this.signature = signature;
30
+ } else {
31
+ const version = (((this.CURRENT_VERSION << 4) | this.CURRENT_VERSION) & 0xff) % 256;
32
+ ciphertext = Buffer.from(ciphertext); // .toString('base64');
33
+ const message = protobufs.SenderKeyMessage.encode(
34
+ protobufs.SenderKeyMessage.create({
35
+ id: keyId,
36
+ iteration,
37
+ ciphertext,
38
+ })
39
+ ).finish();
40
+
41
+ const signature = this.getSignature(
42
+ signatureKey,
43
+ Buffer.concat([Buffer.from([version]), message])
44
+ );
45
+ this.serialized = Buffer.concat([Buffer.from([version]), message, Buffer.from(signature)]);
46
+ this.messageVersion = this.CURRENT_VERSION;
47
+ this.keyId = keyId;
48
+ this.iteration = iteration;
49
+ this.ciphertext = ciphertext;
50
+ this.signature = signature;
51
+ }
52
+ }
53
+
54
+ getKeyId() {
55
+ return this.keyId;
56
+ }
57
+
58
+ getIteration() {
59
+ return this.iteration;
60
+ }
61
+
62
+ getCipherText() {
63
+ return this.ciphertext;
64
+ }
65
+
66
+ verifySignature(signatureKey) {
67
+ const part1 = this.serialized.slice(0, this.serialized.length - this.SIGNATURE_LENGTH);
68
+ const part2 = this.serialized.slice(-1 * this.SIGNATURE_LENGTH);
69
+ const res = curve.verifySignature(signatureKey, part1, part2);
70
+ if (!res) throw new Error('Invalid signature!');
71
+ }
72
+
73
+ getSignature(signatureKey, serialized) {
74
+ const signature = Buffer.from(
75
+ curve.calculateSignature(
76
+ signatureKey,
77
+ serialized
78
+ )
79
+ );
80
+ return signature;
81
+ }
82
+
83
+ serialize() {
84
+ return this.serialized;
85
+ }
86
+
87
+ getType() {
88
+ return 4;
89
+ }
90
+ }
91
+
92
+ module.exports = SenderKeyMessage;
@@ -0,0 +1,70 @@
1
+ function isNull(str) {
2
+ return str === null || str.value === '';
3
+ }
4
+
5
+ /**
6
+ * java String hashCode 的实现
7
+ * @param strKey
8
+ * @return intValue
9
+ */
10
+ function intValue(num) {
11
+ const MAX_VALUE = 0x7fffffff;
12
+ const MIN_VALUE = -0x80000000;
13
+ if (num > MAX_VALUE || num < MIN_VALUE) {
14
+ // eslint-disable-next-line
15
+ return (num &= 0xffffffff);
16
+ }
17
+ return num;
18
+ }
19
+
20
+ function hashCode(strKey) {
21
+ let hash = 0;
22
+ if (!isNull(strKey)) {
23
+ for (let i = 0; i < strKey.length; i++) {
24
+ hash = hash * 31 + strKey.charCodeAt(i);
25
+ hash = intValue(hash);
26
+ }
27
+ }
28
+ return hash;
29
+ }
30
+
31
+ /**
32
+ * 将js页面的number类型转换为java的int类型
33
+ * @param num
34
+ * @return intValue
35
+ */
36
+
37
+ class SenderKeyName {
38
+ constructor(groupId, sender) {
39
+ this.groupId = groupId;
40
+ this.sender = sender;
41
+ }
42
+
43
+ getGroupId() {
44
+ return this.groupId;
45
+ }
46
+
47
+ getSender() {
48
+ return this.sender;
49
+ }
50
+
51
+ serialize() {
52
+ return `${this.groupId}::${this.sender.id}::${this.sender.deviceId}`;
53
+ }
54
+
55
+ toString() {
56
+ return this.serialize();
57
+ }
58
+
59
+ equals(other) {
60
+ if (other === null) return false;
61
+ if (!(other instanceof SenderKeyName)) return false;
62
+ return this.groupId === other.groupId && this.sender.toString() === other.sender.toString();
63
+ }
64
+
65
+ hashCode() {
66
+ return hashCode(this.groupId) ^ hashCode(this.sender.toString());
67
+ }
68
+ }
69
+
70
+ module.exports = SenderKeyName;
@@ -0,0 +1,56 @@
1
+ const SenderKeyState = require('./sender_key_state');
2
+
3
+ class SenderKeyRecord {
4
+ MAX_STATES = 5;
5
+
6
+ constructor(serialized) {
7
+ this.senderKeyStates = [];
8
+
9
+ if (serialized) {
10
+ const list = serialized;
11
+ for (let i = 0; i < list.length; i++) {
12
+ const structure = list[i];
13
+ this.senderKeyStates.push(
14
+ new SenderKeyState(null, null, null, null, null, null, structure)
15
+ );
16
+ }
17
+ }
18
+ }
19
+
20
+ isEmpty() {
21
+ return this.senderKeyStates.length === 0;
22
+ }
23
+
24
+ getSenderKeyState(keyId) {
25
+ if (!keyId && this.senderKeyStates.length) return this.senderKeyStates[this.senderKeyStates.length - 1];
26
+ for (let i = 0; i < this.senderKeyStates.length; i++) {
27
+ const state = this.senderKeyStates[i];
28
+ if (state.getKeyId() === keyId) {
29
+ return state;
30
+ }
31
+ }
32
+ }
33
+
34
+ addSenderKeyState(id, iteration, chainKey, signatureKey) {
35
+ this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, null, signatureKey));
36
+ if (this.senderKeyStates.length > 5) {
37
+ this.senderKeyStates.shift()
38
+ }
39
+ }
40
+
41
+ setSenderKeyState(id, iteration, chainKey, keyPair) {
42
+ this.senderKeyStates.length = 0;
43
+ this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, keyPair));
44
+ }
45
+
46
+ serialize() {
47
+ const recordStructure = [];
48
+ for (let i = 0; i < this.senderKeyStates.length; i++) {
49
+ const senderKeyState = this.senderKeyStates[i];
50
+ recordStructure.push(senderKeyState.getStructure());
51
+ }
52
+ return recordStructure;
53
+ }
54
+ }
55
+
56
+ module.exports = SenderKeyRecord;