safeness-sb-new 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +115 -0
- package/package.json +96 -0
- package/src/WebSocket.js +39 -0
- package/src/client/BaseClient.js +86 -0
- package/src/client/Client.js +836 -0
- package/src/client/WebhookClient.js +61 -0
- package/src/client/actions/Action.js +120 -0
- package/src/client/actions/ActionsManager.js +78 -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 +46 -0
- package/src/client/actions/MessageDelete.js +32 -0
- package/src/client/actions/MessageDeleteBulk.js +46 -0
- package/src/client/actions/MessageReactionAdd.js +56 -0
- package/src/client/actions/MessageReactionRemove.js +45 -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 +46 -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 +57 -0
- package/src/client/actions/WebhooksUpdate.js +20 -0
- package/src/client/voice/ClientVoiceManager.js +150 -0
- package/src/client/voice/VoiceConnection.js +849 -0
- package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
- package/src/client/voice/dispatcher/AudioDispatcher.js +115 -0
- package/src/client/voice/dispatcher/BaseDispatcher.js +405 -0
- package/src/client/voice/dispatcher/VPxDispatcher.js +52 -0
- package/src/client/voice/dispatcher/VideoDispatcher.js +31 -0
- package/src/client/voice/networking/VoiceUDPClient.js +188 -0
- package/src/client/voice/networking/VoiceWebSocket.js +280 -0
- package/src/client/voice/player/MediaPlayer.js +294 -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/receiver/PacketHandler.js +170 -0
- package/src/client/voice/receiver/Receiver.js +82 -0
- package/src/client/voice/receiver/video/IvfJoinner.js +106 -0
- package/src/client/voice/util/Function.js +14 -0
- package/src/client/voice/util/PlayInterface.js +122 -0
- package/src/client/voice/util/Secretbox.js +42 -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 +906 -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 +22 -0
- package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +12 -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 +120 -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_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 +83 -0
- package/src/errors/DJSError.js +61 -0
- package/src/errors/Messages.js +208 -0
- package/src/errors/index.js +4 -0
- package/src/index.js +159 -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 +138 -0
- package/src/managers/ClientUserSettingManager.js +372 -0
- package/src/managers/DataManager.js +61 -0
- package/src/managers/GuildBanManager.js +204 -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 +304 -0
- package/src/managers/GuildMemberManager.js +597 -0
- package/src/managers/GuildMemberRoleManager.js +191 -0
- package/src/managers/GuildScheduledEventManager.js +296 -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 +391 -0
- package/src/managers/PermissionOverwriteManager.js +166 -0
- package/src/managers/PresenceManager.js +58 -0
- package/src/managers/ReactionManager.js +67 -0
- package/src/managers/ReactionUserManager.js +71 -0
- package/src/managers/RelationshipManager.js +265 -0
- package/src/managers/RoleManager.js +352 -0
- package/src/managers/StageInstanceManager.js +162 -0
- package/src/managers/ThreadManager.js +174 -0
- package/src/managers/ThreadMemberManager.js +186 -0
- package/src/managers/UserManager.js +146 -0
- package/src/managers/UserNoteManager.js +53 -0
- package/src/managers/VoiceStateManager.js +37 -0
- package/src/rest/APIRequest.js +159 -0
- package/src/rest/APIRouter.js +53 -0
- package/src/rest/DiscordAPIError.js +104 -0
- package/src/rest/HTTPError.js +62 -0
- package/src/rest/RESTManager.js +62 -0
- package/src/rest/RateLimitError.js +55 -0
- package/src/rest/RequestHandler.js +444 -0
- package/src/sharding/Shard.js +443 -0
- package/src/sharding/ShardClientUtil.js +275 -0
- package/src/sharding/ShardingManager.js +318 -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 +114 -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 +270 -0
- package/src/structures/ClientPresence.js +77 -0
- package/src/structures/ClientUser.js +450 -0
- package/src/structures/CommandInteraction.js +41 -0
- package/src/structures/CommandInteractionOptionResolver.js +276 -0
- package/src/structures/ContextMenuInteraction.js +65 -0
- package/src/structures/DMChannel.js +217 -0
- package/src/structures/DirectoryChannel.js +20 -0
- package/src/structures/Emoji.js +148 -0
- package/src/structures/ForumChannel.js +261 -0
- package/src/structures/GroupDMChannel.js +387 -0
- package/src/structures/Guild.js +1608 -0
- package/src/structures/GuildAuditLogs.js +729 -0
- package/src/structures/GuildBan.js +59 -0
- package/src/structures/GuildBoost.js +108 -0
- package/src/structures/GuildChannel.js +468 -0
- package/src/structures/GuildEmoji.js +161 -0
- package/src/structures/GuildMember.js +568 -0
- package/src/structures/GuildPreview.js +191 -0
- package/src/structures/GuildPreviewEmoji.js +27 -0
- package/src/structures/GuildScheduledEvent.js +441 -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/Message.js +1227 -0
- package/src/structures/MessageActionRow.js +103 -0
- package/src/structures/MessageAttachment.js +204 -0
- package/src/structures/MessageButton.js +165 -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 +586 -0
- package/src/structures/MessageMentions.js +273 -0
- package/src/structures/MessagePayload.js +318 -0
- package/src/structures/MessagePoll.js +238 -0
- package/src/structures/MessageReaction.js +171 -0
- package/src/structures/MessageSelectMenu.js +140 -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 +196 -0
- package/src/structures/Presence.js +1131 -0
- package/src/structures/ReactionCollector.js +229 -0
- package/src/structures/ReactionEmoji.js +31 -0
- package/src/structures/Role.js +531 -0
- package/src/structures/SelectMenuInteraction.js +21 -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 +71 -0
- package/src/structures/TextChannel.js +33 -0
- package/src/structures/TextInputComponent.js +131 -0
- package/src/structures/ThreadChannel.js +607 -0
- package/src/structures/ThreadMember.js +105 -0
- package/src/structures/Typing.js +74 -0
- package/src/structures/User.js +543 -0
- package/src/structures/UserContextMenuInteraction.js +29 -0
- package/src/structures/VoiceChannel.js +110 -0
- package/src/structures/VoiceRegion.js +53 -0
- package/src/structures/VoiceState.js +345 -0
- package/src/structures/WebEmbed.js +373 -0
- package/src/structures/Webhook.js +467 -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 +313 -0
- package/src/structures/interfaces/Collector.js +300 -0
- package/src/structures/interfaces/InteractionResponses.js +313 -0
- package/src/structures/interfaces/TextBasedChannel.js +719 -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 +1815 -0
- package/src/util/DataResolver.js +145 -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 +29 -0
- package/src/util/LimitedCollection.js +131 -0
- package/src/util/MessageFlags.js +54 -0
- package/src/util/Options.js +336 -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 +382 -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 +889 -0
- package/typings/enums.d.ts +297 -0
- package/typings/index.d.ts +7670 -0
- package/typings/index.test-d.ts +0 -0
- package/typings/rawDataTypes.d.ts +342 -0
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const Base = require('./Base');
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Represents a WidgetMember.
|
|
7
|
+
* @extends {Base}
|
|
8
|
+
*/
|
|
9
|
+
class WidgetMember extends Base {
|
|
10
|
+
/**
|
|
11
|
+
* Activity sent in a {@link WidgetMember}.
|
|
12
|
+
* @typedef {Object} WidgetActivity
|
|
13
|
+
* @property {string} name The name of the activity
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
constructor(client, data) {
|
|
17
|
+
super(client);
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* The id of the user. It's an arbitrary number.
|
|
21
|
+
* @type {string}
|
|
22
|
+
*/
|
|
23
|
+
this.id = data.id;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* The username of the member.
|
|
27
|
+
* @type {string}
|
|
28
|
+
*/
|
|
29
|
+
this.username = data.username;
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* The discriminator of the member.
|
|
33
|
+
* @type {string}
|
|
34
|
+
*/
|
|
35
|
+
this.discriminator = data.discriminator;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* The avatar of the member.
|
|
39
|
+
* @type {?string}
|
|
40
|
+
*/
|
|
41
|
+
this.avatar = data.avatar;
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* The status of the member.
|
|
45
|
+
* @type {PresenceStatus}
|
|
46
|
+
*/
|
|
47
|
+
this.status = data.status;
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* If the member is server deafened
|
|
51
|
+
* @type {?boolean}
|
|
52
|
+
*/
|
|
53
|
+
this.deaf = data.deaf ?? null;
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* If the member is server muted
|
|
57
|
+
* @type {?boolean}
|
|
58
|
+
*/
|
|
59
|
+
this.mute = data.mute ?? null;
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* If the member is self deafened
|
|
63
|
+
* @type {?boolean}
|
|
64
|
+
*/
|
|
65
|
+
this.selfDeaf = data.self_deaf ?? null;
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* If the member is self muted
|
|
69
|
+
* @type {?boolean}
|
|
70
|
+
*/
|
|
71
|
+
this.selfMute = data.self_mute ?? null;
|
|
72
|
+
|
|
73
|
+
/**
|
|
74
|
+
* If the member is suppressed
|
|
75
|
+
* @type {?boolean}
|
|
76
|
+
*/
|
|
77
|
+
this.suppress = data.suppress ?? null;
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* The id of the voice channel the member is in, if any
|
|
81
|
+
* @type {?Snowflake}
|
|
82
|
+
*/
|
|
83
|
+
this.channelId = data.channel_id ?? null;
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* The avatar URL of the member.
|
|
87
|
+
* @type {string}
|
|
88
|
+
*/
|
|
89
|
+
this.avatarURL = data.avatar_url;
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* The activity of the member.
|
|
93
|
+
* @type {?WidgetActivity}
|
|
94
|
+
*/
|
|
95
|
+
this.activity = data.activity ?? null;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
module.exports = WidgetMember;
|
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const process = require('node:process');
|
|
4
|
+
const { ApplicationFlags } = require('../../util/ApplicationFlags');
|
|
5
|
+
const { ClientApplicationAssetTypes, Endpoints } = require('../../util/Constants');
|
|
6
|
+
const Permissions = require('../../util/Permissions');
|
|
7
|
+
const SnowflakeUtil = require('../../util/SnowflakeUtil');
|
|
8
|
+
const { ApplicationRoleConnectionMetadata } = require('../ApplicationRoleConnectionMetadata');
|
|
9
|
+
const Base = require('../Base');
|
|
10
|
+
const Team = require('../Team');
|
|
11
|
+
|
|
12
|
+
const AssetTypes = Object.keys(ClientApplicationAssetTypes);
|
|
13
|
+
|
|
14
|
+
let deprecationEmittedForFetchAssets = false;
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Represents an OAuth2 Application.
|
|
18
|
+
* @extends {Base}
|
|
19
|
+
* @abstract
|
|
20
|
+
*/
|
|
21
|
+
class Application extends Base {
|
|
22
|
+
constructor(client, data) {
|
|
23
|
+
super(client);
|
|
24
|
+
this._patch(data);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
_patch(data) {
|
|
28
|
+
/**
|
|
29
|
+
* The application's id
|
|
30
|
+
* @type {Snowflake}
|
|
31
|
+
*/
|
|
32
|
+
this.id = data.id;
|
|
33
|
+
|
|
34
|
+
if ('name' in data) {
|
|
35
|
+
/**
|
|
36
|
+
* The name of the application
|
|
37
|
+
* @type {?string}
|
|
38
|
+
*/
|
|
39
|
+
this.name = data.name;
|
|
40
|
+
} else {
|
|
41
|
+
this.name ??= null;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
if ('description' in data) {
|
|
45
|
+
/**
|
|
46
|
+
* The application's description
|
|
47
|
+
* @type {?string}
|
|
48
|
+
*/
|
|
49
|
+
this.description = data.description;
|
|
50
|
+
} else {
|
|
51
|
+
this.description ??= null;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
if ('icon' in data) {
|
|
55
|
+
/**
|
|
56
|
+
* The application's icon hash
|
|
57
|
+
* @type {?string}
|
|
58
|
+
*/
|
|
59
|
+
this.icon = data.icon;
|
|
60
|
+
} else {
|
|
61
|
+
this.icon ??= null;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
if ('role_connections_verification_url' in data) {
|
|
65
|
+
/**
|
|
66
|
+
* This application's role connection verification entry point URL
|
|
67
|
+
* @type {?string}
|
|
68
|
+
*/
|
|
69
|
+
this.roleConnectionsVerificationURL = data.role_connections_verification_url;
|
|
70
|
+
} else {
|
|
71
|
+
this.roleConnectionsVerificationURL ??= null;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
// ClientApplication
|
|
75
|
+
/**
|
|
76
|
+
* The tags this application has (max of 5)
|
|
77
|
+
* @type {string[]}
|
|
78
|
+
*/
|
|
79
|
+
this.tags = data.tags ?? [];
|
|
80
|
+
|
|
81
|
+
if ('install_params' in data) {
|
|
82
|
+
/**
|
|
83
|
+
* Settings for this application's default in-app authorization
|
|
84
|
+
* @type {?ClientApplicationInstallParams}
|
|
85
|
+
*/
|
|
86
|
+
this.installParams = {
|
|
87
|
+
scopes: data.install_params.scopes,
|
|
88
|
+
permissions: new Permissions(data.install_params.permissions).freeze(),
|
|
89
|
+
};
|
|
90
|
+
} else {
|
|
91
|
+
this.installParams ??= null;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
if ('custom_install_url' in data) {
|
|
95
|
+
/**
|
|
96
|
+
* This application's custom installation URL
|
|
97
|
+
* @type {?string}
|
|
98
|
+
*/
|
|
99
|
+
this.customInstallURL = data.custom_install_url;
|
|
100
|
+
} else {
|
|
101
|
+
this.customInstallURL = null;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
if ('flags' in data) {
|
|
105
|
+
/**
|
|
106
|
+
* The flags this application has
|
|
107
|
+
* @type {ApplicationFlags}
|
|
108
|
+
*/
|
|
109
|
+
this.flags = new ApplicationFlags(data.flags).freeze();
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
if ('approximate_guild_count' in data) {
|
|
113
|
+
/**
|
|
114
|
+
* An approximate amount of guilds this application is in.
|
|
115
|
+
* @type {?number}
|
|
116
|
+
*/
|
|
117
|
+
this.approximateGuildCount = data.approximate_guild_count;
|
|
118
|
+
} else {
|
|
119
|
+
this.approximateGuildCount ??= null;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
if ('guild_id' in data) {
|
|
123
|
+
/**
|
|
124
|
+
* The id of the guild associated with this application.
|
|
125
|
+
* @type {?Snowflake}
|
|
126
|
+
*/
|
|
127
|
+
this.guildId = data.guild_id;
|
|
128
|
+
} else {
|
|
129
|
+
this.guildId ??= null;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
if ('cover_image' in data) {
|
|
133
|
+
/**
|
|
134
|
+
* The hash of the application's cover image
|
|
135
|
+
* @type {?string}
|
|
136
|
+
*/
|
|
137
|
+
this.cover = data.cover_image;
|
|
138
|
+
} else {
|
|
139
|
+
this.cover ??= null;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
if ('rpc_origins' in data) {
|
|
143
|
+
/**
|
|
144
|
+
* The application's RPC origins, if enabled
|
|
145
|
+
* @type {string[]}
|
|
146
|
+
*/
|
|
147
|
+
this.rpcOrigins = data.rpc_origins;
|
|
148
|
+
} else {
|
|
149
|
+
this.rpcOrigins ??= [];
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
if ('bot_require_code_grant' in data) {
|
|
153
|
+
/**
|
|
154
|
+
* If this application's bot requires a code grant when using the OAuth2 flow
|
|
155
|
+
* @type {?boolean}
|
|
156
|
+
*/
|
|
157
|
+
this.botRequireCodeGrant = data.bot_require_code_grant;
|
|
158
|
+
} else {
|
|
159
|
+
this.botRequireCodeGrant ??= null;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
if ('bot_public' in data) {
|
|
163
|
+
/**
|
|
164
|
+
* If this application's bot is public
|
|
165
|
+
* @type {?boolean}
|
|
166
|
+
*/
|
|
167
|
+
this.botPublic = data.bot_public;
|
|
168
|
+
} else {
|
|
169
|
+
this.botPublic ??= null;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* The owner of this OAuth application
|
|
174
|
+
* @type {?(User|Team)}
|
|
175
|
+
*/
|
|
176
|
+
this.owner = data.team
|
|
177
|
+
? new Team(this.client, data.team)
|
|
178
|
+
: data.owner
|
|
179
|
+
? this.client.users._add(data.owner)
|
|
180
|
+
: this.owner ?? null;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
/**
|
|
184
|
+
* The guild associated with this application.
|
|
185
|
+
* @type {?Guild}
|
|
186
|
+
* @readonly
|
|
187
|
+
*/
|
|
188
|
+
get guild() {
|
|
189
|
+
return this.client.guilds.cache.get(this.guildId) ?? null;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* Whether this application is partial
|
|
194
|
+
* @type {boolean}
|
|
195
|
+
* @readonly
|
|
196
|
+
*/
|
|
197
|
+
get partial() {
|
|
198
|
+
return !this.name;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
/**
|
|
202
|
+
* The timestamp the application was created at
|
|
203
|
+
* @type {number}
|
|
204
|
+
* @readonly
|
|
205
|
+
*/
|
|
206
|
+
get createdTimestamp() {
|
|
207
|
+
return SnowflakeUtil.timestampFrom(this.id);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* The time the application was created at
|
|
212
|
+
* @type {Date}
|
|
213
|
+
* @readonly
|
|
214
|
+
*/
|
|
215
|
+
get createdAt() {
|
|
216
|
+
return new Date(this.createdTimestamp);
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
/**
|
|
220
|
+
* Obtains this application from Discord.
|
|
221
|
+
* @returns {Promise<Application>}
|
|
222
|
+
*/
|
|
223
|
+
async fetch() {
|
|
224
|
+
const app = await this.client.api.oauth2.authorize.get({
|
|
225
|
+
query: {
|
|
226
|
+
client_id: this.id,
|
|
227
|
+
scope: 'bot applications.commands',
|
|
228
|
+
},
|
|
229
|
+
});
|
|
230
|
+
const user = this.client.users._add(app.bot);
|
|
231
|
+
user._partial = false;
|
|
232
|
+
this._patch(app.application);
|
|
233
|
+
return this;
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
/**
|
|
237
|
+
* Gets this application's role connection metadata records
|
|
238
|
+
* @returns {Promise<ApplicationRoleConnectionMetadata[]>}
|
|
239
|
+
*/
|
|
240
|
+
async fetchRoleConnectionMetadataRecords() {
|
|
241
|
+
const metadata = await this.client.api.applications(this.id)('role-connections').metadata.get();
|
|
242
|
+
return metadata.map(data => new ApplicationRoleConnectionMetadata(data));
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
/**
|
|
246
|
+
* A link to the application's icon.
|
|
247
|
+
* @param {StaticImageURLOptions} [options={}] Options for the Image URL
|
|
248
|
+
* @returns {?string}
|
|
249
|
+
*/
|
|
250
|
+
iconURL({ format, size } = {}) {
|
|
251
|
+
if (!this.icon) return null;
|
|
252
|
+
return this.client.rest.cdn.AppIcon(this.id, this.icon, { format, size });
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* A link to this application's cover image.
|
|
257
|
+
* @param {StaticImageURLOptions} [options={}] Options for the Image URL
|
|
258
|
+
* @returns {?string}
|
|
259
|
+
*/
|
|
260
|
+
coverURL({ format, size } = {}) {
|
|
261
|
+
if (!this.cover) return null;
|
|
262
|
+
return Endpoints.CDN(this.client.options.http.cdn).AppIcon(this.id, this.cover, { format, size });
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
/**
|
|
266
|
+
* Asset data.
|
|
267
|
+
* @typedef {Object} ApplicationAsset
|
|
268
|
+
* @property {Snowflake} id The asset's id
|
|
269
|
+
* @property {string} name The asset's name
|
|
270
|
+
* @property {string} type The asset's type
|
|
271
|
+
*/
|
|
272
|
+
|
|
273
|
+
/**
|
|
274
|
+
* Gets the application's rich presence assets.
|
|
275
|
+
* @returns {Promise<Array<ApplicationAsset>>}
|
|
276
|
+
* @deprecated This will be removed in the next major as it is unsupported functionality.
|
|
277
|
+
*/
|
|
278
|
+
async fetchAssets() {
|
|
279
|
+
if (!deprecationEmittedForFetchAssets) {
|
|
280
|
+
process.emitWarning(
|
|
281
|
+
'Application#fetchAssets is deprecated as it is unsupported and will be removed in the next major version.',
|
|
282
|
+
'DeprecationWarning',
|
|
283
|
+
);
|
|
284
|
+
|
|
285
|
+
deprecationEmittedForFetchAssets = true;
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
const assets = await this.client.api.oauth2.applications(this.id).assets.get();
|
|
289
|
+
return assets.map(a => ({
|
|
290
|
+
id: a.id,
|
|
291
|
+
name: a.name,
|
|
292
|
+
type: AssetTypes[a.type - 1],
|
|
293
|
+
}));
|
|
294
|
+
}
|
|
295
|
+
|
|
296
|
+
/**
|
|
297
|
+
* When concatenated with a string, this automatically returns the application's name instead of the
|
|
298
|
+
* Application object.
|
|
299
|
+
* @returns {?string}
|
|
300
|
+
* @example
|
|
301
|
+
* // Logs: Application name: My App
|
|
302
|
+
* console.log(`Application name: ${application}`);
|
|
303
|
+
*/
|
|
304
|
+
toString() {
|
|
305
|
+
return this.name;
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
toJSON() {
|
|
309
|
+
return super.toJSON({ createdTimestamp: true });
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
module.exports = Application;
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const EventEmitter = require('node:events');
|
|
4
|
+
const { setTimeout } = require('node:timers');
|
|
5
|
+
const { Collection } = require('@discordjs/collection');
|
|
6
|
+
const { TypeError } = require('../../errors');
|
|
7
|
+
const Util = require('../../util/Util');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Filter to be applied to the collector.
|
|
11
|
+
* @typedef {Function} CollectorFilter
|
|
12
|
+
* @param {...*} args Any arguments received by the listener
|
|
13
|
+
* @param {Collection} collection The items collected by this collector
|
|
14
|
+
* @returns {boolean|Promise<boolean>}
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Options to be applied to the collector.
|
|
19
|
+
* @typedef {Object} CollectorOptions
|
|
20
|
+
* @property {CollectorFilter} [filter] The filter applied to this collector
|
|
21
|
+
* @property {number} [time] How long to run the collector for in milliseconds
|
|
22
|
+
* @property {number} [idle] How long to stop the collector after inactivity in milliseconds
|
|
23
|
+
* @property {boolean} [dispose=false] Whether to dispose data when it's deleted
|
|
24
|
+
*/
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Abstract class for defining a new Collector.
|
|
28
|
+
* @extends {EventEmitter}
|
|
29
|
+
* @abstract
|
|
30
|
+
*/
|
|
31
|
+
class Collector extends EventEmitter {
|
|
32
|
+
constructor(client, options = {}) {
|
|
33
|
+
super();
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* The client that instantiated this Collector
|
|
37
|
+
* @name Collector#client
|
|
38
|
+
* @type {Client}
|
|
39
|
+
* @readonly
|
|
40
|
+
*/
|
|
41
|
+
Object.defineProperty(this, 'client', { value: client });
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* The filter applied to this collector
|
|
45
|
+
* @type {CollectorFilter}
|
|
46
|
+
* @returns {boolean|Promise<boolean>}
|
|
47
|
+
*/
|
|
48
|
+
this.filter = options.filter ?? (() => true);
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* The options of this collector
|
|
52
|
+
* @type {CollectorOptions}
|
|
53
|
+
*/
|
|
54
|
+
this.options = options;
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* The items collected by this collector
|
|
58
|
+
* @type {Collection}
|
|
59
|
+
*/
|
|
60
|
+
this.collected = new Collection();
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Whether this collector has finished collecting
|
|
64
|
+
* @type {boolean}
|
|
65
|
+
*/
|
|
66
|
+
this.ended = false;
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Timeout for cleanup
|
|
70
|
+
* @type {?Timeout}
|
|
71
|
+
* @private
|
|
72
|
+
*/
|
|
73
|
+
this._timeout = null;
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Timeout for cleanup due to inactivity
|
|
77
|
+
* @type {?Timeout}
|
|
78
|
+
* @private
|
|
79
|
+
*/
|
|
80
|
+
this._idletimeout = null;
|
|
81
|
+
|
|
82
|
+
if (typeof this.filter !== 'function') {
|
|
83
|
+
throw new TypeError('INVALID_TYPE', 'options.filter', 'function');
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
this.handleCollect = this.handleCollect.bind(this);
|
|
87
|
+
this.handleDispose = this.handleDispose.bind(this);
|
|
88
|
+
|
|
89
|
+
if (options.time) this._timeout = setTimeout(() => this.stop('time'), options.time).unref();
|
|
90
|
+
if (options.idle) this._idletimeout = setTimeout(() => this.stop('idle'), options.idle).unref();
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* Call this to handle an event as a collectable element. Accepts any event data as parameters.
|
|
95
|
+
* @param {...*} args The arguments emitted by the listener
|
|
96
|
+
* @returns {Promise<void>}
|
|
97
|
+
* @emits Collector#collect
|
|
98
|
+
*/
|
|
99
|
+
async handleCollect(...args) {
|
|
100
|
+
const collect = await this.collect(...args);
|
|
101
|
+
|
|
102
|
+
if (collect && (await this.filter(...args, this.collected))) {
|
|
103
|
+
this.collected.set(collect, args[0]);
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Emitted whenever an element is collected.
|
|
107
|
+
* @event Collector#collect
|
|
108
|
+
* @param {...*} args The arguments emitted by the listener
|
|
109
|
+
*/
|
|
110
|
+
this.emit('collect', ...args);
|
|
111
|
+
|
|
112
|
+
if (this._idletimeout) {
|
|
113
|
+
clearTimeout(this._idletimeout);
|
|
114
|
+
this._idletimeout = setTimeout(() => this.stop('idle'), this.options.idle).unref();
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
this.checkEnd();
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
/**
|
|
121
|
+
* Call this to remove an element from the collection. Accepts any event data as parameters.
|
|
122
|
+
* @param {...*} args The arguments emitted by the listener
|
|
123
|
+
* @returns {Promise<void>}
|
|
124
|
+
* @emits Collector#dispose
|
|
125
|
+
*/
|
|
126
|
+
async handleDispose(...args) {
|
|
127
|
+
if (!this.options.dispose) return;
|
|
128
|
+
|
|
129
|
+
const dispose = this.dispose(...args);
|
|
130
|
+
if (!dispose || !(await this.filter(...args)) || !this.collected.has(dispose)) return;
|
|
131
|
+
this.collected.delete(dispose);
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* Emitted whenever an element is disposed of.
|
|
135
|
+
* @event Collector#dispose
|
|
136
|
+
* @param {...*} args The arguments emitted by the listener
|
|
137
|
+
*/
|
|
138
|
+
this.emit('dispose', ...args);
|
|
139
|
+
this.checkEnd();
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* Returns a promise that resolves with the next collected element;
|
|
144
|
+
* rejects with collected elements if the collector finishes without receiving a next element
|
|
145
|
+
* @type {Promise}
|
|
146
|
+
* @readonly
|
|
147
|
+
*/
|
|
148
|
+
get next() {
|
|
149
|
+
return new Promise((resolve, reject) => {
|
|
150
|
+
if (this.ended) {
|
|
151
|
+
reject(this.collected);
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
const cleanup = () => {
|
|
156
|
+
this.removeListener('collect', onCollect);
|
|
157
|
+
this.removeListener('end', onEnd);
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
const onCollect = item => {
|
|
161
|
+
cleanup();
|
|
162
|
+
resolve(item);
|
|
163
|
+
};
|
|
164
|
+
|
|
165
|
+
const onEnd = () => {
|
|
166
|
+
cleanup();
|
|
167
|
+
reject(this.collected); // eslint-disable-line prefer-promise-reject-errors
|
|
168
|
+
};
|
|
169
|
+
|
|
170
|
+
this.on('collect', onCollect);
|
|
171
|
+
this.on('end', onEnd);
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
/**
|
|
176
|
+
* Stops this collector and emits the `end` event.
|
|
177
|
+
* @param {string} [reason='user'] The reason this collector is ending
|
|
178
|
+
* @emits Collector#end
|
|
179
|
+
*/
|
|
180
|
+
stop(reason = 'user') {
|
|
181
|
+
if (this.ended) return;
|
|
182
|
+
|
|
183
|
+
if (this._timeout) {
|
|
184
|
+
clearTimeout(this._timeout);
|
|
185
|
+
this._timeout = null;
|
|
186
|
+
}
|
|
187
|
+
if (this._idletimeout) {
|
|
188
|
+
clearTimeout(this._idletimeout);
|
|
189
|
+
this._idletimeout = null;
|
|
190
|
+
}
|
|
191
|
+
this.ended = true;
|
|
192
|
+
|
|
193
|
+
/**
|
|
194
|
+
* Emitted when the collector is finished collecting.
|
|
195
|
+
* @event Collector#end
|
|
196
|
+
* @param {Collection} collected The elements collected by the collector
|
|
197
|
+
* @param {string} reason The reason the collector ended
|
|
198
|
+
*/
|
|
199
|
+
this.emit('end', this.collected, reason);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
* Options used to reset the timeout and idle timer of a {@link Collector}.
|
|
204
|
+
* @typedef {Object} CollectorResetTimerOptions
|
|
205
|
+
* @property {number} [time] How long to run the collector for (in milliseconds)
|
|
206
|
+
* @property {number} [idle] How long to wait to stop the collector after inactivity (in milliseconds)
|
|
207
|
+
*/
|
|
208
|
+
|
|
209
|
+
/**
|
|
210
|
+
* Resets the collector's timeout and idle timer.
|
|
211
|
+
* @param {CollectorResetTimerOptions} [options] Options for resetting
|
|
212
|
+
*/
|
|
213
|
+
resetTimer({ time, idle } = {}) {
|
|
214
|
+
if (this._timeout) {
|
|
215
|
+
clearTimeout(this._timeout);
|
|
216
|
+
this._timeout = setTimeout(() => this.stop('time'), time ?? this.options.time).unref();
|
|
217
|
+
}
|
|
218
|
+
if (this._idletimeout) {
|
|
219
|
+
clearTimeout(this._idletimeout);
|
|
220
|
+
this._idletimeout = setTimeout(() => this.stop('idle'), idle ?? this.options.idle).unref();
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
/**
|
|
225
|
+
* Checks whether the collector should end, and if so, ends it.
|
|
226
|
+
* @returns {boolean} Whether the collector ended or not
|
|
227
|
+
*/
|
|
228
|
+
checkEnd() {
|
|
229
|
+
const reason = this.endReason;
|
|
230
|
+
if (reason) this.stop(reason);
|
|
231
|
+
return Boolean(reason);
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
/**
|
|
235
|
+
* Allows collectors to be consumed with for-await-of loops
|
|
236
|
+
* @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for-await...of}
|
|
237
|
+
*/
|
|
238
|
+
async *[Symbol.asyncIterator]() {
|
|
239
|
+
const queue = [];
|
|
240
|
+
const onCollect = item => queue.push(item);
|
|
241
|
+
this.on('collect', onCollect);
|
|
242
|
+
|
|
243
|
+
try {
|
|
244
|
+
while (queue.length || !this.ended) {
|
|
245
|
+
if (queue.length) {
|
|
246
|
+
yield queue.shift();
|
|
247
|
+
} else {
|
|
248
|
+
// eslint-disable-next-line no-await-in-loop
|
|
249
|
+
await new Promise(resolve => {
|
|
250
|
+
const tick = () => {
|
|
251
|
+
this.removeListener('collect', tick);
|
|
252
|
+
this.removeListener('end', tick);
|
|
253
|
+
return resolve();
|
|
254
|
+
};
|
|
255
|
+
this.on('collect', tick);
|
|
256
|
+
this.on('end', tick);
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
} finally {
|
|
261
|
+
this.removeListener('collect', onCollect);
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
toJSON() {
|
|
266
|
+
return Util.flatten(this);
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
/* eslint-disable no-empty-function */
|
|
270
|
+
/**
|
|
271
|
+
* The reason this collector has ended with, or null if it hasn't ended yet
|
|
272
|
+
* @type {?string}
|
|
273
|
+
* @readonly
|
|
274
|
+
* @abstract
|
|
275
|
+
*/
|
|
276
|
+
get endReason() {}
|
|
277
|
+
|
|
278
|
+
/**
|
|
279
|
+
* Handles incoming events from the `handleCollect` function. Returns null if the event should not
|
|
280
|
+
* be collected, or returns an object describing the data that should be stored.
|
|
281
|
+
* @see Collector#handleCollect
|
|
282
|
+
* @param {...*} args Any args the event listener emits
|
|
283
|
+
* @returns {?(*|Promise<?*>)} Data to insert into collection, if any
|
|
284
|
+
* @abstract
|
|
285
|
+
*/
|
|
286
|
+
collect() {}
|
|
287
|
+
|
|
288
|
+
/**
|
|
289
|
+
* Handles incoming events from the `handleDispose`. Returns null if the event should not
|
|
290
|
+
* be disposed, or returns the key that should be removed.
|
|
291
|
+
* @see Collector#handleDispose
|
|
292
|
+
* @param {...*} args Any args the event listener emits
|
|
293
|
+
* @returns {?*} Key to remove from the collection, if any
|
|
294
|
+
* @abstract
|
|
295
|
+
*/
|
|
296
|
+
dispose() {}
|
|
297
|
+
/* eslint-enable no-empty-function */
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
module.exports = Collector;
|