discord.js-selfbot-v13-new 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 (364) hide show
  1. package/LICENSE +674 -0
  2. package/README.md +124 -0
  3. package/package.json +89 -0
  4. package/src/WebSocket.js +39 -0
  5. package/src/client/BaseClient.js +86 -0
  6. package/src/client/Client.js +934 -0
  7. package/src/client/WebhookClient.js +61 -0
  8. package/src/client/actions/Action.js +116 -0
  9. package/src/client/actions/ActionsManager.js +80 -0
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  11. package/src/client/actions/AutoModerationActionExecution.js +27 -0
  12. package/src/client/actions/AutoModerationRuleCreate.js +28 -0
  13. package/src/client/actions/AutoModerationRuleDelete.js +32 -0
  14. package/src/client/actions/AutoModerationRuleUpdate.js +30 -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/InviteCreate.js +28 -0
  45. package/src/client/actions/InviteDelete.js +30 -0
  46. package/src/client/actions/MessageCreate.js +50 -0
  47. package/src/client/actions/MessageDelete.js +32 -0
  48. package/src/client/actions/MessageDeleteBulk.js +46 -0
  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 -0
  52. package/src/client/actions/MessageReactionRemove.js +50 -0
  53. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  54. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  55. package/src/client/actions/MessageUpdate.js +26 -0
  56. package/src/client/actions/PresenceUpdate.js +50 -0
  57. package/src/client/actions/StageInstanceCreate.js +28 -0
  58. package/src/client/actions/StageInstanceDelete.js +33 -0
  59. package/src/client/actions/StageInstanceUpdate.js +30 -0
  60. package/src/client/actions/ThreadCreate.js +24 -0
  61. package/src/client/actions/ThreadDelete.js +32 -0
  62. package/src/client/actions/ThreadListSync.js +59 -0
  63. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  64. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  65. package/src/client/actions/TypingStart.js +29 -0
  66. package/src/client/actions/UserUpdate.js +35 -0
  67. package/src/client/actions/VoiceStateUpdate.js +50 -0
  68. package/src/client/actions/WebhooksUpdate.js +20 -0
  69. package/src/client/voice/ClientVoiceManager.js +151 -0
  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 -0
  92. package/src/client/websocket/WebSocketShard.js +907 -0
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  96. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  97. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  100. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  101. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  102. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  103. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  104. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  105. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  106. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -0
  108. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  109. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  110. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  111. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  112. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  113. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -0
  114. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  115. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  116. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  117. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  118. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  119. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  120. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  121. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  122. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  123. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  128. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  129. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  130. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  131. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -0
  132. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  133. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  134. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  135. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  136. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  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 -0
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  142. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  143. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  144. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  145. package/src/client/websocket/handlers/READY.js +121 -0
  146. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -0
  147. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -0
  148. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -0
  149. package/src/client/websocket/handlers/RESUMED.js +14 -0
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  152. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  153. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  154. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  155. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  156. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  157. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  158. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  159. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  160. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -0
  161. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  162. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -0
  163. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -0
  164. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  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 -0
  167. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  168. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  169. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  170. package/src/client/websocket/handlers/index.js +84 -0
  171. package/src/errors/DJSError.js +61 -0
  172. package/src/errors/Messages.js +217 -0
  173. package/src/errors/index.js +4 -0
  174. package/src/index.js +172 -0
  175. package/src/managers/ApplicationCommandManager.js +264 -0
  176. package/src/managers/ApplicationCommandPermissionsManager.js +417 -0
  177. package/src/managers/AutoModerationRuleManager.js +296 -0
  178. package/src/managers/BaseGuildEmojiManager.js +80 -0
  179. package/src/managers/BaseManager.js +19 -0
  180. package/src/managers/BillingManager.js +66 -0
  181. package/src/managers/CachedManager.js +71 -0
  182. package/src/managers/ChannelManager.js +148 -0
  183. package/src/managers/ClientUserSettingManager.js +372 -0
  184. package/src/managers/DataManager.js +61 -0
  185. package/src/managers/GuildBanManager.js +250 -0
  186. package/src/managers/GuildChannelManager.js +488 -0
  187. package/src/managers/GuildEmojiManager.js +171 -0
  188. package/src/managers/GuildEmojiRoleManager.js +118 -0
  189. package/src/managers/GuildForumThreadManager.js +108 -0
  190. package/src/managers/GuildInviteManager.js +213 -0
  191. package/src/managers/GuildManager.js +338 -0
  192. package/src/managers/GuildMemberManager.js +599 -0
  193. package/src/managers/GuildMemberRoleManager.js +195 -0
  194. package/src/managers/GuildScheduledEventManager.js +314 -0
  195. package/src/managers/GuildSettingManager.js +155 -0
  196. package/src/managers/GuildStickerManager.js +179 -0
  197. package/src/managers/GuildTextThreadManager.js +98 -0
  198. package/src/managers/InteractionManager.js +39 -0
  199. package/src/managers/MessageManager.js +423 -0
  200. package/src/managers/PermissionOverwriteManager.js +164 -0
  201. package/src/managers/PresenceManager.js +71 -0
  202. package/src/managers/ReactionManager.js +67 -0
  203. package/src/managers/ReactionUserManager.js +73 -0
  204. package/src/managers/RelationshipManager.js +278 -0
  205. package/src/managers/RoleManager.js +448 -0
  206. package/src/managers/SessionManager.js +66 -0
  207. package/src/managers/StageInstanceManager.js +162 -0
  208. package/src/managers/ThreadManager.js +175 -0
  209. package/src/managers/ThreadMemberManager.js +186 -0
  210. package/src/managers/UserManager.js +136 -0
  211. package/src/managers/UserNoteManager.js +53 -0
  212. package/src/managers/VoiceStateManager.js +59 -0
  213. package/src/rest/APIRequest.js +154 -0
  214. package/src/rest/APIRouter.js +53 -0
  215. package/src/rest/DiscordAPIError.js +119 -0
  216. package/src/rest/HTTPError.js +62 -0
  217. package/src/rest/RESTManager.js +67 -0
  218. package/src/rest/RateLimitError.js +55 -0
  219. package/src/rest/RequestHandler.js +466 -0
  220. package/src/sharding/Shard.js +444 -0
  221. package/src/sharding/ShardClientUtil.js +279 -0
  222. package/src/sharding/ShardingManager.js +319 -0
  223. package/src/structures/AnonymousGuild.js +98 -0
  224. package/src/structures/ApplicationCommand.js +593 -0
  225. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -0
  226. package/src/structures/AutoModerationActionExecution.js +89 -0
  227. package/src/structures/AutoModerationRule.js +294 -0
  228. package/src/structures/AutocompleteInteraction.js +107 -0
  229. package/src/structures/Base.js +43 -0
  230. package/src/structures/BaseCommandInteraction.js +211 -0
  231. package/src/structures/BaseGuild.js +116 -0
  232. package/src/structures/BaseGuildEmoji.js +56 -0
  233. package/src/structures/BaseGuildTextChannel.js +191 -0
  234. package/src/structures/BaseGuildVoiceChannel.js +241 -0
  235. package/src/structures/BaseMessageComponent.js +181 -0
  236. package/src/structures/ButtonInteraction.js +11 -0
  237. package/src/structures/CallState.js +63 -0
  238. package/src/structures/CategoryChannel.js +85 -0
  239. package/src/structures/Channel.js +284 -0
  240. package/src/structures/ClientPresence.js +77 -0
  241. package/src/structures/ClientUser.js +449 -0
  242. package/src/structures/CommandInteraction.js +41 -0
  243. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  244. package/src/structures/ContainerComponent.js +68 -0
  245. package/src/structures/ContextMenuInteraction.js +65 -0
  246. package/src/structures/DMChannel.js +219 -0
  247. package/src/structures/DirectoryChannel.js +20 -0
  248. package/src/structures/Emoji.js +148 -0
  249. package/src/structures/FileComponent.js +49 -0
  250. package/src/structures/ForumChannel.js +31 -0
  251. package/src/structures/GroupDMChannel.js +394 -0
  252. package/src/structures/Guild.js +1638 -0
  253. package/src/structures/GuildAuditLogs.js +746 -0
  254. package/src/structures/GuildBan.js +59 -0
  255. package/src/structures/GuildBoost.js +108 -0
  256. package/src/structures/GuildChannel.js +470 -0
  257. package/src/structures/GuildEmoji.js +161 -0
  258. package/src/structures/GuildMember.js +636 -0
  259. package/src/structures/GuildPreview.js +191 -0
  260. package/src/structures/GuildPreviewEmoji.js +27 -0
  261. package/src/structures/GuildScheduledEvent.js +536 -0
  262. package/src/structures/GuildTemplate.js +236 -0
  263. package/src/structures/Integration.js +188 -0
  264. package/src/structures/IntegrationApplication.js +96 -0
  265. package/src/structures/Interaction.js +290 -0
  266. package/src/structures/InteractionCollector.js +248 -0
  267. package/src/structures/InteractionWebhook.js +43 -0
  268. package/src/structures/Invite.js +358 -0
  269. package/src/structures/InviteGuild.js +23 -0
  270. package/src/structures/InviteStageInstance.js +86 -0
  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 -0
  275. package/src/structures/MessageActionRow.js +105 -0
  276. package/src/structures/MessageAttachment.js +216 -0
  277. package/src/structures/MessageButton.js +166 -0
  278. package/src/structures/MessageCollector.js +146 -0
  279. package/src/structures/MessageComponentInteraction.js +120 -0
  280. package/src/structures/MessageContextMenuInteraction.js +20 -0
  281. package/src/structures/MessageEmbed.js +596 -0
  282. package/src/structures/MessageMentions.js +273 -0
  283. package/src/structures/MessagePayload.js +354 -0
  284. package/src/structures/MessageReaction.js +181 -0
  285. package/src/structures/MessageSelectMenu.js +141 -0
  286. package/src/structures/Modal.js +161 -0
  287. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  288. package/src/structures/ModalSubmitInteraction.js +119 -0
  289. package/src/structures/NewsChannel.js +32 -0
  290. package/src/structures/OAuth2Guild.js +28 -0
  291. package/src/structures/PermissionOverwrites.js +198 -0
  292. package/src/structures/Poll.js +108 -0
  293. package/src/structures/PollAnswer.js +88 -0
  294. package/src/structures/Presence.js +1105 -0
  295. package/src/structures/ReactionCollector.js +229 -0
  296. package/src/structures/ReactionEmoji.js +31 -0
  297. package/src/structures/Role.js +590 -0
  298. package/src/structures/SectionComponent.js +48 -0
  299. package/src/structures/SelectMenuInteraction.js +21 -0
  300. package/src/structures/SeparatorComponent.js +48 -0
  301. package/src/structures/Session.js +81 -0
  302. package/src/structures/StageChannel.js +104 -0
  303. package/src/structures/StageInstance.js +208 -0
  304. package/src/structures/Sticker.js +310 -0
  305. package/src/structures/StickerPack.js +95 -0
  306. package/src/structures/StoreChannel.js +56 -0
  307. package/src/structures/Team.js +118 -0
  308. package/src/structures/TeamMember.js +80 -0
  309. package/src/structures/TextChannel.js +33 -0
  310. package/src/structures/TextDisplayComponent.js +40 -0
  311. package/src/structures/TextInputComponent.js +132 -0
  312. package/src/structures/ThreadChannel.js +605 -0
  313. package/src/structures/ThreadMember.js +105 -0
  314. package/src/structures/ThreadOnlyChannel.js +249 -0
  315. package/src/structures/ThumbnailComponent.js +57 -0
  316. package/src/structures/Typing.js +74 -0
  317. package/src/structures/UnfurledMediaItem.js +29 -0
  318. package/src/structures/User.js +622 -0
  319. package/src/structures/UserContextMenuInteraction.js +29 -0
  320. package/src/structures/VoiceChannel.js +110 -0
  321. package/src/structures/VoiceChannelEffect.js +69 -0
  322. package/src/structures/VoiceRegion.js +53 -0
  323. package/src/structures/VoiceState.js +354 -0
  324. package/src/structures/WebEmbed.js +373 -0
  325. package/src/structures/Webhook.js +478 -0
  326. package/src/structures/WelcomeChannel.js +60 -0
  327. package/src/structures/WelcomeScreen.js +48 -0
  328. package/src/structures/Widget.js +87 -0
  329. package/src/structures/WidgetMember.js +99 -0
  330. package/src/structures/interfaces/Application.js +825 -0
  331. package/src/structures/interfaces/Collector.js +300 -0
  332. package/src/structures/interfaces/InteractionResponses.js +313 -0
  333. package/src/structures/interfaces/TextBasedChannel.js +759 -0
  334. package/src/util/APITypes.js +59 -0
  335. package/src/util/ActivityFlags.js +44 -0
  336. package/src/util/ApplicationFlags.js +76 -0
  337. package/src/util/AttachmentFlags.js +38 -0
  338. package/src/util/BitField.js +170 -0
  339. package/src/util/ChannelFlags.js +45 -0
  340. package/src/util/Constants.js +1914 -0
  341. package/src/util/DataResolver.js +146 -0
  342. package/src/util/Formatters.js +228 -0
  343. package/src/util/GuildMemberFlags.js +43 -0
  344. package/src/util/Intents.js +74 -0
  345. package/src/util/InviteFlags.js +34 -0
  346. package/src/util/LimitedCollection.js +131 -0
  347. package/src/util/MessageFlags.js +63 -0
  348. package/src/util/Options.js +358 -0
  349. package/src/util/Permissions.js +202 -0
  350. package/src/util/PremiumUsageFlags.js +31 -0
  351. package/src/util/PurchasedFlags.js +33 -0
  352. package/src/util/RemoteAuth.js +382 -0
  353. package/src/util/RoleFlags.js +37 -0
  354. package/src/util/SnowflakeUtil.js +92 -0
  355. package/src/util/Speaking.js +33 -0
  356. package/src/util/Sweepers.js +466 -0
  357. package/src/util/SystemChannelFlags.js +55 -0
  358. package/src/util/ThreadMemberFlags.js +30 -0
  359. package/src/util/UserFlags.js +104 -0
  360. package/src/util/Util.js +1048 -0
  361. package/typings/enums.d.ts +439 -0
  362. package/typings/index.d.ts +8247 -0
  363. package/typings/index.test-d.ts +0 -0
  364. package/typings/rawDataTypes.d.ts +403 -0
