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,63 @@
1
+ 'use strict';
2
+
3
+ const BitField = require('./BitField');
4
+
5
+ /**
6
+ * Data structure that makes it easy to interact with a {@link Message#flags} bitfield.
7
+ * @extends {BitField}
8
+ */
9
+ class MessageFlags extends BitField {}
10
+
11
+ /**
12
+ * @name MessageFlags
13
+ * @kind constructor
14
+ * @memberof MessageFlags
15
+ * @param {BitFieldResolvable} [bits=0] Bit(s) to read from
16
+ */
17
+
18
+ /**
19
+ * Bitfield of the packed bits
20
+ * @type {number}
21
+ * @name MessageFlags#bitfield
22
+ */
23
+
24
+ /**
25
+ * Numeric message flags. All available properties:
26
+ * * `CROSSPOSTED`
27
+ * * `IS_CROSSPOST`
28
+ * * `SUPPRESS_EMBEDS`
29
+ * * `SOURCE_MESSAGE_DELETED`
30
+ * * `URGENT`
31
+ * * `HAS_THREAD`
32
+ * * `EPHEMERAL`
33
+ * * `LOADING`
34
+ * * `FAILED_TO_MENTION_SOME_ROLES_IN_THREAD`
35
+ * * `GUILD_FEED_HIDDEN`
36
+ * * `SHOULD_SHOW_LINK_NOT_DISCORD_WARNING`
37
+ * * `SUPPRESS_NOTIFICATIONS`
38
+ * * `IS_VOICE_MESSAGE`
39
+ * * `HAS_SNAPSHOT`
40
+ * * `IS_COMPONENTS_V2`
41
+ * @type {Object}
42
+ * @see {@link https://discord.com/developers/docs/resources/channel#message-object-message-flags}
43
+ * @see {@link https://docs.discord.food/resources/message#message-flags}
44
+ */
45
+ MessageFlags.FLAGS = {
46
+ CROSSPOSTED: 1 << 0,
47
+ IS_CROSSPOST: 1 << 1,
48
+ SUPPRESS_EMBEDS: 1 << 2,
49
+ SOURCE_MESSAGE_DELETED: 1 << 3,
50
+ URGENT: 1 << 4,
51
+ HAS_THREAD: 1 << 5,
52
+ EPHEMERAL: 1 << 6,
53
+ LOADING: 1 << 7,
54
+ FAILED_TO_MENTION_SOME_ROLES_IN_THREAD: 1 << 8,
55
+ GUILD_FEED_HIDDEN: 1 << 9,
56
+ SHOULD_SHOW_LINK_NOT_DISCORD_WARNING: 1 << 10,
57
+ SUPPRESS_NOTIFICATIONS: 1 << 12,
58
+ IS_VOICE_MESSAGE: 1 << 13,
59
+ HAS_SNAPSHOT: 1 << 14,
60
+ IS_COMPONENTS_V2: 1 << 15,
61
+ };
62
+
63
+ module.exports = MessageFlags;
@@ -0,0 +1,358 @@
1
+ 'use strict';
2
+
3
+ const { randomUUID } = require('node:crypto');
4
+ const { UserAgent } = require('./Constants');
5
+ const Intents = require('./Intents');
6
+
7
+ /**
8
+ * Rate limit data
9
+ * @typedef {Object} RateLimitData
10
+ * @property {number} timeout Time until this rate limit ends, in milliseconds
11
+ * @property {number} limit The maximum amount of requests of this endpoint
12
+ * @property {string} method The HTTP method of this request
13
+ * @property {string} path The path of the request relative to the HTTP endpoint
14
+ * @property {string} route The route of the request relative to the HTTP endpoint
15
+ * @property {boolean} global Whether this is a global rate limit
16
+ */
17
+
18
+ /**
19
+ * Whether this rate limit should throw an Error
20
+ * @typedef {Function} RateLimitQueueFilter
21
+ * @param {RateLimitData} rateLimitData The data of this rate limit
22
+ * @returns {boolean|Promise<boolean>}
23
+ */
24
+
25
+ /**
26
+ * @typedef {Function} CacheFactory
27
+ * @param {Function} manager The manager class the cache is being requested from.
28
+ * @param {Function} holds The class that the cache will hold.
29
+ * @returns {Collection} A Collection used to store the cache of the manager.
30
+ */
31
+
32
+ /**
33
+ * @typedef {Function} CaptchaSolver
34
+ * @param {Captcha} captcha Discord Captcha
35
+ * @param {string} UserAgent Current UserAgent
36
+ * @returns {Promise<string>} HCaptcha Token
37
+ * @example
38
+ * const Captcha = require("2captcha")
39
+ * // A new 'solver' instance with our API key
40
+ * const solver = new Captcha.Solver("<Your 2captcha api key>")
41
+ * function solveCaptcha(captcha, UA) {
42
+ * return solver.hcaptcha(captcha.captcha_sitekey, 'discord.com', {
43
+ * invisible: 1,
44
+ * userAgent: UA,
45
+ * data: captcha.captcha_rqdata,
46
+ * }).then(res => res.data)
47
+ * }
48
+ */
49
+
50
+ /**
51
+ * Options for a client.
52
+ * @typedef {Object} ClientOptions
53
+ * @property {number} [DMChannelVoiceStatusSync=0] The amount of time in milliseconds that the Client to register the event with each DM channel (0=Disable)
54
+ * @property {number} [captchaRetryLimit=3] Captcha retry limit
55
+ * @property {CaptchaSolver} [captchaSolver] Captcha Solver
56
+ * @property {string} [TOTPKey] TOTP key / 2FA Key for two-factor authentication
57
+ * This is a 32-character Base32 string (excluding spaces), typically shown only once during your 2FA setup (QR code), or in the "Manual Entry" section.
58
+ * The library automatically removes spaces and converts the secret to uppercase.
59
+ * Example value: 'ftc3 uz6q 5lpw 2kew 4thr vtyp n2cu topn' or 'WSLIVE6EKYSRMVRBZLFGG2KVIVJMMQY5'
60
+ * @property {number} [closeTimeout=5000] The amount of time in milliseconds to wait for the close frame to be received
61
+ * from the WebSocket.
62
+ * <info>Don't have this too high/low. It's best to have it between 2000-6000 ms.</info>
63
+ * (e.g. recommended shard count, shard count of the ShardingManager)
64
+ * @property {CacheFactory} [makeCache] Function to create a cache.
65
+ * You can use your own function, or the {@link Options} class to customize the Collection used for the cache.
66
+ * <warn>Overriding the cache used in `GuildManager`, `ChannelManager`, `GuildChannelManager`, `RoleManager`,
67
+ * and `PermissionOverwriteManager` is unsupported and **will** break functionality</warn>
68
+ * @property {number} [messageCacheLifetime=0] DEPRECATED: Pass `lifetime` to `sweepers.messages` instead.
69
+ * How long a message should stay in the cache until it is considered sweepable (in seconds, 0 for forever)
70
+ * @property {number} [messageSweepInterval=0] DEPRECATED: Pass `interval` to `sweepers.messages` instead.
71
+ * How frequently to remove messages from the cache that are older than the message cache lifetime
72
+ * (in seconds, 0 for never)
73
+ * @property {MessageMentionOptions} [allowedMentions] Default value for {@link MessageOptions#allowedMentions}
74
+ * @property {number} [invalidRequestWarningInterval=0] The number of invalid REST requests (those that return
75
+ * 401, 403, or 429) in a 10 minute window between emitted warnings (0 for no warnings). That is, if set to 500,
76
+ * warnings will be emitted at invalid request number 500, 1000, 1500, and so on.
77
+ * @property {PartialType[]} [partials=['USER', 'CHANNEL', 'GUILD_MEMBER', 'MESSAGE', 'REACTION', 'GUILD_SCHEDULED_EVENT']] Structures allowed to be partial. This means events can be emitted even when
78
+ * they're missing all the data for a particular structure. See the "Partial Structures" topic on the
79
+ * [guide](https://discordjs.guide/popular-topics/partials.html) for some
80
+ * important usage information, as partials require you to put checks in place when handling data.
81
+ * @property {number} [restWsBridgeTimeout=5000] Maximum time permitted between REST responses and their
82
+ * corresponding WebSocket events
83
+ * @property {number} [restTimeOffset=500] Extra time in milliseconds to wait before continuing to make REST
84
+ * requests (higher values will reduce rate-limiting errors on bad connections)
85
+ * @property {number} [restRequestTimeout=15000] Time to wait before cancelling a REST request, in milliseconds
86
+ * @property {number} [restSweepInterval=60] How frequently to delete inactive request buckets, in seconds
87
+ * (or 0 for never)
88
+ * @property {number} [restGlobalRateLimit=0] How many requests to allow sending per second (0 for unlimited, 50 for
89
+ * the standard global limit used by Discord)
90
+ * @property {string[]|RateLimitQueueFilter} [rejectOnRateLimit] Decides how rate limits and pre-emptive throttles
91
+ * should be handled. If this option is an array containing the prefix of the request route (e.g. /channels to match any
92
+ * route starting with /channels, such as /channels/222197033908436994/messages) or a function returning true, a
93
+ * {@link RateLimitError} will be thrown. Otherwise the request will be queued for later
94
+ * @property {number} [retryLimit=1] How many times to retry on 5XX errors
95
+ * (Infinity for an indefinite amount of retries)
96
+ * @property {boolean} [failIfNotExists=true] Default value for {@link ReplyMessageOptions#failIfNotExists}
97
+ * @property {PresenceData} [presence={ status: 'online', since: 0, activities: [], afk: false }] Presence data to use upon login
98
+ * @property {number} [waitGuildTimeout=15_000] Time in milliseconds that Clients with the GUILDS intent should wait for
99
+ * missing guilds to be received before starting the bot. If not specified, the default is 15 seconds.
100
+ * @property {SweeperOptions} [sweepers={}] Options for cache sweeping
101
+ * @property {WebsocketOptions} [ws] Options for the WebSocket
102
+ * @property {HTTPOptions} [http] HTTP options
103
+ */
104
+
105
+ /**
106
+ * Options for {@link Sweepers} defining the behavior of cache sweeping
107
+ * @typedef {Object<SweeperKey, SweepOptions>} SweeperOptions
108
+ */
109
+
110
+ /**
111
+ * Options for sweeping a single type of item from cache
112
+ * @typedef {Object} SweepOptions
113
+ * @property {number} interval The interval (in seconds) at which to perform sweeping of the item
114
+ * @property {number} [lifetime] How long an item should stay in cache until it is considered sweepable.
115
+ * <warn>This property is only valid for the `invites`, `messages`, and `threads` keys. The `filter` property
116
+ * is mutually exclusive to this property and takes priority</warn>
117
+ * @property {GlobalSweepFilter} filter The function used to determine the function passed to the sweep method
118
+ * <info>This property is optional when the key is `invites`, `messages`, or `threads` and `lifetime` is set</info>
119
+ */
120
+
121
+ /**
122
+ * WebSocket options (these are left as snake_case to match the API)
123
+ * @typedef {Object} WebsocketOptions
124
+ * @property {AgentOptions} [agent={}] HTTPS Agent options (WS Proxy)
125
+ * @property {boolean} [compress=false] Whether to compress data sent on the connection
126
+ * @property {WebSocketProperties} [properties] Properties to identify the client with
127
+ */
128
+
129
+ /**
130
+ * HTTPS Agent options.
131
+ * @typedef {Object} AgentOptions
132
+ * @see {@link https://nodejs.org/api/https.html#https_class_https_agent}
133
+ * @see {@link https://nodejs.org/api/http.html#http_new_agent_options}
134
+ */
135
+
136
+ /**
137
+ * ProxyAgent options.
138
+ * @typedef {Object} ProxyAgentOptions
139
+ * @see {@link https://github.com/nodejs/undici/blob/main/docs/docs/api/ProxyAgent.md}
140
+ */
141
+
142
+ /**
143
+ * HTTP options
144
+ * @typedef {Object} HTTPOptions
145
+ * @property {number} [version=9] API version to use
146
+ * @property {ProxyAgentOptions} [agent={}] ProxyAgent options
147
+ * @property {string} [api='https://discord.com/api'] Base URL of the API
148
+ * @property {string} [cdn='https://cdn.discordapp.com'] Base URL of the CDN
149
+ * @property {string} [invite='https://discord.gg'] Base URL of invites
150
+ * @property {string} [template='https://discord.new'] Base URL of templates
151
+ * @property {Object} [headers] Additional headers to send for all API requests
152
+ * @property {string} [scheduledEvent='https://discord.com/events'] Base URL of guild scheduled events
153
+ */
154
+
155
+ /**
156
+ * Contains various utilities for client options.
157
+ */
158
+ class Options extends null {
159
+ /**
160
+ * The default client options.
161
+ * @returns {ClientOptions}
162
+ */
163
+ static createDefault() {
164
+ return {
165
+ DMChannelVoiceStatusSync: 0,
166
+ captchaRetryLimit: 3,
167
+ captchaSolver: () => {
168
+ const err = new Error('CAPTCHA_SOLVER_NOT_IMPLEMENTED');
169
+ err.cause =
170
+ 'You need to provide a captcha solver to use this feature\nExample: const client = new Client({ captchaSolver: yourAsyncFunction })';
171
+ throw err;
172
+ },
173
+ TOTPKey: null,
174
+ closeTimeout: 5_000,
175
+ waitGuildTimeout: 15_000,
176
+ shardCount: 1,
177
+ shards: [0],
178
+ makeCache: this.cacheWithLimits(this.defaultMakeCacheSettings),
179
+ messageCacheLifetime: 0,
180
+ messageSweepInterval: 0,
181
+ invalidRequestWarningInterval: 0,
182
+ intents: Intents.ALL,
183
+ partials: ['USER', 'CHANNEL', 'GUILD_MEMBER', 'MESSAGE', 'REACTION', 'GUILD_SCHEDULED_EVENT'], // Enable the partials
184
+ restWsBridgeTimeout: 5_000,
185
+ restRequestTimeout: 15_000,
186
+ restGlobalRateLimit: 0,
187
+ retryLimit: 1,
188
+ restTimeOffset: 500,
189
+ restSweepInterval: 60,
190
+ failIfNotExists: true,
191
+ presence: { status: 'online', since: 0, activities: [], afk: true },
192
+ sweepers: {},
193
+ ws: {
194
+ capabilities: 0, // https://discord-userdoccers.vercel.app/topics/gateway#gateway-capabilities
195
+ properties: {
196
+ os: 'Windows',
197
+ browser: 'Discord Client',
198
+ release_channel: 'stable',
199
+ client_version: '1.0.9215',
200
+ os_version: '10.0.19045',
201
+ os_arch: 'x64',
202
+ app_arch: 'x64',
203
+ system_locale: 'en-US',
204
+ has_client_mods: false,
205
+ client_launch_id: randomUUID(),
206
+ browser_user_agent: UserAgent,
207
+ browser_version: '37.6.0',
208
+ os_sdk_version: '19045',
209
+ client_build_number: 471091,
210
+ native_build_number: 72186,
211
+ client_event_source: null,
212
+ launch_signature: randomUUID(),
213
+ client_heartbeat_session_id: randomUUID(),
214
+ client_app_state: 'focused',
215
+ },
216
+ compress: false,
217
+ client_state: {
218
+ guild_versions: {},
219
+ },
220
+ version: 9,
221
+ agent: {},
222
+ },
223
+ http: {
224
+ agent: {},
225
+ headers: {
226
+ 'User-Agent': UserAgent,
227
+ },
228
+ version: 9,
229
+ api: 'https://discord.com/api',
230
+ cdn: 'https://cdn.discordapp.com',
231
+ invite: 'https://discord.gg',
232
+ template: 'https://discord.new',
233
+ scheduledEvent: 'https://discord.com/events',
234
+ },
235
+ };
236
+ }
237
+
238
+ /**
239
+ * Create a cache factory using predefined settings to sweep or limit.
240
+ * @param {Object<string, LimitedCollectionOptions|number>} [settings={}] Settings passed to the relevant constructor.
241
+ * If no setting is provided for a manager, it uses Collection.
242
+ * If a number is provided for a manager, it uses that number as the max size for a LimitedCollection.
243
+ * If LimitedCollectionOptions are provided for a manager, it uses those settings to form a LimitedCollection.
244
+ * @returns {CacheFactory}
245
+ * @example
246
+ * // Store up to 200 messages per channel and discard archived threads if they were archived more than 4 hours ago.
247
+ * // Note archived threads will remain in the guild and client caches with these settings
248
+ * Options.cacheWithLimits({
249
+ * MessageManager: 200,
250
+ * ThreadManager: {
251
+ * sweepInterval: 3600,
252
+ * sweepFilter: LimitedCollection.filterByLifetime({
253
+ * getComparisonTimestamp: e => e.archiveTimestamp,
254
+ * excludeFromSweep: e => !e.archived,
255
+ * }),
256
+ * },
257
+ * });
258
+ * @example
259
+ * // Sweep messages every 5 minutes, removing messages that have not been edited or created in the last 30 minutes
260
+ * Options.cacheWithLimits({
261
+ * // Keep default thread sweeping behavior
262
+ * ...Options.defaultMakeCacheSettings,
263
+ * // Override MessageManager
264
+ * MessageManager: {
265
+ * sweepInterval: 300,
266
+ * sweepFilter: LimitedCollection.filterByLifetime({
267
+ * lifetime: 1800,
268
+ * getComparisonTimestamp: e => e.editedTimestamp ?? e.createdTimestamp,
269
+ * })
270
+ * }
271
+ * });
272
+ */
273
+ static cacheWithLimits(settings = {}) {
274
+ const { Collection } = require('@discordjs/collection');
275
+ const LimitedCollection = require('./LimitedCollection');
276
+
277
+ return manager => {
278
+ const setting = settings[manager.name];
279
+ /* eslint-disable-next-line eqeqeq */
280
+ if (setting == null) {
281
+ return new Collection();
282
+ }
283
+ if (typeof setting === 'number') {
284
+ if (setting === Infinity) {
285
+ return new Collection();
286
+ }
287
+ return new LimitedCollection({ maxSize: setting });
288
+ }
289
+ /* eslint-disable eqeqeq */
290
+ const noSweeping =
291
+ setting.sweepFilter == null ||
292
+ setting.sweepInterval == null ||
293
+ setting.sweepInterval <= 0 ||
294
+ setting.sweepInterval === Infinity;
295
+ const noLimit = setting.maxSize == null || setting.maxSize === Infinity;
296
+ /* eslint-enable eqeqeq */
297
+ if (noSweeping && noLimit) {
298
+ return new Collection();
299
+ }
300
+ return new LimitedCollection(setting);
301
+ };
302
+ }
303
+
304
+ /**
305
+ * Create a cache factory that always caches everything.
306
+ * @returns {CacheFactory}
307
+ */
308
+ static cacheEverything() {
309
+ const { Collection } = require('@discordjs/collection');
310
+ return () => new Collection();
311
+ }
312
+
313
+ /**
314
+ * The default settings passed to {@link ClientOptions.makeCache}.
315
+ * The caches that this changes are:
316
+ * * `MessageManager` - Limit to 200 messages
317
+ * * `ChannelManager` - Sweep archived threads
318
+ * * `GuildChannelManager` - Sweep archived threads
319
+ * * `ThreadManager` - Sweep archived threads
320
+ * <info>If you want to keep default behavior and add on top of it you can use this object and add on to it, e.g.
321
+ * `makeCache: Options.cacheWithLimits({ ...Options.defaultMakeCacheSettings, ReactionManager: 0 })`</info>
322
+ * @type {Object<string, LimitedCollectionOptions|number>}
323
+ */
324
+ static get defaultMakeCacheSettings() {
325
+ return {
326
+ MessageManager: 200,
327
+ ChannelManager: {
328
+ sweepInterval: 3600,
329
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
330
+ },
331
+ GuildChannelManager: {
332
+ sweepInterval: 3600,
333
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
334
+ },
335
+ ThreadManager: {
336
+ sweepInterval: 3600,
337
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
338
+ },
339
+ };
340
+ }
341
+ }
342
+
343
+ /**
344
+ * The default settings passed to {@link ClientOptions.sweepers}.
345
+ * The sweepers that this changes are:
346
+ * * `threads` - Sweep archived threads every hour, removing those archived more than 4 hours ago
347
+ * <info>If you want to keep default behavior and add on top of it you can use this object and add on to it, e.g.
348
+ * `sweepers: { ...Options.defaultSweeperSettings, messages: { interval: 300, lifetime: 600 } }`</info>
349
+ * @type {SweeperOptions}
350
+ */
351
+ Options.defaultSweeperSettings = {
352
+ threads: {
353
+ interval: 3600,
354
+ lifetime: 14400,
355
+ },
356
+ };
357
+
358
+ module.exports = Options;
@@ -0,0 +1,202 @@
1
+ 'use strict';
2
+
3
+ const BitField = require('./BitField');
4
+
5
+ /**
6
+ * Data structure that makes it easy to interact with a permission bitfield. All {@link GuildMember}s have a set of
7
+ * permissions in their guild, and each channel in the guild may also have {@link PermissionOverwrites} for the member
8
+ * that override their default permissions.
9
+ * @extends {BitField}
10
+ */
11
+ class Permissions extends BitField {
12
+ /**
13
+ * Bitfield of the packed bits
14
+ * @type {bigint}
15
+ * @name Permissions#bitfield
16
+ */
17
+
18
+ /**
19
+ * Data that can be resolved to give a permission number. This can be:
20
+ * * A string (see {@link Permissions.FLAGS})
21
+ * * A permission number
22
+ * * An instance of Permissions
23
+ * * An Array of PermissionResolvable
24
+ * @typedef {string|bigint|Permissions|PermissionResolvable[]} PermissionResolvable
25
+ */
26
+
27
+ /**
28
+ * Gets all given bits that are missing from the bitfield.
29
+ * @param {BitFieldResolvable} bits Bit(s) to check for
30
+ * @param {boolean} [checkAdmin=true] Whether to allow the administrator permission to override
31
+ * @returns {string[]}
32
+ */
33
+ missing(bits, checkAdmin = true) {
34
+ return checkAdmin && this.has(this.constructor.FLAGS.ADMINISTRATOR) ? [] : super.missing(bits);
35
+ }
36
+
37
+ /**
38
+ * Checks whether the bitfield has a permission, or any of multiple permissions.
39
+ * @param {PermissionResolvable} permission Permission(s) to check for
40
+ * @param {boolean} [checkAdmin=true] Whether to allow the administrator permission to override
41
+ * @returns {boolean}
42
+ */
43
+ any(permission, checkAdmin = true) {
44
+ return (checkAdmin && super.has(this.constructor.FLAGS.ADMINISTRATOR)) || super.any(permission);
45
+ }
46
+
47
+ /**
48
+ * Checks whether the bitfield has a permission, or multiple permissions.
49
+ * @param {PermissionResolvable} permission Permission(s) to check for
50
+ * @param {boolean} [checkAdmin=true] Whether to allow the administrator permission to override
51
+ * @returns {boolean}
52
+ */
53
+ has(permission, checkAdmin = true) {
54
+ return (checkAdmin && super.has(this.constructor.FLAGS.ADMINISTRATOR)) || super.has(permission);
55
+ }
56
+
57
+ /**
58
+ * Gets an {@link Array} of bitfield names based on the permissions available.
59
+ * @returns {string[]}
60
+ */
61
+ toArray() {
62
+ return super.toArray(false);
63
+ }
64
+ }
65
+
66
+ /**
67
+ * Numeric permission flags. All available properties:
68
+ * * `CREATE_INSTANT_INVITE` (create invitations to the guild)
69
+ * * `KICK_MEMBERS`
70
+ * * `BAN_MEMBERS`
71
+ * * `ADMINISTRATOR` (implicitly has *all* permissions, and bypasses all channel overwrites)
72
+ * * `MANAGE_CHANNELS` (edit and reorder channels)
73
+ * * `MANAGE_GUILD` (edit the guild information, region, etc.)
74
+ * * `ADD_REACTIONS` (add new reactions to messages)
75
+ * * `VIEW_AUDIT_LOG`
76
+ * * `PRIORITY_SPEAKER`
77
+ * * `STREAM`
78
+ * * `VIEW_CHANNEL`
79
+ * * `SEND_MESSAGES`
80
+ * * `SEND_TTS_MESSAGES`
81
+ * * `MANAGE_MESSAGES` (delete messages and reactions)
82
+ * * `EMBED_LINKS` (links posted will have a preview embedded)
83
+ * * `ATTACH_FILES`
84
+ * * `READ_MESSAGE_HISTORY` (view messages that were posted prior to opening Discord)
85
+ * * `MENTION_EVERYONE`
86
+ * * `USE_EXTERNAL_EMOJIS` (use emojis from different guilds)
87
+ * * `VIEW_GUILD_INSIGHTS`
88
+ * * `CONNECT` (connect to a voice channel)
89
+ * * `SPEAK` (speak in a voice channel)
90
+ * * `MUTE_MEMBERS` (mute members across all voice channels)
91
+ * * `DEAFEN_MEMBERS` (deafen members across all voice channels)
92
+ * * `MOVE_MEMBERS` (move members between voice channels)
93
+ * * `USE_VAD` (use voice activity detection)
94
+ * * `CHANGE_NICKNAME`
95
+ * * `MANAGE_NICKNAMES` (change other members' nicknames)
96
+ * * `MANAGE_ROLES`
97
+ * * `MANAGE_WEBHOOKS`
98
+ * * `MANAGE_EMOJIS_AND_STICKERS`
99
+ * * `USE_APPLICATION_COMMANDS`
100
+ * * `REQUEST_TO_SPEAK`
101
+ * * `MANAGE_EVENTS`
102
+ * * `MANAGE_THREADS`
103
+ * * `USE_PUBLIC_THREADS` (deprecated)
104
+ * * `CREATE_PUBLIC_THREADS`
105
+ * * `USE_PRIVATE_THREADS` (deprecated)
106
+ * * `CREATE_PRIVATE_THREADS`
107
+ * * `USE_EXTERNAL_STICKERS` (use stickers from different guilds)
108
+ * * `SEND_MESSAGES_IN_THREADS`
109
+ * * `START_EMBEDDED_ACTIVITIES`
110
+ * * `MODERATE_MEMBERS`
111
+ * * `VIEW_CREATOR_MONETIZATION_ANALYTICS`
112
+ * * `USE_SOUNDBOARD`
113
+ * * `CREATE_GUILD_EXPRESSIONS`
114
+ * * `CREATE_EVENTS`
115
+ * * `USE_EXTERNAL_SOUNDS`
116
+ * * `SEND_VOICE_MESSAGES`
117
+ * * `USE_CLYDE_AI`
118
+ * * `SET_VOICE_CHANNEL_STATUS`
119
+ * * `SEND_POLLS`
120
+ * * `USE_EXTERNAL_APPS`
121
+ * @type {Object<string, bigint>}
122
+ * @see {@link https://discord.com/developers/docs/topics/permissions#permissions-bitwise-permission-flags}
123
+ */
124
+ Permissions.FLAGS = {
125
+ CREATE_INSTANT_INVITE: 1n << 0n,
126
+ KICK_MEMBERS: 1n << 1n,
127
+ BAN_MEMBERS: 1n << 2n,
128
+ ADMINISTRATOR: 1n << 3n,
129
+ MANAGE_CHANNELS: 1n << 4n,
130
+ MANAGE_GUILD: 1n << 5n,
131
+ ADD_REACTIONS: 1n << 6n,
132
+ VIEW_AUDIT_LOG: 1n << 7n,
133
+ PRIORITY_SPEAKER: 1n << 8n,
134
+ STREAM: 1n << 9n,
135
+ VIEW_CHANNEL: 1n << 10n,
136
+ SEND_MESSAGES: 1n << 11n,
137
+ SEND_TTS_MESSAGES: 1n << 12n,
138
+ MANAGE_MESSAGES: 1n << 13n,
139
+ EMBED_LINKS: 1n << 14n,
140
+ ATTACH_FILES: 1n << 15n,
141
+ READ_MESSAGE_HISTORY: 1n << 16n,
142
+ MENTION_EVERYONE: 1n << 17n,
143
+ USE_EXTERNAL_EMOJIS: 1n << 18n,
144
+ VIEW_GUILD_INSIGHTS: 1n << 19n,
145
+ CONNECT: 1n << 20n,
146
+ SPEAK: 1n << 21n,
147
+ MUTE_MEMBERS: 1n << 22n,
148
+ DEAFEN_MEMBERS: 1n << 23n,
149
+ MOVE_MEMBERS: 1n << 24n,
150
+ USE_VAD: 1n << 25n,
151
+ CHANGE_NICKNAME: 1n << 26n,
152
+ MANAGE_NICKNAMES: 1n << 27n,
153
+ MANAGE_ROLES: 1n << 28n,
154
+ MANAGE_WEBHOOKS: 1n << 29n,
155
+ MANAGE_EMOJIS_AND_STICKERS: 1n << 30n,
156
+ USE_APPLICATION_COMMANDS: 1n << 31n,
157
+ REQUEST_TO_SPEAK: 1n << 32n,
158
+ MANAGE_EVENTS: 1n << 33n,
159
+ MANAGE_THREADS: 1n << 34n,
160
+ // TODO: Remove deprecated USE_*_THREADS flags in v14
161
+ USE_PUBLIC_THREADS: 1n << 35n,
162
+ CREATE_PUBLIC_THREADS: 1n << 35n,
163
+ USE_PRIVATE_THREADS: 1n << 36n,
164
+ CREATE_PRIVATE_THREADS: 1n << 36n,
165
+ USE_EXTERNAL_STICKERS: 1n << 37n,
166
+ SEND_MESSAGES_IN_THREADS: 1n << 38n,
167
+ START_EMBEDDED_ACTIVITIES: 1n << 39n,
168
+ MODERATE_MEMBERS: 1n << 40n,
169
+ VIEW_CREATOR_MONETIZATION_ANALYTICS: 1n << 41n,
170
+ USE_SOUNDBOARD: 1n << 42n,
171
+ CREATE_GUILD_EXPRESSIONS: 1n << 43n,
172
+ CREATE_EVENTS: 1n << 44n,
173
+ USE_EXTERNAL_SOUNDS: 1n << 45n,
174
+ SEND_VOICE_MESSAGES: 1n << 46n,
175
+ USE_CLYDE_AI: 1n << 47n,
176
+ SET_VOICE_CHANNEL_STATUS: 1n << 48n,
177
+ SEND_POLLS: 1n << 49n,
178
+ USE_EXTERNAL_APPS: 1n << 50n,
179
+ };
180
+
181
+ /**
182
+ * Bitfield representing every permission combined
183
+ * @type {bigint}
184
+ */
185
+ Permissions.ALL = Object.values(Permissions.FLAGS).reduce((all, p) => all | p, 0n);
186
+
187
+ /**
188
+ * Bitfield representing the default permissions for users
189
+ * @type {bigint}
190
+ */
191
+ Permissions.DEFAULT = BigInt(104324673);
192
+
193
+ /**
194
+ * Bitfield representing the permissions required for moderators of stage channels
195
+ * @type {bigint}
196
+ */
197
+ Permissions.STAGE_MODERATOR =
198
+ Permissions.FLAGS.MANAGE_CHANNELS | Permissions.FLAGS.MUTE_MEMBERS | Permissions.FLAGS.MOVE_MEMBERS;
199
+
200
+ Permissions.defaultBit = BigInt(0);
201
+
202
+ module.exports = Permissions;
@@ -0,0 +1,31 @@
1
+ 'use strict';
2
+
3
+ const BitField = require('./BitField');
4
+
5
+ /**
6
+ * Data structure that makes it easy to interact with an {@link PremiumUsageFlags#flags} bitfield.
7
+ * @extends {BitField}
8
+ */
9
+ class PremiumUsageFlags extends BitField {}
10
+
11
+ /**
12
+ * @name PremiumUsageFlags
13
+ * @kind constructor
14
+ * @memberof PremiumUsageFlags
15
+ * @param {BitFieldResolvable} [bits=0] Bit(s) to read from
16
+ */
17
+
18
+ /**
19
+ * Numeric the Discord premium usage flags. All available properties:
20
+ * * `PREMIUM_DISCRIMINATOR`
21
+ * * `ANIMATED_AVATAR`
22
+ * * `PROFILE_BANNER`
23
+ * @type {Object}
24
+ */
25
+ PremiumUsageFlags.FLAGS = {
26
+ PREMIUM_DISCRIMINATOR: 1 << 0,
27
+ ANIMATED_AVATAR: 1 << 1,
28
+ PROFILE_BANNER: 1 << 2,
29
+ };
30
+
31
+ module.exports = PremiumUsageFlags;
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ const BitField = require('./BitField');
4
+
5
+ /**
6
+ * Data structure that makes it easy to interact with an {@link PurchasedFlags#flags} bitfield.
7
+ * @extends {BitField}
8
+ */
9
+ class PurchasedFlags extends BitField {}
10
+
11
+ /**
12
+ * @name PurchasedFlags
13
+ * @kind constructor
14
+ * @memberof PurchasedFlags
15
+ * @param {BitFieldResolvable} [bits=0] Bit(s) to read from
16
+ */
17
+
18
+ /**
19
+ * Numeric the Discord purchased flags. All available properties:
20
+ * * `NITRO_CLASSIC`
21
+ * * `NITRO`
22
+ * * `GUILD_BOOST`
23
+ * * `NITRO_BASIC`
24
+ * @type {Object}
25
+ */
26
+ PurchasedFlags.FLAGS = {
27
+ NITRO_CLASSIC: 1 << 0,
28
+ NITRO: 1 << 1,
29
+ GUILD_BOOST: 1 << 2,
30
+ NITRO_BASIC: 1 << 3,
31
+ };
32
+
33
+ module.exports = PurchasedFlags;