discord-sb.js 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.
- package/LICENSE +674 -0
- package/README.md +2 -0
- package/package.json +91 -0
- package/src/WebSocket.js +39 -0
- package/src/client/BaseClient.js +86 -0
- package/src/client/Client.js +978 -0
- package/src/client/WebhookClient.js +61 -0
- package/src/client/actions/Action.js +116 -0
- package/src/client/actions/ActionsManager.js +80 -0
- package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
- package/src/client/actions/AutoModerationActionExecution.js +27 -0
- package/src/client/actions/AutoModerationRuleCreate.js +28 -0
- package/src/client/actions/AutoModerationRuleDelete.js +32 -0
- package/src/client/actions/AutoModerationRuleUpdate.js +30 -0
- package/src/client/actions/ChannelCreate.js +23 -0
- package/src/client/actions/ChannelDelete.js +39 -0
- package/src/client/actions/ChannelUpdate.js +43 -0
- package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
- package/src/client/actions/GuildBanAdd.js +20 -0
- package/src/client/actions/GuildBanRemove.js +25 -0
- package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
- package/src/client/actions/GuildDelete.js +65 -0
- package/src/client/actions/GuildEmojiCreate.js +20 -0
- package/src/client/actions/GuildEmojiDelete.js +21 -0
- package/src/client/actions/GuildEmojiUpdate.js +20 -0
- package/src/client/actions/GuildEmojisUpdate.js +34 -0
- package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
- package/src/client/actions/GuildMemberRemove.js +33 -0
- package/src/client/actions/GuildMemberUpdate.js +44 -0
- package/src/client/actions/GuildRoleCreate.js +25 -0
- package/src/client/actions/GuildRoleDelete.js +31 -0
- package/src/client/actions/GuildRoleUpdate.js +39 -0
- package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
- package/src/client/actions/GuildScheduledEventCreate.js +27 -0
- package/src/client/actions/GuildScheduledEventDelete.js +31 -0
- package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
- package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
- package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
- package/src/client/actions/GuildStickerCreate.js +20 -0
- package/src/client/actions/GuildStickerDelete.js +21 -0
- package/src/client/actions/GuildStickerUpdate.js +20 -0
- package/src/client/actions/GuildStickersUpdate.js +34 -0
- package/src/client/actions/GuildUpdate.js +33 -0
- package/src/client/actions/InviteCreate.js +28 -0
- package/src/client/actions/InviteDelete.js +30 -0
- package/src/client/actions/MessageCreate.js +50 -0
- package/src/client/actions/MessageDelete.js +32 -0
- package/src/client/actions/MessageDeleteBulk.js +46 -0
- package/src/client/actions/MessagePollVoteAdd.js +33 -0
- package/src/client/actions/MessagePollVoteRemove.js +33 -0
- package/src/client/actions/MessageReactionAdd.js +68 -0
- package/src/client/actions/MessageReactionRemove.js +50 -0
- package/src/client/actions/MessageReactionRemoveAll.js +33 -0
- package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
- package/src/client/actions/MessageUpdate.js +26 -0
- package/src/client/actions/PresenceUpdate.js +50 -0
- package/src/client/actions/StageInstanceCreate.js +28 -0
- package/src/client/actions/StageInstanceDelete.js +33 -0
- package/src/client/actions/StageInstanceUpdate.js +30 -0
- package/src/client/actions/ThreadCreate.js +24 -0
- package/src/client/actions/ThreadDelete.js +32 -0
- package/src/client/actions/ThreadListSync.js +59 -0
- package/src/client/actions/ThreadMemberUpdate.js +30 -0
- package/src/client/actions/ThreadMembersUpdate.js +34 -0
- package/src/client/actions/TypingStart.js +29 -0
- package/src/client/actions/UserUpdate.js +35 -0
- package/src/client/actions/VoiceStateUpdate.js +50 -0
- package/src/client/actions/WebhooksUpdate.js +20 -0
- package/src/client/voice/ClientVoiceManager.js +151 -0
- package/src/client/voice/VoiceConnection.js +1249 -0
- package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
- package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
- package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
- package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
- package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
- package/src/client/voice/networking/VoiceUDPClient.js +173 -0
- package/src/client/voice/networking/VoiceWebSocket.js +286 -0
- package/src/client/voice/player/MediaPlayer.js +321 -0
- package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
- package/src/client/voice/player/processing/IvfSplitter.js +106 -0
- package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
- package/src/client/voice/receiver/PacketHandler.js +260 -0
- package/src/client/voice/receiver/Receiver.js +96 -0
- package/src/client/voice/receiver/Recorder.js +173 -0
- package/src/client/voice/util/Function.js +116 -0
- package/src/client/voice/util/PlayInterface.js +122 -0
- package/src/client/voice/util/Secretbox.js +64 -0
- package/src/client/voice/util/Silence.js +16 -0
- package/src/client/voice/util/Socket.js +62 -0
- package/src/client/voice/util/VolumeInterface.js +104 -0
- package/src/client/websocket/WebSocketManager.js +392 -0
- package/src/client/websocket/WebSocketShard.js +907 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
- package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
- package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
- package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
- package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
- package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
- package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -0
- package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
- package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
- package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
- package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
- package/src/client/websocket/handlers/GUILD_CREATE.js +52 -0
- package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
- package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
- package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
- package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
- package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
- package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
- package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
- package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -0
- package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
- package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
- package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/READY.js +121 -0
- package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -0
- package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -0
- package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -0
- package/src/client/websocket/handlers/RESUMED.js +14 -0
- package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
- package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
- package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
- package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
- package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
- package/src/client/websocket/handlers/TYPING_START.js +5 -0
- package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -0
- package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -0
- package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
- package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
- package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -0
- package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
- package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/index.js +84 -0
- package/src/errors/DJSError.js +61 -0
- package/src/errors/Messages.js +217 -0
- package/src/errors/index.js +4 -0
- package/src/index.js +172 -0
- package/src/managers/ApplicationCommandManager.js +264 -0
- package/src/managers/ApplicationCommandPermissionsManager.js +417 -0
- package/src/managers/AutoModerationRuleManager.js +296 -0
- package/src/managers/BaseGuildEmojiManager.js +80 -0
- package/src/managers/BaseManager.js +19 -0
- package/src/managers/BillingManager.js +66 -0
- package/src/managers/CachedManager.js +71 -0
- package/src/managers/ChannelManager.js +148 -0
- package/src/managers/ClientUserSettingManager.js +372 -0
- package/src/managers/DataManager.js +61 -0
- package/src/managers/DeveloperManager.js +254 -0
- package/src/managers/GuildBanManager.js +250 -0
- package/src/managers/GuildChannelManager.js +488 -0
- package/src/managers/GuildEmojiManager.js +171 -0
- package/src/managers/GuildEmojiRoleManager.js +118 -0
- package/src/managers/GuildForumThreadManager.js +108 -0
- package/src/managers/GuildInviteManager.js +213 -0
- package/src/managers/GuildManager.js +338 -0
- package/src/managers/GuildMemberManager.js +599 -0
- package/src/managers/GuildMemberRoleManager.js +195 -0
- package/src/managers/GuildScheduledEventManager.js +314 -0
- package/src/managers/GuildSettingManager.js +155 -0
- package/src/managers/GuildStickerManager.js +179 -0
- package/src/managers/GuildTextThreadManager.js +98 -0
- package/src/managers/InteractionManager.js +39 -0
- package/src/managers/MessageManager.js +423 -0
- package/src/managers/PermissionOverwriteManager.js +164 -0
- package/src/managers/PresenceManager.js +71 -0
- package/src/managers/QuestManager.js +353 -0
- package/src/managers/ReactionManager.js +67 -0
- package/src/managers/ReactionUserManager.js +73 -0
- package/src/managers/RelationshipManager.js +278 -0
- package/src/managers/RoleManager.js +448 -0
- package/src/managers/SessionManager.js +66 -0
- package/src/managers/StageInstanceManager.js +162 -0
- package/src/managers/ThreadManager.js +175 -0
- package/src/managers/ThreadMemberManager.js +186 -0
- package/src/managers/UserManager.js +136 -0
- package/src/managers/UserNoteManager.js +53 -0
- package/src/managers/VoiceStateManager.js +59 -0
- package/src/rest/APIRequest.js +154 -0
- package/src/rest/APIRouter.js +53 -0
- package/src/rest/DiscordAPIError.js +119 -0
- package/src/rest/HTTPError.js +62 -0
- package/src/rest/RESTManager.js +67 -0
- package/src/rest/RateLimitError.js +55 -0
- package/src/rest/RequestHandler.js +466 -0
- package/src/sharding/Shard.js +444 -0
- package/src/sharding/ShardClientUtil.js +279 -0
- package/src/sharding/ShardingManager.js +319 -0
- package/src/structures/AnonymousGuild.js +98 -0
- package/src/structures/ApplicationCommand.js +593 -0
- package/src/structures/ApplicationRoleConnectionMetadata.js +48 -0
- package/src/structures/AutoModerationActionExecution.js +89 -0
- package/src/structures/AutoModerationRule.js +294 -0
- package/src/structures/AutocompleteInteraction.js +107 -0
- package/src/structures/Base.js +43 -0
- package/src/structures/BaseCommandInteraction.js +211 -0
- package/src/structures/BaseGuild.js +116 -0
- package/src/structures/BaseGuildEmoji.js +56 -0
- package/src/structures/BaseGuildTextChannel.js +191 -0
- package/src/structures/BaseGuildVoiceChannel.js +241 -0
- package/src/structures/BaseMessageComponent.js +181 -0
- package/src/structures/ButtonInteraction.js +11 -0
- package/src/structures/CallState.js +63 -0
- package/src/structures/CategoryChannel.js +85 -0
- package/src/structures/Channel.js +284 -0
- package/src/structures/ClientPresence.js +77 -0
- package/src/structures/ClientUser.js +655 -0
- package/src/structures/CommandInteraction.js +41 -0
- package/src/structures/CommandInteractionOptionResolver.js +276 -0
- package/src/structures/ContainerComponent.js +68 -0
- package/src/structures/ContextMenuInteraction.js +65 -0
- package/src/structures/DMChannel.js +219 -0
- package/src/structures/DirectoryChannel.js +20 -0
- package/src/structures/Emoji.js +148 -0
- package/src/structures/FileComponent.js +49 -0
- package/src/structures/ForumChannel.js +31 -0
- package/src/structures/GroupDMChannel.js +394 -0
- package/src/structures/Guild.js +1791 -0
- package/src/structures/GuildAuditLogs.js +746 -0
- package/src/structures/GuildBan.js +59 -0
- package/src/structures/GuildBoost.js +108 -0
- package/src/structures/GuildChannel.js +470 -0
- package/src/structures/GuildEmoji.js +161 -0
- package/src/structures/GuildMember.js +636 -0
- package/src/structures/GuildPreview.js +191 -0
- package/src/structures/GuildPreviewEmoji.js +27 -0
- package/src/structures/GuildScheduledEvent.js +536 -0
- package/src/structures/GuildTemplate.js +236 -0
- package/src/structures/Integration.js +188 -0
- package/src/structures/IntegrationApplication.js +96 -0
- package/src/structures/Interaction.js +290 -0
- package/src/structures/InteractionCollector.js +248 -0
- package/src/structures/InteractionWebhook.js +43 -0
- package/src/structures/Invite.js +358 -0
- package/src/structures/InviteGuild.js +23 -0
- package/src/structures/InviteStageInstance.js +86 -0
- package/src/structures/MediaChannel.js +11 -0
- package/src/structures/MediaGalleryComponent.js +41 -0
- package/src/structures/MediaGalleryItem.js +47 -0
- package/src/structures/Message.js +1252 -0
- package/src/structures/MessageActionRow.js +105 -0
- package/src/structures/MessageAttachment.js +216 -0
- package/src/structures/MessageButton.js +166 -0
- package/src/structures/MessageCollector.js +146 -0
- package/src/structures/MessageComponentInteraction.js +120 -0
- package/src/structures/MessageContextMenuInteraction.js +20 -0
- package/src/structures/MessageEmbed.js +596 -0
- package/src/structures/MessageMentions.js +273 -0
- package/src/structures/MessagePayload.js +354 -0
- package/src/structures/MessageReaction.js +181 -0
- package/src/structures/MessageSelectMenu.js +141 -0
- package/src/structures/Modal.js +161 -0
- package/src/structures/ModalSubmitFieldsResolver.js +53 -0
- package/src/structures/ModalSubmitInteraction.js +119 -0
- package/src/structures/NewsChannel.js +32 -0
- package/src/structures/OAuth2Guild.js +28 -0
- package/src/structures/PermissionOverwrites.js +198 -0
- package/src/structures/Poll.js +108 -0
- package/src/structures/PollAnswer.js +88 -0
- package/src/structures/Presence.js +1157 -0
- package/src/structures/ReactionCollector.js +229 -0
- package/src/structures/ReactionEmoji.js +31 -0
- package/src/structures/Role.js +590 -0
- package/src/structures/SectionComponent.js +48 -0
- package/src/structures/SelectMenuInteraction.js +21 -0
- package/src/structures/SeparatorComponent.js +48 -0
- package/src/structures/Session.js +81 -0
- package/src/structures/StageChannel.js +104 -0
- package/src/structures/StageInstance.js +208 -0
- package/src/structures/Sticker.js +310 -0
- package/src/structures/StickerPack.js +95 -0
- package/src/structures/StoreChannel.js +56 -0
- package/src/structures/Team.js +118 -0
- package/src/structures/TeamMember.js +80 -0
- package/src/structures/TextChannel.js +33 -0
- package/src/structures/TextDisplayComponent.js +40 -0
- package/src/structures/TextInputComponent.js +132 -0
- package/src/structures/ThreadChannel.js +605 -0
- package/src/structures/ThreadMember.js +105 -0
- package/src/structures/ThreadOnlyChannel.js +249 -0
- package/src/structures/ThumbnailComponent.js +57 -0
- package/src/structures/Typing.js +74 -0
- package/src/structures/UnfurledMediaItem.js +29 -0
- package/src/structures/User.js +640 -0
- package/src/structures/UserContextMenuInteraction.js +29 -0
- package/src/structures/VoiceChannel.js +110 -0
- package/src/structures/VoiceChannelEffect.js +69 -0
- package/src/structures/VoiceRegion.js +53 -0
- package/src/structures/VoiceState.js +354 -0
- package/src/structures/WebEmbed.js +373 -0
- package/src/structures/Webhook.js +478 -0
- package/src/structures/WelcomeChannel.js +60 -0
- package/src/structures/WelcomeScreen.js +48 -0
- package/src/structures/Widget.js +87 -0
- package/src/structures/WidgetMember.js +99 -0
- package/src/structures/interfaces/Application.js +953 -0
- package/src/structures/interfaces/Collector.js +300 -0
- package/src/structures/interfaces/InteractionResponses.js +313 -0
- package/src/structures/interfaces/TextBasedChannel.js +821 -0
- package/src/util/APITypes.js +59 -0
- package/src/util/ActivityFlags.js +44 -0
- package/src/util/ApplicationFlags.js +76 -0
- package/src/util/AttachmentFlags.js +38 -0
- package/src/util/BitField.js +170 -0
- package/src/util/ChannelFlags.js +45 -0
- package/src/util/Constants.js +1914 -0
- package/src/util/DataResolver.js +146 -0
- package/src/util/Formatters.js +228 -0
- package/src/util/GuildMemberFlags.js +43 -0
- package/src/util/Intents.js +74 -0
- package/src/util/InviteFlags.js +34 -0
- package/src/util/LimitedCollection.js +131 -0
- package/src/util/MessageFlags.js +63 -0
- package/src/util/Options.js +358 -0
- package/src/util/Permissions.js +202 -0
- package/src/util/PremiumUsageFlags.js +31 -0
- package/src/util/PurchasedFlags.js +33 -0
- package/src/util/RemoteAuth.js +415 -0
- package/src/util/RoleFlags.js +37 -0
- package/src/util/SnowflakeUtil.js +92 -0
- package/src/util/Speaking.js +33 -0
- package/src/util/Sweepers.js +466 -0
- package/src/util/SystemChannelFlags.js +55 -0
- package/src/util/ThreadMemberFlags.js +30 -0
- package/src/util/UserFlags.js +104 -0
- package/src/util/Util.js +1048 -0
- package/typings/enums.d.ts +439 -0
- package/typings/index.d.ts +8505 -0
- package/typings/index.test-d.ts +0 -0
- package/typings/rawDataTypes.d.ts +403 -0
|
@@ -0,0 +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 (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
|
+
*/
|
|
@@ -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;
|