djs-selfbot-v13 3.1.8 → 3.7.1

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