seyfert 1.4.0 → 2.0.0

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 (433) hide show
  1. package/LICENSE +21 -190
  2. package/README.md +22 -14
  3. package/lib/api/Router.js +5 -3
  4. package/lib/api/Routes/applications.d.ts +23 -1
  5. package/lib/api/Routes/channels.d.ts +1 -1
  6. package/lib/api/Routes/gateway.d.ts +1 -1
  7. package/lib/api/Routes/guilds.d.ts +8 -2
  8. package/lib/api/Routes/interactions.d.ts +1 -1
  9. package/lib/api/Routes/invites.d.ts +1 -1
  10. package/lib/api/Routes/stage-instances.d.ts +1 -1
  11. package/lib/api/Routes/stickers.d.ts +2 -2
  12. package/lib/api/Routes/users.d.ts +1 -1
  13. package/lib/api/Routes/voice.d.ts +1 -1
  14. package/lib/api/Routes/webhooks.d.ts +2 -2
  15. package/lib/api/api.d.ts +2 -2
  16. package/lib/api/api.js +2 -14
  17. package/lib/api/bucket.d.ts +0 -1
  18. package/lib/api/shared.d.ts +0 -1
  19. package/lib/api/utils/constants.d.ts +2 -5
  20. package/lib/api/utils/constants.js +3 -7
  21. package/lib/api/utils/utils.d.ts +1 -2
  22. package/lib/api/utils/utils.js +2 -3
  23. package/lib/builders/ActionRow.d.ts +1 -1
  24. package/lib/builders/ActionRow.js +3 -3
  25. package/lib/builders/Attachment.d.ts +2 -3
  26. package/lib/builders/Attachment.js +12 -13
  27. package/lib/builders/Base.d.ts +2 -2
  28. package/lib/builders/Base.js +1 -1
  29. package/lib/builders/Button.d.ts +7 -7
  30. package/lib/builders/Button.js +11 -9
  31. package/lib/builders/Embed.d.ts +1 -1
  32. package/lib/builders/Modal.d.ts +1 -1
  33. package/lib/builders/Modal.js +2 -2
  34. package/lib/builders/Poll.d.ts +2 -2
  35. package/lib/builders/Poll.js +5 -6
  36. package/lib/builders/SelectMenu.d.ts +1 -1
  37. package/lib/builders/SelectMenu.js +17 -18
  38. package/lib/builders/index.d.ts +1 -1
  39. package/lib/builders/index.js +10 -11
  40. package/lib/cache/adapters/default.d.ts +16 -9
  41. package/lib/cache/adapters/default.js +42 -31
  42. package/lib/cache/adapters/index.d.ts +0 -1
  43. package/lib/cache/adapters/index.js +0 -1
  44. package/lib/cache/adapters/limited.d.ts +17 -12
  45. package/lib/cache/adapters/limited.js +80 -36
  46. package/lib/cache/adapters/types.d.ts +6 -7
  47. package/lib/cache/adapters/workeradapter.d.ts +6 -6
  48. package/lib/cache/adapters/workeradapter.js +13 -0
  49. package/lib/cache/index.d.ts +24 -11
  50. package/lib/cache/index.js +335 -19
  51. package/lib/cache/resources/bans.d.ts +15 -0
  52. package/lib/cache/resources/bans.js +44 -0
  53. package/lib/cache/resources/channels.d.ts +6 -4
  54. package/lib/cache/resources/channels.js +13 -7
  55. package/lib/cache/resources/default/base.d.ts +7 -7
  56. package/lib/cache/resources/default/base.js +2 -2
  57. package/lib/cache/resources/default/guild-based.d.ts +6 -6
  58. package/lib/cache/resources/default/guild-based.js +6 -6
  59. package/lib/cache/resources/default/guild-related.d.ts +7 -7
  60. package/lib/cache/resources/default/guild-related.js +10 -8
  61. package/lib/cache/resources/emojis.d.ts +15 -6
  62. package/lib/cache/resources/emojis.js +13 -4
  63. package/lib/cache/resources/guilds.d.ts +9 -6
  64. package/lib/cache/resources/guilds.js +27 -6
  65. package/lib/cache/resources/members.d.ts +9 -6
  66. package/lib/cache/resources/members.js +24 -8
  67. package/lib/cache/resources/messages.d.ts +11 -7
  68. package/lib/cache/resources/messages.js +25 -11
  69. package/lib/cache/resources/overwrites.d.ts +11 -2
  70. package/lib/cache/resources/overwrites.js +9 -0
  71. package/lib/cache/resources/presence.d.ts +3 -2
  72. package/lib/cache/resources/roles.d.ts +9 -6
  73. package/lib/cache/resources/roles.js +13 -4
  74. package/lib/cache/resources/stage-instances.d.ts +2 -2
  75. package/lib/cache/resources/stickers.d.ts +9 -6
  76. package/lib/cache/resources/stickers.js +13 -4
  77. package/lib/cache/resources/threads.d.ts +9 -6
  78. package/lib/cache/resources/threads.js +13 -4
  79. package/lib/cache/resources/users.d.ts +9 -6
  80. package/lib/cache/resources/users.js +13 -4
  81. package/lib/cache/resources/voice-states.d.ts +11 -8
  82. package/lib/cache/resources/voice-states.js +15 -4
  83. package/lib/client/base.d.ts +32 -20
  84. package/lib/client/base.js +51 -30
  85. package/lib/client/client.d.ts +12 -9
  86. package/lib/client/client.js +43 -49
  87. package/lib/client/collectors.d.ts +36 -0
  88. package/lib/client/collectors.js +110 -0
  89. package/lib/client/httpclient.d.ts +8 -13
  90. package/lib/client/httpclient.js +27 -218
  91. package/lib/client/index.d.ts +1 -0
  92. package/lib/client/index.js +1 -0
  93. package/lib/client/transformers.d.ts +68 -0
  94. package/lib/client/transformers.js +99 -0
  95. package/lib/client/types.d.ts +5 -0
  96. package/lib/client/types.js +2 -0
  97. package/lib/client/workerclient.d.ts +18 -15
  98. package/lib/client/workerclient.js +148 -110
  99. package/lib/collection.d.ts +2 -2
  100. package/lib/collection.js +2 -2
  101. package/lib/commands/applications/chat.d.ts +40 -38
  102. package/lib/commands/applications/chat.js +22 -12
  103. package/lib/commands/applications/chatcontext.d.ts +17 -17
  104. package/lib/commands/applications/chatcontext.js +5 -5
  105. package/lib/commands/applications/menu.d.ts +9 -9
  106. package/lib/commands/applications/menu.js +5 -7
  107. package/lib/commands/applications/menucontext.d.ts +14 -13
  108. package/lib/commands/applications/menucontext.js +9 -9
  109. package/lib/commands/applications/options.d.ts +1 -1
  110. package/lib/commands/applications/options.js +20 -21
  111. package/lib/commands/applications/shared.d.ts +14 -0
  112. package/lib/commands/decorators.d.ts +47 -35
  113. package/lib/commands/decorators.js +19 -27
  114. package/lib/commands/handle.d.ts +64 -0
  115. package/lib/commands/handle.js +685 -0
  116. package/lib/commands/handler.d.ts +27 -18
  117. package/lib/commands/handler.js +296 -160
  118. package/lib/commands/optionresolver.d.ts +13 -13
  119. package/lib/commands/optionresolver.js +23 -28
  120. package/lib/common/bot/watcher.d.ts +4 -33
  121. package/lib/common/bot/watcher.js +0 -109
  122. package/lib/common/index.d.ts +2 -0
  123. package/lib/common/index.js +4 -1
  124. package/lib/common/it/colors.js +48 -49
  125. package/lib/common/it/formatter.d.ts +187 -0
  126. package/lib/common/it/formatter.js +226 -0
  127. package/lib/common/it/logger.d.ts +0 -1
  128. package/lib/common/it/logger.js +8 -8
  129. package/lib/common/it/utils.d.ts +15 -2
  130. package/lib/common/it/utils.js +80 -21
  131. package/lib/common/shorters/application.d.ts +56 -0
  132. package/lib/common/shorters/application.js +81 -0
  133. package/lib/common/shorters/bans.d.ts +42 -0
  134. package/lib/common/shorters/bans.js +78 -0
  135. package/lib/common/shorters/channels.d.ts +7 -6
  136. package/lib/common/shorters/channels.js +19 -15
  137. package/lib/common/shorters/emojis.d.ts +5 -6
  138. package/lib/common/shorters/emojis.js +8 -7
  139. package/lib/common/shorters/guilds.d.ts +18 -16
  140. package/lib/common/shorters/guilds.js +31 -26
  141. package/lib/common/shorters/interaction.d.ts +6 -6
  142. package/lib/common/shorters/interaction.js +12 -9
  143. package/lib/common/shorters/members.d.ts +29 -12
  144. package/lib/common/shorters/members.js +55 -16
  145. package/lib/common/shorters/messages.d.ts +7 -8
  146. package/lib/common/shorters/messages.js +10 -9
  147. package/lib/common/shorters/reactions.d.ts +3 -3
  148. package/lib/common/shorters/reactions.js +11 -11
  149. package/lib/common/shorters/roles.d.ts +9 -7
  150. package/lib/common/shorters/roles.js +26 -7
  151. package/lib/common/shorters/templates.d.ts +7 -8
  152. package/lib/common/shorters/templates.js +7 -7
  153. package/lib/common/shorters/threads.d.ts +6 -7
  154. package/lib/common/shorters/threads.js +6 -9
  155. package/lib/common/shorters/users.d.ts +4 -4
  156. package/lib/common/shorters/users.js +8 -4
  157. package/lib/common/shorters/webhook.d.ts +10 -10
  158. package/lib/common/shorters/webhook.js +12 -11
  159. package/lib/common/types/resolvables.d.ts +2 -2
  160. package/lib/common/types/util.d.ts +3 -1
  161. package/lib/common/types/write.d.ts +1 -1
  162. package/lib/components/ActionRow.d.ts +1 -1
  163. package/lib/components/BaseComponent.d.ts +1 -1
  164. package/lib/components/BaseComponent.js +1 -1
  165. package/lib/components/BaseSelectMenuComponent.d.ts +1 -1
  166. package/lib/components/ButtonComponent.d.ts +17 -7
  167. package/lib/components/ButtonComponent.js +19 -2
  168. package/lib/components/ChannelSelectMenuComponent.d.ts +3 -3
  169. package/lib/components/MentionableSelectMenuComponent.d.ts +2 -2
  170. package/lib/components/RoleSelectMenuComponent.d.ts +2 -2
  171. package/lib/components/StringSelectMenuComponent.d.ts +2 -2
  172. package/lib/components/TextInputComponent.d.ts +2 -2
  173. package/lib/components/UserSelectMenuComponent.d.ts +2 -2
  174. package/lib/components/componentcommand.d.ts +3 -2
  175. package/lib/components/componentcommand.js +4 -3
  176. package/lib/components/componentcontext.d.ts +11 -10
  177. package/lib/components/componentcontext.js +8 -8
  178. package/lib/components/handler.d.ts +16 -15
  179. package/lib/components/handler.js +101 -108
  180. package/lib/components/index.d.ts +3 -3
  181. package/lib/components/index.js +12 -10
  182. package/lib/components/modalcommand.d.ts +2 -1
  183. package/lib/components/modalcommand.js +1 -0
  184. package/lib/components/modalcontext.d.ts +13 -12
  185. package/lib/components/modalcontext.js +2 -2
  186. package/lib/deps/mixer.d.ts +8 -0
  187. package/lib/deps/mixer.js +66 -0
  188. package/lib/events/event.d.ts +4 -3
  189. package/lib/events/handler.d.ts +40 -15
  190. package/lib/events/handler.js +99 -21
  191. package/lib/events/hooks/application_command.d.ts +2 -2
  192. package/lib/events/hooks/auto_moderation.d.ts +6 -7
  193. package/lib/events/hooks/auto_moderation.js +4 -4
  194. package/lib/events/hooks/channel.d.ts +2 -2
  195. package/lib/events/hooks/channel.js +4 -7
  196. package/lib/events/hooks/custom.d.ts +3 -3
  197. package/lib/events/hooks/dispatch.d.ts +3 -4
  198. package/lib/events/hooks/dispatch.js +2 -2
  199. package/lib/events/hooks/entitlement.d.ts +5 -37
  200. package/lib/events/hooks/entitlement.js +7 -7
  201. package/lib/events/hooks/guild.d.ts +126 -181
  202. package/lib/events/hooks/guild.js +13 -15
  203. package/lib/events/hooks/integration.d.ts +71 -15
  204. package/lib/events/hooks/integration.js +3 -3
  205. package/lib/events/hooks/interactions.d.ts +2 -2
  206. package/lib/events/hooks/invite.d.ts +18 -14
  207. package/lib/events/hooks/message.d.ts +72 -52
  208. package/lib/events/hooks/message.js +4 -8
  209. package/lib/events/hooks/presence.d.ts +21 -16
  210. package/lib/events/hooks/stage.d.ts +4 -4
  211. package/lib/events/hooks/thread.d.ts +140 -60
  212. package/lib/events/hooks/thread.js +4 -4
  213. package/lib/events/hooks/typing.d.ts +28 -5
  214. package/lib/events/hooks/typing.js +2 -2
  215. package/lib/events/hooks/user.d.ts +3 -3
  216. package/lib/events/hooks/user.js +2 -2
  217. package/lib/events/hooks/voice.d.ts +28 -3
  218. package/lib/events/hooks/voice.js +8 -4
  219. package/lib/events/hooks/webhook.d.ts +1 -1
  220. package/lib/index.d.ts +6 -15
  221. package/lib/index.js +8 -12
  222. package/lib/langs/handler.d.ts +14 -10
  223. package/lib/langs/handler.js +40 -9
  224. package/lib/structures/AutoModerationRule.d.ts +4 -4
  225. package/lib/structures/AutoModerationRule.js +1 -2
  226. package/lib/structures/ClientUser.d.ts +1 -1
  227. package/lib/structures/Entitlement.d.ts +10 -0
  228. package/lib/structures/Entitlement.js +16 -0
  229. package/lib/structures/Guild.d.ts +37 -30
  230. package/lib/structures/Guild.js +7 -2
  231. package/lib/structures/GuildBan.d.ts +25 -0
  232. package/lib/structures/GuildBan.js +37 -0
  233. package/lib/structures/GuildEmoji.d.ts +4 -4
  234. package/lib/structures/GuildEmoji.js +3 -2
  235. package/lib/structures/GuildMember.d.ts +27 -19
  236. package/lib/structures/GuildMember.js +21 -11
  237. package/lib/structures/GuildPreview.d.ts +1 -1
  238. package/lib/structures/GuildRole.d.ts +5 -3
  239. package/lib/structures/GuildRole.js +8 -1
  240. package/lib/structures/GuildTemplate.d.ts +2 -2
  241. package/lib/structures/GuildTemplate.js +1 -1
  242. package/lib/structures/Interaction.d.ts +56 -38
  243. package/lib/structures/Interaction.js +134 -86
  244. package/lib/structures/Message.d.ts +80 -20
  245. package/lib/structures/Message.js +67 -26
  246. package/lib/structures/Poll.d.ts +4 -3
  247. package/lib/structures/Poll.js +6 -2
  248. package/lib/structures/Sticker.d.ts +10 -10
  249. package/lib/structures/Sticker.js +7 -7
  250. package/lib/structures/User.d.ts +6 -4
  251. package/lib/structures/User.js +6 -2
  252. package/lib/structures/VoiceState.d.ts +15 -11
  253. package/lib/structures/VoiceState.js +35 -17
  254. package/lib/structures/Webhook.d.ts +6 -7
  255. package/lib/structures/Webhook.js +6 -7
  256. package/lib/structures/channels.d.ts +14 -10
  257. package/lib/structures/channels.js +97 -62
  258. package/lib/structures/extra/BaseGuild.d.ts +1 -1
  259. package/lib/structures/extra/BaseGuild.js +3 -3
  260. package/lib/structures/extra/BitField.d.ts +1 -1
  261. package/lib/structures/extra/BitField.js +3 -2
  262. package/lib/structures/extra/DiscordBase.js +2 -2
  263. package/lib/structures/extra/Permissions.d.ts +3 -1
  264. package/lib/structures/extra/Permissions.js +8 -3
  265. package/lib/types/gateway.d.ts +1537 -0
  266. package/lib/types/gateway.js +4 -0
  267. package/lib/types/index.d.ts +9 -1
  268. package/lib/types/index.js +28 -1
  269. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/attachment.d.ts +5 -0
  270. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/attachment.js +2 -0
  271. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/base.d.ts +22 -0
  272. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/base.js +2 -0
  273. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/boolean.d.ts +4 -0
  274. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/boolean.js +2 -0
  275. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/channel.d.ts +7 -0
  276. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/channel.js +2 -0
  277. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/integer.d.ts +17 -0
  278. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/integer.js +2 -0
  279. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/mentionable.d.ts +5 -0
  280. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/mentionable.js +2 -0
  281. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/number.d.ts +17 -0
  282. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/number.js +2 -0
  283. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/role.d.ts +5 -0
  284. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/role.js +2 -0
  285. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/shared.d.ts +25 -0
  286. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/shared.js +20 -0
  287. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/string.d.ts +17 -0
  288. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/string.js +2 -0
  289. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommand.d.ts +11 -0
  290. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommand.js +2 -0
  291. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts +11 -0
  292. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommandGroup.js +2 -0
  293. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/user.d.ts +5 -0
  294. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/user.js +2 -0
  295. package/lib/types/payloads/_interactions/_applicationCommands/chatInput.d.ts +60 -0
  296. package/lib/types/payloads/_interactions/_applicationCommands/chatInput.js +29 -0
  297. package/lib/types/payloads/_interactions/_applicationCommands/contextMenu.d.ts +65 -0
  298. package/lib/types/payloads/_interactions/_applicationCommands/contextMenu.js +2 -0
  299. package/lib/types/payloads/_interactions/_applicationCommands/internals.d.ts +8 -0
  300. package/lib/types/payloads/_interactions/_applicationCommands/internals.js +2 -0
  301. package/lib/types/payloads/_interactions/_applicationCommands/permissions.d.ts +54 -0
  302. package/lib/types/payloads/_interactions/_applicationCommands/permissions.js +20 -0
  303. package/lib/types/payloads/_interactions/applicationCommands.d.ts +153 -0
  304. package/lib/types/payloads/_interactions/applicationCommands.js +61 -0
  305. package/lib/types/payloads/_interactions/autocomplete.d.ts +10 -0
  306. package/lib/types/payloads/_interactions/autocomplete.js +2 -0
  307. package/lib/types/payloads/_interactions/base.d.ts +197 -0
  308. package/lib/types/payloads/_interactions/base.js +2 -0
  309. package/lib/types/payloads/_interactions/messageComponents.d.ts +41 -0
  310. package/lib/types/payloads/_interactions/messageComponents.js +2 -0
  311. package/lib/types/payloads/_interactions/modalSubmit.d.ts +35 -0
  312. package/lib/types/payloads/_interactions/modalSubmit.js +2 -0
  313. package/lib/types/payloads/_interactions/ping.d.ts +3 -0
  314. package/lib/types/payloads/_interactions/ping.js +2 -0
  315. package/lib/types/payloads/_interactions/responses.d.ts +112 -0
  316. package/lib/types/payloads/_interactions/responses.js +54 -0
  317. package/lib/types/payloads/application.d.ts +292 -0
  318. package/lib/types/payloads/application.js +117 -0
  319. package/lib/types/payloads/auditLog.d.ts +644 -0
  320. package/lib/types/payloads/auditLog.js +80 -0
  321. package/lib/types/payloads/autoModeration.d.ts +219 -0
  322. package/lib/types/payloads/autoModeration.js +87 -0
  323. package/lib/types/payloads/channel.d.ts +1708 -0
  324. package/lib/types/payloads/channel.js +372 -0
  325. package/lib/types/payloads/emoji.d.ts +48 -0
  326. package/lib/types/payloads/emoji.js +5 -0
  327. package/lib/types/payloads/gateway.d.ts +373 -0
  328. package/lib/types/payloads/gateway.js +82 -0
  329. package/lib/types/payloads/guild.d.ts +1060 -0
  330. package/lib/types/payloads/guild.js +324 -0
  331. package/lib/types/payloads/guildScheduledEvent.d.ts +138 -0
  332. package/lib/types/payloads/guildScheduledEvent.js +32 -0
  333. package/lib/types/payloads/index.d.ts +64 -0
  334. package/lib/types/payloads/index.js +37 -0
  335. package/lib/types/payloads/interactions.d.ts +24 -0
  336. package/lib/types/payloads/interactions.js +23 -0
  337. package/lib/types/payloads/invite.d.ts +121 -0
  338. package/lib/types/payloads/invite.js +23 -0
  339. package/lib/types/payloads/monetization.d.ts +150 -0
  340. package/lib/types/payloads/monetization.js +79 -0
  341. package/lib/types/payloads/oauth2.d.ts +131 -0
  342. package/lib/types/payloads/oauth2.js +135 -0
  343. package/lib/types/payloads/permissions.d.ts +97 -0
  344. package/lib/types/payloads/permissions.js +16 -0
  345. package/lib/types/payloads/poll.d.ts +104 -0
  346. package/lib/types/payloads/poll.js +16 -0
  347. package/lib/types/payloads/stageInstance.d.ts +77 -0
  348. package/lib/types/payloads/stageInstance.js +19 -0
  349. package/lib/types/payloads/sticker.d.ts +123 -0
  350. package/lib/types/payloads/sticker.js +30 -0
  351. package/lib/types/payloads/teams.d.ts +78 -0
  352. package/lib/types/payloads/teams.js +23 -0
  353. package/lib/types/payloads/template.d.ts +62 -0
  354. package/lib/types/payloads/template.js +5 -0
  355. package/lib/types/payloads/user.d.ts +337 -0
  356. package/lib/types/payloads/user.js +167 -0
  357. package/lib/types/payloads/voice.d.ts +89 -0
  358. package/lib/types/payloads/voice.js +5 -0
  359. package/lib/types/payloads/webhook.d.ts +76 -0
  360. package/lib/types/payloads/webhook.js +21 -0
  361. package/lib/types/rest/application.d.ts +57 -0
  362. package/lib/types/rest/application.js +2 -0
  363. package/lib/types/rest/auditLog.d.ts +30 -0
  364. package/lib/types/rest/auditLog.js +2 -0
  365. package/lib/types/rest/autoModeration.d.ts +66 -0
  366. package/lib/types/rest/autoModeration.js +2 -0
  367. package/lib/types/rest/channel.d.ts +712 -0
  368. package/lib/types/rest/channel.js +11 -0
  369. package/lib/types/rest/emoji.d.ts +54 -0
  370. package/lib/types/rest/emoji.js +2 -0
  371. package/lib/types/rest/gateway.d.ts +9 -0
  372. package/lib/types/rest/gateway.js +2 -0
  373. package/lib/types/rest/guild.d.ts +865 -0
  374. package/lib/types/rest/guild.js +2 -0
  375. package/lib/types/rest/guildScheduledEvent.d.ts +126 -0
  376. package/lib/types/rest/guildScheduledEvent.js +2 -0
  377. package/lib/types/rest/index.d.ts +296 -0
  378. package/lib/types/rest/index.js +292 -0
  379. package/lib/types/rest/interactions.d.ts +194 -0
  380. package/lib/types/rest/interactions.js +2 -0
  381. package/lib/types/rest/invite.d.ts +24 -0
  382. package/lib/types/rest/invite.js +2 -0
  383. package/lib/types/rest/monetization.d.ts +82 -0
  384. package/lib/types/rest/monetization.js +11 -0
  385. package/lib/types/rest/oauth2.d.ts +172 -0
  386. package/lib/types/rest/oauth2.js +2 -0
  387. package/lib/types/rest/poll.d.ts +44 -0
  388. package/lib/types/rest/poll.js +2 -0
  389. package/lib/types/rest/stageInstance.d.ts +58 -0
  390. package/lib/types/rest/stageInstance.js +2 -0
  391. package/lib/types/rest/sticker.d.ts +77 -0
  392. package/lib/types/rest/sticker.js +2 -0
  393. package/lib/types/rest/template.d.ts +62 -0
  394. package/lib/types/rest/template.js +2 -0
  395. package/lib/types/rest/user.d.ts +120 -0
  396. package/lib/types/rest/user.js +2 -0
  397. package/lib/types/rest/voice.d.ts +17 -0
  398. package/lib/types/rest/voice.js +2 -0
  399. package/lib/types/rest/webhook.d.ts +250 -0
  400. package/lib/types/rest/webhook.js +2 -0
  401. package/lib/types/utils/index.d.ts +797 -0
  402. package/lib/types/utils/index.js +799 -0
  403. package/lib/websocket/SharedTypes.d.ts +4 -3
  404. package/lib/websocket/SharedTypes.js +1 -1
  405. package/lib/websocket/constants/index.d.ts +0 -1
  406. package/lib/websocket/discord/basesocket.d.ts +7 -6
  407. package/lib/websocket/discord/basesocket.js +35 -6
  408. package/lib/websocket/discord/events/memberUpdate.d.ts +1 -6
  409. package/lib/websocket/discord/events/memberUpdate.js +2 -1
  410. package/lib/websocket/discord/events/presenceUpdate.d.ts +5 -18
  411. package/lib/websocket/discord/events/presenceUpdate.js +5 -6
  412. package/lib/websocket/discord/shard.d.ts +9 -8
  413. package/lib/websocket/discord/shard.js +65 -47
  414. package/lib/websocket/discord/sharder.d.ts +6 -5
  415. package/lib/websocket/discord/sharder.js +11 -10
  416. package/lib/websocket/discord/shared.d.ts +13 -5
  417. package/lib/websocket/discord/socket/custom.d.ts +52 -0
  418. package/lib/websocket/discord/socket/custom.js +283 -0
  419. package/lib/websocket/discord/worker.d.ts +5 -10
  420. package/lib/websocket/discord/workermanager.d.ts +8 -15
  421. package/lib/websocket/discord/workermanager.js +35 -39
  422. package/lib/websocket/structures/index.d.ts +0 -1
  423. package/lib/websocket/structures/index.js +1 -1
  424. package/lib/websocket/structures/timeout.d.ts +0 -1
  425. package/package.json +65 -74
  426. package/lib/cache/adapters/redis.d.ts +0 -37
  427. package/lib/cache/adapters/redis.js +0 -218
  428. package/lib/client/oninteractioncreate.d.ts +0 -4
  429. package/lib/client/oninteractioncreate.js +0 -198
  430. package/lib/client/onmessagecreate.d.ts +0 -3
  431. package/lib/client/onmessagecreate.js +0 -395
  432. package/lib/structures/extra/functions.d.ts +0 -12
  433. package/lib/structures/extra/functions.js +0 -70
