@neelegirl/baileys 1.5.2 → 1.5.4

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 (419) hide show
  1. package/README.md +26 -18
  2. package/WAProto/GenerateStatics.sh +3 -0
  3. package/WAProto/WAProto.proto +291 -665
  4. package/WAProto/fix-imports.js +29 -0
  5. package/WAProto/index.d.ts +2297 -48040
  6. package/WAProto/index.js +45500 -140101
  7. package/engine-requirements.js +10 -0
  8. package/lib/Defaults/index.d.ts +58 -64
  9. package/lib/Defaults/index.d.ts.map +1 -0
  10. package/lib/Defaults/index.js +74 -96
  11. package/lib/Defaults/index.js.map +1 -0
  12. package/lib/Signal/Group/ciphertext-message.d.ts +10 -0
  13. package/lib/Signal/Group/ciphertext-message.d.ts.map +1 -0
  14. package/lib/Signal/Group/ciphertext-message.js +12 -0
  15. package/lib/Signal/Group/ciphertext-message.js.map +1 -0
  16. package/lib/Signal/Group/group-session-builder.d.ts +15 -0
  17. package/lib/Signal/Group/group-session-builder.d.ts.map +1 -0
  18. package/lib/Signal/Group/group-session-builder.js +30 -0
  19. package/lib/Signal/Group/group-session-builder.js.map +1 -0
  20. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  21. package/lib/Signal/Group/group_cipher.d.ts.map +1 -0
  22. package/lib/Signal/Group/group_cipher.js +82 -0
  23. package/lib/Signal/Group/group_cipher.js.map +1 -0
  24. package/lib/Signal/Group/index.d.ts +12 -0
  25. package/lib/Signal/Group/index.d.ts.map +1 -0
  26. package/lib/Signal/Group/index.js +12 -0
  27. package/lib/Signal/Group/index.js.map +1 -0
  28. package/lib/Signal/Group/keyhelper.d.ts +11 -0
  29. package/lib/Signal/Group/keyhelper.d.ts.map +1 -0
  30. package/lib/Signal/Group/keyhelper.js +18 -0
  31. package/lib/Signal/Group/keyhelper.js.map +1 -0
  32. package/lib/Signal/Group/sender-chain-key.d.ts +14 -0
  33. package/lib/Signal/Group/sender-chain-key.d.ts.map +1 -0
  34. package/lib/Signal/Group/sender-chain-key.js +26 -0
  35. package/lib/Signal/Group/sender-chain-key.js.map +1 -0
  36. package/lib/Signal/Group/sender-key-distribution-message.d.ts +17 -0
  37. package/lib/Signal/Group/sender-key-distribution-message.d.ts.map +1 -0
  38. package/lib/Signal/Group/sender-key-distribution-message.js +63 -0
  39. package/lib/Signal/Group/sender-key-distribution-message.js.map +1 -0
  40. package/lib/Signal/Group/sender-key-message.d.ts +19 -0
  41. package/lib/Signal/Group/sender-key-message.d.ts.map +1 -0
  42. package/lib/Signal/Group/sender-key-message.js +66 -0
  43. package/lib/Signal/Group/sender-key-message.js.map +1 -0
  44. package/lib/Signal/Group/sender-key-name.d.ts +18 -0
  45. package/lib/Signal/Group/sender-key-name.d.ts.map +1 -0
  46. package/lib/Signal/Group/sender-key-name.js +48 -0
  47. package/lib/Signal/Group/sender-key-name.js.map +1 -0
  48. package/lib/Signal/Group/sender-key-record.d.ts +31 -0
  49. package/lib/Signal/Group/sender-key-record.d.ts.map +1 -0
  50. package/lib/Signal/Group/sender-key-record.js +41 -0
  51. package/lib/Signal/Group/sender-key-record.js.map +1 -0
  52. package/lib/Signal/Group/sender-key-state.d.ts +39 -0
  53. package/lib/Signal/Group/sender-key-state.d.ts.map +1 -0
  54. package/lib/Signal/Group/sender-key-state.js +84 -0
  55. package/lib/Signal/Group/sender-key-state.js.map +1 -0
  56. package/lib/Signal/Group/sender-message-key.d.ts +12 -0
  57. package/lib/Signal/Group/sender-message-key.d.ts.map +1 -0
  58. package/lib/Signal/{WASignalGroup/sender_message_key.js → Group/sender-message-key.js} +3 -16
  59. package/lib/Signal/Group/sender-message-key.js.map +1 -0
  60. package/lib/Signal/libsignal.d.ts +5 -4
  61. package/lib/Signal/libsignal.d.ts.map +1 -0
  62. package/lib/Signal/libsignal.js +292 -112
  63. package/lib/Signal/libsignal.js.map +1 -0
  64. package/lib/Signal/lid-mapping.d.ts +23 -0
  65. package/lib/Signal/lid-mapping.d.ts.map +1 -0
  66. package/lib/Signal/lid-mapping.js +171 -0
  67. package/lib/Signal/lid-mapping.js.map +1 -0
  68. package/lib/Socket/Client/index.d.ts +3 -2
  69. package/lib/Socket/Client/index.d.ts.map +1 -0
  70. package/lib/Socket/Client/index.js +3 -22
  71. package/lib/Socket/Client/index.js.map +1 -0
  72. package/lib/Socket/Client/types.d.ts +15 -15
  73. package/lib/Socket/Client/types.d.ts.map +1 -0
  74. package/lib/Socket/Client/types.js +8 -15
  75. package/lib/Socket/Client/types.js.map +1 -0
  76. package/lib/Socket/Client/websocket.d.ts +12 -12
  77. package/lib/Socket/Client/websocket.d.ts.map +1 -0
  78. package/lib/Socket/Client/websocket.js +24 -36
  79. package/lib/Socket/Client/websocket.js.map +1 -0
  80. package/lib/Socket/business.d.ts +178 -177
  81. package/lib/Socket/business.d.ts.map +1 -0
  82. package/lib/Socket/business.js +179 -71
  83. package/lib/Socket/business.js.map +1 -0
  84. package/lib/Socket/chats.d.ts +93 -93
  85. package/lib/Socket/chats.d.ts.map +1 -0
  86. package/lib/Socket/chats.js +474 -625
  87. package/lib/Socket/chats.js.map +1 -0
  88. package/lib/Socket/communities.d.ts +83 -62
  89. package/lib/Socket/communities.d.ts.map +1 -0
  90. package/lib/Socket/communities.js +412 -414
  91. package/lib/Socket/communities.js.map +1 -0
  92. package/lib/Socket/groups.d.ts +118 -112
  93. package/lib/Socket/groups.d.ts.map +1 -0
  94. package/lib/Socket/groups.js +146 -171
  95. package/lib/Socket/groups.js.map +1 -0
  96. package/lib/Socket/index.d.ts +222 -182
  97. package/lib/Socket/index.d.ts.map +1 -0
  98. package/lib/Socket/index.js +12 -17
  99. package/lib/Socket/index.js.map +1 -0
  100. package/lib/Socket/messages-recv.d.ts +165 -169
  101. package/lib/Socket/messages-recv.d.ts.map +1 -0
  102. package/lib/Socket/messages-recv.js +1185 -1721
  103. package/lib/Socket/messages-recv.js.map +1 -0
  104. package/lib/Socket/messages-send.d.ts +161 -159
  105. package/lib/Socket/messages-send.d.ts.map +1 -0
  106. package/lib/Socket/messages-send.js +650 -991
  107. package/lib/Socket/messages-send.js.map +1 -0
  108. package/lib/Socket/mex.d.ts +1 -0
  109. package/lib/Socket/mex.d.ts.map +1 -0
  110. package/lib/Socket/mex.js +4 -9
  111. package/lib/Socket/mex.js.map +1 -0
  112. package/lib/Socket/newsletter.d.ts +139 -139
  113. package/lib/Socket/newsletter.d.ts.map +1 -0
  114. package/lib/Socket/newsletter.js +153 -258
  115. package/lib/Socket/newsletter.js.map +1 -0
  116. package/lib/Socket/socket.d.ts +42 -36
  117. package/lib/Socket/socket.d.ts.map +1 -0
  118. package/lib/Socket/socket.js +623 -507
  119. package/lib/Socket/socket.js.map +1 -0
  120. package/lib/Types/Auth.d.ts +87 -96
  121. package/lib/Types/Auth.d.ts.map +1 -0
  122. package/lib/Types/Auth.js +2 -3
  123. package/lib/Types/Auth.js.map +1 -0
  124. package/lib/Types/Bussines.d.ts +25 -0
  125. package/lib/Types/Bussines.d.ts.map +1 -0
  126. package/lib/Types/Bussines.js +2 -0
  127. package/lib/Types/Bussines.js.map +1 -0
  128. package/lib/Types/Call.d.ts +13 -13
  129. package/lib/Types/Call.d.ts.map +1 -0
  130. package/lib/Types/Call.js +2 -3
  131. package/lib/Types/Call.js.map +1 -0
  132. package/lib/Types/Chat.d.ts +79 -94
  133. package/lib/Types/Chat.d.ts.map +1 -0
  134. package/lib/Types/Chat.js +8 -9
  135. package/lib/Types/Chat.js.map +1 -0
  136. package/lib/Types/Contact.d.ts +13 -9
  137. package/lib/Types/Contact.d.ts.map +1 -0
  138. package/lib/Types/Contact.js +2 -3
  139. package/lib/Types/Contact.js.map +1 -0
  140. package/lib/Types/Events.d.ts +152 -179
  141. package/lib/Types/Events.d.ts.map +1 -0
  142. package/lib/Types/Events.js +2 -3
  143. package/lib/Types/Events.js.map +1 -0
  144. package/lib/Types/GroupMetadata.d.ts +49 -48
  145. package/lib/Types/GroupMetadata.d.ts.map +1 -0
  146. package/lib/Types/GroupMetadata.js +2 -3
  147. package/lib/Types/GroupMetadata.js.map +1 -0
  148. package/lib/Types/Label.d.ts +13 -14
  149. package/lib/Types/Label.d.ts.map +1 -0
  150. package/lib/Types/Label.js +24 -30
  151. package/lib/Types/Label.js.map +1 -0
  152. package/lib/Types/LabelAssociation.d.ts +15 -20
  153. package/lib/Types/LabelAssociation.d.ts.map +1 -0
  154. package/lib/Types/LabelAssociation.js +6 -12
  155. package/lib/Types/LabelAssociation.js.map +1 -0
  156. package/lib/Types/Message.d.ts +234 -404
  157. package/lib/Types/Message.d.ts.map +1 -0
  158. package/lib/Types/Message.js +11 -13
  159. package/lib/Types/Message.js.map +1 -0
  160. package/lib/Types/Newsletter.d.ts +130 -104
  161. package/lib/Types/Newsletter.d.ts.map +1 -0
  162. package/lib/Types/Newsletter.js +31 -40
  163. package/lib/Types/Newsletter.js.map +1 -0
  164. package/lib/Types/Product.d.ts +58 -71
  165. package/lib/Types/Product.d.ts.map +1 -0
  166. package/lib/Types/Product.js +2 -3
  167. package/lib/Types/Product.js.map +1 -0
  168. package/lib/Types/Signal.d.ts +63 -55
  169. package/lib/Types/Signal.d.ts.map +1 -0
  170. package/lib/Types/Signal.js +2 -3
  171. package/lib/Types/Signal.js.map +1 -0
  172. package/lib/Types/Socket.d.ts +78 -65
  173. package/lib/Types/Socket.d.ts.map +1 -0
  174. package/lib/Types/Socket.js +3 -3
  175. package/lib/Types/Socket.js.map +1 -0
  176. package/lib/Types/State.d.ts +17 -19
  177. package/lib/Types/State.d.ts.map +1 -0
  178. package/lib/Types/State.js +13 -14
  179. package/lib/Types/State.js.map +1 -0
  180. package/lib/Types/USync.d.ts +8 -8
  181. package/lib/Types/USync.d.ts.map +1 -0
  182. package/lib/Types/USync.js +2 -3
  183. package/lib/Types/USync.js.map +1 -0
  184. package/lib/Types/index.d.ts +47 -61
  185. package/lib/Types/index.d.ts.map +1 -0
  186. package/lib/Types/index.js +26 -48
  187. package/lib/Types/index.js.map +1 -0
  188. package/lib/Utils/auth-utils.d.ts +8 -10
  189. package/lib/Utils/auth-utils.d.ts.map +1 -0
  190. package/lib/Utils/auth-utils.js +206 -154
  191. package/lib/Utils/auth-utils.js.map +1 -0
  192. package/lib/Utils/baileys-event-stream.d.ts +6 -7
  193. package/lib/Utils/baileys-event-stream.d.ts.map +1 -0
  194. package/lib/Utils/baileys-event-stream.js +29 -43
  195. package/lib/Utils/baileys-event-stream.js.map +1 -0
  196. package/lib/Utils/browser-utils.d.ts +4 -0
  197. package/lib/Utils/browser-utils.d.ts.map +1 -0
  198. package/lib/Utils/browser-utils.js +28 -0
  199. package/lib/Utils/browser-utils.js.map +1 -0
  200. package/lib/Utils/business.d.ts +14 -20
  201. package/lib/Utils/business.d.ts.map +1 -0
  202. package/lib/Utils/business.js +110 -134
  203. package/lib/Utils/business.js.map +1 -0
  204. package/lib/Utils/chat-utils.d.ts +57 -69
  205. package/lib/Utils/chat-utils.d.ts.map +1 -0
  206. package/lib/Utils/chat-utils.js +362 -380
  207. package/lib/Utils/chat-utils.js.map +1 -0
  208. package/lib/Utils/crypto.d.ts +30 -45
  209. package/lib/Utils/crypto.d.ts.map +1 -0
  210. package/lib/Utils/crypto.js +141 -178
  211. package/lib/Utils/crypto.js.map +1 -0
  212. package/lib/Utils/decode-wa-message.d.ts +42 -35
  213. package/lib/Utils/decode-wa-message.d.ts.map +1 -0
  214. package/lib/Utils/decode-wa-message.js +176 -150
  215. package/lib/Utils/decode-wa-message.js.map +1 -0
  216. package/lib/Utils/event-buffer.d.ts +12 -17
  217. package/lib/Utils/event-buffer.d.ts.map +1 -0
  218. package/lib/Utils/event-buffer.js +269 -286
  219. package/lib/Utils/event-buffer.js.map +1 -0
  220. package/lib/Utils/generics.d.ts +60 -99
  221. package/lib/Utils/generics.d.ts.map +1 -0
  222. package/lib/Utils/generics.js +244 -487
  223. package/lib/Utils/generics.js.map +1 -0
  224. package/lib/Utils/history.d.ts +18 -22
  225. package/lib/Utils/history.d.ts.map +1 -0
  226. package/lib/Utils/history.js +54 -80
  227. package/lib/Utils/history.js.map +1 -0
  228. package/lib/Utils/index.d.ts +20 -19
  229. package/lib/Utils/index.d.ts.map +1 -0
  230. package/lib/Utils/index.js +19 -39
  231. package/lib/Utils/index.js.map +1 -0
  232. package/lib/Utils/link-preview.d.ts +12 -14
  233. package/lib/Utils/link-preview.d.ts.map +1 -0
  234. package/lib/Utils/link-preview.js +40 -75
  235. package/lib/Utils/link-preview.js.map +1 -0
  236. package/lib/Utils/logger.d.ts +10 -11
  237. package/lib/Utils/logger.d.ts.map +1 -0
  238. package/lib/Utils/logger.js +3 -7
  239. package/lib/Utils/logger.js.map +1 -0
  240. package/lib/Utils/lt-hash.d.ts +12 -13
  241. package/lib/Utils/lt-hash.d.ts.map +1 -0
  242. package/lib/Utils/lt-hash.js +27 -37
  243. package/lib/Utils/lt-hash.js.map +1 -0
  244. package/lib/Utils/make-mutex.d.ts +6 -7
  245. package/lib/Utils/make-mutex.d.ts.map +1 -0
  246. package/lib/Utils/make-mutex.js +20 -29
  247. package/lib/Utils/make-mutex.js.map +1 -0
  248. package/lib/Utils/message-retry-manager.d.ts +82 -0
  249. package/lib/Utils/message-retry-manager.d.ts.map +1 -0
  250. package/lib/Utils/message-retry-manager.js +149 -0
  251. package/lib/Utils/message-retry-manager.js.map +1 -0
  252. package/lib/Utils/messages-media.d.ts +87 -102
  253. package/lib/Utils/messages-media.d.ts.map +1 -0
  254. package/lib/Utils/messages-media.js +427 -570
  255. package/lib/Utils/messages-media.js.map +1 -0
  256. package/lib/Utils/messages.d.ts +37 -64
  257. package/lib/Utils/messages.d.ts.map +1 -0
  258. package/lib/Utils/messages.js +511 -1270
  259. package/lib/Utils/messages.js.map +1 -0
  260. package/lib/Utils/noise-handler.d.ts +18 -18
  261. package/lib/Utils/noise-handler.d.ts.map +1 -0
  262. package/lib/Utils/noise-handler.js +101 -109
  263. package/lib/Utils/noise-handler.js.map +1 -0
  264. package/lib/Utils/pre-key-manager.d.ts +28 -0
  265. package/lib/Utils/pre-key-manager.d.ts.map +1 -0
  266. package/lib/Utils/pre-key-manager.js +106 -0
  267. package/lib/Utils/pre-key-manager.js.map +1 -0
  268. package/lib/Utils/process-message.d.ts +25 -32
  269. package/lib/Utils/process-message.d.ts.map +1 -0
  270. package/lib/Utils/process-message.js +266 -281
  271. package/lib/Utils/process-message.js.map +1 -0
  272. package/lib/Utils/signal.d.ts +24 -32
  273. package/lib/Utils/signal.d.ts.map +1 -0
  274. package/lib/Utils/signal.js +98 -105
  275. package/lib/Utils/signal.js.map +1 -0
  276. package/lib/Utils/use-multi-file-auth-state.d.ts +5 -10
  277. package/lib/Utils/use-multi-file-auth-state.d.ts.map +1 -0
  278. package/lib/Utils/use-multi-file-auth-state.js +69 -186
  279. package/lib/Utils/use-multi-file-auth-state.js.map +1 -0
  280. package/lib/Utils/validate-connection.d.ts +11 -13
  281. package/lib/Utils/validate-connection.d.ts.map +1 -0
  282. package/lib/Utils/validate-connection.js +124 -116
  283. package/lib/Utils/validate-connection.js.map +1 -0
  284. package/lib/WABinary/constants.d.ts +25 -27
  285. package/lib/WABinary/constants.d.ts.map +1 -0
  286. package/lib/WABinary/constants.js +1277 -1292
  287. package/lib/WABinary/constants.js.map +1 -0
  288. package/lib/WABinary/decode.d.ts +7 -9
  289. package/lib/WABinary/decode.d.ts.map +1 -0
  290. package/lib/WABinary/decode.js +139 -189
  291. package/lib/WABinary/decode.js.map +1 -0
  292. package/lib/WABinary/encode.d.ts +3 -3
  293. package/lib/WABinary/encode.d.ts.map +1 -0
  294. package/lib/WABinary/encode.js +105 -154
  295. package/lib/WABinary/encode.js.map +1 -0
  296. package/lib/WABinary/generic-utils.d.ts +14 -27
  297. package/lib/WABinary/generic-utils.d.ts.map +1 -0
  298. package/lib/WABinary/generic-utils.js +62 -102
  299. package/lib/WABinary/generic-utils.js.map +1 -0
  300. package/lib/WABinary/index.d.ts +6 -5
  301. package/lib/WABinary/index.d.ts.map +1 -0
  302. package/lib/WABinary/index.js +6 -25
  303. package/lib/WABinary/index.js.map +1 -0
  304. package/lib/WABinary/jid-utils.d.ts +41 -46
  305. package/lib/WABinary/jid-utils.d.ts.map +1 -0
  306. package/lib/WABinary/jid-utils.js +84 -80
  307. package/lib/WABinary/jid-utils.js.map +1 -0
  308. package/lib/WABinary/types.d.ts +10 -13
  309. package/lib/WABinary/types.d.ts.map +1 -0
  310. package/lib/WABinary/types.js +2 -3
  311. package/lib/WABinary/types.js.map +1 -0
  312. package/lib/WAM/BinaryInfo.d.ts +8 -15
  313. package/lib/WAM/BinaryInfo.d.ts.map +1 -0
  314. package/lib/WAM/BinaryInfo.js +7 -14
  315. package/lib/WAM/BinaryInfo.js.map +1 -0
  316. package/lib/WAM/constants.d.ts +30 -37
  317. package/lib/WAM/constants.d.ts.map +1 -0
  318. package/lib/WAM/constants.js +19193 -11711
  319. package/lib/WAM/constants.js.map +1 -0
  320. package/lib/WAM/encode.d.ts +3 -3
  321. package/lib/WAM/encode.d.ts.map +1 -0
  322. package/lib/WAM/encode.js +95 -110
  323. package/lib/WAM/encode.js.map +1 -0
  324. package/lib/WAM/index.d.ts +4 -3
  325. package/lib/WAM/index.d.ts.map +1 -0
  326. package/lib/WAM/index.js +4 -23
  327. package/lib/WAM/index.js.map +1 -0
  328. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -9
  329. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts.map +1 -0
  330. package/lib/WAUSync/Protocols/USyncContactProtocol.js +12 -19
  331. package/lib/WAUSync/Protocols/USyncContactProtocol.js.map +1 -0
  332. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +19 -22
  333. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts.map +1 -0
  334. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +18 -26
  335. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js.map +1 -0
  336. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +11 -12
  337. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts.map +1 -0
  338. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -20
  339. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js.map +1 -0
  340. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +11 -12
  341. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts.map +1 -0
  342. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +16 -24
  343. package/lib/WAUSync/Protocols/USyncStatusProtocol.js.map +1 -0
  344. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +26 -0
  345. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts.map +1 -0
  346. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +51 -0
  347. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js.map +1 -0
  348. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +10 -0
  349. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts.map +1 -0
  350. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +29 -0
  351. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js.map +1 -0
  352. package/lib/WAUSync/Protocols/index.d.ts +5 -6
  353. package/lib/WAUSync/Protocols/index.d.ts.map +1 -0
  354. package/lib/WAUSync/Protocols/index.js +5 -26
  355. package/lib/WAUSync/Protocols/index.js.map +1 -0
  356. package/lib/WAUSync/USyncQuery.d.ts +26 -28
  357. package/lib/WAUSync/USyncQuery.d.ts.map +1 -0
  358. package/lib/WAUSync/USyncQuery.js +64 -62
  359. package/lib/WAUSync/USyncQuery.js.map +1 -0
  360. package/lib/WAUSync/USyncUser.d.ts +11 -10
  361. package/lib/WAUSync/USyncUser.d.ts.map +1 -0
  362. package/lib/WAUSync/USyncUser.js +12 -19
  363. package/lib/WAUSync/USyncUser.js.map +1 -0
  364. package/lib/WAUSync/index.d.ts +4 -3
  365. package/lib/WAUSync/index.d.ts.map +1 -0
  366. package/lib/WAUSync/index.js +4 -23
  367. package/lib/WAUSync/index.js.map +1 -0
  368. package/lib/index.d.ts +10 -11
  369. package/lib/index.d.ts.map +1 -0
  370. package/lib/index.js +11 -33
  371. package/lib/index.js.map +1 -0
  372. package/package.json +48 -43
  373. package/lib/Defaults/baileys-version.json +0 -3
  374. package/lib/Defaults/phonenumber-mcc.json +0 -223
  375. package/lib/Signal/WASignalGroup/GroupProtocol.js +0 -1909
  376. package/lib/Signal/WASignalGroup/ciphertext_message.js +0 -16
  377. package/lib/Signal/WASignalGroup/generate-proto.sh +0 -1
  378. package/lib/Signal/WASignalGroup/group.proto +0 -42
  379. package/lib/Signal/WASignalGroup/group_cipher.js +0 -120
  380. package/lib/Signal/WASignalGroup/group_session_builder.js +0 -46
  381. package/lib/Signal/WASignalGroup/index.js +0 -6
  382. package/lib/Signal/WASignalGroup/keyhelper.js +0 -21
  383. package/lib/Signal/WASignalGroup/protobufs.js +0 -3
  384. package/lib/Signal/WASignalGroup/queue_job.js +0 -69
  385. package/lib/Signal/WASignalGroup/readme.md +0 -6
  386. package/lib/Signal/WASignalGroup/sender_chain_key.js +0 -50
  387. package/lib/Signal/WASignalGroup/sender_key_distribution_message.js +0 -78
  388. package/lib/Signal/WASignalGroup/sender_key_message.js +0 -92
  389. package/lib/Signal/WASignalGroup/sender_key_name.js +0 -70
  390. package/lib/Signal/WASignalGroup/sender_key_record.js +0 -56
  391. package/lib/Signal/WASignalGroup/sender_key_state.js +0 -129
  392. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -15
  393. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  394. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -12
  395. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  396. package/lib/Socket/registration.d.ts +0 -266
  397. package/lib/Socket/registration.js +0 -166
  398. package/lib/Socket/usync.d.ts +0 -37
  399. package/lib/Socket/usync.js +0 -83
  400. package/lib/Store/index.d.ts +0 -4
  401. package/lib/Store/index.js +0 -24
  402. package/lib/Store/make-cache-manager-store.d.ts +0 -14
  403. package/lib/Store/make-cache-manager-store.js +0 -90
  404. package/lib/Store/make-in-memory-store.d.ts +0 -123
  405. package/lib/Store/make-in-memory-store.js +0 -429
  406. package/lib/Store/make-ordered-dictionary.d.ts +0 -12
  407. package/lib/Store/make-ordered-dictionary.js +0 -86
  408. package/lib/Store/object-repository.d.ts +0 -10
  409. package/lib/Store/object-repository.js +0 -31
  410. package/lib/Types/MexUpdates.d.ts +0 -9
  411. package/lib/Types/MexUpdates.js +0 -18
  412. package/lib/Utils/use-mongo-file-auth-state.d.ts +0 -6
  413. package/lib/Utils/use-mongo-file-auth-state.js +0 -84
  414. package/lib/Utils/use-single-file-auth-state.d.ts +0 -13
  415. package/lib/Utils/use-single-file-auth-state.js +0 -80
  416. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.d.ts +0 -28
  417. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.js +0 -69
  418. package/lib/WAUSync/Protocols/USyncLIDProtocol.d.ts +0 -9
  419. package/lib/WAUSync/Protocols/USyncLIDProtocol.js +0 -30
