discord-sb.js 1.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 (366) hide show
  1. package/LICENSE +674 -0
  2. package/README.md +2 -0
  3. package/package.json +91 -0
  4. package/src/WebSocket.js +39 -0
  5. package/src/client/BaseClient.js +86 -0
  6. package/src/client/Client.js +978 -0
  7. package/src/client/WebhookClient.js +61 -0
  8. package/src/client/actions/Action.js +116 -0
  9. package/src/client/actions/ActionsManager.js +80 -0
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  11. package/src/client/actions/AutoModerationActionExecution.js +27 -0
  12. package/src/client/actions/AutoModerationRuleCreate.js +28 -0
  13. package/src/client/actions/AutoModerationRuleDelete.js +32 -0
  14. package/src/client/actions/AutoModerationRuleUpdate.js +30 -0
  15. package/src/client/actions/ChannelCreate.js +23 -0
  16. package/src/client/actions/ChannelDelete.js +39 -0
  17. package/src/client/actions/ChannelUpdate.js +43 -0
  18. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
  19. package/src/client/actions/GuildBanAdd.js +20 -0
  20. package/src/client/actions/GuildBanRemove.js +25 -0
  21. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
  22. package/src/client/actions/GuildDelete.js +65 -0
  23. package/src/client/actions/GuildEmojiCreate.js +20 -0
  24. package/src/client/actions/GuildEmojiDelete.js +21 -0
  25. package/src/client/actions/GuildEmojiUpdate.js +20 -0
  26. package/src/client/actions/GuildEmojisUpdate.js +34 -0
  27. package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
  28. package/src/client/actions/GuildMemberRemove.js +33 -0
  29. package/src/client/actions/GuildMemberUpdate.js +44 -0
  30. package/src/client/actions/GuildRoleCreate.js +25 -0
  31. package/src/client/actions/GuildRoleDelete.js +31 -0
  32. package/src/client/actions/GuildRoleUpdate.js +39 -0
  33. package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
  34. package/src/client/actions/GuildScheduledEventCreate.js +27 -0
  35. package/src/client/actions/GuildScheduledEventDelete.js +31 -0
  36. package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
  37. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
  38. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
  39. package/src/client/actions/GuildStickerCreate.js +20 -0
  40. package/src/client/actions/GuildStickerDelete.js +21 -0
  41. package/src/client/actions/GuildStickerUpdate.js +20 -0
  42. package/src/client/actions/GuildStickersUpdate.js +34 -0
  43. package/src/client/actions/GuildUpdate.js +33 -0
  44. package/src/client/actions/InviteCreate.js +28 -0
  45. package/src/client/actions/InviteDelete.js +30 -0
  46. package/src/client/actions/MessageCreate.js +50 -0
  47. package/src/client/actions/MessageDelete.js +32 -0
  48. package/src/client/actions/MessageDeleteBulk.js +46 -0
  49. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  50. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  51. package/src/client/actions/MessageReactionAdd.js +68 -0
  52. package/src/client/actions/MessageReactionRemove.js +50 -0
  53. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  54. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  55. package/src/client/actions/MessageUpdate.js +26 -0
  56. package/src/client/actions/PresenceUpdate.js +50 -0
  57. package/src/client/actions/StageInstanceCreate.js +28 -0
  58. package/src/client/actions/StageInstanceDelete.js +33 -0
  59. package/src/client/actions/StageInstanceUpdate.js +30 -0
  60. package/src/client/actions/ThreadCreate.js +24 -0
  61. package/src/client/actions/ThreadDelete.js +32 -0
  62. package/src/client/actions/ThreadListSync.js +59 -0
  63. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  64. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  65. package/src/client/actions/TypingStart.js +29 -0
  66. package/src/client/actions/UserUpdate.js +35 -0
  67. package/src/client/actions/VoiceStateUpdate.js +50 -0
  68. package/src/client/actions/WebhooksUpdate.js +20 -0
  69. package/src/client/voice/ClientVoiceManager.js +151 -0
  70. package/src/client/voice/VoiceConnection.js +1249 -0
  71. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  72. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  73. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  74. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  75. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  76. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  77. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  78. package/src/client/voice/player/MediaPlayer.js +321 -0
  79. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  80. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  81. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  82. package/src/client/voice/receiver/PacketHandler.js +260 -0
  83. package/src/client/voice/receiver/Receiver.js +96 -0
  84. package/src/client/voice/receiver/Recorder.js +173 -0
  85. package/src/client/voice/util/Function.js +116 -0
  86. package/src/client/voice/util/PlayInterface.js +122 -0
  87. package/src/client/voice/util/Secretbox.js +64 -0
  88. package/src/client/voice/util/Silence.js +16 -0
  89. package/src/client/voice/util/Socket.js +62 -0
  90. package/src/client/voice/util/VolumeInterface.js +104 -0
  91. package/src/client/websocket/WebSocketManager.js +392 -0
  92. package/src/client/websocket/WebSocketShard.js +907 -0
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  96. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  97. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  100. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  101. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  102. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  103. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  104. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  105. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  106. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -0
  108. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  109. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  110. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  111. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  112. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  113. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -0
  114. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  115. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  116. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  117. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  118. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  119. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  120. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  121. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  122. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  123. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  128. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  129. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  130. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  131. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -0
  132. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  133. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  134. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  135. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  136. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -0
  138. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -0
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  142. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  143. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  144. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  145. package/src/client/websocket/handlers/READY.js +121 -0
  146. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -0
  147. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -0
  148. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -0
  149. package/src/client/websocket/handlers/RESUMED.js +14 -0
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  152. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  153. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  154. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  155. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  156. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  157. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  158. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  159. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  160. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -0
  161. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  162. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -0
  163. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -0
  164. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  166. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -0
  167. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  168. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  169. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  170. package/src/client/websocket/handlers/index.js +84 -0
  171. package/src/errors/DJSError.js +61 -0
  172. package/src/errors/Messages.js +217 -0
  173. package/src/errors/index.js +4 -0
  174. package/src/index.js +172 -0
  175. package/src/managers/ApplicationCommandManager.js +264 -0
  176. package/src/managers/ApplicationCommandPermissionsManager.js +417 -0
  177. package/src/managers/AutoModerationRuleManager.js +296 -0
  178. package/src/managers/BaseGuildEmojiManager.js +80 -0
  179. package/src/managers/BaseManager.js +19 -0
  180. package/src/managers/BillingManager.js +66 -0
  181. package/src/managers/CachedManager.js +71 -0
  182. package/src/managers/ChannelManager.js +148 -0
  183. package/src/managers/ClientUserSettingManager.js +372 -0
  184. package/src/managers/DataManager.js +61 -0
  185. package/src/managers/DeveloperManager.js +254 -0
  186. package/src/managers/GuildBanManager.js +250 -0
  187. package/src/managers/GuildChannelManager.js +488 -0
  188. package/src/managers/GuildEmojiManager.js +171 -0
  189. package/src/managers/GuildEmojiRoleManager.js +118 -0
  190. package/src/managers/GuildForumThreadManager.js +108 -0
  191. package/src/managers/GuildInviteManager.js +213 -0
  192. package/src/managers/GuildManager.js +338 -0
  193. package/src/managers/GuildMemberManager.js +599 -0
  194. package/src/managers/GuildMemberRoleManager.js +195 -0
  195. package/src/managers/GuildScheduledEventManager.js +314 -0
  196. package/src/managers/GuildSettingManager.js +155 -0
  197. package/src/managers/GuildStickerManager.js +179 -0
  198. package/src/managers/GuildTextThreadManager.js +98 -0
  199. package/src/managers/InteractionManager.js +39 -0
  200. package/src/managers/MessageManager.js +423 -0
  201. package/src/managers/PermissionOverwriteManager.js +164 -0
  202. package/src/managers/PresenceManager.js +71 -0
  203. package/src/managers/QuestManager.js +353 -0
  204. package/src/managers/ReactionManager.js +67 -0
  205. package/src/managers/ReactionUserManager.js +73 -0
  206. package/src/managers/RelationshipManager.js +278 -0
  207. package/src/managers/RoleManager.js +448 -0
  208. package/src/managers/SessionManager.js +66 -0
  209. package/src/managers/StageInstanceManager.js +162 -0
  210. package/src/managers/ThreadManager.js +175 -0
  211. package/src/managers/ThreadMemberManager.js +186 -0
  212. package/src/managers/UserManager.js +136 -0
  213. package/src/managers/UserNoteManager.js +53 -0
  214. package/src/managers/VoiceStateManager.js +59 -0
  215. package/src/rest/APIRequest.js +154 -0
  216. package/src/rest/APIRouter.js +53 -0
  217. package/src/rest/DiscordAPIError.js +119 -0
  218. package/src/rest/HTTPError.js +62 -0
  219. package/src/rest/RESTManager.js +67 -0
  220. package/src/rest/RateLimitError.js +55 -0
  221. package/src/rest/RequestHandler.js +466 -0
  222. package/src/sharding/Shard.js +444 -0
  223. package/src/sharding/ShardClientUtil.js +279 -0
  224. package/src/sharding/ShardingManager.js +319 -0
  225. package/src/structures/AnonymousGuild.js +98 -0
  226. package/src/structures/ApplicationCommand.js +593 -0
  227. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -0
  228. package/src/structures/AutoModerationActionExecution.js +89 -0
  229. package/src/structures/AutoModerationRule.js +294 -0
  230. package/src/structures/AutocompleteInteraction.js +107 -0
  231. package/src/structures/Base.js +43 -0
  232. package/src/structures/BaseCommandInteraction.js +211 -0
  233. package/src/structures/BaseGuild.js +116 -0
  234. package/src/structures/BaseGuildEmoji.js +56 -0
  235. package/src/structures/BaseGuildTextChannel.js +191 -0
  236. package/src/structures/BaseGuildVoiceChannel.js +241 -0
  237. package/src/structures/BaseMessageComponent.js +181 -0
  238. package/src/structures/ButtonInteraction.js +11 -0
  239. package/src/structures/CallState.js +63 -0
  240. package/src/structures/CategoryChannel.js +85 -0
  241. package/src/structures/Channel.js +284 -0
  242. package/src/structures/ClientPresence.js +77 -0
  243. package/src/structures/ClientUser.js +655 -0
  244. package/src/structures/CommandInteraction.js +41 -0
  245. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  246. package/src/structures/ContainerComponent.js +68 -0
  247. package/src/structures/ContextMenuInteraction.js +65 -0
  248. package/src/structures/DMChannel.js +219 -0
  249. package/src/structures/DirectoryChannel.js +20 -0
  250. package/src/structures/Emoji.js +148 -0
  251. package/src/structures/FileComponent.js +49 -0
  252. package/src/structures/ForumChannel.js +31 -0
  253. package/src/structures/GroupDMChannel.js +394 -0
  254. package/src/structures/Guild.js +1791 -0
  255. package/src/structures/GuildAuditLogs.js +746 -0
  256. package/src/structures/GuildBan.js +59 -0
  257. package/src/structures/GuildBoost.js +108 -0
  258. package/src/structures/GuildChannel.js +470 -0
  259. package/src/structures/GuildEmoji.js +161 -0
  260. package/src/structures/GuildMember.js +636 -0
  261. package/src/structures/GuildPreview.js +191 -0
  262. package/src/structures/GuildPreviewEmoji.js +27 -0
  263. package/src/structures/GuildScheduledEvent.js +536 -0
  264. package/src/structures/GuildTemplate.js +236 -0
  265. package/src/structures/Integration.js +188 -0
  266. package/src/structures/IntegrationApplication.js +96 -0
  267. package/src/structures/Interaction.js +290 -0
  268. package/src/structures/InteractionCollector.js +248 -0
  269. package/src/structures/InteractionWebhook.js +43 -0
  270. package/src/structures/Invite.js +358 -0
  271. package/src/structures/InviteGuild.js +23 -0
  272. package/src/structures/InviteStageInstance.js +86 -0
  273. package/src/structures/MediaChannel.js +11 -0
  274. package/src/structures/MediaGalleryComponent.js +41 -0
  275. package/src/structures/MediaGalleryItem.js +47 -0
  276. package/src/structures/Message.js +1252 -0
  277. package/src/structures/MessageActionRow.js +105 -0
  278. package/src/structures/MessageAttachment.js +216 -0
  279. package/src/structures/MessageButton.js +166 -0
  280. package/src/structures/MessageCollector.js +146 -0
  281. package/src/structures/MessageComponentInteraction.js +120 -0
  282. package/src/structures/MessageContextMenuInteraction.js +20 -0
  283. package/src/structures/MessageEmbed.js +596 -0
  284. package/src/structures/MessageMentions.js +273 -0
  285. package/src/structures/MessagePayload.js +354 -0
  286. package/src/structures/MessageReaction.js +181 -0
  287. package/src/structures/MessageSelectMenu.js +141 -0
  288. package/src/structures/Modal.js +161 -0
  289. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  290. package/src/structures/ModalSubmitInteraction.js +119 -0
  291. package/src/structures/NewsChannel.js +32 -0
  292. package/src/structures/OAuth2Guild.js +28 -0
  293. package/src/structures/PermissionOverwrites.js +198 -0
  294. package/src/structures/Poll.js +108 -0
  295. package/src/structures/PollAnswer.js +88 -0
  296. package/src/structures/Presence.js +1157 -0
  297. package/src/structures/ReactionCollector.js +229 -0
  298. package/src/structures/ReactionEmoji.js +31 -0
  299. package/src/structures/Role.js +590 -0
  300. package/src/structures/SectionComponent.js +48 -0
  301. package/src/structures/SelectMenuInteraction.js +21 -0
  302. package/src/structures/SeparatorComponent.js +48 -0
  303. package/src/structures/Session.js +81 -0
  304. package/src/structures/StageChannel.js +104 -0
  305. package/src/structures/StageInstance.js +208 -0
  306. package/src/structures/Sticker.js +310 -0
  307. package/src/structures/StickerPack.js +95 -0
  308. package/src/structures/StoreChannel.js +56 -0
  309. package/src/structures/Team.js +118 -0
  310. package/src/structures/TeamMember.js +80 -0
  311. package/src/structures/TextChannel.js +33 -0
  312. package/src/structures/TextDisplayComponent.js +40 -0
  313. package/src/structures/TextInputComponent.js +132 -0
  314. package/src/structures/ThreadChannel.js +605 -0
  315. package/src/structures/ThreadMember.js +105 -0
  316. package/src/structures/ThreadOnlyChannel.js +249 -0
  317. package/src/structures/ThumbnailComponent.js +57 -0
  318. package/src/structures/Typing.js +74 -0
  319. package/src/structures/UnfurledMediaItem.js +29 -0
  320. package/src/structures/User.js +640 -0
  321. package/src/structures/UserContextMenuInteraction.js +29 -0
  322. package/src/structures/VoiceChannel.js +110 -0
  323. package/src/structures/VoiceChannelEffect.js +69 -0
  324. package/src/structures/VoiceRegion.js +53 -0
  325. package/src/structures/VoiceState.js +354 -0
  326. package/src/structures/WebEmbed.js +373 -0
  327. package/src/structures/Webhook.js +478 -0
  328. package/src/structures/WelcomeChannel.js +60 -0
  329. package/src/structures/WelcomeScreen.js +48 -0
  330. package/src/structures/Widget.js +87 -0
  331. package/src/structures/WidgetMember.js +99 -0
  332. package/src/structures/interfaces/Application.js +953 -0
  333. package/src/structures/interfaces/Collector.js +300 -0
  334. package/src/structures/interfaces/InteractionResponses.js +313 -0
  335. package/src/structures/interfaces/TextBasedChannel.js +821 -0
  336. package/src/util/APITypes.js +59 -0
  337. package/src/util/ActivityFlags.js +44 -0
  338. package/src/util/ApplicationFlags.js +76 -0
  339. package/src/util/AttachmentFlags.js +38 -0
  340. package/src/util/BitField.js +170 -0
  341. package/src/util/ChannelFlags.js +45 -0
  342. package/src/util/Constants.js +1914 -0
  343. package/src/util/DataResolver.js +146 -0
  344. package/src/util/Formatters.js +228 -0
  345. package/src/util/GuildMemberFlags.js +43 -0
  346. package/src/util/Intents.js +74 -0
  347. package/src/util/InviteFlags.js +34 -0
  348. package/src/util/LimitedCollection.js +131 -0
  349. package/src/util/MessageFlags.js +63 -0
  350. package/src/util/Options.js +358 -0
  351. package/src/util/Permissions.js +202 -0
  352. package/src/util/PremiumUsageFlags.js +31 -0
  353. package/src/util/PurchasedFlags.js +33 -0
  354. package/src/util/RemoteAuth.js +415 -0
  355. package/src/util/RoleFlags.js +37 -0
  356. package/src/util/SnowflakeUtil.js +92 -0
  357. package/src/util/Speaking.js +33 -0
  358. package/src/util/Sweepers.js +466 -0
  359. package/src/util/SystemChannelFlags.js +55 -0
  360. package/src/util/ThreadMemberFlags.js +30 -0
  361. package/src/util/UserFlags.js +104 -0
  362. package/src/util/Util.js +1048 -0
  363. package/typings/enums.d.ts +439 -0
  364. package/typings/index.d.ts +8505 -0
  365. package/typings/index.test-d.ts +0 -0
  366. package/typings/rawDataTypes.d.ts +403 -0
