safeness-sb-new 0.0.1

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 (343) hide show
  1. package/README.md +115 -0
  2. package/package.json +96 -0
  3. package/src/WebSocket.js +39 -0
  4. package/src/client/BaseClient.js +86 -0
  5. package/src/client/Client.js +836 -0
  6. package/src/client/WebhookClient.js +61 -0
  7. package/src/client/actions/Action.js +120 -0
  8. package/src/client/actions/ActionsManager.js +78 -0
  9. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  10. package/src/client/actions/AutoModerationActionExecution.js +27 -0
  11. package/src/client/actions/AutoModerationRuleCreate.js +28 -0
  12. package/src/client/actions/AutoModerationRuleDelete.js +32 -0
  13. package/src/client/actions/AutoModerationRuleUpdate.js +30 -0
  14. package/src/client/actions/ChannelCreate.js +23 -0
  15. package/src/client/actions/ChannelDelete.js +39 -0
  16. package/src/client/actions/ChannelUpdate.js +43 -0
  17. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
  18. package/src/client/actions/GuildBanAdd.js +20 -0
  19. package/src/client/actions/GuildBanRemove.js +25 -0
  20. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
  21. package/src/client/actions/GuildDelete.js +65 -0
  22. package/src/client/actions/GuildEmojiCreate.js +20 -0
  23. package/src/client/actions/GuildEmojiDelete.js +21 -0
  24. package/src/client/actions/GuildEmojiUpdate.js +20 -0
  25. package/src/client/actions/GuildEmojisUpdate.js +34 -0
  26. package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
  27. package/src/client/actions/GuildMemberRemove.js +33 -0
  28. package/src/client/actions/GuildMemberUpdate.js +44 -0
  29. package/src/client/actions/GuildRoleCreate.js +25 -0
  30. package/src/client/actions/GuildRoleDelete.js +31 -0
  31. package/src/client/actions/GuildRoleUpdate.js +39 -0
  32. package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
  33. package/src/client/actions/GuildScheduledEventCreate.js +27 -0
  34. package/src/client/actions/GuildScheduledEventDelete.js +31 -0
  35. package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
  36. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
  37. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
  38. package/src/client/actions/GuildStickerCreate.js +20 -0
  39. package/src/client/actions/GuildStickerDelete.js +21 -0
  40. package/src/client/actions/GuildStickerUpdate.js +20 -0
  41. package/src/client/actions/GuildStickersUpdate.js +34 -0
  42. package/src/client/actions/GuildUpdate.js +33 -0
  43. package/src/client/actions/InviteCreate.js +28 -0
  44. package/src/client/actions/InviteDelete.js +30 -0
  45. package/src/client/actions/MessageCreate.js +46 -0
  46. package/src/client/actions/MessageDelete.js +32 -0
  47. package/src/client/actions/MessageDeleteBulk.js +46 -0
  48. package/src/client/actions/MessageReactionAdd.js +56 -0
  49. package/src/client/actions/MessageReactionRemove.js +45 -0
  50. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  51. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  52. package/src/client/actions/MessageUpdate.js +26 -0
  53. package/src/client/actions/PresenceUpdate.js +46 -0
  54. package/src/client/actions/StageInstanceCreate.js +28 -0
  55. package/src/client/actions/StageInstanceDelete.js +33 -0
  56. package/src/client/actions/StageInstanceUpdate.js +30 -0
  57. package/src/client/actions/ThreadCreate.js +24 -0
  58. package/src/client/actions/ThreadDelete.js +32 -0
  59. package/src/client/actions/ThreadListSync.js +59 -0
  60. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  61. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  62. package/src/client/actions/TypingStart.js +29 -0
  63. package/src/client/actions/UserUpdate.js +35 -0
  64. package/src/client/actions/VoiceStateUpdate.js +57 -0
  65. package/src/client/actions/WebhooksUpdate.js +20 -0
  66. package/src/client/voice/ClientVoiceManager.js +150 -0
  67. package/src/client/voice/VoiceConnection.js +849 -0
  68. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  69. package/src/client/voice/dispatcher/AudioDispatcher.js +115 -0
  70. package/src/client/voice/dispatcher/BaseDispatcher.js +405 -0
  71. package/src/client/voice/dispatcher/VPxDispatcher.js +52 -0
  72. package/src/client/voice/dispatcher/VideoDispatcher.js +31 -0
  73. package/src/client/voice/networking/VoiceUDPClient.js +188 -0
  74. package/src/client/voice/networking/VoiceWebSocket.js +280 -0
  75. package/src/client/voice/player/MediaPlayer.js +294 -0
  76. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  77. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  78. package/src/client/voice/receiver/PacketHandler.js +170 -0
  79. package/src/client/voice/receiver/Receiver.js +82 -0
  80. package/src/client/voice/receiver/video/IvfJoinner.js +106 -0
  81. package/src/client/voice/util/Function.js +14 -0
  82. package/src/client/voice/util/PlayInterface.js +122 -0
  83. package/src/client/voice/util/Secretbox.js +42 -0
  84. package/src/client/voice/util/Silence.js +16 -0
  85. package/src/client/voice/util/Socket.js +62 -0
  86. package/src/client/voice/util/VolumeInterface.js +104 -0
  87. package/src/client/websocket/WebSocketManager.js +392 -0
  88. package/src/client/websocket/WebSocketShard.js +906 -0
  89. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  90. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  91. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  92. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  93. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  94. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  95. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  96. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  97. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  98. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  99. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  100. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  101. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  102. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  103. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -0
  104. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  105. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  106. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  107. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  108. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  109. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -0
  110. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  111. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  112. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  113. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  114. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  115. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  116. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  117. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  118. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  119. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  120. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  121. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  122. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  123. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  125. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  126. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  127. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -0
  128. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  129. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  130. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  131. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  132. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  133. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +22 -0
  134. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +12 -0
  135. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
  136. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  137. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  138. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  139. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  140. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  141. package/src/client/websocket/handlers/READY.js +120 -0
  142. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -0
  143. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -0
  144. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -0
  145. package/src/client/websocket/handlers/RESUMED.js +14 -0
  146. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  147. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  148. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  149. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  150. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  151. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  152. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  153. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  154. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  155. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  156. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -0
  157. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  158. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -0
  159. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -0
  160. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  161. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -0
  162. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  163. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  164. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  165. package/src/client/websocket/handlers/index.js +83 -0
  166. package/src/errors/DJSError.js +61 -0
  167. package/src/errors/Messages.js +208 -0
  168. package/src/errors/index.js +4 -0
  169. package/src/index.js +159 -0
  170. package/src/managers/ApplicationCommandManager.js +264 -0
  171. package/src/managers/ApplicationCommandPermissionsManager.js +417 -0
  172. package/src/managers/AutoModerationRuleManager.js +296 -0
  173. package/src/managers/BaseGuildEmojiManager.js +80 -0
  174. package/src/managers/BaseManager.js +19 -0
  175. package/src/managers/BillingManager.js +66 -0
  176. package/src/managers/CachedManager.js +71 -0
  177. package/src/managers/ChannelManager.js +138 -0
  178. package/src/managers/ClientUserSettingManager.js +372 -0
  179. package/src/managers/DataManager.js +61 -0
  180. package/src/managers/GuildBanManager.js +204 -0
  181. package/src/managers/GuildChannelManager.js +488 -0
  182. package/src/managers/GuildEmojiManager.js +171 -0
  183. package/src/managers/GuildEmojiRoleManager.js +118 -0
  184. package/src/managers/GuildForumThreadManager.js +108 -0
  185. package/src/managers/GuildInviteManager.js +213 -0
  186. package/src/managers/GuildManager.js +304 -0
  187. package/src/managers/GuildMemberManager.js +597 -0
  188. package/src/managers/GuildMemberRoleManager.js +191 -0
  189. package/src/managers/GuildScheduledEventManager.js +296 -0
  190. package/src/managers/GuildSettingManager.js +155 -0
  191. package/src/managers/GuildStickerManager.js +179 -0
  192. package/src/managers/GuildTextThreadManager.js +98 -0
  193. package/src/managers/InteractionManager.js +39 -0
  194. package/src/managers/MessageManager.js +391 -0
  195. package/src/managers/PermissionOverwriteManager.js +166 -0
  196. package/src/managers/PresenceManager.js +58 -0
  197. package/src/managers/ReactionManager.js +67 -0
  198. package/src/managers/ReactionUserManager.js +71 -0
  199. package/src/managers/RelationshipManager.js +265 -0
  200. package/src/managers/RoleManager.js +352 -0
  201. package/src/managers/StageInstanceManager.js +162 -0
  202. package/src/managers/ThreadManager.js +174 -0
  203. package/src/managers/ThreadMemberManager.js +186 -0
  204. package/src/managers/UserManager.js +146 -0
  205. package/src/managers/UserNoteManager.js +53 -0
  206. package/src/managers/VoiceStateManager.js +37 -0
  207. package/src/rest/APIRequest.js +159 -0
  208. package/src/rest/APIRouter.js +53 -0
  209. package/src/rest/DiscordAPIError.js +104 -0
  210. package/src/rest/HTTPError.js +62 -0
  211. package/src/rest/RESTManager.js +62 -0
  212. package/src/rest/RateLimitError.js +55 -0
  213. package/src/rest/RequestHandler.js +444 -0
  214. package/src/sharding/Shard.js +443 -0
  215. package/src/sharding/ShardClientUtil.js +275 -0
  216. package/src/sharding/ShardingManager.js +318 -0
  217. package/src/structures/AnonymousGuild.js +98 -0
  218. package/src/structures/ApplicationCommand.js +593 -0
  219. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -0
  220. package/src/structures/AutoModerationActionExecution.js +89 -0
  221. package/src/structures/AutoModerationRule.js +294 -0
  222. package/src/structures/AutocompleteInteraction.js +107 -0
  223. package/src/structures/Base.js +43 -0
  224. package/src/structures/BaseCommandInteraction.js +211 -0
  225. package/src/structures/BaseGuild.js +116 -0
  226. package/src/structures/BaseGuildEmoji.js +56 -0
  227. package/src/structures/BaseGuildTextChannel.js +191 -0
  228. package/src/structures/BaseGuildVoiceChannel.js +241 -0
  229. package/src/structures/BaseMessageComponent.js +114 -0
  230. package/src/structures/ButtonInteraction.js +11 -0
  231. package/src/structures/CallState.js +63 -0
  232. package/src/structures/CategoryChannel.js +85 -0
  233. package/src/structures/Channel.js +270 -0
  234. package/src/structures/ClientPresence.js +77 -0
  235. package/src/structures/ClientUser.js +450 -0
  236. package/src/structures/CommandInteraction.js +41 -0
  237. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  238. package/src/structures/ContextMenuInteraction.js +65 -0
  239. package/src/structures/DMChannel.js +217 -0
  240. package/src/structures/DirectoryChannel.js +20 -0
  241. package/src/structures/Emoji.js +148 -0
  242. package/src/structures/ForumChannel.js +261 -0
  243. package/src/structures/GroupDMChannel.js +387 -0
  244. package/src/structures/Guild.js +1608 -0
  245. package/src/structures/GuildAuditLogs.js +729 -0
  246. package/src/structures/GuildBan.js +59 -0
  247. package/src/structures/GuildBoost.js +108 -0
  248. package/src/structures/GuildChannel.js +468 -0
  249. package/src/structures/GuildEmoji.js +161 -0
  250. package/src/structures/GuildMember.js +568 -0
  251. package/src/structures/GuildPreview.js +191 -0
  252. package/src/structures/GuildPreviewEmoji.js +27 -0
  253. package/src/structures/GuildScheduledEvent.js +441 -0
  254. package/src/structures/GuildTemplate.js +236 -0
  255. package/src/structures/Integration.js +188 -0
  256. package/src/structures/IntegrationApplication.js +96 -0
  257. package/src/structures/Interaction.js +290 -0
  258. package/src/structures/InteractionCollector.js +248 -0
  259. package/src/structures/InteractionWebhook.js +43 -0
  260. package/src/structures/Invite.js +358 -0
  261. package/src/structures/InviteGuild.js +23 -0
  262. package/src/structures/InviteStageInstance.js +86 -0
  263. package/src/structures/Message.js +1227 -0
  264. package/src/structures/MessageActionRow.js +103 -0
  265. package/src/structures/MessageAttachment.js +204 -0
  266. package/src/structures/MessageButton.js +165 -0
  267. package/src/structures/MessageCollector.js +146 -0
  268. package/src/structures/MessageComponentInteraction.js +120 -0
  269. package/src/structures/MessageContextMenuInteraction.js +20 -0
  270. package/src/structures/MessageEmbed.js +586 -0
  271. package/src/structures/MessageMentions.js +273 -0
  272. package/src/structures/MessagePayload.js +318 -0
  273. package/src/structures/MessagePoll.js +238 -0
  274. package/src/structures/MessageReaction.js +171 -0
  275. package/src/structures/MessageSelectMenu.js +140 -0
  276. package/src/structures/Modal.js +161 -0
  277. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  278. package/src/structures/ModalSubmitInteraction.js +119 -0
  279. package/src/structures/NewsChannel.js +32 -0
  280. package/src/structures/OAuth2Guild.js +28 -0
  281. package/src/structures/PermissionOverwrites.js +196 -0
  282. package/src/structures/Presence.js +1131 -0
  283. package/src/structures/ReactionCollector.js +229 -0
  284. package/src/structures/ReactionEmoji.js +31 -0
  285. package/src/structures/Role.js +531 -0
  286. package/src/structures/SelectMenuInteraction.js +21 -0
  287. package/src/structures/StageChannel.js +104 -0
  288. package/src/structures/StageInstance.js +208 -0
  289. package/src/structures/Sticker.js +310 -0
  290. package/src/structures/StickerPack.js +95 -0
  291. package/src/structures/StoreChannel.js +56 -0
  292. package/src/structures/Team.js +118 -0
  293. package/src/structures/TeamMember.js +71 -0
  294. package/src/structures/TextChannel.js +33 -0
  295. package/src/structures/TextInputComponent.js +131 -0
  296. package/src/structures/ThreadChannel.js +607 -0
  297. package/src/structures/ThreadMember.js +105 -0
  298. package/src/structures/Typing.js +74 -0
  299. package/src/structures/User.js +543 -0
  300. package/src/structures/UserContextMenuInteraction.js +29 -0
  301. package/src/structures/VoiceChannel.js +110 -0
  302. package/src/structures/VoiceRegion.js +53 -0
  303. package/src/structures/VoiceState.js +345 -0
  304. package/src/structures/WebEmbed.js +373 -0
  305. package/src/structures/Webhook.js +467 -0
  306. package/src/structures/WelcomeChannel.js +60 -0
  307. package/src/structures/WelcomeScreen.js +48 -0
  308. package/src/structures/Widget.js +87 -0
  309. package/src/structures/WidgetMember.js +99 -0
  310. package/src/structures/interfaces/Application.js +313 -0
  311. package/src/structures/interfaces/Collector.js +300 -0
  312. package/src/structures/interfaces/InteractionResponses.js +313 -0
  313. package/src/structures/interfaces/TextBasedChannel.js +719 -0
  314. package/src/util/ActivityFlags.js +44 -0
  315. package/src/util/ApplicationFlags.js +76 -0
  316. package/src/util/AttachmentFlags.js +38 -0
  317. package/src/util/BitField.js +170 -0
  318. package/src/util/ChannelFlags.js +45 -0
  319. package/src/util/Constants.js +1815 -0
  320. package/src/util/DataResolver.js +145 -0
  321. package/src/util/Formatters.js +228 -0
  322. package/src/util/GuildMemberFlags.js +43 -0
  323. package/src/util/Intents.js +74 -0
  324. package/src/util/InviteFlags.js +29 -0
  325. package/src/util/LimitedCollection.js +131 -0
  326. package/src/util/MessageFlags.js +54 -0
  327. package/src/util/Options.js +336 -0
  328. package/src/util/Permissions.js +202 -0
  329. package/src/util/PremiumUsageFlags.js +31 -0
  330. package/src/util/PurchasedFlags.js +33 -0
  331. package/src/util/RemoteAuth.js +382 -0
  332. package/src/util/RoleFlags.js +37 -0
  333. package/src/util/SnowflakeUtil.js +92 -0
  334. package/src/util/Speaking.js +33 -0
  335. package/src/util/Sweepers.js +466 -0
  336. package/src/util/SystemChannelFlags.js +55 -0
  337. package/src/util/ThreadMemberFlags.js +30 -0
  338. package/src/util/UserFlags.js +104 -0
  339. package/src/util/Util.js +889 -0
  340. package/typings/enums.d.ts +297 -0
  341. package/typings/index.d.ts +7670 -0
  342. package/typings/index.test-d.ts +0 -0
  343. package/typings/rawDataTypes.d.ts +342 -0
