djs-selfbot-v13 1.0.0

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 (348) hide show
  1. package/LICENSE +674 -0
  2. package/README.md +132 -0
  3. package/package.json +100 -0
  4. package/src/WebSocket.js +39 -0
  5. package/src/client/BaseClient.js +87 -0
  6. package/src/client/Client.js +1117 -0
  7. package/src/client/WebhookClient.js +61 -0
  8. package/src/client/actions/Action.js +115 -0
  9. package/src/client/actions/ActionsManager.js +72 -0
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  11. package/src/client/actions/AutoModerationActionExecution.js +26 -0
  12. package/src/client/actions/AutoModerationRuleCreate.js +27 -0
  13. package/src/client/actions/AutoModerationRuleDelete.js +31 -0
  14. package/src/client/actions/AutoModerationRuleUpdate.js +29 -0
  15. package/src/client/actions/ChannelCreate.js +23 -0
  16. package/src/client/actions/ChannelDelete.js +39 -0
  17. package/src/client/actions/ChannelUpdate.js +43 -0
  18. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
  19. package/src/client/actions/GuildBanAdd.js +20 -0
  20. package/src/client/actions/GuildBanRemove.js +25 -0
  21. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
  22. package/src/client/actions/GuildDelete.js +65 -0
  23. package/src/client/actions/GuildEmojiCreate.js +20 -0
  24. package/src/client/actions/GuildEmojiDelete.js +21 -0
  25. package/src/client/actions/GuildEmojiUpdate.js +20 -0
  26. package/src/client/actions/GuildEmojisUpdate.js +34 -0
  27. package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
  28. package/src/client/actions/GuildMemberRemove.js +33 -0
  29. package/src/client/actions/GuildMemberUpdate.js +44 -0
  30. package/src/client/actions/GuildRoleCreate.js +25 -0
  31. package/src/client/actions/GuildRoleDelete.js +31 -0
  32. package/src/client/actions/GuildRoleUpdate.js +39 -0
  33. package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
  34. package/src/client/actions/GuildScheduledEventCreate.js +27 -0
  35. package/src/client/actions/GuildScheduledEventDelete.js +31 -0
  36. package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
  37. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
  38. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
  39. package/src/client/actions/GuildStickerCreate.js +20 -0
  40. package/src/client/actions/GuildStickerDelete.js +21 -0
  41. package/src/client/actions/GuildStickerUpdate.js +20 -0
  42. package/src/client/actions/GuildStickersUpdate.js +34 -0
  43. package/src/client/actions/GuildUpdate.js +33 -0
  44. package/src/client/actions/InteractionCreate.js +115 -0
  45. package/src/client/actions/InviteCreate.js +28 -0
  46. package/src/client/actions/InviteDelete.js +30 -0
  47. package/src/client/actions/MessageCreate.js +50 -0
  48. package/src/client/actions/MessageDelete.js +32 -0
  49. package/src/client/actions/MessageDeleteBulk.js +46 -0
  50. package/src/client/actions/MessageReactionAdd.js +56 -0
  51. package/src/client/actions/MessageReactionRemove.js +45 -0
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  54. package/src/client/actions/MessageUpdate.js +26 -0
  55. package/src/client/actions/PresenceUpdate.js +45 -0
  56. package/src/client/actions/StageInstanceCreate.js +28 -0
  57. package/src/client/actions/StageInstanceDelete.js +33 -0
  58. package/src/client/actions/StageInstanceUpdate.js +30 -0
  59. package/src/client/actions/ThreadCreate.js +24 -0
  60. package/src/client/actions/ThreadDelete.js +32 -0
  61. package/src/client/actions/ThreadListSync.js +59 -0
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  64. package/src/client/actions/TypingStart.js +29 -0
  65. package/src/client/actions/UserUpdate.js +35 -0
  66. package/src/client/actions/VoiceStateUpdate.js +57 -0
  67. package/src/client/actions/WebhooksUpdate.js +20 -0
  68. package/src/client/voice/ClientVoiceManager.js +51 -0
  69. package/src/client/websocket/WebSocketManager.js +412 -0
  70. package/src/client/websocket/WebSocketShard.js +905 -0
  71. package/src/client/websocket/handlers/APPLICATION_COMMAND_AUTOCOMPLETE_RESPONSE.js +23 -0
  72. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  73. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  74. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  75. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  76. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  77. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  78. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  79. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  80. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  81. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  82. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  83. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  84. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  85. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  86. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +16 -0
  87. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  88. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  89. package/src/client/websocket/handlers/GUILD_APPLICATION_COMMANDS_UPDATE.js +11 -0
  90. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  91. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  92. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  93. package/src/client/websocket/handlers/GUILD_CREATE.js +46 -0
  94. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  95. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  96. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  97. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  98. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  99. package/src/client/websocket/handlers/GUILD_MEMBER_LIST_UPDATE.js +55 -0
  100. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  101. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  102. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  103. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  104. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  105. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  106. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  107. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  108. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  109. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  110. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUNDS_UPDATE.js +0 -0
  111. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_CREATE.js +0 -0
  112. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_DELETE.js +0 -0
  113. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_UPDATE.js +0 -0
  114. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  115. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  116. package/src/client/websocket/handlers/INTERACTION_CREATE.js +16 -0
  117. package/src/client/websocket/handlers/INTERACTION_FAILURE.js +18 -0
  118. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +11 -0
  119. package/src/client/websocket/handlers/INTERACTION_SUCCESS.js +30 -0
  120. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  121. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  122. package/src/client/websocket/handlers/MESSAGE_ACK.js +16 -0
  123. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  124. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  125. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  126. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
  127. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  128. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  129. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  130. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  131. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  132. package/src/client/websocket/handlers/READY.js +170 -0
  133. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +17 -0
  134. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +15 -0
  135. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +18 -0
  136. package/src/client/websocket/handlers/RESUMED.js +14 -0
  137. package/src/client/websocket/handlers/SOUNDBOARD_SOUNDS.js +0 -0
  138. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  139. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  140. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  141. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  142. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  143. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  144. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  145. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  146. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  147. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  148. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +12 -0
  149. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  150. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +9 -0
  151. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  152. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +0 -0
  153. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  154. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  155. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  156. package/src/client/websocket/handlers/index.js +86 -0
  157. package/src/errors/DJSError.js +61 -0
  158. package/src/errors/Messages.js +227 -0
  159. package/src/errors/index.js +4 -0
  160. package/src/index.js +189 -0
  161. package/src/managers/ApplicationCommandManager.js +267 -0
  162. package/src/managers/ApplicationCommandPermissionsManager.js +425 -0
  163. package/src/managers/AutoModerationRuleManager.js +296 -0
  164. package/src/managers/BaseGuildEmojiManager.js +80 -0
  165. package/src/managers/BaseManager.js +19 -0
  166. package/src/managers/BillingManager.js +66 -0
  167. package/src/managers/CachedManager.js +71 -0
  168. package/src/managers/ChannelManager.js +139 -0
  169. package/src/managers/ClientUserSettingManager.js +490 -0
  170. package/src/managers/DataManager.js +61 -0
  171. package/src/managers/DeveloperPortalManager.js +104 -0
  172. package/src/managers/GuildApplicationCommandManager.js +28 -0
  173. package/src/managers/GuildBanManager.js +204 -0
  174. package/src/managers/GuildChannelManager.js +502 -0
  175. package/src/managers/GuildEmojiManager.js +171 -0
  176. package/src/managers/GuildEmojiRoleManager.js +118 -0
  177. package/src/managers/GuildFolderManager.js +24 -0
  178. package/src/managers/GuildForumThreadManager.js +114 -0
  179. package/src/managers/GuildInviteManager.js +213 -0
  180. package/src/managers/GuildManager.js +304 -0
  181. package/src/managers/GuildMemberManager.js +769 -0
  182. package/src/managers/GuildMemberRoleManager.js +191 -0
  183. package/src/managers/GuildScheduledEventManager.js +296 -0
  184. package/src/managers/GuildSettingManager.js +148 -0
  185. package/src/managers/GuildStickerManager.js +179 -0
  186. package/src/managers/GuildTextThreadManager.js +98 -0
  187. package/src/managers/InteractionManager.js +39 -0
  188. package/src/managers/MessageManager.js +393 -0
  189. package/src/managers/PermissionOverwriteManager.js +166 -0
  190. package/src/managers/PresenceManager.js +58 -0
  191. package/src/managers/ReactionManager.js +67 -0
  192. package/src/managers/ReactionUserManager.js +71 -0
  193. package/src/managers/RelationshipManager.js +258 -0
  194. package/src/managers/RoleManager.js +352 -0
  195. package/src/managers/SessionManager.js +57 -0
  196. package/src/managers/StageInstanceManager.js +162 -0
  197. package/src/managers/ThreadManager.js +207 -0
  198. package/src/managers/ThreadMemberManager.js +186 -0
  199. package/src/managers/UserManager.js +150 -0
  200. package/src/managers/VoiceStateManager.js +37 -0
  201. package/src/rest/APIRequest.js +132 -0
  202. package/src/rest/APIRouter.js +53 -0
  203. package/src/rest/CaptchaSolver.js +132 -0
  204. package/src/rest/DiscordAPIError.js +103 -0
  205. package/src/rest/HTTPError.js +62 -0
  206. package/src/rest/RESTManager.js +82 -0
  207. package/src/rest/RateLimitError.js +55 -0
  208. package/src/rest/RequestHandler.js +430 -0
  209. package/src/sharding/Shard.js +443 -0
  210. package/src/sharding/ShardClientUtil.js +275 -0
  211. package/src/sharding/ShardingManager.js +318 -0
  212. package/src/structures/AnonymousGuild.js +98 -0
  213. package/src/structures/ApplicationCommand.js +1030 -0
  214. package/src/structures/ApplicationRoleConnectionMetadata.js +45 -0
  215. package/src/structures/AutoModerationActionExecution.js +89 -0
  216. package/src/structures/AutoModerationRule.js +294 -0
  217. package/src/structures/AutocompleteInteraction.js +106 -0
  218. package/src/structures/Base.js +43 -0
  219. package/src/structures/BaseCommandInteraction.js +211 -0
  220. package/src/structures/BaseGuild.js +116 -0
  221. package/src/structures/BaseGuildEmoji.js +56 -0
  222. package/src/structures/BaseGuildTextChannel.js +193 -0
  223. package/src/structures/BaseGuildVoiceChannel.js +243 -0
  224. package/src/structures/BaseMessageComponent.js +114 -0
  225. package/src/structures/ButtonInteraction.js +11 -0
  226. package/src/structures/Call.js +58 -0
  227. package/src/structures/CategoryChannel.js +83 -0
  228. package/src/structures/Channel.js +271 -0
  229. package/src/structures/ClientApplication.js +204 -0
  230. package/src/structures/ClientPresence.js +84 -0
  231. package/src/structures/ClientUser.js +634 -0
  232. package/src/structures/CommandInteraction.js +41 -0
  233. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  234. package/src/structures/ContextMenuInteraction.js +65 -0
  235. package/src/structures/DMChannel.js +280 -0
  236. package/src/structures/DeveloperPortalApplication.js +520 -0
  237. package/src/structures/DirectoryChannel.js +20 -0
  238. package/src/structures/Emoji.js +148 -0
  239. package/src/structures/ForumChannel.js +271 -0
  240. package/src/structures/Guild.js +1744 -0
  241. package/src/structures/GuildAuditLogs.js +734 -0
  242. package/src/structures/GuildBan.js +59 -0
  243. package/src/structures/GuildBoost.js +108 -0
  244. package/src/structures/GuildChannel.js +454 -0
  245. package/src/structures/GuildEmoji.js +161 -0
  246. package/src/structures/GuildFolder.js +75 -0
  247. package/src/structures/GuildMember.js +686 -0
  248. package/src/structures/GuildPreview.js +191 -0
  249. package/src/structures/GuildPreviewEmoji.js +27 -0
  250. package/src/structures/GuildScheduledEvent.js +441 -0
  251. package/src/structures/GuildTemplate.js +236 -0
  252. package/src/structures/Integration.js +188 -0
  253. package/src/structures/IntegrationApplication.js +96 -0
  254. package/src/structures/Interaction.js +351 -0
  255. package/src/structures/InteractionCollector.js +248 -0
  256. package/src/structures/InteractionResponse.js +114 -0
  257. package/src/structures/InteractionWebhook.js +43 -0
  258. package/src/structures/Invite.js +375 -0
  259. package/src/structures/InviteGuild.js +23 -0
  260. package/src/structures/InviteStageInstance.js +86 -0
  261. package/src/structures/Message.js +1182 -0
  262. package/src/structures/MessageActionRow.js +103 -0
  263. package/src/structures/MessageAttachment.js +193 -0
  264. package/src/structures/MessageButton.js +231 -0
  265. package/src/structures/MessageCollector.js +146 -0
  266. package/src/structures/MessageComponentInteraction.js +120 -0
  267. package/src/structures/MessageContextMenuInteraction.js +20 -0
  268. package/src/structures/MessageEmbed.js +586 -0
  269. package/src/structures/MessageMentions.js +272 -0
  270. package/src/structures/MessagePayload.js +358 -0
  271. package/src/structures/MessageReaction.js +171 -0
  272. package/src/structures/MessageSelectMenu.js +391 -0
  273. package/src/structures/Modal.js +279 -0
  274. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  275. package/src/structures/ModalSubmitInteraction.js +119 -0
  276. package/src/structures/NewsChannel.js +32 -0
  277. package/src/structures/OAuth2Guild.js +28 -0
  278. package/src/structures/PartialGroupDMChannel.js +433 -0
  279. package/src/structures/PermissionOverwrites.js +196 -0
  280. package/src/structures/Presence.js +443 -0
  281. package/src/structures/ReactionCollector.js +229 -0
  282. package/src/structures/ReactionEmoji.js +31 -0
  283. package/src/structures/RichPresence.js +722 -0
  284. package/src/structures/Role.js +515 -0
  285. package/src/structures/SelectMenuInteraction.js +170 -0
  286. package/src/structures/Session.js +81 -0
  287. package/src/structures/StageChannel.js +104 -0
  288. package/src/structures/StageInstance.js +208 -0
  289. package/src/structures/Sticker.js +310 -0
  290. package/src/structures/StickerPack.js +95 -0
  291. package/src/structures/StoreChannel.js +56 -0
  292. package/src/structures/Team.js +167 -0
  293. package/src/structures/TeamMember.js +71 -0
  294. package/src/structures/TextChannel.js +33 -0
  295. package/src/structures/TextInputComponent.js +201 -0
  296. package/src/structures/ThreadChannel.js +626 -0
  297. package/src/structures/ThreadMember.js +105 -0
  298. package/src/structures/Typing.js +74 -0
  299. package/src/structures/User.js +737 -0
  300. package/src/structures/UserContextMenuInteraction.js +29 -0
  301. package/src/structures/VoiceChannel.js +110 -0
  302. package/src/structures/VoiceRegion.js +53 -0
  303. package/src/structures/VoiceState.js +306 -0
  304. package/src/structures/WebEmbed.js +387 -0
  305. package/src/structures/Webhook.js +461 -0
  306. package/src/structures/WelcomeChannel.js +60 -0
  307. package/src/structures/WelcomeScreen.js +48 -0
  308. package/src/structures/Widget.js +87 -0
  309. package/src/structures/WidgetMember.js +99 -0
  310. package/src/structures/interfaces/Application.js +190 -0
  311. package/src/structures/interfaces/Collector.js +300 -0
  312. package/src/structures/interfaces/InteractionResponses.js +313 -0
  313. package/src/structures/interfaces/TextBasedChannel.js +566 -0
  314. package/src/util/ActivityFlags.js +44 -0
  315. package/src/util/ApplicationFlags.js +76 -0
  316. package/src/util/BitField.js +170 -0
  317. package/src/util/ChannelFlags.js +45 -0
  318. package/src/util/Constants.js +1938 -0
  319. package/src/util/DataResolver.js +145 -0
  320. package/src/util/Formatters.js +214 -0
  321. package/src/util/GuildMemberFlags.js +43 -0
  322. package/src/util/Intents.js +74 -0
  323. package/src/util/LimitedCollection.js +131 -0
  324. package/src/util/MessageFlags.js +54 -0
  325. package/src/util/Options.js +362 -0
  326. package/src/util/Permissions.js +187 -0
  327. package/src/util/PremiumUsageFlags.js +31 -0
  328. package/src/util/PurchasedFlags.js +31 -0
  329. package/src/util/RemoteAuth.js +514 -0
  330. package/src/util/SnowflakeUtil.js +92 -0
  331. package/src/util/Sweepers.js +466 -0
  332. package/src/util/SystemChannelFlags.js +55 -0
  333. package/src/util/ThreadMemberFlags.js +30 -0
  334. package/src/util/UserFlags.js +104 -0
  335. package/src/util/Util.js +763 -0
  336. package/src/util/Voice.js +1456 -0
  337. package/src/util/arRPC/index.js +229 -0
  338. package/src/util/arRPC/process/detectable.json +1 -0
  339. package/src/util/arRPC/process/index.js +102 -0
  340. package/src/util/arRPC/process/native/index.js +5 -0
  341. package/src/util/arRPC/process/native/linux.js +37 -0
  342. package/src/util/arRPC/process/native/win32.js +25 -0
  343. package/src/util/arRPC/transports/ipc.js +281 -0
  344. package/src/util/arRPC/transports/websocket.js +128 -0
  345. package/typings/enums.d.ts +346 -0
  346. package/typings/index.d.ts +7741 -0
  347. package/typings/index.test-d.ts +0 -0
  348. package/typings/rawDataTypes.d.ts +283 -0
