djs-selfbot-v13 3.2.2 → 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 (363) hide show
  1. package/README.md +37 -36
  2. package/package.json +89 -85
  3. package/src/WebSocket.js +39 -39
  4. package/src/client/BaseClient.js +86 -86
  5. package/src/client/Client.js +934 -836
  6. package/src/client/WebhookClient.js +61 -61
  7. package/src/client/actions/Action.js +116 -120
  8. package/src/client/actions/ActionsManager.js +80 -78
  9. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
  10. package/src/client/actions/AutoModerationActionExecution.js +27 -27
  11. package/src/client/actions/AutoModerationRuleCreate.js +28 -28
  12. package/src/client/actions/AutoModerationRuleDelete.js +32 -32
  13. package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
  14. package/src/client/actions/ChannelCreate.js +23 -23
  15. package/src/client/actions/ChannelDelete.js +39 -39
  16. package/src/client/actions/ChannelUpdate.js +43 -43
  17. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
  18. package/src/client/actions/GuildBanAdd.js +20 -20
  19. package/src/client/actions/GuildBanRemove.js +25 -25
  20. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
  21. package/src/client/actions/GuildDelete.js +65 -65
  22. package/src/client/actions/GuildEmojiCreate.js +20 -20
  23. package/src/client/actions/GuildEmojiDelete.js +21 -21
  24. package/src/client/actions/GuildEmojiUpdate.js +20 -20
  25. package/src/client/actions/GuildEmojisUpdate.js +34 -34
  26. package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
  27. package/src/client/actions/GuildMemberRemove.js +33 -32
  28. package/src/client/actions/GuildMemberUpdate.js +44 -43
  29. package/src/client/actions/GuildRoleCreate.js +25 -25
  30. package/src/client/actions/GuildRoleDelete.js +31 -31
  31. package/src/client/actions/GuildRoleUpdate.js +39 -39
  32. package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
  33. package/src/client/actions/GuildScheduledEventCreate.js +27 -27
  34. package/src/client/actions/GuildScheduledEventDelete.js +31 -31
  35. package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
  36. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
  37. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
  38. package/src/client/actions/GuildStickerCreate.js +20 -20
  39. package/src/client/actions/GuildStickerDelete.js +21 -21
  40. package/src/client/actions/GuildStickerUpdate.js +20 -20
  41. package/src/client/actions/GuildStickersUpdate.js +34 -34
  42. package/src/client/actions/GuildUpdate.js +33 -33
  43. package/src/client/actions/InviteCreate.js +28 -28
  44. package/src/client/actions/InviteDelete.js +30 -30
  45. package/src/client/actions/MessageCreate.js +50 -46
  46. package/src/client/actions/MessageDelete.js +32 -32
  47. package/src/client/actions/MessageDeleteBulk.js +46 -46
  48. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  49. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  50. package/src/client/actions/MessageReactionAdd.js +68 -56
  51. package/src/client/actions/MessageReactionRemove.js +50 -45
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -33
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
  54. package/src/client/actions/MessageUpdate.js +26 -26
  55. package/src/client/actions/PresenceUpdate.js +50 -46
  56. package/src/client/actions/StageInstanceCreate.js +28 -28
  57. package/src/client/actions/StageInstanceDelete.js +33 -33
  58. package/src/client/actions/StageInstanceUpdate.js +30 -30
  59. package/src/client/actions/ThreadCreate.js +24 -24
  60. package/src/client/actions/ThreadDelete.js +32 -32
  61. package/src/client/actions/ThreadListSync.js +59 -59
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -30
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -34
  64. package/src/client/actions/TypingStart.js +29 -29
  65. package/src/client/actions/UserUpdate.js +35 -35
  66. package/src/client/actions/VoiceStateUpdate.js +50 -57
  67. package/src/client/actions/WebhooksUpdate.js +20 -20
  68. package/src/client/voice/ClientVoiceManager.js +151 -51
  69. package/src/client/voice/VoiceConnection.js +1249 -0
  70. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  71. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  72. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  73. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  74. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  75. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  76. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  77. package/src/client/voice/player/MediaPlayer.js +321 -0
  78. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  79. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  80. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  81. package/src/client/voice/receiver/PacketHandler.js +260 -0
  82. package/src/client/voice/receiver/Receiver.js +96 -0
  83. package/src/client/voice/receiver/Recorder.js +173 -0
  84. package/src/client/voice/util/Function.js +116 -0
  85. package/src/client/voice/util/PlayInterface.js +122 -0
  86. package/src/client/voice/util/Secretbox.js +64 -0
  87. package/src/client/voice/util/Silence.js +16 -0
  88. package/src/client/voice/util/Socket.js +62 -0
  89. package/src/client/voice/util/VolumeInterface.js +104 -0
  90. package/src/client/websocket/WebSocketManager.js +392 -392
  91. package/src/client/websocket/WebSocketShard.js +907 -906
  92. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
  96. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
  97. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
  100. package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
  101. package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
  102. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
  103. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
  104. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
  105. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
  106. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
  108. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
  109. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
  110. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
  111. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
  112. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -52
  113. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
  114. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
  115. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
  116. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
  117. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -19
  118. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
  119. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
  120. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
  121. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
  122. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
  123. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
  128. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
  129. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
  130. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
  131. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
  132. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
  133. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
  134. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
  135. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
  136. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -22
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -12
  138. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
  142. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
  143. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
  144. package/src/client/websocket/handlers/READY.js +121 -120
  145. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
  146. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
  147. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
  148. package/src/client/websocket/handlers/RESUMED.js +14 -14
  149. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
  152. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
  153. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
  154. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
  155. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
  156. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
  157. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
  158. package/src/client/websocket/handlers/TYPING_START.js +5 -5
  159. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
  160. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
  161. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
  162. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
  163. package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
  164. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
  166. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
  167. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
  168. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
  169. package/src/client/websocket/handlers/index.js +84 -83
  170. package/src/errors/DJSError.js +61 -61
  171. package/src/errors/Messages.js +217 -183
  172. package/src/errors/index.js +4 -4
  173. package/src/index.js +172 -159
  174. package/src/managers/ApplicationCommandManager.js +264 -264
  175. package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
  176. package/src/managers/AutoModerationRuleManager.js +296 -296
  177. package/src/managers/BaseGuildEmojiManager.js +80 -80
  178. package/src/managers/BaseManager.js +19 -19
  179. package/src/managers/BillingManager.js +66 -66
  180. package/src/managers/CachedManager.js +71 -71
  181. package/src/managers/ChannelManager.js +148 -138
  182. package/src/managers/ClientUserSettingManager.js +372 -372
  183. package/src/managers/DataManager.js +61 -61
  184. package/src/managers/GuildBanManager.js +250 -250
  185. package/src/managers/GuildChannelManager.js +488 -488
  186. package/src/managers/GuildEmojiManager.js +171 -171
  187. package/src/managers/GuildEmojiRoleManager.js +118 -118
  188. package/src/managers/GuildForumThreadManager.js +108 -108
  189. package/src/managers/GuildInviteManager.js +213 -213
  190. package/src/managers/GuildManager.js +338 -304
  191. package/src/managers/GuildMemberManager.js +599 -597
  192. package/src/managers/GuildMemberRoleManager.js +195 -191
  193. package/src/managers/GuildScheduledEventManager.js +314 -296
  194. package/src/managers/GuildSettingManager.js +155 -155
  195. package/src/managers/GuildStickerManager.js +179 -179
  196. package/src/managers/GuildTextThreadManager.js +98 -98
  197. package/src/managers/InteractionManager.js +39 -39
  198. package/src/managers/MessageManager.js +423 -391
  199. package/src/managers/PermissionOverwriteManager.js +164 -166
  200. package/src/managers/PresenceManager.js +71 -58
  201. package/src/managers/ReactionManager.js +67 -67
  202. package/src/managers/ReactionUserManager.js +73 -71
  203. package/src/managers/RelationshipManager.js +278 -265
  204. package/src/managers/RoleManager.js +448 -352
  205. package/src/managers/SessionManager.js +66 -0
  206. package/src/managers/StageInstanceManager.js +162 -162
  207. package/src/managers/ThreadManager.js +175 -174
  208. package/src/managers/ThreadMemberManager.js +186 -186
  209. package/src/managers/UserManager.js +136 -146
  210. package/src/managers/UserNoteManager.js +53 -53
  211. package/src/managers/VoiceStateManager.js +59 -37
  212. package/src/rest/APIRequest.js +154 -160
  213. package/src/rest/APIRouter.js +53 -53
  214. package/src/rest/DiscordAPIError.js +119 -104
  215. package/src/rest/HTTPError.js +62 -62
  216. package/src/rest/RESTManager.js +67 -62
  217. package/src/rest/RateLimitError.js +55 -55
  218. package/src/rest/RequestHandler.js +466 -444
  219. package/src/sharding/Shard.js +444 -443
  220. package/src/sharding/ShardClientUtil.js +279 -275
  221. package/src/sharding/ShardingManager.js +319 -318
  222. package/src/structures/AnonymousGuild.js +98 -98
  223. package/src/structures/ApplicationCommand.js +593 -593
  224. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -48
  225. package/src/structures/AutoModerationActionExecution.js +89 -89
  226. package/src/structures/AutoModerationRule.js +294 -294
  227. package/src/structures/AutocompleteInteraction.js +107 -107
  228. package/src/structures/Base.js +43 -43
  229. package/src/structures/BaseCommandInteraction.js +211 -211
  230. package/src/structures/BaseGuild.js +116 -116
  231. package/src/structures/BaseGuildEmoji.js +56 -56
  232. package/src/structures/BaseGuildTextChannel.js +191 -191
  233. package/src/structures/BaseGuildVoiceChannel.js +241 -241
  234. package/src/structures/BaseMessageComponent.js +181 -114
  235. package/src/structures/ButtonInteraction.js +11 -11
  236. package/src/structures/CallState.js +63 -63
  237. package/src/structures/CategoryChannel.js +85 -85
  238. package/src/structures/Channel.js +284 -270
  239. package/src/structures/ClientPresence.js +77 -85
  240. package/src/structures/ClientUser.js +479 -448
  241. package/src/structures/CommandInteraction.js +41 -41
  242. package/src/structures/CommandInteractionOptionResolver.js +276 -276
  243. package/src/structures/ContainerComponent.js +68 -0
  244. package/src/structures/ContextMenuInteraction.js +65 -65
  245. package/src/structures/DMChannel.js +219 -217
  246. package/src/structures/DirectoryChannel.js +20 -20
  247. package/src/structures/Emoji.js +148 -148
  248. package/src/structures/FileComponent.js +49 -0
  249. package/src/structures/ForumChannel.js +31 -261
  250. package/src/structures/GroupDMChannel.js +394 -387
  251. package/src/structures/Guild.js +1643 -1608
  252. package/src/structures/GuildAuditLogs.js +746 -729
  253. package/src/structures/GuildBan.js +59 -59
  254. package/src/structures/GuildBoost.js +108 -108
  255. package/src/structures/GuildChannel.js +470 -468
  256. package/src/structures/GuildEmoji.js +161 -161
  257. package/src/structures/GuildMember.js +636 -568
  258. package/src/structures/GuildPreview.js +191 -191
  259. package/src/structures/GuildPreviewEmoji.js +27 -27
  260. package/src/structures/GuildScheduledEvent.js +536 -441
  261. package/src/structures/GuildTemplate.js +236 -236
  262. package/src/structures/Integration.js +188 -188
  263. package/src/structures/IntegrationApplication.js +96 -96
  264. package/src/structures/Interaction.js +290 -290
  265. package/src/structures/InteractionCollector.js +248 -248
  266. package/src/structures/InteractionWebhook.js +43 -43
  267. package/src/structures/Invite.js +358 -358
  268. package/src/structures/InviteGuild.js +23 -23
  269. package/src/structures/InviteStageInstance.js +86 -86
  270. package/src/structures/MediaChannel.js +11 -0
  271. package/src/structures/MediaGalleryComponent.js +41 -0
  272. package/src/structures/MediaGalleryItem.js +47 -0
  273. package/src/structures/Message.js +1252 -1227
  274. package/src/structures/MessageActionRow.js +105 -103
  275. package/src/structures/MessageAttachment.js +216 -204
  276. package/src/structures/MessageButton.js +166 -165
  277. package/src/structures/MessageCollector.js +146 -146
  278. package/src/structures/MessageComponentInteraction.js +120 -120
  279. package/src/structures/MessageContextMenuInteraction.js +20 -20
  280. package/src/structures/MessageEmbed.js +596 -586
  281. package/src/structures/MessageMentions.js +273 -273
  282. package/src/structures/MessagePayload.js +354 -318
  283. package/src/structures/MessageReaction.js +181 -171
  284. package/src/structures/MessageSelectMenu.js +141 -140
  285. package/src/structures/Modal.js +161 -161
  286. package/src/structures/ModalSubmitFieldsResolver.js +53 -53
  287. package/src/structures/ModalSubmitInteraction.js +119 -119
  288. package/src/structures/NewsChannel.js +32 -32
  289. package/src/structures/OAuth2Guild.js +28 -28
  290. package/src/structures/PermissionOverwrites.js +198 -196
  291. package/src/structures/Poll.js +108 -0
  292. package/src/structures/PollAnswer.js +88 -0
  293. package/src/structures/Presence.js +1105 -1101
  294. package/src/structures/ReactionCollector.js +229 -229
  295. package/src/structures/ReactionEmoji.js +31 -31
  296. package/src/structures/Role.js +590 -531
  297. package/src/structures/SectionComponent.js +48 -0
  298. package/src/structures/SelectMenuInteraction.js +21 -21
  299. package/src/structures/SeparatorComponent.js +48 -0
  300. package/src/structures/Session.js +81 -0
  301. package/src/structures/StageChannel.js +104 -104
  302. package/src/structures/StageInstance.js +208 -208
  303. package/src/structures/Sticker.js +310 -310
  304. package/src/structures/StickerPack.js +95 -95
  305. package/src/structures/StoreChannel.js +56 -56
  306. package/src/structures/Team.js +118 -118
  307. package/src/structures/TeamMember.js +80 -71
  308. package/src/structures/TextChannel.js +33 -33
  309. package/src/structures/TextDisplayComponent.js +40 -0
  310. package/src/structures/TextInputComponent.js +132 -131
  311. package/src/structures/ThreadChannel.js +605 -607
  312. package/src/structures/ThreadMember.js +105 -105
  313. package/src/structures/ThreadOnlyChannel.js +249 -0
  314. package/src/structures/ThumbnailComponent.js +57 -0
  315. package/src/structures/Typing.js +74 -74
  316. package/src/structures/UnfurledMediaItem.js +29 -0
  317. package/src/structures/User.js +640 -543
  318. package/src/structures/UserContextMenuInteraction.js +29 -29
  319. package/src/structures/VoiceChannel.js +110 -110
  320. package/src/structures/VoiceChannelEffect.js +69 -0
  321. package/src/structures/VoiceRegion.js +53 -53
  322. package/src/structures/VoiceState.js +354 -341
  323. package/src/structures/WebEmbed.js +373 -373
  324. package/src/structures/Webhook.js +478 -467
  325. package/src/structures/WelcomeChannel.js +60 -60
  326. package/src/structures/WelcomeScreen.js +48 -48
  327. package/src/structures/Widget.js +87 -87
  328. package/src/structures/WidgetMember.js +99 -99
  329. package/src/structures/interfaces/Application.js +825 -313
  330. package/src/structures/interfaces/Collector.js +300 -300
  331. package/src/structures/interfaces/InteractionResponses.js +313 -313
  332. package/src/structures/interfaces/TextBasedChannel.js +759 -719
  333. package/src/util/APITypes.js +59 -0
  334. package/src/util/ActivityFlags.js +44 -44
  335. package/src/util/ApplicationFlags.js +76 -76
  336. package/src/util/AttachmentFlags.js +38 -38
  337. package/src/util/BitField.js +170 -170
  338. package/src/util/ChannelFlags.js +45 -45
  339. package/src/util/Constants.js +1914 -1773
  340. package/src/util/DataResolver.js +146 -145
  341. package/src/util/Formatters.js +228 -228
  342. package/src/util/GuildMemberFlags.js +43 -43
  343. package/src/util/Intents.js +74 -74
  344. package/src/util/InviteFlags.js +34 -29
  345. package/src/util/LimitedCollection.js +131 -131
  346. package/src/util/MessageFlags.js +63 -54
  347. package/src/util/Options.js +358 -336
  348. package/src/util/Permissions.js +202 -202
  349. package/src/util/PremiumUsageFlags.js +31 -31
  350. package/src/util/PurchasedFlags.js +33 -33
  351. package/src/util/RemoteAuth.js +382 -379
  352. package/src/util/RoleFlags.js +37 -37
  353. package/src/util/SnowflakeUtil.js +92 -92
  354. package/src/util/Speaking.js +33 -0
  355. package/src/util/Sweepers.js +466 -466
  356. package/src/util/SystemChannelFlags.js +55 -55
  357. package/src/util/ThreadMemberFlags.js +30 -30
  358. package/src/util/UserFlags.js +104 -104
  359. package/src/util/Util.js +1048 -889
  360. package/typings/enums.d.ts +439 -297
  361. package/typings/index.d.ts +8247 -7432
  362. package/typings/rawDataTypes.d.ts +403 -342
  363. package/src/structures/MessagePoll.js +0 -238
@@ -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;