discord-selfbot-v13.js 0.0.1-security → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of discord-selfbot-v13.js might be problematic. Click here for more details.

Files changed (351) hide show
  1. package/LICENSE +674 -0
  2. package/README.md +128 -5
  3. package/package.json +98 -3
  4. package/src/WebSocket.js +39 -0
  5. package/src/client/BaseClient.js +87 -0
  6. package/src/client/Client.js +1124 -0
  7. package/src/client/WebhookClient.js +61 -0
  8. package/src/client/actions/Action.js +120 -0
  9. package/src/client/actions/ActionsManager.js +78 -0
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  11. package/src/client/actions/AutoModerationActionExecution.js +26 -0
  12. package/src/client/actions/AutoModerationRuleCreate.js +27 -0
  13. package/src/client/actions/AutoModerationRuleDelete.js +31 -0
  14. package/src/client/actions/AutoModerationRuleUpdate.js +29 -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/InteractionCreate.js +115 -0
  45. package/src/client/actions/InviteCreate.js +28 -0
  46. package/src/client/actions/InviteDelete.js +30 -0
  47. package/src/client/actions/MessageCreate.js +61 -0
  48. package/src/client/actions/MessageDelete.js +32 -0
  49. package/src/client/actions/MessageDeleteBulk.js +46 -0
  50. package/src/client/actions/MessageReactionAdd.js +56 -0
  51. package/src/client/actions/MessageReactionRemove.js +45 -0
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  54. package/src/client/actions/MessageUpdate.js +26 -0
  55. package/src/client/actions/PresenceUpdate.js +45 -0
  56. package/src/client/actions/StageInstanceCreate.js +28 -0
  57. package/src/client/actions/StageInstanceDelete.js +33 -0
  58. package/src/client/actions/StageInstanceUpdate.js +30 -0
  59. package/src/client/actions/ThreadCreate.js +24 -0
  60. package/src/client/actions/ThreadDelete.js +32 -0
  61. package/src/client/actions/ThreadListSync.js +59 -0
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  64. package/src/client/actions/TypingStart.js +29 -0
  65. package/src/client/actions/UserUpdate.js +35 -0
  66. package/src/client/actions/VoiceStateUpdate.js +57 -0
  67. package/src/client/actions/WebhooksUpdate.js +20 -0
  68. package/src/client/voice/ClientVoiceManager.js +51 -0
  69. package/src/client/websocket/WebSocketManager.js +412 -0
  70. package/src/client/websocket/WebSocketShard.js +905 -0
  71. package/src/client/websocket/handlers/APPLICATION_COMMAND_AUTOCOMPLETE_RESPONSE.js +23 -0
  72. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  73. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  74. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  75. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  76. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  77. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  78. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  79. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  80. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  81. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  82. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  83. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  84. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  85. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  86. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +16 -0
  87. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  88. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  89. package/src/client/websocket/handlers/GUILD_APPLICATION_COMMANDS_UPDATE.js +11 -0
  90. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  91. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  92. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  93. package/src/client/websocket/handlers/GUILD_CREATE.js +53 -0
  94. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  95. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  96. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  97. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  98. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  99. package/src/client/websocket/handlers/GUILD_MEMBER_LIST_UPDATE.js +55 -0
  100. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  101. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  102. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  103. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  104. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  105. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  106. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  107. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  108. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  109. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  110. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUNDS_UPDATE.js +0 -0
  111. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_CREATE.js +0 -0
  112. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_DELETE.js +0 -0
  113. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_UPDATE.js +0 -0
  114. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  115. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  116. package/src/client/websocket/handlers/INTERACTION_CREATE.js +16 -0
  117. package/src/client/websocket/handlers/INTERACTION_FAILURE.js +18 -0
  118. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +11 -0
  119. package/src/client/websocket/handlers/INTERACTION_SUCCESS.js +30 -0
  120. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  121. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  122. package/src/client/websocket/handlers/MESSAGE_ACK.js +16 -0
  123. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  124. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  125. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  126. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
  127. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  128. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  129. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  130. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  131. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  132. package/src/client/websocket/handlers/READY.js +171 -0
  133. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +17 -0
  134. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +15 -0
  135. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +18 -0
  136. package/src/client/websocket/handlers/RESUMED.js +14 -0
  137. package/src/client/websocket/handlers/SOUNDBOARD_SOUNDS.js +0 -0
  138. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  139. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  140. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  141. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  142. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  143. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  144. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  145. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  146. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  147. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  148. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +12 -0
  149. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  150. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +5 -0
  151. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +9 -0
  152. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  153. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +0 -0
  154. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  155. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  156. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  157. package/src/client/websocket/handlers/index.js +87 -0
  158. package/src/errors/DJSError.js +61 -0
  159. package/src/errors/Messages.js +228 -0
  160. package/src/errors/index.js +4 -0
  161. package/src/index.js +194 -0
  162. package/src/managers/ApplicationCommandManager.js +267 -0
  163. package/src/managers/ApplicationCommandPermissionsManager.js +425 -0
  164. package/src/managers/AutoModerationRuleManager.js +296 -0
  165. package/src/managers/BaseGuildEmojiManager.js +80 -0
  166. package/src/managers/BaseManager.js +19 -0
  167. package/src/managers/BillingManager.js +66 -0
  168. package/src/managers/CachedManager.js +71 -0
  169. package/src/managers/ChannelManager.js +139 -0
  170. package/src/managers/ClientUserSettingManager.js +490 -0
  171. package/src/managers/DataManager.js +61 -0
  172. package/src/managers/DeveloperPortalManager.js +104 -0
  173. package/src/managers/GuildApplicationCommandManager.js +28 -0
  174. package/src/managers/GuildBanManager.js +204 -0
  175. package/src/managers/GuildChannelManager.js +504 -0
  176. package/src/managers/GuildEmojiManager.js +171 -0
  177. package/src/managers/GuildEmojiRoleManager.js +118 -0
  178. package/src/managers/GuildFolderManager.js +24 -0
  179. package/src/managers/GuildForumThreadManager.js +114 -0
  180. package/src/managers/GuildInviteManager.js +213 -0
  181. package/src/managers/GuildManager.js +304 -0
  182. package/src/managers/GuildMemberManager.js +772 -0
  183. package/src/managers/GuildMemberRoleManager.js +191 -0
  184. package/src/managers/GuildScheduledEventManager.js +296 -0
  185. package/src/managers/GuildSettingManager.js +148 -0
  186. package/src/managers/GuildStickerManager.js +179 -0
  187. package/src/managers/GuildTextThreadManager.js +98 -0
  188. package/src/managers/InteractionManager.js +39 -0
  189. package/src/managers/MessageManager.js +393 -0
  190. package/src/managers/PermissionOverwriteManager.js +166 -0
  191. package/src/managers/PresenceManager.js +58 -0
  192. package/src/managers/ReactionManager.js +67 -0
  193. package/src/managers/ReactionUserManager.js +71 -0
  194. package/src/managers/RelationshipManager.js +258 -0
  195. package/src/managers/RoleManager.js +352 -0
  196. package/src/managers/SessionManager.js +57 -0
  197. package/src/managers/StageInstanceManager.js +162 -0
  198. package/src/managers/ThreadManager.js +207 -0
  199. package/src/managers/ThreadMemberManager.js +186 -0
  200. package/src/managers/UserManager.js +150 -0
  201. package/src/managers/VoiceStateManager.js +37 -0
  202. package/src/rest/APIRequest.js +133 -0
  203. package/src/rest/APIRouter.js +53 -0
  204. package/src/rest/CaptchaSolver.js +139 -0
  205. package/src/rest/DiscordAPIError.js +103 -0
  206. package/src/rest/HTTPError.js +62 -0
  207. package/src/rest/RESTManager.js +82 -0
  208. package/src/rest/RateLimitError.js +55 -0
  209. package/src/rest/RequestHandler.js +430 -0
  210. package/src/sharding/Shard.js +443 -0
  211. package/src/sharding/ShardClientUtil.js +275 -0
  212. package/src/sharding/ShardingManager.js +318 -0
  213. package/src/structures/AnonymousGuild.js +98 -0
  214. package/src/structures/ApplicationCommand.js +1030 -0
  215. package/src/structures/ApplicationRoleConnectionMetadata.js +45 -0
  216. package/src/structures/AutoModerationActionExecution.js +89 -0
  217. package/src/structures/AutoModerationRule.js +294 -0
  218. package/src/structures/AutocompleteInteraction.js +106 -0
  219. package/src/structures/Base.js +43 -0
  220. package/src/structures/BaseCommandInteraction.js +211 -0
  221. package/src/structures/BaseGuild.js +116 -0
  222. package/src/structures/BaseGuildEmoji.js +56 -0
  223. package/src/structures/BaseGuildTextChannel.js +203 -0
  224. package/src/structures/BaseGuildVoiceChannel.js +243 -0
  225. package/src/structures/BaseMessageComponent.js +114 -0
  226. package/src/structures/ButtonInteraction.js +11 -0
  227. package/src/structures/Call.js +58 -0
  228. package/src/structures/CategoryChannel.js +85 -0
  229. package/src/structures/Channel.js +271 -0
  230. package/src/structures/ClientApplication.js +233 -0
  231. package/src/structures/ClientPresence.js +92 -0
  232. package/src/structures/ClientUser.js +635 -0
  233. package/src/structures/CommandInteraction.js +41 -0
  234. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  235. package/src/structures/ContextMenuInteraction.js +65 -0
  236. package/src/structures/DMChannel.js +289 -0
  237. package/src/structures/DeveloperPortalApplication.js +520 -0
  238. package/src/structures/DirectoryChannel.js +20 -0
  239. package/src/structures/Emoji.js +148 -0
  240. package/src/structures/ForumChannel.js +271 -0
  241. package/src/structures/Guild.js +1744 -0
  242. package/src/structures/GuildAuditLogs.js +734 -0
  243. package/src/structures/GuildBan.js +59 -0
  244. package/src/structures/GuildBoost.js +108 -0
  245. package/src/structures/GuildChannel.js +468 -0
  246. package/src/structures/GuildEmoji.js +161 -0
  247. package/src/structures/GuildFolder.js +75 -0
  248. package/src/structures/GuildMember.js +686 -0
  249. package/src/structures/GuildPreview.js +191 -0
  250. package/src/structures/GuildPreviewEmoji.js +27 -0
  251. package/src/structures/GuildScheduledEvent.js +441 -0
  252. package/src/structures/GuildTemplate.js +236 -0
  253. package/src/structures/Integration.js +188 -0
  254. package/src/structures/IntegrationApplication.js +96 -0
  255. package/src/structures/Interaction.js +351 -0
  256. package/src/structures/InteractionCollector.js +248 -0
  257. package/src/structures/InteractionResponse.js +114 -0
  258. package/src/structures/InteractionWebhook.js +43 -0
  259. package/src/structures/Invite.js +375 -0
  260. package/src/structures/InviteGuild.js +23 -0
  261. package/src/structures/InviteStageInstance.js +86 -0
  262. package/src/structures/Message.js +1188 -0
  263. package/src/structures/MessageActionRow.js +103 -0
  264. package/src/structures/MessageAttachment.js +204 -0
  265. package/src/structures/MessageButton.js +231 -0
  266. package/src/structures/MessageCollector.js +146 -0
  267. package/src/structures/MessageComponentInteraction.js +120 -0
  268. package/src/structures/MessageContextMenuInteraction.js +20 -0
  269. package/src/structures/MessageEmbed.js +586 -0
  270. package/src/structures/MessageMentions.js +272 -0
  271. package/src/structures/MessagePayload.js +358 -0
  272. package/src/structures/MessageReaction.js +171 -0
  273. package/src/structures/MessageSelectMenu.js +391 -0
  274. package/src/structures/Modal.js +279 -0
  275. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  276. package/src/structures/ModalSubmitInteraction.js +119 -0
  277. package/src/structures/NewsChannel.js +32 -0
  278. package/src/structures/OAuth2Guild.js +28 -0
  279. package/src/structures/PartialGroupDMChannel.js +449 -0
  280. package/src/structures/PermissionOverwrites.js +196 -0
  281. package/src/structures/Presence.js +443 -0
  282. package/src/structures/ReactionCollector.js +229 -0
  283. package/src/structures/ReactionEmoji.js +31 -0
  284. package/src/structures/RichPresence.js +722 -0
  285. package/src/structures/Role.js +531 -0
  286. package/src/structures/SelectMenuInteraction.js +170 -0
  287. package/src/structures/Session.js +81 -0
  288. package/src/structures/StageChannel.js +104 -0
  289. package/src/structures/StageInstance.js +208 -0
  290. package/src/structures/Sticker.js +310 -0
  291. package/src/structures/StickerPack.js +95 -0
  292. package/src/structures/StoreChannel.js +56 -0
  293. package/src/structures/Team.js +167 -0
  294. package/src/structures/TeamMember.js +71 -0
  295. package/src/structures/TextChannel.js +33 -0
  296. package/src/structures/TextInputComponent.js +201 -0
  297. package/src/structures/ThreadChannel.js +626 -0
  298. package/src/structures/ThreadMember.js +105 -0
  299. package/src/structures/Typing.js +74 -0
  300. package/src/structures/User.js +730 -0
  301. package/src/structures/UserContextMenuInteraction.js +29 -0
  302. package/src/structures/VoiceChannel.js +110 -0
  303. package/src/structures/VoiceRegion.js +53 -0
  304. package/src/structures/VoiceState.js +353 -0
  305. package/src/structures/WebEmbed.js +412 -0
  306. package/src/structures/Webhook.js +461 -0
  307. package/src/structures/WelcomeChannel.js +60 -0
  308. package/src/structures/WelcomeScreen.js +48 -0
  309. package/src/structures/Widget.js +87 -0
  310. package/src/structures/WidgetMember.js +99 -0
  311. package/src/structures/interfaces/Application.js +190 -0
  312. package/src/structures/interfaces/Collector.js +300 -0
  313. package/src/structures/interfaces/InteractionResponses.js +313 -0
  314. package/src/structures/interfaces/TextBasedChannel.js +566 -0
  315. package/src/util/ActivityFlags.js +44 -0
  316. package/src/util/ApplicationFlags.js +76 -0
  317. package/src/util/AttachmentFlags.js +38 -0
  318. package/src/util/BitField.js +170 -0
  319. package/src/util/ChannelFlags.js +45 -0
  320. package/src/util/Constants.js +1940 -0
  321. package/src/util/DataResolver.js +145 -0
  322. package/src/util/Formatters.js +214 -0
  323. package/src/util/GuildMemberFlags.js +43 -0
  324. package/src/util/Intents.js +74 -0
  325. package/src/util/LimitedCollection.js +131 -0
  326. package/src/util/MessageFlags.js +54 -0
  327. package/src/util/Options.js +364 -0
  328. package/src/util/Permissions.js +187 -0
  329. package/src/util/PremiumUsageFlags.js +31 -0
  330. package/src/util/PurchasedFlags.js +31 -0
  331. package/src/util/RemoteAuth.js +514 -0
  332. package/src/util/RoleFlags.js +37 -0
  333. package/src/util/SnowflakeUtil.js +92 -0
  334. package/src/util/Sweepers.js +466 -0
  335. package/src/util/SystemChannelFlags.js +55 -0
  336. package/src/util/ThreadMemberFlags.js +30 -0
  337. package/src/util/UserFlags.js +104 -0
  338. package/src/util/Util.js +882 -0
  339. package/src/util/Voice.js +1456 -0
  340. package/src/util/arRPC/index.js +229 -0
  341. package/src/util/arRPC/process/detectable.json +1 -0
  342. package/src/util/arRPC/process/index.js +102 -0
  343. package/src/util/arRPC/process/native/index.js +5 -0
  344. package/src/util/arRPC/process/native/linux.js +37 -0
  345. package/src/util/arRPC/process/native/win32.js +25 -0
  346. package/src/util/arRPC/transports/ipc.js +281 -0
  347. package/src/util/arRPC/transports/websocket.js +128 -0
  348. package/typings/enums.d.ts +346 -0
  349. package/typings/index.d.ts +7776 -0
  350. package/typings/index.test-d.ts +0 -0
  351. package/typings/rawDataTypes.d.ts +283 -0
