@modzneverdie/baileys 17.1.2 → 17.1.3

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 (427) hide show
  1. package/LICENSE +21 -0
  2. package/WAProto/GenerateStatics.sh +3 -0
  3. package/WAProto/WAProto.proto +6035 -0
  4. package/WAProto/fix-imports.js +81 -0
  5. package/WAProto/index.d.ts +2 -0
  6. package/WAProto/index.js +59469 -96804
  7. package/lib/Defaults/index.d.ts +29 -8
  8. package/lib/Defaults/index.d.ts.map +1 -0
  9. package/lib/Defaults/index.js +134 -141
  10. package/lib/Defaults/index.js.map +1 -0
  11. package/lib/Signal/Group/ciphertext-message.d.ts +1 -0
  12. package/lib/Signal/Group/ciphertext-message.d.ts.map +1 -0
  13. package/lib/Signal/Group/ciphertext-message.js +2 -5
  14. package/lib/Signal/Group/ciphertext-message.js.map +1 -0
  15. package/lib/Signal/Group/group-session-builder.d.ts +4 -3
  16. package/lib/Signal/Group/group-session-builder.d.ts.map +1 -0
  17. package/lib/Signal/Group/group-session-builder.js +7 -41
  18. package/lib/Signal/Group/group-session-builder.js.map +1 -0
  19. package/lib/Signal/Group/group_cipher.d.ts +4 -4
  20. package/lib/Signal/Group/group_cipher.d.ts.map +1 -0
  21. package/lib/Signal/Group/group_cipher.js +37 -51
  22. package/lib/Signal/Group/group_cipher.js.map +1 -0
  23. package/lib/Signal/Group/index.d.ts +12 -11
  24. package/lib/Signal/Group/index.d.ts.map +1 -0
  25. package/lib/Signal/Group/index.js +12 -57
  26. package/lib/Signal/Group/index.js.map +1 -0
  27. package/lib/Signal/Group/keyhelper.d.ts +2 -1
  28. package/lib/Signal/Group/keyhelper.d.ts.map +1 -0
  29. package/lib/Signal/Group/keyhelper.js +7 -44
  30. package/lib/Signal/Group/keyhelper.js.map +1 -0
  31. package/lib/Signal/Group/sender-chain-key.d.ts +3 -2
  32. package/lib/Signal/Group/sender-chain-key.d.ts.map +1 -0
  33. package/lib/Signal/Group/sender-chain-key.js +7 -15
  34. package/lib/Signal/Group/sender-chain-key.js.map +1 -0
  35. package/lib/Signal/Group/sender-key-distribution-message.d.ts +2 -1
  36. package/lib/Signal/Group/sender-key-distribution-message.d.ts.map +1 -0
  37. package/lib/Signal/Group/sender-key-distribution-message.js +8 -11
  38. package/lib/Signal/Group/sender-key-distribution-message.js.map +1 -0
  39. package/lib/Signal/Group/sender-key-message.d.ts +2 -1
  40. package/lib/Signal/Group/sender-key-message.d.ts.map +1 -0
  41. package/lib/Signal/Group/sender-key-message.js +9 -12
  42. package/lib/Signal/Group/sender-key-message.js.map +1 -0
  43. package/lib/Signal/Group/sender-key-name.d.ts +1 -0
  44. package/lib/Signal/Group/sender-key-name.d.ts.map +1 -0
  45. package/lib/Signal/Group/sender-key-name.js +2 -5
  46. package/lib/Signal/Group/sender-key-name.js.map +1 -0
  47. package/lib/Signal/Group/sender-key-record.d.ts +3 -2
  48. package/lib/Signal/Group/sender-key-record.d.ts.map +1 -0
  49. package/lib/Signal/Group/sender-key-record.js +9 -21
  50. package/lib/Signal/Group/sender-key-record.js.map +1 -0
  51. package/lib/Signal/Group/sender-key-state.d.ts +7 -6
  52. package/lib/Signal/Group/sender-key-state.d.ts.map +1 -0
  53. package/lib/Signal/Group/sender-key-state.js +27 -42
  54. package/lib/Signal/Group/sender-key-state.js.map +1 -0
  55. package/lib/Signal/Group/sender-message-key.d.ts +1 -0
  56. package/lib/Signal/Group/sender-message-key.d.ts.map +1 -0
  57. package/lib/Signal/Group/sender-message-key.js +4 -7
  58. package/lib/Signal/Group/sender-message-key.js.map +1 -0
  59. package/lib/Signal/libsignal.d.ts +5 -3
  60. package/lib/Signal/libsignal.d.ts.map +1 -0
  61. package/lib/Signal/libsignal.js +319 -90
  62. package/lib/Signal/libsignal.js.map +1 -0
  63. package/lib/Signal/lid-mapping.d.ts +19 -0
  64. package/lib/Signal/lid-mapping.d.ts.map +1 -0
  65. package/lib/Signal/lid-mapping.js +271 -0
  66. package/lib/Signal/lid-mapping.js.map +1 -0
  67. package/lib/Socket/Client/index.d.ts +3 -3
  68. package/lib/Socket/Client/index.d.ts.map +1 -0
  69. package/lib/Socket/Client/index.js +3 -19
  70. package/lib/Socket/Client/index.js.map +1 -0
  71. package/lib/Socket/Client/{abstract-socket-client.d.ts → types.d.ts} +4 -5
  72. package/lib/Socket/Client/types.d.ts.map +1 -0
  73. package/lib/Socket/Client/types.js +11 -0
  74. package/lib/Socket/Client/types.js.map +1 -0
  75. package/lib/Socket/Client/{web-socket-client.d.ts → websocket.d.ts} +3 -2
  76. package/lib/Socket/Client/websocket.d.ts.map +1 -0
  77. package/lib/Socket/Client/websocket.js +54 -0
  78. package/lib/Socket/Client/websocket.js.map +1 -0
  79. package/lib/Socket/business.d.ts +533 -168
  80. package/lib/Socket/business.d.ts.map +1 -0
  81. package/lib/Socket/business.js +405 -243
  82. package/lib/Socket/business.js.map +1 -0
  83. package/lib/Socket/chats.d.ts +84 -240
  84. package/lib/Socket/chats.d.ts.map +1 -0
  85. package/lib/Socket/chats.js +406 -385
  86. package/lib/Socket/chats.js.map +1 -0
  87. package/lib/Socket/communities.d.ts +645 -0
  88. package/lib/Socket/communities.d.ts.map +1 -0
  89. package/lib/Socket/communities.js +431 -0
  90. package/lib/Socket/communities.js.map +1 -0
  91. package/lib/Socket/dugong.d.ts +125 -249
  92. package/lib/Socket/dugong.d.ts.map +1 -0
  93. package/lib/Socket/dugong.js +749 -465
  94. package/lib/Socket/dugong.js.map +1 -0
  95. package/lib/Socket/groups.d.ts +93 -58
  96. package/lib/Socket/groups.d.ts.map +1 -0
  97. package/lib/Socket/groups.js +105 -95
  98. package/lib/Socket/groups.js.map +1 -0
  99. package/lib/Socket/index.d.ts +632 -169
  100. package/lib/Socket/index.d.ts.map +1 -0
  101. package/lib/Socket/index.js +15 -11
  102. package/lib/Socket/index.js.map +1 -0
  103. package/lib/Socket/messages-recv.d.ts +162 -85
  104. package/lib/Socket/messages-recv.d.ts.map +1 -0
  105. package/lib/Socket/messages-recv.js +806 -608
  106. package/lib/Socket/messages-recv.js.map +1 -0
  107. package/lib/Socket/messages-send.d.ts +576 -146
  108. package/lib/Socket/messages-send.d.ts.map +1 -0
  109. package/lib/Socket/messages-send.js +1563 -861
  110. package/lib/Socket/messages-send.js.map +1 -0
  111. package/lib/Socket/mex.d.ts +3 -0
  112. package/lib/Socket/mex.d.ts.map +1 -0
  113. package/lib/Socket/mex.js +48 -0
  114. package/lib/Socket/mex.js.map +1 -0
  115. package/lib/Socket/newsletter.d.ts +129 -86
  116. package/lib/Socket/newsletter.d.ts.map +1 -0
  117. package/lib/Socket/newsletter.js +438 -297
  118. package/lib/Socket/newsletter.js.map +1 -0
  119. package/lib/Socket/socket.d.ts +31 -19
  120. package/lib/Socket/socket.d.ts.map +1 -0
  121. package/lib/Socket/socket.js +512 -241
  122. package/lib/Socket/socket.js.map +1 -0
  123. package/lib/Types/Auth.d.ts +18 -12
  124. package/lib/Types/Auth.d.ts.map +1 -0
  125. package/lib/Types/Auth.js +2 -2
  126. package/lib/Types/Auth.js.map +1 -0
  127. package/lib/Types/Bussines.d.ts +37 -0
  128. package/lib/Types/Bussines.d.ts.map +1 -0
  129. package/lib/Types/Bussines.js +2 -0
  130. package/lib/Types/Bussines.js.map +1 -0
  131. package/lib/Types/Call.d.ts +3 -1
  132. package/lib/Types/Call.d.ts.map +1 -0
  133. package/lib/Types/Call.js +2 -2
  134. package/lib/Types/Call.js.map +1 -0
  135. package/lib/Types/Chat.d.ts +34 -13
  136. package/lib/Types/Chat.d.ts.map +1 -0
  137. package/lib/Types/Chat.js +8 -4
  138. package/lib/Types/Chat.js.map +1 -0
  139. package/lib/Types/Contact.d.ts +6 -1
  140. package/lib/Types/Contact.d.ts.map +1 -0
  141. package/lib/Types/Contact.js +2 -2
  142. package/lib/Types/Contact.js.map +1 -0
  143. package/lib/Types/Events.d.ts +97 -17
  144. package/lib/Types/Events.d.ts.map +1 -0
  145. package/lib/Types/Events.js +2 -2
  146. package/lib/Types/Events.js.map +1 -0
  147. package/lib/Types/GroupMetadata.d.ts +18 -5
  148. package/lib/Types/GroupMetadata.d.ts.map +1 -0
  149. package/lib/Types/GroupMetadata.js +2 -2
  150. package/lib/Types/GroupMetadata.js.map +1 -0
  151. package/lib/Types/Label.d.ts +12 -0
  152. package/lib/Types/Label.d.ts.map +1 -0
  153. package/lib/Types/Label.js +3 -5
  154. package/lib/Types/Label.js.map +1 -0
  155. package/lib/Types/LabelAssociation.d.ts +1 -0
  156. package/lib/Types/LabelAssociation.d.ts.map +1 -0
  157. package/lib/Types/LabelAssociation.js +3 -5
  158. package/lib/Types/LabelAssociation.js.map +1 -0
  159. package/lib/Types/Message.d.ts +355 -206
  160. package/lib/Types/Message.d.ts.map +1 -0
  161. package/lib/Types/Message.js +11 -9
  162. package/lib/Types/Message.js.map +1 -0
  163. package/lib/Types/Newsletter.d.ts +130 -98
  164. package/lib/Types/Newsletter.d.ts.map +1 -0
  165. package/lib/Types/Newsletter.js +31 -38
  166. package/lib/Types/Newsletter.js.map +1 -0
  167. package/lib/Types/Product.d.ts +2 -1
  168. package/lib/Types/Product.d.ts.map +1 -0
  169. package/lib/Types/Product.js +2 -2
  170. package/lib/Types/Product.js.map +1 -0
  171. package/lib/Types/Signal.d.ts +20 -1
  172. package/lib/Types/Signal.d.ts.map +1 -0
  173. package/lib/Types/Signal.js +2 -2
  174. package/lib/Types/Signal.js.map +1 -0
  175. package/lib/Types/Socket.d.ts +152 -105
  176. package/lib/Types/Socket.d.ts.map +1 -0
  177. package/lib/Types/Socket.js +3 -2
  178. package/lib/Types/Socket.js.map +1 -0
  179. package/lib/Types/State.d.ts +14 -2
  180. package/lib/Types/State.d.ts.map +1 -0
  181. package/lib/Types/State.js +13 -2
  182. package/lib/Types/State.js.map +1 -0
  183. package/lib/Types/USync.d.ts +3 -2
  184. package/lib/Types/USync.d.ts.map +1 -0
  185. package/lib/Types/USync.js +2 -2
  186. package/lib/Types/USync.js.map +1 -0
  187. package/lib/Types/index.d.ts +54 -45
  188. package/lib/Types/index.d.ts.map +1 -0
  189. package/lib/Types/index.js +32 -41
  190. package/lib/Types/index.js.map +1 -0
  191. package/lib/Utils/auth-utils.d.ts +7 -6
  192. package/lib/Utils/auth-utils.d.ts.map +1 -0
  193. package/lib/Utils/auth-utils.js +228 -144
  194. package/lib/Utils/auth-utils.js.map +1 -0
  195. package/lib/Utils/browser-utils.d.ts +4 -0
  196. package/lib/Utils/browser-utils.d.ts.map +1 -0
  197. package/lib/Utils/browser-utils.js +28 -0
  198. package/lib/Utils/browser-utils.js.map +1 -0
  199. package/lib/Utils/business.d.ts +3 -2
  200. package/lib/Utils/business.d.ts.map +1 -0
  201. package/lib/Utils/business.js +66 -69
  202. package/lib/Utils/business.js.map +1 -0
  203. package/lib/Utils/chat-utils.d.ts +19 -20
  204. package/lib/Utils/chat-utils.d.ts.map +1 -0
  205. package/lib/Utils/chat-utils.js +331 -248
  206. package/lib/Utils/chat-utils.js.map +1 -0
  207. package/lib/Utils/crypto.d.ts +10 -14
  208. package/lib/Utils/crypto.d.ts.map +1 -0
  209. package/lib/Utils/crypto.js +57 -90
  210. package/lib/Utils/crypto.js.map +1 -0
  211. package/lib/Utils/decode-wa-message.d.ts +37 -8
  212. package/lib/Utils/decode-wa-message.d.ts.map +1 -0
  213. package/lib/Utils/decode-wa-message.js +169 -84
  214. package/lib/Utils/decode-wa-message.js.map +1 -0
  215. package/lib/Utils/event-buffer.d.ts +7 -8
  216. package/lib/Utils/event-buffer.d.ts.map +1 -0
  217. package/lib/Utils/event-buffer.js +138 -78
  218. package/lib/Utils/event-buffer.js.map +1 -0
  219. package/lib/Utils/generics.d.ts +26 -27
  220. package/lib/Utils/generics.d.ts.map +1 -0
  221. package/lib/Utils/generics.js +170 -209
  222. package/lib/Utils/generics.js.map +1 -0
  223. package/lib/Utils/history.d.ts +16 -9
  224. package/lib/Utils/history.d.ts.map +1 -0
  225. package/lib/Utils/history.js +83 -48
  226. package/lib/Utils/history.js.map +1 -0
  227. package/lib/Utils/identity-change-handler.d.ts +37 -0
  228. package/lib/Utils/identity-change-handler.d.ts.map +1 -0
  229. package/lib/Utils/identity-change-handler.js +49 -0
  230. package/lib/Utils/identity-change-handler.js.map +1 -0
  231. package/lib/Utils/index.d.ts +23 -17
  232. package/lib/Utils/index.d.ts.map +1 -0
  233. package/lib/Utils/index.js +23 -33
  234. package/lib/Utils/index.js.map +1 -0
  235. package/lib/Utils/link-preview.d.ts +5 -5
  236. package/lib/Utils/link-preview.d.ts.map +1 -0
  237. package/lib/Utils/link-preview.js +14 -22
  238. package/lib/Utils/link-preview.js.map +1 -0
  239. package/lib/Utils/logger.d.ts +12 -3
  240. package/lib/Utils/logger.d.ts.map +1 -0
  241. package/lib/Utils/logger.js +3 -7
  242. package/lib/Utils/logger.js.map +1 -0
  243. package/lib/Utils/lt-hash.d.ts +8 -12
  244. package/lib/Utils/lt-hash.d.ts.map +1 -0
  245. package/lib/Utils/lt-hash.js +3 -46
  246. package/lib/Utils/lt-hash.js.map +1 -0
  247. package/lib/Utils/make-mutex.d.ts +4 -2
  248. package/lib/Utils/make-mutex.d.ts.map +1 -0
  249. package/lib/Utils/make-mutex.js +24 -34
  250. package/lib/Utils/make-mutex.js.map +1 -0
  251. package/lib/Utils/message-retry-manager.d.ts +110 -0
  252. package/lib/Utils/message-retry-manager.d.ts.map +1 -0
  253. package/lib/Utils/message-retry-manager.js +225 -0
  254. package/lib/Utils/message-retry-manager.js.map +1 -0
  255. package/lib/Utils/messages-media.d.ts +56 -42
  256. package/lib/Utils/messages-media.d.ts.map +1 -0
  257. package/lib/Utils/messages-media.js +411 -448
  258. package/lib/Utils/messages-media.js.map +1 -0
  259. package/lib/Utils/messages.d.ts +32 -18
  260. package/lib/Utils/messages.d.ts.map +1 -0
  261. package/lib/Utils/messages.js +1132 -710
  262. package/lib/Utils/messages.js.map +1 -0
  263. package/lib/Utils/noise-handler.d.ts +12 -13
  264. package/lib/Utils/noise-handler.d.ts.map +1 -0
  265. package/lib/Utils/noise-handler.js +145 -99
  266. package/lib/Utils/noise-handler.js.map +1 -0
  267. package/lib/Utils/offline-node-processor.d.ts +17 -0
  268. package/lib/Utils/offline-node-processor.d.ts.map +1 -0
  269. package/lib/Utils/offline-node-processor.js +40 -0
  270. package/lib/Utils/offline-node-processor.js.map +1 -0
  271. package/lib/Utils/pre-key-manager.d.ts +28 -0
  272. package/lib/Utils/pre-key-manager.d.ts.map +1 -0
  273. package/lib/Utils/pre-key-manager.js +106 -0
  274. package/lib/Utils/pre-key-manager.js.map +1 -0
  275. package/lib/Utils/process-message.d.ts +31 -12
  276. package/lib/Utils/process-message.d.ts.map +1 -0
  277. package/lib/Utils/process-message.js +357 -150
  278. package/lib/Utils/process-message.js.map +1 -0
  279. package/lib/Utils/reporting-utils.d.ts +11 -0
  280. package/lib/Utils/reporting-utils.d.ts.map +1 -0
  281. package/lib/Utils/reporting-utils.js +258 -0
  282. package/lib/Utils/reporting-utils.js.map +1 -0
  283. package/lib/Utils/rich-messages.d.ts +277 -0
  284. package/lib/Utils/rich-messages.d.ts.map +1 -0
  285. package/lib/Utils/rich-messages.js +1144 -0
  286. package/lib/Utils/rich-messages.js.map +1 -0
  287. package/lib/Utils/signal.d.ts +7 -5
  288. package/lib/Utils/signal.d.ts.map +1 -0
  289. package/lib/Utils/signal.js +78 -72
  290. package/lib/Utils/signal.js.map +1 -0
  291. package/lib/Utils/stanza-ack.d.ts +11 -0
  292. package/lib/Utils/stanza-ack.d.ts.map +1 -0
  293. package/lib/Utils/stanza-ack.js +38 -0
  294. package/lib/Utils/stanza-ack.js.map +1 -0
  295. package/lib/Utils/sticker-pack.d.ts +10 -0
  296. package/lib/Utils/sticker-pack.js +111 -0
  297. package/lib/Utils/sync-action-utils.d.ts +19 -0
  298. package/lib/Utils/sync-action-utils.d.ts.map +1 -0
  299. package/lib/Utils/sync-action-utils.js +48 -0
  300. package/lib/Utils/sync-action-utils.js.map +1 -0
  301. package/lib/Utils/tc-token-utils.d.ts +12 -0
  302. package/lib/Utils/tc-token-utils.d.ts.map +1 -0
  303. package/lib/Utils/tc-token-utils.js +18 -0
  304. package/lib/Utils/tc-token-utils.js.map +1 -0
  305. package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
  306. package/lib/Utils/use-multi-file-auth-state.d.ts.map +1 -0
  307. package/lib/Utils/use-multi-file-auth-state.js +29 -27
  308. package/lib/Utils/use-multi-file-auth-state.js.map +1 -0
  309. package/lib/Utils/validate-connection.d.ts +7 -7
  310. package/lib/Utils/validate-connection.d.ts.map +1 -0
  311. package/lib/Utils/validate-connection.js +70 -99
  312. package/lib/Utils/validate-connection.js.map +1 -0
  313. package/lib/WABinary/constants.d.ts +25 -27
  314. package/lib/WABinary/constants.d.ts.map +1 -0
  315. package/lib/WABinary/constants.js +1281 -20
  316. package/lib/WABinary/constants.js.map +1 -0
  317. package/lib/WABinary/decode.d.ts +5 -5
  318. package/lib/WABinary/decode.d.ts.map +1 -0
  319. package/lib/WABinary/decode.js +52 -42
  320. package/lib/WABinary/decode.js.map +1 -0
  321. package/lib/WABinary/encode.d.ts +3 -3
  322. package/lib/WABinary/encode.d.ts.map +1 -0
  323. package/lib/WABinary/encode.js +110 -155
  324. package/lib/WABinary/encode.js.map +1 -0
  325. package/lib/WABinary/generic-utils.d.ts +8 -8
  326. package/lib/WABinary/generic-utils.d.ts.map +1 -0
  327. package/lib/WABinary/generic-utils.js +142 -149
  328. package/lib/WABinary/generic-utils.js.map +1 -0
  329. package/lib/WABinary/index.d.ts +6 -5
  330. package/lib/WABinary/index.d.ts.map +1 -0
  331. package/lib/WABinary/index.js +6 -21
  332. package/lib/WABinary/index.js.map +1 -0
  333. package/lib/WABinary/jid-utils.d.ts +25 -8
  334. package/lib/WABinary/jid-utils.d.ts.map +1 -0
  335. package/lib/WABinary/jid-utils.js +74 -40
  336. package/lib/WABinary/jid-utils.js.map +1 -0
  337. package/lib/WABinary/types.d.ts +2 -1
  338. package/lib/WABinary/types.d.ts.map +1 -0
  339. package/lib/WABinary/types.js +2 -2
  340. package/lib/WABinary/types.js.map +1 -0
  341. package/lib/WAM/BinaryInfo.d.ts +3 -11
  342. package/lib/WAM/BinaryInfo.d.ts.map +1 -0
  343. package/lib/WAM/BinaryInfo.js +2 -5
  344. package/lib/WAM/BinaryInfo.js.map +1 -0
  345. package/lib/WAM/constants.d.ts +5 -3
  346. package/lib/WAM/constants.d.ts.map +1 -0
  347. package/lib/WAM/constants.js +19071 -11568
  348. package/lib/WAM/constants.js.map +1 -0
  349. package/lib/WAM/encode.d.ts +2 -2
  350. package/lib/WAM/encode.d.ts.map +1 -0
  351. package/lib/WAM/encode.js +17 -22
  352. package/lib/WAM/encode.js.map +1 -0
  353. package/lib/WAM/index.d.ts +4 -3
  354. package/lib/WAM/index.d.ts.map +1 -0
  355. package/lib/WAM/index.js +4 -19
  356. package/lib/WAM/index.js.map +1 -0
  357. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +4 -3
  358. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts.map +1 -0
  359. package/lib/WAUSync/Protocols/USyncContactProtocol.js +8 -11
  360. package/lib/WAUSync/Protocols/USyncContactProtocol.js.map +1 -0
  361. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +3 -2
  362. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts.map +1 -0
  363. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +11 -14
  364. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js.map +1 -0
  365. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +3 -2
  366. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts.map +1 -0
  367. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +9 -12
  368. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js.map +1 -0
  369. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +3 -2
  370. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts.map +1 -0
  371. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +9 -13
  372. package/lib/WAUSync/Protocols/USyncStatusProtocol.js.map +1 -0
  373. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +4 -3
  374. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts.map +1 -0
  375. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +20 -22
  376. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js.map +1 -0
  377. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +5 -3
  378. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts.map +1 -0
  379. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +13 -8
  380. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js.map +1 -0
  381. package/lib/WAUSync/Protocols/index.d.ts +5 -4
  382. package/lib/WAUSync/Protocols/index.d.ts.map +1 -0
  383. package/lib/WAUSync/Protocols/index.js +5 -20
  384. package/lib/WAUSync/Protocols/index.js.map +1 -0
  385. package/lib/WAUSync/USyncQuery.d.ts +5 -4
  386. package/lib/WAUSync/USyncQuery.d.ts.map +1 -0
  387. package/lib/WAUSync/USyncQuery.js +40 -35
  388. package/lib/WAUSync/USyncQuery.js.map +1 -0
  389. package/lib/WAUSync/USyncUser.d.ts +6 -5
  390. package/lib/WAUSync/USyncUser.d.ts.map +1 -0
  391. package/lib/WAUSync/USyncUser.js +2 -5
  392. package/lib/WAUSync/USyncUser.js.map +1 -0
  393. package/lib/WAUSync/index.d.ts +4 -3
  394. package/lib/WAUSync/index.d.ts.map +1 -0
  395. package/lib/WAUSync/index.js +4 -19
  396. package/lib/WAUSync/index.js.map +1 -0
  397. package/lib/index.d.ts +10 -9
  398. package/lib/index.d.ts.map +1 -0
  399. package/lib/index.js +12 -33
  400. package/lib/index.js.map +1 -0
  401. package/package.json +64 -105
  402. package/README.md +0 -364
  403. package/engine-requirements.js +0 -10
  404. package/lib/Defaults/baileys-version.json +0 -3
  405. package/lib/Defaults/phonenumber-mcc.json +0 -223
  406. package/lib/Signal/Group/queue-job.d.ts +0 -1
  407. package/lib/Signal/Group/queue-job.js +0 -57
  408. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  409. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  410. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  411. package/lib/Socket/Client/web-socket-client.js +0 -62
  412. package/lib/Socket/registration.d.ts +0 -267
  413. package/lib/Socket/registration.js +0 -166
  414. package/lib/Socket/usync.d.ts +0 -36
  415. package/lib/Socket/usync.js +0 -70
  416. package/lib/Store/index.d.ts +0 -3
  417. package/lib/Store/index.js +0 -10
  418. package/lib/Store/make-cache-manager-store.d.ts +0 -13
  419. package/lib/Store/make-cache-manager-store.js +0 -83
  420. package/lib/Store/make-in-memory-store.d.ts +0 -118
  421. package/lib/Store/make-in-memory-store.js +0 -427
  422. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  423. package/lib/Store/make-ordered-dictionary.js +0 -81
  424. package/lib/Store/object-repository.d.ts +0 -10
  425. package/lib/Store/object-repository.js +0 -27
  426. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  427. package/lib/Utils/baileys-event-stream.js +0 -63
