seyfert 1.5.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 (427) hide show
  1. package/LICENSE +21 -190
  2. package/README.md +18 -10
  3. package/lib/api/Router.js +2 -2
  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 +5 -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 +18 -9
  50. package/lib/cache/index.js +319 -21
  51. package/lib/cache/resources/bans.d.ts +9 -6
  52. package/lib/cache/resources/bans.js +13 -4
  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 +22 -6
  67. package/lib/cache/resources/messages.d.ts +11 -7
  68. package/lib/cache/resources/messages.js +19 -7
  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 +28 -20
  84. package/lib/client/base.js +58 -56
  85. package/lib/client/client.d.ts +7 -16
  86. package/lib/client/client.js +29 -31
  87. package/lib/client/collectors.d.ts +10 -10
  88. package/lib/client/collectors.js +26 -1
  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 +14 -14
  98. package/lib/client/workerclient.js +112 -66
  99. package/lib/commands/applications/chat.d.ts +35 -34
  100. package/lib/commands/applications/chat.js +5 -9
  101. package/lib/commands/applications/chatcontext.d.ts +17 -17
  102. package/lib/commands/applications/chatcontext.js +5 -5
  103. package/lib/commands/applications/menu.d.ts +2 -3
  104. package/lib/commands/applications/menu.js +2 -5
  105. package/lib/commands/applications/menucontext.d.ts +14 -13
  106. package/lib/commands/applications/menucontext.js +9 -9
  107. package/lib/commands/applications/options.d.ts +1 -1
  108. package/lib/commands/applications/options.js +20 -21
  109. package/lib/commands/applications/shared.d.ts +3 -1
  110. package/lib/commands/decorators.d.ts +38 -20
  111. package/lib/commands/decorators.js +17 -18
  112. package/lib/commands/handle.d.ts +64 -0
  113. package/lib/commands/handle.js +685 -0
  114. package/lib/commands/handler.d.ts +27 -18
  115. package/lib/commands/handler.js +290 -164
  116. package/lib/commands/optionresolver.d.ts +13 -13
  117. package/lib/commands/optionresolver.js +23 -28
  118. package/lib/common/bot/watcher.d.ts +4 -33
  119. package/lib/common/bot/watcher.js +0 -109
  120. package/lib/common/index.d.ts +1 -0
  121. package/lib/common/index.js +1 -0
  122. package/lib/common/it/colors.js +48 -49
  123. package/lib/common/it/formatter.d.ts +32 -0
  124. package/lib/common/it/formatter.js +42 -0
  125. package/lib/common/it/logger.d.ts +0 -1
  126. package/lib/common/it/logger.js +3 -3
  127. package/lib/common/it/utils.d.ts +15 -2
  128. package/lib/common/it/utils.js +78 -17
  129. package/lib/common/shorters/application.d.ts +56 -0
  130. package/lib/common/shorters/application.js +81 -0
  131. package/lib/common/shorters/bans.d.ts +4 -5
  132. package/lib/common/shorters/bans.js +3 -3
  133. package/lib/common/shorters/channels.d.ts +7 -6
  134. package/lib/common/shorters/channels.js +19 -15
  135. package/lib/common/shorters/emojis.d.ts +5 -6
  136. package/lib/common/shorters/emojis.js +5 -5
  137. package/lib/common/shorters/guilds.d.ts +18 -16
  138. package/lib/common/shorters/guilds.js +31 -26
  139. package/lib/common/shorters/interaction.d.ts +6 -6
  140. package/lib/common/shorters/interaction.js +3 -2
  141. package/lib/common/shorters/members.d.ts +29 -12
  142. package/lib/common/shorters/members.js +55 -16
  143. package/lib/common/shorters/messages.d.ts +7 -8
  144. package/lib/common/shorters/messages.js +8 -7
  145. package/lib/common/shorters/reactions.d.ts +3 -3
  146. package/lib/common/shorters/reactions.js +11 -11
  147. package/lib/common/shorters/roles.d.ts +9 -7
  148. package/lib/common/shorters/roles.js +26 -7
  149. package/lib/common/shorters/templates.d.ts +7 -8
  150. package/lib/common/shorters/templates.js +7 -7
  151. package/lib/common/shorters/threads.d.ts +6 -7
  152. package/lib/common/shorters/threads.js +6 -9
  153. package/lib/common/shorters/users.d.ts +4 -4
  154. package/lib/common/shorters/users.js +8 -4
  155. package/lib/common/shorters/webhook.d.ts +10 -10
  156. package/lib/common/shorters/webhook.js +10 -9
  157. package/lib/common/types/resolvables.d.ts +2 -2
  158. package/lib/common/types/util.d.ts +3 -1
  159. package/lib/common/types/write.d.ts +1 -1
  160. package/lib/components/ActionRow.d.ts +1 -1
  161. package/lib/components/BaseComponent.d.ts +1 -1
  162. package/lib/components/BaseComponent.js +1 -1
  163. package/lib/components/BaseSelectMenuComponent.d.ts +1 -1
  164. package/lib/components/ButtonComponent.d.ts +17 -7
  165. package/lib/components/ButtonComponent.js +19 -2
  166. package/lib/components/ChannelSelectMenuComponent.d.ts +3 -3
  167. package/lib/components/MentionableSelectMenuComponent.d.ts +2 -2
  168. package/lib/components/RoleSelectMenuComponent.d.ts +2 -2
  169. package/lib/components/StringSelectMenuComponent.d.ts +2 -2
  170. package/lib/components/TextInputComponent.d.ts +2 -2
  171. package/lib/components/UserSelectMenuComponent.d.ts +2 -2
  172. package/lib/components/componentcommand.js +2 -2
  173. package/lib/components/componentcontext.d.ts +10 -9
  174. package/lib/components/componentcontext.js +8 -8
  175. package/lib/components/handler.d.ts +15 -14
  176. package/lib/components/handler.js +89 -93
  177. package/lib/components/index.d.ts +3 -3
  178. package/lib/components/index.js +12 -10
  179. package/lib/components/modalcontext.d.ts +12 -11
  180. package/lib/components/modalcontext.js +2 -2
  181. package/lib/deps/mixer.d.ts +8 -0
  182. package/lib/deps/mixer.js +66 -0
  183. package/lib/events/handler.d.ts +35 -13
  184. package/lib/events/handler.js +58 -25
  185. package/lib/events/hooks/application_command.d.ts +2 -2
  186. package/lib/events/hooks/auto_moderation.d.ts +6 -7
  187. package/lib/events/hooks/auto_moderation.js +4 -4
  188. package/lib/events/hooks/channel.d.ts +2 -2
  189. package/lib/events/hooks/channel.js +4 -7
  190. package/lib/events/hooks/custom.d.ts +3 -3
  191. package/lib/events/hooks/dispatch.d.ts +3 -4
  192. package/lib/events/hooks/dispatch.js +2 -2
  193. package/lib/events/hooks/entitlement.d.ts +5 -37
  194. package/lib/events/hooks/entitlement.js +7 -7
  195. package/lib/events/hooks/guild.d.ts +125 -125
  196. package/lib/events/hooks/guild.js +13 -15
  197. package/lib/events/hooks/integration.d.ts +27 -28
  198. package/lib/events/hooks/integration.js +3 -3
  199. package/lib/events/hooks/interactions.d.ts +2 -2
  200. package/lib/events/hooks/invite.d.ts +18 -17
  201. package/lib/events/hooks/message.d.ts +69 -54
  202. package/lib/events/hooks/message.js +4 -8
  203. package/lib/events/hooks/presence.d.ts +17 -16
  204. package/lib/events/hooks/stage.d.ts +4 -4
  205. package/lib/events/hooks/thread.d.ts +132 -63
  206. package/lib/events/hooks/thread.js +4 -4
  207. package/lib/events/hooks/typing.d.ts +28 -6
  208. package/lib/events/hooks/typing.js +2 -2
  209. package/lib/events/hooks/user.d.ts +3 -3
  210. package/lib/events/hooks/user.js +2 -2
  211. package/lib/events/hooks/voice.d.ts +28 -3
  212. package/lib/events/hooks/voice.js +8 -4
  213. package/lib/events/hooks/webhook.d.ts +1 -1
  214. package/lib/index.d.ts +5 -14
  215. package/lib/index.js +7 -12
  216. package/lib/langs/handler.d.ts +14 -10
  217. package/lib/langs/handler.js +40 -9
  218. package/lib/structures/AutoModerationRule.d.ts +4 -4
  219. package/lib/structures/AutoModerationRule.js +1 -2
  220. package/lib/structures/ClientUser.d.ts +1 -1
  221. package/lib/structures/Entitlement.d.ts +10 -0
  222. package/lib/structures/Entitlement.js +16 -0
  223. package/lib/structures/Guild.d.ts +33 -34
  224. package/lib/structures/Guild.js +5 -2
  225. package/lib/structures/GuildBan.d.ts +6 -6
  226. package/lib/structures/GuildBan.js +2 -1
  227. package/lib/structures/GuildEmoji.d.ts +4 -4
  228. package/lib/structures/GuildEmoji.js +3 -2
  229. package/lib/structures/GuildMember.d.ts +20 -17
  230. package/lib/structures/GuildMember.js +18 -8
  231. package/lib/structures/GuildPreview.d.ts +1 -1
  232. package/lib/structures/GuildRole.d.ts +5 -3
  233. package/lib/structures/GuildRole.js +8 -1
  234. package/lib/structures/GuildTemplate.d.ts +2 -2
  235. package/lib/structures/GuildTemplate.js +1 -1
  236. package/lib/structures/Interaction.d.ts +53 -36
  237. package/lib/structures/Interaction.js +127 -91
  238. package/lib/structures/Message.d.ts +29 -30
  239. package/lib/structures/Message.js +8 -9
  240. package/lib/structures/Poll.d.ts +4 -3
  241. package/lib/structures/Poll.js +6 -2
  242. package/lib/structures/Sticker.d.ts +7 -7
  243. package/lib/structures/Sticker.js +7 -7
  244. package/lib/structures/User.d.ts +5 -4
  245. package/lib/structures/User.js +2 -1
  246. package/lib/structures/VoiceState.d.ts +15 -11
  247. package/lib/structures/VoiceState.js +35 -17
  248. package/lib/structures/Webhook.d.ts +6 -7
  249. package/lib/structures/Webhook.js +6 -7
  250. package/lib/structures/channels.d.ts +11 -10
  251. package/lib/structures/channels.js +70 -65
  252. package/lib/structures/extra/BaseGuild.d.ts +1 -1
  253. package/lib/structures/extra/BaseGuild.js +3 -3
  254. package/lib/structures/extra/BitField.d.ts +1 -1
  255. package/lib/structures/extra/BitField.js +3 -2
  256. package/lib/structures/extra/DiscordBase.js +2 -2
  257. package/lib/structures/extra/Permissions.d.ts +3 -1
  258. package/lib/structures/extra/Permissions.js +8 -3
  259. package/lib/types/gateway.d.ts +1537 -0
  260. package/lib/types/gateway.js +4 -0
  261. package/lib/types/index.d.ts +9 -1
  262. package/lib/types/index.js +28 -1
  263. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/attachment.d.ts +5 -0
  264. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/attachment.js +2 -0
  265. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/base.d.ts +22 -0
  266. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/base.js +2 -0
  267. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/boolean.d.ts +4 -0
  268. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/boolean.js +2 -0
  269. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/channel.d.ts +7 -0
  270. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/channel.js +2 -0
  271. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/integer.d.ts +17 -0
  272. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/integer.js +2 -0
  273. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/mentionable.d.ts +5 -0
  274. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/mentionable.js +2 -0
  275. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/number.d.ts +17 -0
  276. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/number.js +2 -0
  277. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/role.d.ts +5 -0
  278. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/role.js +2 -0
  279. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/shared.d.ts +25 -0
  280. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/shared.js +20 -0
  281. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/string.d.ts +17 -0
  282. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/string.js +2 -0
  283. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommand.d.ts +11 -0
  284. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommand.js +2 -0
  285. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts +11 -0
  286. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommandGroup.js +2 -0
  287. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/user.d.ts +5 -0
  288. package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/user.js +2 -0
  289. package/lib/types/payloads/_interactions/_applicationCommands/chatInput.d.ts +60 -0
  290. package/lib/types/payloads/_interactions/_applicationCommands/chatInput.js +29 -0
  291. package/lib/types/payloads/_interactions/_applicationCommands/contextMenu.d.ts +65 -0
  292. package/lib/types/payloads/_interactions/_applicationCommands/contextMenu.js +2 -0
  293. package/lib/types/payloads/_interactions/_applicationCommands/internals.d.ts +8 -0
  294. package/lib/types/payloads/_interactions/_applicationCommands/internals.js +2 -0
  295. package/lib/types/payloads/_interactions/_applicationCommands/permissions.d.ts +54 -0
  296. package/lib/types/payloads/_interactions/_applicationCommands/permissions.js +20 -0
  297. package/lib/types/payloads/_interactions/applicationCommands.d.ts +153 -0
  298. package/lib/types/payloads/_interactions/applicationCommands.js +61 -0
  299. package/lib/types/payloads/_interactions/autocomplete.d.ts +10 -0
  300. package/lib/types/payloads/_interactions/autocomplete.js +2 -0
  301. package/lib/types/payloads/_interactions/base.d.ts +197 -0
  302. package/lib/types/payloads/_interactions/base.js +2 -0
  303. package/lib/types/payloads/_interactions/messageComponents.d.ts +41 -0
  304. package/lib/types/payloads/_interactions/messageComponents.js +2 -0
  305. package/lib/types/payloads/_interactions/modalSubmit.d.ts +35 -0
  306. package/lib/types/payloads/_interactions/modalSubmit.js +2 -0
  307. package/lib/types/payloads/_interactions/ping.d.ts +3 -0
  308. package/lib/types/payloads/_interactions/ping.js +2 -0
  309. package/lib/types/payloads/_interactions/responses.d.ts +112 -0
  310. package/lib/types/payloads/_interactions/responses.js +54 -0
  311. package/lib/types/payloads/application.d.ts +292 -0
  312. package/lib/types/payloads/application.js +117 -0
  313. package/lib/types/payloads/auditLog.d.ts +644 -0
  314. package/lib/types/payloads/auditLog.js +80 -0
  315. package/lib/types/payloads/autoModeration.d.ts +219 -0
  316. package/lib/types/payloads/autoModeration.js +87 -0
  317. package/lib/types/payloads/channel.d.ts +1708 -0
  318. package/lib/types/payloads/channel.js +372 -0
  319. package/lib/types/payloads/emoji.d.ts +48 -0
  320. package/lib/types/payloads/emoji.js +5 -0
  321. package/lib/types/payloads/gateway.d.ts +373 -0
  322. package/lib/types/payloads/gateway.js +82 -0
  323. package/lib/types/payloads/guild.d.ts +1060 -0
  324. package/lib/types/payloads/guild.js +324 -0
  325. package/lib/types/payloads/guildScheduledEvent.d.ts +138 -0
  326. package/lib/types/payloads/guildScheduledEvent.js +32 -0
  327. package/lib/types/payloads/index.d.ts +64 -0
  328. package/lib/types/payloads/index.js +37 -0
  329. package/lib/types/payloads/interactions.d.ts +24 -0
  330. package/lib/types/payloads/interactions.js +23 -0
  331. package/lib/types/payloads/invite.d.ts +121 -0
  332. package/lib/types/payloads/invite.js +23 -0
  333. package/lib/types/payloads/monetization.d.ts +150 -0
  334. package/lib/types/payloads/monetization.js +79 -0
  335. package/lib/types/payloads/oauth2.d.ts +131 -0
  336. package/lib/types/payloads/oauth2.js +135 -0
  337. package/lib/types/payloads/permissions.d.ts +97 -0
  338. package/lib/types/payloads/permissions.js +16 -0
  339. package/lib/types/payloads/poll.d.ts +104 -0
  340. package/lib/types/payloads/poll.js +16 -0
  341. package/lib/types/payloads/stageInstance.d.ts +77 -0
  342. package/lib/types/payloads/stageInstance.js +19 -0
  343. package/lib/types/payloads/sticker.d.ts +123 -0
  344. package/lib/types/payloads/sticker.js +30 -0
  345. package/lib/types/payloads/teams.d.ts +78 -0
  346. package/lib/types/payloads/teams.js +23 -0
  347. package/lib/types/payloads/template.d.ts +62 -0
  348. package/lib/types/payloads/template.js +5 -0
  349. package/lib/types/payloads/user.d.ts +337 -0
  350. package/lib/types/payloads/user.js +167 -0
  351. package/lib/types/payloads/voice.d.ts +89 -0
  352. package/lib/types/payloads/voice.js +5 -0
  353. package/lib/types/payloads/webhook.d.ts +76 -0
  354. package/lib/types/payloads/webhook.js +21 -0
  355. package/lib/types/rest/application.d.ts +57 -0
  356. package/lib/types/rest/application.js +2 -0
  357. package/lib/types/rest/auditLog.d.ts +30 -0
  358. package/lib/types/rest/auditLog.js +2 -0
  359. package/lib/types/rest/autoModeration.d.ts +66 -0
  360. package/lib/types/rest/autoModeration.js +2 -0
  361. package/lib/types/rest/channel.d.ts +712 -0
  362. package/lib/types/rest/channel.js +11 -0
  363. package/lib/types/rest/emoji.d.ts +54 -0
  364. package/lib/types/rest/emoji.js +2 -0
  365. package/lib/types/rest/gateway.d.ts +9 -0
  366. package/lib/types/rest/gateway.js +2 -0
  367. package/lib/types/rest/guild.d.ts +865 -0
  368. package/lib/types/rest/guild.js +2 -0
  369. package/lib/types/rest/guildScheduledEvent.d.ts +126 -0
  370. package/lib/types/rest/guildScheduledEvent.js +2 -0
  371. package/lib/types/rest/index.d.ts +296 -0
  372. package/lib/types/rest/index.js +292 -0
  373. package/lib/types/rest/interactions.d.ts +194 -0
  374. package/lib/types/rest/interactions.js +2 -0
  375. package/lib/types/rest/invite.d.ts +24 -0
  376. package/lib/types/rest/invite.js +2 -0
  377. package/lib/types/rest/monetization.d.ts +82 -0
  378. package/lib/types/rest/monetization.js +11 -0
  379. package/lib/types/rest/oauth2.d.ts +172 -0
  380. package/lib/types/rest/oauth2.js +2 -0
  381. package/lib/types/rest/poll.d.ts +44 -0
  382. package/lib/types/rest/poll.js +2 -0
  383. package/lib/types/rest/stageInstance.d.ts +58 -0
  384. package/lib/types/rest/stageInstance.js +2 -0
  385. package/lib/types/rest/sticker.d.ts +77 -0
  386. package/lib/types/rest/sticker.js +2 -0
  387. package/lib/types/rest/template.d.ts +62 -0
  388. package/lib/types/rest/template.js +2 -0
  389. package/lib/types/rest/user.d.ts +120 -0
  390. package/lib/types/rest/user.js +2 -0
  391. package/lib/types/rest/voice.d.ts +17 -0
  392. package/lib/types/rest/voice.js +2 -0
  393. package/lib/types/rest/webhook.d.ts +250 -0
  394. package/lib/types/rest/webhook.js +2 -0
  395. package/lib/types/utils/index.d.ts +797 -0
  396. package/lib/types/utils/index.js +799 -0
  397. package/lib/websocket/SharedTypes.d.ts +4 -3
  398. package/lib/websocket/SharedTypes.js +1 -1
  399. package/lib/websocket/constants/index.d.ts +0 -1
  400. package/lib/websocket/discord/basesocket.d.ts +7 -7
  401. package/lib/websocket/discord/basesocket.js +34 -22
  402. package/lib/websocket/discord/events/memberUpdate.d.ts +1 -6
  403. package/lib/websocket/discord/events/memberUpdate.js +2 -1
  404. package/lib/websocket/discord/events/presenceUpdate.d.ts +5 -18
  405. package/lib/websocket/discord/events/presenceUpdate.js +5 -6
  406. package/lib/websocket/discord/shard.d.ts +8 -8
  407. package/lib/websocket/discord/shard.js +59 -47
  408. package/lib/websocket/discord/sharder.d.ts +6 -5
  409. package/lib/websocket/discord/sharder.js +11 -10
  410. package/lib/websocket/discord/shared.d.ts +13 -5
  411. package/lib/websocket/discord/socket/custom.d.ts +52 -0
  412. package/lib/websocket/discord/socket/custom.js +283 -0
  413. package/lib/websocket/discord/worker.d.ts +5 -10
  414. package/lib/websocket/discord/workermanager.d.ts +8 -15
  415. package/lib/websocket/discord/workermanager.js +35 -39
  416. package/lib/websocket/structures/index.d.ts +0 -1
  417. package/lib/websocket/structures/index.js +1 -1
  418. package/lib/websocket/structures/timeout.d.ts +0 -1
  419. package/package.json +65 -74
  420. package/lib/cache/adapters/redis.d.ts +0 -37
  421. package/lib/cache/adapters/redis.js +0 -218
  422. package/lib/client/oninteractioncreate.d.ts +0 -4
  423. package/lib/client/oninteractioncreate.js +0 -198
  424. package/lib/client/onmessagecreate.d.ts +0 -13
  425. package/lib/client/onmessagecreate.js +0 -410
  426. package/lib/structures/extra/functions.d.ts +0 -12
  427. 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");