@@ -0,0 +1,769 @@
1
+ 'use strict';
2
+
3
+ const { Buffer } = require('node:buffer');
4
+ const { setTimeout } = require('node:timers');
5
+ const { Collection } = require('@discordjs/collection');
6
+ require('lodash.permutations');
7
+ const _ = require('lodash');
8
+ const CachedManager = require('./CachedManager');
9
+ const { Error, TypeError, RangeError } = require('../errors');
10
+ const BaseGuildVoiceChannel = require('../structures/BaseGuildVoiceChannel');
11
+ const { GuildMember } = require('../structures/GuildMember');
12
+ const { Role } = require('../structures/Role');
13
+ const { Events, Opcodes } = require('../util/Constants');
14
+ const { PartialTypes } = require('../util/Constants');
15
+ const DataResolver = require('../util/DataResolver');
16
+ const GuildMemberFlags = require('../util/GuildMemberFlags');
17
+ const SnowflakeUtil = require('../util/SnowflakeUtil');
18
+
19
+ /**
20
+ * Manages API methods for GuildMembers and stores their cache.
21
+ * @extends {CachedManager}
22
+ */
23
+ class GuildMemberManager extends CachedManager {
24
+ constructor(guild, iterable) {
25
+ super(guild.client, GuildMember, iterable);
26
+
27
+ /**
28
+ * The guild this manager belongs to
29
+ * @type {Guild}
30
+ */
31
+ this.guild = guild;
32
+ }
33
+
34
+ /**
35
+ * The cache of this Manager
36
+ * @type {Collection<Snowflake, GuildMember>}
37
+ * @name GuildMemberManager#cache
38
+ */
39
+
40
+ _add(data, cache = true) {
41
+ return super._add(data, cache, { id: data.user.id, extras: [this.guild] });
42
+ }
43
+
44
+ /**
45
+ * Data that resolves to give a GuildMember object. This can be:
46
+ * * A GuildMember object
47
+ * * A User resolvable
48
+ * @typedef {GuildMember|UserResolvable} GuildMemberResolvable
49
+ */
50
+
51
+ /**
52
+ * Resolves a {@link GuildMemberResolvable} to a {@link GuildMember} object.
53
+ * @param {GuildMemberResolvable} member The user that is part of the guild
54
+ * @returns {?GuildMember}
55
+ */
56
+ resolve(member) {
57
+ const memberResolvable = super.resolve(member);
58
+ if (memberResolvable) return memberResolvable;
59
+ const userResolvable = this.client.users.resolveId(member);
60
+ if (userResolvable) return super.resolve(userResolvable);
61
+ return null;
62
+ }
63
+
64
+ /**
65
+ * Resolves a {@link GuildMemberResolvable} to a member id.
66
+ * @param {GuildMemberResolvable} member The user that is part of the guild
67
+ * @returns {?Snowflake}
68
+ */
69
+ resolveId(member) {
70
+ const memberResolvable = super.resolveId(member);
71
+ if (memberResolvable) return memberResolvable;
72
+ const userResolvable = this.client.users.resolveId(member);
73
+ return this.cache.has(userResolvable) ? userResolvable : null;
74
+ }
75
+
76
+ /**
77
+ * Options used to add a user to a guild using OAuth2.
78
+ * @typedef {Object} AddGuildMemberOptions
79
+ * @property {string} accessToken An OAuth2 access token for the user with the `guilds.join` scope granted to the
80
+ * bot's application
81
+ * @property {string} [nick] The nickname to give to the member (requires `MANAGE_NICKNAMES`)
82
+ * @property {Collection<Snowflake, Role>|RoleResolvable[]} [roles] The roles to add to the member
83
+ * (requires `MANAGE_ROLES`)
84
+ * @property {boolean} [mute] Whether the member should be muted (requires `MUTE_MEMBERS`)
85
+ * @property {boolean} [deaf] Whether the member should be deafened (requires `DEAFEN_MEMBERS`)
86
+ * @property {boolean} [force] Whether to skip the cache check and call the API directly
87
+ * @property {boolean} [fetchWhenExisting=true] Whether to fetch the user if not cached and already a member
88
+ */
89
+
90
+ /**
91
+ * Adds a user to the guild using OAuth2. Requires the `CREATE_INSTANT_INVITE` permission.
92
+ * @param {UserResolvable} user The user to add to the guild
93
+ * @param {AddGuildMemberOptions} options Options for adding the user to the guild
94
+ * @returns {Promise<GuildMember|null>}
95
+ */
96
+ async add(user, options) {
97
+ const userId = this.client.users.resolveId(user);
98
+ if (!userId) throw new TypeError('INVALID_TYPE', 'user', 'UserResolvable');
99
+ if (!options.force) {
100
+ const cachedUser = this.cache.get(userId);
101
+ if (cachedUser) return cachedUser;
102
+ }
103
+ const resolvedOptions = {
104
+ access_token: options.accessToken,
105
+ nick: options.nick,
106
+ mute: options.mute,
107
+ deaf: options.deaf,
108
+ };
109
+ if (options.roles) {
110
+ if (!Array.isArray(options.roles) && !(options.roles instanceof Collection)) {
111
+ throw new TypeError('INVALID_TYPE', 'options.roles', 'Array or Collection of Roles or Snowflakes', true);
112
+ }
113
+ const resolvedRoles = [];
114
+ for (const role of options.roles.values()) {
115
+ const resolvedRole = this.guild.roles.resolveId(role);
116
+ if (!resolvedRole) throw new TypeError('INVALID_ELEMENT', 'Array or Collection', 'options.roles', role);
117
+ resolvedRoles.push(resolvedRole);
118
+ }
119
+ resolvedOptions.roles = resolvedRoles;
120
+ }
121
+ const data = await this.client.api.guilds(this.guild.id).members(userId).put({ data: resolvedOptions });
122
+ // Data is an empty buffer if the member is already part of the guild.
123
+ return data instanceof Buffer ? (options.fetchWhenExisting === false ? null : this.fetch(userId)) : this._add(data);
124
+ }
125
+
126
+ /**
127
+ * The client user as a GuildMember of this guild
128
+ * @type {?GuildMember}
129
+ * @readonly
130
+ */
131
+ get me() {
132
+ return (
133
+ this.resolve(this.client.user.id) ??
134
+ (this.client.options.partials.includes(PartialTypes.GUILD_MEMBER)
135
+ ? this._add({ user: { id: this.client.user.id } }, true)
136
+ : null)
137
+ );
138
+ }
139
+
140
+ /**
141
+ * Options used to fetch a single member from a guild.
142
+ * @typedef {BaseFetchOptions} FetchMemberOptions
143
+ * @property {UserResolvable} user The user to fetch
144
+ */
145
+
146
+ /**
147
+ * Options used to fetch multiple members from a guild.
148
+ * @typedef {Object} FetchMembersOptions
149
+ * @property {UserResolvable|UserResolvable[]} user The user(s) to fetch
150
+ * @property {?string} query Limit fetch to members with similar usernames
151
+ * @property {number} [limit=0] Maximum number of members to request
152
+ * @property {boolean} [withPresences=false] Whether or not to include the presences
153
+ * @property {number} [time=120e3] Timeout for receipt of members
154
+ * @property {?string} nonce Nonce for this request (32 characters max - default to base 16 now timestamp)
155
+ * @property {boolean} [force=false] Whether to skip the cache check and request the API
156
+ */
157
+
158
+ /**
159
+ * Fetches member(s) from Discord, even if they're offline.
160
+ * @param {UserResolvable|FetchMemberOptions|FetchMembersOptions} [options] If a UserResolvable, the user to fetch.
161
+ * If undefined, fetches all members.
162
+ * If a query, it limits the results to users with similar usernames.
163
+ * @returns {Promise<GuildMember|Collection<Snowflake, GuildMember>>}
164
+ * @example
165
+ * // Fetch all members from a guild
166
+ * guild.members.fetch()
167
+ * .then(console.log)
168
+ * .catch(console.error);
169
+ * @example
170
+ * // Fetch a single member
171
+ * guild.members.fetch('66564597481480192')
172
+ * .then(console.log)
173
+ * .catch(console.error);
174
+ * @example
175
+ * // Fetch a single member without checking cache
176
+ * guild.members.fetch({ user, force: true })
177
+ * .then(console.log)
178
+ * .catch(console.error)
179
+ * @example
180
+ * // Fetch a single member without caching
181
+ * guild.members.fetch({ user, cache: false })
182
+ * .then(console.log)
183
+ * .catch(console.error);
184
+ * @example
185
+ * // Fetch by an array of users including their presences
186
+ * guild.members.fetch({ user: ['66564597481480192', '191615925336670208'], withPresences: true })
187
+ * .then(console.log)
188
+ * .catch(console.error);
189
+ * @example
190
+ * // Fetch by query
191
+ * guild.members.fetch({ query: 'hydra', limit: 1 })
192
+ * .then(console.log)
193
+ * .catch(console.error);
194
+ * @see {@link https://github.com/aiko-chan-ai/discord.js-selfbot-v13/blob/main/Document/FetchGuildMember.md}
195
+ */
196
+ fetch(options) {
197
+ if (!options || (typeof options === 'object' && !('user' in options) && !('query' in options))) {
198
+ if (
199
+ this.guild.members.me.permissions.has('KICK_MEMBERS') ||
200
+ this.guild.members.me.permissions.has('BAN_MEMBERS') ||
201
+ this.guild.members.me.permissions.has('MANAGE_ROLES')
202
+ ) {
203
+ return this._fetchMany();
204
+ } else {
205
+ return this.fetchByMemberSafety();
206
+ /*
207
+ NOTE: This is a very slow method, and can take up to 999+ minutes to complete.
208
+ this.fetchBruteforce({
209
+ delay: 50,
210
+ skipWarn: true,
211
+ depth: 1,
212
+ });
213
+ */
214
+ }
215
+ }
216
+ const user = this.client.users.resolveId(options);
217
+ if (user) return this._fetchSingle({ user, cache: true });
218
+ if (options.user) {
219
+ if (Array.isArray(options.user)) {
220
+ options.user = options.user.map(u => this.client.users.resolveId(u));
221
+ return this._fetchMany(options);
222
+ } else {
223
+ options.user = this.client.users.resolveId(options.user);
224
+ }
225
+ if (!options.limit && !options.withPresences) return this._fetchSingle(options);
226
+ }
227
+ return this._fetchMany(options);
228
+ }
229
+
230
+ /**
231
+ * Fetches the client user as a GuildMember of the guild.
232
+ * @param {BaseFetchOptions} [options] The options for fetching the member
233
+ * @returns {Promise<GuildMember>}
234
+ */
235
+ fetchMe(options) {
236
+ return this.fetch({ ...options, user: this.client.user.id });
237
+ }
238
+
239
+ /**
240
+ * Options used for searching guild members.
241
+ * @typedef {Object} GuildSearchMembersOptions
242
+ * @property {string} query Filter members whose username or nickname start with this query
243
+ * @property {number} [limit=1] Maximum number of members to search
244
+ * @property {boolean} [cache=true] Whether or not to cache the fetched member(s)
245
+ */
246
+
247
+ /**
248
+ * Searches for members in the guild based on a query.
249
+ * @param {GuildSearchMembersOptions} options Options for searching members
250
+ * @returns {Promise<Collection<Snowflake, GuildMember>>}
251
+ */
252
+ async search({ query, limit = 1, cache = true } = {}) {
253
+ const data = await this.client.api.guilds(this.guild.id).members.search.get({ query: { query, limit } });
254
+ return data.reduce((col, member) => col.set(member.user.id, this._add(member, cache)), new Collection());
255
+ }
256
+
257
+ /**
258
+ * Options used for listing guild members.
259
+ * @typedef {Object} GuildListMembersOptions
260
+ * @property {Snowflake} [after] Limit fetching members to those with an id greater than the supplied id
261
+ * @property {number} [limit=1] Maximum number of members to list
262
+ * @property {boolean} [cache=true] Whether or not to cache the fetched member(s)
263
+ */
264
+
265
+ /**
266
+ * Lists up to 1000 members of the guild.
267
+ * @param {GuildListMembersOptions} [options] Options for listing members
268
+ * @returns {Promise<Collection<Snowflake, GuildMember>>}
269
+ */
270
+ async list({ after, limit = 1, cache = true } = {}) {
271
+ const data = await this.client.api.guilds(this.guild.id).members.get({ query: { after, limit } });
272
+ return data.reduce((col, member) => col.set(member.user.id, this._add(member, cache)), new Collection());
273
+ }
274
+
275
+ /**
276
+ * The data for editing a guild member.
277
+ * @typedef {Object} GuildMemberEditData
278
+ * @property {?string} [nick] The nickname to set for the member
279
+ * @property {Collection<Snowflake, Role>|RoleResolvable[]} [roles] The roles or role ids to apply
280
+ * @property {boolean} [mute] Whether or not the member should be muted
281
+ * @property {boolean} [deaf] Whether or not the member should be deafened
282
+ * @property {GuildVoiceChannelResolvable|null} [channel] Channel to move the member to
283
+ * (if they are connected to voice), or `null` if you want to disconnect them from voice
284
+ * @property {DateResolvable|null} [communicationDisabledUntil] The date or timestamp
285
+ * for the member's communication to be disabled until. Provide `null` to enable communication again.
286
+ * @property {GuildMemberFlagsResolvable} [flags] The flags to set for the member
287
+ * @property {?(BufferResolvable|Base64Resolvable)} [avatar] The new guild avatar
288
+ * @property {?(BufferResolvable|Base64Resolvable)} [banner] The new guild banner
289
+ * @property {?string} [bio] The new guild about me
290
+ */
291
+
292
+ /**
293
+ * Edits a member of the guild.
294
+ * <info>The user must be a member of the guild</info>
295
+ * @param {UserResolvable} user The member to edit
296
+ * @param {GuildMemberEditData} data The data to edit the member with
297
+ * @param {string} [reason] Reason for editing this user
298
+ * @returns {Promise<GuildMember>}
299
+ */
300
+ async edit(user, data, reason) {
301
+ const id = this.client.users.resolveId(user);
302
+ if (!id) throw new TypeError('INVALID_TYPE', 'user', 'UserResolvable');
303
+
304
+ // Clone the data object for immutability
305
+ const _data = { ...data };
306
+ if (_data.channel) {
307
+ _data.channel = this.guild.channels.resolve(_data.channel);
308
+ if (!(_data.channel instanceof BaseGuildVoiceChannel)) {
309
+ throw new Error('GUILD_VOICE_CHANNEL_RESOLVE');
310
+ }
311
+ _data.channel_id = _data.channel.id;
312
+ _data.channel = undefined;
313
+ } else if (_data.channel === null) {
314
+ _data.channel_id = null;
315
+ _data.channel = undefined;
316
+ }
317
+ _data.roles &&= _data.roles.map(role => (role instanceof Role ? role.id : role));
318
+
319
+ _data.communication_disabled_until =
320
+ _data.communicationDisabledUntil && new Date(_data.communicationDisabledUntil).toISOString();
321
+
322
+ _data.flags = _data.flags && GuildMemberFlags.resolve(_data.flags);
323
+
324
+ // Avatar, banner, bio
325
+ if (typeof _data.avatar !== 'undefined') {
326
+ _data.avatar = await DataResolver.resolveImage(_data.avatar);
327
+ }
328
+ if (typeof _data.banner !== 'undefined') {
329
+ _data.banner = await DataResolver.resolveImage(_data.banner);
330
+ }
331
+
332
+ let endpoint = this.client.api.guilds(this.guild.id);
333
+ if (id === this.client.user.id) {
334
+ const keys = Object.keys(data);
335
+ if (keys.length === 1 && ['nick', 'avatar', 'banner', 'bio'].includes(keys[0])) {
336
+ endpoint = endpoint.members('@me');
337
+ } else {
338
+ endpoint = endpoint.members(id);
339
+ }
340
+ } else {
341
+ endpoint = endpoint.members(id);
342
+ }
343
+ const d = await endpoint.patch({ data: _data, reason });
344
+
345
+ const clone = this.cache.get(id)?._clone();
346
+ clone?._patch(d);
347
+ return clone ?? this._add(d, false);
348
+ }
349
+
350
+ /**
351
+ * Options used for pruning guild members.
352
+ * <info>It's recommended to set {@link GuildPruneMembersOptions#count options.count}
353
+ * to `false` for large guilds.</info>
354
+ * @typedef {Object} GuildPruneMembersOptions
355
+ * @property {number} [days=7] Number of days of inactivity required to kick
356
+ * @property {boolean} [dry=false] Get the number of users that will be kicked, without actually kicking them
357
+ * @property {boolean} [count=true] Whether or not to return the number of users that have been kicked.
358
+ * @property {RoleResolvable[]} [roles] Array of roles to bypass the "...and no roles" constraint when pruning
359
+ * @property {string} [reason] Reason for this prune
360
+ */
361
+
362
+ /**
363
+ * Prunes members from the guild based on how long they have been inactive.
364
+ * @param {GuildPruneMembersOptions} [options] Options for pruning
365
+ * @returns {Promise<number|null>} The number of members that were/will be kicked
366
+ * @example
367
+ * // See how many members will be pruned
368
+ * guild.members.prune({ dry: true })
369
+ * .then(pruned => console.log(`This will prune ${pruned} people!`))
370
+ * .catch(console.error);
371
+ * @example
372
+ * // Actually prune the members
373
+ * guild.members.prune({ days: 1, reason: 'too many people!' })
374
+ * .then(pruned => console.log(`I just pruned ${pruned} people!`))
375
+ * .catch(console.error);
376
+ * @example
377
+ * // Include members with a specified role
378
+ * guild.members.prune({ days: 7, roles: ['657259391652855808'] })
379
+ * .then(pruned => console.log(`I just pruned ${pruned} people!`))
380
+ * .catch(console.error);
381
+ */
382
+ async prune({ days = 7, dry = false, count: compute_prune_count = true, roles = [], reason } = {}) {
383
+ if (typeof days !== 'number') throw new TypeError('PRUNE_DAYS_TYPE');
384
+
385
+ const query = { days };
386
+ const resolvedRoles = [];
387
+
388
+ for (const role of roles) {
389
+ const resolvedRole = this.guild.roles.resolveId(role);
390
+ if (!resolvedRole) {
391
+ throw new TypeError('INVALID_ELEMENT', 'Array', 'options.roles', role);
392
+ }
393
+ resolvedRoles.push(resolvedRole);
394
+ }
395
+
396
+ if (resolvedRoles.length) {
397
+ query.include_roles = dry ? resolvedRoles.join(',') : resolvedRoles;
398
+ }
399
+
400
+ const endpoint = this.client.api.guilds(this.guild.id).prune;
401
+
402
+ const { pruned } = await (dry
403
+ ? endpoint.get({ query, reason })
404
+ : endpoint.post({ data: { ...query, compute_prune_count }, reason }));
405
+
406
+ return pruned;
407
+ }
408
+
409
+ /**
410
+ * Kicks a user from the guild.
411
+ * <info>The user must be a member of the guild</info>
412
+ * @param {UserResolvable} user The member to kick
413
+ * @param {string} [reason] Reason for kicking
414
+ * @returns {Promise<GuildMember|User|Snowflake>} Result object will be resolved as specifically as possible.
415
+ * If the GuildMember cannot be resolved, the User will instead be attempted to be resolved. If that also cannot
416
+ * be resolved, the user's id will be the result.
417
+ * @example
418
+ * // Kick a user by id (or with a user/guild member object)
419
+ * guild.members.kick('84484653687267328')
420
+ * .then(kickInfo => console.log(`Kicked ${kickInfo.user?.tag ?? kickInfo.tag ?? kickInfo}`))
421
+ * .catch(console.error);
422
+ */
423
+ async kick(user, reason) {
424
+ const id = this.client.users.resolveId(user);
425
+ if (!id) return Promise.reject(new TypeError('INVALID_TYPE', 'user', 'UserResolvable'));
426
+
427
+ await this.client.api.guilds(this.guild.id).members(id).delete({ reason });
428
+
429
+ return this.resolve(user) ?? this.client.users.resolve(user) ?? id;
430
+ }
431
+
432
+ /**
433
+ * Bans a user from the guild.
434
+ * @param {UserResolvable} user The user to ban
435
+ * @param {BanOptions} [options] Options for the ban
436
+ * @returns {Promise<GuildMember|User|Snowflake>} Result object will be resolved as specifically as possible.
437
+ * If the GuildMember cannot be resolved, the User will instead be attempted to be resolved. If that also cannot
438
+ * be resolved, the user id will be the result.
439
+ * Internally calls the GuildBanManager#create method.
440
+ * @example
441
+ * // Ban a user by id (or with a user/guild member object)
442
+ * guild.members.ban('84484653687267328')
443
+ * .then(banInfo => console.log(`Banned ${banInfo.user?.tag ?? banInfo.tag ?? banInfo}`))
444
+ * .catch(console.error);
445
+ */
446
+ ban(user, options) {
447
+ return this.guild.bans.create(user, options);
448
+ }
449
+
450
+ /**
451
+ * Unbans a user from the guild. Internally calls the {@link GuildBanManager#remove} method.
452
+ * @param {UserResolvable} user The user to unban
453
+ * @param {string} [reason] Reason for unbanning user
454
+ * @returns {Promise<?User>} The user that was unbanned
455
+ * @example
456
+ * // Unban a user by id (or with a user/guild member object)
457
+ * guild.members.unban('84484653687267328')
458
+ * .then(user => console.log(`Unbanned ${user.username} from ${guild.name}`))
459
+ * .catch(console.error);
460
+ */
461
+ unban(user, reason) {
462
+ return this.guild.bans.remove(user, reason);
463
+ }
464
+
465
+ async _fetchSingle({ user, cache, force = false }) {
466
+ if (!force) {
467
+ const existing = this.cache.get(user);
468
+ if (existing && !existing.partial) return existing;
469
+ }
470
+
471
+ const data = await this.client.api.guilds(this.guild.id).members(user).get();
472
+ return this._add(data, cache);
473
+ }
474
+
475
+ /**
476
+ * Options used to fetch multiple members from a guild.
477
+ * @typedef {Object} BruteforceOptions
478
+ * @property {number} [limit=100] Maximum number of members per request
479
+ * @property {number} [delay=500] Timeout for new requests in ms
480
+ * @property {number} [depth=1] Permutations length
481
+ */
482
+
483
+ /**
484
+ * Fetches multiple members from the guild.
485
+ * @param {BruteforceOptions} options Options for the bruteforce
486
+ * @returns {Collection<Snowflake, GuildMember>} (All) members in the guild
487
+ * @see https://github.com/aiko-chan-ai/discord.js-selfbot-v13/blob/main/Document/FetchGuildMember.md
488
+ * @example
489
+ * guild.members.fetchBruteforce()
490
+ * .then(members => console.log(`Fetched ${members.size} members`))
491
+ * .catch(console.error);
492
+ */
493
+ fetchBruteforce(options = {}) {
494
+ const defaultQuery = 'abcdefghijklmnopqrstuvwxyz0123456789!"#$%&\'()*+,-./:;<=>?@[]^_`{|}~ ';
495
+ let dictionary;
496
+ let limit = 100;
497
+ let delay = 500;
498
+ let depth = 1;
499
+ if (options?.limit) limit = options?.limit;
500
+ if (options?.delay) delay = options?.delay;
501
+ if (options?.depth) depth = options?.depth;
502
+ if (typeof limit !== 'number') throw new TypeError('INVALID_TYPE', 'limit', 'Number');
503
+ if (limit < 1 || limit > 100) throw new RangeError('INVALID_RANGE_QUERY_MEMBER');
504
+ if (typeof delay !== 'number') throw new TypeError('INVALID_TYPE', 'delay', 'Number');
505
+ if (typeof depth !== 'number') throw new TypeError('INVALID_TYPE', 'depth', 'Number');
506
+ if (depth < 1) throw new RangeError('INVALID_RANGE_QUERY_MEMBER');
507
+ if (depth > 2) {
508
+ console.warn(`[WARNING] GuildMemberManager#fetchBruteforce: depth greater than 2, can lead to very slow speeds`);
509
+ }
510
+ if (delay < 500 && !options?.skipWarn) {
511
+ console.warn(
512
+ `[WARNING] GuildMemberManager#fetchBruteforce: delay is less than 500ms, this may cause rate limits.`,
513
+ );
514
+ }
515
+ let skipValues = [];
516
+ // eslint-disable-next-line no-async-promise-executor
517
+ return new Promise(async (resolve, reject) => {
518
+ for (let i = 1; i <= depth; i++) {
519
+ dictionary = _(defaultQuery)
520
+ .permutations(i)
521
+ .map(v => _.join(v, ''))
522
+ .value();
523
+ for (const query of dictionary) {
524
+ if (this.guild.members.cache.size >= this.guild.memberCount) break;
525
+ this.client.emit(
526
+ 'debug',
527
+ `[INFO] GuildMemberManager#fetchBruteforce: Querying ${query}, Skip: [${skipValues.join(', ')}]`,
528
+ );
529
+ if (skipValues.some(v => query.startsWith(v))) continue;
530
+ await this._fetchMany({ query, limit })
531
+ .then(members => {
532
+ if (members.size === 0) skipValues.push(query);
533
+ })
534
+ .catch(reject);
535
+ await this.guild.client.sleep(delay);
536
+ }
537
+ }
538
+ resolve(this.guild.members.cache);
539
+ });
540
+ }
541
+
542
+ /**
543
+ * Experimental method to fetch all members from the guild.
544
+ * @param {number} [timeout=120000] Timeout for receipt of members in ms
545
+ * @returns {Promise<Collection<Snowflake, GuildMember>>}
546
+ */
547
+ fetchByMemberSafety(timeout = 120_000) {
548
+ return new Promise(resolve => {
549
+ let timeout_ = setTimeout(() => {
550
+ this.client.removeListener(Events.GUILD_MEMBER_LIST_UPDATE, handler);
551
+ resolve(this.guild.members.cache);
552
+ }, timeout).unref();
553
+ const handler = (members, guild, raw) => {
554
+ if (guild.id == this.guild.id && !raw.nonce && raw.index == 0 && raw.count == 1) {
555
+ if (members.size > 0) {
556
+ this.client.ws.broadcast({
557
+ op: 35,
558
+ d: {
559
+ guild_id: this.guild.id,
560
+ query: '',
561
+ continuation_token: members.first()?.id,
562
+ },
563
+ });
564
+ } else {
565
+ clearTimeout(timeout_);
566
+ this.client.removeListener(Events.GUILD_MEMBER_LIST_UPDATE, handler);
567
+ resolve(this.guild.members.cache);
568
+ }
569
+ }
570
+ };
571
+ this.client.on('guildMembersChunk', handler);
572
+ this.client.ws.broadcast({
573
+ op: 35,
574
+ d: {
575
+ guild_id: this.guild.id,
576
+ query: '',
577
+ continuation_token: null,
578
+ },
579
+ });
580
+ });
581
+ }
582
+
583
+ /**
584
+ * Fetches multiple members from the guild in the channel.
585
+ * @param {GuildTextChannelResolvable} channel The channel to get members from (Members has VIEW_CHANNEL permission)
586
+ * @param {number} [offset=0] Start index of the members to get
587
+ * @param {boolean} [double=false] Whether to use double range
588
+ * @param {number} [retryMax=3] Number of retries
589
+ * @param {number} [time=10e3] Timeout for receipt of members
590
+ * @returns {Collection<Snowflake, GuildMember>} Members in the guild
591
+ * @see {@link https://github.com/aiko-chan-ai/discord.js-selfbot-v13/blob/main/Document/FetchGuildMember.md}
592
+ * @example
593
+ * const guild = client.guilds.cache.get('id');
594
+ * const channel = guild.channels.cache.get('id');
595
+ * // Overlap (slow)
596
+ * for (let index = 0; index <= guild.memberCount; index += 100) {
597
+ * await guild.members.fetchMemberList(channel, index, index !== 100).catch(() => {});
598
+ * await client.sleep(500);
599
+ * }
600
+ * // Non-overlap (fast)
601
+ * for (let index = 0; index <= guild.memberCount; index += 200) {
602
+ * await guild.members.fetchMemberList(channel, index == 0 ? 100 : index, index !== 100).catch(() => {});
603
+ * await client.sleep(500);
604
+ * }
605
+ * console.log(guild.members.cache.size); // will print the number of members in the guild
606
+ */
607
+ fetchMemberList(channel, offset = 0, double = false, retryMax = 3, time = 10_000) {
608
+ const channel_ = this.guild.channels.resolve(channel);
609
+ if (!channel_?.isText()) throw new TypeError('INVALID_TYPE', 'channel', 'GuildTextChannelResolvable');
610
+ if (typeof offset !== 'number') throw new TypeError('INVALID_TYPE', 'offset', 'Number');
611
+ if (typeof time !== 'number') throw new TypeError('INVALID_TYPE', 'time', 'Number');
612
+ if (typeof retryMax !== 'number') throw new TypeError('INVALID_TYPE', 'retryMax', 'Number');
613
+ if (retryMax < 1) throw new RangeError('INVALID_RANGE_RETRY');
614
+ if (typeof double !== 'boolean') throw new TypeError('INVALID_TYPE', 'double', 'Boolean');
615
+ // TODO: if (this.guild.large) throw new Error('GUILD_IS_LARGE');
616
+ return new Promise((resolve, reject) => {
617
+ const default_ = [[0, 99]];
618
+ const fetchedMembers = new Collection();
619
+ if (offset > 99) {
620
+ // eslint-disable-next-line no-unused-expressions
621
+ double
622
+ ? default_.push([offset, offset + 99], [offset + 100, offset + 199])
623
+ : default_.push([offset, offset + 99]);
624
+ }
625
+ let retry = 0;
626
+ const handler = (members, guild, type, raw) => {
627
+ timeout.refresh();
628
+ if (guild.id !== this.guild.id) return;
629
+ if (type == 'INVALIDATE' && offset > 100) {
630
+ if (retry < retryMax) {
631
+ this.guild.shard.send({
632
+ op: Opcodes.GUILD_SUBSCRIPTIONS,
633
+ d: {
634
+ guild_id: this.guild.id,
635
+ typing: true,
636
+ threads: true,
637
+ activities: true,
638
+ channels: {
639
+ [channel_.id]: default_,
640
+ },
641
+ thread_member_lists: [],
642
+ members: [],
643
+ },
644
+ });
645
+ retry++;
646
+ } else {
647
+ clearTimeout(timeout);
648
+ this.client.removeListener(Events.GUILD_MEMBER_LIST_UPDATE, handler);
649
+ this.client.decrementMaxListeners();
650
+ reject(new Error('INVALIDATE_MEMBER', raw.ops[0].range));
651
+ }
652
+ } else {
653
+ for (const member of members.values()) {
654
+ fetchedMembers.set(member.id, member);
655
+ }
656
+ clearTimeout(timeout);
657
+ this.client.removeListener(Events.GUILD_MEMBER_LIST_UPDATE, handler);
658
+ this.client.decrementMaxListeners();
659
+ resolve(fetchedMembers);
660
+ }
661
+ };
662
+ const timeout = setTimeout(() => {
663
+ this.client.removeListener(Events.GUILD_MEMBER_LIST_UPDATE, handler);
664
+ this.client.decrementMaxListeners();
665
+ reject(new Error('GUILD_MEMBERS_TIMEOUT'));
666
+ }, time).unref();
667
+ this.client.incrementMaxListeners();
668
+ this.client.on(Events.GUILD_MEMBER_LIST_UPDATE, handler);
669
+ this.guild.shard.send({
670
+ op: Opcodes.GUILD_SUBSCRIPTIONS,
671
+ d: {
672
+ guild_id: this.guild.id,
673
+ typing: true,
674
+ threads: true,
675
+ activities: true,
676
+ channels: {
677
+ [channel_.id]: default_,
678
+ },
679
+ thread_member_lists: [],
680
+ members: [],
681
+ },
682
+ });
683
+ });
684
+ }
685
+
686
+ /**
687
+ * Adds a role to a member.
688
+ * @param {GuildMemberResolvable} user The user to add the role from
689
+ * @param {RoleResolvable} role The role to add
690
+ * @param {string} [reason] Reason for adding the role
691
+ * @returns {Promise<GuildMember|User|Snowflake>}
692
+ */
693
+ async addRole(user, role, reason) {
694
+ const userId = this.guild.members.resolveId(user);
695
+ const roleId = this.guild.roles.resolveId(role);
696
+
697
+ await this.client.api.guilds(this.guild.id).members(userId).roles(roleId).put({ reason });
698
+
699
+ return this.resolve(user) ?? this.client.users.resolve(user) ?? userId;
700
+ }
701
+
702
+ /**
703
+ * Removes a role from a member.
704
+ * @param {UserResolvable} user The user to remove the role from
705
+ * @param {RoleResolvable} role The role to remove
706
+ * @param {string} [reason] Reason for removing the role
707
+ * @returns {Promise<GuildMember|User|Snowflake>}
708
+ */
709
+ async removeRole(user, role, reason) {
710
+ const userId = this.guild.members.resolveId(user);
711
+ const roleId = this.guild.roles.resolveId(role);
712
+
713
+ await this.client.api.guilds(this.guild.id).members(userId).roles(roleId).delete({ reason });
714
+
715
+ return this.resolve(user) ?? this.client.users.resolve(user) ?? userId;
716
+ }
717
+
718
+ _fetchMany({
719
+ limit = 0,
720
+ withPresences: presences = true,
721
+ user: user_ids,
722
+ query,
723
+ time = 120e3,
724
+ nonce = SnowflakeUtil.generate(),
725
+ } = {}) {
726
+ return new Promise((resolve, reject) => {
727
+ if (!query && !user_ids) query = '';
728
+ if (nonce.length > 32) throw new RangeError('MEMBER_FETCH_NONCE_LENGTH');
729
+ this.guild.shard.send({
730
+ op: Opcodes.REQUEST_GUILD_MEMBERS,
731
+ d: {
732
+ guild_id: this.guild.id,
733
+ presences,
734
+ user_ids,
735
+ query,
736
+ nonce,
737
+ limit,
738
+ },
739
+ });
740
+ const fetchedMembers = new Collection();
741
+ let i = 0;
742
+ const handler = (members, _, chunk) => {
743
+ timeout.refresh();
744
+ if (chunk.nonce !== nonce) return;
745
+ i++;
746
+ for (const member of members.values()) {
747
+ fetchedMembers.set(member.id, member);
748
+ }
749
+ if (members.size < 1_000 || (limit && fetchedMembers.size >= limit) || i === chunk.count) {
750
+ clearTimeout(timeout);
751
+ this.client.removeListener(Events.GUILD_MEMBERS_CHUNK, handler);
752
+ this.client.decrementMaxListeners();
753
+ let fetched = fetchedMembers;
754
+ if (user_ids && !Array.isArray(user_ids) && fetched.size) fetched = fetched.first();
755
+ resolve(fetched);
756
+ }
757
+ };
758
+ const timeout = setTimeout(() => {
759
+ this.client.removeListener(Events.GUILD_MEMBERS_CHUNK, handler);
760
+ this.client.decrementMaxListeners();
761
+ reject(new Error('GUILD_MEMBERS_TIMEOUT'));
762
+ }, time).unref();
763
+ this.client.incrementMaxListeners();
764
+ this.client.on(Events.GUILD_MEMBERS_CHUNK, handler);
765
+ });
766
+ }
767
+ }
768
+
769
+ module.exports = GuildMemberManager;