djs-selfbot-v13 3.2.2 → 3.7.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 +37 -36
- package/package.json +89 -85
- package/src/WebSocket.js +39 -39
- package/src/client/BaseClient.js +86 -86
- package/src/client/Client.js +934 -836
- package/src/client/WebhookClient.js +61 -61
- package/src/client/actions/Action.js +116 -120
- package/src/client/actions/ActionsManager.js +80 -78
- package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
- package/src/client/actions/AutoModerationActionExecution.js +27 -27
- package/src/client/actions/AutoModerationRuleCreate.js +28 -28
- package/src/client/actions/AutoModerationRuleDelete.js +32 -32
- package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
- package/src/client/actions/ChannelCreate.js +23 -23
- package/src/client/actions/ChannelDelete.js +39 -39
- package/src/client/actions/ChannelUpdate.js +43 -43
- package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
- package/src/client/actions/GuildBanAdd.js +20 -20
- package/src/client/actions/GuildBanRemove.js +25 -25
- package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
- package/src/client/actions/GuildDelete.js +65 -65
- package/src/client/actions/GuildEmojiCreate.js +20 -20
- package/src/client/actions/GuildEmojiDelete.js +21 -21
- package/src/client/actions/GuildEmojiUpdate.js +20 -20
- package/src/client/actions/GuildEmojisUpdate.js +34 -34
- package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
- package/src/client/actions/GuildMemberRemove.js +33 -32
- package/src/client/actions/GuildMemberUpdate.js +44 -43
- package/src/client/actions/GuildRoleCreate.js +25 -25
- package/src/client/actions/GuildRoleDelete.js +31 -31
- package/src/client/actions/GuildRoleUpdate.js +39 -39
- package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
- package/src/client/actions/GuildScheduledEventCreate.js +27 -27
- package/src/client/actions/GuildScheduledEventDelete.js +31 -31
- package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
- package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
- package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
- package/src/client/actions/GuildStickerCreate.js +20 -20
- package/src/client/actions/GuildStickerDelete.js +21 -21
- package/src/client/actions/GuildStickerUpdate.js +20 -20
- package/src/client/actions/GuildStickersUpdate.js +34 -34
- package/src/client/actions/GuildUpdate.js +33 -33
- package/src/client/actions/InviteCreate.js +28 -28
- package/src/client/actions/InviteDelete.js +30 -30
- package/src/client/actions/MessageCreate.js +50 -46
- package/src/client/actions/MessageDelete.js +32 -32
- package/src/client/actions/MessageDeleteBulk.js +46 -46
- package/src/client/actions/MessagePollVoteAdd.js +33 -0
- package/src/client/actions/MessagePollVoteRemove.js +33 -0
- package/src/client/actions/MessageReactionAdd.js +68 -56
- package/src/client/actions/MessageReactionRemove.js +50 -45
- package/src/client/actions/MessageReactionRemoveAll.js +33 -33
- package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
- package/src/client/actions/MessageUpdate.js +26 -26
- package/src/client/actions/PresenceUpdate.js +50 -46
- package/src/client/actions/StageInstanceCreate.js +28 -28
- package/src/client/actions/StageInstanceDelete.js +33 -33
- package/src/client/actions/StageInstanceUpdate.js +30 -30
- package/src/client/actions/ThreadCreate.js +24 -24
- package/src/client/actions/ThreadDelete.js +32 -32
- package/src/client/actions/ThreadListSync.js +59 -59
- package/src/client/actions/ThreadMemberUpdate.js +30 -30
- package/src/client/actions/ThreadMembersUpdate.js +34 -34
- package/src/client/actions/TypingStart.js +29 -29
- package/src/client/actions/UserUpdate.js +35 -35
- package/src/client/actions/VoiceStateUpdate.js +50 -57
- package/src/client/actions/WebhooksUpdate.js +20 -20
- package/src/client/voice/ClientVoiceManager.js +151 -51
- 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 -392
- package/src/client/websocket/WebSocketShard.js +907 -906
- package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
- package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
- package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
- package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
- package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
- package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
- package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
- package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
- package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
- package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
- package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
- package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
- package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
- package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
- package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
- package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
- package/src/client/websocket/handlers/GUILD_CREATE.js +52 -52
- package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
- package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
- package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -19
- package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
- package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
- package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
- package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
- package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
- package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
- package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
- package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -22
- package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -12
- package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
- package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
- package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
- package/src/client/websocket/handlers/READY.js +121 -120
- package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
- package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
- package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
- package/src/client/websocket/handlers/RESUMED.js +14 -14
- package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
- package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
- package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
- package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
- package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
- package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
- package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
- package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
- package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
- package/src/client/websocket/handlers/TYPING_START.js +5 -5
- package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
- package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
- package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
- package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
- package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
- package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
- package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
- package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
- package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
- package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
- package/src/client/websocket/handlers/index.js +84 -83
- package/src/errors/DJSError.js +61 -61
- package/src/errors/Messages.js +217 -183
- package/src/errors/index.js +4 -4
- package/src/index.js +172 -159
- package/src/managers/ApplicationCommandManager.js +264 -264
- package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
- package/src/managers/AutoModerationRuleManager.js +296 -296
- package/src/managers/BaseGuildEmojiManager.js +80 -80
- package/src/managers/BaseManager.js +19 -19
- package/src/managers/BillingManager.js +66 -66
- package/src/managers/CachedManager.js +71 -71
- package/src/managers/ChannelManager.js +148 -138
- package/src/managers/ClientUserSettingManager.js +372 -372
- package/src/managers/DataManager.js +61 -61
- package/src/managers/GuildBanManager.js +250 -250
- package/src/managers/GuildChannelManager.js +488 -488
- package/src/managers/GuildEmojiManager.js +171 -171
- package/src/managers/GuildEmojiRoleManager.js +118 -118
- package/src/managers/GuildForumThreadManager.js +108 -108
- package/src/managers/GuildInviteManager.js +213 -213
- package/src/managers/GuildManager.js +338 -304
- package/src/managers/GuildMemberManager.js +599 -597
- package/src/managers/GuildMemberRoleManager.js +195 -191
- package/src/managers/GuildScheduledEventManager.js +314 -296
- package/src/managers/GuildSettingManager.js +155 -155
- package/src/managers/GuildStickerManager.js +179 -179
- package/src/managers/GuildTextThreadManager.js +98 -98
- package/src/managers/InteractionManager.js +39 -39
- package/src/managers/MessageManager.js +423 -391
- package/src/managers/PermissionOverwriteManager.js +164 -166
- package/src/managers/PresenceManager.js +71 -58
- package/src/managers/ReactionManager.js +67 -67
- package/src/managers/ReactionUserManager.js +73 -71
- package/src/managers/RelationshipManager.js +278 -265
- package/src/managers/RoleManager.js +448 -352
- package/src/managers/SessionManager.js +66 -0
- package/src/managers/StageInstanceManager.js +162 -162
- package/src/managers/ThreadManager.js +175 -174
- package/src/managers/ThreadMemberManager.js +186 -186
- package/src/managers/UserManager.js +136 -146
- package/src/managers/UserNoteManager.js +53 -53
- package/src/managers/VoiceStateManager.js +59 -37
- package/src/rest/APIRequest.js +154 -160
- package/src/rest/APIRouter.js +53 -53
- package/src/rest/DiscordAPIError.js +119 -104
- package/src/rest/HTTPError.js +62 -62
- package/src/rest/RESTManager.js +67 -62
- package/src/rest/RateLimitError.js +55 -55
- package/src/rest/RequestHandler.js +466 -444
- package/src/sharding/Shard.js +444 -443
- package/src/sharding/ShardClientUtil.js +279 -275
- package/src/sharding/ShardingManager.js +319 -318
- package/src/structures/AnonymousGuild.js +98 -98
- package/src/structures/ApplicationCommand.js +593 -593
- package/src/structures/ApplicationRoleConnectionMetadata.js +48 -48
- package/src/structures/AutoModerationActionExecution.js +89 -89
- package/src/structures/AutoModerationRule.js +294 -294
- package/src/structures/AutocompleteInteraction.js +107 -107
- package/src/structures/Base.js +43 -43
- package/src/structures/BaseCommandInteraction.js +211 -211
- package/src/structures/BaseGuild.js +116 -116
- package/src/structures/BaseGuildEmoji.js +56 -56
- package/src/structures/BaseGuildTextChannel.js +191 -191
- package/src/structures/BaseGuildVoiceChannel.js +241 -241
- package/src/structures/BaseMessageComponent.js +181 -114
- package/src/structures/ButtonInteraction.js +11 -11
- package/src/structures/CallState.js +63 -63
- package/src/structures/CategoryChannel.js +85 -85
- package/src/structures/Channel.js +284 -270
- package/src/structures/ClientPresence.js +77 -85
- package/src/structures/ClientUser.js +479 -448
- package/src/structures/CommandInteraction.js +41 -41
- package/src/structures/CommandInteractionOptionResolver.js +276 -276
- package/src/structures/ContainerComponent.js +68 -0
- package/src/structures/ContextMenuInteraction.js +65 -65
- package/src/structures/DMChannel.js +219 -217
- package/src/structures/DirectoryChannel.js +20 -20
- package/src/structures/Emoji.js +148 -148
- package/src/structures/FileComponent.js +49 -0
- package/src/structures/ForumChannel.js +31 -261
- package/src/structures/GroupDMChannel.js +394 -387
- package/src/structures/Guild.js +1643 -1608
- package/src/structures/GuildAuditLogs.js +746 -729
- package/src/structures/GuildBan.js +59 -59
- package/src/structures/GuildBoost.js +108 -108
- package/src/structures/GuildChannel.js +470 -468
- package/src/structures/GuildEmoji.js +161 -161
- package/src/structures/GuildMember.js +636 -568
- package/src/structures/GuildPreview.js +191 -191
- package/src/structures/GuildPreviewEmoji.js +27 -27
- package/src/structures/GuildScheduledEvent.js +536 -441
- package/src/structures/GuildTemplate.js +236 -236
- package/src/structures/Integration.js +188 -188
- package/src/structures/IntegrationApplication.js +96 -96
- package/src/structures/Interaction.js +290 -290
- package/src/structures/InteractionCollector.js +248 -248
- package/src/structures/InteractionWebhook.js +43 -43
- package/src/structures/Invite.js +358 -358
- package/src/structures/InviteGuild.js +23 -23
- package/src/structures/InviteStageInstance.js +86 -86
- 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 -1227
- package/src/structures/MessageActionRow.js +105 -103
- package/src/structures/MessageAttachment.js +216 -204
- package/src/structures/MessageButton.js +166 -165
- package/src/structures/MessageCollector.js +146 -146
- package/src/structures/MessageComponentInteraction.js +120 -120
- package/src/structures/MessageContextMenuInteraction.js +20 -20
- package/src/structures/MessageEmbed.js +596 -586
- package/src/structures/MessageMentions.js +273 -273
- package/src/structures/MessagePayload.js +354 -318
- package/src/structures/MessageReaction.js +181 -171
- package/src/structures/MessageSelectMenu.js +141 -140
- package/src/structures/Modal.js +161 -161
- package/src/structures/ModalSubmitFieldsResolver.js +53 -53
- package/src/structures/ModalSubmitInteraction.js +119 -119
- package/src/structures/NewsChannel.js +32 -32
- package/src/structures/OAuth2Guild.js +28 -28
- package/src/structures/PermissionOverwrites.js +198 -196
- package/src/structures/Poll.js +108 -0
- package/src/structures/PollAnswer.js +88 -0
- package/src/structures/Presence.js +1105 -1101
- package/src/structures/ReactionCollector.js +229 -229
- package/src/structures/ReactionEmoji.js +31 -31
- package/src/structures/Role.js +590 -531
- package/src/structures/SectionComponent.js +48 -0
- package/src/structures/SelectMenuInteraction.js +21 -21
- package/src/structures/SeparatorComponent.js +48 -0
- package/src/structures/Session.js +81 -0
- package/src/structures/StageChannel.js +104 -104
- package/src/structures/StageInstance.js +208 -208
- package/src/structures/Sticker.js +310 -310
- package/src/structures/StickerPack.js +95 -95
- package/src/structures/StoreChannel.js +56 -56
- package/src/structures/Team.js +118 -118
- package/src/structures/TeamMember.js +80 -71
- package/src/structures/TextChannel.js +33 -33
- package/src/structures/TextDisplayComponent.js +40 -0
- package/src/structures/TextInputComponent.js +132 -131
- package/src/structures/ThreadChannel.js +605 -607
- package/src/structures/ThreadMember.js +105 -105
- package/src/structures/ThreadOnlyChannel.js +249 -0
- package/src/structures/ThumbnailComponent.js +57 -0
- package/src/structures/Typing.js +74 -74
- package/src/structures/UnfurledMediaItem.js +29 -0
- package/src/structures/User.js +640 -543
- package/src/structures/UserContextMenuInteraction.js +29 -29
- package/src/structures/VoiceChannel.js +110 -110
- package/src/structures/VoiceChannelEffect.js +69 -0
- package/src/structures/VoiceRegion.js +53 -53
- package/src/structures/VoiceState.js +354 -341
- package/src/structures/WebEmbed.js +373 -373
- package/src/structures/Webhook.js +478 -467
- package/src/structures/WelcomeChannel.js +60 -60
- package/src/structures/WelcomeScreen.js +48 -48
- package/src/structures/Widget.js +87 -87
- package/src/structures/WidgetMember.js +99 -99
- package/src/structures/interfaces/Application.js +825 -313
- package/src/structures/interfaces/Collector.js +300 -300
- package/src/structures/interfaces/InteractionResponses.js +313 -313
- package/src/structures/interfaces/TextBasedChannel.js +759 -719
- package/src/util/APITypes.js +59 -0
- package/src/util/ActivityFlags.js +44 -44
- package/src/util/ApplicationFlags.js +76 -76
- package/src/util/AttachmentFlags.js +38 -38
- package/src/util/BitField.js +170 -170
- package/src/util/ChannelFlags.js +45 -45
- package/src/util/Constants.js +1914 -1773
- package/src/util/DataResolver.js +146 -145
- package/src/util/Formatters.js +228 -228
- package/src/util/GuildMemberFlags.js +43 -43
- package/src/util/Intents.js +74 -74
- package/src/util/InviteFlags.js +34 -29
- package/src/util/LimitedCollection.js +131 -131
- package/src/util/MessageFlags.js +63 -54
- package/src/util/Options.js +358 -336
- package/src/util/Permissions.js +202 -202
- package/src/util/PremiumUsageFlags.js +31 -31
- package/src/util/PurchasedFlags.js +33 -33
- package/src/util/RemoteAuth.js +382 -379
- package/src/util/RoleFlags.js +37 -37
- package/src/util/SnowflakeUtil.js +92 -92
- package/src/util/Speaking.js +33 -0
- package/src/util/Sweepers.js +466 -466
- package/src/util/SystemChannelFlags.js +55 -55
- package/src/util/ThreadMemberFlags.js +30 -30
- package/src/util/UserFlags.js +104 -104
- package/src/util/Util.js +1048 -889
- package/typings/enums.d.ts +439 -297
- package/typings/index.d.ts +8247 -7432
- package/typings/rawDataTypes.d.ts +403 -342
- package/src/structures/MessagePoll.js +0 -238
|
@@ -1,53 +1,53 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const { Collection } = require('@discordjs/collection');
|
|
4
|
-
const BaseManager = require('./BaseManager');
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Manages API methods for Client and stores their cache.
|
|
8
|
-
* @extends {BaseManager}
|
|
9
|
-
*/
|
|
10
|
-
class UserNoteManager extends BaseManager {
|
|
11
|
-
constructor(client, data = {}) {
|
|
12
|
-
super(client);
|
|
13
|
-
/**
|
|
14
|
-
* Cache User Note
|
|
15
|
-
* @type {Collection<Snowflake, string>}
|
|
16
|
-
*/
|
|
17
|
-
this.cache = new Collection(Object.entries(data));
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
_reload(data = {}) {
|
|
21
|
-
this.cache = new Collection(Object.entries(data));
|
|
22
|
-
return this;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
async updateNote(id, note = null) {
|
|
26
|
-
await this.client.api.users['@me'].notes(id).put({ data: { note } });
|
|
27
|
-
if (!note) this.cache.delete(id, note);
|
|
28
|
-
else this.cache.set(id, note);
|
|
29
|
-
return this;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
/**
|
|
33
|
-
* Obtains a user from Discord, or the user cache if it's already available.
|
|
34
|
-
* @param {UserResolvable} user The user to fetch
|
|
35
|
-
* @param {BaseFetchOptions} [options] Additional options for this fetch
|
|
36
|
-
* @returns {Promise<string>}
|
|
37
|
-
*/
|
|
38
|
-
async fetch(user, { cache = true, force = false } = {}) {
|
|
39
|
-
const id = this.resolveId(user);
|
|
40
|
-
if (!force) {
|
|
41
|
-
const existing = this.cache.get(id);
|
|
42
|
-
if (existing) return existing;
|
|
43
|
-
}
|
|
44
|
-
const data = await this.client.api.users['@me'].notes[id]
|
|
45
|
-
.get()
|
|
46
|
-
.then(d => d.note)
|
|
47
|
-
.catch(() => '');
|
|
48
|
-
if (cache) this.cache.set(id, data);
|
|
49
|
-
return data;
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
module.exports = UserNoteManager;
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const { Collection } = require('@discordjs/collection');
|
|
4
|
+
const BaseManager = require('./BaseManager');
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Manages API methods for Client and stores their cache.
|
|
8
|
+
* @extends {BaseManager}
|
|
9
|
+
*/
|
|
10
|
+
class UserNoteManager extends BaseManager {
|
|
11
|
+
constructor(client, data = {}) {
|
|
12
|
+
super(client);
|
|
13
|
+
/**
|
|
14
|
+
* Cache User Note
|
|
15
|
+
* @type {Collection<Snowflake, string>}
|
|
16
|
+
*/
|
|
17
|
+
this.cache = new Collection(Object.entries(data));
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
_reload(data = {}) {
|
|
21
|
+
this.cache = new Collection(Object.entries(data));
|
|
22
|
+
return this;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
async updateNote(id, note = null) {
|
|
26
|
+
await this.client.api.users['@me'].notes(id).put({ data: { note } });
|
|
27
|
+
if (!note) this.cache.delete(id, note);
|
|
28
|
+
else this.cache.set(id, note);
|
|
29
|
+
return this;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Obtains a user from Discord, or the user cache if it's already available.
|
|
34
|
+
* @param {UserResolvable} user The user to fetch
|
|
35
|
+
* @param {BaseFetchOptions} [options] Additional options for this fetch
|
|
36
|
+
* @returns {Promise<string>}
|
|
37
|
+
*/
|
|
38
|
+
async fetch(user, { cache = true, force = false } = {}) {
|
|
39
|
+
const id = this.resolveId(user);
|
|
40
|
+
if (!force) {
|
|
41
|
+
const existing = this.cache.get(id);
|
|
42
|
+
if (existing) return existing;
|
|
43
|
+
}
|
|
44
|
+
const data = await this.client.api.users['@me'].notes[id]
|
|
45
|
+
.get()
|
|
46
|
+
.then(d => d.note)
|
|
47
|
+
.catch(() => '');
|
|
48
|
+
if (cache) this.cache.set(id, data);
|
|
49
|
+
return data;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
module.exports = UserNoteManager;
|
|
@@ -1,37 +1,59 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const CachedManager = require('./CachedManager');
|
|
4
|
-
const VoiceState = require('../structures/VoiceState');
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Manages API methods for VoiceStates and stores their cache.
|
|
8
|
-
* @extends {CachedManager}
|
|
9
|
-
*/
|
|
10
|
-
class VoiceStateManager extends CachedManager {
|
|
11
|
-
constructor(guild, iterable) {
|
|
12
|
-
super(guild.client, VoiceState, iterable);
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* The guild this manager belongs to
|
|
16
|
-
* @type {Guild}
|
|
17
|
-
*/
|
|
18
|
-
this.guild = guild;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* The cache of this manager
|
|
23
|
-
* @type {Collection<Snowflake, VoiceState>}
|
|
24
|
-
* @name VoiceStateManager#cache
|
|
25
|
-
*/
|
|
26
|
-
|
|
27
|
-
_add(data, cache = true) {
|
|
28
|
-
const existing = this.cache.get(data.user_id);
|
|
29
|
-
if (existing) return existing._patch(data);
|
|
30
|
-
|
|
31
|
-
const entry = new this.holds(this.guild, data);
|
|
32
|
-
if (cache) this.cache.set(data.user_id, entry);
|
|
33
|
-
return entry;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const CachedManager = require('./CachedManager');
|
|
4
|
+
const VoiceState = require('../structures/VoiceState');
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Manages API methods for VoiceStates and stores their cache.
|
|
8
|
+
* @extends {CachedManager}
|
|
9
|
+
*/
|
|
10
|
+
class VoiceStateManager extends CachedManager {
|
|
11
|
+
constructor(guild, iterable) {
|
|
12
|
+
super(guild.client, VoiceState, iterable);
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* The guild this manager belongs to
|
|
16
|
+
* @type {Guild}
|
|
17
|
+
*/
|
|
18
|
+
this.guild = guild;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* The cache of this manager
|
|
23
|
+
* @type {Collection<Snowflake, VoiceState>}
|
|
24
|
+
* @name VoiceStateManager#cache
|
|
25
|
+
*/
|
|
26
|
+
|
|
27
|
+
_add(data, cache = true) {
|
|
28
|
+
const existing = this.cache.get(data.user_id);
|
|
29
|
+
if (existing) return existing._patch(data);
|
|
30
|
+
|
|
31
|
+
const entry = new this.holds(this.guild, data);
|
|
32
|
+
if (cache) this.cache.set(data.user_id, entry);
|
|
33
|
+
return entry;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Obtains a user's voice state from discord or from the cache if it's already available.
|
|
38
|
+
* @param {GuildMemberResolvable|'@me'} member The member whose voice state is to be fetched
|
|
39
|
+
* @param {BaseFetchOptions} [options] Additional options for this fetch
|
|
40
|
+
* @returns {Promise<VoiceState>}
|
|
41
|
+
* @example
|
|
42
|
+
* // Fetch a member's voice state
|
|
43
|
+
* guild.voiceStates.fetch("66564597481480192")
|
|
44
|
+
* .then(console.log)
|
|
45
|
+
* .catch(console.error);
|
|
46
|
+
*/
|
|
47
|
+
async fetch(member, { cache = true, force = false } = {}) {
|
|
48
|
+
if (!this.guild?.id) throw new Error('Guild is not defined');
|
|
49
|
+
const id = member === '@me' ? member : this.guild.members.resolveId(member);
|
|
50
|
+
if (!force) {
|
|
51
|
+
const existing = this.cache.get(id === '@me' ? this.client.user.id : id);
|
|
52
|
+
if (existing) return existing;
|
|
53
|
+
}
|
|
54
|
+
const data = await this.client.api.guilds(this.guild.id)['voice-states'][id].get();
|
|
55
|
+
return this._add(data, cache);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
module.exports = VoiceStateManager;
|
package/src/rest/APIRequest.js
CHANGED
|
@@ -1,160 +1,154 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const Buffer = require('node:buffer').Buffer;
|
|
4
|
-
const
|
|
5
|
-
const {
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
this.
|
|
21
|
-
|
|
22
|
-
this.
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
if (
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
signal: controller.signal,
|
|
156
|
-
}).finally(() => clearTimeout(timeout));
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
module.exports = APIRequest;
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const Buffer = require('node:buffer').Buffer;
|
|
4
|
+
const { setTimeout } = require('node:timers');
|
|
5
|
+
const { FormData, buildConnector, Client, ProxyAgent } = require('undici');
|
|
6
|
+
const { ciphers } = require('../util/Constants');
|
|
7
|
+
const Util = require('../util/Util');
|
|
8
|
+
|
|
9
|
+
let agent = null;
|
|
10
|
+
|
|
11
|
+
class APIRequest {
|
|
12
|
+
constructor(rest, method, path, options) {
|
|
13
|
+
this.rest = rest;
|
|
14
|
+
this.client = rest.client;
|
|
15
|
+
this.method = method;
|
|
16
|
+
this.route = options.route;
|
|
17
|
+
this.options = options;
|
|
18
|
+
this.retries = 0;
|
|
19
|
+
|
|
20
|
+
this.fullUserAgent = this.client.options.http.headers['User-Agent'];
|
|
21
|
+
|
|
22
|
+
this.client.options.ws.properties.browser_user_agent = this.fullUserAgent;
|
|
23
|
+
|
|
24
|
+
let queryString = '';
|
|
25
|
+
if (options.query) {
|
|
26
|
+
const query = Object.entries(options.query)
|
|
27
|
+
.filter(([, value]) => value !== null && typeof value !== 'undefined')
|
|
28
|
+
.flatMap(([key, value]) => (Array.isArray(value) ? value.map(v => [key, v]) : [[key, value]]));
|
|
29
|
+
queryString = new URLSearchParams(query).toString();
|
|
30
|
+
}
|
|
31
|
+
this.path = `${path}${queryString && `?${queryString}`}`;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
make(captchaKey, captchaRqToken) {
|
|
35
|
+
if (!agent) {
|
|
36
|
+
const r_ = Util.checkUndiciProxyAgent(this.client.options.http.agent);
|
|
37
|
+
if (!r_) {
|
|
38
|
+
agent = new Client('https://discord.com', {
|
|
39
|
+
connect: buildConnector({ ciphers: ciphers.join(':') }),
|
|
40
|
+
});
|
|
41
|
+
} else {
|
|
42
|
+
agent = new ProxyAgent({
|
|
43
|
+
...r_,
|
|
44
|
+
ciphers: ciphers.join(':'),
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
const API =
|
|
50
|
+
this.options.versioned === false
|
|
51
|
+
? this.client.options.http.api
|
|
52
|
+
: `${this.client.options.http.api}/v${this.client.options.http.version}`;
|
|
53
|
+
const url = API + this.path;
|
|
54
|
+
|
|
55
|
+
let headers = {
|
|
56
|
+
accept: '*/*',
|
|
57
|
+
'accept-language': 'en-US',
|
|
58
|
+
priority: 'u=1, i',
|
|
59
|
+
referer: 'https://discord.com/channels/@me',
|
|
60
|
+
'sec-ch-ua': '"Not:A-Brand";v="24", "Chromium";v="134"',
|
|
61
|
+
'sec-ch-ua-mobile': '?0',
|
|
62
|
+
'sec-ch-ua-platform': '"Windows"',
|
|
63
|
+
'sec-fetch-dest': 'empty',
|
|
64
|
+
'sec-fetch-mode': 'cors',
|
|
65
|
+
'sec-fetch-site': 'same-origin',
|
|
66
|
+
'x-discord-locale': 'en-US',
|
|
67
|
+
'x-discord-timezone': Intl.DateTimeFormat().resolvedOptions().timeZone,
|
|
68
|
+
'x-super-properties': `${Buffer.from(JSON.stringify(this.client.options.ws.properties), 'ascii').toString(
|
|
69
|
+
'base64',
|
|
70
|
+
)}`,
|
|
71
|
+
origin: 'https://discord.com',
|
|
72
|
+
'x-debug-options': 'bugReporterEnabled',
|
|
73
|
+
...this.client.options.http.headers,
|
|
74
|
+
'User-Agent': this.fullUserAgent,
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
if (this.options.auth !== false) headers.Authorization = this.rest.getAuth();
|
|
78
|
+
if (this.options.reason) headers['X-Audit-Log-Reason'] = encodeURIComponent(this.options.reason);
|
|
79
|
+
if (this.options.headers) headers = Object.assign(headers, this.options.headers);
|
|
80
|
+
|
|
81
|
+
// Delete all headers if undefined
|
|
82
|
+
for (const [key, value] of Object.entries(headers)) {
|
|
83
|
+
if (value === undefined) delete headers[key];
|
|
84
|
+
}
|
|
85
|
+
if (this.options.webhook === true) {
|
|
86
|
+
headers = {
|
|
87
|
+
'User-Agent': this.client.options.http.headers['User-Agent'],
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// Some options
|
|
92
|
+
if (this.options.DiscordContext) {
|
|
93
|
+
headers['X-Context-Properties'] = Buffer.from(JSON.stringify(this.options.DiscordContext), 'utf8').toString(
|
|
94
|
+
'base64',
|
|
95
|
+
);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
if (this.options.mfaToken) {
|
|
99
|
+
headers['X-Discord-Mfa-Authorization'] = this.options.mfaToken;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
// Captcha
|
|
103
|
+
if (captchaKey && typeof captchaKey == 'string') headers['X-Captcha-Key'] = captchaKey;
|
|
104
|
+
if (captchaRqToken && typeof captchaRqToken == 'string') headers['X-Captcha-Rqtoken'] = captchaRqToken;
|
|
105
|
+
|
|
106
|
+
let body;
|
|
107
|
+
if (this.options.files?.length) {
|
|
108
|
+
body = new FormData();
|
|
109
|
+
for (const [index, file] of this.options.files.entries()) {
|
|
110
|
+
// Why undici#FormData doesn't support file stream?
|
|
111
|
+
// Hacky way to support file stream
|
|
112
|
+
if (file?.file) {
|
|
113
|
+
body.set(file.key ?? `files[${index}]`, {
|
|
114
|
+
[Symbol.toStringTag]: 'File',
|
|
115
|
+
name: file.name,
|
|
116
|
+
stream: () => file.file,
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
if (typeof this.options.data !== 'undefined') {
|
|
121
|
+
if (this.options.dontUsePayloadJSON) {
|
|
122
|
+
for (const [key, value] of Object.entries(this.options.data)) body.append(key, value);
|
|
123
|
+
} else {
|
|
124
|
+
body.append('payload_json', JSON.stringify(this.options.data));
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
// eslint-disable-next-line eqeqeq
|
|
128
|
+
} else if (this.options.data != null) {
|
|
129
|
+
if (this.options.usePayloadJSON) {
|
|
130
|
+
body = new FormData();
|
|
131
|
+
body.append('payload_json', JSON.stringify(this.options.data));
|
|
132
|
+
} else {
|
|
133
|
+
body = JSON.stringify(this.options.data);
|
|
134
|
+
headers['Content-Type'] = 'application/json';
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const controller = new AbortController();
|
|
139
|
+
const timeout = setTimeout(() => controller.abort(), this.client.options.restRequestTimeout).unref();
|
|
140
|
+
return this.rest
|
|
141
|
+
.fetch(url, {
|
|
142
|
+
method: this.method.toUpperCase(), // Undici doesn't normalize "patch" into "PATCH" (which surprisingly follows the spec).
|
|
143
|
+
headers,
|
|
144
|
+
body,
|
|
145
|
+
signal: controller.signal,
|
|
146
|
+
redirect: 'follow',
|
|
147
|
+
dispatcher: agent,
|
|
148
|
+
credentials: 'include',
|
|
149
|
+
})
|
|
150
|
+
.finally(() => clearTimeout(timeout));
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
module.exports = APIRequest;
|
package/src/rest/APIRouter.js
CHANGED
|
@@ -1,53 +1,53 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const noop = () => {}; // eslint-disable-line no-empty-function
|
|
4
|
-
const methods = ['get', 'post', 'delete', 'patch', 'put'];
|
|
5
|
-
const reflectors = [
|
|
6
|
-
'toString',
|
|
7
|
-
'valueOf',
|
|
8
|
-
'inspect',
|
|
9
|
-
'constructor',
|
|
10
|
-
Symbol.toPrimitive,
|
|
11
|
-
Symbol.for('nodejs.util.inspect.custom'),
|
|
12
|
-
];
|
|
13
|
-
|
|
14
|
-
function buildRoute(manager) {
|
|
15
|
-
const route = [''];
|
|
16
|
-
const handler = {
|
|
17
|
-
get(target, name) {
|
|
18
|
-
if (reflectors.includes(name)) return () => route.join('/');
|
|
19
|
-
if (methods.includes(name)) {
|
|
20
|
-
const routeBucket = [];
|
|
21
|
-
for (let i = 0; i < route.length; i++) {
|
|
22
|
-
// Reactions routes and sub-routes all share the same bucket
|
|
23
|
-
if (route[i - 1] === 'reactions') break;
|
|
24
|
-
// Literal ids should only be taken account if they are the Major id (the Channel/Guild id)
|
|
25
|
-
if (/\d{16,19}/g.test(route[i]) && !/channels|guilds/.test(route[i - 1])) routeBucket.push(':id');
|
|
26
|
-
// All other parts of the route should be considered as part of the bucket identifier
|
|
27
|
-
else routeBucket.push(route[i]);
|
|
28
|
-
}
|
|
29
|
-
return options =>
|
|
30
|
-
manager.request(
|
|
31
|
-
name,
|
|
32
|
-
route.join('/'),
|
|
33
|
-
Object.assign(
|
|
34
|
-
{
|
|
35
|
-
versioned: manager.versioned,
|
|
36
|
-
route: routeBucket.join('/'),
|
|
37
|
-
},
|
|
38
|
-
options,
|
|
39
|
-
),
|
|
40
|
-
);
|
|
41
|
-
}
|
|
42
|
-
route.push(name);
|
|
43
|
-
return new Proxy(noop, handler);
|
|
44
|
-
},
|
|
45
|
-
apply(target, _, args) {
|
|
46
|
-
route.push(...args.filter(x => x != null)); // eslint-disable-line eqeqeq
|
|
47
|
-
return new Proxy(noop, handler);
|
|
48
|
-
},
|
|
49
|
-
};
|
|
50
|
-
return new Proxy(noop, handler);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
module.exports = buildRoute;
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const noop = () => {}; // eslint-disable-line no-empty-function
|
|
4
|
+
const methods = ['get', 'post', 'delete', 'patch', 'put'];
|
|
5
|
+
const reflectors = [
|
|
6
|
+
'toString',
|
|
7
|
+
'valueOf',
|
|
8
|
+
'inspect',
|
|
9
|
+
'constructor',
|
|
10
|
+
Symbol.toPrimitive,
|
|
11
|
+
Symbol.for('nodejs.util.inspect.custom'),
|
|
12
|
+
];
|
|
13
|
+
|
|
14
|
+
function buildRoute(manager) {
|
|
15
|
+
const route = [''];
|
|
16
|
+
const handler = {
|
|
17
|
+
get(target, name) {
|
|
18
|
+
if (reflectors.includes(name)) return () => route.join('/');
|
|
19
|
+
if (methods.includes(name)) {
|
|
20
|
+
const routeBucket = [];
|
|
21
|
+
for (let i = 0; i < route.length; i++) {
|
|
22
|
+
// Reactions routes and sub-routes all share the same bucket
|
|
23
|
+
if (route[i - 1] === 'reactions') break;
|
|
24
|
+
// Literal ids should only be taken account if they are the Major id (the Channel/Guild id)
|
|
25
|
+
if (/\d{16,19}/g.test(route[i]) && !/channels|guilds/.test(route[i - 1])) routeBucket.push(':id');
|
|
26
|
+
// All other parts of the route should be considered as part of the bucket identifier
|
|
27
|
+
else routeBucket.push(route[i]);
|
|
28
|
+
}
|
|
29
|
+
return options =>
|
|
30
|
+
manager.request(
|
|
31
|
+
name,
|
|
32
|
+
route.join('/'),
|
|
33
|
+
Object.assign(
|
|
34
|
+
{
|
|
35
|
+
versioned: manager.versioned,
|
|
36
|
+
route: routeBucket.join('/'),
|
|
37
|
+
},
|
|
38
|
+
options,
|
|
39
|
+
),
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
route.push(name);
|
|
43
|
+
return new Proxy(noop, handler);
|
|
44
|
+
},
|
|
45
|
+
apply(target, _, args) {
|
|
46
|
+
route.push(...args.filter(x => x != null)); // eslint-disable-line eqeqeq
|
|
47
|
+
return new Proxy(noop, handler);
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
return new Proxy(noop, handler);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
module.exports = buildRoute;
|