@@ -0,0 +1,175 @@
1
+ 'use strict';
2
+
3
+ const { Collection } = require('@discordjs/collection');
4
+ const CachedManager = require('./CachedManager');
5
+ const ThreadChannel = require('../structures/ThreadChannel');
6
+
7
+ /**
8
+ * Manages API methods for {@link ThreadChannel} objects and stores their cache.
9
+ * @extends {CachedManager}
10
+ */
11
+ class ThreadManager extends CachedManager {
12
+ constructor(channel, iterable) {
13
+ super(channel.client, ThreadChannel, iterable);
14
+
15
+ /**
16
+ * The channel this Manager belongs to
17
+ * @type {NewsChannel|TextChannel}
18
+ */
19
+ this.channel = channel;
20
+ }
21
+
22
+ /**
23
+ * The cache of this Manager
24
+ * @type {Collection<Snowflake, ThreadChannel>}
25
+ * @name ThreadManager#cache
26
+ */
27
+
28
+ _add(thread) {
29
+ const existing = this.cache.get(thread.id);
30
+ if (existing) return existing;
31
+ this.cache.set(thread.id, thread);
32
+ return thread;
33
+ }
34
+
35
+ /**
36
+ * Data that can be resolved to a Thread Channel object. This can be:
37
+ * * A ThreadChannel object
38
+ * * A Snowflake
39
+ * @typedef {ThreadChannel|Snowflake} ThreadChannelResolvable
40
+ */
41
+
42
+ /**
43
+ * Resolves a {@link ThreadChannelResolvable} to a {@link ThreadChannel} object.
44
+ * @method resolve
45
+ * @memberof ThreadManager
46
+ * @instance
47
+ * @param {ThreadChannelResolvable} thread The ThreadChannel resolvable to resolve
48
+ * @returns {?ThreadChannel}
49
+ */
50
+
51
+ /**
52
+ * Resolves a {@link ThreadChannelResolvable} to a {@link ThreadChannel} id.
53
+ * @method resolveId
54
+ * @memberof ThreadManager
55
+ * @instance
56
+ * @param {ThreadChannelResolvable} thread The ThreadChannel resolvable to resolve
57
+ * @returns {?Snowflake}
58
+ */
59
+
60
+ /**
61
+ * Options for fetching multiple threads.
62
+ * @typedef {Object} FetchThreadsOptions
63
+ * @property {FetchArchivedThreadOptions} [archived] The options used to fetch archived threads
64
+ */
65
+
66
+ /**
67
+ * Obtains a thread from Discord, or the channel cache if it's already available.
68
+ * @param {ThreadChannelResolvable|FetchChannelThreadsOptions|FetchThreadsOptions} [options] The options to fetch threads. If it is a
69
+ * ThreadChannelResolvable then the specified thread will be fetched. Fetches all active threads if `undefined`
70
+ * @param {BaseFetchOptions} [cacheOptions] Additional options for this fetch. <warn>The `force` field gets ignored
71
+ * if `options` is not a {@link ThreadChannelResolvable}</warn>
72
+ * @returns {Promise<?(ThreadChannel|FetchedThreads)>}
73
+ * @example
74
+ * // Fetch a thread by its id
75
+ * channel.threads.fetch('831955138126104859')
76
+ * .then(channel => console.log(channel.name))
77
+ * .catch(console.error);
78
+ */
79
+ fetch(options, { cache, force } = {}) {
80
+ if (!options) return this.fetchActive(cache);
81
+ const channel = this.client.channels.resolveId(options);
82
+ if (channel) return this.client.channels.fetch(channel, { cache, force });
83
+ if (options.archived) {
84
+ return this.fetchArchived(options.archived, cache);
85
+ }
86
+ return this.fetchActive(cache);
87
+ }
88
+
89
+ /**
90
+ * Data that can be resolved to a Date object. This can be:
91
+ * * A Date object
92
+ * * A number representing a timestamp
93
+ * * An [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) string
94
+ * @typedef {Date|number|string} DateResolvable
95
+ */
96
+
97
+ /**
98
+ * The options used to fetch archived threads.
99
+ * @typedef {Object} FetchArchivedThreadOptions
100
+ * @property {string} [type='public'] The type of threads to fetch, either `public` or `private`
101
+ * @property {boolean} [fetchAll=false] Whether to fetch **all** archived threads when type is `private`.
102
+ * Requires `MANAGE_THREADS` if true
103
+ * @property {DateResolvable|ThreadChannelResolvable} [before] Only return threads that were archived before this Date
104
+ * or Snowflake. <warn>Must be a {@link ThreadChannelResolvable} when type is `private` and fetchAll is `false`</warn>
105
+ * @property {number} [limit] Maximum number of threads to return
106
+ */
107
+
108
+ /**
109
+ * The data returned from a thread fetch that returns multiple threads.
110
+ * @typedef {Object} FetchedThreads
111
+ * @property {Collection<Snowflake, ThreadChannel>} threads The threads that were fetched, with any members returned
112
+ * @property {?boolean} hasMore Whether there are potentially additional threads that require a subsequent call
113
+ */
114
+
115
+ /**
116
+ * Obtains a set of archived threads from Discord, requires `READ_MESSAGE_HISTORY` in the parent channel.
117
+ * @param {FetchChannelThreadsOptions} [options] The options to fetch archived threads
118
+ * @param {boolean} [cache=true] Whether to cache the new thread objects if they aren't already
119
+ * @returns {Promise<FetchedThreads>}
120
+ */
121
+ fetchArchived(options = {}, cache = true) {
122
+ return this.fetchActive(cache, { archived: true, ...options });
123
+ }
124
+
125
+ /**
126
+ * Discord.js self-bot specific options field for fetching active threads.
127
+ * @typedef {Object} FetchChannelThreadsOptions
128
+ * @property {boolean} [archived] Whether to fetch archived threads (default is false)
129
+ * @property {string} [sortBy] The order in which the threads should be fetched in (default is last_message_time)
130
+ * @property {string} [sortOrder] How the threads should be ordered (default is desc)
131
+ * @property {number} [limit] The maximum number of threads to return (default is 25)
132
+ * @property {number} [offset] The number of threads to offset fetching (useful when making multiple fetches) (default is 0)
133
+ */
134
+
135
+ /**
136
+ * Obtains the accessible active threads from Discord, requires `READ_MESSAGE_HISTORY` in the parent channel.
137
+ * @param {boolean} [cache=true] Whether to cache the new thread objects if they aren't already
138
+ * @param {FetchChannelThreadsOptions} [options] Options for self-bots where advanced users can specify further options
139
+ * @returns {Promise<FetchedThreads>}
140
+ */
141
+ async fetchActive(cache = true, options = {}) {
142
+ const raw = await this.client.api.channels(this.channel.id).threads.search.get({
143
+ query: {
144
+ archived: options?.archived ?? false,
145
+ limit: options?.limit ?? 25,
146
+ offset: options?.offset ?? 0,
147
+ sort_by: options?.sortBy ?? 'last_message_time',
148
+ sort_order: options?.sortOrder ?? 'desc',
149
+ },
150
+ });
151
+
152
+ return this.constructor._mapThreads(raw, this.client, { parent: this.channel, cache });
153
+ }
154
+
155
+ static _mapThreads(rawThreads, client, { parent, guild, cache }) {
156
+ const threads = rawThreads.threads.reduce((coll, raw) => {
157
+ const thread = client.channels._add(raw, guild ?? parent?.guild, { cache });
158
+ if (parent && thread.parentId !== parent.id) return coll;
159
+ return coll.set(thread.id, thread);
160
+ }, new Collection());
161
+ // Discord sends the thread id as id in this object
162
+ for (const rawMember of rawThreads.members) client.channels.cache.get(rawMember.id)?.members._add(rawMember);
163
+ // Patch firstMessage
164
+ // According to https://github.com/aiko-chan-ai/discord-selfbot.js/issues/1502, rawThreads.first_messages could be null.
165
+ for (const rawMessage of rawThreads?.first_messages || []) {
166
+ client.channels.cache.get(rawMessage.id)?.messages._add(rawMessage);
167
+ }
168
+ return {
169
+ threads,
170
+ hasMore: rawThreads.has_more ?? false,
171
+ };
172
+ }
173
+ }
174
+
175
+ module.exports = ThreadManager;
@@ -0,0 +1,186 @@
1
+ 'use strict';
2
+ const process = require('node:process');
3
+
4
+ const { Collection } = require('@discordjs/collection');
5
+ const CachedManager = require('./CachedManager');
6
+ const { TypeError } = require('../errors');
7
+ const ThreadMember = require('../structures/ThreadMember');
8
+
9
+ let deprecationEmittedForPassingBoolean = false;
10
+
11
+ /**
12
+ * Manages API methods for GuildMembers and stores their cache.
13
+ * @extends {CachedManager}
14
+ */
15
+ class ThreadMemberManager extends CachedManager {
16
+ constructor(thread, iterable) {
17
+ super(thread.client, ThreadMember, iterable);
18
+
19
+ /**
20
+ * The thread this manager belongs to
21
+ * @type {ThreadChannel}
22
+ */
23
+ this.thread = thread;
24
+ }
25
+
26
+ /**
27
+ * The cache of this Manager
28
+ * @type {Collection<Snowflake, ThreadMember>}
29
+ * @name ThreadMemberManager#cache
30
+ */
31
+
32
+ _add(data, cache = true) {
33
+ const existing = this.cache.get(data.user_id);
34
+ if (cache) existing?._patch(data, { cache });
35
+ if (existing) return existing;
36
+
37
+ const member = new ThreadMember(this.thread, data, { cache });
38
+ if (cache) this.cache.set(data.user_id, member);
39
+ return member;
40
+ }
41
+
42
+ /**
43
+ * Fetches the client user as a ThreadMember of the thread.
44
+ * @param {BaseFetchOptions} [options] The options for fetching the member
45
+ * @returns {Promise<ThreadMember>}
46
+ */
47
+ fetchMe(options) {
48
+ return this.fetch(this.client.user.id, options);
49
+ }
50
+
51
+ /**
52
+ * The client user as a ThreadMember of this ThreadChannel
53
+ * @type {?ThreadMember}
54
+ * @readonly
55
+ */
56
+ get me() {
57
+ return this.cache.get(this.client.user.id) ?? null;
58
+ }
59
+
60
+ /**
61
+ * Data that resolves to give a ThreadMember object. This can be:
62
+ * * A ThreadMember object
63
+ * * A User resolvable
64
+ * @typedef {ThreadMember|UserResolvable} ThreadMemberResolvable
65
+ */
66
+
67
+ /**
68
+ * Resolves a {@link ThreadMemberResolvable} to a {@link ThreadMember} object.
69
+ * @param {ThreadMemberResolvable} member The user that is part of the thread
70
+ * @returns {?GuildMember}
71
+ */
72
+ resolve(member) {
73
+ const memberResolvable = super.resolve(member);
74
+ if (memberResolvable) return memberResolvable;
75
+ const userId = this.client.users.resolveId(member);
76
+ if (userId) return this.cache.get(userId) ?? null;
77
+ return null;
78
+ }
79
+
80
+ /**
81
+ * Resolves a {@link ThreadMemberResolvable} to a {@link ThreadMember} id string.
82
+ * @param {ThreadMemberResolvable} member The user that is part of the guild
83
+ * @returns {?Snowflake}
84
+ */
85
+ resolveId(member) {
86
+ const memberResolvable = super.resolveId(member);
87
+ if (memberResolvable) return memberResolvable;
88
+ const userResolvable = this.client.users.resolveId(member);
89
+ return this.cache.has(userResolvable) ? userResolvable : null;
90
+ }
91
+
92
+ /**
93
+ * Adds a member to the thread.
94
+ * @param {UserResolvable|'@me'} member The member to add
95
+ * @param {string} [reason] The reason for adding this member
96
+ * @returns {Promise<Snowflake>}
97
+ */
98
+ async add(member, reason) {
99
+ const id = member === '@me' ? member : this.client.users.resolveId(member);
100
+ if (!id) throw new TypeError('INVALID_TYPE', 'member', 'UserResolvable');
101
+ await this.client.api.channels(this.thread.id, 'thread-members', id).put({ reason });
102
+ return id;
103
+ }
104
+
105
+ /**
106
+ * Remove a user from the thread.
107
+ * @param {Snowflake|'@me'} id The id of the member to remove
108
+ * @param {string} [reason] The reason for removing this member from the thread
109
+ * @returns {Promise<Snowflake>}
110
+ */
111
+ async remove(id, reason) {
112
+ await this.client.api.channels(this.thread.id, 'thread-members', id).delete({ reason });
113
+ return id;
114
+ }
115
+
116
+ async _fetchOne(memberId, { cache, force = false, withMember }) {
117
+ if (!force) {
118
+ const existing = this.cache.get(memberId);
119
+ if (existing) return existing;
120
+ }
121
+
122
+ const data = await this.client.api.channels(this.thread.id, 'thread-members', memberId).get({
123
+ query: { with_member: withMember },
124
+ });
125
+ return this._add(data, cache);
126
+ }
127
+
128
+ async _fetchMany({ cache, limit, after, withMember } = {}) {
129
+ const raw = await this.client.api.channels(this.thread.id, 'thread-members').get({
130
+ query: { with_member: withMember, limit, after },
131
+ });
132
+ return raw.reduce((col, member) => col.set(member.user_id, this._add(member, cache)), new Collection());
133
+ }
134
+
135
+ /**
136
+ * Options used to fetch a thread member.
137
+ * @typedef {BaseFetchOptions} FetchThreadMemberOptions
138
+ * @property {boolean} [withMember] Whether to also return the guild member associated with this thread member
139
+ */
140
+
141
+ /**
142
+ * Options used to fetch multiple thread members with guild member data.
143
+ * <info>With `withMember` set to `true`, pagination is enabled.</info>
144
+ * @typedef {Object} FetchThreadMembersWithGuildMemberDataOptions
145
+ * @property {true} withMember Whether to also return the guild member data
146
+ * @property {Snowflake} [after] Consider only thread members after this id
147
+ * @property {number} [limit] The maximum number of thread members to return
148
+ * @property {boolean} [cache] Whether to cache the fetched thread members and guild members
149
+ */
150
+
151
+ /**
152
+ * Options used to fetch multiple thread members without guild member data.
153
+ * @typedef {Object} FetchThreadMembersWithoutGuildMemberDataOptions
154
+ * @property {false} [withMember] Whether to also return the guild member data
155
+ * @property {boolean} [cache] Whether to cache the fetched thread members
156
+ */
157
+
158
+ /**
159
+ * Options used to fetch multiple thread members.
160
+ * @typedef {FetchThreadMembersWithGuildMemberDataOptions|
161
+ * FetchThreadMembersWithoutGuildMemberDataOptions} FetchThreadMembersOptions
162
+ */
163
+
164
+ /**
165
+ * Fetches member(s) for the thread from Discord.
166
+ * @param {UserResolvable|FetchThreadMembersOptions|boolean} [member] The member to fetch. If `undefined`, all members
167
+ * in the thread are fetched, and will be cached based on `options.cache`.
168
+ * @param {FetchThreadMemberOptions|FetchThreadMembersOptions} [options] Additional options for this fetch
169
+ * @returns {Promise<ThreadMember|Collection<Snowflake, ThreadMember>>}
170
+ */
171
+ fetch(member, options = { cache: true, force: false }) {
172
+ if (typeof member === 'boolean' && !deprecationEmittedForPassingBoolean) {
173
+ process.emitWarning(
174
+ 'Passing boolean to member option is deprecated, use cache property instead.',
175
+ 'DeprecationWarning',
176
+ );
177
+ deprecationEmittedForPassingBoolean = true;
178
+ }
179
+ const id = this.resolveId(member);
180
+ return id
181
+ ? this._fetchOne(id, options)
182
+ : this._fetchMany(typeof member === 'boolean' ? { ...options, cache: member } : options);
183
+ }
184
+ }
185
+
186
+ module.exports = ThreadMemberManager;
@@ -0,0 +1,136 @@
1
+ 'use strict';
2
+
3
+ const CachedManager = require('./CachedManager');
4
+ const { Error } = require('../errors');
5
+ const { GuildMember } = require('../structures/GuildMember');
6
+ const { Message } = require('../structures/Message');
7
+ const ThreadMember = require('../structures/ThreadMember');
8
+ const User = require('../structures/User');
9
+
10
+ /**
11
+ * Manages API methods for users and stores their cache.
12
+ * @extends {CachedManager}
13
+ */
14
+ class UserManager extends CachedManager {
15
+ constructor(client, iterable) {
16
+ super(client, User, iterable);
17
+ }
18
+
19
+ /**
20
+ * The cache of this manager
21
+ * @type {Collection<Snowflake, User>}
22
+ * @name UserManager#cache
23
+ */
24
+
25
+ /**
26
+ * Data that resolves to give a User object. This can be:
27
+ * * A User object
28
+ * * A Snowflake
29
+ * * A Message object (resolves to the message author)
30
+ * * A GuildMember object
31
+ * * A ThreadMember object
32
+ * @typedef {User|Snowflake|Message|GuildMember|ThreadMember} UserResolvable
33
+ */
34
+
35
+ /**
36
+ * The DM between the client's user and a user
37
+ * @param {Snowflake} userId The user id
38
+ * @returns {?DMChannel}
39
+ * @private
40
+ */
41
+ dmChannel(userId) {
42
+ return this.client.channels.cache.find(c => c.type === 'DM' && c.recipient.id === userId) ?? null;
43
+ }
44
+
45
+ /**
46
+ * Creates a {@link DMChannel} between the client and a user.
47
+ * @param {UserResolvable} user The UserResolvable to identify
48
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
49
+ * @returns {Promise<DMChannel>}
50
+ */
51
+ async createDM(user, { cache = true, force = false } = {}) {
52
+ const id = this.resolveId(user);
53
+
54
+ if (!force) {
55
+ const dmChannel = this.dmChannel(id);
56
+ if (dmChannel && !dmChannel.partial) return dmChannel;
57
+ }
58
+
59
+ const data = await this.client.api.users['@me'].channels.post({
60
+ data: {
61
+ recipients: [id],
62
+ },
63
+ DiscordContext: {},
64
+ });
65
+
66
+ const dm_channel = await this.client.channels._add(data, null, { cache });
67
+ dm_channel.sync();
68
+ return dm_channel;
69
+ }
70
+
71
+ /**
72
+ * Deletes a {@link DMChannel} (if one exists) between the client and a user. Resolves with the channel if successful.
73
+ * @param {UserResolvable} user The UserResolvable to identify
74
+ * @returns {Promise<DMChannel>}
75
+ */
76
+ async deleteDM(user) {
77
+ const id = this.resolveId(user);
78
+ const dmChannel = this.dmChannel(id);
79
+ if (!dmChannel) throw new Error('USER_NO_DM_CHANNEL');
80
+ await this.client.api.channels(dmChannel.id).delete();
81
+ this.client.channels._remove(dmChannel.id);
82
+ return dmChannel;
83
+ }
84
+
85
+ /**
86
+ * Obtains a user from Discord, or the user cache if it's already available.
87
+ * @param {UserResolvable} user The user to fetch
88
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
89
+ * @returns {Promise<User>}
90
+ */
91
+ async fetch(user, { cache = true, force = false } = {}) {
92
+ const id = this.resolveId(user);
93
+ if (!force) {
94
+ const existing = this.cache.get(id);
95
+ if (existing && !existing.partial) return existing;
96
+ }
97
+
98
+ const data = await this.client.api.users(id).get();
99
+ return this._add(data, cache);
100
+ }
101
+
102
+ /**
103
+ * Sends a message to a user.
104
+ * @param {UserResolvable} user The UserResolvable to identify
105
+ * @param {string|MessagePayload|MessageOptions} options The options to provide
106
+ * @returns {Promise<Message>}
107
+ */
108
+ async send(user, options) {
109
+ return (await this.createDM(user)).send(options);
110
+ }
111
+
112
+ /**
113
+ * Resolves a {@link UserResolvable} to a {@link User} object.
114
+ * @param {UserResolvable} user The UserResolvable to identify
115
+ * @returns {?User}
116
+ */
117
+ resolve(user) {
118
+ if (user instanceof GuildMember || user instanceof ThreadMember) return user.user;
119
+ if (user instanceof Message) return user.author;
120
+ return super.resolve(user);
121
+ }
122
+
123
+ /**
124
+ * Resolves a {@link UserResolvable} to a {@link User} id.
125
+ * @param {UserResolvable} user The UserResolvable to identify
126
+ * @returns {?Snowflake}
127
+ */
128
+ resolveId(user) {
129
+ if (user instanceof ThreadMember) return user.id;
130
+ if (user instanceof GuildMember) return user.user.id;
131
+ if (user instanceof Message) return user.author.id;
132
+ return super.resolveId(user);
133
+ }
134
+ }
135
+
136
+ module.exports = UserManager;
@@ -0,0 +1,53 @@
1
+ 'use strict';
2
+
3
+ const { Collection } = require('@discordjs/collection');
4
+ const BaseManager = require('./BaseManager');
5
+
6
+ /**
7
+ * Manages API methods for Client and stores their cache.
8
+ * @extends {BaseManager}
9
+ */
10
+ class UserNoteManager extends BaseManager {
11
+ constructor(client, data = {}) {
12
+ super(client);
13
+ /**
14
+ * Cache User Note
15
+ * @type {Collection<Snowflake, string>}
16
+ */
17
+ this.cache = new Collection(Object.entries(data));
18
+ }
19
+
20
+ _reload(data = {}) {
21
+ this.cache = new Collection(Object.entries(data));
22
+ return this;
23
+ }
24
+
25
+ async updateNote(id, note = null) {
26
+ await this.client.api.users['@me'].notes(id).put({ data: { note } });
27
+ if (!note) this.cache.delete(id, note);
28
+ else this.cache.set(id, note);
29
+ return this;
30
+ }
31
+
32
+ /**
33
+ * Obtains a user from Discord, or the user cache if it's already available.
34
+ * @param {UserResolvable} user The user to fetch
35
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
36
+ * @returns {Promise<string>}
37
+ */
38
+ async fetch(user, { cache = true, force = false } = {}) {
39
+ const id = this.resolveId(user);
40
+ if (!force) {
41
+ const existing = this.cache.get(id);
42
+ if (existing) return existing;
43
+ }
44
+ const data = await this.client.api.users['@me'].notes[id]
45
+ .get()
46
+ .then(d => d.note)
47
+ .catch(() => '');
48
+ if (cache) this.cache.set(id, data);
49
+ return data;
50
+ }
51
+ }
52
+
53
+ module.exports = UserNoteManager;
@@ -0,0 +1,59 @@
1
+ 'use strict';
2
+
3
+ const CachedManager = require('./CachedManager');
4
+ const VoiceState = require('../structures/VoiceState');
5
+
6
+ /**
7
+ * Manages API methods for VoiceStates and stores their cache.
8
+ * @extends {CachedManager}
9
+ */
10
+ class VoiceStateManager extends CachedManager {
11
+ constructor(guild, iterable) {
12
+ super(guild.client, VoiceState, iterable);
13
+
14
+ /**
15
+ * The guild this manager belongs to
16
+ * @type {Guild}
17
+ */
18
+ this.guild = guild;
19
+ }
20
+
21
+ /**
22
+ * The cache of this manager
23
+ * @type {Collection<Snowflake, VoiceState>}
24
+ * @name VoiceStateManager#cache
25
+ */
26
+
27
+ _add(data, cache = true) {
28
+ const existing = this.cache.get(data.user_id);
29
+ if (existing) return existing._patch(data);
30
+
31
+ const entry = new this.holds(this.guild, data);
32
+ if (cache) this.cache.set(data.user_id, entry);
33
+ return entry;
34
+ }
35
+
36
+ /**
37
+ * Obtains a user's voice state from discord or from the cache if it's already available.
38
+ * @param {GuildMemberResolvable|'@me'} member The member whose voice state is to be fetched
39
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
40
+ * @returns {Promise<VoiceState>}
41
+ * @example
42
+ * // Fetch a member's voice state
43
+ * guild.voiceStates.fetch("66564597481480192")
44
+ * .then(console.log)
45
+ * .catch(console.error);
46
+ */
47
+ async fetch(member, { cache = true, force = false } = {}) {
48
+ if (!this.guild?.id) throw new Error('Guild is not defined');
49
+ const id = member === '@me' ? member : this.guild.members.resolveId(member);
50
+ if (!force) {
51
+ const existing = this.cache.get(id === '@me' ? this.client.user.id : id);
52
+ if (existing) return existing;
53
+ }
54
+ const data = await this.client.api.guilds(this.guild.id)['voice-states'][id].get();
55
+ return this._add(data, cache);
56
+ }
57
+ }
58
+
59
+ module.exports = VoiceStateManager;