@@ -1,429 +0,0 @@
1
- "use strict"
2
-
3
- var __importDefault = (this && this.__importDefault) || function (mod) {
4
- return (mod && mod.__esModule) ? mod : { "default": mod }
5
- }
6
-
7
- Object.defineProperty(exports, "__esModule", { value: true })
8
-
9
- const WAProto_1 = require("../../WAProto")
10
- const Defaults_1 = require("../Defaults")
11
- const LabelAssociation_1 = require("../Types/LabelAssociation")
12
- const Utils_1 = require("../Utils")
13
- const WABinary_1 = require("../WABinary")
14
- const Store_1 = require("./make-ordered-dictionary")
15
- const object_repository_1 = require("./object-repository")
16
-
17
- const waChatKey = (pin) => ({
18
- key: (c) => (pin ? (c.pinned ? '1' : '0') : '') + (c.archived ? '0' : '1') + (c.conversationTimestamp ? c.conversationTimestamp.toString(16).padStart(8, '0') : '') + c.id,
19
- compare: (k1, k2) => k2.localeCompare(k1)
20
- })
21
-
22
- const waMessageID = (m) => m.key.id || ''
23
-
24
- const waLabelAssociationKey = {
25
- key: (la) => (la.type === LabelAssociation_1.LabelAssociationType.Chat ? la.chatId + la.labelId : la.chatId + la.messageId + la.labelId),
26
- compare: (k1, k2) => k2.localeCompare(k1)
27
- }
28
-
29
- const makeMessagesDictionary = () => Store_1.makeOrderedDictionary(waMessageID)
30
-
31
- const makeInMemoryStore = (config) => {
32
- const socket = config.socket
33
- const chatKey = config.chatKey || waChatKey(true)
34
- const labelAssociationKey = config.labelAssociationKey || waLabelAssociationKey
35
- const logger = config.logger || Defaults_1.DEFAULT_CONNECTION_CONFIG.logger.child({ stream: 'in-mem-store' })
36
- const KeyedDB = require('@adiwajshing/keyed-db').default
37
- const chats = new KeyedDB(chatKey, c => c.id)
38
- const messages = {}
39
- const contacts = {}
40
- const groupMetadata = {}
41
- const presences = {}
42
- const state = { connection: 'close' }
43
- const labels = new object_repository_1.ObjectRepository()
44
- const labelAssociations = new KeyedDB(labelAssociationKey, labelAssociationKey.key)
45
- const assertMessageList = (jid) => {
46
- if (!messages[jid]) {
47
- messages[jid] = makeMessagesDictionary()
48
- }
49
- return messages[jid]
50
- }
51
- const contactsUpsert = (newContacts) => {
52
- const oldContacts = new Set(Object.keys(contacts))
53
- for (const contact of newContacts) {
54
- oldContacts.delete(contact.id)
55
- contacts[contact.id] = Object.assign(contacts[contact.id] || {}, contact)
56
- }
57
- return oldContacts
58
- }
59
- const labelsUpsert = (newLabels) => {
60
- for (const label of newLabels) {
61
- labels.upsertById(label.id, label)
62
- }
63
- }
64
- /**
65
- * binds to a BaileysEventEmitter.
66
- * It listens to all events and constructs a state that you can query accurate data from.
67
- * Eg. can use the store to fetch chats, contacts, messages etc.
68
- * @param ev typically the event emitter from the socket connection
69
- */
70
- const bind = (ev) => {
71
- ev.on('connection.update', update => {
72
- Object.assign(state, update)
73
- })
74
- ev.on('messaging-history.set', ({ chats: newChats, contacts: newContacts, messages: newMessages, isLatest, syncType }) => {
75
- if (syncType === WAProto_1.proto.HistorySync.HistorySyncType.ON_DEMAND) {
76
- return // FOR NOW,
77
- //TODO: HANDLE
78
- }
79
- if (isLatest) {
80
- chats.clear()
81
- for (const id in messages) {
82
- delete messages[id]
83
- }
84
- }
85
- const chatsAdded = chats.insertIfAbsent(...newChats).length
86
- logger.debug({ chatsAdded }, 'synced chats')
87
- const oldContacts = contactsUpsert(newContacts)
88
- if (isLatest) {
89
- for (const jid of oldContacts) {
90
- delete contacts[jid]
91
- }
92
- }
93
- logger.debug({ deletedContacts: isLatest ? oldContacts.size : 0, newContacts }, 'synced contacts')
94
- for (const msg of newMessages) {
95
- const jid = msg.key.remoteJid
96
- const list = assertMessageList(jid)
97
- list.upsert(msg, 'prepend')
98
- }
99
- logger.debug({ messages: newMessages.length }, 'synced messages')
100
- })
101
- ev.on('contacts.upsert', contacts => {
102
- contactsUpsert(contacts)
103
- })
104
- ev.on('contacts.update', async (updates) => {
105
- for (const update of updates) {
106
- let contact
107
- if (contacts[update.id]) {
108
- contact = contacts[update.id]
109
- }
110
- else {
111
- const contactHashes = await Promise.all(Object.keys(contacts).map(async (contactId) => {
112
- const { user } = WABinary_1.jidDecode(contactId)
113
- return [contactId, (await Utils_1.md5(Buffer.from(user + 'WA_ADD_NOTIF', 'utf8'))).toString('base64').slice(0, 3)]
114
- }))
115
- contact = contacts[contactHashes.find(([, b]) => b === update.id?.[0]) || ''] // find contact by attrs.hash, when user is not saved as a contact
116
- }
117
- if (contact) {
118
- if (update.imgUrl === 'changed') {
119
- contact.imgUrl = socket ? await socket.profilePictureUrl(contact.id) : undefined
120
- }
121
- else if (update.imgUrl === 'removed') {
122
- delete contact.imgUrl
123
- }
124
- }
125
- else {
126
- return logger.debug({ update }, 'got update for non-existant contact')
127
- }
128
- Object.assign(contacts[contact.id], contact)
129
- }
130
- })
131
- ev.on('chats.upsert', newChats => {
132
- chats.upsert(...newChats)
133
- })
134
- ev.on('chats.update', updates => {
135
- for (let update of updates) {
136
- const result = chats.update(update.id, chat => {
137
- if (update.unreadCount > 0) {
138
- update = { ...update }
139
- update.unreadCount = (chat.unreadCount || 0) + update.unreadCount
140
- }
141
- Object.assign(chat, update)
142
- })
143
- if (!result) {
144
- logger.debug({ update }, 'got update for non-existant chat')
145
- }
146
- }
147
- })
148
- ev.on('labels.edit', (label) => {
149
- if (label.deleted) {
150
- return labels.deleteById(label.id)
151
- }
152
- // WhatsApp can store only up to 20 labels
153
- if (labels.count() < 20) {
154
- return labels.upsertById(label.id, label)
155
- }
156
- logger.error('Labels count exceed')
157
- })
158
- ev.on('labels.association', ({ type, association }) => {
159
- switch (type) {
160
- case 'add':
161
- labelAssociations.upsert(association)
162
- break
163
- case 'remove':
164
- labelAssociations.delete(association)
165
- break
166
- default:
167
- console.error(`unknown operation type [${type}]`)
168
- }
169
- })
170
- ev.on('presence.update', ({ id, presences: update }) => {
171
- presences[id] = presences[id] || {}
172
- Object.assign(presences[id], update)
173
- })
174
- ev.on('chats.delete', deletions => {
175
- for (const item of deletions) {
176
- if (chats.get(item)) {
177
- chats.deleteById(item)
178
- }
179
- }
180
- })
181
- ev.on('messages.upsert', ({ messages: newMessages, type }) => {
182
- switch (type) {
183
- case 'append':
184
- case 'notify':
185
- for (const msg of newMessages) {
186
- const jid = WABinary_1.jidNormalizedUser(msg.key.remoteJid)
187
- const list = assertMessageList(jid)
188
- list.upsert(msg, 'append')
189
- if (type === 'notify' && !chats.get(jid)) {
190
- ev.emit('chats.upsert', [
191
- {
192
- id: jid,
193
- conversationTimestamp: Utils_1.toNumber(msg.messageTimestamp),
194
- unreadCount: 1
195
- }
196
- ])
197
- }
198
- }
199
- break
200
- }
201
- })
202
- ev.on('messages.update', updates => {
203
- for (const { update, key } of updates) {
204
- const list = assertMessageList(WABinary_1.jidNormalizedUser(key.remoteJid))
205
- if (update?.status) {
206
- const listStatus = list.get(key.id)?.status
207
- if (listStatus && update?.status <= listStatus) {
208
- logger.debug({ update, storedStatus: listStatus }, 'status stored newer then update')
209
- delete update.status
210
- logger.debug({ update }, 'new update object')
211
- }
212
- }
213
- const result = list.updateAssign(key.id, update)
214
- if (!result) {
215
- logger.debug({ update }, 'got update for non-existent message')
216
- }
217
- }
218
- })
219
- ev.on('messages.delete', item => {
220
- if ('all' in item) {
221
- const list = messages[item.jid]
222
- list?.clear()
223
- }
224
- else {
225
- const jid = item.keys[0].remoteJid
226
- const list = messages[jid]
227
- if (list) {
228
- const idSet = new Set(item.keys.map(k => k.id))
229
- list.filter(m => !idSet.has(m.key.id))
230
- }
231
- }
232
- })
233
- ev.on('groups.update', updates => {
234
- for (const update of updates) {
235
- const id = update.id
236
- if (groupMetadata[id]) {
237
- Object.assign(groupMetadata[id], update)
238
- }
239
- else {
240
- logger.debug({ update }, 'got update for non-existant group metadata')
241
- }
242
- }
243
- })
244
- ev.on('group-participants.update', ({ id, participants, action }) => {
245
- const metadata = groupMetadata[id]
246
- if (metadata) {
247
- switch (action) {
248
- case 'add':
249
- metadata.participants.push(...participants.map(id => ({ id, isAdmin: false, isSuperAdmin: false })))
250
- break
251
- case 'demote':
252
- case 'promote':
253
- for (const participant of metadata.participants) {
254
- if (participants.includes(participant.id)) {
255
- participant.isAdmin = action === 'promote'
256
- }
257
- }
258
- break
259
- case 'remove':
260
- metadata.participants = metadata.participants.filter(p => !participants.includes(p.id))
261
- break
262
- }
263
- }
264
- })
265
- ev.on('message-receipt.update', updates => {
266
- for (const { key, receipt } of updates) {
267
- const obj = messages[key.remoteJid]
268
- const msg = obj?.get(key.id)
269
- if (msg) {
270
- Utils_1.updateMessageWithReceipt(msg, receipt)
271
- }
272
- }
273
- })
274
- ev.on('messages.reaction', (reactions) => {
275
- for (const { key, reaction } of reactions) {
276
- const obj = messages[key.remoteJid]
277
- const msg = obj?.get(key.id)
278
- if (msg) {
279
- Utils_1.updateMessageWithReaction(msg, reaction)
280
- }
281
- }
282
- })
283
- }
284
- const toJSON = () => ({
285
- chats,
286
- contacts,
287
- messages,
288
- labels,
289
- labelAssociations
290
- })
291
- const fromJSON = (json) => {
292
- chats.upsert(...json.chats)
293
- labelAssociations.upsert(...json.labelAssociations || [])
294
- contactsUpsert(Object.values(json.contacts))
295
- labelsUpsert(Object.values(json.labels || {}))
296
- for (const jid in json.messages) {
297
- const list = assertMessageList(jid)
298
- for (const msg of json.messages[jid]) {
299
- list.upsert(WAProto_1.proto.WebMessageInfo.fromObject(msg), 'append')
300
- }
301
- }
302
- }
303
- return {
304
- chats,
305
- contacts,
306
- messages,
307
- groupMetadata,
308
- state,
309
- presences,
310
- labels,
311
- labelAssociations,
312
- bind,
313
- /** loads messages from the store, if not found -- uses the legacy connection */
314
- loadMessages: async (jid, count, cursor) => {
315
- const list = assertMessageList(jid)
316
- const mode = !cursor || 'before' in cursor ? 'before' : 'after'
317
- const cursorKey = !!cursor ? ('before' in cursor ? cursor.before : cursor.after) : undefined
318
- const cursorValue = cursorKey ? list.get(cursorKey.id) : undefined
319
- let messages
320
- if (list && mode === 'before' && (!cursorKey || cursorValue)) {
321
- if (cursorValue) {
322
- const msgIdx = list.array.findIndex(m => m.key.id === cursorKey?.id)
323
- messages = list.array.slice(0, msgIdx)
324
- }
325
- else {
326
- messages = list.array
327
- }
328
- const diff = count - messages.length
329
- if (diff < 0) {
330
- messages = messages.slice(-count) // get the last X messages
331
- }
332
- }
333
- else {
334
- messages = []
335
- }
336
- return messages
337
- },
338
- /**
339
- * Get all available labels for profile
340
- *
341
- * Keep in mind that the list is formed from predefined tags and tags
342
- * that were "caught" during their editing.
343
- */
344
- getLabels: () => {
345
- return labels
346
- },
347
- /**
348
- * Get labels for chat
349
- *
350
- * @returns Label IDs
351
- **/
352
- getChatLabels: (chatId) => {
353
- return labelAssociations.filter((la) => la.chatId === chatId).all()
354
- },
355
- /**
356
- * Get labels for message
357
- *
358
- * @returns Label IDs
359
- **/
360
- getMessageLabels: (messageId) => {
361
- const associations = labelAssociations
362
- .filter((la) => la.messageId === messageId)
363
- .all()
364
- return associations.map(({ labelId }) => labelId)
365
- },
366
- loadMessage: async (jid, id) => messages[jid]?.get(id),
367
- mostRecentMessage: async (jid) => {
368
- const message = messages[jid]?.array.slice(-1)[0]
369
- return message
370
- },
371
- fetchImageUrl: async (jid, Neele) => {
372
- const contact = contacts[jid]
373
- if (!contact) {
374
- return Neele?.profilePictureUrl(jid)
375
- }
376
- if (typeof contact.imgUrl === 'undefined') {
377
- contact.imgUrl = await Neele?.profilePictureUrl(jid)
378
- }
379
- return contact.imgUrl
380
- },
381
- fetchGroupMetadata: async (jid, Neele) => {
382
- if (!groupMetadata[jid]) {
383
- const metadata = await Neele?.groupMetadata(jid)
384
- if (metadata) {
385
- groupMetadata[jid] = metadata
386
- }
387
- }
388
- return groupMetadata[jid]
389
- },
390
- // fetchBroadcastListInfo: async(jid: string, sock: WASocket | undefined) => {
391
- // if(!groupMetadata[jid]) {
392
- // const metadata = await sock?.getBroadcastListInfo(jid)
393
- // if(metadata) {
394
- // groupMetadata[jid] = metadata
395
- // }
396
- // }
397
- // return groupMetadata[jid]
398
- // },
399
- fetchMessageReceipts: async ({ remoteJid, id }) => {
400
- const list = messages[remoteJid]
401
- const msg = list?.get(id)
402
- return msg?.userReceipt
403
- },
404
- toJSON,
405
- fromJSON,
406
- writeToFile: (path) => {
407
- // require fs here so that in case "fs" is not available -- the app does not crash
408
- const { writeFileSync } = require('fs')
409
- writeFileSync(path, JSON.stringify(toJSON()))
410
- },
411
- readFromFile: (path) => {
412
- // require fs here so that in case "fs" is not available -- the app does not crash
413
- const { readFileSync, existsSync } = require('fs')
414
- if (existsSync(path)) {
415
- logger.debug({ path }, 'reading from file')
416
- const jsonStr = readFileSync(path, { encoding: 'utf-8' })
417
- const json = JSON.parse(jsonStr)
418
- fromJSON(json)
419
- }
420
- }
421
- }
422
- }
423
-
424
- module.exports = {
425
- waChatKey,
426
- waMessageID,
427
- waLabelAssociationKey,
428
- makeInMemoryStore
429
- }
@@ -1,12 +0,0 @@
1
- export declare function makeOrderedDictionary<T>(idGetter: (item: T) => string): {
2
- array: T[]
3
- get: (id: string) => T | undefined
4
- upsert: (item: T, mode: 'append' | 'prepend') => void
5
- update: (item: T) => boolean
6
- remove: (item: T) => boolean
7
- updateAssign: (id: string, update: Partial<T>) => boolean
8
- clear: () => void
9
- filter: (contain: (item: T) => boolean) => void
10
- toJSON: () => T[]
11
- fromJSON: (newItems: T[]) => void
12
- }
@@ -1,86 +0,0 @@
1
- "use strict"
2
-
3
- Object.defineProperty(exports, "__esModule", { value: true })
4
-
5
- function makeOrderedDictionary(idGetter) {
6
- const array = []
7
- const dict = {}
8
- const get = (id) => dict[id]
9
- const update = (item) => {
10
- const id = idGetter(item)
11
- const idx = array.findIndex(i => idGetter(i) === id)
12
- if (idx >= 0) {
13
- array[idx] = item
14
- dict[id] = item
15
- }
16
- return false
17
- }
18
- const upsert = (item, mode) => {
19
- const id = idGetter(item)
20
- if (get(id)) {
21
- update(item)
22
- }
23
- else {
24
- if (mode === 'append') {
25
- array.push(item)
26
- }
27
- else {
28
- array.splice(0, 0, item)
29
- }
30
- dict[id] = item
31
- }
32
- }
33
- const remove = (item) => {
34
- const id = idGetter(item)
35
- const idx = array.findIndex(i => idGetter(i) === id)
36
- if (idx >= 0) {
37
- array.splice(idx, 1)
38
- delete dict[id]
39
- return true
40
- }
41
- return false
42
- }
43
- return {
44
- array,
45
- get,
46
- upsert,
47
- update,
48
- remove,
49
- updateAssign: (id, update) => {
50
- const item = get(id)
51
- if (item) {
52
- Object.assign(item, update)
53
- delete dict[id]
54
- dict[idGetter(item)] = item
55
- return true
56
- }
57
- return false
58
- },
59
- clear: () => {
60
- array.splice(0, array.length)
61
- for (const key of Object.keys(dict)) {
62
- delete dict[key]
63
- }
64
- },
65
- filter: (contain) => {
66
- let i = 0
67
- while (i < array.length) {
68
- if (!contain(array[i])) {
69
- delete dict[idGetter(array[i])]
70
- array.splice(i, 1)
71
- }
72
- else {
73
- i += 1
74
- }
75
- }
76
- },
77
- toJSON: () => array,
78
- fromJSON: (newItems) => {
79
- array.splice(0, array.length, ...newItems)
80
- }
81
- }
82
- }
83
-
84
- module.exports = {
85
- makeOrderedDictionary
86
- }
@@ -1,10 +0,0 @@
1
- export declare class ObjectRepository<T extends object> {
2
- readonly entityMap: Map<string, T>
3
- constructor(entities?: Record<string, T>)
4
- findById(id: string): T | undefined
5
- findAll(): T[]
6
- upsertById(id: string, entity: T): Map<string, T>
7
- deleteById(id: string): boolean
8
- count(): number
9
- toJSON(): T[]
10
- }
@@ -1,31 +0,0 @@
1
- "use strict"
2
-
3
- Object.defineProperty(exports, "__esModule", { value: true })
4
-
5
- class ObjectRepository {
6
- constructor(entities = {}) {
7
- this.entityMap = new Map(Object.entries(entities))
8
- }
9
- findById(id) {
10
- return this.entityMap.get(id)
11
- }
12
- findAll() {
13
- return Array.from(this.entityMap.values())
14
- }
15
- upsertById(id, entity) {
16
- return this.entityMap.set(id, { ...entity })
17
- }
18
- deleteById(id) {
19
- return this.entityMap.delete(id)
20
- }
21
- count() {
22
- return this.entityMap.size
23
- }
24
- toJSON() {
25
- return this.findAll()
26
- }
27
- }
28
-
29
- module.exports = {
30
- ObjectRepository
31
- }
@@ -1,9 +0,0 @@
1
- export declare const enum MexUpdatesOperations {
2
- OWNER_COMMUNITY = "NotificationCommunityOwnerUpdate",
3
- GROUP_LIMIT_SHARING = "NotificationGroupLimitSharingPropertyUpdate"
4
- }
5
-
6
- export declare const enum XWAPathsUpdates {
7
- GROUP_SHARING_CHANGE = "xwa2_notify_group_on_prop_change",
8
- COMMUNITY_OWNER_CHANGE = "xwa2_notify_group_on_participants_roles_change"
9
- }
@@ -1,18 +0,0 @@
1
- "use strict"
2
-
3
- Object.defineProperty(exports, "__esModule", { value: true })
4
-
5
- const MexUpdatesOperations = {
6
- OWNER_COMMUNITY: "NotificationCommunityOwnerUpdate",
7
- GROUP_LIMIT_SHARING: "NotificationGroupLimitSharingPropertyUpdate"
8
- }
9
-
10
- const XWAPathsMexUpdates = {
11
- GROUP_SHARING_CHANGE: "xwa2_notify_group_on_prop_change",
12
- COMMUNITY_OWNER_CHANGE: "xwa2_notify_group_on_participants_roles_change"
13
- }
14
-
15
- module.exports = {
16
- MexUpdatesOperations,
17
- XWAPathsMexUpdates
18
- }
@@ -1,6 +0,0 @@
1
- import { AuthenticationState } from '../Types'
2
-
3
- export declare const useMongoFileAuthState: (collection: string) => Promise<{
4
- state: AuthenticationState
5
- saveCreds: () => Promise<void>
6
- }>
@@ -1,84 +0,0 @@
1
- "use strict"
2
-
3
- Object.defineProperty(exports, "__esModule", { value: true })
4
-
5
- const WAProto_1 = require("../../WAProto")
6
- const auth_utils_1 = require("./auth-utils")
7
- const generics_1 = require("./generics")
8
-
9
- /*
10
- code from amiruldev readjusted by @irull2nd, don't delete WM!
11
- */
12
- const useMongoFileAuthState = async (collection) => {
13
- const writeData = (data,id) => {
14
- const informationToStore = JSON.parse(
15
- JSON.stringify(data, generics_1.BufferJSON.replacer)
16
- )
17
- const update = {
18
- $set: {
19
- ...informationToStore,
20
- },
21
- }
22
-
23
- return collection.updateOne({_id: id},update, {upsert: true})
24
- }
25
-
26
- const readData = async (id) => {
27
- try {
28
- const data = JSON.stringify(await collection.findOne({_id: id}))
29
- return JSON.parse(data, generics_1.BufferJSON.reviver)
30
- } catch (err) {
31
- console.log(err)
32
- }
33
- }
34
-
35
- const removeData = async (id) => {
36
- try{
37
- await collection.deleteOne({_id: id})
38
- }catch(err){
39
- console.log('error',err)
40
- }
41
- }
42
-
43
- const creds = (await readData('creds')) || auth_utils_1.initAuthCreds()
44
-
45
- return{
46
- state:{
47
- creds,
48
- keys: {
49
- get: async (type,ids)=> {
50
- const data = {}
51
- await Promise
52
- .all(
53
- ids.map(async (id) => {
54
- let value = await readData(`${type}-${id}`)
55
- if(type === "app-state-sync-key"){
56
- value = WAProto_1.proto.Message.AppStateSyncKeyData.fromObject(data)
57
- }
58
- data[id] = value
59
- })
60
- )
61
- return data
62
- },
63
- set: async (data) => {
64
- const tasks = []
65
- for (const category of Object.keys(data)){
66
- for (const id of Object.keys(data[category])){
67
- const value = data[category][id]
68
- const key = `${category}-${id}`
69
- tasks.push(value? writeData(value,key) : removeData(key))
70
- }
71
- }
72
- await Promise.all(tasks)
73
- },
74
- },
75
- },
76
- saveCreds: () => {
77
- return writeData(creds, "creds")
78
- }
79
- }
80
- }
81
-
82
- module.exports = {
83
- useMongoFileAuthState
84
- }