djs-selfbot-v13 3.1.8 → 3.7.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 (364) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +48 -37
  3. package/package.json +44 -26
  4. package/src/WebSocket.js +39 -39
  5. package/src/client/BaseClient.js +86 -86
  6. package/src/client/Client.js +934 -765
  7. package/src/client/WebhookClient.js +61 -61
  8. package/src/client/actions/Action.js +116 -120
  9. package/src/client/actions/ActionsManager.js +80 -78
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
  11. package/src/client/actions/AutoModerationActionExecution.js +27 -27
  12. package/src/client/actions/AutoModerationRuleCreate.js +28 -28
  13. package/src/client/actions/AutoModerationRuleDelete.js +32 -32
  14. package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
  15. package/src/client/actions/ChannelCreate.js +23 -23
  16. package/src/client/actions/ChannelDelete.js +39 -39
  17. package/src/client/actions/ChannelUpdate.js +43 -43
  18. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
  19. package/src/client/actions/GuildBanAdd.js +20 -20
  20. package/src/client/actions/GuildBanRemove.js +25 -25
  21. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
  22. package/src/client/actions/GuildDelete.js +65 -65
  23. package/src/client/actions/GuildEmojiCreate.js +20 -20
  24. package/src/client/actions/GuildEmojiDelete.js +21 -21
  25. package/src/client/actions/GuildEmojiUpdate.js +20 -20
  26. package/src/client/actions/GuildEmojisUpdate.js +34 -34
  27. package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
  28. package/src/client/actions/GuildMemberRemove.js +33 -33
  29. package/src/client/actions/GuildMemberUpdate.js +44 -44
  30. package/src/client/actions/GuildRoleCreate.js +25 -25
  31. package/src/client/actions/GuildRoleDelete.js +31 -31
  32. package/src/client/actions/GuildRoleUpdate.js +39 -39
  33. package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
  34. package/src/client/actions/GuildScheduledEventCreate.js +27 -27
  35. package/src/client/actions/GuildScheduledEventDelete.js +31 -31
  36. package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
  37. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
  38. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
  39. package/src/client/actions/GuildStickerCreate.js +20 -20
  40. package/src/client/actions/GuildStickerDelete.js +21 -21
  41. package/src/client/actions/GuildStickerUpdate.js +20 -20
  42. package/src/client/actions/GuildStickersUpdate.js +34 -34
  43. package/src/client/actions/GuildUpdate.js +33 -33
  44. package/src/client/actions/InviteCreate.js +28 -28
  45. package/src/client/actions/InviteDelete.js +30 -30
  46. package/src/client/actions/MessageCreate.js +50 -46
  47. package/src/client/actions/MessageDelete.js +32 -32
  48. package/src/client/actions/MessageDeleteBulk.js +46 -46
  49. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  50. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  51. package/src/client/actions/MessageReactionAdd.js +68 -56
  52. package/src/client/actions/MessageReactionRemove.js +50 -45
  53. package/src/client/actions/MessageReactionRemoveAll.js +33 -33
  54. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
  55. package/src/client/actions/MessageUpdate.js +26 -26
  56. package/src/client/actions/PresenceUpdate.js +50 -46
  57. package/src/client/actions/StageInstanceCreate.js +28 -28
  58. package/src/client/actions/StageInstanceDelete.js +33 -33
  59. package/src/client/actions/StageInstanceUpdate.js +30 -30
  60. package/src/client/actions/ThreadCreate.js +24 -24
  61. package/src/client/actions/ThreadDelete.js +32 -32
  62. package/src/client/actions/ThreadListSync.js +59 -59
  63. package/src/client/actions/ThreadMemberUpdate.js +30 -30
  64. package/src/client/actions/ThreadMembersUpdate.js +34 -34
  65. package/src/client/actions/TypingStart.js +29 -29
  66. package/src/client/actions/UserUpdate.js +35 -35
  67. package/src/client/actions/VoiceStateUpdate.js +50 -57
  68. package/src/client/actions/WebhooksUpdate.js +20 -20
  69. package/src/client/voice/ClientVoiceManager.js +151 -51
  70. package/src/client/voice/VoiceConnection.js +1249 -0
  71. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  72. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  73. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  74. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  75. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  76. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  77. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  78. package/src/client/voice/player/MediaPlayer.js +321 -0
  79. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  80. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  81. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  82. package/src/client/voice/receiver/PacketHandler.js +260 -0
  83. package/src/client/voice/receiver/Receiver.js +96 -0
  84. package/src/client/voice/receiver/Recorder.js +173 -0
  85. package/src/client/voice/util/Function.js +116 -0
  86. package/src/client/voice/util/PlayInterface.js +122 -0
  87. package/src/client/voice/util/Secretbox.js +64 -0
  88. package/src/client/voice/util/Silence.js +16 -0
  89. package/src/client/voice/util/Socket.js +62 -0
  90. package/src/client/voice/util/VolumeInterface.js +104 -0
  91. package/src/client/websocket/WebSocketManager.js +392 -392
  92. package/src/client/websocket/WebSocketShard.js +907 -906
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
  96. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
  97. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
  100. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
  101. package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
  102. package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
  103. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
  104. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
  105. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
  106. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
  108. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
  109. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
  110. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
  111. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
  112. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
  113. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -53
  114. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
  115. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
  116. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
  117. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
  118. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -20
  119. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
  120. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
  121. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
  122. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
  123. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
  128. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
  129. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
  130. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
  131. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
  132. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
  133. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
  134. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
  135. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
  136. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -0
  138. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -0
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
  142. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
  143. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
  144. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
  145. package/src/client/websocket/handlers/READY.js +121 -80
  146. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
  147. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
  148. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
  149. package/src/client/websocket/handlers/RESUMED.js +14 -14
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
  152. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
  153. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
  154. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
  155. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
  156. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
  157. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
  158. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
  159. package/src/client/websocket/handlers/TYPING_START.js +5 -5
  160. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
  161. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
  162. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
  163. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
  164. package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  166. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
  167. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
  168. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
  169. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
  170. package/src/client/websocket/handlers/index.js +84 -81
  171. package/src/errors/DJSError.js +61 -61
  172. package/src/errors/Messages.js +217 -182
  173. package/src/errors/index.js +4 -4
  174. package/src/index.js +172 -158
  175. package/src/managers/ApplicationCommandManager.js +264 -264
  176. package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
  177. package/src/managers/AutoModerationRuleManager.js +296 -296
  178. package/src/managers/BaseGuildEmojiManager.js +80 -80
  179. package/src/managers/BaseManager.js +19 -19
  180. package/src/managers/BillingManager.js +66 -66
  181. package/src/managers/CachedManager.js +71 -71
  182. package/src/managers/ChannelManager.js +148 -138
  183. package/src/managers/ClientUserSettingManager.js +372 -372
  184. package/src/managers/DataManager.js +61 -61
  185. package/src/managers/GuildBanManager.js +250 -204
  186. package/src/managers/GuildChannelManager.js +488 -504
  187. package/src/managers/GuildEmojiManager.js +171 -171
  188. package/src/managers/GuildEmojiRoleManager.js +118 -118
  189. package/src/managers/GuildForumThreadManager.js +108 -108
  190. package/src/managers/GuildInviteManager.js +213 -213
  191. package/src/managers/GuildManager.js +338 -304
  192. package/src/managers/GuildMemberManager.js +599 -593
  193. package/src/managers/GuildMemberRoleManager.js +195 -191
  194. package/src/managers/GuildScheduledEventManager.js +314 -296
  195. package/src/managers/GuildSettingManager.js +155 -155
  196. package/src/managers/GuildStickerManager.js +179 -179
  197. package/src/managers/GuildTextThreadManager.js +98 -98
  198. package/src/managers/InteractionManager.js +39 -39
  199. package/src/managers/MessageManager.js +423 -391
  200. package/src/managers/PermissionOverwriteManager.js +164 -166
  201. package/src/managers/PresenceManager.js +71 -58
  202. package/src/managers/ReactionManager.js +67 -67
  203. package/src/managers/ReactionUserManager.js +73 -71
  204. package/src/managers/RelationshipManager.js +278 -265
  205. package/src/managers/RoleManager.js +448 -352
  206. package/src/managers/SessionManager.js +66 -0
  207. package/src/managers/StageInstanceManager.js +162 -162
  208. package/src/managers/ThreadManager.js +175 -174
  209. package/src/managers/ThreadMemberManager.js +186 -186
  210. package/src/managers/UserManager.js +136 -146
  211. package/src/managers/UserNoteManager.js +53 -53
  212. package/src/managers/VoiceStateManager.js +59 -37
  213. package/src/rest/APIRequest.js +154 -154
  214. package/src/rest/APIRouter.js +53 -53
  215. package/src/rest/DiscordAPIError.js +119 -104
  216. package/src/rest/HTTPError.js +62 -62
  217. package/src/rest/RESTManager.js +67 -62
  218. package/src/rest/RateLimitError.js +55 -55
  219. package/src/rest/RequestHandler.js +466 -444
  220. package/src/sharding/Shard.js +444 -443
  221. package/src/sharding/ShardClientUtil.js +279 -275
  222. package/src/sharding/ShardingManager.js +319 -318
  223. package/src/structures/AnonymousGuild.js +98 -98
  224. package/src/structures/ApplicationCommand.js +593 -593
  225. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -48
  226. package/src/structures/AutoModerationActionExecution.js +89 -89
  227. package/src/structures/AutoModerationRule.js +294 -294
  228. package/src/structures/AutocompleteInteraction.js +107 -107
  229. package/src/structures/Base.js +43 -43
  230. package/src/structures/BaseCommandInteraction.js +211 -211
  231. package/src/structures/BaseGuild.js +116 -116
  232. package/src/structures/BaseGuildEmoji.js +56 -56
  233. package/src/structures/BaseGuildTextChannel.js +191 -191
  234. package/src/structures/BaseGuildVoiceChannel.js +241 -241
  235. package/src/structures/BaseMessageComponent.js +181 -114
  236. package/src/structures/ButtonInteraction.js +11 -11
  237. package/src/structures/CallState.js +63 -63
  238. package/src/structures/CategoryChannel.js +85 -85
  239. package/src/structures/Channel.js +284 -270
  240. package/src/structures/ClientPresence.js +77 -88
  241. package/src/structures/ClientUser.js +479 -450
  242. package/src/structures/CommandInteraction.js +41 -41
  243. package/src/structures/CommandInteractionOptionResolver.js +276 -276
  244. package/src/structures/ContainerComponent.js +68 -0
  245. package/src/structures/ContextMenuInteraction.js +65 -65
  246. package/src/structures/DMChannel.js +219 -217
  247. package/src/structures/DirectoryChannel.js +20 -20
  248. package/src/structures/Emoji.js +148 -148
  249. package/src/structures/FileComponent.js +49 -0
  250. package/src/structures/ForumChannel.js +31 -261
  251. package/src/structures/GroupDMChannel.js +394 -387
  252. package/src/structures/Guild.js +1643 -1608
  253. package/src/structures/GuildAuditLogs.js +746 -729
  254. package/src/structures/GuildBan.js +59 -59
  255. package/src/structures/GuildBoost.js +108 -108
  256. package/src/structures/GuildChannel.js +470 -468
  257. package/src/structures/GuildEmoji.js +161 -161
  258. package/src/structures/GuildMember.js +636 -568
  259. package/src/structures/GuildPreview.js +191 -191
  260. package/src/structures/GuildPreviewEmoji.js +27 -27
  261. package/src/structures/GuildScheduledEvent.js +536 -441
  262. package/src/structures/GuildTemplate.js +236 -236
  263. package/src/structures/Integration.js +188 -188
  264. package/src/structures/IntegrationApplication.js +96 -96
  265. package/src/structures/Interaction.js +290 -290
  266. package/src/structures/InteractionCollector.js +248 -248
  267. package/src/structures/InteractionWebhook.js +43 -43
  268. package/src/structures/Invite.js +358 -358
  269. package/src/structures/InviteGuild.js +23 -23
  270. package/src/structures/InviteStageInstance.js +86 -86
  271. package/src/structures/MediaChannel.js +11 -0
  272. package/src/structures/MediaGalleryComponent.js +41 -0
  273. package/src/structures/MediaGalleryItem.js +47 -0
  274. package/src/structures/Message.js +1252 -1236
  275. package/src/structures/MessageActionRow.js +105 -103
  276. package/src/structures/MessageAttachment.js +216 -204
  277. package/src/structures/MessageButton.js +166 -165
  278. package/src/structures/MessageCollector.js +146 -146
  279. package/src/structures/MessageComponentInteraction.js +120 -120
  280. package/src/structures/MessageContextMenuInteraction.js +20 -20
  281. package/src/structures/MessageEmbed.js +596 -586
  282. package/src/structures/MessageMentions.js +273 -273
  283. package/src/structures/MessagePayload.js +354 -316
  284. package/src/structures/MessageReaction.js +181 -171
  285. package/src/structures/MessageSelectMenu.js +141 -140
  286. package/src/structures/Modal.js +161 -174
  287. package/src/structures/ModalSubmitFieldsResolver.js +53 -53
  288. package/src/structures/ModalSubmitInteraction.js +119 -119
  289. package/src/structures/NewsChannel.js +32 -32
  290. package/src/structures/OAuth2Guild.js +28 -28
  291. package/src/structures/PermissionOverwrites.js +198 -196
  292. package/src/structures/Poll.js +108 -0
  293. package/src/structures/PollAnswer.js +88 -0
  294. package/src/structures/Presence.js +1105 -443
  295. package/src/structures/ReactionCollector.js +229 -229
  296. package/src/structures/ReactionEmoji.js +31 -31
  297. package/src/structures/Role.js +590 -531
  298. package/src/structures/SectionComponent.js +48 -0
  299. package/src/structures/SelectMenuInteraction.js +21 -21
  300. package/src/structures/SeparatorComponent.js +48 -0
  301. package/src/structures/Session.js +81 -0
  302. package/src/structures/StageChannel.js +104 -104
  303. package/src/structures/StageInstance.js +208 -208
  304. package/src/structures/Sticker.js +310 -310
  305. package/src/structures/StickerPack.js +95 -95
  306. package/src/structures/StoreChannel.js +56 -56
  307. package/src/structures/Team.js +118 -118
  308. package/src/structures/TeamMember.js +80 -71
  309. package/src/structures/TextChannel.js +33 -33
  310. package/src/structures/TextDisplayComponent.js +40 -0
  311. package/src/structures/TextInputComponent.js +132 -131
  312. package/src/structures/ThreadChannel.js +605 -607
  313. package/src/structures/ThreadMember.js +105 -105
  314. package/src/structures/ThreadOnlyChannel.js +249 -0
  315. package/src/structures/ThumbnailComponent.js +57 -0
  316. package/src/structures/Typing.js +74 -74
  317. package/src/structures/UnfurledMediaItem.js +29 -0
  318. package/src/structures/User.js +640 -509
  319. package/src/structures/UserContextMenuInteraction.js +29 -29
  320. package/src/structures/VoiceChannel.js +110 -110
  321. package/src/structures/VoiceChannelEffect.js +69 -0
  322. package/src/structures/VoiceRegion.js +53 -53
  323. package/src/structures/VoiceState.js +354 -341
  324. package/src/structures/WebEmbed.js +373 -373
  325. package/src/structures/Webhook.js +478 -467
  326. package/src/structures/WelcomeChannel.js +60 -60
  327. package/src/structures/WelcomeScreen.js +48 -48
  328. package/src/structures/Widget.js +87 -87
  329. package/src/structures/WidgetMember.js +99 -99
  330. package/src/structures/interfaces/Application.js +825 -313
  331. package/src/structures/interfaces/Collector.js +300 -300
  332. package/src/structures/interfaces/InteractionResponses.js +313 -313
  333. package/src/structures/interfaces/TextBasedChannel.js +759 -721
  334. package/src/util/APITypes.js +59 -0
  335. package/src/util/ActivityFlags.js +44 -44
  336. package/src/util/ApplicationFlags.js +76 -76
  337. package/src/util/AttachmentFlags.js +38 -38
  338. package/src/util/BitField.js +170 -170
  339. package/src/util/ChannelFlags.js +45 -45
  340. package/src/util/Constants.js +1914 -1760
  341. package/src/util/DataResolver.js +146 -145
  342. package/src/util/Formatters.js +228 -228
  343. package/src/util/GuildMemberFlags.js +43 -43
  344. package/src/util/Intents.js +74 -74
  345. package/src/util/InviteFlags.js +34 -29
  346. package/src/util/LimitedCollection.js +131 -131
  347. package/src/util/MessageFlags.js +63 -54
  348. package/src/util/Options.js +358 -342
  349. package/src/util/Permissions.js +202 -192
  350. package/src/util/PremiumUsageFlags.js +31 -31
  351. package/src/util/PurchasedFlags.js +33 -33
  352. package/src/util/RemoteAuth.js +382 -379
  353. package/src/util/RoleFlags.js +37 -37
  354. package/src/util/SnowflakeUtil.js +92 -92
  355. package/src/util/Speaking.js +33 -0
  356. package/src/util/Sweepers.js +466 -466
  357. package/src/util/SystemChannelFlags.js +55 -55
  358. package/src/util/ThreadMemberFlags.js +30 -30
  359. package/src/util/UserFlags.js +104 -104
  360. package/src/util/Util.js +1048 -803
  361. package/typings/enums.d.ts +439 -291
  362. package/typings/index.d.ts +8247 -7390
  363. package/typings/rawDataTypes.d.ts +403 -342
  364. package/src/structures/RichPresence.js +0 -702