@@ -0,0 +1,364 @@
1
+ 'use strict';
2
+
3
+ const JSONBig = require('json-bigint');
4
+ const Intents = require('./Intents');
5
+ const { defaultUA } = require('../util/Constants');
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
+ * Options for a client.
33
+ * @typedef {Object} ClientOptions
34
+ * @property {number|number[]|string} [shards] The shard's id to run, or an array of shard ids. If not specified,
35
+ * the client will spawn {@link ClientOptions#shardCount} shards. If set to `auto`, it will fetch the
36
+ * recommended amount of shards from Discord and spawn that amount
37
+ * @property {number} [closeTimeout=5000] The amount of time in milliseconds to wait for the close frame to be received
38
+ * from the WebSocket. Don't have this too high/low. Its best to have it between 2_000-6_000 ms.
39
+ * @property {boolean} [checkUpdate=true] Display module update information on the screen
40
+ * @property {boolean} [syncStatus=true] Sync state with Discord Client
41
+ * @property {boolean} [patchVoice=false] Automatically patch @discordjs/voice module (support for call)
42
+ * @property {string} [captchaService=null] Captcha service to use for solving captcha {@link captchaServices}
43
+ * @property {string} [captchaKey=null] Captcha service key
44
+ * @property {string} [captchaRetryLimit=3] Captcha retry limit
45
+ * @property {string} [captchaWithProxy=false] Whether to use proxy for captcha solving
46
+ * @property {string} [password=null] Your Discord account password
47
+ * @property {boolean} [usingNewAttachmentAPI=true] Use new attachment API
48
+ * @property {string} [interactionTimeout=15000] The amount of time in milliseconds to wait for an interaction response, before rejecting
49
+ * @property {boolean} [autoRedeemNitro=false] Automaticlly redeems nitro codes <NOTE: there is no cooldown on the auto redeem>
50
+ * @property {string} [proxy] Proxy to use for the WebSocket + REST connection (proxy-agent uri type) {@link https://www.npmjs.com/package/proxy-agent}.
51
+ * @property {boolean} [DMSync=false] Automatically synchronize call status (DM and group) at startup (event synchronization) [Warning: May cause rate limit to gateway)
52
+ * @property {number} [shardCount=1] The total amount of shards used by all processes of this bot
53
+ * (e.g. recommended shard count, shard count of the ShardingManager)
54
+ * @property {CacheFactory} [makeCache] Function to create a cache.
55
+ * You can use your own function, or the {@link Options} class to customize the Collection used for the cache.
56
+ * <warn>Overriding the cache used in `GuildManager`, `ChannelManager`, `GuildChannelManager`, `RoleManager`,
57
+ * and `PermissionOverwriteManager` is unsupported and **will** break functionality</warn>
58
+ * @property {number} [messageCacheLifetime=0] DEPRECATED: Pass `lifetime` to `sweepers.messages` instead.
59
+ * How long a message should stay in the cache until it is considered sweepable (in seconds, 0 for forever)
60
+ * @property {number} [messageSweepInterval=0] DEPRECATED: Pass `interval` to `sweepers.messages` instead.
61
+ * How frequently to remove messages from the cache that are older than the message cache lifetime
62
+ * (in seconds, 0 for never)
63
+ * @property {MessageMentionOptions} [allowedMentions] Default value for {@link MessageOptions#allowedMentions}
64
+ * @property {number} [invalidRequestWarningInterval=0] The number of invalid REST requests (those that return
65
+ * 401, 403, or 429) in a 10 minute window between emitted warnings (0 for no warnings). That is, if set to 500,
66
+ * warnings will be emitted at invalid request number 500, 1000, 1500, and so on.
67
+ * @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
68
+ * they're missing all the data for a particular structure. See the "Partial Structures" topic on the
69
+ * [guide](https://discordjs.guide/popular-topics/partials.html) for some
70
+ * important usage information, as partials require you to put checks in place when handling data.
71
+ * @property {number} [restWsBridgeTimeout=5000] Maximum time permitted between REST responses and their
72
+ * corresponding WebSocket events
73
+ * @property {number} [restTimeOffset=500] Extra time in milliseconds to wait before continuing to make REST
74
+ * requests (higher values will reduce rate-limiting errors on bad connections)
75
+ * @property {number} [restRequestTimeout=15000] Time to wait before cancelling a REST request, in milliseconds
76
+ * @property {number} [restSweepInterval=60] How frequently to delete inactive request buckets, in seconds
77
+ * (or 0 for never)
78
+ * @property {number} [restGlobalRateLimit=0] How many requests to allow sending per second (0 for unlimited, 50 for
79
+ * the standard global limit used by Discord)
80
+ * @property {string[]|RateLimitQueueFilter} [rejectOnRateLimit] Decides how rate limits and pre-emptive throttles
81
+ * should be handled. If this option is an array containing the prefix of the request route (e.g. /channels to match any
82
+ * route starting with /channels, such as /channels/222197033908436994/messages) or a function returning true, a
83
+ * {@link RateLimitError} will be thrown. Otherwise the request will be queued for later
84
+ * @property {number} [retryLimit=1] How many times to retry on 5XX errors
85
+ * (Infinity for an indefinite amount of retries)
86
+ * @property {boolean} [failIfNotExists=true] Default value for {@link ReplyMessageOptions#failIfNotExists}
87
+ * @property {string[]} [userAgentSuffix] An array of additional bot info to be appended to the end of the required
88
+ * [User Agent](https://discord.com/developers/docs/reference#user-agent) header
89
+ * @property {PresenceData} [presence={}] Presence data to use upon login
90
+ * @property {IntentsResolvable} [intents=131071] Intents to enable for this connection (but not using)
91
+ * @property {number} [waitGuildTimeout=15000] Time in milliseconds that Clients with the GUILDS intent should wait for
92
+ * @property {number} [messageCreateEventGuildTimeout=100] Time in milliseconds that Clients to register for messages with each guild
93
+ * missing guilds to be received before starting the bot. If not specified, the default is 100 milliseconds.
94
+ * @property {SweeperOptions} [sweepers={}] Options for cache sweeping
95
+ * @property {WebsocketOptions} [ws] Options for the WebSocket
96
+ * @property {HTTPOptions} [http] HTTP options
97
+ * @property {CustomCaptchaSolver} [captchaSolver] Function to solve a captcha (custom)
98
+ */
99
+
100
+ /**
101
+ * Function to solve a captcha
102
+ * @typedef {function} CustomCaptchaSolver
103
+ * @param {Captcha} captcha The captcha to solve
104
+ * @param {string} userAgent The user agent to use for the request
105
+ * @returns {Promise<string>} hcaptcha token
106
+ */
107
+
108
+ /**
109
+ * Options for {@link Sweepers} defining the behavior of cache sweeping
110
+ * @typedef {Object<SweeperKey, SweepOptions>} SweeperOptions
111
+ */
112
+
113
+ /**
114
+ * Options for sweeping a single type of item from cache
115
+ * @typedef {Object} SweepOptions
116
+ * @property {number} interval The interval (in seconds) at which to perform sweeping of the item
117
+ * @property {number} [lifetime] How long an item should stay in cache until it is considered sweepable.
118
+ * <warn>This property is only valid for the `invites`, `messages`, and `threads` keys. The `filter` property
119
+ * is mutually exclusive to this property and takes priority</warn>
120
+ * @property {GlobalSweepFilter} filter The function used to determine the function passed to the sweep method
121
+ * <info>This property is optional when the key is `invites`, `messages`, or `threads` and `lifetime` is set</info>
122
+ */
123
+
124
+ /**
125
+ * WebSocket options (these are left as snake_case to match the API)
126
+ * @typedef {Object} WebsocketOptions
127
+ * @property {boolean} [compress=false] Whether to compress data sent on the connection
128
+ * @property {WebSocketProperties} [properties] Properties to identify the client with
129
+ */
130
+
131
+ /**
132
+ * HTTPS Agent options.
133
+ * @typedef {Object} AgentOptions
134
+ * @see {@link https://nodejs.org/api/https.html#https_class_https_agent}
135
+ * @see {@link https://nodejs.org/api/http.html#http_new_agent_options}
136
+ */
137
+
138
+ /**
139
+ * HTTP options
140
+ * @typedef {Object} HTTPOptions
141
+ * @property {number} [version=9] API version to use
142
+ * @property {AgentOptions} [agent={}] HTTPS Agent options
143
+ * @property {string} [api='https://discord.com/api'] Base URL of the API
144
+ * @property {string} [cdn='https://cdn.discordapp.com'] Base URL of the CDN
145
+ * @property {string} [invite='https://discord.gg'] Base URL of invites
146
+ * @property {string} [template='https://discord.new'] Base URL of templates
147
+ * @property {Object} [headers] Additional headers to send for all API requests
148
+ * @property {string} [scheduledEvent='https://discord.com/events'] Base URL of guild scheduled events
149
+ */
150
+
151
+ /**
152
+ * Contains various utilities for client options.
153
+ */
154
+ class Options extends null {
155
+ /**
156
+ * The default client options.
157
+ * @returns {ClientOptions}
158
+ */
159
+ static createDefault() {
160
+ return {
161
+ jsonTransformer: object => JSONBig.stringify(object),
162
+ captchaSolver: captcha => Promise.reject(new Error('CAPTCHA_SOLVER_NOT_IMPLEMENTED', captcha)),
163
+ closeTimeout: 5_000,
164
+ checkUpdate: true,
165
+ syncStatus: true,
166
+ autoRedeemNitro: false,
167
+ captchaService: '',
168
+ captchaKey: null,
169
+ captchaRetryLimit: 3,
170
+ captchaWithProxy: false,
171
+ DMSync: false,
172
+ patchVoice: false,
173
+ password: null,
174
+ usingNewAttachmentAPI: true,
175
+ interactionTimeout: 15_000,
176
+ waitGuildTimeout: 15_000,
177
+ messageCreateEventGuildTimeout: 100,
178
+ shardCount: 1,
179
+ makeCache: this.cacheWithLimits(this.defaultMakeCacheSettings),
180
+ messageCacheLifetime: 0,
181
+ messageSweepInterval: 0,
182
+ invalidRequestWarningInterval: 0,
183
+ intents: Intents.ALL,
184
+ partials: ['USER', 'CHANNEL', 'GUILD_MEMBER', 'MESSAGE', 'REACTION', 'GUILD_SCHEDULED_EVENT'], // Enable the partials
185
+ restWsBridgeTimeout: 5_000,
186
+ restRequestTimeout: 15_000,
187
+ restGlobalRateLimit: 0,
188
+ retryLimit: 1,
189
+ restTimeOffset: 500,
190
+ restSweepInterval: 60,
191
+ failIfNotExists: false,
192
+ userAgentSuffix: [],
193
+ presence: { status: 'online', since: 0, activities: [], afk: false },
194
+ sweepers: {},
195
+ proxy: '',
196
+ ws: {
197
+ // eslint-disable-next-line no-undef
198
+ capabilities: 0, // https://discord-userdoccers.vercel.app/topics/gateway#gateway-capabilities
199
+ properties: {
200
+ os: 'Windows',
201
+ browser: 'Discord Client',
202
+ release_channel: 'stable',
203
+ client_version: '1.0.9023',
204
+ os_version: '10.0.19045',
205
+ os_arch: 'x64',
206
+ app_arch: 'ia32',
207
+ system_locale: 'en-US',
208
+ browser_user_agent: defaultUA,
209
+ browser_version: '22.3.26',
210
+ client_build_number: 244874,
211
+ native_build_number: 39515,
212
+ client_event_source: null,
213
+ design_id: 0,
214
+ },
215
+ compress: false,
216
+ client_state: {
217
+ guild_versions: {},
218
+ highest_last_message_id: '0',
219
+ read_state_version: 0,
220
+ user_guild_settings_version: -1,
221
+ user_settings_version: -1,
222
+ private_channels_version: '0',
223
+ api_code_version: 0,
224
+ },
225
+ version: 9,
226
+ },
227
+ http: {
228
+ agent: {},
229
+ headers: {
230
+ 'User-Agent': defaultUA,
231
+ },
232
+ version: 9,
233
+ api: 'https://discord.com/api',
234
+ cdn: 'https://cdn.discordapp.com',
235
+ invite: 'https://discord.gg',
236
+ template: 'https://discord.new',
237
+ scheduledEvent: 'https://discord.com/events',
238
+ },
239
+ };
240
+ }
241
+
242
+ /**
243
+ * Create a cache factory using predefined settings to sweep or limit.
244
+ * @param {Object<string, LimitedCollectionOptions|number>} [settings={}] Settings passed to the relevant constructor.
245
+ * If no setting is provided for a manager, it uses Collection.
246
+ * If a number is provided for a manager, it uses that number as the max size for a LimitedCollection.
247
+ * If LimitedCollectionOptions are provided for a manager, it uses those settings to form a LimitedCollection.
248
+ * @returns {CacheFactory}
249
+ * @example
250
+ * // Store up to 200 messages per channel and discard archived threads if they were archived more than 4 hours ago.
251
+ * // Note archived threads will remain in the guild and client caches with these settings
252
+ * Options.cacheWithLimits({
253
+ * MessageManager: 200,
254
+ * ThreadManager: {
255
+ * sweepInterval: 3600,
256
+ * sweepFilter: LimitedCollection.filterByLifetime({
257
+ * getComparisonTimestamp: e => e.archiveTimestamp,
258
+ * excludeFromSweep: e => !e.archived,
259
+ * }),
260
+ * },
261
+ * });
262
+ * @example
263
+ * // Sweep messages every 5 minutes, removing messages that have not been edited or created in the last 30 minutes
264
+ * Options.cacheWithLimits({
265
+ * // Keep default thread sweeping behavior
266
+ * ...Options.defaultMakeCacheSettings,
267
+ * // Override MessageManager
268
+ * MessageManager: {
269
+ * sweepInterval: 300,
270
+ * sweepFilter: LimitedCollection.filterByLifetime({
271
+ * lifetime: 1800,
272
+ * getComparisonTimestamp: e => e.editedTimestamp ?? e.createdTimestamp,
273
+ * })
274
+ * }
275
+ * });
276
+ */
277
+ static cacheWithLimits(settings = {}) {
278
+ const { Collection } = require('@discordjs/collection');
279
+ const LimitedCollection = require('./LimitedCollection');
280
+
281
+ return manager => {
282
+ const setting = settings[manager.name];
283
+ /* eslint-disable-next-line eqeqeq */
284
+ if (setting == null) {
285
+ return new Collection();
286
+ }
287
+ if (typeof setting === 'number') {
288
+ if (setting === Infinity) {
289
+ return new Collection();
290
+ }
291
+ return new LimitedCollection({ maxSize: setting });
292
+ }
293
+ /* eslint-disable eqeqeq */
294
+ const noSweeping =
295
+ setting.sweepFilter == null ||
296
+ setting.sweepInterval == null ||
297
+ setting.sweepInterval <= 0 ||
298
+ setting.sweepInterval === Infinity;
299
+ const noLimit = setting.maxSize == null || setting.maxSize === Infinity;
300
+ /* eslint-enable eqeqeq */
301
+ if (noSweeping && noLimit) {
302
+ return new Collection();
303
+ }
304
+ return new LimitedCollection(setting);
305
+ };
306
+ }
307
+
308
+ /**
309
+ * Create a cache factory that always caches everything.
310
+ * @returns {CacheFactory}
311
+ */
312
+ static cacheEverything() {
313
+ const { Collection } = require('@discordjs/collection');
314
+ return () => new Collection();
315
+ }
316
+
317
+ /**
318
+ * The default settings passed to {@link ClientOptions.makeCache}.
319
+ * The caches that this changes are:
320
+ * * `MessageManager` - Limit to 200 messages
321
+ * * `ChannelManager` - Sweep archived threads
322
+ * * `GuildChannelManager` - Sweep archived threads
323
+ * * `ThreadManager` - Sweep archived threads
324
+ * <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.
325
+ * `makeCache: Options.cacheWithLimits({ ...Options.defaultMakeCacheSettings, ReactionManager: 0 })`</info>
326
+ * @type {Object<string, LimitedCollectionOptions|number>}
327
+ */
328
+ static get defaultMakeCacheSettings() {
329
+ return {
330
+ MessageManager: 200,
331
+ /*
332
+ ChannelManager: {
333
+ sweepInterval: 3600,
334
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
335
+ },
336
+ GuildChannelManager: {
337
+ sweepInterval: 3600,
338
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
339
+ },
340
+ ThreadManager: {
341
+ sweepInterval: 3600,
342
+ sweepFilter: require('./Util').archivedThreadSweepFilter(),
343
+ },
344
+ */
345
+ };
346
+ }
347
+ }
348
+
349
+ /**
350
+ * The default settings passed to {@link ClientOptions.sweepers}.
351
+ * The sweepers that this changes are:
352
+ * * `threads` - Sweep archived threads every hour, removing those archived more than 4 hours ago
353
+ * <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.
354
+ * `sweepers: { ...Options.defaultSweeperSettings, messages: { interval: 300, lifetime: 600 } }`</info>
355
+ * @type {SweeperOptions}
356
+ */
357
+ Options.defaultSweeperSettings = {
358
+ threads: {
359
+ interval: 3600,
360
+ lifetime: 14400,
361
+ },
362
+ };
363
+
364
+ module.exports = Options;
@@ -0,0 +1,187 @@
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
+ * @type {Object<string, bigint>}
114
+ * @see {@link https://discord.com/developers/docs/topics/permissions#permissions-bitwise-permission-flags}
115
+ */
116
+ Permissions.FLAGS = {
117
+ CREATE_INSTANT_INVITE: 1n << 0n,
118
+ KICK_MEMBERS: 1n << 1n,
119
+ BAN_MEMBERS: 1n << 2n,
120
+ ADMINISTRATOR: 1n << 3n,
121
+ MANAGE_CHANNELS: 1n << 4n,
122
+ MANAGE_GUILD: 1n << 5n,
123
+ ADD_REACTIONS: 1n << 6n,
124
+ VIEW_AUDIT_LOG: 1n << 7n,
125
+ PRIORITY_SPEAKER: 1n << 8n,
126
+ STREAM: 1n << 9n,
127
+ VIEW_CHANNEL: 1n << 10n,
128
+ SEND_MESSAGES: 1n << 11n,
129
+ SEND_TTS_MESSAGES: 1n << 12n,
130
+ MANAGE_MESSAGES: 1n << 13n,
131
+ EMBED_LINKS: 1n << 14n,
132
+ ATTACH_FILES: 1n << 15n,
133
+ READ_MESSAGE_HISTORY: 1n << 16n,
134
+ MENTION_EVERYONE: 1n << 17n,
135
+ USE_EXTERNAL_EMOJIS: 1n << 18n,
136
+ VIEW_GUILD_INSIGHTS: 1n << 19n,
137
+ CONNECT: 1n << 20n,
138
+ SPEAK: 1n << 21n,
139
+ MUTE_MEMBERS: 1n << 22n,
140
+ DEAFEN_MEMBERS: 1n << 23n,
141
+ MOVE_MEMBERS: 1n << 24n,
142
+ USE_VAD: 1n << 25n,
143
+ CHANGE_NICKNAME: 1n << 26n,
144
+ MANAGE_NICKNAMES: 1n << 27n,
145
+ MANAGE_ROLES: 1n << 28n,
146
+ MANAGE_WEBHOOKS: 1n << 29n,
147
+ MANAGE_EMOJIS_AND_STICKERS: 1n << 30n,
148
+ USE_APPLICATION_COMMANDS: 1n << 31n,
149
+ REQUEST_TO_SPEAK: 1n << 32n,
150
+ MANAGE_EVENTS: 1n << 33n,
151
+ MANAGE_THREADS: 1n << 34n,
152
+ // TODO: Remove deprecated USE_*_THREADS flags in v14
153
+ USE_PUBLIC_THREADS: 1n << 35n,
154
+ CREATE_PUBLIC_THREADS: 1n << 35n,
155
+ USE_PRIVATE_THREADS: 1n << 36n,
156
+ CREATE_PRIVATE_THREADS: 1n << 36n,
157
+ USE_EXTERNAL_STICKERS: 1n << 37n,
158
+ SEND_MESSAGES_IN_THREADS: 1n << 38n,
159
+ START_EMBEDDED_ACTIVITIES: 1n << 39n,
160
+ MODERATE_MEMBERS: 1n << 40n,
161
+ VIEW_CREATOR_MONETIZATION_ANALYTICS: 1n << 41n,
162
+ USE_SOUNDBOARD: 1n << 42n,
163
+ SEND_VOICE_MESSAGES: 1n << 46n,
164
+ };
165
+
166
+ /**
167
+ * Bitfield representing every permission combined
168
+ * @type {bigint}
169
+ */
170
+ Permissions.ALL = Object.values(Permissions.FLAGS).reduce((all, p) => all | p, 0n);
171
+
172
+ /**
173
+ * Bitfield representing the default permissions for users
174
+ * @type {bigint}
175
+ */
176
+ Permissions.DEFAULT = BigInt(104324673);
177
+
178
+ /**
179
+ * Bitfield representing the permissions required for moderators of stage channels
180
+ * @type {bigint}
181
+ */
182
+ Permissions.STAGE_MODERATOR =
183
+ Permissions.FLAGS.MANAGE_CHANNELS | Permissions.FLAGS.MUTE_MEMBERS | Permissions.FLAGS.MOVE_MEMBERS;
184
+
185
+ Permissions.defaultBit = BigInt(0);
186
+
187
+ 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,31 @@
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
+ * @type {Object}
24
+ */
25
+ PurchasedFlags.FLAGS = {
26
+ NITRO_CLASSIC: 1 << 0,
27
+ NITRO: 1 << 1,
28
+ GUILD_BOOST: 1 << 2,
29
+ };
30
+
31
+ module.exports = PurchasedFlags;