@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,740 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.processSyncAction = exports.chatModificationToAppPatch = exports.decodePatches = exports.decodeSyncdSnapshot = exports.downloadExternalPatch = exports.downloadExternalBlob = exports.extractSyncdPatches = exports.decodeSyncdPatch = exports.decodeSyncdMutations = exports.encodeSyncdPatch = exports.newLTHashState = void 0;
4
- const boom_1 = require("@hapi/boom");
5
- const WAProto_1 = require("../../WAProto");
6
- const LabelAssociation_1 = require("../Types/LabelAssociation");
7
- const WABinary_1 = require("../WABinary");
8
- const crypto_1 = require("./crypto");
9
- const generics_1 = require("./generics");
10
- const lt_hash_1 = require("./lt-hash");
11
- const messages_media_1 = require("./messages-media");
12
- const mutationKeys = (keydata) => {
13
- const expanded = (0, crypto_1.hkdf)(keydata, 160, { info: 'WhatsApp Mutation Keys' });
14
- return {
15
- indexKey: expanded.slice(0, 32),
16
- valueEncryptionKey: expanded.slice(32, 64),
17
- valueMacKey: expanded.slice(64, 96),
18
- snapshotMacKey: expanded.slice(96, 128),
19
- patchMacKey: expanded.slice(128, 160)
20
- };
21
- };
22
- const generateMac = (operation, data, keyId, key) => {
23
- const getKeyData = () => {
24
- let r;
25
- switch (operation) {
26
- case WAProto_1.proto.SyncdMutation.SyncdOperation.SET:
27
- r = 0x01;
28
- break;
29
- case WAProto_1.proto.SyncdMutation.SyncdOperation.REMOVE:
30
- r = 0x02;
31
- break;
32
- }
33
- const buff = Buffer.from([r]);
34
- return Buffer.concat([buff, Buffer.from(keyId, 'base64')]);
35
- };
36
- const keyData = getKeyData();
37
- const last = Buffer.alloc(8); // 8 bytes
38
- last.set([keyData.length], last.length - 1);
39
- const total = Buffer.concat([keyData, data, last]);
40
- const hmac = (0, crypto_1.hmacSign)(total, key, 'sha512');
41
- return hmac.slice(0, 32);
42
- };
43
- const to64BitNetworkOrder = (e) => {
44
- const buff = Buffer.alloc(8);
45
- buff.writeUint32BE(e, 4);
46
- return buff;
47
- };
48
- const makeLtHashGenerator = ({ indexValueMap, hash }) => {
49
- indexValueMap = { ...indexValueMap };
50
- const addBuffs = [];
51
- const subBuffs = [];
52
- return {
53
- mix: ({ indexMac, valueMac, operation }) => {
54
- const indexMacBase64 = Buffer.from(indexMac).toString('base64');
55
- const prevOp = indexValueMap[indexMacBase64];
56
- if (operation === WAProto_1.proto.SyncdMutation.SyncdOperation.REMOVE) {
57
- if (!prevOp) {
58
- throw new boom_1.Boom('tried remove, but no previous op', { data: { indexMac, valueMac } });
59
- }
60
- // remove from index value mac, since this mutation is erased
61
- delete indexValueMap[indexMacBase64];
62
- }
63
- else {
64
- addBuffs.push(new Uint8Array(valueMac).buffer);
65
- // add this index into the history map
66
- indexValueMap[indexMacBase64] = { valueMac };
67
- }
68
- if (prevOp) {
69
- subBuffs.push(new Uint8Array(prevOp.valueMac).buffer);
70
- }
71
- },
72
- finish: () => {
73
- const hashArrayBuffer = new Uint8Array(hash).buffer;
74
- const result = lt_hash_1.LT_HASH_ANTI_TAMPERING.subtractThenAdd(hashArrayBuffer, addBuffs, subBuffs);
75
- const buffer = Buffer.from(result);
76
- return {
77
- hash: buffer,
78
- indexValueMap
79
- };
80
- }
81
- };
82
- };
83
- const generateSnapshotMac = (lthash, version, name, key) => {
84
- const total = Buffer.concat([
85
- lthash,
86
- to64BitNetworkOrder(version),
87
- Buffer.from(name, 'utf-8')
88
- ]);
89
- return (0, crypto_1.hmacSign)(total, key, 'sha256');
90
- };
91
- const generatePatchMac = (snapshotMac, valueMacs, version, type, key) => {
92
- const total = Buffer.concat([
93
- snapshotMac,
94
- ...valueMacs,
95
- to64BitNetworkOrder(version),
96
- Buffer.from(type, 'utf-8')
97
- ]);
98
- return (0, crypto_1.hmacSign)(total, key);
99
- };
100
- const newLTHashState = () => ({ version: 0, hash: Buffer.alloc(128), indexValueMap: {} });
101
- exports.newLTHashState = newLTHashState;
102
- const encodeSyncdPatch = async ({ type, index, syncAction, apiVersion, operation }, myAppStateKeyId, state, getAppStateSyncKey) => {
103
- const key = !!myAppStateKeyId ? await getAppStateSyncKey(myAppStateKeyId) : undefined;
104
- if (!key) {
105
- throw new boom_1.Boom(`myAppStateKey ("${myAppStateKeyId}") not present`, { statusCode: 404 });
106
- }
107
- const encKeyId = Buffer.from(myAppStateKeyId, 'base64');
108
- state = { ...state, indexValueMap: { ...state.indexValueMap } };
109
- const indexBuffer = Buffer.from(JSON.stringify(index));
110
- const dataProto = WAProto_1.proto.SyncActionData.fromObject({
111
- index: indexBuffer,
112
- value: syncAction,
113
- padding: new Uint8Array(0),
114
- version: apiVersion
115
- });
116
- const encoded = WAProto_1.proto.SyncActionData.encode(dataProto).finish();
117
- const keyValue = mutationKeys(key.keyData);
118
- const encValue = (0, crypto_1.aesEncrypt)(encoded, keyValue.valueEncryptionKey);
119
- const valueMac = generateMac(operation, encValue, encKeyId, keyValue.valueMacKey);
120
- const indexMac = (0, crypto_1.hmacSign)(indexBuffer, keyValue.indexKey);
121
- // update LT hash
122
- const generator = makeLtHashGenerator(state);
123
- generator.mix({ indexMac, valueMac, operation });
124
- Object.assign(state, generator.finish());
125
- state.version += 1;
126
- const snapshotMac = generateSnapshotMac(state.hash, state.version, type, keyValue.snapshotMacKey);
127
- const patch = {
128
- patchMac: generatePatchMac(snapshotMac, [valueMac], state.version, type, keyValue.patchMacKey),
129
- snapshotMac: snapshotMac,
130
- keyId: { id: encKeyId },
131
- mutations: [
132
- {
133
- operation: operation,
134
- record: {
135
- index: {
136
- blob: indexMac
137
- },
138
- value: {
139
- blob: Buffer.concat([encValue, valueMac])
140
- },
141
- keyId: { id: encKeyId }
142
- }
143
- }
144
- ]
145
- };
146
- const base64Index = indexMac.toString('base64');
147
- state.indexValueMap[base64Index] = { valueMac };
148
- return { patch, state };
149
- };
150
- exports.encodeSyncdPatch = encodeSyncdPatch;
151
- const decodeSyncdMutations = async (msgMutations, initialState, getAppStateSyncKey, onMutation, validateMacs) => {
152
- const ltGenerator = makeLtHashGenerator(initialState);
153
- // indexKey used to HMAC sign record.index.blob
154
- // valueEncryptionKey used to AES-256-CBC encrypt record.value.blob[0:-32]
155
- // the remaining record.value.blob[0:-32] is the mac, it the HMAC sign of key.keyId + decoded proto data + length of bytes in keyId
156
- for (const msgMutation of msgMutations) {
157
- // if it's a syncdmutation, get the operation property
158
- // otherwise, if it's only a record -- it'll be a SET mutation
159
- const operation = 'operation' in msgMutation ? msgMutation.operation : WAProto_1.proto.SyncdMutation.SyncdOperation.SET;
160
- const record = ('record' in msgMutation && !!msgMutation.record) ? msgMutation.record : msgMutation;
161
- const key = await getKey(record.keyId.id);
162
- const content = Buffer.from(record.value.blob);
163
- const encContent = content.slice(0, -32);
164
- const ogValueMac = content.slice(-32);
165
- if (validateMacs) {
166
- const contentHmac = generateMac(operation, encContent, record.keyId.id, key.valueMacKey);
167
- if (Buffer.compare(contentHmac, ogValueMac) !== 0) {
168
- throw new boom_1.Boom('HMAC content verification failed');
169
- }
170
- }
171
- const result = (0, crypto_1.aesDecrypt)(encContent, key.valueEncryptionKey);
172
- const syncAction = WAProto_1.proto.SyncActionData.decode(result);
173
- if (validateMacs) {
174
- const hmac = (0, crypto_1.hmacSign)(syncAction.index, key.indexKey);
175
- if (Buffer.compare(hmac, record.index.blob) !== 0) {
176
- throw new boom_1.Boom('HMAC index verification failed');
177
- }
178
- }
179
- const indexStr = Buffer.from(syncAction.index).toString();
180
- onMutation({ syncAction, index: JSON.parse(indexStr) });
181
- ltGenerator.mix({
182
- indexMac: record.index.blob,
183
- valueMac: ogValueMac,
184
- operation: operation
185
- });
186
- }
187
- return ltGenerator.finish();
188
- async function getKey(keyId) {
189
- const base64Key = Buffer.from(keyId).toString('base64');
190
- const keyEnc = await getAppStateSyncKey(base64Key);
191
- if (!keyEnc) {
192
- throw new boom_1.Boom(`failed to find key "${base64Key}" to decode mutation`, { statusCode: 404, data: { msgMutations } });
193
- }
194
- return mutationKeys(keyEnc.keyData);
195
- }
196
- };
197
- exports.decodeSyncdMutations = decodeSyncdMutations;
198
- const decodeSyncdPatch = async (msg, name, initialState, getAppStateSyncKey, onMutation, validateMacs) => {
199
- if (validateMacs) {
200
- const base64Key = Buffer.from(msg.keyId.id).toString('base64');
201
- const mainKeyObj = await getAppStateSyncKey(base64Key);
202
- if (!mainKeyObj) {
203
- throw new boom_1.Boom(`failed to find key "${base64Key}" to decode patch`, { statusCode: 404, data: { msg } });
204
- }
205
- const mainKey = mutationKeys(mainKeyObj.keyData);
206
- const mutationmacs = msg.mutations.map(mutation => mutation.record.value.blob.slice(-32));
207
- const patchMac = generatePatchMac(msg.snapshotMac, mutationmacs, (0, generics_1.toNumber)(msg.version.version), name, mainKey.patchMacKey);
208
- if (Buffer.compare(patchMac, msg.patchMac) !== 0) {
209
- throw new boom_1.Boom('Invalid patch mac');
210
- }
211
- }
212
- const result = await (0, exports.decodeSyncdMutations)(msg.mutations, initialState, getAppStateSyncKey, onMutation, validateMacs);
213
- return result;
214
- };
215
- exports.decodeSyncdPatch = decodeSyncdPatch;
216
- const extractSyncdPatches = async (result, options) => {
217
- const syncNode = (0, WABinary_1.getBinaryNodeChild)(result, 'sync');
218
- const collectionNodes = (0, WABinary_1.getBinaryNodeChildren)(syncNode, 'collection');
219
- const final = {};
220
- await Promise.all(collectionNodes.map(async (collectionNode) => {
221
- const patchesNode = (0, WABinary_1.getBinaryNodeChild)(collectionNode, 'patches');
222
- const patches = (0, WABinary_1.getBinaryNodeChildren)(patchesNode || collectionNode, 'patch');
223
- const snapshotNode = (0, WABinary_1.getBinaryNodeChild)(collectionNode, 'snapshot');
224
- const syncds = [];
225
- const name = collectionNode.attrs.name;
226
- const hasMorePatches = collectionNode.attrs.has_more_patches === 'true';
227
- let snapshot = undefined;
228
- if (snapshotNode && !!snapshotNode.content) {
229
- if (!Buffer.isBuffer(snapshotNode)) {
230
- snapshotNode.content = Buffer.from(Object.values(snapshotNode.content));
231
- }
232
- const blobRef = WAProto_1.proto.ExternalBlobReference.decode(snapshotNode.content);
233
- const data = await (0, exports.downloadExternalBlob)(blobRef, options);
234
- snapshot = WAProto_1.proto.SyncdSnapshot.decode(data);
235
- }
236
- for (let { content } of patches) {
237
- if (content) {
238
- if (!Buffer.isBuffer(content)) {
239
- content = Buffer.from(Object.values(content));
240
- }
241
- const syncd = WAProto_1.proto.SyncdPatch.decode(content);
242
- if (!syncd.version) {
243
- syncd.version = { version: +collectionNode.attrs.version + 1 };
244
- }
245
- syncds.push(syncd);
246
- }
247
- }
248
- final[name] = { patches: syncds, hasMorePatches, snapshot };
249
- }));
250
- return final;
251
- };
252
- exports.extractSyncdPatches = extractSyncdPatches;
253
- const downloadExternalBlob = async (blob, options) => {
254
- const stream = await (0, messages_media_1.downloadContentFromMessage)(blob, 'md-app-state', { options });
255
- const bufferArray = [];
256
- for await (const chunk of stream) {
257
- bufferArray.push(chunk);
258
- }
259
- return Buffer.concat(bufferArray);
260
- };
261
- exports.downloadExternalBlob = downloadExternalBlob;
262
- const downloadExternalPatch = async (blob, options) => {
263
- const buffer = await (0, exports.downloadExternalBlob)(blob, options);
264
- const syncData = WAProto_1.proto.SyncdMutations.decode(buffer);
265
- return syncData;
266
- };
267
- exports.downloadExternalPatch = downloadExternalPatch;
268
- const decodeSyncdSnapshot = async (name, snapshot, getAppStateSyncKey, minimumVersionNumber, validateMacs = true) => {
269
- const newState = (0, exports.newLTHashState)();
270
- newState.version = (0, generics_1.toNumber)(snapshot.version.version);
271
- const mutationMap = {};
272
- const areMutationsRequired = typeof minimumVersionNumber === 'undefined'
273
- || newState.version > minimumVersionNumber;
274
- const { hash, indexValueMap } = await (0, exports.decodeSyncdMutations)(snapshot.records, newState, getAppStateSyncKey, areMutationsRequired
275
- ? (mutation) => {
276
- var _a;
277
- const index = (_a = mutation.syncAction.index) === null || _a === void 0 ? void 0 : _a.toString();
278
- mutationMap[index] = mutation;
279
- }
280
- : () => { }, validateMacs);
281
- newState.hash = hash;
282
- newState.indexValueMap = indexValueMap;
283
- if (validateMacs) {
284
- const base64Key = Buffer.from(snapshot.keyId.id).toString('base64');
285
- const keyEnc = await getAppStateSyncKey(base64Key);
286
- if (!keyEnc) {
287
- throw new boom_1.Boom(`failed to find key "${base64Key}" to decode mutation`);
288
- }
289
- const result = mutationKeys(keyEnc.keyData);
290
- const computedSnapshotMac = generateSnapshotMac(newState.hash, newState.version, name, result.snapshotMacKey);
291
- if (Buffer.compare(snapshot.mac, computedSnapshotMac) !== 0) {
292
- throw new boom_1.Boom(`failed to verify LTHash at ${newState.version} of ${name} from snapshot`);
293
- }
294
- }
295
- return {
296
- state: newState,
297
- mutationMap
298
- };
299
- };
300
- exports.decodeSyncdSnapshot = decodeSyncdSnapshot;
301
- const decodePatches = async (name, syncds, initial, getAppStateSyncKey, options, minimumVersionNumber, logger, validateMacs = true) => {
302
- var _a;
303
- const newState = {
304
- ...initial,
305
- indexValueMap: { ...initial.indexValueMap }
306
- };
307
- const mutationMap = {};
308
- for (let i = 0; i < syncds.length; i++) {
309
- const syncd = syncds[i];
310
- const { version, keyId, snapshotMac } = syncd;
311
- if (syncd.externalMutations) {
312
- logger === null || logger === void 0 ? void 0 : logger.trace({ name, version }, 'downloading external patch');
313
- const ref = await (0, exports.downloadExternalPatch)(syncd.externalMutations, options);
314
- logger === null || logger === void 0 ? void 0 : logger.debug({ name, version, mutations: ref.mutations.length }, 'downloaded external patch');
315
- (_a = syncd.mutations) === null || _a === void 0 ? void 0 : _a.push(...ref.mutations);
316
- }
317
- const patchVersion = (0, generics_1.toNumber)(version.version);
318
- newState.version = patchVersion;
319
- const shouldMutate = typeof minimumVersionNumber === 'undefined' || patchVersion > minimumVersionNumber;
320
- const decodeResult = await (0, exports.decodeSyncdPatch)(syncd, name, newState, getAppStateSyncKey, shouldMutate
321
- ? mutation => {
322
- var _a;
323
- const index = (_a = mutation.syncAction.index) === null || _a === void 0 ? void 0 : _a.toString();
324
- mutationMap[index] = mutation;
325
- }
326
- : (() => { }), true);
327
- newState.hash = decodeResult.hash;
328
- newState.indexValueMap = decodeResult.indexValueMap;
329
- if (validateMacs) {
330
- const base64Key = Buffer.from(keyId.id).toString('base64');
331
- const keyEnc = await getAppStateSyncKey(base64Key);
332
- if (!keyEnc) {
333
- throw new boom_1.Boom(`failed to find key "${base64Key}" to decode mutation`);
334
- }
335
- const result = mutationKeys(keyEnc.keyData);
336
- const computedSnapshotMac = generateSnapshotMac(newState.hash, newState.version, name, result.snapshotMacKey);
337
- if (Buffer.compare(snapshotMac, computedSnapshotMac) !== 0) {
338
- throw new boom_1.Boom(`failed to verify LTHash at ${newState.version} of ${name}`);
339
- }
340
- }
341
- // clear memory used up by the mutations
342
- syncd.mutations = [];
343
- }
344
- return { state: newState, mutationMap };
345
- };
346
- exports.decodePatches = decodePatches;
347
- const chatModificationToAppPatch = (mod, jid) => {
348
- const OP = WAProto_1.proto.SyncdMutation.SyncdOperation;
349
- const getMessageRange = (lastMessages) => {
350
- let messageRange;
351
- if (Array.isArray(lastMessages)) {
352
- const lastMsg = lastMessages[lastMessages.length - 1];
353
- messageRange = {
354
- lastMessageTimestamp: lastMsg === null || lastMsg === void 0 ? void 0 : lastMsg.messageTimestamp,
355
- messages: (lastMessages === null || lastMessages === void 0 ? void 0 : lastMessages.length) ? lastMessages.map(m => {
356
- var _a, _b;
357
- if (!((_a = m.key) === null || _a === void 0 ? void 0 : _a.id) || !((_b = m.key) === null || _b === void 0 ? void 0 : _b.remoteJid)) {
358
- throw new boom_1.Boom('Incomplete key', { statusCode: 400, data: m });
359
- }
360
- if ((0, WABinary_1.isJidGroup)(m.key.remoteJid) && !m.key.fromMe && !m.key.participant) {
361
- throw new boom_1.Boom('Expected not from me message to have participant', { statusCode: 400, data: m });
362
- }
363
- if (!m.messageTimestamp || !(0, generics_1.toNumber)(m.messageTimestamp)) {
364
- throw new boom_1.Boom('Missing timestamp in last message list', { statusCode: 400, data: m });
365
- }
366
- if (m.key.participant) {
367
- m.key.participant = (0, WABinary_1.jidNormalizedUser)(m.key.participant);
368
- }
369
- return m;
370
- }) : undefined
371
- };
372
- }
373
- else {
374
- messageRange = lastMessages;
375
- }
376
- return messageRange;
377
- };
378
- let patch;
379
- if ('mute' in mod) {
380
- patch = {
381
- syncAction: {
382
- muteAction: {
383
- muted: !!mod.mute,
384
- muteEndTimestamp: mod.mute || undefined
385
- }
386
- },
387
- index: ['mute', jid],
388
- type: 'regular_high',
389
- apiVersion: 2,
390
- operation: OP.SET
391
- };
392
- }
393
- else if ('archive' in mod) {
394
- patch = {
395
- syncAction: {
396
- archiveChatAction: {
397
- archived: !!mod.archive,
398
- messageRange: getMessageRange(mod.lastMessages)
399
- }
400
- },
401
- index: ['archive', jid],
402
- type: 'regular_low',
403
- apiVersion: 3,
404
- operation: OP.SET
405
- };
406
- }
407
- else if ('markRead' in mod) {
408
- patch = {
409
- syncAction: {
410
- markChatAsReadAction: {
411
- read: mod.markRead,
412
- messageRange: getMessageRange(mod.lastMessages)
413
- }
414
- },
415
- index: ['markChatAsRead', jid],
416
- type: 'regular_low',
417
- apiVersion: 3,
418
- operation: OP.SET
419
- };
420
- }
421
- else if ('clear' in mod) {
422
- if (mod.clear === 'all') {
423
- throw new boom_1.Boom('not supported');
424
- }
425
- else {
426
- const key = mod.clear.messages[0];
427
- patch = {
428
- syncAction: {
429
- deleteMessageForMeAction: {
430
- deleteMedia: false,
431
- messageTimestamp: key.timestamp
432
- }
433
- },
434
- index: ['deleteMessageForMe', jid, key.id, key.fromMe ? '1' : '0', '0'],
435
- type: 'regular_high',
436
- apiVersion: 3,
437
- operation: OP.SET
438
- };
439
- }
440
- }
441
- else if ('pin' in mod) {
442
- patch = {
443
- syncAction: {
444
- pinAction: {
445
- pinned: !!mod.pin
446
- }
447
- },
448
- index: ['pin_v1', jid],
449
- type: 'regular_low',
450
- apiVersion: 5,
451
- operation: OP.SET
452
- };
453
- }
454
- else if ('star' in mod) {
455
- const key = mod.star.messages[0];
456
- patch = {
457
- syncAction: {
458
- starAction: {
459
- starred: !!mod.star.star
460
- }
461
- },
462
- index: ['star', jid, key.id, key.fromMe ? '1' : '0', '0'],
463
- type: 'regular_low',
464
- apiVersion: 2,
465
- operation: OP.SET
466
- };
467
- }
468
- else if ('delete' in mod) {
469
- patch = {
470
- syncAction: {
471
- deleteChatAction: {
472
- messageRange: getMessageRange(mod.lastMessages),
473
- }
474
- },
475
- index: ['deleteChat', jid, '1'],
476
- type: 'regular_high',
477
- apiVersion: 6,
478
- operation: OP.SET
479
- };
480
- }
481
- else if ('pushNameSetting' in mod) {
482
- patch = {
483
- syncAction: {
484
- pushNameSetting: {
485
- name: mod.pushNameSetting
486
- }
487
- },
488
- index: ['setting_pushName'],
489
- type: 'critical_block',
490
- apiVersion: 1,
491
- operation: OP.SET,
492
- };
493
- }
494
- else if ('addLabel' in mod) {
495
- patch = {
496
- syncAction: {
497
- labelEditAction: {
498
- name: mod.addLabel.name,
499
- color: mod.addLabel.color,
500
- predefinedId: mod.addLabel.predefinedId,
501
- deleted: mod.addLabel.deleted
502
- }
503
- },
504
- index: ['label_edit', mod.addLabel.id],
505
- type: 'regular',
506
- apiVersion: 3,
507
- operation: OP.SET,
508
- };
509
- }
510
- else if ('addChatLabel' in mod) {
511
- patch = {
512
- syncAction: {
513
- labelAssociationAction: {
514
- labeled: true,
515
- }
516
- },
517
- index: [LabelAssociation_1.LabelAssociationType.Chat, mod.addChatLabel.labelId, jid],
518
- type: 'regular',
519
- apiVersion: 3,
520
- operation: OP.SET,
521
- };
522
- }
523
- else if ('removeChatLabel' in mod) {
524
- patch = {
525
- syncAction: {
526
- labelAssociationAction: {
527
- labeled: false,
528
- }
529
- },
530
- index: [LabelAssociation_1.LabelAssociationType.Chat, mod.removeChatLabel.labelId, jid],
531
- type: 'regular',
532
- apiVersion: 3,
533
- operation: OP.SET,
534
- };
535
- }
536
- else if ('addMessageLabel' in mod) {
537
- patch = {
538
- syncAction: {
539
- labelAssociationAction: {
540
- labeled: true,
541
- }
542
- },
543
- index: [
544
- LabelAssociation_1.LabelAssociationType.Message,
545
- mod.addMessageLabel.labelId,
546
- jid,
547
- mod.addMessageLabel.messageId,
548
- '0',
549
- '0'
550
- ],
551
- type: 'regular',
552
- apiVersion: 3,
553
- operation: OP.SET,
554
- };
555
- }
556
- else if ('removeMessageLabel' in mod) {
557
- patch = {
558
- syncAction: {
559
- labelAssociationAction: {
560
- labeled: false,
561
- }
562
- },
563
- index: [
564
- LabelAssociation_1.LabelAssociationType.Message,
565
- mod.removeMessageLabel.labelId,
566
- jid,
567
- mod.removeMessageLabel.messageId,
568
- '0',
569
- '0'
570
- ],
571
- type: 'regular',
572
- apiVersion: 3,
573
- operation: OP.SET,
574
- };
575
- }
576
- else {
577
- throw new boom_1.Boom('not supported');
578
- }
579
- patch.syncAction.timestamp = Date.now();
580
- return patch;
581
- };
582
- exports.chatModificationToAppPatch = chatModificationToAppPatch;
583
- const processSyncAction = (syncAction, ev, me, initialSyncOpts, logger) => {
584
- var _a, _b, _c, _d;
585
- const isInitialSync = !!initialSyncOpts;
586
- const accountSettings = initialSyncOpts === null || initialSyncOpts === void 0 ? void 0 : initialSyncOpts.accountSettings;
587
- logger === null || logger === void 0 ? void 0 : logger.trace({ syncAction, initialSync: !!initialSyncOpts }, 'processing sync action');
588
- const { syncAction: { value: action }, index: [type, id, msgId, fromMe] } = syncAction;
589
- if (action === null || action === void 0 ? void 0 : action.muteAction) {
590
- ev.emit('chats.update', [
591
- {
592
- id,
593
- muteEndTime: ((_a = action.muteAction) === null || _a === void 0 ? void 0 : _a.muted)
594
- ? (0, generics_1.toNumber)(action.muteAction.muteEndTimestamp)
595
- : null,
596
- conditional: getChatUpdateConditional(id, undefined)
597
- }
598
- ]);
599
- }
600
- else if ((action === null || action === void 0 ? void 0 : action.archiveChatAction) || type === 'archive' || type === 'unarchive') {
601
- // okay so we've to do some annoying computation here
602
- // when we're initially syncing the app state
603
- // there are a few cases we need to handle
604
- // 1. if the account unarchiveChats setting is true
605
- // a. if the chat is archived, and no further messages have been received -- simple, keep archived
606
- // b. if the chat was archived, and the user received messages from the other person afterwards
607
- // then the chat should be marked unarchved --
608
- // we compare the timestamp of latest message from the other person to determine this
609
- // 2. if the account unarchiveChats setting is false -- then it doesn't matter,
610
- // it'll always take an app state action to mark in unarchived -- which we'll get anyway
611
- const archiveAction = action === null || action === void 0 ? void 0 : action.archiveChatAction;
612
- const isArchived = archiveAction
613
- ? archiveAction.archived
614
- : type === 'archive';
615
- // // basically we don't need to fire an "archive" update if the chat is being marked unarchvied
616
- // // this only applies for the initial sync
617
- // if(isInitialSync && !isArchived) {
618
- // isArchived = false
619
- // }
620
- const msgRange = !(accountSettings === null || accountSettings === void 0 ? void 0 : accountSettings.unarchiveChats) ? undefined : archiveAction === null || archiveAction === void 0 ? void 0 : archiveAction.messageRange;
621
- // logger?.debug({ chat: id, syncAction }, 'message range archive')
622
- ev.emit('chats.update', [{
623
- id,
624
- archived: isArchived,
625
- conditional: getChatUpdateConditional(id, msgRange)
626
- }]);
627
- }
628
- else if (action === null || action === void 0 ? void 0 : action.markChatAsReadAction) {
629
- const markReadAction = action.markChatAsReadAction;
630
- // basically we don't need to fire an "read" update if the chat is being marked as read
631
- // because the chat is read by default
632
- // this only applies for the initial sync
633
- const isNullUpdate = isInitialSync && markReadAction.read;
634
- ev.emit('chats.update', [{
635
- id,
636
- unreadCount: isNullUpdate ? null : !!(markReadAction === null || markReadAction === void 0 ? void 0 : markReadAction.read) ? 0 : -1,
637
- conditional: getChatUpdateConditional(id, markReadAction === null || markReadAction === void 0 ? void 0 : markReadAction.messageRange)
638
- }]);
639
- }
640
- else if ((action === null || action === void 0 ? void 0 : action.deleteMessageForMeAction) || type === 'deleteMessageForMe') {
641
- ev.emit('messages.delete', {
642
- keys: [
643
- {
644
- remoteJid: id,
645
- id: msgId,
646
- fromMe: fromMe === '1'
647
- }
648
- ]
649
- });
650
- }
651
- else if (action === null || action === void 0 ? void 0 : action.contactAction) {
652
- ev.emit('contacts.upsert', [{ id, name: action.contactAction.fullName }]);
653
- }
654
- else if (action === null || action === void 0 ? void 0 : action.pushNameSetting) {
655
- const name = (_b = action === null || action === void 0 ? void 0 : action.pushNameSetting) === null || _b === void 0 ? void 0 : _b.name;
656
- if (name && (me === null || me === void 0 ? void 0 : me.name) !== name) {
657
- ev.emit('creds.update', { me: { ...me, name } });
658
- }
659
- }
660
- else if (action === null || action === void 0 ? void 0 : action.pinAction) {
661
- ev.emit('chats.update', [{
662
- id,
663
- pinned: ((_c = action.pinAction) === null || _c === void 0 ? void 0 : _c.pinned) ? (0, generics_1.toNumber)(action.timestamp) : null,
664
- conditional: getChatUpdateConditional(id, undefined)
665
- }]);
666
- }
667
- else if (action === null || action === void 0 ? void 0 : action.unarchiveChatsSetting) {
668
- const unarchiveChats = !!action.unarchiveChatsSetting.unarchiveChats;
669
- ev.emit('creds.update', { accountSettings: { unarchiveChats } });
670
- logger === null || logger === void 0 ? void 0 : logger.info(`archive setting updated => '${action.unarchiveChatsSetting.unarchiveChats}'`);
671
- if (accountSettings) {
672
- accountSettings.unarchiveChats = unarchiveChats;
673
- }
674
- }
675
- else if ((action === null || action === void 0 ? void 0 : action.starAction) || type === 'star') {
676
- let starred = (_d = action === null || action === void 0 ? void 0 : action.starAction) === null || _d === void 0 ? void 0 : _d.starred;
677
- if (typeof starred !== 'boolean') {
678
- starred = syncAction.index[syncAction.index.length - 1] === '1';
679
- }
680
- ev.emit('messages.update', [
681
- {
682
- key: { remoteJid: id, id: msgId, fromMe: fromMe === '1' },
683
- update: { starred }
684
- }
685
- ]);
686
- }
687
- else if ((action === null || action === void 0 ? void 0 : action.deleteChatAction) || type === 'deleteChat') {
688
- if (!isInitialSync) {
689
- ev.emit('chats.delete', [id]);
690
- }
691
- }
692
- else if (action === null || action === void 0 ? void 0 : action.labelEditAction) {
693
- const { name, color, deleted, predefinedId } = action.labelEditAction;
694
- ev.emit('labels.edit', {
695
- id,
696
- name: name,
697
- color: color,
698
- deleted: deleted,
699
- predefinedId: predefinedId ? String(predefinedId) : undefined
700
- });
701
- }
702
- else if (action === null || action === void 0 ? void 0 : action.labelAssociationAction) {
703
- ev.emit('labels.association', {
704
- type: action.labelAssociationAction.labeled
705
- ? 'add'
706
- : 'remove',
707
- association: type === LabelAssociation_1.LabelAssociationType.Chat
708
- ? {
709
- type: LabelAssociation_1.LabelAssociationType.Chat,
710
- chatId: syncAction.index[2],
711
- labelId: syncAction.index[1]
712
- }
713
- : {
714
- type: LabelAssociation_1.LabelAssociationType.Message,
715
- chatId: syncAction.index[2],
716
- messageId: syncAction.index[3],
717
- labelId: syncAction.index[1]
718
- }
719
- });
720
- }
721
- else {
722
- logger === null || logger === void 0 ? void 0 : logger.debug({ syncAction, id }, 'unprocessable update');
723
- }
724
- function getChatUpdateConditional(id, msgRange) {
725
- return isInitialSync
726
- ? (data) => {
727
- const chat = data.historySets.chats[id] || data.chatUpserts[id];
728
- if (chat) {
729
- return msgRange ? isValidPatchBasedOnMessageRange(chat, msgRange) : true;
730
- }
731
- }
732
- : undefined;
733
- }
734
- function isValidPatchBasedOnMessageRange(chat, msgRange) {
735
- const lastMsgTimestamp = Number((msgRange === null || msgRange === void 0 ? void 0 : msgRange.lastMessageTimestamp) || (msgRange === null || msgRange === void 0 ? void 0 : msgRange.lastSystemMessageTimestamp) || 0);
736
- const chatLastMsgTimestamp = Number((chat === null || chat === void 0 ? void 0 : chat.lastMessageRecvTimestamp) || 0);
737
- return lastMsgTimestamp >= chatLastMsgTimestamp;
738
- }
739
- };
740
- exports.processSyncAction = processSyncAction;