djs-selfbot-v13 3.2.2 → 3.7.2

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/README.md +63 -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 +941 -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/QuestManager.js +376 -0
  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 -160
  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 -85
  241. package/src/structures/ClientUser.js +653 -448
  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 +1697 -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 -1227
  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 -318
  284. package/src/structures/MessageReaction.js +181 -171
  285. package/src/structures/MessageSelectMenu.js +141 -140
  286. package/src/structures/Modal.js +161 -161
  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 +1137 -1101
  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 -543
  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 -719
  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 -1773
  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 -336
  349. package/src/util/Permissions.js +202 -202
  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 -889
  361. package/typings/enums.d.ts +439 -297
  362. package/typings/index.d.ts +8392 -7432
  363. package/typings/rawDataTypes.d.ts +403 -342
  364. 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;