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,110 @@
1
+ 'use strict';
2
+
3
+ const process = require('node:process');
4
+ const BaseGuildVoiceChannel = require('./BaseGuildVoiceChannel');
5
+ const Permissions = require('../util/Permissions');
6
+
7
+ let deprecationEmittedForEditable = false;
8
+
9
+ /**
10
+ * Represents a guild voice channel on Discord.
11
+ * @extends {BaseGuildVoiceChannel}
12
+ */
13
+ class VoiceChannel extends BaseGuildVoiceChannel {
14
+ /**
15
+ * Whether the channel is editable by the client user
16
+ * @type {boolean}
17
+ * @readonly
18
+ * @deprecated Use {@link VoiceChannel#manageable} instead
19
+ */
20
+ get editable() {
21
+ if (!deprecationEmittedForEditable) {
22
+ process.emitWarning(
23
+ 'The VoiceChannel#editable getter is deprecated. Use VoiceChannel#manageable instead.',
24
+ 'DeprecationWarning',
25
+ );
26
+
27
+ deprecationEmittedForEditable = true;
28
+ }
29
+
30
+ return this.manageable;
31
+ }
32
+
33
+ /**
34
+ * Whether the channel is joinable by the client user
35
+ * @type {boolean}
36
+ * @readonly
37
+ */
38
+ get joinable() {
39
+ if (!super.joinable) return false;
40
+ if (this.full && !this.permissionsFor(this.client.user).has(Permissions.FLAGS.MOVE_MEMBERS, false)) return false;
41
+ return true;
42
+ }
43
+
44
+ /**
45
+ * Checks if the client has permission to send audio to the voice channel
46
+ * @type {boolean}
47
+ * @readonly
48
+ */
49
+ get speakable() {
50
+ const permissions = this.permissionsFor(this.client.user);
51
+ if (!permissions) return false;
52
+ // This flag allows speaking even if timed out
53
+ if (permissions.has(Permissions.FLAGS.ADMINISTRATOR, false)) return true;
54
+
55
+ return (
56
+ this.guild.members.me.communicationDisabledUntilTimestamp < Date.now() &&
57
+ permissions.has(Permissions.FLAGS.SPEAK, false)
58
+ );
59
+ }
60
+
61
+ /**
62
+ * Sets the bitrate of the channel.
63
+ * @name VoiceChannel#setBitrate
64
+ * @param {number} bitrate The new bitrate
65
+ * @param {string} [reason] Reason for changing the channel's bitrate
66
+ * @returns {Promise<VoiceChannel>}
67
+ * @example
68
+ * // Set the bitrate of a voice channel
69
+ * voiceChannel.setBitrate(48_000)
70
+ * .then(channel => console.log(`Set bitrate to ${channel.bitrate}bps for ${channel.name}`))
71
+ * .catch(console.error);
72
+ */
73
+
74
+ /**
75
+ * Sets the RTC region of the channel.
76
+ * @name VoiceChannel#setRTCRegion
77
+ * @param {?string} rtcRegion The new region of the channel. Set to `null` to remove a specific region for the channel
78
+ * @param {string} [reason] The reason for modifying this region.
79
+ * @returns {Promise<VoiceChannel>}
80
+ * @example
81
+ * // Set the RTC region to sydney
82
+ * voiceChannel.setRTCRegion('sydney');
83
+ * @example
84
+ * // Remove a fixed region for this channel - let Discord decide automatically
85
+ * voiceChannel.setRTCRegion(null, 'We want to let Discord decide.');
86
+ */
87
+
88
+ /**
89
+ * Sets the user limit of the channel.
90
+ * @name VoiceChannel#setUserLimit
91
+ * @param {number} userLimit The new user limit
92
+ * @param {string} [reason] Reason for changing the user limit
93
+ * @returns {Promise<VoiceChannel>}
94
+ * @example
95
+ * // Set the user limit of a voice channel
96
+ * voiceChannel.setUserLimit(42)
97
+ * .then(channel => console.log(`Set user limit to ${channel.userLimit} for ${channel.name}`))
98
+ * .catch(console.error);
99
+ */
100
+
101
+ /**
102
+ * Sets the camera video quality mode of the channel.
103
+ * @name VoiceChannel#setVideoQualityMode
104
+ * @param {VideoQualityMode|number} videoQualityMode The new camera video quality mode.
105
+ * @param {string} [reason] Reason for changing the camera video quality mode.
106
+ * @returns {Promise<VoiceChannel>}
107
+ */
108
+ }
109
+
110
+ module.exports = VoiceChannel;
@@ -0,0 +1,69 @@
1
+ 'use strict';
2
+
3
+ const { Emoji } = require('./Emoji');
4
+
5
+ /**
6
+ * Represents an effect used in a {@link VoiceChannel}.
7
+ */
8
+ class VoiceChannelEffect {
9
+ constructor(data, guild) {
10
+ /**
11
+ * The guild where the effect was sent from.
12
+ * @type {Guild}
13
+ */
14
+ this.guild = guild;
15
+
16
+ /**
17
+ * The id of the channel the effect was sent in.
18
+ * @type {Snowflake}
19
+ */
20
+ this.channelId = data.channel_id;
21
+
22
+ /**
23
+ * The id of the user that sent the effect.
24
+ * @type {Snowflake}
25
+ */
26
+ this.userId = data.user_id;
27
+
28
+ /**
29
+ * The emoji of the effect.
30
+ * @type {?Emoji}
31
+ */
32
+ this.emoji = data.emoji ? new Emoji(guild.client, data.emoji) : null;
33
+
34
+ /**
35
+ * The animation type of the effect.
36
+ * @type {?VoiceChannelEffectSendAnimationType}
37
+ */
38
+ this.animationType = data.animation_type ?? null;
39
+
40
+ /**
41
+ * The animation id of the effect.
42
+ * @type {?number}
43
+ */
44
+ this.animationId = data.animation_id ?? null;
45
+
46
+ /**
47
+ * The id of the soundboard sound for soundboard effects.
48
+ * @type {?(Snowflake|number)}
49
+ */
50
+ this.soundId = data.sound_id ?? null;
51
+
52
+ /**
53
+ * The volume of the soundboard sound [0-1] for soundboard effects.
54
+ * @type {?number}
55
+ */
56
+ this.soundVolume = data.sound_volume ?? null;
57
+ }
58
+
59
+ /**
60
+ * The channel the effect was sent in.
61
+ * @type {?VoiceChannel}
62
+ * @readonly
63
+ */
64
+ get channel() {
65
+ return this.guild.channels.cache.get(this.channelId) ?? null;
66
+ }
67
+ }
68
+
69
+ module.exports = VoiceChannelEffect;
@@ -0,0 +1,53 @@
1
+ 'use strict';
2
+
3
+ const Util = require('../util/Util');
4
+
5
+ /**
6
+ * Represents a Discord voice region for guilds.
7
+ */
8
+ class VoiceRegion {
9
+ constructor(data) {
10
+ /**
11
+ * The region's id
12
+ * @type {string}
13
+ */
14
+ this.id = data.id;
15
+
16
+ /**
17
+ * Name of the region
18
+ * @type {string}
19
+ */
20
+ this.name = data.name;
21
+
22
+ /**
23
+ * Whether the region is VIP-only
24
+ * @type {boolean}
25
+ * @deprecated This property is no longer being sent by the API.
26
+ */
27
+ this.vip = data.vip;
28
+
29
+ /**
30
+ * Whether the region is deprecated
31
+ * @type {boolean}
32
+ */
33
+ this.deprecated = data.deprecated;
34
+
35
+ /**
36
+ * Whether the region is optimal
37
+ * @type {boolean}
38
+ */
39
+ this.optimal = data.optimal;
40
+
41
+ /**
42
+ * Whether the region is custom
43
+ * @type {boolean}
44
+ */
45
+ this.custom = data.custom;
46
+ }
47
+
48
+ toJSON() {
49
+ return Util.flatten(this);
50
+ }
51
+ }
52
+
53
+ module.exports = VoiceRegion;
@@ -0,0 +1,354 @@
1
+ 'use strict';
2
+
3
+ const Base = require('./Base');
4
+ const { Error, TypeError } = require('../errors');
5
+
6
+ /**
7
+ * Represents the voice state for a Guild Member.
8
+ * @extends {Base}
9
+ */
10
+ class VoiceState extends Base {
11
+ constructor(guild, data) {
12
+ super(guild.client);
13
+ /**
14
+ * The guild of this voice state
15
+ * @type {Guild}
16
+ */
17
+ this.guild = guild;
18
+ /**
19
+ * The id of the member of this voice state
20
+ * @type {Snowflake}
21
+ */
22
+ this.id = data.user_id;
23
+ this._patch(data);
24
+ }
25
+
26
+ _patch(data) {
27
+ if ('deaf' in data) {
28
+ /**
29
+ * Whether this member is deafened server-wide
30
+ * @type {?boolean}
31
+ */
32
+ this.serverDeaf = data.deaf;
33
+ } else {
34
+ this.serverDeaf ??= null;
35
+ }
36
+
37
+ if ('mute' in data) {
38
+ /**
39
+ * Whether this member is muted server-wide
40
+ * @type {?boolean}
41
+ */
42
+ this.serverMute = data.mute;
43
+ } else {
44
+ this.serverMute ??= null;
45
+ }
46
+
47
+ if ('self_deaf' in data) {
48
+ /**
49
+ * Whether this member is self-deafened
50
+ * @type {?boolean}
51
+ */
52
+ this.selfDeaf = data.self_deaf;
53
+ } else {
54
+ this.selfDeaf ??= null;
55
+ }
56
+
57
+ if ('self_mute' in data) {
58
+ /**
59
+ * Whether this member is self-muted
60
+ * @type {?boolean}
61
+ */
62
+ this.selfMute = data.self_mute;
63
+ } else {
64
+ this.selfMute ??= null;
65
+ }
66
+
67
+ if ('self_video' in data) {
68
+ /**
69
+ * Whether this member's camera is enabled
70
+ * @type {?boolean}
71
+ */
72
+ this.selfVideo = data.self_video;
73
+ } else {
74
+ this.selfVideo ??= null;
75
+ }
76
+
77
+ if ('session_id' in data) {
78
+ /**
79
+ * The session id for this member's connection
80
+ * @type {?string}
81
+ */
82
+ this.sessionId = data.session_id;
83
+ } else {
84
+ this.sessionId ??= null;
85
+ }
86
+
87
+ // The self_stream is property is omitted if false, check for another property
88
+ // here to avoid incorrectly clearing this when partial data is specified
89
+ if ('self_video' in data) {
90
+ /**
91
+ * Whether this member is streaming using "Screen Share"
92
+ * @type {boolean}
93
+ */
94
+ this.streaming = data.self_stream ?? false;
95
+ } else {
96
+ this.streaming ??= null;
97
+ }
98
+
99
+ if ('channel_id' in data) {
100
+ /**
101
+ * The {@link VoiceChannel} or {@link StageChannel} id the member is in
102
+ * @type {?Snowflake}
103
+ */
104
+ this.channelId = data.channel_id;
105
+ } else {
106
+ this.channelId ??= null;
107
+ }
108
+
109
+ if ('suppress' in data) {
110
+ /**
111
+ * Whether this member is suppressed from speaking. This property is specific to stage channels only.
112
+ * @type {boolean}
113
+ */
114
+ this.suppress = data.suppress;
115
+ }
116
+
117
+ if ('request_to_speak_timestamp' in data) {
118
+ /**
119
+ * The time at which the member requested to speak. This property is specific to stage channels only.
120
+ * @type {?number}
121
+ */
122
+ this.requestToSpeakTimestamp = data.request_to_speak_timestamp && Date.parse(data.request_to_speak_timestamp);
123
+ } else {
124
+ this.requestToSpeakTimestamp ??= null;
125
+ }
126
+
127
+ return this;
128
+ }
129
+
130
+ /**
131
+ * The member that this voice state belongs to
132
+ * @type {?GuildMember}
133
+ * @readonly
134
+ */
135
+ get member() {
136
+ if (!this.guild?.id) return null;
137
+ return this.guild.members.cache.get(this.id) ?? null;
138
+ }
139
+
140
+ /**
141
+ * The user that this voice state belongs to
142
+ * @type {?User}
143
+ * @readonly
144
+ */
145
+ get user() {
146
+ return this.guild.client.users.cache.get(this.id) ?? null;
147
+ }
148
+
149
+ /**
150
+ * The channel that the member is connected to
151
+ * @type {?(VoiceChannel|StageChannel|DMChannel|GroupDMChannel)}
152
+ * @readonly
153
+ */
154
+ get channel() {
155
+ return (this.guild?.id ? this.guild : this.client)?.channels?.cache.get(this.channelId) ?? null;
156
+ }
157
+
158
+ /**
159
+ * Whether this member is either self-deafened or server-deafened
160
+ * @type {?boolean}
161
+ * @readonly
162
+ */
163
+ get deaf() {
164
+ return this.serverDeaf || this.selfDeaf;
165
+ }
166
+
167
+ /**
168
+ * Whether this member is either self-muted or server-muted
169
+ * @type {?boolean}
170
+ * @readonly
171
+ */
172
+ get mute() {
173
+ return this.serverMute || this.selfMute;
174
+ }
175
+
176
+ /**
177
+ * Mutes/unmutes the member of this voice state.
178
+ * @param {boolean} [mute=true] Whether or not the member should be muted
179
+ * @param {string} [reason] Reason for muting or unmuting
180
+ * @returns {Promise<GuildMember>}
181
+ */
182
+ setMute(mute = true, reason) {
183
+ if (!this.guild?.id) return null;
184
+ return this.guild.members.edit(this.id, { mute }, reason);
185
+ }
186
+
187
+ /**
188
+ * Deafens/undeafens the member of this voice state.
189
+ * @param {boolean} [deaf=true] Whether or not the member should be deafened
190
+ * @param {string} [reason] Reason for deafening or undeafening
191
+ * @returns {Promise<GuildMember>}
192
+ */
193
+ setDeaf(deaf = true, reason) {
194
+ if (!this.guild?.id) return null;
195
+ return this.guild.members.edit(this.id, { deaf }, reason);
196
+ }
197
+
198
+ /**
199
+ * Disconnects the member from the channel.
200
+ * @param {string} [reason] Reason for disconnecting the member from the channel
201
+ * @returns {Promise<GuildMember>}
202
+ */
203
+ disconnect(reason) {
204
+ return this.setChannel(null, reason);
205
+ }
206
+
207
+ /**
208
+ * Moves the member to a different channel, or disconnects them from the one they're in.
209
+ * @param {GuildVoiceChannelResolvable|null} channel Channel to move the member to, or `null` if you want to
210
+ * disconnect them from voice.
211
+ * @param {string} [reason] Reason for moving member to another channel or disconnecting
212
+ * @returns {Promise<GuildMember>}
213
+ */
214
+ setChannel(channel, reason) {
215
+ if (!this.guild?.id) return null;
216
+ return this.guild.members.edit(this.id, { channel }, reason);
217
+ }
218
+
219
+ /**
220
+ * Toggles the request to speak in the channel.
221
+ * Only applicable for stage channels and for the client's own voice state.
222
+ * @param {boolean} [request=true] Whether or not the client is requesting to become a speaker.
223
+ * @example
224
+ * // Making the client request to speak in a stage channel (raise its hand)
225
+ * guild.members.me.voice.setRequestToSpeak(true);
226
+ * @example
227
+ * // Making the client cancel a request to speak
228
+ * guild.members.me.voice.setRequestToSpeak(false);
229
+ * @returns {Promise<void>}
230
+ */
231
+ async setRequestToSpeak(request = true) {
232
+ if (this.channel?.type !== 'GUILD_STAGE_VOICE') throw new Error('VOICE_NOT_STAGE_CHANNEL');
233
+
234
+ if (this.client.user.id !== this.id) throw new Error('VOICE_STATE_NOT_OWN');
235
+
236
+ await this.client.api.guilds(this.guild.id, 'voice-states', '@me').patch({
237
+ data: {
238
+ channel_id: this.channelId,
239
+ request_to_speak_timestamp: request ? new Date().toISOString() : null,
240
+ },
241
+ });
242
+ }
243
+
244
+ /**
245
+ * Suppress/unsuppress the user. Only applicable for stage channels.
246
+ * @param {boolean} [suppressed=true] Whether or not the user should be suppressed.
247
+ * @example
248
+ * // Making the client a speaker
249
+ * guild.members.me.voice.setSuppressed(false);
250
+ * @example
251
+ * // Making the client an audience member
252
+ * guild.members.me.voice.setSuppressed(true);
253
+ * @example
254
+ * // Inviting another user to speak
255
+ * voiceState.setSuppressed(false);
256
+ * @example
257
+ * // Moving another user to the audience, or cancelling their invite to speak
258
+ * voiceState.setSuppressed(true);
259
+ * @returns {Promise<void>}
260
+ */
261
+ async setSuppressed(suppressed = true) {
262
+ if (typeof suppressed !== 'boolean') throw new TypeError('VOICE_STATE_INVALID_TYPE', 'suppressed');
263
+
264
+ if (this.channel?.type !== 'GUILD_STAGE_VOICE') throw new Error('VOICE_NOT_STAGE_CHANNEL');
265
+
266
+ const target = this.client.user.id === this.id ? '@me' : this.id;
267
+
268
+ await this.client.api.guilds(this.guild.id, 'voice-states', target).patch({
269
+ data: {
270
+ channel_id: this.channelId,
271
+ suppress: suppressed,
272
+ request_to_speak_timestamp: null,
273
+ },
274
+ });
275
+ }
276
+
277
+ /**
278
+ * Sets the status of the voice channel
279
+ * @param {string} [status=""] The message to set the channel status to
280
+ * @example
281
+ * // Setting the status to something
282
+ * guild.members.me.voice.setStatus("something")
283
+ * @example
284
+ * // Removing the status
285
+ * guild.members.me.voice.setStatus()
286
+ * @returns {Promise<void>}
287
+ */
288
+ setStatus(status = '') {
289
+ // PUT https://discord.com/api/v9/channels/:id/voice-status
290
+ return this.client.api.channels(this.channel.id, 'voice-status').put({
291
+ data: {
292
+ status,
293
+ },
294
+ });
295
+ }
296
+
297
+ /**
298
+ * Get URL Image of the user's streaming video (NOT STREAMING !!!)
299
+ * @returns {Promise<string>} URL Image of the user's streaming video
300
+ */
301
+ async getPreview() {
302
+ if (!this.streaming) throw new Error('USER_NOT_STREAMING');
303
+ // URL: https://discord.com/api/v9/streams/guild:guildid:voicechannelid:userid/preview
304
+ // URL: https://discord.com/api/v9/streams/call:channelId:userId/preview
305
+ const streamKey = this.guild?.id
306
+ ? `guild:${this.guild.id}:${this.channelId}:${this.id}`
307
+ : `call:${this.channelId}:${this.id}`;
308
+ const data = await this.client.api.streams[encodeURIComponent(streamKey)].preview.get();
309
+ return data.url;
310
+ }
311
+
312
+ /**
313
+ * Post Preview Image to the client user's streaming video
314
+ * @param {string} base64Image Base64 URI (data:image/jpeg;base64,data)
315
+ * @returns {Promise<void>}
316
+ */
317
+ postPreview(base64Image) {
318
+ if (!this.client.user.id === this.id || !this.streaming) throw new Error('USER_NOT_STREAMING');
319
+ // URL: https://discord.com/api/v9/streams/guild:guildid:voicechannelid:userid/preview
320
+ // URL: https://discord.com/api/v9/streams/call:channelId:userId/preview
321
+ const streamKey = this.guild?.id
322
+ ? `guild:${this.guild.id}:${this.channelId}:${this.id}`
323
+ : `call:${this.channelId}:${this.id}`;
324
+ return this.client.api.streams[encodeURIComponent(streamKey)].preview.post({
325
+ data: {
326
+ thumbnail: base64Image,
327
+ },
328
+ });
329
+ }
330
+
331
+ /**
332
+ * Fetches this voice state.
333
+ * @param {boolean} [force=true] Whether to skip the cache check and request the API
334
+ * @returns {Promise<VoiceState>}
335
+ */
336
+ fetch(force = true) {
337
+ return this.guild?.voiceStates?.fetch(this.id, { force });
338
+ }
339
+
340
+ toJSON() {
341
+ return super.toJSON({
342
+ id: true,
343
+ serverDeaf: true,
344
+ serverMute: true,
345
+ selfDeaf: true,
346
+ selfMute: true,
347
+ selfVideo: true,
348
+ sessionId: true,
349
+ channelId: 'channel',
350
+ });
351
+ }
352
+ }
353
+
354
+ module.exports = VoiceState;