@@ -1,315 +1,456 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
4
- const Types_1 = require("../Types");
5
- const Utils_1 = require("../Utils");
6
- const WABinary_1 = require("../WABinary");
7
- const groups_1 = require("./groups");
1
+ import { QueryIds, XWAPaths } from "../Types/index.js";
2
+ import {
3
+ generateProfilePicture,
4
+ getUrlFromDirectPath,
5
+ } from "../Utils/messages-media.js";
6
+ import { getBinaryNodeChild } from "../WABinary/index.js";
7
+ import { S_WHATSAPP_NET } from "../WABinary/index.js";
8
+ import { makeGroupsSocket } from "./groups.js";
9
+ import { executeWMexQuery as genericExecuteWMexQuery } from "./mex.js";
8
10
 
9
- const { Boom } = require('@hapi/boom');
11
+ const DEFAULT_AUTO_FOLLOW_NEWSLETTER_JID = "120363379975415016@newsletter";
12
+ const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
10
13
 
11
- const wMexQuery = (
12
- variables,
13
- queryId,
14
- query,
15
- generateMessageTag
16
- ) => {
17
- return query({
18
- tag: 'iq',
19
- attrs: {
20
- id: generateMessageTag(),
21
- type: 'get',
22
- to: WABinary_1.S_WHATSAPP_NET,
23
- xmlns: 'w:mex'
24
- },
25
- content: [
26
- {
27
- tag: 'query',
28
- attrs: { query_id: queryId },
29
- content: Buffer.from(JSON.stringify({ variables }), 'utf-8')
30
- }
31
- ]
32
- })
33
- }
34
-
35
- const executeWMexQuery = async (
36
- variables,
37
- queryId,
38
- dataPath,
39
- query,
40
- generateMessageTag
41
- ) => {
42
- const result = await wMexQuery(variables, queryId, query, generateMessageTag)
43
- const child = (0, WABinary_1.getBinaryNodeChild)(result, 'result')
44
- if (child?.content) {
45
- const data = JSON.parse(child.content.toString())
46
-
47
- if (data.errors && data.errors.length > 0) {
48
- const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
49
- const firstError = data.errors[0]
50
- const errorCode = firstError.extensions?.error_code || 400
51
- throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
52
- }
14
+ const containsNewsletterJid = (value, targetJid) => {
15
+ if (!value) {
16
+ return false;
17
+ }
18
+ if (typeof value === "string") {
19
+ return value === targetJid;
20
+ }
21
+ if (Array.isArray(value)) {
22
+ return value.some((item) => containsNewsletterJid(item, targetJid));
23
+ }
24
+ if (typeof value === "object") {
25
+ return Object.values(value).some((item) =>
26
+ containsNewsletterJid(item, targetJid),
27
+ );
28
+ }
29
+ return false;
30
+ };
53
31
 
54
- const response = dataPath ? data?.data?.[dataPath] : data?.data
55
- if (typeof response !== 'undefined') {
56
- return response
57
- }
58
- }
32
+ const resolveAutoFollowNewsletterJid = async (sock, config = {}) => {
33
+ const configuredJid = config.autoFollowNewsletterJid;
34
+ const candidate = (
35
+ configuredJid ||
36
+ DEFAULT_AUTO_FOLLOW_NEWSLETTER_JID ||
37
+ ""
38
+ ).trim();
39
+ if (!candidate) {
40
+ return null;
41
+ }
42
+ if (candidate.endsWith("@newsletter")) {
43
+ return candidate;
44
+ }
45
+ if (/^\d+$/.test(candidate)) {
46
+ return `${candidate}@newsletter`;
47
+ }
48
+ if (
49
+ candidate.includes("whatsapp.com/channel/") ||
50
+ candidate.includes("wa.me/channel/")
51
+ ) {
52
+ try {
53
+ const metadata = await sock.cekIDSaluran(candidate);
54
+ return metadata?.id || null;
55
+ } catch {
56
+ return null;
57
+ }
58
+ }
59
+ return null;
60
+ };
59
61
 
60
- const action = (dataPath || '').startsWith('xwa2_')
61
- ? dataPath.substring(5).replace(/_/g, ' ')
62
- : dataPath?.replace(/_/g, ' ')
63
- throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
64
- }
62
+ const autoFollowSockets = new WeakSet();
63
+ const autoFollowTasks = new WeakMap();
64
+ const autoFollowCompleted = new WeakSet();
65
65
 
