@queenanya/baileys 7.3.5 → 7.3.7

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 (395) hide show
  1. package/.anya-md/.replit +2 -0
  2. package/.anya-md/.temp/.temp +1 -0
  3. package/.anya-md/Dockerfile +16 -0
  4. package/.anya-md/LICENCE +674 -0
  5. package/.anya-md/README.md +301 -0
  6. package/.anya-md/app.json +81 -0
  7. package/.anya-md/config.js +74 -0
  8. package/.anya-md/heroku.yml +5 -0
  9. package/.anya-md/index.js +47 -0
  10. package/.anya-md/koyeb.yaml +14 -0
  11. package/.anya-md/lib/.dev.js +47 -0
  12. package/.anya-md/lib/Assets/aliveMedia.mp4 +0 -0
  13. package/.anya-md/lib/Assets/goodbyeBG.jpg +0 -0
  14. package/.anya-md/lib/Assets/image_1.jpg +0 -0
  15. package/.anya-md/lib/Assets/image_2.jpg +0 -0
  16. package/.anya-md/lib/Assets/menuMedia.mp4 +0 -0
  17. package/.anya-md/lib/Assets/ownerMentionMp3.mp3 +0 -0
  18. package/.anya-md/lib/Assets/port.html +36 -0
  19. package/.anya-md/lib/Assets/reaction/angry/angry108202410.jpeg +0 -0
  20. package/.anya-md/lib/Assets/reaction/angry/angry108202412.jpeg +0 -0
  21. package/.anya-md/lib/Assets/reaction/angry/angry108202413.jpeg +0 -0
  22. package/.anya-md/lib/Assets/reaction/angry/angry108202414.jpeg +0 -0
  23. package/.anya-md/lib/Assets/reaction/angry/angry108202415.jpeg +0 -0
  24. package/.anya-md/lib/Assets/reaction/angry/angry108202416.jpeg +0 -0
  25. package/.anya-md/lib/Assets/reaction/angry/angry108202417.jpeg +0 -0
  26. package/.anya-md/lib/Assets/reaction/angry/angry108202418.jpeg +0 -0
  27. package/.anya-md/lib/Assets/reaction/angry/angry108202419.jpeg +0 -0
  28. package/.anya-md/lib/Assets/reaction/angry/angry108202420.jpeg +0 -0
  29. package/.anya-md/lib/Assets/reaction/angry/angry108202421.jpeg +0 -0
  30. package/.anya-md/lib/Assets/reaction/angry/angry108202423.jpeg +0 -0
  31. package/.anya-md/lib/Assets/reaction/angry/angry108202425.jpeg +0 -0
  32. package/.anya-md/lib/Assets/reaction/angry/angry108202426.jpeg +0 -0
  33. package/.anya-md/lib/Assets/reaction/angry/angry108202427.jpeg +0 -0
  34. package/.anya-md/lib/Assets/reaction/angry/angry108202428.jpeg +0 -0
  35. package/.anya-md/lib/Assets/reaction/angry/angry108202429.jpeg +0 -0
  36. package/.anya-md/lib/Assets/reaction/angry/angry108202430.jpeg +0 -0
  37. package/.anya-md/lib/Assets/reaction/angry/angry108202431.jpeg +0 -0
  38. package/.anya-md/lib/Assets/reaction/angry/angry108202469.jpeg +0 -0
  39. package/.anya-md/lib/Assets/reaction/angry/angry10820249.jpeg +0 -0
  40. package/.anya-md/lib/Assets/reaction/angry/angry11.mp4 +0 -0
  41. package/.anya-md/lib/Assets/reaction/angry/angry12.mp4 +0 -0
  42. package/.anya-md/lib/Assets/reaction/angry/angry14.jpg +0 -0
  43. package/.anya-md/lib/Assets/reaction/angry/angry2.mp4 +0 -0
  44. package/.anya-md/lib/Assets/reaction/angry/angry3.mp4 +0 -0
  45. package/.anya-md/lib/Assets/reaction/angry/angry5.jpg +0 -0
  46. package/.anya-md/lib/Assets/reaction/angry/angry6.png +0 -0
  47. package/.anya-md/lib/Assets/reaction/angry/angry8.png +0 -0
  48. package/.anya-md/lib/Assets/reaction/angry/angry9.jpg +0 -0
  49. package/.anya-md/lib/Assets/reaction/confused/confused1.png +0 -0
  50. package/.anya-md/lib/Assets/reaction/confused/confused2.jpg +0 -0
  51. package/.anya-md/lib/Assets/reaction/confused/confused3.jpg +0 -0
  52. package/.anya-md/lib/Assets/reaction/confused/confused4.mp4 +0 -0
  53. package/.anya-md/lib/Assets/reaction/confused/confused5.jpg +0 -0
  54. package/.anya-md/lib/Assets/reaction/confused/confused6.webp +0 -0
  55. package/.anya-md/lib/Assets/reaction/confused/confused7.png +0 -0
  56. package/.anya-md/lib/Assets/reaction/confused/confused8.jpg +0 -0
  57. package/.anya-md/lib/Assets/reaction/cry/cry1.jpeg +0 -0
  58. package/.anya-md/lib/Assets/reaction/cry/cry12.jpeg +0 -0
  59. package/.anya-md/lib/Assets/reaction/cry/cry13.jpeg +0 -0
  60. package/.anya-md/lib/Assets/reaction/cry/cry14.jpeg +0 -0
  61. package/.anya-md/lib/Assets/reaction/cry/cry15.jpeg +0 -0
  62. package/.anya-md/lib/Assets/reaction/cry/cry16.jpeg +0 -0
  63. package/.anya-md/lib/Assets/reaction/cry/cry17.jpeg +0 -0
  64. package/.anya-md/lib/Assets/reaction/cry/cry18.jpeg +0 -0
  65. package/.anya-md/lib/Assets/reaction/cry/cry19.jpeg +0 -0
  66. package/.anya-md/lib/Assets/reaction/cry/cry22.jpeg +0 -0
  67. package/.anya-md/lib/Assets/reaction/cry/cry23.jpeg +0 -0
  68. package/.anya-md/lib/Assets/reaction/cry/cry5.jpeg +0 -0
  69. package/.anya-md/lib/Assets/reaction/cry/cry9.jpeg +0 -0
  70. package/.anya-md/lib/Assets/reaction/happy/happyrect1.jpeg +0 -0
  71. package/.anya-md/lib/Assets/reaction/no/_pika +1 -0
  72. package/.anya-md/lib/Assets/reaction/no/no1.jpg +0 -0
  73. package/.anya-md/lib/Assets/reaction/no/no2.png +0 -0
  74. package/.anya-md/lib/Assets/reaction/no/no3.jpg +0 -0
  75. package/.anya-md/lib/Assets/reaction/no/no4.png +0 -0
  76. package/.anya-md/lib/Assets/reaction/no/no5.png +0 -0
  77. package/.anya-md/lib/Assets/reaction/no/no6.jpg +0 -0
  78. package/.anya-md/lib/Assets/reaction/no/no7.jpg +0 -0
  79. package/.anya-md/lib/Assets/reaction/no/no8.jpg +0 -0
  80. package/.anya-md/lib/Assets/reaction/no/no9.mp4 +0 -0
  81. package/.anya-md/lib/Assets/reaction/smug/059e1bdc-e62a-4943-b85e-ea372709f6a7.jpeg +0 -0
  82. package/.anya-md/lib/Assets/reaction/smug/8fda90b3-bc98-4d24-ac10-4402c4e7be93.jpeg +0 -0
  83. package/.anya-md/lib/Assets/reaction/smug/Aqua.jpeg +0 -0
  84. package/.anya-md/lib/Assets/reaction/smug/Karasuma Chitose.jpeg +0 -0
  85. package/.anya-md/lib/Assets/reaction/smug/Smug Face - Fibel Sistine.jpeg +0 -0
  86. package/.anya-md/lib/Assets/reaction/smug/bf8d78ec-4fcc-4ff7-b3c3-91a0c5f22567.jpeg +0 -0
  87. package/.anya-md/lib/Assets/reaction/smug//330/247/330/255/331/204/330/247/331/213 /330/247/330/250/330/252/330/263/330/247/331/205/331/207 /330/264/330/261/331/212/330/261/331/207/360/237/230/255/360/237/230/255/360/237/230/255.jpeg +0 -0
  88. package/.anya-md/lib/Assets/verifyIMG.jpg +0 -0
  89. package/.anya-md/lib/Assets/welcomeGIF.mp4 +0 -0
  90. package/.anya-md/lib/database/categories.json +77 -0
  91. package/.anya-md/lib/database/cooldown.json +1 -0
  92. package/.anya-md/lib/database/disk/main.js +43 -0
  93. package/.anya-md/lib/database/emoji.js +23 -0
  94. package/.anya-md/lib/database/games/quiz/Questions.js +44 -0
  95. package/.anya-md/lib/database/games/quiz/Quiz.js +169 -0
  96. package/.anya-md/lib/database/games/quiz/database.json +1 -0
  97. package/.anya-md/lib/database/games/quiz/index.js +7 -0
  98. package/.anya-md/lib/database/json/.pika.js +3 -0
  99. package/.anya-md/lib/database/json/animeQuotes.json +51062 -0
  100. package/.anya-md/lib/database/json/bioQuotes.json +5744 -0
  101. package/.anya-md/lib/database/json/cogan.json +102 -0
  102. package/.anya-md/lib/database/json/countries.json +21210 -0
  103. package/.anya-md/lib/database/json/countries2.json +1 -0
  104. package/.anya-md/lib/database/json/couplepp.json +725 -0
  105. package/.anya-md/lib/database/json/flaming.json +7 -0
  106. package/.anya-md/lib/database/json/ganpati.json +102 -0
  107. package/.anya-md/lib/database/json/husbu.json +1967 -0
  108. package/.anya-md/lib/database/json/islamicWall.json +501 -0
  109. package/.anya-md/lib/database/json/pickupLines.json +118 -0
  110. package/.anya-md/lib/database/json/shreeram.json +49 -0
  111. package/.anya-md/lib/database/json/truthDare.json +643 -0
  112. package/.anya-md/lib/database/mongodb/README.md +142 -0
  113. package/.anya-md/lib/database/mongodb/bot.js +12 -0
  114. package/.anya-md/lib/database/mongodb/cmd.js +17 -0
  115. package/.anya-md/lib/database/mongodb/group.js +22 -0
  116. package/.anya-md/lib/database/mongodb/index.js +24 -0
  117. package/.anya-md/lib/database/mongodb/plugins.js +124 -0
  118. package/.anya-md/lib/database/mongodb/system.js +34 -0
  119. package/.anya-md/lib/database/mongodb/ui.js +15 -0
  120. package/.anya-md/lib/database/mongodb/user.js +17 -0
  121. package/.anya-md/lib/database/mongodb/warn.js +136 -0
  122. package/.anya-md/lib/database/sessions/.pika.js +3 -0
  123. package/.anya-md/lib/frameworks/index.js +5 -0
  124. package/.anya-md/lib/frameworks/reactionMedia.js +91 -0
  125. package/.anya-md/lib/lib/README.md +29 -0
  126. package/.anya-md/lib/lib/ai/README.md +35 -0
  127. package/.anya-md/lib/lib/ai/aiArt.js +47 -0
  128. package/.anya-md/lib/lib/ai/index.js +7 -0
  129. package/.anya-md/lib/lib/buttons.js +530 -0
  130. package/.anya-md/lib/lib/connectionMsg.js +72 -0
  131. package/.anya-md/lib/lib/converter.js +355 -0
  132. package/.anya-md/lib/lib/cooldown.js +46 -0
  133. package/.anya-md/lib/lib/events.js +47 -0
  134. package/.anya-md/lib/lib/functions.js +47 -0
  135. package/.anya-md/lib/lib/greeting.js +115 -0
  136. package/.anya-md/lib/lib/index.js +381 -0
  137. package/.anya-md/lib/lib/logger.js +7 -0
  138. package/.anya-md/lib/lib/maker/remini.js +35 -0
  139. package/.anya-md/lib/lib/mongoUrlFix.js +46 -0
  140. package/.anya-md/lib/lib/myfunc.js +47 -0
  141. package/.anya-md/lib/lib/plugins.js +20 -0
  142. package/.anya-md/lib/lib/prefix.js +47 -0
  143. package/.anya-md/lib/lib/scraper/README.md +35 -0
  144. package/.anya-md/lib/lib/scraper/SoundCloud.js +47 -0
  145. package/.anya-md/lib/lib/scraper/WebToons.js +47 -0
  146. package/.anya-md/lib/lib/scraper/android1.js +47 -0
  147. package/.anya-md/lib/lib/scraper/happymodSearch.js +47 -0
  148. package/.anya-md/lib/lib/scraper/index.js +27 -0
  149. package/.anya-md/lib/lib/scraper/konaChanSearch.js +47 -0
  150. package/.anya-md/lib/lib/scraper/pinterest.js +47 -0
  151. package/.anya-md/lib/lib/scraper/playstore.js +47 -0
  152. package/.anya-md/lib/lib/scraper/ringtone.js +47 -0
  153. package/.anya-md/lib/lib/scraper/steam.js +47 -0
  154. package/.anya-md/lib/lib/scraper/trendingTwitter.js +51 -0
  155. package/.anya-md/lib/lib/scraper/wattpad.js +61 -0
  156. package/.anya-md/lib/lib/scraper/wikipediaSearch.js +42 -0
  157. package/.anya-md/lib/lib/scraper.js +47 -0
  158. package/.anya-md/lib/lib/session.js +47 -0
  159. package/.anya-md/lib/lib/session2.js +47 -0
  160. package/.anya-md/lib/lib/similar.js +47 -0
  161. package/.anya-md/lib/lib/stylish-font.js +2302 -0
  162. package/.anya-md/lib/lib/unicode.js +877 -0
  163. package/.anya-md/lib/lib/upload/index.js +3 -0
  164. package/.anya-md/lib/lib/upload/webp2mp4File.js +56 -0
  165. package/.anya-md/lib/lib/ytdl-core.js +47 -0
  166. package/.anya-md/lib/plugins/README.md +83 -0
  167. package/.anya-md/lib/plugins/_menu.js +810 -0
  168. package/.anya-md/lib/plugins/_plugins.js +239 -0
  169. package/.anya-md/lib/plugins/admins.js +689 -0
  170. package/.anya-md/lib/plugins/ai.js +160 -0
  171. package/.anya-md/lib/plugins/autoreply.js +101 -0
  172. package/.anya-md/lib/plugins/broadcast.js +204 -0
  173. package/.anya-md/lib/plugins/convert.js +293 -0
  174. package/.anya-md/lib/plugins/core.js +941 -0
  175. package/.anya-md/lib/plugins/download.js +373 -0
  176. package/.anya-md/lib/plugins/fun.js +75 -0
  177. package/.anya-md/lib/plugins/games.js +33 -0
  178. package/.anya-md/lib/plugins/gcswitches.js +204 -0
  179. package/.anya-md/lib/plugins/general.js +456 -0
  180. package/.anya-md/lib/plugins/maker.js +41 -0
  181. package/.anya-md/lib/plugins/owner.js +1049 -0
  182. package/.anya-md/lib/plugins/religious.js +81 -0
  183. package/.anya-md/lib/plugins/search.js +902 -0
  184. package/.anya-md/lib/plugins/stalker.js +187 -0
  185. package/.anya-md/lib/plugins/sticker.js +125 -0
  186. package/.anya-md/lib/plugins/tools.js +193 -0
  187. package/.anya-md/lib/plugins/youtube.js +204 -0
  188. package/.anya-md/package.json +75 -0
  189. package/.anya-md/railway.json +12 -0
  190. package/.anya-md/render.yaml +48 -0
  191. package/.anya-md/replit.nix +18 -0
  192. package/.bash_history +500 -0
  193. package/.config/gh/config.yml +19 -0
  194. package/.config/gh/hosts.yml +11 -0
  195. package/.config/ngrok/ngrok.yml +3 -0
  196. package/.config/yarn/global/package.json +5 -0
  197. package/.gitconfig +772 -0
  198. package/.node_repl_history +0 -0
  199. package/.npm/_cacache/content-v2/sha512/02/b3/d1abf5af06222f7de440ab1b057deb21f9dfb0ce0a8f5064b2ba00595933bbcbbaa040b4616f951d9f8ba48d67491df1198a4831fbd8ee26eb27dde36511 +0 -0
  200. package/.npm/_cacache/content-v2/sha512/49/7b/0cdbb4861f7c9358a7367ca478498371b269efb8143d75de901ed1169a267f56a68e60f008952f3ebcc727dbb60bb401011af3514a1dd33cdbed8d981fa8 +0 -0
  201. package/.npm/_cacache/content-v2/sha512/54/3a/647bceb49b7632e6e700cb9f1b66f0f528d4ca71f4f73e76a1e7c8c50b563a2d0bb7734c18f93e6c03b7ea93167db35db0e1999ab13b08ed6b250eed2d2a +1 -0
  202. package/.npm/_cacache/content-v2/sha512/56/7c/4d5820233a7278225351642f7355d9889af42e7efbbfe27d6b201727efad972a59fa32063c7e1159d01dbf27ba014095ca1349ec0d0767746c39441178fa +1 -0
  203. package/.npm/_cacache/content-v2/sha512/89/88/d295c7e4f4d0f4621676d4c499bea2a1c72b0c31a84ff78a8bb8f83042da2bcf596e664c021d21025b296cdd4aecb57a036ea366e39466df5a129fa471df +0 -0
  204. package/.npm/_cacache/content-v2/sha512/8b/46/42882ebb46a975b0ce6b9cdea357190c41b51bb59a21df41c575418850b28115921e130709846d8ff9cabeae72544ec37a48ee7ccb074fe94da925250e55 +1 -0
  205. package/.npm/_cacache/content-v2/sha512/dd/0d/f856b793da0619d18260556498dfff13391593abb6d6a582bf052f03ba35a03a1444bf5c2d40b7515d268ec2cb3e67a17a42f09f5e668c3bb9b743e3b8a7 +1 -0
  206. package/.npm/_cacache/content-v2/sha512/dd/15/702501c36ce653a003d2b101034a0cb9c0fd262fa77797f1a286a161a0b2dce51ef13199e9a3fa58008bdbbf4646a33b6f1a24a2807691093cb89beefb00 +1 -0
  207. package/.npm/_cacache/index-v5/35/f9/e8cc076ef93c1bc40804d3fe05171053366095c922f515b1fab2b580116f +4 -0
  208. package/.npm/_cacache/index-v5/6a/a2/780c77f928115d4dad58a9dc4fa241de8d914abfff994e44602cc93a697c +2 -0
  209. package/.npm/_cacache/index-v5/71/ba/d0bb16fddeb617bbbb3713f46750d1bf5b57742abb6feb6dee4d16c68da4 +4 -0
  210. package/.npm/_cacache/index-v5/72/ae/c69532318093b3bd13618450ca5c26adc018a4afc0e020786207068593cf +2 -0
  211. package/.npm/_cacache/index-v5/7e/5e/9683ad4854f4201d7e53bf9beb2aefafa7b1efbb2c6ac7b36b78d0b218c8 +2 -0
  212. package/.npm/_cacache/index-v5/eb/a0/19e529094c594367a9e1aa68096a313d3dc5509d410761bf50122826a6d2 +4 -0
  213. package/.npm/_cacache/index-v5/f1/fa/2d2f12de549683d1275ec0f2ff15610b408fd89d1b7a755ddb7b77c00371 +2 -0
  214. package/.npm/_logs/2024-10-03T05_52_01_853Z-debug-0.log +52 -0
  215. package/.npm/_logs/2024-10-03T05_52_08_135Z-debug-0.log +52 -0
  216. package/.npm/_logs/2024-10-03T05_52_14_087Z-debug-0.log +52 -0
  217. package/.npm/_logs/2024-10-03T05_52_22_730Z-debug-0.log +52 -0
  218. package/.npm/_logs/2024-10-03T05_52_29_410Z-debug-0.log +52 -0
  219. package/.npm/_logs/2024-10-03T05_52_35_375Z-debug-0.log +52 -0
  220. package/.npm/_logs/2024-10-03T15_32_57_465Z-debug-0.log +20 -0
  221. package/.npm/_logs/2024-10-10T05_40_23_847Z-debug-0.log +254 -0
  222. package/.npm/_logs/2024-10-10T05_40_50_397Z-debug-0.log +73 -0
  223. package/.npm/_logs/2024-10-10T05_40_59_931Z-debug-0.log +52 -0
  224. package/.npm/_logs/2024-10-10T05_42_07_969Z-debug-0.log +52 -0
  225. package/.pm2/logs/anya-error.log +0 -0
  226. package/.pm2/logs/anya-out.log +59 -0
  227. package/.pm2/logs/anya-v2-error.log +2184 -0
  228. package/.pm2/logs/anya-v2-out.log +362 -0
  229. package/.pm2/module_conf.json +1 -0
  230. package/.pm2/pm2.log +919 -0
  231. package/.pm2/pm2.pid +1 -0
  232. package/.pm2/touch +1 -0
  233. package/.ssh/authorized_keys +0 -0
  234. package/.termux/termux.properties +180 -0
  235. package/.wget-hsts +5 -0
  236. package/package.json +2 -102
  237. package/LICENSE +0 -21
  238. package/README.md +0 -941
  239. package/WAProto/GenerateStatics.sh +0 -4
  240. package/WAProto/WAProto.proto +0 -3344
  241. package/WAProto/index.d.ts +0 -37016
  242. package/WAProto/index.js +0 -101044
  243. package/WASignalGroup/GroupProtocol.js +0 -1697
  244. package/WASignalGroup/ciphertext_message.js +0 -16
  245. package/WASignalGroup/group_cipher.js +0 -120
  246. package/WASignalGroup/group_session_builder.js +0 -46
  247. package/WASignalGroup/index.js +0 -5
  248. package/WASignalGroup/keyhelper.js +0 -21
  249. package/WASignalGroup/protobufs.js +0 -3
  250. package/WASignalGroup/queue_job.js +0 -69
  251. package/WASignalGroup/sender_chain_key.js +0 -50
  252. package/WASignalGroup/sender_key_distribution_message.js +0 -78
  253. package/WASignalGroup/sender_key_message.js +0 -92
  254. package/WASignalGroup/sender_key_name.js +0 -70
  255. package/WASignalGroup/sender_key_record.js +0 -56
  256. package/WASignalGroup/sender_key_state.js +0 -129
  257. package/WASignalGroup/sender_message_key.js +0 -39
  258. package/lib/Defaults/baileys-version.json +0 -3
  259. package/lib/Defaults/index.d.ts +0 -284
  260. package/lib/Defaults/index.js +0 -122
  261. package/lib/Defaults/phonenumber-mcc.json +0 -223
  262. package/lib/Signal/libsignal.d.ts +0 -3
  263. package/lib/Signal/libsignal.js +0 -152
  264. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
  265. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  266. package/lib/Socket/Client/index.d.ts +0 -3
  267. package/lib/Socket/Client/index.js +0 -19
  268. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  269. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  270. package/lib/Socket/Client/web-socket-client.d.ts +0 -12
  271. package/lib/Socket/Client/web-socket-client.js +0 -62
  272. package/lib/Socket/business.d.ts +0 -177
  273. package/lib/Socket/business.js +0 -260
  274. package/lib/Socket/chats.d.ts +0 -91
  275. package/lib/Socket/chats.js +0 -948
  276. package/lib/Socket/groups.d.ts +0 -137
  277. package/lib/Socket/groups.js +0 -314
  278. package/lib/Socket/index.d.ts +0 -179
  279. package/lib/Socket/index.js +0 -10
  280. package/lib/Socket/messages-recv.d.ts +0 -164
  281. package/lib/Socket/messages-recv.js +0 -921
  282. package/lib/Socket/messages-send.d.ts +0 -157
  283. package/lib/Socket/messages-send.js +0 -779
  284. package/lib/Socket/newsletter.d.ts +0 -143
  285. package/lib/Socket/newsletter.js +0 -249
  286. package/lib/Socket/registration.d.ts +0 -271
  287. package/lib/Socket/registration.js +0 -166
  288. package/lib/Socket/socket.d.ts +0 -44
  289. package/lib/Socket/socket.js +0 -620
  290. package/lib/Store/index.d.ts +0 -3
  291. package/lib/Store/index.js +0 -10
  292. package/lib/Store/make-cache-manager-store.d.ts +0 -14
  293. package/lib/Store/make-cache-manager-store.js +0 -83
  294. package/lib/Store/make-in-memory-store.d.ts +0 -118
  295. package/lib/Store/make-in-memory-store.js +0 -422
  296. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  297. package/lib/Store/make-ordered-dictionary.js +0 -81
  298. package/lib/Store/object-repository.d.ts +0 -10
  299. package/lib/Store/object-repository.js +0 -27
  300. package/lib/Types/Auth.d.ts +0 -111
  301. package/lib/Types/Auth.js +0 -2
  302. package/lib/Types/Call.d.ts +0 -13
  303. package/lib/Types/Call.js +0 -2
  304. package/lib/Types/Chat.d.ts +0 -107
  305. package/lib/Types/Chat.js +0 -4
  306. package/lib/Types/Contact.d.ts +0 -19
  307. package/lib/Types/Contact.js +0 -2
  308. package/lib/Types/Events.d.ts +0 -199
  309. package/lib/Types/Events.js +0 -2
  310. package/lib/Types/GroupMetadata.d.ts +0 -56
  311. package/lib/Types/GroupMetadata.js +0 -2
  312. package/lib/Types/Label.d.ts +0 -46
  313. package/lib/Types/Label.js +0 -27
  314. package/lib/Types/LabelAssociation.d.ts +0 -29
  315. package/lib/Types/LabelAssociation.js +0 -9
  316. package/lib/Types/Message.d.ts +0 -278
  317. package/lib/Types/Message.js +0 -9
  318. package/lib/Types/Newsletter.d.ts +0 -79
  319. package/lib/Types/Newsletter.js +0 -18
  320. package/lib/Types/Product.d.ts +0 -78
  321. package/lib/Types/Product.js +0 -2
  322. package/lib/Types/Signal.d.ts +0 -57
  323. package/lib/Types/Signal.js +0 -2
  324. package/lib/Types/Socket.d.ts +0 -118
  325. package/lib/Types/Socket.js +0 -2
  326. package/lib/Types/State.d.ts +0 -27
  327. package/lib/Types/State.js +0 -2
  328. package/lib/Types/index.d.ts +0 -65
  329. package/lib/Types/index.js +0 -42
  330. package/lib/Utils/auth-utils.d.ts +0 -18
  331. package/lib/Utils/auth-utils.js +0 -206
  332. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  333. package/lib/Utils/baileys-event-stream.js +0 -63
  334. package/lib/Utils/business.d.ts +0 -22
  335. package/lib/Utils/business.js +0 -234
  336. package/lib/Utils/chat-utils.d.ts +0 -72
  337. package/lib/Utils/chat-utils.js +0 -740
  338. package/lib/Utils/crypto.d.ts +0 -42
  339. package/lib/Utils/crypto.js +0 -153
  340. package/lib/Utils/decode-wa-message.d.ts +0 -20
  341. package/lib/Utils/decode-wa-message.js +0 -207
  342. package/lib/Utils/event-buffer.d.ts +0 -35
  343. package/lib/Utils/event-buffer.js +0 -520
  344. package/lib/Utils/generics.d.ts +0 -115
  345. package/lib/Utils/generics.js +0 -440
  346. package/lib/Utils/history.d.ts +0 -19
  347. package/lib/Utils/history.js +0 -94
  348. package/lib/Utils/index.d.ts +0 -17
  349. package/lib/Utils/index.js +0 -33
  350. package/lib/Utils/link-preview.d.ts +0 -21
  351. package/lib/Utils/link-preview.js +0 -93
  352. package/lib/Utils/logger.d.ts +0 -2
  353. package/lib/Utils/logger.js +0 -7
  354. package/lib/Utils/lt-hash.d.ts +0 -12
  355. package/lib/Utils/lt-hash.js +0 -51
  356. package/lib/Utils/make-mutex.d.ts +0 -7
  357. package/lib/Utils/make-mutex.js +0 -43
  358. package/lib/Utils/messages-media.d.ts +0 -131
  359. package/lib/Utils/messages-media.js +0 -793
  360. package/lib/Utils/messages.d.ts +0 -78
  361. package/lib/Utils/messages.js +0 -771
  362. package/lib/Utils/noise-handler.d.ts +0 -22
  363. package/lib/Utils/noise-handler.js +0 -155
  364. package/lib/Utils/process-message.d.ts +0 -42
  365. package/lib/Utils/process-message.js +0 -354
  366. package/lib/Utils/signal.d.ts +0 -32
  367. package/lib/Utils/signal.js +0 -156
  368. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -12
  369. package/lib/Utils/use-multi-file-auth-state.js +0 -93
  370. package/lib/Utils/validate-connection.d.ts +0 -11
  371. package/lib/Utils/validate-connection.js +0 -205
  372. package/lib/WABinary/constants.d.ts +0 -27
  373. package/lib/WABinary/constants.js +0 -40
  374. package/lib/WABinary/decode.d.ts +0 -8
  375. package/lib/WABinary/decode.js +0 -254
  376. package/lib/WABinary/encode.d.ts +0 -2
  377. package/lib/WABinary/encode.js +0 -228
  378. package/lib/WABinary/generic-utils.d.ts +0 -16
  379. package/lib/WABinary/generic-utils.js +0 -110
  380. package/lib/WABinary/index.d.ts +0 -5
  381. package/lib/WABinary/index.js +0 -21
  382. package/lib/WABinary/jid-utils.d.ts +0 -31
  383. package/lib/WABinary/jid-utils.js +0 -62
  384. package/lib/WABinary/types.d.ts +0 -18
  385. package/lib/WABinary/types.js +0 -2
  386. package/lib/WAM/BinaryInfo.d.ts +0 -18
  387. package/lib/WAM/BinaryInfo.js +0 -13
  388. package/lib/WAM/constants.d.ts +0 -38
  389. package/lib/WAM/constants.js +0 -15350
  390. package/lib/WAM/encode.d.ts +0 -4
  391. package/lib/WAM/encode.js +0 -155
  392. package/lib/WAM/index.d.ts +0 -3
  393. package/lib/WAM/index.js +0 -19
  394. package/lib/index.d.ts +0 -11
  395. package/lib/index.js +0 -30
