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,466 +1,466 @@
1
- 'use strict';
2
-
3
- const { setInterval } = require('node:timers');
4
- const { Events, ThreadChannelTypes, SweeperKeys } = require('./Constants');
5
- const { TypeError } = require('../errors/DJSError.js');
6
-
7
- /**
8
- * @typedef {Function} GlobalSweepFilter
9
- * @returns {Function|null} Return `null` to skip sweeping, otherwise a function passed to `sweep()`,
10
- * See {@link [Collection#sweep](https://discord.js.org/docs/packages/collection/stable/Collection:Class#sweep)}
11
- * for the definition of this function.
12
- */
13
-
14
- /**
15
- * A container for all cache sweeping intervals and their associated sweep methods.
16
- */
17
- class Sweepers {
18
- constructor(client, options) {
19
- /**
20
- * The client that instantiated this
21
- * @type {Client}
22
- * @readonly
23
- */
24
- Object.defineProperty(this, 'client', { value: client });
25
-
26
- /**
27
- * The options the sweepers were instantiated with
28
- * @type {SweeperOptions}
29
- */
30
- this.options = options;
31
-
32
- /**
33
- * A record of interval timeout that is used to sweep the indicated items, or null if not being swept
34
- * @type {Object<SweeperKey, ?Timeout>}
35
- */
36
- this.intervals = Object.fromEntries(SweeperKeys.map(key => [key, null]));
37
-
38
- for (const key of SweeperKeys) {
39
- if (!(key in options)) continue;
40
-
41
- this._validateProperties(key);
42
-
43
- const clonedOptions = { ...this.options[key] };
44
-
45
- // Handle cases that have a "lifetime"
46
- if (!('filter' in clonedOptions)) {
47
- switch (key) {
48
- case 'invites':
49
- clonedOptions.filter = this.constructor.expiredInviteSweepFilter(clonedOptions.lifetime);
50
- break;
51
- case 'messages':
52
- clonedOptions.filter = this.constructor.outdatedMessageSweepFilter(clonedOptions.lifetime);
53
- break;
54
- case 'threads':
55
- clonedOptions.filter = this.constructor.archivedThreadSweepFilter(clonedOptions.lifetime);
56
- }
57
- }
58
-
59
- this._initInterval(key, `sweep${key[0].toUpperCase()}${key.slice(1)}`, clonedOptions);
60
- }
61
- }
62
-
63
- /**
64
- * Sweeps all guild and global application commands and removes the ones which are indicated by the filter.
65
- * @param {Function} filter The function used to determine which commands will be removed from the caches.
66
- * @returns {number} Amount of commands that were removed from the caches
67
- */
68
- sweepApplicationCommands(filter) {
69
- const { guilds, items: guildCommands } = this._sweepGuildDirectProp('commands', filter, { emit: false });
70
-
71
- const globalCommands = this.client.application?.commands.cache.sweep(filter) ?? 0;
72
-
73
- this.client.emit(
74
- Events.CACHE_SWEEP,
75
- `Swept ${globalCommands} global application commands and ${guildCommands} guild commands in ${guilds} guilds.`,
76
- );
77
- return guildCommands + globalCommands;
78
- }
79
-
80
- /**
81
- * Sweeps all auto moderation rules and removes the ones which are indicated by the filter.
82
- * @param {Function} filter The function used to determine
83
- * which auto moderation rules will be removed from the caches
84
- * @returns {number} Amount of auto moderation rules that were removed from the caches
85
- */
86
- sweepAutoModerationRules(filter) {
87
- return this._sweepGuildDirectProp('autoModerationRules', filter).items;
88
- }
89
-
90
- /**
91
- * Sweeps all guild bans and removes the ones which are indicated by the filter.
92
- * @param {Function} filter The function used to determine which bans will be removed from the caches.
93
- * @returns {number} Amount of bans that were removed from the caches
94
- */
95
- sweepBans(filter) {
96
- return this._sweepGuildDirectProp('bans', filter).items;
97
- }
98
-
99
- /**
100
- * Sweeps all guild emojis and removes the ones which are indicated by the filter.
101
- * @param {Function} filter The function used to determine which emojis will be removed from the caches.
102
- * @returns {number} Amount of emojis that were removed from the caches
103
- */
104
- sweepEmojis(filter) {
105
- return this._sweepGuildDirectProp('emojis', filter).items;
106
- }
107
-
108
- /**
109
- * Sweeps all guild invites and removes the ones which are indicated by the filter.
110
- * @param {Function} filter The function used to determine which invites will be removed from the caches.
111
- * @returns {number} Amount of invites that were removed from the caches
112
- */
113
- sweepInvites(filter) {
114
- return this._sweepGuildDirectProp('invites', filter).items;
115
- }
116
-
117
- /**
118
- * Sweeps all guild members and removes the ones which are indicated by the filter.
119
- * <info>It is highly recommended to keep the client guild member cached</info>
120
- * @param {Function} filter The function used to determine which guild members will be removed from the caches.
121
- * @returns {number} Amount of guild members that were removed from the caches
122
- */
123
- sweepGuildMembers(filter) {
124
- return this._sweepGuildDirectProp('members', filter, { outputName: 'guild members' }).items;
125
- }
126
-
127
- /**
128
- * Sweeps all text-based channels' messages and removes the ones which are indicated by the filter.
129
- * @param {Function} filter The function used to determine which messages will be removed from the caches.
130
- * @returns {number} Amount of messages that were removed from the caches
131
- * @example
132
- * // Remove all messages older than 1800 seconds from the messages cache
133
- * const amount = sweepers.sweepMessages(
134
- * Sweepers.filterByLifetime({
135
- * lifetime: 1800,
136
- * getComparisonTimestamp: m => m.editedTimestamp ?? m.createdTimestamp,
137
- * })(),
138
- * );
139
- * console.log(`Successfully removed ${amount} messages from the cache.`);
140
- */
141
- sweepMessages(filter) {
142
- if (typeof filter !== 'function') {
143
- throw new TypeError('INVALID_TYPE', 'filter', 'function');
144
- }
145
- let channels = 0;
146
- let messages = 0;
147
-
148
- for (const channel of this.client.channels.cache.values()) {
149
- if (!channel.isText()) continue;
150
-
151
- channels++;
152
- messages += channel.messages.cache.sweep(filter);
153
- }
154
- this.client.emit(Events.CACHE_SWEEP, `Swept ${messages} messages in ${channels} text-based channels.`);
155
- return messages;
156
- }
157
-
158
- /**
159
- * Sweeps all presences and removes the ones which are indicated by the filter.
160
- * @param {Function} filter The function used to determine which presences will be removed from the caches.
161
- * @returns {number} Amount of presences that were removed from the caches
162
- */
163
- sweepPresences(filter) {
164
- return this._sweepGuildDirectProp('presences', filter).items;
165
- }
166
-
167
- /**
168
- * Sweeps all message reactions and removes the ones which are indicated by the filter.
169
- * @param {Function} filter The function used to determine which reactions will be removed from the caches.
170
- * @returns {number} Amount of reactions that were removed from the caches
171
- */
172
- sweepReactions(filter) {
173
- if (typeof filter !== 'function') {
174
- throw new TypeError('INVALID_TYPE', 'filter', 'function');
175
- }
176
- let channels = 0;
177
- let messages = 0;
178
- let reactions = 0;
179
-
180
- for (const channel of this.client.channels.cache.values()) {
181
- if (!channel.isText()) continue;
182
- channels++;
183
-
184
- for (const message of channel.messages.cache.values()) {
185
- messages++;
186
- reactions += message.reactions.cache.sweep(filter);
187
- }
188
- }
189
- this.client.emit(
190
- Events.CACHE_SWEEP,
191
- `Swept ${reactions} reactions on ${messages} messages in ${channels} text-based channels.`,
192
- );
193
- return reactions;
194
- }
195
-
196
- /**
197
- * Sweeps all guild stage instances and removes the ones which are indicated by the filter.
198
- * @param {Function} filter The function used to determine which stage instances will be removed from the caches.
199
- * @returns {number} Amount of stage instances that were removed from the caches
200
- */
201
- sweepStageInstances(filter) {
202
- return this._sweepGuildDirectProp('stageInstances', filter, { outputName: 'stage instances' }).items;
203
- }
204
-
205
- /**
206
- * Sweeps all guild stickers and removes the ones which are indicated by the filter.
207
- * @param {Function} filter The function used to determine which stickers will be removed from the caches.
208
- * @returns {number} Amount of stickers that were removed from the caches
209
- */
210
- sweepStickers(filter) {
211
- return this._sweepGuildDirectProp('stickers', filter).items;
212
- }
213
-
214
- /**
215
- * Sweeps all thread members and removes the ones which are indicated by the filter.
216
- * <info>It is highly recommended to keep the client thread member cached</info>
217
- * @param {Function} filter The function used to determine which thread members will be removed from the caches.
218
- * @returns {number} Amount of thread members that were removed from the caches
219
- */
220
- sweepThreadMembers(filter) {
221
- if (typeof filter !== 'function') {
222
- throw new TypeError('INVALID_TYPE', 'filter', 'function');
223
- }
224
-
225
- let threads = 0;
226
- let members = 0;
227
- for (const channel of this.client.channels.cache.values()) {
228
- if (!ThreadChannelTypes.includes(channel.type)) continue;
229
- threads++;
230
- members += channel.members.cache.sweep(filter);
231
- }
232
- this.client.emit(Events.CACHE_SWEEP, `Swept ${members} thread members in ${threads} threads.`);
233
- return members;
234
- }
235
-
236
- /**
237
- * Sweeps all threads and removes the ones which are indicated by the filter.
238
- * @param {Function} filter The function used to determine which threads will be removed from the caches.
239
- * @returns {number} filter Amount of threads that were removed from the caches
240
- * @example
241
- * // Remove all threads archived greater than 1 day ago from all the channel caches
242
- * const amount = sweepers.sweepThreads(
243
- * Sweepers.filterByLifetime({
244
- * getComparisonTimestamp: t => t.archivedTimestamp,
245
- * excludeFromSweep: t => !t.archived,
246
- * })(),
247
- * );
248
- * console.log(`Successfully removed ${amount} threads from the cache.`);
249
- */
250
- sweepThreads(filter) {
251
- if (typeof filter !== 'function') {
252
- throw new TypeError('INVALID_TYPE', 'filter', 'function');
253
- }
254
-
255
- let threads = 0;
256
- for (const [key, val] of this.client.channels.cache.entries()) {
257
- if (!ThreadChannelTypes.includes(val.type)) continue;
258
- if (filter(val, key, this.client.channels.cache)) {
259
- threads++;
260
- this.client.channels._remove(key);
261
- }
262
- }
263
- this.client.emit(Events.CACHE_SWEEP, `Swept ${threads} threads.`);
264
- return threads;
265
- }
266
-
267
- /**
268
- * Sweeps all users and removes the ones which are indicated by the filter.
269
- * @param {Function} filter The function used to determine which users will be removed from the caches.
270
- * @returns {number} Amount of users that were removed from the caches
271
- */
272
- sweepUsers(filter) {
273
- if (typeof filter !== 'function') {
274
- throw new TypeError('INVALID_TYPE', 'filter', 'function');
275
- }
276
-
277
- const users = this.client.users.cache.sweep(filter);
278
-
279
- this.client.emit(Events.CACHE_SWEEP, `Swept ${users} users.`);
280
-
281
- return users;
282
- }
283
-
284
- /**
285
- * Sweeps all guild voice states and removes the ones which are indicated by the filter.
286
- * @param {Function} filter The function used to determine which voice states will be removed from the caches.
287
- * @returns {number} Amount of voice states that were removed from the caches
288
- */
289
- sweepVoiceStates(filter) {
290
- return this._sweepGuildDirectProp('voiceStates', filter, { outputName: 'voice states' }).items;
291
- }
292
-
293
- /**
294
- * Cancels all sweeping intervals
295
- * @returns {void}
296
- */
297
- destroy() {
298
- for (const key of SweeperKeys) {
299
- if (this.intervals[key]) clearInterval(this.intervals[key]);
300
- }
301
- }
302
-
303
- /**
304
- * Options for generating a filter function based on lifetime
305
- * @typedef {Object} LifetimeFilterOptions
306
- * @property {number} [lifetime=14400] How long, in seconds, an entry should stay in the collection
307
- * before it is considered sweepable.
308
- * @property {Function} [getComparisonTimestamp=e => e?.createdTimestamp] A function that takes an entry, key,
309
- * and the collection and returns a timestamp to compare against in order to determine the lifetime of the entry.
310
- * @property {Function} [excludeFromSweep=() => false] A function that takes an entry, key, and the collection
311
- * and returns a boolean, `true` when the entry should not be checked for sweepability.
312
- */
313
-
314
- /**
315
- * Create a sweepFilter function that uses a lifetime to determine sweepability.
316
- * @param {LifetimeFilterOptions} [options={}] The options used to generate the filter function
317
- * @returns {GlobalSweepFilter}
318
- */
319
- static filterByLifetime({
320
- lifetime = 14400,
321
- getComparisonTimestamp = e => e?.createdTimestamp,
322
- excludeFromSweep = () => false,
323
- } = {}) {
324
- if (typeof lifetime !== 'number') {
325
- throw new TypeError('INVALID_TYPE', 'lifetime', 'number');
326
- }
327
- if (typeof getComparisonTimestamp !== 'function') {
328
- throw new TypeError('INVALID_TYPE', 'getComparisonTimestamp', 'function');
329
- }
330
- if (typeof excludeFromSweep !== 'function') {
331
- throw new TypeError('INVALID_TYPE', 'excludeFromSweep', 'function');
332
- }
333
- return () => {
334
- if (lifetime <= 0) return null;
335
- const lifetimeMs = lifetime * 1_000;
336
- const now = Date.now();
337
- return (entry, key, coll) => {
338
- if (excludeFromSweep(entry, key, coll)) {
339
- return false;
340
- }
341
- const comparisonTimestamp = getComparisonTimestamp(entry, key, coll);
342
- if (!comparisonTimestamp || typeof comparisonTimestamp !== 'number') return false;
343
- return now - comparisonTimestamp > lifetimeMs;
344
- };
345
- };
346
- }
347
-
348
- /**
349
- * Creates a sweep filter that sweeps archived threads
350
- * @param {number} [lifetime=14400] How long a thread has to be archived to be valid for sweeping
351
- * @returns {GlobalSweepFilter}
352
- */
353
- static archivedThreadSweepFilter(lifetime = 14400) {
354
- return this.filterByLifetime({
355
- lifetime,
356
- getComparisonTimestamp: e => e.archiveTimestamp,
357
- excludeFromSweep: e => !e.archived,
358
- });
359
- }
360
-
361
- /**
362
- * Creates a sweep filter that sweeps expired invites
363
- * @param {number} [lifetime=14400] How long ago an invite has to have expired to be valid for sweeping
364
- * @returns {GlobalSweepFilter}
365
- */
366
- static expiredInviteSweepFilter(lifetime = 14400) {
367
- return this.filterByLifetime({
368
- lifetime,
369
- getComparisonTimestamp: i => i.expiresTimestamp,
370
- });
371
- }
372
-
373
- /**
374
- * Creates a sweep filter that sweeps outdated messages (edits taken into account)
375
- * @param {number} [lifetime=3600] How long ago a message has to have been sent or edited to be valid for sweeping
376
- * @returns {GlobalSweepFilter}
377
- */
378
- static outdatedMessageSweepFilter(lifetime = 3600) {
379
- return this.filterByLifetime({
380
- lifetime,
381
- getComparisonTimestamp: m => m.editedTimestamp ?? m.createdTimestamp,
382
- });
383
- }
384
-
385
- /**
386
- * Configuration options for emitting the cache sweep client event
387
- * @typedef {Object} SweepEventOptions
388
- * @property {boolean} [emit=true] Whether to emit the client event in this method
389
- * @property {string} [outputName] A name to output in the client event if it should differ from the key
390
- * @private
391
- */
392
-
393
- /**
394
- * Sweep a direct sub property of all guilds
395
- * @param {string} key The name of the property
396
- * @param {Function} filter Filter function passed to sweep
397
- * @param {SweepEventOptions} [eventOptions={}] Options for the Client event emitted here
398
- * @returns {Object} Object containing the number of guilds swept and the number of items swept
399
- * @private
400
- */
401
- _sweepGuildDirectProp(key, filter, { emit = true, outputName } = {}) {
402
- if (typeof filter !== 'function') {
403
- throw new TypeError('INVALID_TYPE', 'filter', 'function');
404
- }
405
-
406
- let guilds = 0;
407
- let items = 0;
408
-
409
- for (const guild of this.client.guilds.cache.values()) {
410
- const { cache } = guild[key];
411
-
412
- guilds++;
413
- items += cache.sweep(filter);
414
- }
415
-
416
- if (emit) {
417
- this.client.emit(Events.CACHE_SWEEP, `Swept ${items} ${outputName ?? key} in ${guilds} guilds.`);
418
- }
419
-
420
- return { guilds, items };
421
- }
422
-
423
- /**
424
- * Validates a set of properties
425
- * @param {string} key Key of the options object to check
426
- * @private
427
- */
428
- _validateProperties(key) {
429
- const props = this.options[key];
430
- if (typeof props !== 'object') {
431
- throw new TypeError('INVALID_TYPE', `sweepers.${key}`, 'object', true);
432
- }
433
- if (typeof props.interval !== 'number') {
434
- throw new TypeError('INVALID_TYPE', `sweepers.${key}.interval`, 'number');
435
- }
436
- // Invites, Messages, and Threads can be provided a lifetime parameter, which we use to generate the filter
437
- if (['invites', 'messages', 'threads'].includes(key) && !('filter' in props)) {
438
- if (typeof props.lifetime !== 'number') {
439
- throw new TypeError('INVALID_TYPE', `sweepers.${key}.lifetime`, 'number');
440
- }
441
- return;
442
- }
443
- if (typeof props.filter !== 'function') {
444
- throw new TypeError('INVALID_TYPE', `sweepers.${key}.filter`, 'function');
445
- }
446
- }
447
-
448
- /**
449
- * Initialize an interval for sweeping
450
- * @param {string} intervalKey The name of the property that stores the interval for this sweeper
451
- * @param {string} sweepKey The name of the function that sweeps the desired caches
452
- * @param {Object} opts Validated options for a sweep
453
- * @private
454
- */
455
- _initInterval(intervalKey, sweepKey, opts) {
456
- if (opts.interval <= 0 || opts.interval === Infinity) return;
457
- this.intervals[intervalKey] = setInterval(() => {
458
- const sweepFn = opts.filter();
459
- if (sweepFn === null) return;
460
- if (typeof sweepFn !== 'function') throw new TypeError('SWEEP_FILTER_RETURN');
461
- this[sweepKey](sweepFn);
462
- }, opts.interval * 1_000).unref();
463
- }
464
- }
465
-
466
- module.exports = Sweepers;
1
+ 'use strict';
2
+
3
+ const { setInterval } = require('node:timers');
4
+ const { Events, ThreadChannelTypes, SweeperKeys } = require('./Constants');
5
+ const { TypeError } = require('../errors/DJSError.js');
6
+
7
+ /**
8
+ * @typedef {Function} GlobalSweepFilter
9
+ * @returns {Function|null} Return `null` to skip sweeping, otherwise a function passed to `sweep()`,
10
+ * See {@link [Collection#sweep](https://discord.js.org/docs/packages/collection/stable/Collection:Class#sweep)}
11
+ * for the definition of this function.
12
+ */
13
+
14
+ /**
15
+ * A container for all cache sweeping intervals and their associated sweep methods.
16
+ */
17
+ class Sweepers {
18
+ constructor(client, options) {
19
+ /**
20
+ * The client that instantiated this
21
+ * @type {Client}
22
+ * @readonly
23
+ */
24
+ Object.defineProperty(this, 'client', { value: client });
25
+
26
+ /**
27
+ * The options the sweepers were instantiated with
28
+ * @type {SweeperOptions}
29
+ */
30
+ this.options = options;
31
+
32
+ /**
33
+ * A record of interval timeout that is used to sweep the indicated items, or null if not being swept
34
+ * @type {Object<SweeperKey, ?Timeout>}
35
+ */
36
+ this.intervals = Object.fromEntries(SweeperKeys.map(key => [key, null]));
37
+
38
+ for (const key of SweeperKeys) {
39
+ if (!(key in options)) continue;
40
+
41
+ this._validateProperties(key);
42
+
43
+ const clonedOptions = { ...this.options[key] };
44
+
45
+ // Handle cases that have a "lifetime"
46
+ if (!('filter' in clonedOptions)) {
47
+ switch (key) {
48
+ case 'invites':
49
+ clonedOptions.filter = this.constructor.expiredInviteSweepFilter(clonedOptions.lifetime);
50
+ break;
51
+ case 'messages':
52
+ clonedOptions.filter = this.constructor.outdatedMessageSweepFilter(clonedOptions.lifetime);
53
+ break;
54
+ case 'threads':
55
+ clonedOptions.filter = this.constructor.archivedThreadSweepFilter(clonedOptions.lifetime);
56
+ }
57
+ }
58
+
59
+ this._initInterval(key, `sweep${key[0].toUpperCase()}${key.slice(1)}`, clonedOptions);
60
+ }
61
+ }
62
+
63
+ /**
64
+ * Sweeps all guild and global application commands and removes the ones which are indicated by the filter.
65
+ * @param {Function} filter The function used to determine which commands will be removed from the caches.
66
+ * @returns {number} Amount of commands that were removed from the caches
67
+ */
68
+ sweepApplicationCommands(filter) {
69
+ const { guilds, items: guildCommands } = this._sweepGuildDirectProp('commands', filter, { emit: false });
70
+
71
+ const globalCommands = this.client.application?.commands.cache.sweep(filter) ?? 0;
72
+
73
+ this.client.emit(
74
+ Events.CACHE_SWEEP,
75
+ `Swept ${globalCommands} global application commands and ${guildCommands} guild commands in ${guilds} guilds.`,
76
+ );
77
+ return guildCommands + globalCommands;
78
+ }
79
+
80
+ /**
81
+ * Sweeps all auto moderation rules and removes the ones which are indicated by the filter.
82
+ * @param {Function} filter The function used to determine
83
+ * which auto moderation rules will be removed from the caches
84
+ * @returns {number} Amount of auto moderation rules that were removed from the caches
85
+ */
86
+ sweepAutoModerationRules(filter) {
87
+ return this._sweepGuildDirectProp('autoModerationRules', filter).items;
88
+ }
89
+
90
+ /**
91
+ * Sweeps all guild bans and removes the ones which are indicated by the filter.
92
+ * @param {Function} filter The function used to determine which bans will be removed from the caches.
93
+ * @returns {number} Amount of bans that were removed from the caches
94
+ */
95
+ sweepBans(filter) {
96
+ return this._sweepGuildDirectProp('bans', filter).items;
97
+ }
98
+
99
+ /**
100
+ * Sweeps all guild emojis and removes the ones which are indicated by the filter.
101
+ * @param {Function} filter The function used to determine which emojis will be removed from the caches.
102
+ * @returns {number} Amount of emojis that were removed from the caches
103
+ */
104
+ sweepEmojis(filter) {
105
+ return this._sweepGuildDirectProp('emojis', filter).items;
106
+ }
107
+
108
+ /**
109
+ * Sweeps all guild invites and removes the ones which are indicated by the filter.
110
+ * @param {Function} filter The function used to determine which invites will be removed from the caches.
111
+ * @returns {number} Amount of invites that were removed from the caches
112
+ */
113
+ sweepInvites(filter) {
114
+ return this._sweepGuildDirectProp('invites', filter).items;
115
+ }
116
+
117
+ /**
118
+ * Sweeps all guild members and removes the ones which are indicated by the filter.
119
+ * <info>It is highly recommended to keep the client guild member cached</info>
120
+ * @param {Function} filter The function used to determine which guild members will be removed from the caches.
121
+ * @returns {number} Amount of guild members that were removed from the caches
122
+ */
123
+ sweepGuildMembers(filter) {
124
+ return this._sweepGuildDirectProp('members', filter, { outputName: 'guild members' }).items;
125
+ }
126
+
127
+ /**
128
+ * Sweeps all text-based channels' messages and removes the ones which are indicated by the filter.
129
+ * @param {Function} filter The function used to determine which messages will be removed from the caches.
130
+ * @returns {number} Amount of messages that were removed from the caches
131
+ * @example
132
+ * // Remove all messages older than 1800 seconds from the messages cache
133
+ * const amount = sweepers.sweepMessages(
134
+ * Sweepers.filterByLifetime({
135
+ * lifetime: 1800,
136
+ * getComparisonTimestamp: m => m.editedTimestamp ?? m.createdTimestamp,
137
+ * })(),
138
+ * );
139
+ * console.log(`Successfully removed ${amount} messages from the cache.`);
140
+ */
141
+ sweepMessages(filter) {
142
+ if (typeof filter !== 'function') {
143
+ throw new TypeError('INVALID_TYPE', 'filter', 'function');
144
+ }
145
+ let channels = 0;
146
+ let messages = 0;
147
+
148
+ for (const channel of this.client.channels.cache.values()) {
149
+ if (!channel.isText()) continue;
150
+
151
+ channels++;
152
+ messages += channel.messages.cache.sweep(filter);
153
+ }
154
+ this.client.emit(Events.CACHE_SWEEP, `Swept ${messages} messages in ${channels} text-based channels.`);
155
+ return messages;
156
+ }
157
+
158
+ /**
159
+ * Sweeps all presences and removes the ones which are indicated by the filter.
160
+ * @param {Function} filter The function used to determine which presences will be removed from the caches.
161
+ * @returns {number} Amount of presences that were removed from the caches
162
+ */
163
+ sweepPresences(filter) {
164
+ return this._sweepGuildDirectProp('presences', filter).items;
165
+ }
166
+
167
+ /**
168
+ * Sweeps all message reactions and removes the ones which are indicated by the filter.
169
+ * @param {Function} filter The function used to determine which reactions will be removed from the caches.
170
+ * @returns {number} Amount of reactions that were removed from the caches
171
+ */
172
+ sweepReactions(filter) {
173
+ if (typeof filter !== 'function') {
174
+ throw new TypeError('INVALID_TYPE', 'filter', 'function');
175
+ }
176
+ let channels = 0;
177
+ let messages = 0;
178
+ let reactions = 0;
179
+
180
+ for (const channel of this.client.channels.cache.values()) {
181
+ if (!channel.isText()) continue;
182
+ channels++;
183
+
184
+ for (const message of channel.messages.cache.values()) {
185
+ messages++;
186
+ reactions += message.reactions.cache.sweep(filter);
187
+ }
188
+ }
189
+ this.client.emit(
190
+ Events.CACHE_SWEEP,
191
+ `Swept ${reactions} reactions on ${messages} messages in ${channels} text-based channels.`,
192
+ );
193
+ return reactions;
194
+ }
195
+
196
+ /**
197
+ * Sweeps all guild stage instances and removes the ones which are indicated by the filter.
198
+ * @param {Function} filter The function used to determine which stage instances will be removed from the caches.
199
+ * @returns {number} Amount of stage instances that were removed from the caches
200
+ */
201
+ sweepStageInstances(filter) {
202
+ return this._sweepGuildDirectProp('stageInstances', filter, { outputName: 'stage instances' }).items;
203
+ }
204
+
205
+ /**
206
+ * Sweeps all guild stickers and removes the ones which are indicated by the filter.
207
+ * @param {Function} filter The function used to determine which stickers will be removed from the caches.
208
+ * @returns {number} Amount of stickers that were removed from the caches
209
+ */
210
+ sweepStickers(filter) {
211
+ return this._sweepGuildDirectProp('stickers', filter).items;
212
+ }
213
+
214
+ /**
215
+ * Sweeps all thread members and removes the ones which are indicated by the filter.
216
+ * <info>It is highly recommended to keep the client thread member cached</info>
217
+ * @param {Function} filter The function used to determine which thread members will be removed from the caches.
218
+ * @returns {number} Amount of thread members that were removed from the caches
219
+ */
220
+ sweepThreadMembers(filter) {
221
+ if (typeof filter !== 'function') {
222
+ throw new TypeError('INVALID_TYPE', 'filter', 'function');
223
+ }
224
+
225
+ let threads = 0;
226
+ let members = 0;
227
+ for (const channel of this.client.channels.cache.values()) {
228
+ if (!ThreadChannelTypes.includes(channel.type)) continue;
229
+ threads++;
230
+ members += channel.members.cache.sweep(filter);
231
+ }
232
+ this.client.emit(Events.CACHE_SWEEP, `Swept ${members} thread members in ${threads} threads.`);
233
+ return members;
234
+ }
235
+
236
+ /**
237
+ * Sweeps all threads and removes the ones which are indicated by the filter.
238
+ * @param {Function} filter The function used to determine which threads will be removed from the caches.
239
+ * @returns {number} filter Amount of threads that were removed from the caches
240
+ * @example
241
+ * // Remove all threads archived greater than 1 day ago from all the channel caches
242
+ * const amount = sweepers.sweepThreads(
243
+ * Sweepers.filterByLifetime({
244
+ * getComparisonTimestamp: t => t.archivedTimestamp,
245
+ * excludeFromSweep: t => !t.archived,
246
+ * })(),
247
+ * );
248
+ * console.log(`Successfully removed ${amount} threads from the cache.`);
249
+ */
250
+ sweepThreads(filter) {
251
+ if (typeof filter !== 'function') {
252
+ throw new TypeError('INVALID_TYPE', 'filter', 'function');
253
+ }
254
+
255
+ let threads = 0;
256
+ for (const [key, val] of this.client.channels.cache.entries()) {
257
+ if (!ThreadChannelTypes.includes(val.type)) continue;
258
+ if (filter(val, key, this.client.channels.cache)) {
259
+ threads++;
260
+ this.client.channels._remove(key);
261
+ }
262
+ }
263
+ this.client.emit(Events.CACHE_SWEEP, `Swept ${threads} threads.`);
264
+ return threads;
265
+ }
266
+
267
+ /**
268
+ * Sweeps all users and removes the ones which are indicated by the filter.
269
+ * @param {Function} filter The function used to determine which users will be removed from the caches.
270
+ * @returns {number} Amount of users that were removed from the caches
271
+ */
272
+ sweepUsers(filter) {
273
+ if (typeof filter !== 'function') {
274
+ throw new TypeError('INVALID_TYPE', 'filter', 'function');
275
+ }
276
+
277
+ const users = this.client.users.cache.sweep(filter);
278
+
279
+ this.client.emit(Events.CACHE_SWEEP, `Swept ${users} users.`);
280
+
281
+ return users;
282
+ }
283
+
284
+ /**
285
+ * Sweeps all guild voice states and removes the ones which are indicated by the filter.
286
+ * @param {Function} filter The function used to determine which voice states will be removed from the caches.
287
+ * @returns {number} Amount of voice states that were removed from the caches
288
+ */
289
+ sweepVoiceStates(filter) {
290
+ return this._sweepGuildDirectProp('voiceStates', filter, { outputName: 'voice states' }).items;
291
+ }
292
+
293
+ /**
294
+ * Cancels all sweeping intervals
295
+ * @returns {void}
296
+ */
297
+ destroy() {
298
+ for (const key of SweeperKeys) {
299
+ if (this.intervals[key]) clearInterval(this.intervals[key]);
300
+ }
301
+ }
302
+
303
+ /**
304
+ * Options for generating a filter function based on lifetime
305
+ * @typedef {Object} LifetimeFilterOptions
306
+ * @property {number} [lifetime=14400] How long, in seconds, an entry should stay in the collection
307
+ * before it is considered sweepable.
308
+ * @property {Function} [getComparisonTimestamp=e => e?.createdTimestamp] A function that takes an entry, key,
309
+ * and the collection and returns a timestamp to compare against in order to determine the lifetime of the entry.
310
+ * @property {Function} [excludeFromSweep=() => false] A function that takes an entry, key, and the collection
311
+ * and returns a boolean, `true` when the entry should not be checked for sweepability.
312
+ */
313
+
314
+ /**
315
+ * Create a sweepFilter function that uses a lifetime to determine sweepability.
316
+ * @param {LifetimeFilterOptions} [options={}] The options used to generate the filter function
317
+ * @returns {GlobalSweepFilter}
318
+ */
319
+ static filterByLifetime({
320
+ lifetime = 14400,
321
+ getComparisonTimestamp = e => e?.createdTimestamp,
322
+ excludeFromSweep = () => false,
323
+ } = {}) {
324
+ if (typeof lifetime !== 'number') {
325
+ throw new TypeError('INVALID_TYPE', 'lifetime', 'number');
326
+ }
327
+ if (typeof getComparisonTimestamp !== 'function') {
328
+ throw new TypeError('INVALID_TYPE', 'getComparisonTimestamp', 'function');
329
+ }
330
+ if (typeof excludeFromSweep !== 'function') {
331
+ throw new TypeError('INVALID_TYPE', 'excludeFromSweep', 'function');
332
+ }
333
+ return () => {
334
+ if (lifetime <= 0) return null;
335
+ const lifetimeMs = lifetime * 1_000;
336
+ const now = Date.now();
337
+ return (entry, key, coll) => {
338
+ if (excludeFromSweep(entry, key, coll)) {
339
+ return false;
340
+ }
341
+ const comparisonTimestamp = getComparisonTimestamp(entry, key, coll);
342
+ if (!comparisonTimestamp || typeof comparisonTimestamp !== 'number') return false;
343
+ return now - comparisonTimestamp > lifetimeMs;
344
+ };
345
+ };
346
+ }
347
+
348
+ /**
349
+ * Creates a sweep filter that sweeps archived threads
350
+ * @param {number} [lifetime=14400] How long a thread has to be archived to be valid for sweeping
351
+ * @returns {GlobalSweepFilter}
352
+ */
353
+ static archivedThreadSweepFilter(lifetime = 14400) {
354
+ return this.filterByLifetime({
355
+ lifetime,
356
+ getComparisonTimestamp: e => e.archiveTimestamp,
357
+ excludeFromSweep: e => !e.archived,
358
+ });
359
+ }
360
+
361
+ /**
362
+ * Creates a sweep filter that sweeps expired invites
363
+ * @param {number} [lifetime=14400] How long ago an invite has to have expired to be valid for sweeping
364
+ * @returns {GlobalSweepFilter}
365
+ */
366
+ static expiredInviteSweepFilter(lifetime = 14400) {
367
+ return this.filterByLifetime({
368
+ lifetime,
369
+ getComparisonTimestamp: i => i.expiresTimestamp,
370
+ });
371
+ }
372
+
373
+ /**
374
+ * Creates a sweep filter that sweeps outdated messages (edits taken into account)
375
+ * @param {number} [lifetime=3600] How long ago a message has to have been sent or edited to be valid for sweeping
376
+ * @returns {GlobalSweepFilter}
377
+ */
378
+ static outdatedMessageSweepFilter(lifetime = 3600) {
379
+ return this.filterByLifetime({
380
+ lifetime,
381
+ getComparisonTimestamp: m => m.editedTimestamp ?? m.createdTimestamp,
382
+ });
383
+ }
384
+
385
+ /**
386
+ * Configuration options for emitting the cache sweep client event
387
+ * @typedef {Object} SweepEventOptions
388
+ * @property {boolean} [emit=true] Whether to emit the client event in this method
389
+ * @property {string} [outputName] A name to output in the client event if it should differ from the key
390
+ * @private
391
+ */
392
+
393
+ /**
394
+ * Sweep a direct sub property of all guilds
395
+ * @param {string} key The name of the property
396
+ * @param {Function} filter Filter function passed to sweep
397
+ * @param {SweepEventOptions} [eventOptions={}] Options for the Client event emitted here
398
+ * @returns {Object} Object containing the number of guilds swept and the number of items swept
399
+ * @private
400
+ */
401
+ _sweepGuildDirectProp(key, filter, { emit = true, outputName } = {}) {
402
+ if (typeof filter !== 'function') {
403
+ throw new TypeError('INVALID_TYPE', 'filter', 'function');
404
+ }
405
+
406
+ let guilds = 0;
407
+ let items = 0;
408
+
409
+ for (const guild of this.client.guilds.cache.values()) {
410
+ const { cache } = guild[key];
411
+
412
+ guilds++;
413
+ items += cache.sweep(filter);
414
+ }
415
+
416
+ if (emit) {
417
+ this.client.emit(Events.CACHE_SWEEP, `Swept ${items} ${outputName ?? key} in ${guilds} guilds.`);
418
+ }
419
+
420
+ return { guilds, items };
421
+ }
422
+
423
+ /**
424
+ * Validates a set of properties
425
+ * @param {string} key Key of the options object to check
426
+ * @private
427
+ */
428
+ _validateProperties(key) {
429
+ const props = this.options[key];
430
+ if (typeof props !== 'object') {
431
+ throw new TypeError('INVALID_TYPE', `sweepers.${key}`, 'object', true);
432
+ }
433
+ if (typeof props.interval !== 'number') {
434
+ throw new TypeError('INVALID_TYPE', `sweepers.${key}.interval`, 'number');
435
+ }
436
+ // Invites, Messages, and Threads can be provided a lifetime parameter, which we use to generate the filter
437
+ if (['invites', 'messages', 'threads'].includes(key) && !('filter' in props)) {
438
+ if (typeof props.lifetime !== 'number') {
439
+ throw new TypeError('INVALID_TYPE', `sweepers.${key}.lifetime`, 'number');
440
+ }
441
+ return;
442
+ }
443
+ if (typeof props.filter !== 'function') {
444
+ throw new TypeError('INVALID_TYPE', `sweepers.${key}.filter`, 'function');
445
+ }
446
+ }
447
+
448
+ /**
449
+ * Initialize an interval for sweeping
450
+ * @param {string} intervalKey The name of the property that stores the interval for this sweeper
451
+ * @param {string} sweepKey The name of the function that sweeps the desired caches
452
+ * @param {Object} opts Validated options for a sweep
453
+ * @private
454
+ */
455
+ _initInterval(intervalKey, sweepKey, opts) {
456
+ if (opts.interval <= 0 || opts.interval === Infinity) return;
457
+ this.intervals[intervalKey] = setInterval(() => {
458
+ const sweepFn = opts.filter();
459
+ if (sweepFn === null) return;
460
+ if (typeof sweepFn !== 'function') throw new TypeError('SWEEP_FILTER_RETURN');
461
+ this[sweepKey](sweepFn);
462
+ }, opts.interval * 1_000).unref();
463
+ }
464
+ }
465
+
466
+ module.exports = Sweepers;