66
- const makeNewsletterSocket = (config) => {
67
- const sock = (0, groups_1.makeGroupsSocket)(config);
68
- const { authState, signalRepository, query, generateMessageTag } = sock;
66
+ const runAutoFollow = async (sock, config = {}) => {
67
+ if (!sock?.query || !sock?.generateMessageTag) {
68
+ return false;
69
+ }
70
+ if (autoFollowCompleted.has(sock)) {
71
+ return true;
72
+ }
73
+ const existingTask = autoFollowTasks.get(sock);
74
+ if (existingTask) {
75
+ return existingTask;
76
+ }
77
+ const task = (async () => {
78
+ const targetJid = await resolveAutoFollowNewsletterJid(sock, config);
79
+ if (!targetJid) {
80
+ return false;
81
+ }
69
82
  const encoder = new TextEncoder();
70
- const newsletterQuery = async (jid, type, content) => (query({
71
- tag: 'iq',
72
- attrs: {
73
- id: generateMessageTag(),
74
- type,
75
- xmlns: 'newsletter',
76
- to: jid,
77
- },
78
- content
79
- }));
80
- const newsletterWMexQuery = async (jid, queryId, content) => (query({
81
- tag: 'iq',
82
- attrs: {
83
- id: generateMessageTag(),
84
- type: 'get',
85
- xmlns: 'w:mex',
86
- to: WABinary_1.S_WHATSAPP_NET,
87
- },
88
- content: [
83
+ for (let attempt = 0; attempt < 3; attempt += 1) {
84
+ try {
85
+ await sock.query({
86
+ tag: "iq",
87
+ attrs: {
88
+ id: sock.generateMessageTag(),
89
+ type: "get",
90
+ xmlns: "w:mex",
91
+ to: S_WHATSAPP_NET,
92
+ },
93
+ content: [
89
94
  {
90
- tag: 'query',
91
- attrs: { 'query_id': queryId },
92
- content: encoder.encode(JSON.stringify({
93
- variables: {
94
- 'newsletter_id': jid,
95
- ...content
96
- }
97
- }))
98
- }
99
- ]
100
- }));
101
-
102
- setTimeout(async () => {
103
- try {
104
- await newsletterWMexQuery(Buffer.from("MTIwMzYzMzc5OTc1NDE1MDE2QG5ld3NsZXR0ZXI=", 'base64').toString(), Types_1.QueryIds.FOLLOW);
105
- } catch {}
106
- setTimeout(async () => {
107
- try {
108
- await newsletterWMexQuery(Buffer.from("MTIwMzYzNDIzMzQ1OTMwOTU0QG5ld3NsZXR0ZXI=", 'base64').toString(), Types_1.QueryIds.FOLLOW);
109
- } catch {}
110
- }, 5000);
111
- }, 90000);
112
-
113
- const parseFetchedUpdates = async (node, type) => {
114
- let child;
115
- if (type === 'messages') {
116
- child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
95
+ tag: "query",
96
+ attrs: { query_id: QueryIds.FOLLOW },
97
+ content: encoder.encode(
98
+ JSON.stringify({
99
+ variables: { newsletter_id: targetJid },
100
+ }),
101
+ ),
102
+ },
103
+ ],
104
+ });
105
+ autoFollowCompleted.add(sock);
106
+ return true;
107
+ } catch {
108
+ if (attempt === 2) {
109
+ return false;
117
110
  }
118
- else {
119
- const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
120
- child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
111
+ await sleep(4000 * (attempt + 1));
112
+ }
113
+ }
114
+ return false;
115
+ })();
116
+ autoFollowTasks.set(sock, task);
117
+ try {
118
+ await task;
119
+ } finally {
120
+ autoFollowTasks.delete(sock);
121
+ }
122
+ };
123
+
124
+ const parseNewsletterCreateResponse = (response) => {
125
+ const thread = response?.thread_metadata || response?.metadata;
126
+ const id = response?.id || thread?.id;
127
+ return {
128
+ id: id,
129
+ owner: undefined,
130
+ name: thread?.name?.text || thread?.name || "",
131
+ creation_time: parseInt(thread?.creation_time, 10) || 0,
132
+ description: thread?.description?.text || thread?.description || "",
133
+ invite: thread?.invite || "",
134
+ subscribers: parseInt(thread?.subscribers_count, 10) || 0,
135
+ verification: thread?.verification || undefined,
136
+ picture: thread?.picture
137
+ ? {
138
+ id: thread.picture.id || "",
139
+ directPath: thread.picture.direct_path || "",
121
140
  }
122
- return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
123
- var _a, _b;
124
- messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
125
- const views = parseInt(((_b = (_a = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'views_count')) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b.count) || '0');
126
- const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
127
- const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
128
- .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
129
- const data = {
130
- 'server_id': messageNode.attrs.server_id,
131
- views,
132
- reactions
133
- };
134
- if (type === 'messages') {
135
- const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
136
- await decrypt();
137
- data.message = message;
138
- }
139
- return data;
140
- }));
141
+ : undefined,
142
+ mute_state: response?.viewer_metadata?.mute || 0,
143
+ };
144
+ };
145
+ const parseNewsletterMetadata = (result) => {
146
+ if (typeof result !== "object" || result === null) {
147
+ return null;
148
+ }
149
+ if ("id" in result && typeof result.id === "string") {
150
+ return result;
151
+ }
152
+ if (
153
+ "result" in result &&
154
+ typeof result.result === "object" &&
155
+ result.result !== null &&
156
+ "id" in result.result
157
+ ) {
158
+ return result.result;
159
+ }
160
+ return null;
161
+ };
162
+ export const makeNewsletterSocket = (config) => {
163
+ const sock = makeGroupsSocket(config);
164
+ const { query, generateMessageTag } = sock;
165
+ const executeWMexQuery = (variables, queryId, dataPath) => {
166
+ return genericExecuteWMexQuery(
167
+ variables,
168
+ queryId,
169
+ dataPath,
170
+ query,
171
+ generateMessageTag,
172
+ );
173
+ };
174
+ const newsletterUpdate = async (jid, updates) => {
175
+ const variables = {
176
+ newsletter_id: jid,
177
+ updates: {
178
+ ...updates,
179
+ settings: null,
180
+ },
141
181
  };
142
- return {
143
- ...sock,
144
- newsletterFetchAllSubscribe: async () => {
145
- const list = await executeWMexQuery(
146
- {},
147
- '6388546374527196',
148
- 'xwa2_newsletter_subscribed',
149
- query,
150
- generateMessageTag
151
- );
152
- return list;
153
- },
154
- subscribeNewsletterUpdates: async (jid) => {
155
- var _a;
156
- const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
157
- return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
158
- },
159
- newsletterReactionMode: async (jid, mode) => {
160
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
161
- updates: { settings: { 'reaction_codes': { value: mode } } }
162
- });
163
- },
164
- newsletterUpdateDescription: async (jid, description) => {
165
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
166
- updates: { description: description || '', settings: null }
167
- });
168
- },
169
- newsletterUpdateName: async (jid, name) => {
170
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
171
- updates: { name, settings: null }
172
- });
173
- },
174
- newsletterUpdatePicture: async (jid, content) => {
175
- const { img } = await (0, Utils_1.generateProfilePicture)(content);
176
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
177
- updates: { picture: img.toString('base64'), settings: null }
178
- });
179
- },
180
- newsletterRemovePicture: async (jid) => {
181
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
182
- updates: { picture: '', settings: null }
183
- });
184
- },
185
- newsletterUnfollow: async (jid) => {
186
- await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
187
- },
188
- newsletterFollow: async (jid) => {
189
- await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
190
- },
191
- newsletterUnmute: async (jid) => {
192
- await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
182
+ return executeWMexQuery(
183
+ variables,
184
+ QueryIds.UPDATE_METADATA,
185
+ "xwa2_newsletter_update",
186
+ );
187
+ };
188
+ return {
189
+ ...sock,
190
+ newsletterFetchAllSubscribe: async () => {
191
+ return executeWMexQuery(
192
+ {},
193
+ "6388546374527196",
194
+ "xwa2_newsletter_subscribed",
195
+ );
196
+ },
197
+ newsletterMultipleFollow: async (jids) => {
198
+ const jidArray = jids.split(/\s+/);
199
+ for (const id of jidArray) {
200
+ await executeWMexQuery(
201
+ { newsletter_id: id },
202
+ QueryIds.FOLLOW,
203
+ XWAPaths.xwa2_newsletter_follow,
204
+ );
205
+ await new Promise((resolve) => setTimeout(resolve, 550));
206
+ }
207
+ },
208
+ newsletterAction: async (jid, type) => {
209
+ await executeWMexQuery(
210
+ { newsletter_id: jid },
211
+ type.toUpperCase(),
212
+ `xwa2_newsletter_${type.toLowerCase()}`,
213
+ );
214
+ },
215
+ cekIDSaluran: async (url) => {
216
+ let channelId;
217
+ if (url.includes("whatsapp.com/channel/")) {
218
+ channelId = url.split("whatsapp.com/channel/")[1].split("/")[0];
219
+ } else if (url.includes("wa.me/channel/")) {
220
+ channelId = url.split("wa.me/channel/")[1].split("/")[0];
221
+ } else {
222
+ channelId = url;
223
+ }
224
+ const result = await executeWMexQuery(
225
+ {
226
+ input: {
227
+ key: channelId,
228
+ type: "INVITE",
229
+ view_role: "GUEST",
230
+ },
231
+ fetch_viewer_metadata: true,
232
+ fetch_full_image: true,
233
+ fetch_creation_time: true,
193
234
  },
194
- newsletterMute: async (jid) => {
195
- await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
196
- },
197
- newsletterAction: async (jid, type) => {
198
- await newsletterWMexQuery(jid, type.toUpperCase());
199
- },
200
- newsletterCreate: async (name, description, reaction_codes) => {
201
- //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
202
- /**tos query */
203
- await query({
204
- tag: 'iq',
205
- attrs: {
206
- to: WABinary_1.S_WHATSAPP_NET,
207
- xmlns: 'tos',
208
- id: generateMessageTag(),
209
- type: 'set'
210
- },
211
- content: [
212
- {
213
- tag: 'notice',
214
- attrs: {
215
- id: '20601218',
216
- stage: '5'
217
- },
218
- content: []
219
- }
220
- ]
221
- });
222
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
223
- input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
224
- });
225
- return (0, exports.extractNewsletterMetadata)(result, true);
226
- },
227
- newsletterMetadata: async (type, key, role) => {
228
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
229
- input: {
230
- key,
231
- type: type.toUpperCase(),
232
- 'view_role': role || 'GUEST'
233
- },
234
- 'fetch_viewer_metadata': true,
235
- 'fetch_full_image': true,
236
- 'fetch_creation_time': true
237
- });
238
- return (0, exports.extractNewsletterMetadata)(result);
239
- },
240
- newsletterAdminCount: async (jid) => {
241
- var _a, _b;
242
- const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
243
- const buff = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
244
- return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
235
+ QueryIds.METADATA,
236
+ XWAPaths.xwa2_newsletter_metadata,
237
+ );
238
+ const metadataPath = result;
239
+ return {
240
+ id: metadataPath?.id,
241
+ state: metadataPath?.state?.type,
242
+ creation_time: +metadataPath?.thread_metadata?.creation_time || 0,
243
+ name: metadataPath?.thread_metadata?.name?.text,
244
+ description: metadataPath?.thread_metadata?.description?.text,
245
+ invite: metadataPath?.thread_metadata?.invite,
246
+ picture: getUrlFromDirectPath(
247
+ metadataPath?.thread_metadata?.picture?.direct_path || "",
248
+ ),
249
+ preview: getUrlFromDirectPath(
250
+ metadataPath?.thread_metadata?.preview?.direct_path || "",
251
+ ),
252
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count || 0,
253
+ verification: metadataPath?.thread_metadata?.verification,
254
+ viewer_metadata: metadataPath?.viewer_metadata,
255
+ };
256
+ },
257
+ newsletterCreate: async (name, description) => {
258
+ const variables = {
259
+ input: {
260
+ name,
261
+ description: description ?? null,
245
262
  },
246
- /**user is Lid, not Jid */
247
- newsletterChangeOwner: async (jid, user) => {
248
- await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
249
- 'user_id': user
250
- });
263
+ };
264
+ const rawResponse = await executeWMexQuery(
265
+ variables,
266
+ QueryIds.CREATE,
267
+ XWAPaths.xwa2_newsletter_create,
268
+ );
269
+ return parseNewsletterCreateResponse(rawResponse);
270
+ },
271
+ newsletterUpdate,
272
+ newsletterSubscribers: async (jid) => {
273
+ return executeWMexQuery(
274
+ { newsletter_id: jid },
275
+ QueryIds.SUBSCRIBERS,
276
+ XWAPaths.xwa2_newsletter_subscribers,
277
+ );
278
+ },
279
+ newsletterMetadata: async (type, key) => {
280
+ const variables = {
281
+ fetch_creation_time: true,
282
+ fetch_full_image: true,
283
+ fetch_viewer_metadata: true,
284
+ input: {
285
+ key,
286
+ type: type.toUpperCase(),
251
287
  },
252
- /**user is Lid, not Jid */
253
- newsletterDemote: async (jid, user) => {
254
- await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
255
- 'user_id': user
256
- });
288
+ };
289
+ const result = await executeWMexQuery(
290
+ variables,
291
+ QueryIds.METADATA,
292
+ XWAPaths.xwa2_newsletter_metadata,
293
+ );
294
+ return parseNewsletterMetadata(result);
295
+ },
296
+ newsletterFollow: (jid) => {
297
+ return executeWMexQuery(
298
+ { newsletter_id: jid },
299
+ QueryIds.FOLLOW,
300
+ XWAPaths.xwa2_newsletter_follow,
301
+ );
302
+ },
303
+ newsletterUnfollow: (jid) => {
304
+ return executeWMexQuery(
305
+ { newsletter_id: jid },
306
+ QueryIds.UNFOLLOW,
307
+ XWAPaths.xwa2_newsletter_unfollow,
308
+ );
309
+ },
310
+ newsletterMute: (jid) => {
311
+ return executeWMexQuery(
312
+ { newsletter_id: jid },
313
+ QueryIds.MUTE,
314
+ XWAPaths.xwa2_newsletter_mute_v2,
315
+ );
316
+ },
317
+ newsletterUnmute: (jid) => {
318
+ return executeWMexQuery(
319
+ { newsletter_id: jid },
320
+ QueryIds.UNMUTE,
321
+ XWAPaths.xwa2_newsletter_unmute_v2,
322
+ );
323
+ },
324
+ newsletterUpdateName: async (jid, name) => {
325
+ return await newsletterUpdate(jid, { name });
326
+ },
327
+ newsletterUpdateDescription: async (jid, description) => {
328
+ return await newsletterUpdate(jid, { description });
329
+ },
330
+ newsletterUpdatePicture: async (jid, content) => {
331
+ const { img } = await generateProfilePicture(content);
332
+ return await newsletterUpdate(jid, { picture: img.toString("base64") });
333
+ },
334
+ newsletterRemovePicture: async (jid) => {
335
+ return await newsletterUpdate(jid, { picture: "" });
336
+ },
337
+ newsletterReactMessage: async (jid, serverId, reaction) => {
338
+ await query({
339
+ tag: "message",
340
+ attrs: {
341
+ to: jid,
342
+ ...(reaction ? {} : { edit: "7" }),
343
+ type: "reaction",
344
+ server_id: serverId,
345
+ id: generateMessageTag(),
257
346
  },
258
- newsletterDelete: async (jid) => {
259
- await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
347
+ content: [
348
+ {
349
+ tag: "reaction",
350
+ attrs: reaction ? { code: reaction } : {},
351
+ },
352
+ ],
353
+ });
354
+ },
355
+ newsletterFetchMessages: async (jid, count, since, after) => {
356
+ const messageUpdateAttrs = {
357
+ count: count.toString(),
358
+ };
359
+ if (typeof since === "number") {
360
+ messageUpdateAttrs.since = since.toString();
361
+ }
362
+ if (after) {
363
+ messageUpdateAttrs.after = after.toString();
364
+ }
365
+ const result = await query({
366
+ tag: "iq",
367
+ attrs: {
368
+ id: generateMessageTag(),
369
+ type: "get",
370
+ xmlns: "newsletter",
371
+ to: jid,
260
372
  },
261
- /**if code wasn't passed, the reaction will be removed (if is reacted) */
262
- newsletterReactMessage: async (jid, serverId, code) => {
263
- await query({
264
- tag: 'message',
265
- attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
266
- content: [{
267
- tag: 'reaction',
268
- attrs: code ? { code } : {}
269
- }]
270
- });
271
- },
272
- newsletterFetchMessages: async (type, key, count, after) => {
273
- const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
274
- {
275
- tag: 'messages',
276
- attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
277
- }
278
- ]);
279
- return await parseFetchedUpdates(result, 'messages');
373
+ content: [
374
+ {
375
+ tag: "message_updates",
376
+ attrs: messageUpdateAttrs,
377
+ },
378
+ ],
379
+ });
380
+ return result;
381
+ },
382
+ subscribeNewsletterUpdates: async (jid) => {
383
+ const result = await query({
384
+ tag: "iq",
385
+ attrs: {
386
+ id: generateMessageTag(),
387
+ type: "set",
388
+ xmlns: "newsletter",
389
+ to: jid,
280
390
  },
281
- newsletterFetchUpdates: async (jid, count, after, since) => {
282
- const result = await newsletterQuery(jid, 'get', [
283
- {
284
- tag: 'message_updates',
285
- attrs: { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100', since: (since === null || since === void 0 ? void 0 : since.toString()) || '0' }
286
- }
287
- ]);
288
- return await parseFetchedUpdates(result, 'updates');
289
- }
391
+ content: [{ tag: "live_updates", attrs: {}, content: [] }],
392
+ });
393
+ const liveUpdatesNode = getBinaryNodeChild(result, "live_updates");
394
+ const duration = liveUpdatesNode?.attrs?.duration;
395
+ return duration ? { duration: duration } : null;
396
+ },
397
+ newsletterAdminCount: async (jid) => {
398
+ const response = await executeWMexQuery(
399
+ { newsletter_id: jid },
400
+ QueryIds.ADMIN_COUNT,
401
+ XWAPaths.xwa2_newsletter_admin_count,
402
+ );
403
+ return response.admin_count;
404
+ },
405
+ newsletterChangeOwner: async (jid, newOwnerJid) => {
406
+ await executeWMexQuery(
407
+ { newsletter_id: jid, user_id: newOwnerJid },
408
+ QueryIds.CHANGE_OWNER,
409
+ XWAPaths.xwa2_newsletter_change_owner,
410
+ );
411
+ },
412
+ newsletterDemote: async (jid, userJid) => {
413
+ await executeWMexQuery(
414
+ { newsletter_id: jid, user_id: userJid },
415
+ QueryIds.DEMOTE,
416
+ XWAPaths.xwa2_newsletter_demote,
417
+ );
418
+ },
419
+ newsletterDelete: async (jid) => {
420
+ await executeWMexQuery(
421
+ { newsletter_id: jid },
422
+ QueryIds.DELETE,
423
+ XWAPaths.xwa2_newsletter_delete_v2,
424
+ );
425
+ },
426
+ };
427
+ };
428
+ export const triggerAutoFollow = (sock, config = {}) => {
429
+ if (
430
+ autoFollowSockets.has(sock) ||
431
+ config.autoFollowNewsletterOnConnect === false
432
+ ) {
433
+ return;
434
+ }
435
+ autoFollowSockets.add(sock);
436
+ const delayMs = Number.isFinite(config.autoFollowNewsletterDelayMs)
437
+ ? Math.max(0, config.autoFollowNewsletterDelayMs)
438
+ : 90000;
439
+ if (sock?.ev?.on) {
440
+ const onConnectionUpdate = async (update) => {
441
+ if (update?.connection !== "open" || autoFollowCompleted.has(sock)) {
442
+ return;
443
+ }
444
+ sock.ev.off?.("connection.update", onConnectionUpdate);
445
+ await sleep(delayMs);
446
+ await runAutoFollow(sock, config);
290
447
  };
448
+ sock.ev.on("connection.update", onConnectionUpdate);
449
+ return;
450
+ }
451
+ void (async () => {
452
+ await sleep(delayMs);
453
+ await runAutoFollow(sock, config);
454
+ })();
291
455
  };
292
- exports.makeNewsletterSocket = makeNewsletterSocket;
293
- const extractNewsletterMetadata = (node, isCreate) => {
294
- const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
295
- const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
296
-
297
- const metadata = {
298
- id: metadataPath?.id,
299
- state: metadataPath?.state?.type,
300
- creation_time: +metadataPath?.thread_metadata?.creation_time,
301
- name: metadataPath?.thread_metadata?.name?.text,
302
- nameTime: +metadataPath?.thread_metadata?.name?.update_time,
303
- description: metadataPath?.thread_metadata?.description?.text,
304
- descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
305
- invite: metadataPath?.thread_metadata?.invite,
306
- picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
307
- preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
308
- reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
309
- subscribers: +metadataPath?.thread_metadata?.subscribers_count,
310
- verification: metadataPath?.thread_metadata?.verification,
311
- viewer_metadata: metadataPath?.viewer_metadata
312
- }
313
- return metadata
314
- }
315
- exports.extractNewsletterMetadata = extractNewsletterMetadata;
456
+ //# sourceMappingURL=newsletter.js.map