@@ -27,7 +28,7 @@ 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
30
  const bans_1 = require("./resources/bans");
30
- const v10_1 = require("discord-api-types/v10");
31
+ const types_1 = require("../types");
31
32
  const overwrites_1 = require("./resources/overwrites");
32
33
  const messages_1 = require("./resources/messages");
33
34
  __exportStar(require("./adapters/index"), exports);
@@ -52,55 +53,58 @@ class Cache {
52
53
  stageInstances;
53
54
  messages;
54
55
  bans;
55
- constructor(intents, adapter, disabledCache = [], client) {
56
+ __logger__;
57
+ constructor(intents, adapter, disabledCache = {}, client) {
56
58
  this.intents = intents;
57
59
  this.adapter = adapter;
58
60
  this.disabledCache = disabledCache;
59
61
  // non-guild based
60
- if (!this.disabledCache.includes('users')) {
62
+ if (!this.disabledCache.users) {
61
63
  this.users = new users_1.Users(this, client);
62
64
  }
63
- if (!this.disabledCache.includes('guilds')) {
65
+ if (!this.disabledCache.guilds) {
64
66
  this.guilds = new guilds_1.Guilds(this, client);
65
67
  }
66
68
  // guild related
67
- if (!this.disabledCache.includes('members')) {
69
+ if (!this.disabledCache.members) {
68
70
  this.members = new members_1.Members(this, client);
69
71
  }
70
- if (!this.disabledCache.includes('voiceStates')) {
72
+ if (!this.disabledCache.voiceStates) {
71
73
  this.voiceStates = new voice_states_1.VoiceStates(this, client);
72
74
  }
73
75
  // guild based
74
- if (!this.disabledCache.includes('roles')) {
76
+ if (!this.disabledCache.roles) {
75
77
  this.roles = new roles_1.Roles(this, client);
76
78
  }
77
- if (!this.disabledCache.includes('overwrites')) {
79
+ if (!this.disabledCache.overwrites) {
78
80
  this.overwrites = new overwrites_1.Overwrites(this, client);
79
81
  }
80
- if (!this.disabledCache.includes('channels')) {
82
+ if (!this.disabledCache.channels) {
81
83
  this.channels = new channels_1.Channels(this, client);
82
84
  }
83
- if (!this.disabledCache.includes('emojis')) {
85
+ if (!this.disabledCache.emojis) {
84
86
  this.emojis = new emojis_1.Emojis(this, client);
85
87
  }
86
- if (!this.disabledCache.includes('stickers')) {
88
+ if (!this.disabledCache.stickers) {
87
89
  this.stickers = new stickers_1.Stickers(this, client);
88
90
  }
89
- if (!this.disabledCache.includes('presences')) {
91
+ if (!this.disabledCache.presences) {
90
92
  this.presences = new presence_1.Presences(this, client);
91
93
  }
92
- if (!this.disabledCache.includes('threads')) {
94
+ if (!this.disabledCache.threads) {
93
95
  this.threads = new threads_1.Threads(this, client);
94
96
  }
95
- if (!this.disabledCache.includes('stageInstances')) {
97
+ if (!this.disabledCache.stageInstances) {
96
98
  this.stageInstances = new stage_instances_1.StageInstances(this, client);
97
99
  }
98
- if (!this.disabledCache.includes('messages')) {
100
+ if (!this.disabledCache.messages) {
99
101
  this.messages = new messages_1.Messages(this, client);
100
102
  }
101
- if (!this.disabledCache.includes('bans')) {
103
+ if (!this.disabledCache.bans) {
102
104
  this.bans = new bans_1.Bans(this, client);
103
105
  }
106
+ if (this.disabledCache.onPacket)
107
+ delete this.onPacket;
104
108
  }
105
109
  /** @internal */
106
110
  __setClient(client) {
@@ -124,7 +128,7 @@ class Cache {
124
128
  }
125
129
  // internal use ./structures
126
130
  hasIntent(intent) {
127
- return (this.intents & v10_1.GatewayIntentBits[intent]) === v10_1.GatewayIntentBits[intent];
131
+ return (this.intents & types_1.GatewayIntentBits[intent]) === types_1.GatewayIntentBits[intent];
128
132
  }
129
133
  get hasGuildsIntent() {
130
134
  return this.hasIntent('Guilds');
@@ -274,7 +278,7 @@ class Cache {
274
278
  }
275
279
  }
276
280
  await this.adapter.bulkAddToRelationShip(relationshipsData);
277
- await this.adapter.patch(false, allData);
281
+ await this.adapter.bulkPatch(false, allData);
278
282
  }
279
283
  async bulkSet(keys) {
280
284
  const allData = [];
@@ -289,7 +293,6 @@ class Cache {
289
293
  case 'stageInstances':
290
294
  case 'emojis':
291
295
  case 'overwrites':
292
- case 'bans':
293
296
  case 'messages':
294
297
  {
295
298
  if (!this[type]?.filter(data, id, guildId))
@@ -308,6 +311,7 @@ class Cache {
308
311
  allData.push([this[type].hashId(id), this[type].parse(data, id, guildId)]);
309
312
  }
310
313
  break;
314
+ case 'bans':
311
315
  case 'voiceStates':
312
316
  case 'members':
313
317
  {
@@ -346,7 +350,7 @@ class Cache {
346
350
  }
347
351
  }
348
352
  await this.adapter.bulkAddToRelationShip(relationshipsData);
349
- await this.adapter.set(allData);
353
+ await this.adapter.bulkSet(allData);
350
354
  }
351
355
  async onPacket(event) {
352
356
  switch (event.t) {
@@ -373,7 +377,7 @@ class Cache {
373
377
  await this.overwrites?.set(event.d.id, event.d.guild_id, event.d.permission_overwrites);
374
378
  break;
375
379
  }
376
- if (event.d.type === v10_1.ChannelType.DM) {
380
+ if (event.d.type === types_1.ChannelType.DM) {
377
381
  await this.channels?.set(event.d.recipients[0]?.id, '@me', event.d);
378
382
  break;
379
383
  }
@@ -457,5 +461,299 @@ class Cache {
457
461
  break;
458
462
  }
459
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
+ }
460
758
  }
461
759
  exports.Cache = Cache;
@@ -1,12 +1,15 @@
1
- import type { APIBan } from 'discord-api-types/v10';
1
+ import type { APIBan, GatewayGuildBanModifyDispatchData } from '../../types';
2
2
  import type { ReturnCache } from '../..';
3
3
  import { GuildBasedResource } from './default/guild-based';
4
- import { GuildBan } from '../../structures/GuildBan';
5
- export declare class Bans extends GuildBasedResource {
4
+ import { type GuildBanStructure } from '../../client/transformers';
5
+ export declare class Bans extends GuildBasedResource<any, GatewayGuildBanModifyDispatchData | APIBan> {
6
6
  namespace: string;
7
7
  filter(data: APIBan, id: string, guild_id: string): boolean;
8
8
  parse(data: any, key: string, guild_id: string): any;
9
- get(id: string, guild: string): ReturnCache<GuildBan | undefined>;
10
- bulk(ids: string[], guild: string): ReturnCache<GuildBan[]>;
11
- values(guild: string): ReturnCache<GuildBan[]>;
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'>[]>;
12
15
  }
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Bans = void 0;
4
4
  const common_1 = require("../../common");
5
5
  const guild_based_1 = require("./default/guild-based");
6
- const GuildBan_1 = require("../../structures/GuildBan");
6
+ const transformers_1 = require("../../client/transformers");
7
7
  class Bans extends guild_based_1.GuildBasedResource {
8
8
  namespace = 'ban';
9
9
  //@ts-expect-error
@@ -15,21 +15,30 @@ class Bans extends guild_based_1.GuildBasedResource {
15
15
  return rest;
16
16
  }
17
17
  get(id, guild) {
18
- return (0, common_1.fakePromise)(super.get(id, guild)).then(rawBan => rawBan ? new GuildBan_1.GuildBan(this.client, rawBan, guild) : undefined);
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);
19
22
  }
20
23
  bulk(ids, guild) {
21
24
  return (0, common_1.fakePromise)(super.bulk(ids, guild)).then(bans => bans
22
25
  .map(rawBan => {
23
- return rawBan ? new GuildBan_1.GuildBan(this.client, rawBan, guild) : undefined;
26
+ return rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined;
24
27
  })
25
28
  .filter(Boolean));
26
29
  }
30
+ bulkRaw(ids, guild) {
31
+ return super.bulk(ids, guild);
32
+ }
27
33
  values(guild) {
28
34
  return (0, common_1.fakePromise)(super.values(guild)).then(bans => bans
29
35
  .map(rawBan => {
30
- return rawBan ? new GuildBan_1.GuildBan(this.client, rawBan, guild) : undefined;
36
+ return rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined;
31
37
  })
32
38
  .filter(Boolean));
33
39
  }
40
+ valuesRaw(guild) {
41
+ return super.values(guild);
42
+ }
34
43
  }
35
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;
@@ -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 GuildBasedResource<T = any> {
4
+ export declare class GuildBasedResource<T = any, S = any> {
5
5
  protected cache: Cache;
6
6
  client: UsingClient;
7
7
  namespace: string;
@@ -10,16 +10,16 @@ export declare class GuildBasedResource<T = any> {
10
10
  parse(data: any, id: string, guild_id: string): any;
11
11
  get adapter(): import("../../index").Adapter;
12
12
  removeIfNI(intent: keyof typeof GatewayIntentBits, id: string | string[], guildId: string): import("../../../common").Awaitable<void>;
13
- setIfNI(intent: keyof typeof GatewayIntentBits, id: string, guildId: string, data: any): void;
13
+ setIfNI(intent: keyof typeof GatewayIntentBits, id: string, guildId: string, data: S): void;
14
14
  get(id: string, guild: string): ReturnCache<(T & {
15
15
  guild_id: string;
16
16
  }) | undefined>;
17
17
  bulk(ids: string[], guild: string): ReturnCache<(T & {
18
18
  guild_id: string;
19
19
  })[]>;
20
- set(__keys: string, guild: string, data: any): ReturnCache<void>;
21
- set(__keys: [string, any][], guild: string): ReturnCache<void>;
22
- patch(__keys: string, guild: string, data: any): ReturnCache<void>;
20
+ set(__keys: string, guild: string, data: S): ReturnCache<void>;
21
+ set(__keys: [string, S][], guild: string): ReturnCache<void>;
22
+ patch(__keys: string, guild: string, data: S): ReturnCache<void>;
23
23
  patch(__keys: [string, any][], guild: string): ReturnCache<void>;
24
24
  remove(id: string | string[], guild: string): import("../../../common").Awaitable<void>;
25
25
  keys(guild: string): ReturnCache<string[]>;