@@ -15,6 +15,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  exports.Cache = void 0;
18
+ const common_1 = require("../common");
18
19
  const guilds_1 = require("./resources/guilds");
19
20
  const users_1 = require("./resources/users");
20
21
  const channels_1 = require("./resources/channels");
@@ -26,7 +27,8 @@ const stage_instances_1 = require("./resources/stage-instances");
26
27
  const stickers_1 = require("./resources/stickers");
27
28
  const threads_1 = require("./resources/threads");
28
29
  const voice_states_1 = require("./resources/voice-states");
29
- const v10_1 = require("discord-api-types/v10");
30
+ const bans_1 = require("./resources/bans");
31
+ const types_1 = require("../types");
30
32
  const overwrites_1 = require("./resources/overwrites");
31
33
  const messages_1 = require("./resources/messages");
32
34
  __exportStar(require("./adapters/index"), exports);
@@ -50,52 +52,59 @@ class Cache {
50
52
  presences;
51
53
  stageInstances;
52
54
  messages;
53
- constructor(intents, adapter, disabledCache = [], client) {
55
+ bans;
56
+ __logger__;
57
+ constructor(intents, adapter, disabledCache = {}, client) {
54
58
  this.intents = intents;
55
59
  this.adapter = adapter;
56
60
  this.disabledCache = disabledCache;
57
61
  // non-guild based
58
- if (!this.disabledCache.includes('users')) {
62
+ if (!this.disabledCache.users) {
59
63
  this.users = new users_1.Users(this, client);
60
64
  }
61
- if (!this.disabledCache.includes('guilds')) {
65
+ if (!this.disabledCache.guilds) {
62
66
  this.guilds = new guilds_1.Guilds(this, client);
63
67
  }
64
68
  // guild related
65
- if (!this.disabledCache.includes('members')) {
69
+ if (!this.disabledCache.members) {
66
70
  this.members = new members_1.Members(this, client);
67
71
  }
68
- if (!this.disabledCache.includes('voiceStates')) {
72
+ if (!this.disabledCache.voiceStates) {
69
73
  this.voiceStates = new voice_states_1.VoiceStates(this, client);
70
74
  }
71
75
  // guild based
72
- if (!this.disabledCache.includes('roles')) {
76
+ if (!this.disabledCache.roles) {
73
77
  this.roles = new roles_1.Roles(this, client);
74
78
  }
75
- if (!this.disabledCache.includes('overwrites')) {
79
+ if (!this.disabledCache.overwrites) {
76
80
  this.overwrites = new overwrites_1.Overwrites(this, client);
77
81
  }
78
- if (!this.disabledCache.includes('channels')) {
82
+ if (!this.disabledCache.channels) {
79
83
  this.channels = new channels_1.Channels(this, client);
80
84
  }
81
- if (!this.disabledCache.includes('emojis')) {
85
+ if (!this.disabledCache.emojis) {
82
86
  this.emojis = new emojis_1.Emojis(this, client);
83
87
  }
84
- if (!this.disabledCache.includes('stickers')) {
88
+ if (!this.disabledCache.stickers) {
85
89
  this.stickers = new stickers_1.Stickers(this, client);
86
90
  }
87
- if (!this.disabledCache.includes('presences')) {
91
+ if (!this.disabledCache.presences) {
88
92
  this.presences = new presence_1.Presences(this, client);
89
93
  }
90
- if (!this.disabledCache.includes('threads')) {
94
+ if (!this.disabledCache.threads) {
91
95
  this.threads = new threads_1.Threads(this, client);
92
96
  }
93
- if (!this.disabledCache.includes('stageInstances')) {
97
+ if (!this.disabledCache.stageInstances) {
94
98
  this.stageInstances = new stage_instances_1.StageInstances(this, client);
95
99
  }
96
- if (!this.disabledCache.includes('messages')) {
100
+ if (!this.disabledCache.messages) {
97
101
  this.messages = new messages_1.Messages(this, client);
98
102
  }
103
+ if (!this.disabledCache.bans) {
104
+ this.bans = new bans_1.Bans(this, client);
105
+ }
106
+ if (this.disabledCache.onPacket)
107
+ delete this.onPacket;
99
108
  }
100
109
  /** @internal */
101
110
  __setClient(client) {
@@ -112,13 +121,14 @@ class Cache {
112
121
  this.threads?.__setClient(client);
113
122
  this.stageInstances?.__setClient(client);
114
123
  this.messages?.__setClient(client);
124
+ this.bans?.__setClient(client);
115
125
  }
116
126
  flush() {
117
127
  return this.adapter.flush();
118
128
  }
119
129
  // internal use ./structures
120
130
  hasIntent(intent) {
121
- return (this.intents & v10_1.GatewayIntentBits[intent]) === v10_1.GatewayIntentBits[intent];
131
+ return (this.intents & types_1.GatewayIntentBits[intent]) === types_1.GatewayIntentBits[intent];
122
132
  }
123
133
  get hasGuildsIntent() {
124
134
  return this.hasIntent('Guilds');
@@ -144,6 +154,9 @@ class Cache {
144
154
  get hasDirectMessages() {
145
155
  return this.hasIntent('DirectMessages');
146
156
  }
157
+ get hasBansIntent() {
158
+ return this.hasIntent('GuildBans');
159
+ }
147
160
  async bulkGet(keys) {
148
161
  const allData = {};
149
162
  for (const [type, id, guildId] of keys) {
@@ -167,6 +180,7 @@ class Cache {
167
180
  case 'users':
168
181
  case 'guilds':
169
182
  case 'overwrites':
183
+ case 'bans':
170
184
  case 'messages':
171
185
  {
172
186
  if (!allData[type]) {
@@ -207,6 +221,7 @@ class Cache {
207
221
  case 'stageInstances':
208
222
  case 'emojis':
209
223
  case 'overwrites':
224
+ case 'bans':
210
225
  case 'messages':
211
226
  {
212
227
  if (!this[type]?.filter(data, id, guildId))
@@ -263,7 +278,7 @@ class Cache {
263
278
  }
264
279
  }
265
280
  await this.adapter.bulkAddToRelationShip(relationshipsData);
266
- await this.adapter.patch(false, allData);
281
+ await this.adapter.bulkPatch(false, allData);
267
282
  }
268
283
  async bulkSet(keys) {
269
284
  const allData = [];
@@ -296,6 +311,7 @@ class Cache {
296
311
  allData.push([this[type].hashId(id), this[type].parse(data, id, guildId)]);
297
312
  }
298
313
  break;
314
+ case 'bans':
299
315
  case 'voiceStates':
300
316
  case 'members':
301
317
  {
@@ -334,7 +350,7 @@ class Cache {
334
350
  }
335
351
  }
336
352
  await this.adapter.bulkAddToRelationShip(relationshipsData);
337
- await this.adapter.set(allData);
353
+ await this.adapter.bulkSet(allData);
338
354
  }
339
355
  async onPacket(event) {
340
356
  switch (event.t) {
@@ -361,7 +377,7 @@ class Cache {
361
377
  await this.overwrites?.set(event.d.id, event.d.guild_id, event.d.permission_overwrites);
362
378
  break;
363
379
  }
364
- if (event.d.type === v10_1.ChannelType.DM) {
380
+ if (event.d.type === types_1.ChannelType.DM) {
365
381
  await this.channels?.set(event.d.recipients[0]?.id, '@me', event.d);
366
382
  break;
367
383
  }
@@ -376,6 +392,12 @@ class Cache {
376
392
  case 'GUILD_ROLE_DELETE':
377
393
  await this.roles?.remove(event.d.role_id, event.d.guild_id);
378
394
  break;
395
+ case 'GUILD_BAN_ADD':
396
+ await this.bans?.set(event.d.user.id, event.d.guild_id, event.d);
397
+ break;
398
+ case 'GUILD_BAN_REMOVE':
399
+ await this.bans?.remove(event.d.user.id, event.d.guild_id);
400
+ break;
379
401
  case 'GUILD_EMOJIS_UPDATE':
380
402
  await this.emojis?.remove(await this.emojis?.keys(event.d.guild_id), event.d.guild_id);
381
403
  await this.emojis?.set(event.d.emojis.map(x => [x.id, x]), event.d.guild_id);
@@ -439,5 +461,299 @@ class Cache {
439
461
  break;
440
462
  }
441
463
  }
464
+ async testAdapter() {
465
+ this.__logger__ ??= new common_1.Logger({
466
+ name: '[CACHE]',
467
+ });
468
+ await this.adapter.flush();
469
+ // this method will only check the cache for `users`, `members` y `channels`
470
+ // likewise these have the three types of resources (GuildRelatedResource, GuildBasedResource, BaseResource)
471
+ // will also check `overwrites`, since the latter stores an array not as an object but as data.
472
+ await this.testUsersAndMembers();
473
+ await this.testChannelsAndOverwrites();
474
+ this.__logger__.info('The adapter seems to work properly');
475
+ this.__logger__.debug('Flushing adapter');
476
+ delete this.__logger__;
477
+ await this.adapter.flush();
478
+ }
479
+ async testUsersAndMembers() {
480
+ if (!this.users)
481
+ throw new Error('Users cache disabled, you should enable it for this.');
482
+ if (!this.members)
483
+ throw new Error('Members cache disabled, you should enable it for this.');
484
+ function createUser(name) {
485
+ return {
486
+ avatar: 'xdxd',
487
+ discriminator: '0',
488
+ global_name: name,
489
+ id: `${Math.random()}`.slice(2),
490
+ username: `@seyfert/${name}`,
491
+ };
492
+ }
493
+ function createMember(name) {
494
+ return {
495
+ banner: null,
496
+ avatar: 'xdxd',
497
+ deaf: !false,
498
+ flags: types_1.GuildMemberFlags.StartedHomeActions,
499
+ joined_at: new Date().toISOString(),
500
+ mute: !true,
501
+ roles: ['111111111111'],
502
+ user: createUser(name),
503
+ };
504
+ }
505
+ const users = [
506
+ createUser('witherking_'),
507
+ createUser('vanecia'),
508
+ createUser('socram'),
509
+ createUser('free'),
510
+ createUser('justevil'),
511
+ createUser('nobody'),
512
+ createUser('aaron'),
513
+ createUser('simxnet'),
514
+ createUser('yuzu'),
515
+ createUser('vyrek'),
516
+ createUser('marcrock'),
517
+ ];
518
+ for (const user of users) {
519
+ await this.users.set(user.id, user);
520
+ }
521
+ let count = 0;
522
+ if ((await this.users.values()).length !== users.length)
523
+ throw new Error('users.values() is not of the expected size.');
524
+ if ((await this.users.count()) !== users.length)
525
+ throw new Error('users.count() is not of the expected amount');
526
+ for (const user of users) {
527
+ const cache = await this.users.raw(user.id);
528
+ if (!cache)
529
+ throw new Error(`users.raw(${user.id}) has returned undefined!!!!!!`);
530
+ if (cache.username !== user.username)
531
+ throw new Error(`users.raw(${user.id}).username is not of the expected value!!!!! (cache (${cache.username})) (expected value: (${user.username}))`);
532
+ if (cache.id !== user.id)
533
+ throw new Error(`users.raw(${user.id}).id is not of the expected value!!!!!! (cache (${cache.id})) (expected value: (${user.id}))`);
534
+ await this.users.remove(user.id);
535
+ if ((await this.users.count()) !== users.length - ++count)
536
+ throw new Error(`users.count() should be ${users.length - count}!! please check your remove method`);
537
+ }
538
+ this.__logger__.info('the user cache seems to be alright.');
539
+ this.__logger__.debug('Flushing adapter to clear users cache.');
540
+ await this.adapter.flush();
541
+ // unexpected error message
542
+ if ((await this.users.count()) !== 0)
543
+ throw new Error('users.count() should be 0!! please check your flush method');
544
+ const guildMembers = {
545
+ '852531635252494346': [
546
+ createMember("witherking_'s member"),
547
+ createMember("vanecia's member"),
548
+ createMember("nobody's member"),
549
+ ],
550
+ '1003825077969764412': [
551
+ createMember("free's member"),
552
+ createMember("socram's member"),
553
+ createMember("marcrock's member"),
554
+ createMember("justevil's member"),
555
+ createMember("vyrek's member"),
556
+ ],
557
+ '876711213126520882': [
558
+ createMember("aaron's member"),
559
+ createMember("simxnet's member"),
560
+ createMember("yuzu's member"),
561
+ ],
562
+ };
563
+ for (const guildId in guildMembers) {
564
+ const members = guildMembers[guildId];
565
+ for (const member of members) {
566
+ await this.members.set(member.user.id, guildId, member);
567
+ }
568
+ if ((await this.members.values(guildId)).length !== members.length)
569
+ throw new Error('members.values(guildId) is not of the expected size.');
570
+ if ((await this.members.count(guildId)) !== members.length)
571
+ throw new Error('members.count(guildId) is not of the expected amount');
572
+ for (const member of members) {
573
+ const cache = await this.members.raw(member.user.id, guildId);
574
+ if (!cache)
575
+ throw new Error(`members.raw(${member.user.id}, ${guildId}) has returned undefined.`);
576
+ if (cache.roles[0] !== member.roles[0])
577
+ throw new Error(`members.raw(${member.user.id}, ${guildId}).roles[0] is not the expected value: ${member.roles[0]} (cache: ${cache.roles[0]})`);
578
+ if (cache.user.username !== member.user.username)
579
+ throw new Error(`members.raw(${member.user.id}, ${guildId}).user.username is not the expected value!!!!!! (cache (${cache.user.username})) (expected value: (${member.user.username}))`);
580
+ if (cache.user.id !== member.user.id)
581
+ throw new Error(`members.raw(${member.user.id}, ${guildId}).user.id is not the expected value!!!!!! (cache (${cache.user.id})) (expected value: (${member.user.id}))`);
582
+ }
583
+ }
584
+ if ((await this.members.values('*')).length !== Object.values(guildMembers).flat().length)
585
+ throw new Error('members.values(*) is not of the expected size');
586
+ if ((await this.members.count('*')) !== Object.values(guildMembers).flat().length)
587
+ throw new Error('the global amount of members.count(*) is not the expected amount');
588
+ count = 0;
589
+ for (const guildId in guildMembers) {
590
+ const members = guildMembers[guildId];
591
+ for (const member of members) {
592
+ await this.members.remove(member.user.id, guildId);
593
+ if ((await this.members.count(guildId)) !== members.length - ++count)
594
+ throw new Error(`members.count(${guildId}) should be ${members.length - count}!! please check your remove method`);
595
+ }
596
+ count = 0;
597
+ }
598
+ await this.adapter.flush();
599
+ // unexpected error message
600
+ if ((await this.users.count()) !== 0)
601
+ throw new Error('users.count() should be zero!! please check your flush method');
602
+ // unexpected error message
603
+ if ((await this.members.count('*')) !== 0)
604
+ throw new Error("members.count('*') should be zero!! please check your flush method");
605
+ this.__logger__.info('the member cache seems to be alright.');
606
+ }
607
+ async testChannelsAndOverwrites() {
608
+ if (!this.channels)
609
+ throw new Error('Channels cache disabled, you should enable it for this.');
610
+ if (!this.overwrites)
611
+ throw new Error('Overwrites cache disabled, you should enable it for this.');
612
+ function createChannel(name) {
613
+ return {
614
+ id: `${Math.random()}`.slice(2),
615
+ name,
616
+ type: types_1.ChannelType.GuildText,
617
+ position: Math.random() > 0.5 ? 1 : 0,
618
+ };
619
+ }
620
+ function createOverwrites(name) {
621
+ const channel_id = `${Math.random()}`.slice(2);
622
+ return [
623
+ {
624
+ id: name,
625
+ allow: '8',
626
+ deny: '2',
627
+ type: types_1.OverwriteType.Role,
628
+ channel_id,
629
+ },
630
+ {
631
+ id: `${name}-2`,
632
+ allow: '8',
633
+ deny: '2',
634
+ type: types_1.OverwriteType.Role,
635
+ channel_id,
636
+ },
637
+ ];
638
+ }
639
+ const guildChannels = {
640
+ '852531635252494346': [
641
+ createChannel("witherking_'s channel"),
642
+ createChannel("vanecia's channel"),
643
+ createChannel("nobody's channel"),
644
+ ],
645
+ '1003825077969764412': [
646
+ createChannel("free's channel"),
647
+ createChannel("socram's channel"),
648
+ createChannel("marcrock's channel"),
649
+ createChannel("justevil's channel"),
650
+ createChannel("vyrek's channel"),
651
+ ],
652
+ '876711213126520882': [
653
+ createChannel("aaron's channel"),
654
+ createChannel("simxnet's channel"),
655
+ createChannel("yuzu's channel"),
656
+ ],
657
+ };
658
+ for (const guildId in guildChannels) {
659
+ const channels = guildChannels[guildId];
660
+ for (const channel of channels) {
661
+ await this.channels.set(channel.id, guildId, channel);
662
+ }
663
+ if ((await this.channels.values(guildId)).length !== channels.length)
664
+ throw new Error('channels.values(guildId) is not of the expected size');
665
+ if ((await this.channels.count(guildId)) !== channels.length)
666
+ throw new Error('channels.count(guildId) is not of the expected amount');
667
+ for (const channel of channels) {
668
+ const cache = await this.channels.raw(channel.id);
669
+ if (!cache)
670
+ throw new Error(`channels.raw(${channel.id}) has returned undefined!!!!!!`);
671
+ if (cache.type !== types_1.ChannelType.GuildText)
672
+ throw new Error(`channels.raw(${channel.id}).type is not of the expected type: ${channel.type}!!!!!!!! (mismatched type: ${cache.type})`);
673
+ if (cache.name !== channel.name)
674
+ throw new Error(`channels.raw(${channel.id}).name is not the expected value!!!!!! (cache (${cache.name})) (expected value: (${channel.name}))`);
675
+ if (cache.id !== channel.id)
676
+ throw new Error(`channels.raw(${channel.id}).id is not the expected value!!!!!! (cache (${cache.id})) (expected value: (${channel.id}))`);
677
+ }
678
+ }
679
+ if ((await this.channels.values('*')).length !== Object.values(guildChannels).flat().length)
680
+ throw new Error('channels.values(*) is not of the expected size');
681
+ if ((await this.channels.count('*')) !== Object.values(guildChannels).flat().length)
682
+ throw new Error('channels.count(*) is not of the expected amount');
683
+ let count = 0;
684
+ for (const guildId in guildChannels) {
685
+ const channels = guildChannels[guildId];
686
+ for (const channel of channels) {
687
+ await this.channels.remove(channel.id, guildId);
688
+ if ((await this.channels.count(guildId)) !== channels.length - ++count)
689
+ throw new Error(`channels.count(${guildId}) should be ${channels.length - count}!! please check your remove method`);
690
+ }
691
+ count = 0;
692
+ }
693
+ // unexpected error message
694
+ if ((await this.channels.count('*')) !== 0)
695
+ throw new Error(`channels.count('*') should be zero!! please check your remove method`);
696
+ this.__logger__.info('the channel cache seems to be alright');
697
+ const guildOverwrites = {
698
+ '852531635252494346': [
699
+ createOverwrites("witherking_'s channel"),
700
+ createOverwrites("vanecia's channel"),
701
+ createOverwrites("nobody's channel"),
702
+ ],
703
+ '1003825077969764412': [
704
+ createOverwrites("free's channel"),
705
+ createOverwrites("socram's channel"),
706
+ createOverwrites("marcrock's channel"),
707
+ createOverwrites("justevil's channel"),
708
+ createOverwrites("vyrek's channel"),
709
+ ],
710
+ '876711213126520882': [
711
+ createOverwrites("aaron's channel"),
712
+ createOverwrites("simxnet's channel"),
713
+ createOverwrites("yuzu's channel"),
714
+ ],
715
+ };
716
+ for (const guildId in guildOverwrites) {
717
+ const bulkOverwrites = guildOverwrites[guildId];
718
+ for (const overwrites of bulkOverwrites) {
719
+ await this.overwrites.set(overwrites[0].channel_id, guildId, overwrites);
720
+ }
721
+ if ((await this.overwrites.values(guildId)).length !== bulkOverwrites.length)
722
+ throw new Error('overwrites.values(channelId) is not of the expected size');
723
+ if ((await this.overwrites.count(guildId)) !== bulkOverwrites.length)
724
+ throw new Error('overwrites.count(channelId) is not of the expected amount');
725
+ for (const overwrites of bulkOverwrites) {
726
+ const cache = await this.overwrites.raw(overwrites[0].channel_id);
727
+ if (!cache)
728
+ throw new Error(`overwrites.raw(${overwrites[0].channel_id}) has returned undefined!!!!!!`);
729
+ if (cache.length !== overwrites.length)
730
+ throw new Error(`overwrites.raw(${overwrites[0].channel_id}).length is not of the expected length!!!!!! (cache (${cache.length})) (expected value: (${overwrites.length}))`);
731
+ for (const overwrite of overwrites) {
732
+ if (!cache.some(x => {
733
+ return (x.allow === overwrite.allow &&
734
+ x.deny === overwrite.deny &&
735
+ x.guild_id === guildId &&
736
+ x.id === overwrite.id &&
737
+ x.type === overwrite.type);
738
+ }))
739
+ throw new Error("cache wasn't found in the overwrites cache");
740
+ }
741
+ }
742
+ }
743
+ count = 0;
744
+ for (const guildId in guildOverwrites) {
745
+ const bulkOverwrites = guildOverwrites[guildId];
746
+ for (const overwrites of bulkOverwrites) {
747
+ await this.overwrites.remove(overwrites[0].channel_id, guildId);
748
+ if ((await this.overwrites.count(guildId)) !== bulkOverwrites.length - ++count)
749
+ throw new Error(`overwrites.count(${guildId}) should be ${overwrites.length - count}!! please check your remove method`);
750
+ }
751
+ count = 0;
752
+ }
753
+ // unexpected error message
754
+ if ((await this.overwrites.count('*')) !== 0)
755
+ throw new Error(`overwrites.count('*') should be zero!! please check your remove method`);
756
+ this.__logger__.info('the overwrites cache seems to be alright.');
757
+ }
442
758
  }
443
759
  exports.Cache = Cache;
@@ -0,0 +1,15 @@
1
+ import type { APIBan, GatewayGuildBanModifyDispatchData } from '../../types';
2
+ import type { ReturnCache } from '../..';
3
+ import { GuildBasedResource } from './default/guild-based';
4
+ import { type GuildBanStructure } from '../../client/transformers';
5
+ export declare class Bans extends GuildBasedResource<any, GatewayGuildBanModifyDispatchData | APIBan> {
6
+ namespace: string;
7
+ filter(data: APIBan, id: string, guild_id: string): boolean;
8
+ parse(data: any, key: string, guild_id: string): any;
9
+ get(id: string, guild: string): ReturnCache<GuildBanStructure | undefined>;
10
+ raw(id: string, guild: string): ReturnCache<Omit<GatewayGuildBanModifyDispatchData | APIBan, 'user'> | undefined>;
11
+ bulk(ids: string[], guild: string): ReturnCache<GuildBanStructure[]>;
12
+ bulkRaw(ids: string[], guild: string): ReturnCache<Omit<GatewayGuildBanModifyDispatchData | APIBan, 'user'>[]>;
13
+ values(guild: string): ReturnCache<GuildBanStructure[]>;
14
+ valuesRaw(guild: string): ReturnCache<Omit<GatewayGuildBanModifyDispatchData | APIBan, 'user'>[]>;
15
+ }
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Bans = void 0;
4
+ const common_1 = require("../../common");
5
+ const guild_based_1 = require("./default/guild-based");
6
+ const transformers_1 = require("../../client/transformers");
7
+ class Bans extends guild_based_1.GuildBasedResource {
8
+ namespace = 'ban';
9
+ //@ts-expect-error
10
+ filter(data, id, guild_id) {
11
+ return true;
12
+ }
13
+ parse(data, key, guild_id) {
14
+ const { user, ...rest } = super.parse(data, data.user?.id ?? key, guild_id);
15
+ return rest;
16
+ }
17
+ get(id, guild) {
18
+ return (0, common_1.fakePromise)(super.get(id, guild)).then(rawBan => rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined);
19
+ }
20
+ raw(id, guild) {
21
+ return super.get(id, guild);
22
+ }
23
+ bulk(ids, guild) {
24
+ return (0, common_1.fakePromise)(super.bulk(ids, guild)).then(bans => bans
25
+ .map(rawBan => {
26
+ return rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined;
27
+ })
28
+ .filter(Boolean));
29
+ }
30
+ bulkRaw(ids, guild) {
31
+ return super.bulk(ids, guild);
32
+ }
33
+ values(guild) {
34
+ return (0, common_1.fakePromise)(super.values(guild)).then(bans => bans
35
+ .map(rawBan => {
36
+ return rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined;
37
+ })
38
+ .filter(Boolean));
39
+ }
40
+ valuesRaw(guild) {
41
+ return super.values(guild);
42
+ }
43
+ }
44
+ exports.Bans = Bans;
@@ -1,12 +1,14 @@
1
- import type { APIChannel } from 'discord-api-types/v10';
2
- import type { AllChannels } from '../../structures';
3
- import channelFrom from '../../structures/channels';
1
+ import type { APIChannel } from '../../types';
2
+ import { channelFrom, type AllChannels } from '../../structures';
4
3
  import type { ReturnCache } from '../index';
5
4
  import { GuildRelatedResource } from './default/guild-related';
6
- export declare class Channels extends GuildRelatedResource {
5
+ export declare class Channels extends GuildRelatedResource<any, APIChannel> {
7
6
  namespace: string;
8
7
  parse(data: APIChannel, id: string, guild_id: string): any;
9
8
  get(id: string): ReturnCache<AllChannels | undefined>;
9
+ raw(id: string): ReturnCache<Omit<APIChannel, 'permission_overwrites'> | undefined>;
10
10
  bulk(ids: string[]): ReturnCache<ReturnType<typeof channelFrom>[]>;
11
+ bulkRaw(ids: string[]): ReturnCache<Omit<APIChannel, 'permission_overwrites'>[]>;
11
12
  values(guild: string): ReturnCache<ReturnType<typeof channelFrom>[]>;
13
+ valuesRaw(guild: string): ReturnCache<Omit<APIChannel, 'permission_overwrites'>[]>;
12
14
  }
@@ -1,11 +1,8 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
3
  exports.Channels = void 0;
7
4
  const common_1 = require("../../common");
8
- const channels_1 = __importDefault(require("../../structures/channels"));
5
+ const structures_1 = require("../../structures");
9
6
  const guild_related_1 = require("./default/guild-related");
10
7
  class Channels extends guild_related_1.GuildRelatedResource {
11
8
  namespace = 'channel';
@@ -14,13 +11,22 @@ class Channels extends guild_related_1.GuildRelatedResource {
14
11
  return rest;
15
12
  }
16
13
  get(id) {
17
- return (0, common_1.fakePromise)(super.get(id)).then(rawChannel => rawChannel ? (0, channels_1.default)(rawChannel, this.client) : undefined);
14
+ return (0, common_1.fakePromise)(super.get(id)).then(rawChannel => rawChannel ? (0, structures_1.channelFrom)(rawChannel, this.client) : undefined);
15
+ }
16
+ raw(id) {
17
+ return super.get(id);
18
18
  }
19
19
  bulk(ids) {
20
- return (0, common_1.fakePromise)(super.bulk(ids)).then(channels => channels.map(rawChannel => (0, channels_1.default)(rawChannel, this.client)));
20
+ return (0, common_1.fakePromise)(super.bulk(ids)).then(channels => channels.map(rawChannel => (0, structures_1.channelFrom)(rawChannel, this.client)));
21
+ }
22
+ bulkRaw(ids) {
23
+ return super.bulk(ids);
21
24
  }
22
25
  values(guild) {
23
- return (0, common_1.fakePromise)(super.values(guild)).then(channels => channels.map(rawChannel => (0, channels_1.default)(rawChannel, this.client)));
26
+ return (0, common_1.fakePromise)(super.values(guild)).then(channels => channels.map(rawChannel => (0, structures_1.channelFrom)(rawChannel, this.client)));
27
+ }
28
+ valuesRaw(guild) {
29
+ return super.values(guild);
24
30
  }
25
31
  }
26
32
  exports.Channels = Channels;
@@ -1,7 +1,7 @@
1
- import type { GatewayIntentBits } from 'discord-api-types/v10';
2
1
  import type { UsingClient } from '../../../commands';
2
+ import type { GatewayIntentBits } from '../../../types';
3
3
  import type { Cache, ReturnCache } from '../../index';
4
- export declare class BaseResource<T = any> {
4
+ export declare class BaseResource<T = any, S = any> {
5
5
  protected cache: Cache;
6
6
  client: UsingClient;
7
7
  namespace: string;
@@ -9,16 +9,16 @@ export declare class BaseResource<T = any> {
9
9
  filter(data: any, id: string): boolean;
10
10
  get adapter(): import("../../index").Adapter;
11
11
  removeIfNI(intent: keyof typeof GatewayIntentBits, id: string): import("../../../common").Awaitable<void>;
12
- setIfNI(intent: keyof typeof GatewayIntentBits, id: string, data: any): import("../../../common").Awaitable<void>;
12
+ setIfNI(intent: keyof typeof GatewayIntentBits, id: string, data: S): import("../../../common").Awaitable<void>;
13
13
  get(id: string): ReturnCache<T | undefined>;
14
14
  bulk(ids: string[]): ReturnCache<T[]>;
15
- set(id: string, data: any): import("../../../common").Awaitable<void>;
16
- patch(id: string, data: any): import("../../../common").Awaitable<void>;
15
+ set(id: string, data: S): import("../../../common").Awaitable<void>;
16
+ patch(id: string, data: S): import("../../../common").Awaitable<void>;
17
17
  remove(id: string): import("../../../common").Awaitable<void>;
18
18
  keys(): ReturnCache<string[]>;
19
19
  values(): ReturnCache<T[]>;
20
- count(): import("../../../common").Awaitable<number>;
21
- contains(id: string): import("../../../common").Awaitable<boolean>;
20
+ count(): ReturnCache<number>;
21
+ contains(id: string): ReturnCache<boolean>;
22
22
  getToRelationship(): import("../../../common").Awaitable<string[]>;
23
23
  addToRelationship(id: string | string[]): import("../../../common").Awaitable<void>;
24
24
  removeToRelationship(id: string | string[]): import("../../../common").Awaitable<void>;
@@ -38,7 +38,7 @@ class BaseResource {
38
38
  return this.adapter.get(this.hashId(id));
39
39
  }
40
40
  bulk(ids) {
41
- return (0, common_1.fakePromise)(this.adapter.get(ids.map(id => this.hashId(id)))).then(x => x.filter(y => y));
41
+ return (0, common_1.fakePromise)(this.adapter.bulkGet(ids.map(id => this.hashId(id)))).then(x => x.filter(y => y));
42
42
  }
43
43
  set(id, data) {
44
44
  if (!this.filter(data, id))
@@ -75,7 +75,7 @@ class BaseResource {
75
75
  return this.adapter.removeToRelationship(this.namespace, id);
76
76
  }
77
77
  hashId(id) {
78
- return `${this.namespace}.${id}`;
78
+ return id.startsWith(this.namespace) ? id : `${this.namespace}.${id}`;
79
79
  }
80
80
  }
81
81
  exports.BaseResource = BaseResource;