@@ -0,0 +1,622 @@
1
+ 'use strict';
2
+
3
+ const Base = require('./Base');
4
+ const VoiceState = require('./VoiceState');
5
+ const TextBasedChannel = require('./interfaces/TextBasedChannel');
6
+ const { Error } = require('../errors');
7
+ const { RelationshipTypes } = require('../util/Constants');
8
+ const SnowflakeUtil = require('../util/SnowflakeUtil');
9
+ const UserFlags = require('../util/UserFlags');
10
+ const Util = require('../util/Util');
11
+
12
+ /**
13
+ * Represents a user on Discord.
14
+ * @implements {TextBasedChannel}
15
+ * @extends {Base}
16
+ */
17
+ class User extends Base {
18
+ constructor(client, data) {
19
+ super(client);
20
+
21
+ /**
22
+ * The user's id
23
+ * @type {Snowflake}
24
+ */
25
+ this.id = data.id;
26
+
27
+ this.bot = null;
28
+
29
+ this.system = null;
30
+
31
+ this.flags = null;
32
+
33
+ this._patch(data);
34
+ }
35
+
36
+ _patch(data) {
37
+ if ('username' in data) {
38
+ /**
39
+ * The username of the user
40
+ * @type {?string}
41
+ */
42
+ this.username = data.username;
43
+ } else {
44
+ this.username ??= null;
45
+ }
46
+
47
+ if ('global_name' in data) {
48
+ /**
49
+ * The global name of this user
50
+ * @type {?string}
51
+ */
52
+ this.globalName = data.global_name;
53
+ } else {
54
+ this.globalName ??= null;
55
+ }
56
+
57
+ if ('bot' in data) {
58
+ /**
59
+ * Whether or not the user is a bot
60
+ * @type {?boolean}
61
+ */
62
+ this.bot = Boolean(data.bot);
63
+ } else if (!this.partial && typeof this.bot !== 'boolean') {
64
+ this.bot = false;
65
+ }
66
+
67
+ if ('discriminator' in data) {
68
+ /**
69
+ * The discriminator of this user
70
+ * <info>`'0'`, or a 4-digit stringified number if they're using the legacy username system</info>
71
+ * @type {?string}
72
+ */
73
+ this.discriminator = data.discriminator;
74
+ } else {
75
+ this.discriminator ??= null;
76
+ }
77
+
78
+ if ('avatar' in data) {
79
+ /**
80
+ * The user avatar's hash
81
+ * @type {?string}
82
+ */
83
+ this.avatar = data.avatar;
84
+ } else {
85
+ this.avatar ??= null;
86
+ }
87
+
88
+ if ('banner' in data) {
89
+ /**
90
+ * The user banner's hash
91
+ * <info>The user must be force fetched for this property to be present or be updated</info>
92
+ * @type {?string}
93
+ */
94
+ this.banner = data.banner;
95
+ } else if (this.banner !== null) {
96
+ this.banner ??= undefined;
97
+ }
98
+
99
+ if ('banner_color' in data) {
100
+ /**
101
+ * The user banner's hex
102
+ * <info>The user must be force fetched for this property to be present or be updated</info>
103
+ * @type {?string}
104
+ */
105
+ this.bannerColor = data.banner_color;
106
+ } else if (this.bannerColor !== null) {
107
+ this.bannerColor ??= undefined;
108
+ }
109
+
110
+ if ('accent_color' in data) {
111
+ /**
112
+ * The base 10 accent color of the user's banner
113
+ * <info>The user must be force fetched for this property to be present or be updated</info>
114
+ * @type {?number}
115
+ */
116
+ this.accentColor = data.accent_color;
117
+ } else if (this.accentColor !== null) {
118
+ this.accentColor ??= undefined;
119
+ }
120
+
121
+ if ('system' in data) {
122
+ /**
123
+ * Whether the user is an Official Discord System user (part of the urgent message system)
124
+ * @type {?boolean}
125
+ */
126
+ this.system = Boolean(data.system);
127
+ } else if (!this.partial && typeof this.system !== 'boolean') {
128
+ this.system = false;
129
+ }
130
+
131
+ if ('public_flags' in data) {
132
+ /**
133
+ * The flags for this user
134
+ * @type {?UserFlags}
135
+ */
136
+ this.flags = new UserFlags(data.public_flags);
137
+ }
138
+
139
+ /**
140
+ * @typedef {Object} AvatarDecorationData
141
+ * @property {string} asset The avatar decoration hash
142
+ * @property {Snowflake} skuId The id of the avatar decoration's SKU
143
+ */
144
+
145
+ if (data.avatar_decoration_data) {
146
+ if (data.avatar_decoration_data) {
147
+ /**
148
+ * The user avatar decoration's data
149
+ * @type {?AvatarDecorationData}
150
+ */
151
+ this.avatarDecorationData = {
152
+ asset: data.avatar_decoration_data.asset,
153
+ skuId: data.avatar_decoration_data.sku_id,
154
+ };
155
+ } else {
156
+ this.avatarDecorationData = null;
157
+ }
158
+ } else {
159
+ this.avatarDecorationData ??= null;
160
+ }
161
+
162
+ /**
163
+ * @typedef {Object} UserPrimaryGuild
164
+ * @property {?Snowflake} identityGuildId The id of the user's primary guild
165
+ * @property {?boolean} identityEnabled Whether the user is displaying the primary guild's tag
166
+ * @property {?string} tag The user's guild tag. Limited to 4 characters
167
+ * @property {?string} badge The guild tag badge hash
168
+ */
169
+
170
+ if ('primary_guild' in data) {
171
+ if (data.primary_guild) {
172
+ /**
173
+ * The primary guild of the user
174
+ * @type {?UserPrimaryGuild}
175
+ */
176
+ this.primaryGuild = {
177
+ identityGuildId: data.primary_guild.identity_guild_id,
178
+ identityEnabled: data.primary_guild.identity_enabled,
179
+ tag: data.primary_guild.tag,
180
+ badge: data.primary_guild.badge,
181
+ };
182
+ } else {
183
+ this.primaryGuild = null;
184
+ }
185
+ } else {
186
+ this.primaryGuild ??= null;
187
+ }
188
+
189
+ /**
190
+ * @typedef {Object} NameplateData
191
+ * @property {Snowflake} skuId The id of the nameplate's SKU
192
+ * @property {string} asset The nameplate's asset path
193
+ * @property {string} label The nameplate's label
194
+ * @property {NameplatePalette} palette Background color of the nameplate
195
+ */
196
+
197
+ /**
198
+ * @typedef {Object} Collectibles
199
+ * @property {?NameplateData} nameplate The user's nameplate data
200
+ */
201
+
202
+ if (data.collectibles) {
203
+ if (data.collectibles.nameplate) {
204
+ /**
205
+ * The user's collectibles
206
+ * @type {?Collectibles}
207
+ */
208
+ this.collectibles = {
209
+ nameplate: {
210
+ skuId: data.collectibles.nameplate.sku_id,
211
+ asset: data.collectibles.nameplate.asset,
212
+ label: data.collectibles.nameplate.label,
213
+ palette: data.collectibles.nameplate.palette,
214
+ },
215
+ };
216
+ } else {
217
+ this.collectibles = { nameplate: null };
218
+ }
219
+ } else {
220
+ this.collectibles ??= null;
221
+ }
222
+ }
223
+
224
+ /**
225
+ * The primary clan the user is in
226
+ * @type {?PrimaryGuild}
227
+ * @deprecated Use `primaryGuild` instead
228
+ */
229
+ get clan() {
230
+ return this.primaryGuild;
231
+ }
232
+
233
+ /**
234
+ * The user avatar decoration's hash
235
+ * @type {?string}
236
+ * @deprecated Use `avatarDecorationData` instead
237
+ * Removed in v4
238
+ */
239
+ get avatarDecoration() {
240
+ return this.avatarDecorationData?.asset || null;
241
+ }
242
+
243
+ /**
244
+ * Whether this User is a partial
245
+ * @type {boolean}
246
+ * @readonly
247
+ */
248
+ get partial() {
249
+ return typeof this.username !== 'string';
250
+ }
251
+
252
+ /**
253
+ * The timestamp the user was created at
254
+ * @type {number}
255
+ * @readonly
256
+ */
257
+ get createdTimestamp() {
258
+ return SnowflakeUtil.timestampFrom(this.id);
259
+ }
260
+
261
+ /**
262
+ * The time the user was created at
263
+ * @type {Date}
264
+ * @readonly
265
+ */
266
+ get createdAt() {
267
+ return new Date(this.createdTimestamp);
268
+ }
269
+
270
+ /**
271
+ * A link to the user's avatar.
272
+ * @param {ImageURLOptions} [options={}] Options for the Image URL
273
+ * @returns {?string}
274
+ */
275
+ avatarURL({ format, size, dynamic } = {}) {
276
+ if (!this.avatar) return null;
277
+ return this.client.rest.cdn.Avatar(this.id, this.avatar, format, size, dynamic);
278
+ }
279
+
280
+ /**
281
+ * A link to the user's avatar decoration.
282
+ * @returns {?string}
283
+ */
284
+ avatarDecorationURL() {
285
+ if (!this.avatarDecorationData) return null;
286
+ return this.client.rest.cdn.AvatarDecoration(this.avatarDecorationData.asset);
287
+ }
288
+
289
+ /**
290
+ * A link to the user's guild tag badge.
291
+ * @returns {?string}
292
+ * @deprecated
293
+ */
294
+ clanBadgeURL() {
295
+ return this.guildTagBadgeURL();
296
+ }
297
+
298
+ /**
299
+ * A link to the user's guild tag badge.
300
+ * @returns {?string}
301
+ */
302
+ guildTagBadgeURL() {
303
+ if (!this.primaryGuild || !this.primaryGuild.identityGuildId || !this.primaryGuild.badge) return null;
304
+ return this.client.rest.cdn.GuildTagBadge(this.primaryGuild.identityGuildId, this.primaryGuild.badge);
305
+ }
306
+
307
+ /**
308
+ * A link to the user's default avatar
309
+ * @type {string}
310
+ * @readonly
311
+ */
312
+ get defaultAvatarURL() {
313
+ const index =
314
+ this.discriminator === '0' || this.discriminator === '0000'
315
+ ? Util.calculateUserDefaultAvatarIndex(this.id)
316
+ : this.discriminator % 5;
317
+ return this.client.rest.cdn.DefaultAvatar(index);
318
+ }
319
+
320
+ /**
321
+ * A link to the user's avatar if they have one.
322
+ * Otherwise a link to their default avatar will be returned.
323
+ * @param {ImageURLOptions} [options={}] Options for the Image URL
324
+ * @returns {string}
325
+ */
326
+ displayAvatarURL(options) {
327
+ return this.avatarURL(options) ?? this.defaultAvatarURL;
328
+ }
329
+
330
+ /**
331
+ * The hexadecimal version of the user accent color, with a leading hash
332
+ * <info>The user must be force fetched for this property to be present</info>
333
+ * @type {?string}
334
+ * @readonly
335
+ */
336
+ get hexAccentColor() {
337
+ if (typeof this.accentColor !== 'number') return this.accentColor;
338
+ return `#${this.accentColor.toString(16).padStart(6, '0')}`;
339
+ }
340
+
341
+ /**
342
+ * A link to the user's banner.
343
+ * <info>This method will throw an error if called before the user is force fetched.
344
+ * See {@link User#banner} for more info</info>
345
+ * @param {ImageURLOptions} [options={}] Options for the Image URL
346
+ * @returns {?string}
347
+ */
348
+ bannerURL({ format, size, dynamic } = {}) {
349
+ if (typeof this.banner === 'undefined') throw new Error('USER_BANNER_NOT_FETCHED');
350
+ if (!this.banner) return null;
351
+ return this.client.rest.cdn.Banner(this.id, this.banner, format, size, dynamic);
352
+ }
353
+
354
+ /**
355
+ * The tag of this user
356
+ * <info>This user's username, or their legacy tag (e.g. `hydrabolt#0001`)
357
+ * if they're using the legacy username system</info>
358
+ * @type {?string}
359
+ * @readonly
360
+ */
361
+ get tag() {
362
+ return typeof this.username === 'string'
363
+ ? this.discriminator === '0' || this.discriminator === '0000'
364
+ ? this.username
365
+ : `${this.username}#${this.discriminator}`
366
+ : null;
367
+ }
368
+
369
+ /**
370
+ * The global name of this user, or their username if they don't have one
371
+ * @type {?string}
372
+ * @readonly
373
+ */
374
+ get displayName() {
375
+ return this.globalName ?? this.username;
376
+ }
377
+
378
+ /**
379
+ * The DM between the client's user and this user
380
+ * @type {?DMChannel}
381
+ * @readonly
382
+ */
383
+ get dmChannel() {
384
+ return this.client.users.dmChannel(this.id);
385
+ }
386
+
387
+ /**
388
+ * Creates a DM channel between the client and the user.
389
+ * @param {boolean} [force=false] Whether to skip the cache check and request the API
390
+ * @returns {Promise<DMChannel>}
391
+ */
392
+ createDM(force = false) {
393
+ return this.client.users.createDM(this.id, force);
394
+ }
395
+
396
+ /**
397
+ * Deletes a DM channel (if one exists) between the client and the user. Resolves with the channel if successful.
398
+ * @returns {Promise<DMChannel>}
399
+ */
400
+ deleteDM() {
401
+ return this.client.users.deleteDM(this.id);
402
+ }
403
+
404
+ /**
405
+ * Checks if the user is equal to another.
406
+ * It compares id, username, discriminator, avatar, banner, accent color, and bot flags.
407
+ * It is recommended to compare equality by using `user.id === user2.id` unless you want to compare all properties.
408
+ * @param {User} user User to compare with
409
+ * @returns {boolean}
410
+ */
411
+ equals(user) {
412
+ return (
413
+ user &&
414
+ this.id === user.id &&
415
+ this.username === user.username &&
416
+ this.discriminator === user.discriminator &&
417
+ this.globalName === user.globalName &&
418
+ this.avatar === user.avatar &&
419
+ this.flags?.bitfield === user.flags?.bitfield &&
420
+ this.banner === user.banner &&
421
+ this.accentColor === user.accentColor &&
422
+ this.avatarDecorationData?.asset === user.avatarDecorationData?.asset &&
423
+ this.avatarDecorationData?.skuId === user.avatarDecorationData?.skuId &&
424
+ this.collectibles?.nameplate?.skuId === user.collectibles?.nameplate?.skuId &&
425
+ this.collectibles?.nameplate?.asset === user.collectibles?.nameplate?.asset &&
426
+ this.collectibles?.nameplate?.label === user.collectibles?.nameplate?.label &&
427
+ this.collectibles?.nameplate?.palette === user.collectibles?.nameplate?.palette &&
428
+ this.primaryGuild?.identityGuildId === user.primaryGuild?.identityGuildId &&
429
+ this.primaryGuild?.identityEnabled === user.primaryGuild?.identityEnabled &&
430
+ this.primaryGuild?.tag === user.primaryGuild?.tag &&
431
+ this.primaryGuild?.badge === user.primaryGuild?.badge
432
+ );
433
+ }
434
+
435
+ /**
436
+ * Compares the user with an API user object
437
+ * @param {APIUser} user The API user object to compare
438
+ * @returns {boolean}
439
+ * @private
440
+ */
441
+ _equals(user) {
442
+ return (
443
+ user &&
444
+ this.id === user.id &&
445
+ this.username === user.username &&
446
+ this.discriminator === user.discriminator &&
447
+ this.globalName === user.global_name &&
448
+ this.avatar === user.avatar &&
449
+ this.flags?.bitfield === user.public_flags &&
450
+ ('banner' in user ? this.banner === user.banner : true) &&
451
+ ('accent_color' in user ? this.accentColor === user.accent_color : true) &&
452
+ ('avatar_decoration_data' in user
453
+ ? this.avatarDecorationData?.asset === user.avatar_decoration_data?.asset &&
454
+ this.avatarDecorationData?.skuId === user.avatar_decoration_data?.sku_id
455
+ : true) &&
456
+ ('collectibles' in user
457
+ ? this.collectibles?.nameplate?.skuId === user.collectibles?.nameplate?.sku_id &&
458
+ this.collectibles?.nameplate?.asset === user.collectibles?.nameplate?.asset &&
459
+ this.collectibles?.nameplate?.label === user.collectibles?.nameplate?.label &&
460
+ this.collectibles?.nameplate?.palette === user.collectibles?.nameplate?.palette
461
+ : true) &&
462
+ ('primary_guild' in user
463
+ ? this.primaryGuild?.identityGuildId === user.primary_guild?.identity_guild_id &&
464
+ this.primaryGuild?.identityEnabled === user.primary_guild?.identity_enabled &&
465
+ this.primaryGuild?.tag === user.primary_guild?.tag &&
466
+ this.primaryGuild?.badge === user.primary_guild?.badge
467
+ : true)
468
+ );
469
+ }
470
+
471
+ /**
472
+ * Fetches this user.
473
+ * @param {boolean} [force=true] Whether to skip the cache check and request the API
474
+ * @returns {Promise<User>}
475
+ */
476
+ fetch(force = true) {
477
+ return this.client.users.fetch(this.id, { force });
478
+ }
479
+
480
+ /**
481
+ * Returns a user profile object for a given user ID.
482
+ * <info>This endpoint requires one of the following:
483
+ * - The user is a bot
484
+ * - The user shares a mutual guild with the current user
485
+ * - The user is a friend of the current user
486
+ * - The user is a friend suggestion of the current user
487
+ * - The user has an outgoing friend request to the current user</info>
488
+ * @param {Snowflake} [guildId] The guild ID to get the user's member profile in
489
+ * @returns {Promise<Object>}
490
+ * @see {@link https://discord-userdoccers.vercel.app/resources/user#response-body}
491
+ */
492
+ getProfile(guildId) {
493
+ return this.client.api.users(this.id).profile.get({
494
+ query: {
495
+ with_mutual_guilds: true,
496
+ with_mutual_friends: true,
497
+ with_mutual_friends_count: true,
498
+ guild_id: guildId,
499
+ },
500
+ });
501
+ }
502
+
503
+ /**
504
+ * When concatenated with a string, this automatically returns the user's mention instead of the User object.
505
+ * @returns {string}
506
+ * @example
507
+ * // Logs: Hello from <@123456789012345678>!
508
+ * console.log(`Hello from ${user}!`);
509
+ */
510
+ toString() {
511
+ return `<@${this.id}>`;
512
+ }
513
+
514
+ toJSON(...props) {
515
+ const json = super.toJSON(
516
+ {
517
+ createdTimestamp: true,
518
+ defaultAvatarURL: true,
519
+ hexAccentColor: true,
520
+ tag: true,
521
+ },
522
+ ...props,
523
+ );
524
+ json.avatarURL = this.avatarURL();
525
+ json.displayAvatarURL = this.displayAvatarURL();
526
+ json.bannerURL = this.banner ? this.bannerURL() : this.banner;
527
+ json.guildTagBadgeURL = this.guildTagBadgeURL();
528
+ return json;
529
+ }
530
+
531
+ /**
532
+ * The function updates the note of a user and returns the updated user.
533
+ * @param {string|null|undefined} [note=null] - The `note` parameter is the new value that you want to set for the note of the
534
+ * user. It is an optional parameter and its default value is `null`.
535
+ * @returns {Promise<User>} The `setNote` method is returning the `User` object.
536
+ */
537
+ async setNote(note = null) {
538
+ await this.client.notes.updateNote(this.id, note);
539
+ return this;
540
+ }
541
+
542
+ /**
543
+ * The function returns the note associated with a specific client ID from a cache.
544
+ * @type {?string} The note that corresponds to the given id.
545
+ */
546
+ get note() {
547
+ return this.client.notes.cache.get(this.id);
548
+ }
549
+
550
+ /**
551
+ * The voice state of this member
552
+ * @type {VoiceState}
553
+ * @readonly
554
+ */
555
+ get voice() {
556
+ return (
557
+ this.client.voiceStates.cache.get(this.id) ??
558
+ this.client.guilds.cache.find(g => g?.voiceStates?.cache?.get(this.id))?.voiceStates?.cache?.get(this.id) ??
559
+ new VoiceState({ client: this.client }, { user_id: this.id })
560
+ );
561
+ }
562
+
563
+ /**
564
+ * Send Friend Request to the user
565
+ * @type {boolean}
566
+ * @returns {Promise<boolean>}
567
+ */
568
+ sendFriendRequest() {
569
+ return this.client.relationships.sendFriendRequest(this);
570
+ }
571
+
572
+ /**
573
+ * Unblock / Unfriend / Cancels a friend request
574
+ * @type {boolean}
575
+ * @returns {Promise<boolean>}
576
+ */
577
+ deleteRelationship() {
578
+ return this.client.relationships.deleteRelationship(this);
579
+ }
580
+
581
+ /**
582
+ * Check relationship status (Client -> User)
583
+ * @type {RelationshipType}
584
+ * @readonly
585
+ */
586
+ get relationship() {
587
+ const i = this.client.relationships.cache.get(this.id) ?? 0;
588
+ return RelationshipTypes[parseInt(i)];
589
+ }
590
+
591
+ /**
592
+ * Get friend nickname
593
+ * @type {?string}
594
+ * @readonly
595
+ */
596
+ get friendNickname() {
597
+ return this.client.relationships.friendNicknames.get(this.id);
598
+ }
599
+ }
600
+
601
+ /**
602
+ * Sends a message to this user.
603
+ * @method send
604
+ * @memberof User
605
+ * @instance
606
+ * @param {string|MessagePayload|MessageOptions} options The options to provide
607
+ * @returns {Promise<Message>}
608
+ * @example
609
+ * // Send a direct message
610
+ * user.send('Hello!')
611
+ * .then(message => console.log(`Sent message: ${message.content} to ${user.tag}`))
612
+ * .catch(console.error);
613
+ */
614
+
615
+ TextBasedChannel.applyToClass(User);
616
+
617
+ module.exports = User;
618
+
619
+ /**
620
+ * @external APIUser
621
+ * @see {@link https://discord.com/developers/docs/resources/user#user-object}
622
+ */
@@ -0,0 +1,29 @@
1
+ 'use strict';
2
+
3
+ const ContextMenuInteraction = require('./ContextMenuInteraction');
4
+
5
+ /**
6
+ * Represents a user context menu interaction.
7
+ * @extends {ContextMenuInteraction}
8
+ */
9
+ class UserContextMenuInteraction extends ContextMenuInteraction {
10
+ /**
11
+ * The target user from this interaction
12
+ * @type {User}
13
+ * @readonly
14
+ */
15
+ get targetUser() {
16
+ return this.options.getUser('user');
17
+ }
18
+
19
+ /**
20
+ * The target member from this interaction
21
+ * @type {?(GuildMember|APIGuildMember)}
22
+ * @readonly
23
+ */
24
+ get targetMember() {
25
+ return this.options.getMember('user');
26
+ }
27
+ }
28
+
29
+ module.exports = UserContextMenuInteraction;