@@ -1,620 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.makeSocket = void 0;
4
- const boom_1 = require("@hapi/boom");
5
- const crypto_1 = require("crypto");
6
- const url_1 = require("url");
7
- const util_1 = require("util");
8
- const WAProto_1 = require("../../WAProto");
9
- const Defaults_1 = require("../Defaults");
10
- const Types_1 = require("../Types");
11
- const Utils_1 = require("../Utils");
12
- const WABinary_1 = require("../WABinary");
13
- const Client_1 = require("./Client");
14
- /**
15
- * Connects to WA servers and performs:
16
- * - simple queries (no retry mechanism, wait for connection establishment)
17
- * - listen to messages and emit events
18
- * - query phone connection
19
- */
20
- const makeSocket = (config) => {
21
- var _a, _b;
22
- const { waWebSocketUrl, connectTimeoutMs, logger, keepAliveIntervalMs, browser, auth: authState, printQRInTerminal, defaultQueryTimeoutMs, transactionOpts, qrTimeout, makeSignalRepository, } = config;
23
- let url = typeof waWebSocketUrl === 'string' ? new url_1.URL(waWebSocketUrl) : waWebSocketUrl;
24
- config.mobile = config.mobile || url.protocol === 'tcp:';
25
- if (config.mobile && url.protocol !== 'tcp:') {
26
- url = new url_1.URL(`tcp://${Defaults_1.MOBILE_ENDPOINT}:${Defaults_1.MOBILE_PORT}`);
27
- }
28
- if (!config.mobile && url.protocol === 'wss' && ((_a = authState === null || authState === void 0 ? void 0 : authState.creds) === null || _a === void 0 ? void 0 : _a.routingInfo)) {
29
- url.searchParams.append('ED', authState.creds.routingInfo.toString('base64url'));
30
- }
31
- const ws = config.socket ? config.socket : config.mobile ? new Client_1.MobileSocketClient(url, config) : new Client_1.WebSocketClient(url, config);
32
- ws.connect();
33
- const ev = (0, Utils_1.makeEventBuffer)(logger);
34
- /** ephemeral key pair used to encrypt/decrypt communication. Unique for each connection */
35
- const ephemeralKeyPair = Utils_1.Curve.generateKeyPair();
36
- /** WA noise protocol wrapper */
37
- const noise = (0, Utils_1.makeNoiseHandler)({
38
- keyPair: ephemeralKeyPair,
39
- NOISE_HEADER: config.mobile ? Defaults_1.MOBILE_NOISE_HEADER : Defaults_1.NOISE_WA_HEADER,
40
- mobile: config.mobile,
41
- logger,
42
- routingInfo: (_b = authState === null || authState === void 0 ? void 0 : authState.creds) === null || _b === void 0 ? void 0 : _b.routingInfo
43
- });
44
- const { creds } = authState;
45
- // add transaction capability
46
- const keys = (0, Utils_1.addTransactionCapability)(authState.keys, logger, transactionOpts);
47
- const signalRepository = makeSignalRepository({ creds, keys });
48
- let lastDateRecv;
49
- let epoch = 1;
50
- let keepAliveReq;
51
- let qrTimer;
52
- let closed = false;
53
- const uqTagId = (0, Utils_1.generateMdTagPrefix)();
54
- const generateMessageTag = () => `${uqTagId}${epoch++}`;
55
- const sendPromise = (0, util_1.promisify)(ws.send);
56
- /** send a raw buffer */
57
- const sendRawMessage = async (data) => {
58
- if (!ws.isOpen) {
59
- throw new boom_1.Boom('Connection Closed', { statusCode: Types_1.DisconnectReason.connectionClosed });
60
- }
61
- const bytes = noise.encodeFrame(data);
62
- await (0, Utils_1.promiseTimeout)(connectTimeoutMs, async (resolve, reject) => {
63
- try {
64
- await sendPromise.call(ws, bytes);
65
- resolve();
66
- }
67
- catch (error) {
68
- reject(error);
69
- }
70
- });
71
- };
72
- /** send a binary node */
73
- const sendNode = (frame) => {
74
- if (logger.level === 'trace') {
75
- logger.trace({ xml: (0, WABinary_1.binaryNodeToString)(frame), msg: 'xml send' });
76
- }
77
- const node = (0, WABinary_1.encodeBinaryNode)(frame);
78
- const buff = Buffer.from(node);
79
- return sendRawMessage(buff);
80
- };
81
- /** log & process any unexpected errors */
82
- const onUnexpectedError = (err, msg) => {
83
- logger.error({ err }, `unexpected error in '${msg}'`);
84
- };
85
- /** await the next incoming message */
86
- const awaitNextMessage = async (sendMsg) => {
87
- if (!ws.isOpen) {
88
- throw new boom_1.Boom('Connection Closed', {
89
- statusCode: Types_1.DisconnectReason.connectionClosed
90
- });
91
- }
92
- let onOpen;
93
- let onClose;
94
- const result = (0, Utils_1.promiseTimeout)(connectTimeoutMs, (resolve, reject) => {
95
- onOpen = resolve;
96
- onClose = mapWebSocketError(reject);
97
- ws.on('frame', onOpen);
98
- ws.on('close', onClose);
99
- ws.on('error', onClose);
100
- })
101
- .finally(() => {
102
- ws.off('frame', onOpen);
103
- ws.off('close', onClose);
104
- ws.off('error', onClose);
105
- });
106
- if (sendMsg) {
107
- sendRawMessage(sendMsg).catch(onClose);
108
- }
109
- return result;
110
- };
111
- /**
112
- * Wait for a message with a certain tag to be received
113
- * @param msgId the message tag to await
114
- * @param timeoutMs timeout after which the promise will reject
115
- */
116
- const waitForMessage = async (msgId, timeoutMs = defaultQueryTimeoutMs) => {
117
- let onRecv;
118
- let onErr;
119
- try {
120
- return await (0, Utils_1.promiseTimeout)(timeoutMs, (resolve, reject) => {
121
- onRecv = resolve;
122
- onErr = err => {
123
- reject(err || new boom_1.Boom('Connection Closed', { statusCode: Types_1.DisconnectReason.connectionClosed }));
124
- };
125
- ws.on(`TAG:${msgId}`, onRecv);
126
- ws.on('close', onErr); // if the socket closes, you'll never receive the message
127
- ws.off('error', onErr);
128
- });
129
- }
130
- finally {
131
- ws.off(`TAG:${msgId}`, onRecv);
132
- ws.off('close', onErr); // if the socket closes, you'll never receive the message
133
- ws.off('error', onErr);
134
- }
135
- };
136
- /** send a query, and wait for its response. auto-generates message ID if not provided */
137
- const query = async (node, timeoutMs) => {
138
- if (!node.attrs.id) {
139
- node.attrs.id = generateMessageTag();
140
- }
141
- const msgId = node.attrs.id;
142
- const wait = waitForMessage(msgId, timeoutMs);
143
- await sendNode(node);
144
- const result = await wait;
145
- if ('tag' in result) {
146
- (0, WABinary_1.assertNodeErrorFree)(result);
147
- }
148
- return result;
149
- };
150
- /** connection handshake */
151
- const validateConnection = async () => {
152
- let helloMsg = {
153
- clientHello: { ephemeral: ephemeralKeyPair.public }
154
- };
155
- helloMsg = WAProto_1.proto.HandshakeMessage.fromObject(helloMsg);
156
- logger.info({ browser, helloMsg }, 'connected to WA');
157
- const init = WAProto_1.proto.HandshakeMessage.encode(helloMsg).finish();
158
- const result = await awaitNextMessage(init);
159
- const handshake = WAProto_1.proto.HandshakeMessage.decode(result);
160
- logger.trace({ handshake }, 'handshake recv from WA');
161
- const keyEnc = noise.processHandshake(handshake, creds.noiseKey);
162
- let node;
163
- if (config.mobile) {
164
- node = (0, Utils_1.generateMobileNode)(config);
165
- }
166
- else if (!creds.me) {
167
- node = (0, Utils_1.generateRegistrationNode)(creds, config);
168
- logger.info({ node }, 'not logged in, attempting registration...');
169
- }
170
- else {
171
- node = (0, Utils_1.generateLoginNode)(creds.me.id, config);
172
- logger.info({ node }, 'logging in...');
173
- }
174
- const payloadEnc = noise.encrypt(WAProto_1.proto.ClientPayload.encode(node).finish());
175
- await sendRawMessage(WAProto_1.proto.HandshakeMessage.encode({
176
- clientFinish: {
177
- static: keyEnc,
178
- payload: payloadEnc,
179
- },
180
- }).finish());
181
- noise.finishInit();
182
- startKeepAliveRequest();
183
- };
184
- const getAvailablePreKeysOnServer = async () => {
185
- const result = await query({
186
- tag: 'iq',
187
- attrs: {
188
- id: generateMessageTag(),
189
- xmlns: 'encrypt',
190
- type: 'get',
191
- to: WABinary_1.S_WHATSAPP_NET
192
- },
193
- content: [
194
- { tag: 'count', attrs: {} }
195
- ]
196
- });
197
- const countChild = (0, WABinary_1.getBinaryNodeChild)(result, 'count');
198
- return +countChild.attrs.value;
199
- };
200
- /** generates and uploads a set of pre-keys to the server */
201
- const uploadPreKeys = async (count = Defaults_1.INITIAL_PREKEY_COUNT) => {
202
- await keys.transaction(async () => {
203
- logger.info({ count }, 'uploading pre-keys');
204
- const { update, node } = await (0, Utils_1.getNextPreKeysNode)({ creds, keys }, count);
205
- await query(node);
206
- ev.emit('creds.update', update);
207
- logger.info({ count }, 'uploaded pre-keys');
208
- });
209
- };
210
- const uploadPreKeysToServerIfRequired = async () => {
211
- const preKeyCount = await getAvailablePreKeysOnServer();
212
- logger.info(`${preKeyCount} pre-keys found on server`);
213
- if (preKeyCount <= Defaults_1.MIN_PREKEY_COUNT) {
214
- await uploadPreKeys();
215
- }
216
- };
217
- const onMessageReceived = (data) => {
218
- noise.decodeFrame(data, frame => {
219
- var _a;
220
- // reset ping timeout
221
- lastDateRecv = new Date();
222
- let anyTriggered = false;
223
- anyTriggered = ws.emit('frame', frame);
224
- // if it's a binary node
225
- if (!(frame instanceof Uint8Array)) {
226
- const msgId = frame.attrs.id;
227
- if (logger.level === 'trace') {
228
- logger.trace({ xml: (0, WABinary_1.binaryNodeToString)(frame), msg: 'recv xml' });
229
- }
230
- /* Check if this is a response to a message we sent */
231
- anyTriggered = ws.emit(`${Defaults_1.DEF_TAG_PREFIX}${msgId}`, frame) || anyTriggered;
232
- /* Check if this is a response to a message we are expecting */
233
- const l0 = frame.tag;
234
- const l1 = frame.attrs || {};
235
- const l2 = Array.isArray(frame.content) ? (_a = frame.content[0]) === null || _a === void 0 ? void 0 : _a.tag : '';
236
- Object.keys(l1).forEach(key => {
237
- anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},${key}:${l1[key]},${l2}`, frame) || anyTriggered;
238
- anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},${key}:${l1[key]}`, frame) || anyTriggered;
239
- anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},${key}`, frame) || anyTriggered;
240
- });
241
- anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},,${l2}`, frame) || anyTriggered;
242
- anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0}`, frame) || anyTriggered;
243
- if (!anyTriggered && logger.level === 'debug') {
244
- logger.debug({ unhandled: true, msgId, fromMe: false, frame }, 'communication recv');
245
- }
246
- }
247
- });
248
- };
249
- const end = (error) => {
250
- if (closed) {
251
- logger.trace({ trace: error === null || error === void 0 ? void 0 : error.stack }, 'connection already closed');
252
- return;
253
- }
254
- closed = true;
255
- logger.info({ trace: error === null || error === void 0 ? void 0 : error.stack }, error ? 'connection errored' : 'connection closed');
256
- clearInterval(keepAliveReq);
257
- clearTimeout(qrTimer);
258
- ws.removeAllListeners('close');
259
- ws.removeAllListeners('error');
260
- ws.removeAllListeners('open');
261
- ws.removeAllListeners('message');
262
- if (!ws.isClosed && !ws.isClosing) {
263
- try {
264
- ws.close();
265
- }
266
- catch (_a) { }
267
- }
268
- ev.emit('connection.update', {
269
- connection: 'close',
270
- lastDisconnect: {
271
- error,
272
- date: new Date()
273
- }
274
- });
275
- ev.removeAllListeners('connection.update');
276
- };
277
- const waitForSocketOpen = async () => {
278
- if (ws.isOpen) {
279
- return;
280
- }
281
- if (ws.isClosed || ws.isClosing) {
282
- throw new boom_1.Boom('Connection Closed', { statusCode: Types_1.DisconnectReason.connectionClosed });
283
- }
284
- let onOpen;
285
- let onClose;
286
- await new Promise((resolve, reject) => {
287
- onOpen = () => resolve(undefined);
288
- onClose = mapWebSocketError(reject);
289
- ws.on('open', onOpen);
290
- ws.on('close', onClose);
291
- ws.on('error', onClose);
292
- })
293
- .finally(() => {
294
- ws.off('open', onOpen);
295
- ws.off('close', onClose);
296
- ws.off('error', onClose);
297
- });
298
- };
299
- const startKeepAliveRequest = () => (keepAliveReq = setInterval(() => {
300
- if (!lastDateRecv) {
301
- lastDateRecv = new Date();
302
- }
303
- const diff = Date.now() - lastDateRecv.getTime();
304
- /*
305
- check if it's been a suspicious amount of time since the server responded with our last seen
306
- it could be that the network is down
307
- */
308
- if (diff > keepAliveIntervalMs + 5000) {
309
- end(new boom_1.Boom('Connection was lost', { statusCode: Types_1.DisconnectReason.connectionLost }));
310
- }
311
- else if (ws.isOpen) {
312
- // if its all good, send a keep alive request
313
- query({
314
- tag: 'iq',
315
- attrs: {
316
- id: generateMessageTag(),
317
- to: WABinary_1.S_WHATSAPP_NET,
318
- type: 'get',
319
- xmlns: 'w:p',
320
- },
321
- content: [{ tag: 'ping', attrs: {} }]
322
- })
323
- .catch(err => {
324
- logger.error({ trace: err.stack }, 'error in sending keep alive');
325
- });
326
- }
327
- else {
328
- logger.warn('keep alive called when WS not open');
329
- }
330
- }, keepAliveIntervalMs));
331
- /** i have no idea why this exists. pls enlighten me */
332
- const sendPassiveIq = (tag) => (query({
333
- tag: 'iq',
334
- attrs: {
335
- to: WABinary_1.S_WHATSAPP_NET,
336
- xmlns: 'passive',
337
- type: 'set',
338
- },
339
- content: [
340
- { tag, attrs: {} }
341
- ]
342
- }));
343
- /** logout & invalidate connection */
344
- const logout = async (msg) => {
345
- var _a;
346
- const jid = (_a = authState.creds.me) === null || _a === void 0 ? void 0 : _a.id;
347
- if (jid) {
348
- await sendNode({
349
- tag: 'iq',
350
- attrs: {
351
- to: WABinary_1.S_WHATSAPP_NET,
352
- type: 'set',
353
- id: generateMessageTag(),
354
- xmlns: 'md'
355
- },
356
- content: [
357
- {
358
- tag: 'remove-companion-device',
359
- attrs: {
360
- jid,
361
- reason: 'user_initiated'
362
- }
363
- }
364
- ]
365
- });
366
- }
367
- end(new boom_1.Boom(msg || 'Intentional Logout', { statusCode: Types_1.DisconnectReason.loggedOut }));
368
- };
369
- const requestPairingCode = async (phoneNumber) => {
370
- authState.creds.pairingCode = (0, Utils_1.bytesToCrockford)((0, crypto_1.randomBytes)(5));
371
- authState.creds.me = {
372
- id: (0, WABinary_1.jidEncode)(phoneNumber, 's.whatsapp.net'),
373
- name: '~'
374
- };
375
- ev.emit('creds.update', authState.creds);
376
- await sendNode({
377
- tag: 'iq',
378
- attrs: {
379
- to: WABinary_1.S_WHATSAPP_NET,
380
- type: 'set',
381
- id: generateMessageTag(),
382
- xmlns: 'md'
383
- },
384
- content: [
385
- {
386
- tag: 'link_code_companion_reg',
387
- attrs: {
388
- jid: authState.creds.me.id,
389
- stage: 'companion_hello',
390
- // eslint-disable-next-line camelcase
391
- should_show_push_notification: 'true'
392
- },
393
- content: [
394
- {
395
- tag: 'link_code_pairing_wrapped_companion_ephemeral_pub',
396
- attrs: {},
397
- content: await generatePairingKey()
398
- },
399
- {
400
- tag: 'companion_server_auth_key_pub',
401
- attrs: {},
402
- content: authState.creds.noiseKey.public
403
- },
404
- {
405
- tag: 'companion_platform_id',
406
- attrs: {},
407
- content: (0, Utils_1.getPlatformId)(browser[1])
408
- },
409
- {
410
- tag: 'companion_platform_display',
411
- attrs: {},
412
- content: `${browser[1]} (${browser[0]})`
413
- },
414
- {
415
- tag: 'link_code_pairing_nonce',
416
- attrs: {},
417
- content: '0'
418
- }
419
- ]
420
- }
421
- ]
422
- });
423
- return authState.creds.pairingCode;
424
- };
425
- async function generatePairingKey() {
426
- const salt = (0, crypto_1.randomBytes)(32);
427
- const randomIv = (0, crypto_1.randomBytes)(16);
428
- const key = await (0, Utils_1.derivePairingCodeKey)(authState.creds.pairingCode, salt);
429
- const ciphered = (0, Utils_1.aesEncryptCTR)(authState.creds.pairingEphemeralKeyPair.public, key, randomIv);
430
- return Buffer.concat([salt, randomIv, ciphered]);
431
- }
432
- const sendWAMBuffer = (wamBuffer) => {
433
- return query({
434
- tag: 'iq',
435
- attrs: {
436
- to: WABinary_1.S_WHATSAPP_NET,
437
- id: generateMessageTag(),
438
- xmlns: 'w:stats'
439
- },
440
- content: [
441
- {
442
- tag: 'add',
443
- attrs: {},
444
- content: wamBuffer
445
- }
446
- ]
447
- });
448
- };
449
- ws.on('message', onMessageReceived);
450
- ws.on('open', async () => {
451
- try {
452
- await validateConnection();
453
- }
454
- catch (err) {
455
- logger.error({ err }, 'error in validating connection');
456
- end(err);
457
- }
458
- });
459
- ws.on('error', mapWebSocketError(end));
460
- ws.on('close', () => end(new boom_1.Boom('Connection Terminated', { statusCode: Types_1.DisconnectReason.connectionClosed })));
461
- // the server terminated the connection
462
- ws.on('CB:xmlstreamend', () => end(new boom_1.Boom('Connection Terminated by Server', { statusCode: Types_1.DisconnectReason.connectionClosed })));
463
- // QR gen
464
- ws.on('CB:iq,type:set,pair-device', async (stanza) => {
465
- const iq = {
466
- tag: 'iq',
467
- attrs: {
468
- to: WABinary_1.S_WHATSAPP_NET,
469
- type: 'result',
470
- id: stanza.attrs.id,
471
- }
472
- };
473
- await sendNode(iq);
474
- const pairDeviceNode = (0, WABinary_1.getBinaryNodeChild)(stanza, 'pair-device');
475
- const refNodes = (0, WABinary_1.getBinaryNodeChildren)(pairDeviceNode, 'ref');
476
- const noiseKeyB64 = Buffer.from(creds.noiseKey.public).toString('base64');
477
- const identityKeyB64 = Buffer.from(creds.signedIdentityKey.public).toString('base64');
478
- const advB64 = creds.advSecretKey;
479
- let qrMs = qrTimeout || 60000; // time to let a QR live
480
- const genPairQR = () => {
481
- if (!ws.isOpen) {
482
- return;
483
- }
484
- const refNode = refNodes.shift();
485
- if (!refNode) {
486
- end(new boom_1.Boom('QR refs attempts ended', { statusCode: Types_1.DisconnectReason.timedOut }));
487
- return;
488
- }
489
- const ref = refNode.content.toString('utf-8');
490
- const qr = [ref, noiseKeyB64, identityKeyB64, advB64].join(',');
491
- ev.emit('connection.update', { qr });
492
- qrTimer = setTimeout(genPairQR, qrMs);
493
- qrMs = qrTimeout || 20000; // shorter subsequent qrs
494
- };
495
- genPairQR();
496
- });
497
- // device paired for the first time
498
- // if device pairs successfully, the server asks to restart the connection
499
- ws.on('CB:iq,,pair-success', async (stanza) => {
500
- logger.debug('pair success recv');
501
- try {
502
- const { reply, creds: updatedCreds } = (0, Utils_1.configureSuccessfulPairing)(stanza, creds);
503
- logger.info({ me: updatedCreds.me, platform: updatedCreds.platform }, 'pairing configured successfully, expect to restart the connection...');
504
- ev.emit('creds.update', updatedCreds);
505
- ev.emit('connection.update', { isNewLogin: true, qr: undefined });
506
- await sendNode(reply);
507
- }
508
- catch (error) {
509
- logger.info({ trace: error.stack }, 'error in pairing');
510
- end(error);
511
- }
512
- });
513
- // login complete
514
- ws.on('CB:success', async (node) => {
515
- await uploadPreKeysToServerIfRequired();
516
- await sendPassiveIq('active');
517
- logger.info('opened connection to WA');
518
- clearTimeout(qrTimer); // will never happen in all likelyhood -- but just in case WA sends success on first try
519
- ev.emit('creds.update', { me: { ...authState.creds.me, lid: node.attrs.lid } });
520
- ev.emit('connection.update', { connection: 'open' });
521
- });
522
- ws.on('CB:stream:error', (node) => {
523
- logger.error({ node }, 'stream errored out');
524
- const { reason, statusCode } = (0, Utils_1.getErrorCodeFromStreamError)(node);
525
- end(new boom_1.Boom(`Stream Errored (${reason})`, { statusCode, data: node }));
526
- });
527
- // stream fail, possible logout
528
- ws.on('CB:failure', (node) => {
529
- const reason = +(node.attrs.reason || 500);
530
- end(new boom_1.Boom('Connection Failure', { statusCode: reason, data: node.attrs }));
531
- });
532
- ws.on('CB:ib,,downgrade_webclient', () => {
533
- end(new boom_1.Boom('Multi-device beta not joined', { statusCode: Types_1.DisconnectReason.multideviceMismatch }));
534
- });
535
- ws.on('CB:ib,,edge_routing', (node) => {
536
- const edgeRoutingNode = (0, WABinary_1.getBinaryNodeChild)(node, 'edge_routing');
537
- const routingInfo = (0, WABinary_1.getBinaryNodeChild)(edgeRoutingNode, 'routing_info');
538
- if (routingInfo === null || routingInfo === void 0 ? void 0 : routingInfo.content) {
539
- authState.creds.routingInfo = Buffer.from(routingInfo === null || routingInfo === void 0 ? void 0 : routingInfo.content);
540
- ev.emit('creds.update', authState.creds);
541
- }
542
- });
543
- let didStartBuffer = false;
544
- process.nextTick(() => {
545
- var _a;
546
- if ((_a = creds.me) === null || _a === void 0 ? void 0 : _a.id) {
547
- // start buffering important events
548
- // if we're logged in
549
- ev.buffer();
550
- didStartBuffer = true;
551
- }
552
- ev.emit('connection.update', { connection: 'connecting', receivedPendingNotifications: false, qr: undefined });
553
- });
554
- // called when all offline notifs are handled
555
- ws.on('CB:ib,,offline', (node) => {
556
- const child = (0, WABinary_1.getBinaryNodeChild)(node, 'offline');
557
- const offlineNotifs = +((child === null || child === void 0 ? void 0 : child.attrs.count) || 0);
558
- logger.info(`handled ${offlineNotifs} offline messages/notifications`);
559
- if (didStartBuffer) {
560
- ev.flush();
561
- logger.trace('flushed events for initial buffer');
562
- }
563
- ev.emit('connection.update', { receivedPendingNotifications: true });
564
- });
565
- // update credentials when required
566
- ev.on('creds.update', update => {
567
- var _a, _b;
568
- const name = (_a = update.me) === null || _a === void 0 ? void 0 : _a.name;
569
- // if name has just been received
570
- if (((_b = creds.me) === null || _b === void 0 ? void 0 : _b.name) !== name) {
571
- logger.debug({ name }, 'updated pushName');
572
- sendNode({
573
- tag: 'presence',
574
- attrs: { name: name }
575
- })
576
- .catch(err => {
577
- logger.warn({ trace: err.stack }, 'error in sending presence update on name change');
578
- });
579
- }
580
- Object.assign(creds, update);
581
- });
582
- if (printQRInTerminal) {
583
- (0, Utils_1.printQRIfNecessaryListener)(ev, logger);
584
- }
585
- return {
586
- type: 'md',
587
- ws,
588
- ev,
589
- authState: { creds, keys },
590
- signalRepository,
591
- get user() {
592
- return authState.creds.me;
593
- },
594
- generateMessageTag,
595
- query,
596
- waitForMessage,
597
- waitForSocketOpen,
598
- sendRawMessage,
599
- sendNode,
600
- logout,
601
- end,
602
- onUnexpectedError,
603
- uploadPreKeys,
604
- uploadPreKeysToServerIfRequired,
605
- requestPairingCode,
606
- /** Waits for the connection to WA to reach a state */
607
- waitForConnectionUpdate: (0, Utils_1.bindWaitForConnectionUpdate)(ev),
608
- sendWAMBuffer,
609
- };
610
- };
611
- exports.makeSocket = makeSocket;
612
- /**
613
- * map the websocket error to the right type
614
- * so it can be retried by the caller
615
- * */
616
- function mapWebSocketError(handler) {
617
- return (error) => {
618
- handler(new boom_1.Boom(`WebSocket Error (${error === null || error === void 0 ? void 0 : error.message})`, { statusCode: (0, Utils_1.getCodeFromWSError)(error), data: error }));
619
- };
620
- }
@@ -1,3 +0,0 @@
1
- import makeCacheManagerAuthState from './make-cache-manager-store';
2
- import makeInMemoryStore from './make-in-memory-store';
3
- export { makeInMemoryStore, makeCacheManagerAuthState };
@@ -1,10 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.makeCacheManagerAuthState = exports.makeInMemoryStore = void 0;
7
- const make_cache_manager_store_1 = __importDefault(require("./make-cache-manager-store"));
8
- exports.makeCacheManagerAuthState = make_cache_manager_store_1.default;
9
- const make_in_memory_store_1 = __importDefault(require("./make-in-memory-store"));
10
- exports.makeInMemoryStore = make_in_memory_store_1.default;
@@ -1,14 +0,0 @@
1
- import { Store } from 'cache-manager';
2
- import { AuthenticationCreds } from '../Types';
3
- declare const makeCacheManagerAuthState: (store: Store, sessionKey: string) => Promise<{
4
- clearState: () => Promise<void>;
5
- saveCreds: () => Promise<void>;
6
- state: {
7
- creds: AuthenticationCreds;
8
- keys: {
9
- get: (type: string, ids: string[]) => Promise<{}>;
10
- set: (data: any) => Promise<void>;
11
- };
12
- };
13
- }>;
14
- export default makeCacheManagerAuthState;