@@ -0,0 +1,336 @@
1
+ 'use strict';
2
+
3
+ const { UserAgent } = require('./Constants');
4
+ const Intents = require('./Intents');
5
+
6
+ /**
7
+ * Rate limit data
8
+ * @typedef {Object} RateLimitData
9
+ * @property {number} timeout Time until this rate limit ends, in milliseconds
10
+ * @property {number} limit The maximum amount of requests of this endpoint
11
+ * @property {string} method The HTTP method of this request
12
+ * @property {string} path The path of the request relative to the HTTP endpoint
13
+ * @property {string} route The route of the request relative to the HTTP endpoint
14
+ * @property {boolean} global Whether this is a global rate limit
15
+ */
16
+
17
+ /**
18
+ * Whether this rate limit should throw an Error
19
+ * @typedef {Function} RateLimitQueueFilter
20
+ * @param {RateLimitData} rateLimitData The data of this rate limit
21
+ * @returns {boolean|Promise<boolean>}
22
+ */
23
+
24
+ /**
25
+ * @typedef {Function} CacheFactory
26
+ * @param {Function} manager The manager class the cache is being requested from.
27
+ * @param {Function} holds The class that the cache will hold.
28
+ * @returns {Collection} A Collection used to store the cache of the manager.
29
+ */
30
+
31
+ /**
32
+ * @typedef {Function} CaptchaSolver
33
+ * @param {Captcha} captcha Discord Captcha
34
+ * @param {string} UserAgent Current UserAgent
35
+ * @returns {Promise<string>} HCaptcha Token
36
+ * @example
37
+ * const Captcha = require("2captcha")
38
+ * // A new 'solver' instance with our API key
39
+ * const solver = new Captcha.Solver("<Your 2captcha api key>")
40
+ * function solveCaptcha(captcha, UA) {
41
+ * return solver.hcaptcha(captcha.captcha_sitekey, 'discord.com', {
42
+ * invisible: 1,
43
+ * userAgent: UA,
44
+ * data: captcha.captcha_rqdata,
45
+ * }).then(res => res.data)
46
+ * }
47
+ */
48
+
49
+ /**
50
+ * Options for a client.
51
+ * @typedef {Object} ClientOptions
52
+ * @property {number} [DMChannelVoiceStatusSync=0] The amount of time in milliseconds that the Client to register the event with each DM channel (0=Disable)
53
+ * @property {number} [captchaRetryLimit=3] Captcha retry limit
54
+ * @property {CaptchaSolver} [captchaSolver] Captcha Solver
55
+ * @property {number} [closeTimeout=5000] The amount of time in milliseconds to wait for the close frame to be received
56
+ * from the WebSocket.
57
+ * <info>Don't have this too high/low. It's best to have it between 2000-6000 ms.</info>
58
+ * (e.g. recommended shard count, shard count of the ShardingManager)
59
+ * @property {CacheFactory} [makeCache] Function to create a cache.
60
+ * You can use your own function, or the {@link Options} class to customize the Collection used for the cache.
61
+ * <warn>Overriding the cache used in `GuildManager`, `ChannelManager`, `GuildChannelManager`, `RoleManager`,
62
+ * and `PermissionOverwriteManager` is unsupported and **will** break functionality</warn>
63
+ * @property {number} [messageCacheLifetime=0] DEPRECATED: Pass `lifetime` to `sweepers.messages` instead.
64
+ * How long a message should stay in the cache until it is considered sweepable (in seconds, 0 for forever)
65
+ * @property {number} [messageSweepInterval=0] DEPRECATED: Pass `interval` to `sweepers.messages` instead.
66
+ * How frequently to remove messages from the cache that are older than the message cache lifetime
67
+ * (in seconds, 0 for never)
68
+ * @property {MessageMentionOptions} [allowedMentions] Default value for {@link MessageOptions#allowedMentions}
69
+ * @property {number} [invalidRequestWarningInterval=0] The number of invalid REST requests (those that return
70
+ * 401, 403, or 429) in a 10 minute window between emitted warnings (0 for no warnings). That is, if set to 500,
71
+ * warnings will be emitted at invalid request number 500, 1000, 1500, and so on.
72
+ * @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
73
+ * they're missing all the data for a particular structure. See the "Partial Structures" topic on the
74
+ * [guide](https://discordjs.guide/popular-topics/partials.html) for some
75
+ * important usage information, as partials require you to put checks in place when handling data.
76
+ * @property {number} [restWsBridgeTimeout=5000] Maximum time permitted between REST responses and their
77
+ * corresponding WebSocket events
78
+ * @property {number} [restTimeOffset=500] Extra time in milliseconds to wait before continuing to make REST
79
+ * requests (higher values will reduce rate-limiting errors on bad connections)
80
+ * @property {number} [restRequestTimeout=15000] Time to wait before cancelling a REST request, in milliseconds
81
+ * @property {number} [restSweepInterval=60] How frequently to delete inactive request buckets, in seconds
82
+ * (or 0 for never)
83
+ * @property {number} [restGlobalRateLimit=0] How many requests to allow sending per second (0 for unlimited, 50 for
84
+ * the standard global limit used by Discord)
85
+ * @property {string[]|RateLimitQueueFilter} [rejectOnRateLimit] Decides how rate limits and pre-emptive throttles
86
+ * should be handled. If this option is an array containing the prefix of the request route (e.g. /channels to match any
87
+ * route starting with /channels, such as /channels/222197033908436994/messages) or a function returning true, a
88
+ * {@link RateLimitError} will be thrown. Otherwise the request will be queued for later
89
+ * @property {number} [retryLimit=1] How many times to retry on 5XX errors
90
+ * (Infinity for an indefinite amount of retries)
91
+ * @property {boolean} [failIfNotExists=true] Default value for {@link ReplyMessageOptions#failIfNotExists}
92
+ * @property {PresenceData} [presence={ status: 'online', since: 0, activities: [], afk: false }] Presence data to use upon login
93
+ * @property {number} [waitGuildTimeout=15_000] Time in milliseconds that Clients with the GUILDS intent should wait for
94
+ * missing guilds to be received before starting the bot. If not specified, the default is 15 seconds.
95
+ * @property {SweeperOptions} [sweepers={}] Options for cache sweeping
96
+ * @property {WebsocketOptions} [ws] Options for the WebSocket
97
+ * @property {HTTPOptions} [http] HTTP options
98
+ */
99
+
100
+ /**
101
+ * Options for {@link Sweepers} defining the behavior of cache sweeping
102
+ * @typedef {Object<SweeperKey, SweepOptions>} SweeperOptions
103
+ */
104
+
105
+ /**
106
+ * Options for sweeping a single type of item from cache
107
+ * @typedef {Object} SweepOptions
108
+ * @property {number} interval The interval (in seconds) at which to perform sweeping of the item
109
+ * @property {number} [lifetime] How long an item should stay in cache until it is considered sweepable.
110
+ * <warn>This property is only valid for the `invites`, `messages`, and `threads` keys. The `filter` property
111
+ * is mutually exclusive to this property and takes priority</warn>
112
+ * @property {GlobalSweepFilter} filter The function used to determine the function passed to the sweep method
113
+ * <info>This property is optional when the key is `invites`, `messages`, or `threads` and `lifetime` is set</info>
114
+ */
115
+
116
+ /**
117
+ * WebSocket options (these are left as snake_case to match the API)
118
+ * @typedef {Object} WebsocketOptions
119
+ * @property {AgentOptions} [agent={}] HTTPS Agent options (WS Proxy)
120
+ * @property {boolean} [compress=false] Whether to compress data sent on the connection
121
+ * @property {WebSocketProperties} [properties] Properties to identify the client with
122
+ */
123
+
124
+ /**
125
+ * HTTPS Agent options.
126
+ * @typedef {Object} AgentOptions
127
+ * @see {@link https://nodejs.org/api/https.html#https_class_https_agent}
128
+ * @see {@link https://nodejs.org/api/http.html#http_new_agent_options}
129
+ */
130
+
131
+ /**
132
+ * HTTP options
133
+ * @typedef {Object} HTTPOptions
134
+ * @property {number} [version=9] API version to use
135
+ * @property {AgentOptions} [agent={}] HTTPS Agent options
136
+ * @property {string} [api='https://discord.com/api'] Base URL of the API
137
+ * @property {string} [cdn='https://cdn.discordapp.com'] Base URL of the CDN
138
+ * @property {string} [invite='https://discord.gg'] Base URL of invites
139
+ * @property {string} [template='https://discord.new'] Base URL of templates
140
+ * @property {Object} [headers] Additional headers to send for all API requests
141
+ * @property {string} [scheduledEvent='https://discord.com/events'] Base URL of guild scheduled events
142
+ */
143
+
144
+ /**
145
+ * Contains various utilities for client options.
146
+ */
147
+ class Options extends null {
148
+ /**
149
+ * The default client options.
150
+ * @returns {ClientOptions}
151
+ */
152
+ static createDefault() {
153
+ return {
154
+ DMChannelVoiceStatusSync: 0,
155
+ captchaRetryLimit: 3,
156
+ captchaSolver: () => Promise.reject(new Error('CAPTCHA_SOLVER_NOT_IMPLEMENTED')),
157
+ closeTimeout: 5_000,
158
+ waitGuildTimeout: 15_000,
159
+ shardCount: 1,
160
+ shards: [0],
161
+ makeCache: this.cacheWithLimits(this.defaultMakeCacheSettings),
162
+ messageCacheLifetime: 0,
163
+ messageSweepInterval: 0,
164
+ invalidRequestWarningInterval: 0,
165
+ intents: Intents.ALL,
166
+ partials: ['USER', 'CHANNEL', 'GUILD_MEMBER', 'MESSAGE', 'REACTION', 'GUILD_SCHEDULED_EVENT'], // Enable the partials
167
+ restWsBridgeTimeout: 5_000,
168
+ restRequestTimeout: 15_000,
169
+ restGlobalRateLimit: 0,
170
+ retryLimit: 1,
171
+ restTimeOffset: 500,
172
+ restSweepInterval: 60,
173
+ failIfNotExists: true,
174
+ presence: { status: 'online', since: 0, activities: [], afk: true },
175
+ sweepers: {},
176
+ ws: {
177
+ capabilities: 0, // https://discord-userdoccers.vercel.app/topics/gateway#gateway-capabilities
178
+ properties: {
179
+ os: 'Windows',
180
+ browser: 'Chrome',
181
+ device: '',
182
+ system_locale: 'vi-VN',
183
+ browser_user_agent: UserAgent,
184
+ browser_version: '108.0.5359.215',
185
+ os_version: '10',
186
+ referrer: '',
187
+ referring_domain: '',
188
+ referrer_current: '',
189
+ referring_domain_current: '',
190
+ release_channel: 'stable',
191
+ client_build_number: 306208,
192
+ client_event_source: null,
193
+ },
194
+ compress: false,
195
+ client_state: {
196
+ guild_versions: {},
197
+ },
198
+ version: 9,
199
+ agent: {},
200
+ },
201
+ http: {
202
+ agent: {},
203
+ headers: {
204
+ 'User-Agent': UserAgent,
205
+ },
206
+ version: 9,
207
+ api: 'https://discord.com/api',
208
+ cdn: 'https://cdn.discordapp.com',
209
+ invite: 'https://discord.gg',
210
+ template: 'https://discord.new',
211
+ scheduledEvent: 'https://discord.com/events',
212
+ },
213
+ };
214
+ }
215
+
216
+ /**
217
+ * Create a cache factory using predefined settings to sweep or limit.
218
+ * @param {Object<string, LimitedCollectionOptions|number>} [settings={}] Settings passed to the relevant constructor.
219
+ * If no setting is provided for a manager, it uses Collection.
220
+ * If a number is provided for a manager, it uses that number as the max size for a LimitedCollection.
221
+ * If LimitedCollectionOptions are provided for a manager, it uses those settings to form a LimitedCollection.
222
+ * @returns {CacheFactory}
223
+ * @example
224
+ * // Store up to 200 messages per channel and discard archived threads if they were archived more than 4 hours ago.
225
+ * // Note archived threads will remain in the guild and client caches with these settings
226
+ * Options.cacheWithLimits({
227
+ * MessageManager: 200,
228
+ * ThreadManager: {
229
+ * sweepInterval: 3600,
230
+ * sweepFilter: LimitedCollection.filterByLifetime({
231
+ * getComparisonTimestamp: e => e.archiveTimestamp,
232
+ * excludeFromSweep: e => !e.archived,
233
+ * }),
234
+ * },
235
+ * });
236
+ * @example
237
+ * // Sweep messages every 5 minutes, removing messages that have not been edited or created in the last 30 minutes
238
+ * Options.cacheWithLimits({
239
+ * // Keep default thread sweeping behavior
240
+ * ...Options.defaultMakeCacheSettings,
241
+ * // Override MessageManager
242
+ * MessageManager: {
243
+ * sweepInterval: 300,
244
+ * sweepFilter: LimitedCollection.filterByLifetime({
245
+ * lifetime: 1800,
246
+ * getComparisonTimestamp: e => e.editedTimestamp ?? e.createdTimestamp,
247
+ * })
248
+ * }
249
+ * });
250
+ */
251
+ static cacheWithLimits(settings = {}) {
252
+ const { Collection } = require('@discordjs/collection');
253
+ const LimitedCollection = require('./LimitedCollection');
254
+
255
+ return manager => {
256
+ const setting = settings[manager.name];
257
+ /* eslint-disable-next-line eqeqeq */
258
+ if (setting == null) {
259
+ return new Collection();
260
+ }
261
+ if (typeof setting === 'number') {
262
+ if (setting === Infinity) {
263
+ return new Collection();
264
+ }
265
+ return new LimitedCollection({ maxSize: setting });
266
+ }
267
+ /* eslint-disable eqeqeq */
268
+ const noSweeping =
269
+ setting.sweepFilter == null ||
270
+ setting.sweepInterval == null ||
271
+ setting.sweepInterval <= 0 ||
272
+ setting.sweepInterval === Infinity;
273
+ const noLimit = setting.maxSize == null || setting.maxSize === Infinity;
274
+ /* eslint-enable eqeqeq */
275
+ if (noSweeping && noLimit) {
276
+ return new Collection();
277
+ }
278
+ return new LimitedCollection(setting);
279
+ };
280
+ }
281
+
282
+ /**
283
+ * Create a cache factory that always caches everything.
284
+ * @returns {CacheFactory}
285
+ */
286
+ static cacheEverything() {
287
+ const { Collection } = require('@discordjs/collection');
288
+ return () => new Collection();
289
+ }
290
+
291
+ /**
292
+ * The default settings passed to {@link ClientOptions.makeCache}.
293
+ * The caches that this changes are:
294
+ * * `MessageManager` - Limit to 200 messages
295
+ * * `ChannelManager` - Sweep archived threads
296
+ * * `GuildChannelManager` - Sweep archived threads
297
+ * * `ThreadManager` - Sweep archived threads
298
+ * <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.
299
+ * `makeCache: Options.cacheWithLimits({ ...Options.defaultMakeCacheSettings, ReactionManager: 0 })`</info>
300
+ * @type {Object<string, LimitedCollectionOptions|number>}
301
+ */
302
+ static get defaultMakeCacheSettings() {
303
+ return {
304
+ MessageManager: 200,
305
+ ChannelManager: {
306
+ sweepInterval: 3600,
307
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
308
+ },
309
+ GuildChannelManager: {
310
+ sweepInterval: 3600,
311
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
312
+ },
313
+ ThreadManager: {
314
+ sweepInterval: 3600,
315
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
316
+ },
317
+ };
318
+ }
319
+ }
320
+
321
+ /**
322
+ * The default settings passed to {@link ClientOptions.sweepers}.
323
+ * The sweepers that this changes are:
324
+ * * `threads` - Sweep archived threads every hour, removing those archived more than 4 hours ago
325
+ * <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.
326
+ * `sweepers: { ...Options.defaultSweeperSettings, messages: { interval: 300, lifetime: 600 } }`</info>
327
+ * @type {SweeperOptions}
328
+ */
329
+ Options.defaultSweeperSettings = {
330
+ threads: {
331
+ interval: 3600,
332
+ lifetime: 14400,
333
+ },
334
+ };
335
+
336
+ 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;