@@ -1,275 +1,279 @@
1
- 'use strict';
2
-
3
- const process = require('node:process');
4
- const { Error } = require('../errors');
5
- const { Events } = require('../util/Constants');
6
- const Util = require('../util/Util');
7
-
8
- /**
9
- * Helper class for sharded clients spawned as a child process/worker, such as from a {@link ShardingManager}.
10
- * Utilises IPC to send and receive data to/from the master process and other shards.
11
- */
12
- class ShardClientUtil {
13
- constructor(client, mode) {
14
- /**
15
- * Client for the shard
16
- * @type {Client}
17
- */
18
- this.client = client;
19
-
20
- /**
21
- * Mode the shard was spawned with
22
- * @type {ShardingManagerMode}
23
- */
24
- this.mode = mode;
25
-
26
- /**
27
- * Message port for the master process (only when {@link ShardClientUtil#mode} is `worker`)
28
- * @type {?MessagePort}
29
- */
30
- this.parentPort = null;
31
-
32
- if (mode === 'process') {
33
- process.on('message', this._handleMessage.bind(this));
34
- client.on('ready', () => {
35
- process.send({ _ready: true });
36
- });
37
- client.on('disconnect', () => {
38
- process.send({ _disconnect: true });
39
- });
40
- client.on('reconnecting', () => {
41
- process.send({ _reconnecting: true });
42
- });
43
- } else if (mode === 'worker') {
44
- this.parentPort = require('node:worker_threads').parentPort;
45
- this.parentPort.on('message', this._handleMessage.bind(this));
46
- client.on('ready', () => {
47
- this.parentPort.postMessage({ _ready: true });
48
- });
49
- client.on('disconnect', () => {
50
- this.parentPort.postMessage({ _disconnect: true });
51
- });
52
- client.on('reconnecting', () => {
53
- this.parentPort.postMessage({ _reconnecting: true });
54
- });
55
- }
56
- }
57
-
58
- /**
59
- * Array of shard ids of this client
60
- * @type {number[]}
61
- * @readonly
62
- */
63
- get ids() {
64
- return this.client.options.shards;
65
- }
66
-
67
- /**
68
- * Total number of shards
69
- * @type {number}
70
- * @readonly
71
- */
72
- get count() {
73
- return this.client.options.shardCount;
74
- }
75
-
76
- /**
77
- * Sends a message to the master process.
78
- * @param {*} message Message to send
79
- * @returns {Promise<void>}
80
- * @emits Shard#message
81
- */
82
- send(message) {
83
- return new Promise((resolve, reject) => {
84
- if (this.mode === 'process') {
85
- process.send(message, err => {
86
- if (err) reject(err);
87
- else resolve();
88
- });
89
- } else if (this.mode === 'worker') {
90
- this.parentPort.postMessage(message);
91
- resolve();
92
- }
93
- });
94
- }
95
-
96
- /**
97
- * Fetches a client property value of each shard, or a given shard.
98
- * @param {string} prop Name of the client property to get, using periods for nesting
99
- * @param {number} [shard] Shard to fetch property from, all if undefined
100
- * @returns {Promise<*|Array<*>>}
101
- * @example
102
- * client.shard.fetchClientValues('guilds.cache.size')
103
- * .then(results => console.log(`${results.reduce((prev, val) => prev + val, 0)} total guilds`))
104
- * .catch(console.error);
105
- * @see {@link ShardingManager#fetchClientValues}
106
- */
107
- fetchClientValues(prop, shard) {
108
- return new Promise((resolve, reject) => {
109
- const parent = this.parentPort ?? process;
110
-
111
- const listener = message => {
112
- if (message?._sFetchProp !== prop || message._sFetchPropShard !== shard) return;
113
- parent.removeListener('message', listener);
114
- this.decrementMaxListeners(parent);
115
- if (!message._error) resolve(message._result);
116
- else reject(Util.makeError(message._error));
117
- };
118
- this.incrementMaxListeners(parent);
119
- parent.on('message', listener);
120
-
121
- this.send({ _sFetchProp: prop, _sFetchPropShard: shard }).catch(err => {
122
- parent.removeListener('message', listener);
123
- this.decrementMaxListeners(parent);
124
- reject(err);
125
- });
126
- });
127
- }
128
-
129
- /**
130
- * Evaluates a script or function on all shards, or a given shard, in the context of the {@link Client}s.
131
- * @param {Function} script JavaScript to run on each shard
132
- * @param {BroadcastEvalOptions} [options={}] The options for the broadcast
133
- * @returns {Promise<*|Array<*>>} Results of the script execution
134
- * @example
135
- * client.shard.broadcastEval(client => client.guilds.cache.size)
136
- * .then(results => console.log(`${results.reduce((prev, val) => prev + val, 0)} total guilds`))
137
- * .catch(console.error);
138
- * @see {@link ShardingManager#broadcastEval}
139
- */
140
- broadcastEval(script, options = {}) {
141
- return new Promise((resolve, reject) => {
142
- const parent = this.parentPort ?? process;
143
- if (typeof script !== 'function') {
144
- reject(new TypeError('SHARDING_INVALID_EVAL_BROADCAST'));
145
- return;
146
- }
147
- script = `(${script})(this, ${JSON.stringify(options.context)})`;
148
-
149
- const listener = message => {
150
- if (message?._sEval !== script || message._sEvalShard !== options.shard) return;
151
- parent.removeListener('message', listener);
152
- this.decrementMaxListeners(parent);
153
- if (!message._error) resolve(message._result);
154
- else reject(Util.makeError(message._error));
155
- };
156
- this.incrementMaxListeners(parent);
157
- parent.on('message', listener);
158
- this.send({ _sEval: script, _sEvalShard: options.shard }).catch(err => {
159
- parent.removeListener('message', listener);
160
- this.decrementMaxListeners(parent);
161
- reject(err);
162
- });
163
- });
164
- }
165
-
166
- /**
167
- * Requests a respawn of all shards.
168
- * @param {MultipleShardRespawnOptions} [options] Options for respawning shards
169
- * @returns {Promise<void>} Resolves upon the message being sent
170
- * @see {@link ShardingManager#respawnAll}
171
- */
172
- respawnAll({ shardDelay = 5_000, respawnDelay = 500, timeout = 30_000 } = {}) {
173
- return this.send({ _sRespawnAll: { shardDelay, respawnDelay, timeout } });
174
- }
175
-
176
- /**
177
- * Handles an IPC message.
178
- * @param {*} message Message received
179
- * @private
180
- */
181
- async _handleMessage(message) {
182
- if (!message) return;
183
- if (message._fetchProp) {
184
- try {
185
- const props = message._fetchProp.split('.');
186
- let value = this.client;
187
- for (const prop of props) value = value[prop];
188
- this._respond('fetchProp', { _fetchProp: message._fetchProp, _result: value });
189
- } catch (err) {
190
- this._respond('fetchProp', { _fetchProp: message._fetchProp, _error: Util.makePlainError(err) });
191
- }
192
- } else if (message._eval) {
193
- try {
194
- this._respond('eval', { _eval: message._eval, _result: await this.client._eval(message._eval) });
195
- } catch (err) {
196
- this._respond('eval', { _eval: message._eval, _error: Util.makePlainError(err) });
197
- }
198
- }
199
- }
200
-
201
- /**
202
- * Sends a message to the master process, emitting an error from the client upon failure.
203
- * @param {string} type Type of response to send
204
- * @param {*} message Message to send
205
- * @private
206
- */
207
- _respond(type, message) {
208
- this.send(message).catch(err => {
209
- const error = new Error(`Error when sending ${type} response to master process: ${err.message}`);
210
- error.stack = err.stack;
211
- /**
212
- * Emitted when the client encounters an error.
213
- * @event Client#error
214
- * @param {Error} error The error encountered
215
- */
216
- this.client.emit(Events.ERROR, error);
217
- });
218
- }
219
-
220
- /**
221
- * Creates/gets the singleton of this class.
222
- * @param {Client} client The client to use
223
- * @param {ShardingManagerMode} mode Mode the shard was spawned with
224
- * @returns {ShardClientUtil}
225
- */
226
- static singleton(client, mode) {
227
- if (!this._singleton) {
228
- this._singleton = new this(client, mode);
229
- } else {
230
- client.emit(
231
- Events.WARN,
232
- 'Multiple clients created in child process/worker; only the first will handle sharding helpers.',
233
- );
234
- }
235
- return this._singleton;
236
- }
237
-
238
- /**
239
- * Get the shard id for a given guild id.
240
- * @param {Snowflake} guildId Snowflake guild id to get shard id for
241
- * @param {number} shardCount Number of shards
242
- * @returns {number}
243
- */
244
- static shardIdForGuildId(guildId, shardCount) {
245
- const shard = Number(BigInt(guildId) >> 22n) % shardCount;
246
- if (shard < 0) throw new Error('SHARDING_SHARD_MISCALCULATION', shard, guildId, shardCount);
247
- return shard;
248
- }
249
-
250
- /**
251
- * Increments max listeners by one for a given emitter, if they are not zero.
252
- * @param {EventEmitter|process} emitter The emitter that emits the events.
253
- * @private
254
- */
255
- incrementMaxListeners(emitter) {
256
- const maxListeners = emitter.getMaxListeners();
257
- if (maxListeners !== 0) {
258
- emitter.setMaxListeners(maxListeners + 1);
259
- }
260
- }
261
-
262
- /**
263
- * Decrements max listeners by one for a given emitter, if they are not zero.
264
- * @param {EventEmitter|process} emitter The emitter that emits the events.
265
- * @private
266
- */
267
- decrementMaxListeners(emitter) {
268
- const maxListeners = emitter.getMaxListeners();
269
- if (maxListeners !== 0) {
270
- emitter.setMaxListeners(maxListeners - 1);
271
- }
272
- }
273
- }
274
-
275
- module.exports = ShardClientUtil;
1
+ 'use strict';
2
+
3
+ const process = require('node:process');
4
+ const { Error } = require('../errors');
5
+ const { Events } = require('../util/Constants');
6
+ const Util = require('../util/Util');
7
+
8
+ /**
9
+ * Helper class for sharded clients spawned as a child process/worker, such as from a {@link ShardingManager}.
10
+ * Utilizes IPC to send and receive data to/from the master process and other shards.
11
+ * @deprecated
12
+ */
13
+ class ShardClientUtil {
14
+ constructor(client, mode) {
15
+ /**
16
+ * Client for the shard
17
+ * @type {Client}
18
+ */
19
+ this.client = client;
20
+
21
+ /**
22
+ * Mode the shard was spawned with
23
+ * @type {ShardingManagerMode}
24
+ */
25
+ this.mode = mode;
26
+
27
+ /**
28
+ * Message port for the master process (only when {@link ShardClientUtil#mode} is `worker`)
29
+ * @type {?MessagePort}
30
+ */
31
+ this.parentPort = null;
32
+
33
+ if (mode === 'process') {
34
+ process.on('message', this._handleMessage.bind(this));
35
+ client.on('ready', () => {
36
+ process.send({ _ready: true });
37
+ });
38
+ client.on('disconnect', () => {
39
+ process.send({ _disconnect: true });
40
+ });
41
+ client.on('reconnecting', () => {
42
+ process.send({ _reconnecting: true });
43
+ });
44
+ } else if (mode === 'worker') {
45
+ this.parentPort = require('node:worker_threads').parentPort;
46
+ this.parentPort.on('message', this._handleMessage.bind(this));
47
+ client.on('ready', () => {
48
+ this.parentPort.postMessage({ _ready: true });
49
+ });
50
+ client.on('disconnect', () => {
51
+ this.parentPort.postMessage({ _disconnect: true });
52
+ });
53
+ client.on('reconnecting', () => {
54
+ this.parentPort.postMessage({ _reconnecting: true });
55
+ });
56
+ }
57
+ }
58
+
59
+ /**
60
+ * Array of shard ids of this client
61
+ * @type {number[]}
62
+ * @readonly
63
+ */
64
+ get ids() {
65
+ return this.client.options.shards;
66
+ }
67
+
68
+ /**
69
+ * Total number of shards
70
+ * @type {number}
71
+ * @readonly
72
+ */
73
+ get count() {
74
+ return this.client.options.shardCount;
75
+ }
76
+
77
+ /**
78
+ * Sends a message to the master process.
79
+ * @param {*} message Message to send
80
+ * @returns {Promise<void>}
81
+ * @emits Shard#message
82
+ */
83
+ send(message) {
84
+ return new Promise((resolve, reject) => {
85
+ if (this.mode === 'process') {
86
+ process.send(message, err => {
87
+ if (err) reject(err);
88
+ else resolve();
89
+ });
90
+ } else if (this.mode === 'worker') {
91
+ this.parentPort.postMessage(message);
92
+ resolve();
93
+ }
94
+ });
95
+ }
96
+
97
+ /**
98
+ * Fetches a client property value of each shard, or a given shard.
99
+ * @param {string} prop Name of the client property to get, using periods for nesting
100
+ * @param {number} [shard] Shard to fetch property from, all if undefined
101
+ * @returns {Promise<*|Array<*>>}
102
+ * @example
103
+ * client.shard.fetchClientValues('guilds.cache.size')
104
+ * .then(results => console.log(`${results.reduce((prev, val) => prev + val, 0)} total guilds`))
105
+ * .catch(console.error);
106
+ * @see {@link ShardingManager#fetchClientValues}
107
+ */
108
+ fetchClientValues(prop, shard) {
109
+ return new Promise((resolve, reject) => {
110
+ const parent = this.parentPort ?? process;
111
+
112
+ const listener = message => {
113
+ if (message?._sFetchProp !== prop || message._sFetchPropShard !== shard) return;
114
+ parent.removeListener('message', listener);
115
+ this.decrementMaxListeners(parent);
116
+ if (!message._error) resolve(message._result);
117
+ else reject(Util.makeError(message._error));
118
+ };
119
+ this.incrementMaxListeners(parent);
120
+ parent.on('message', listener);
121
+
122
+ this.send({ _sFetchProp: prop, _sFetchPropShard: shard }).catch(err => {
123
+ parent.removeListener('message', listener);
124
+ this.decrementMaxListeners(parent);
125
+ reject(err);
126
+ });
127
+ });
128
+ }
129
+
130
+ /**
131
+ * Evaluates a script or function on all shards, or a given shard, in the context of the {@link Client}s.
132
+ * @param {Function} script JavaScript to run on each shard
133
+ * @param {BroadcastEvalOptions} [options={}] The options for the broadcast
134
+ * @returns {Promise<*|Array<*>>} Results of the script execution
135
+ * @example
136
+ * client.shard.broadcastEval(client => client.guilds.cache.size)
137
+ * .then(results => console.log(`${results.reduce((prev, val) => prev + val, 0)} total guilds`))
138
+ * .catch(console.error);
139
+ * @see {@link ShardingManager#broadcastEval}
140
+ */
141
+ broadcastEval(script, options = {}) {
142
+ return new Promise((resolve, reject) => {
143
+ const parent = this.parentPort ?? process;
144
+ if (typeof script !== 'function') {
145
+ reject(new TypeError('SHARDING_INVALID_EVAL_BROADCAST'));
146
+ return;
147
+ }
148
+ script = `(${script})(this, ${JSON.stringify(options.context)})`;
149
+
150
+ const listener = message => {
151
+ if (message?._sEval !== script || message._sEvalShard !== options.shard) return;
152
+ parent.removeListener('message', listener);
153
+ this.decrementMaxListeners(parent);
154
+ if (!message._error) resolve(message._result);
155
+ else reject(Util.makeError(message._error));
156
+ };
157
+ this.incrementMaxListeners(parent);
158
+ parent.on('message', listener);
159
+ this.send({ _sEval: script, _sEvalShard: options.shard }).catch(err => {
160
+ parent.removeListener('message', listener);
161
+ this.decrementMaxListeners(parent);
162
+ reject(err);
163
+ });
164
+ });
165
+ }
166
+
167
+ /**
168
+ * Requests a respawn of all shards.
169
+ * @param {MultipleShardRespawnOptions} [options] Options for respawning shards
170
+ * @returns {Promise<void>} Resolves upon the message being sent
171
+ * @see {@link ShardingManager#respawnAll}
172
+ */
173
+ respawnAll({ shardDelay = 5_000, respawnDelay = 500, timeout = 30_000 } = {}) {
174
+ return this.send({ _sRespawnAll: { shardDelay, respawnDelay, timeout } });
175
+ }
176
+
177
+ /**
178
+ * Handles an IPC message.
179
+ * @param {*} message Message received
180
+ * @private
181
+ */
182
+ async _handleMessage(message) {
183
+ if (!message) return;
184
+ if (message._fetchProp) {
185
+ try {
186
+ const props = message._fetchProp.split('.');
187
+ let value = this.client;
188
+ for (const prop of props) value = value[prop];
189
+ this._respond('fetchProp', { _fetchProp: message._fetchProp, _result: value });
190
+ } catch (err) {
191
+ this._respond('fetchProp', { _fetchProp: message._fetchProp, _error: Util.makePlainError(err) });
192
+ }
193
+ } else if (message._eval) {
194
+ try {
195
+ this._respond('eval', { _eval: message._eval, _result: await this.client._eval(message._eval) });
196
+ } catch (err) {
197
+ this._respond('eval', { _eval: message._eval, _error: Util.makePlainError(err) });
198
+ }
199
+ }
200
+ }
201
+
202
+ /**
203
+ * Sends a message to the master process, emitting an error from the client upon failure.
204
+ * @param {string} type Type of response to send
205
+ * @param {*} message Message to send
206
+ * @private
207
+ */
208
+ _respond(type, message) {
209
+ this.send(message).catch(err => {
210
+ const error = new Error(`Error when sending ${type} response to master process: ${err.message}`);
211
+ error.stack = err.stack;
212
+ /**
213
+ * Emitted when the client encounters an error.
214
+ * <warn>Errors thrown within this event do not have a catch handler, it is
215
+ * recommended to not use async functions as `error` event handlers. See the
216
+ * [Node.js docs](https://nodejs.org/api/events.html#capture-rejections-of-promises) for details.</warn>
217
+ * @event Client#error
218
+ * @param {Error} error The error encountered
219
+ */
220
+ this.client.emit(Events.ERROR, error);
221
+ });
222
+ }
223
+
224
+ /**
225
+ * Creates/gets the singleton of this class.
226
+ * @param {Client} client The client to use
227
+ * @param {ShardingManagerMode} mode Mode the shard was spawned with
228
+ * @returns {ShardClientUtil}
229
+ */
230
+ static singleton(client, mode) {
231
+ if (!this._singleton) {
232
+ this._singleton = new this(client, mode);
233
+ } else {
234
+ client.emit(
235
+ Events.WARN,
236
+ 'Multiple clients created in child process/worker; only the first will handle sharding helpers.',
237
+ );
238
+ }
239
+ return this._singleton;
240
+ }
241
+
242
+ /**
243
+ * Get the shard id for a given guild id.
244
+ * @param {Snowflake} guildId Snowflake guild id to get shard id for
245
+ * @param {number} shardCount Number of shards
246
+ * @returns {number}
247
+ */
248
+ static shardIdForGuildId(guildId, shardCount) {
249
+ const shard = Number(BigInt(guildId) >> 22n) % shardCount;
250
+ if (shard < 0) throw new Error('SHARDING_SHARD_MISCALCULATION', shard, guildId, shardCount);
251
+ return shard;
252
+ }
253
+
254
+ /**
255
+ * Increments max listeners by one for a given emitter, if they are not zero.
256
+ * @param {EventEmitter|process} emitter The emitter that emits the events.
257
+ * @private
258
+ */
259
+ incrementMaxListeners(emitter) {
260
+ const maxListeners = emitter.getMaxListeners();
261
+ if (maxListeners !== 0) {
262
+ emitter.setMaxListeners(maxListeners + 1);
263
+ }
264
+ }
265
+
266
+ /**
267
+ * Decrements max listeners by one for a given emitter, if they are not zero.
268
+ * @param {EventEmitter|process} emitter The emitter that emits the events.
269
+ * @private
270
+ */
271
+ decrementMaxListeners(emitter) {
272
+ const maxListeners = emitter.getMaxListeners();
273
+ if (maxListeners !== 0) {
274
+ emitter.setMaxListeners(maxListeners - 1);
275
+ }
276
+ }
277
+ }
278
+
279
+ module.exports = ShardClientUtil;