djs-selfbot-v13 3.2.2 → 3.7.2

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