seyfert 1.4.0 → 2.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 +21 -190
- package/README.md +22 -14
- package/lib/api/Router.js +5 -3
- package/lib/api/Routes/applications.d.ts +23 -1
- package/lib/api/Routes/channels.d.ts +1 -1
- package/lib/api/Routes/gateway.d.ts +1 -1
- package/lib/api/Routes/guilds.d.ts +8 -2
- package/lib/api/Routes/interactions.d.ts +1 -1
- package/lib/api/Routes/invites.d.ts +1 -1
- package/lib/api/Routes/stage-instances.d.ts +1 -1
- package/lib/api/Routes/stickers.d.ts +2 -2
- package/lib/api/Routes/users.d.ts +1 -1
- package/lib/api/Routes/voice.d.ts +1 -1
- package/lib/api/Routes/webhooks.d.ts +2 -2
- package/lib/api/api.d.ts +2 -2
- package/lib/api/api.js +2 -14
- package/lib/api/bucket.d.ts +0 -1
- package/lib/api/shared.d.ts +0 -1
- package/lib/api/utils/constants.d.ts +2 -5
- package/lib/api/utils/constants.js +3 -7
- package/lib/api/utils/utils.d.ts +1 -2
- package/lib/api/utils/utils.js +2 -3
- package/lib/builders/ActionRow.d.ts +1 -1
- package/lib/builders/ActionRow.js +3 -3
- package/lib/builders/Attachment.d.ts +2 -3
- package/lib/builders/Attachment.js +12 -13
- package/lib/builders/Base.d.ts +2 -2
- package/lib/builders/Base.js +1 -1
- package/lib/builders/Button.d.ts +7 -7
- package/lib/builders/Button.js +11 -9
- package/lib/builders/Embed.d.ts +1 -1
- package/lib/builders/Modal.d.ts +1 -1
- package/lib/builders/Modal.js +2 -2
- package/lib/builders/Poll.d.ts +2 -2
- package/lib/builders/Poll.js +5 -6
- package/lib/builders/SelectMenu.d.ts +1 -1
- package/lib/builders/SelectMenu.js +17 -18
- package/lib/builders/index.d.ts +1 -1
- package/lib/builders/index.js +10 -11
- package/lib/cache/adapters/default.d.ts +16 -9
- package/lib/cache/adapters/default.js +42 -31
- package/lib/cache/adapters/index.d.ts +0 -1
- package/lib/cache/adapters/index.js +0 -1
- package/lib/cache/adapters/limited.d.ts +17 -12
- package/lib/cache/adapters/limited.js +80 -36
- package/lib/cache/adapters/types.d.ts +6 -7
- package/lib/cache/adapters/workeradapter.d.ts +6 -6
- package/lib/cache/adapters/workeradapter.js +13 -0
- package/lib/cache/index.d.ts +24 -11
- package/lib/cache/index.js +335 -19
- package/lib/cache/resources/bans.d.ts +15 -0
- package/lib/cache/resources/bans.js +44 -0
- package/lib/cache/resources/channels.d.ts +6 -4
- package/lib/cache/resources/channels.js +13 -7
- package/lib/cache/resources/default/base.d.ts +7 -7
- package/lib/cache/resources/default/base.js +2 -2
- package/lib/cache/resources/default/guild-based.d.ts +6 -6
- package/lib/cache/resources/default/guild-based.js +6 -6
- package/lib/cache/resources/default/guild-related.d.ts +7 -7
- package/lib/cache/resources/default/guild-related.js +10 -8
- package/lib/cache/resources/emojis.d.ts +15 -6
- package/lib/cache/resources/emojis.js +13 -4
- package/lib/cache/resources/guilds.d.ts +9 -6
- package/lib/cache/resources/guilds.js +27 -6
- package/lib/cache/resources/members.d.ts +9 -6
- package/lib/cache/resources/members.js +24 -8
- package/lib/cache/resources/messages.d.ts +11 -7
- package/lib/cache/resources/messages.js +25 -11
- package/lib/cache/resources/overwrites.d.ts +11 -2
- package/lib/cache/resources/overwrites.js +9 -0
- package/lib/cache/resources/presence.d.ts +3 -2
- package/lib/cache/resources/roles.d.ts +9 -6
- package/lib/cache/resources/roles.js +13 -4
- package/lib/cache/resources/stage-instances.d.ts +2 -2
- package/lib/cache/resources/stickers.d.ts +9 -6
- package/lib/cache/resources/stickers.js +13 -4
- package/lib/cache/resources/threads.d.ts +9 -6
- package/lib/cache/resources/threads.js +13 -4
- package/lib/cache/resources/users.d.ts +9 -6
- package/lib/cache/resources/users.js +13 -4
- package/lib/cache/resources/voice-states.d.ts +11 -8
- package/lib/cache/resources/voice-states.js +15 -4
- package/lib/client/base.d.ts +32 -20
- package/lib/client/base.js +51 -30
- package/lib/client/client.d.ts +12 -9
- package/lib/client/client.js +43 -49
- package/lib/client/collectors.d.ts +36 -0
- package/lib/client/collectors.js +110 -0
- package/lib/client/httpclient.d.ts +8 -13
- package/lib/client/httpclient.js +27 -218
- package/lib/client/index.d.ts +1 -0
- package/lib/client/index.js +1 -0
- package/lib/client/transformers.d.ts +68 -0
- package/lib/client/transformers.js +99 -0
- package/lib/client/types.d.ts +5 -0
- package/lib/client/types.js +2 -0
- package/lib/client/workerclient.d.ts +18 -15
- package/lib/client/workerclient.js +148 -110
- package/lib/collection.d.ts +2 -2
- package/lib/collection.js +2 -2
- package/lib/commands/applications/chat.d.ts +40 -38
- package/lib/commands/applications/chat.js +22 -12
- package/lib/commands/applications/chatcontext.d.ts +17 -17
- package/lib/commands/applications/chatcontext.js +5 -5
- package/lib/commands/applications/menu.d.ts +9 -9
- package/lib/commands/applications/menu.js +5 -7
- package/lib/commands/applications/menucontext.d.ts +14 -13
- package/lib/commands/applications/menucontext.js +9 -9
- package/lib/commands/applications/options.d.ts +1 -1
- package/lib/commands/applications/options.js +20 -21
- package/lib/commands/applications/shared.d.ts +14 -0
- package/lib/commands/decorators.d.ts +47 -35
- package/lib/commands/decorators.js +19 -27
- package/lib/commands/handle.d.ts +64 -0
- package/lib/commands/handle.js +685 -0
- package/lib/commands/handler.d.ts +27 -18
- package/lib/commands/handler.js +296 -160
- package/lib/commands/optionresolver.d.ts +13 -13
- package/lib/commands/optionresolver.js +23 -28
- package/lib/common/bot/watcher.d.ts +4 -33
- package/lib/common/bot/watcher.js +0 -109
- package/lib/common/index.d.ts +2 -0
- package/lib/common/index.js +4 -1
- package/lib/common/it/colors.js +48 -49
- package/lib/common/it/formatter.d.ts +187 -0
- package/lib/common/it/formatter.js +226 -0
- package/lib/common/it/logger.d.ts +0 -1
- package/lib/common/it/logger.js +8 -8
- package/lib/common/it/utils.d.ts +15 -2
- package/lib/common/it/utils.js +80 -21
- package/lib/common/shorters/application.d.ts +56 -0
- package/lib/common/shorters/application.js +81 -0
- package/lib/common/shorters/bans.d.ts +42 -0
- package/lib/common/shorters/bans.js +78 -0
- package/lib/common/shorters/channels.d.ts +7 -6
- package/lib/common/shorters/channels.js +19 -15
- package/lib/common/shorters/emojis.d.ts +5 -6
- package/lib/common/shorters/emojis.js +8 -7
- package/lib/common/shorters/guilds.d.ts +18 -16
- package/lib/common/shorters/guilds.js +31 -26
- package/lib/common/shorters/interaction.d.ts +6 -6
- package/lib/common/shorters/interaction.js +12 -9
- package/lib/common/shorters/members.d.ts +29 -12
- package/lib/common/shorters/members.js +55 -16
- package/lib/common/shorters/messages.d.ts +7 -8
- package/lib/common/shorters/messages.js +10 -9
- package/lib/common/shorters/reactions.d.ts +3 -3
- package/lib/common/shorters/reactions.js +11 -11
- package/lib/common/shorters/roles.d.ts +9 -7
- package/lib/common/shorters/roles.js +26 -7
- package/lib/common/shorters/templates.d.ts +7 -8
- package/lib/common/shorters/templates.js +7 -7
- package/lib/common/shorters/threads.d.ts +6 -7
- package/lib/common/shorters/threads.js +6 -9
- package/lib/common/shorters/users.d.ts +4 -4
- package/lib/common/shorters/users.js +8 -4
- package/lib/common/shorters/webhook.d.ts +10 -10
- package/lib/common/shorters/webhook.js +12 -11
- package/lib/common/types/resolvables.d.ts +2 -2
- package/lib/common/types/util.d.ts +3 -1
- package/lib/common/types/write.d.ts +1 -1
- package/lib/components/ActionRow.d.ts +1 -1
- package/lib/components/BaseComponent.d.ts +1 -1
- package/lib/components/BaseComponent.js +1 -1
- package/lib/components/BaseSelectMenuComponent.d.ts +1 -1
- package/lib/components/ButtonComponent.d.ts +17 -7
- package/lib/components/ButtonComponent.js +19 -2
- package/lib/components/ChannelSelectMenuComponent.d.ts +3 -3
- package/lib/components/MentionableSelectMenuComponent.d.ts +2 -2
- package/lib/components/RoleSelectMenuComponent.d.ts +2 -2
- package/lib/components/StringSelectMenuComponent.d.ts +2 -2
- package/lib/components/TextInputComponent.d.ts +2 -2
- package/lib/components/UserSelectMenuComponent.d.ts +2 -2
- package/lib/components/componentcommand.d.ts +3 -2
- package/lib/components/componentcommand.js +4 -3
- package/lib/components/componentcontext.d.ts +11 -10
- package/lib/components/componentcontext.js +8 -8
- package/lib/components/handler.d.ts +16 -15
- package/lib/components/handler.js +101 -108
- package/lib/components/index.d.ts +3 -3
- package/lib/components/index.js +12 -10
- package/lib/components/modalcommand.d.ts +2 -1
- package/lib/components/modalcommand.js +1 -0
- package/lib/components/modalcontext.d.ts +13 -12
- package/lib/components/modalcontext.js +2 -2
- package/lib/deps/mixer.d.ts +8 -0
- package/lib/deps/mixer.js +66 -0
- package/lib/events/event.d.ts +4 -3
- package/lib/events/handler.d.ts +40 -15
- package/lib/events/handler.js +99 -21
- package/lib/events/hooks/application_command.d.ts +2 -2
- package/lib/events/hooks/auto_moderation.d.ts +6 -7
- package/lib/events/hooks/auto_moderation.js +4 -4
- package/lib/events/hooks/channel.d.ts +2 -2
- package/lib/events/hooks/channel.js +4 -7
- package/lib/events/hooks/custom.d.ts +3 -3
- package/lib/events/hooks/dispatch.d.ts +3 -4
- package/lib/events/hooks/dispatch.js +2 -2
- package/lib/events/hooks/entitlement.d.ts +5 -37
- package/lib/events/hooks/entitlement.js +7 -7
- package/lib/events/hooks/guild.d.ts +126 -181
- package/lib/events/hooks/guild.js +13 -15
- package/lib/events/hooks/integration.d.ts +71 -15
- package/lib/events/hooks/integration.js +3 -3
- package/lib/events/hooks/interactions.d.ts +2 -2
- package/lib/events/hooks/invite.d.ts +18 -14
- package/lib/events/hooks/message.d.ts +72 -52
- package/lib/events/hooks/message.js +4 -8
- package/lib/events/hooks/presence.d.ts +21 -16
- package/lib/events/hooks/stage.d.ts +4 -4
- package/lib/events/hooks/thread.d.ts +140 -60
- package/lib/events/hooks/thread.js +4 -4
- package/lib/events/hooks/typing.d.ts +28 -5
- package/lib/events/hooks/typing.js +2 -2
- package/lib/events/hooks/user.d.ts +3 -3
- package/lib/events/hooks/user.js +2 -2
- package/lib/events/hooks/voice.d.ts +28 -3
- package/lib/events/hooks/voice.js +8 -4
- package/lib/events/hooks/webhook.d.ts +1 -1
- package/lib/index.d.ts +6 -15
- package/lib/index.js +8 -12
- package/lib/langs/handler.d.ts +14 -10
- package/lib/langs/handler.js +40 -9
- package/lib/structures/AutoModerationRule.d.ts +4 -4
- package/lib/structures/AutoModerationRule.js +1 -2
- package/lib/structures/ClientUser.d.ts +1 -1
- package/lib/structures/Entitlement.d.ts +10 -0
- package/lib/structures/Entitlement.js +16 -0
- package/lib/structures/Guild.d.ts +37 -30
- package/lib/structures/Guild.js +7 -2
- package/lib/structures/GuildBan.d.ts +25 -0
- package/lib/structures/GuildBan.js +37 -0
- package/lib/structures/GuildEmoji.d.ts +4 -4
- package/lib/structures/GuildEmoji.js +3 -2
- package/lib/structures/GuildMember.d.ts +27 -19
- package/lib/structures/GuildMember.js +21 -11
- package/lib/structures/GuildPreview.d.ts +1 -1
- package/lib/structures/GuildRole.d.ts +5 -3
- package/lib/structures/GuildRole.js +8 -1
- package/lib/structures/GuildTemplate.d.ts +2 -2
- package/lib/structures/GuildTemplate.js +1 -1
- package/lib/structures/Interaction.d.ts +56 -38
- package/lib/structures/Interaction.js +134 -86
- package/lib/structures/Message.d.ts +80 -20
- package/lib/structures/Message.js +67 -26
- package/lib/structures/Poll.d.ts +4 -3
- package/lib/structures/Poll.js +6 -2
- package/lib/structures/Sticker.d.ts +10 -10
- package/lib/structures/Sticker.js +7 -7
- package/lib/structures/User.d.ts +6 -4
- package/lib/structures/User.js +6 -2
- package/lib/structures/VoiceState.d.ts +15 -11
- package/lib/structures/VoiceState.js +35 -17
- package/lib/structures/Webhook.d.ts +6 -7
- package/lib/structures/Webhook.js +6 -7
- package/lib/structures/channels.d.ts +14 -10
- package/lib/structures/channels.js +97 -62
- package/lib/structures/extra/BaseGuild.d.ts +1 -1
- package/lib/structures/extra/BaseGuild.js +3 -3
- package/lib/structures/extra/BitField.d.ts +1 -1
- package/lib/structures/extra/BitField.js +3 -2
- package/lib/structures/extra/DiscordBase.js +2 -2
- package/lib/structures/extra/Permissions.d.ts +3 -1
- package/lib/structures/extra/Permissions.js +8 -3
- package/lib/types/gateway.d.ts +1537 -0
- package/lib/types/gateway.js +4 -0
- package/lib/types/index.d.ts +9 -1
- package/lib/types/index.js +28 -1
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/attachment.d.ts +5 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/attachment.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/base.d.ts +22 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/base.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/boolean.d.ts +4 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/boolean.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/channel.d.ts +7 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/channel.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/integer.d.ts +17 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/integer.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/mentionable.d.ts +5 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/mentionable.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/number.d.ts +17 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/number.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/role.d.ts +5 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/role.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/shared.d.ts +25 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/shared.js +20 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/string.d.ts +17 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/string.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommand.d.ts +11 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommand.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts +11 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/subcommandGroup.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/user.d.ts +5 -0
- package/lib/types/payloads/_interactions/_applicationCommands/_chatInput/user.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/chatInput.d.ts +60 -0
- package/lib/types/payloads/_interactions/_applicationCommands/chatInput.js +29 -0
- package/lib/types/payloads/_interactions/_applicationCommands/contextMenu.d.ts +65 -0
- package/lib/types/payloads/_interactions/_applicationCommands/contextMenu.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/internals.d.ts +8 -0
- package/lib/types/payloads/_interactions/_applicationCommands/internals.js +2 -0
- package/lib/types/payloads/_interactions/_applicationCommands/permissions.d.ts +54 -0
- package/lib/types/payloads/_interactions/_applicationCommands/permissions.js +20 -0
- package/lib/types/payloads/_interactions/applicationCommands.d.ts +153 -0
- package/lib/types/payloads/_interactions/applicationCommands.js +61 -0
- package/lib/types/payloads/_interactions/autocomplete.d.ts +10 -0
- package/lib/types/payloads/_interactions/autocomplete.js +2 -0
- package/lib/types/payloads/_interactions/base.d.ts +197 -0
- package/lib/types/payloads/_interactions/base.js +2 -0
- package/lib/types/payloads/_interactions/messageComponents.d.ts +41 -0
- package/lib/types/payloads/_interactions/messageComponents.js +2 -0
- package/lib/types/payloads/_interactions/modalSubmit.d.ts +35 -0
- package/lib/types/payloads/_interactions/modalSubmit.js +2 -0
- package/lib/types/payloads/_interactions/ping.d.ts +3 -0
- package/lib/types/payloads/_interactions/ping.js +2 -0
- package/lib/types/payloads/_interactions/responses.d.ts +112 -0
- package/lib/types/payloads/_interactions/responses.js +54 -0
- package/lib/types/payloads/application.d.ts +292 -0
- package/lib/types/payloads/application.js +117 -0
- package/lib/types/payloads/auditLog.d.ts +644 -0
- package/lib/types/payloads/auditLog.js +80 -0
- package/lib/types/payloads/autoModeration.d.ts +219 -0
- package/lib/types/payloads/autoModeration.js +87 -0
- package/lib/types/payloads/channel.d.ts +1708 -0
- package/lib/types/payloads/channel.js +372 -0
- package/lib/types/payloads/emoji.d.ts +48 -0
- package/lib/types/payloads/emoji.js +5 -0
- package/lib/types/payloads/gateway.d.ts +373 -0
- package/lib/types/payloads/gateway.js +82 -0
- package/lib/types/payloads/guild.d.ts +1060 -0
- package/lib/types/payloads/guild.js +324 -0
- package/lib/types/payloads/guildScheduledEvent.d.ts +138 -0
- package/lib/types/payloads/guildScheduledEvent.js +32 -0
- package/lib/types/payloads/index.d.ts +64 -0
- package/lib/types/payloads/index.js +37 -0
- package/lib/types/payloads/interactions.d.ts +24 -0
- package/lib/types/payloads/interactions.js +23 -0
- package/lib/types/payloads/invite.d.ts +121 -0
- package/lib/types/payloads/invite.js +23 -0
- package/lib/types/payloads/monetization.d.ts +150 -0
- package/lib/types/payloads/monetization.js +79 -0
- package/lib/types/payloads/oauth2.d.ts +131 -0
- package/lib/types/payloads/oauth2.js +135 -0
- package/lib/types/payloads/permissions.d.ts +97 -0
- package/lib/types/payloads/permissions.js +16 -0
- package/lib/types/payloads/poll.d.ts +104 -0
- package/lib/types/payloads/poll.js +16 -0
- package/lib/types/payloads/stageInstance.d.ts +77 -0
- package/lib/types/payloads/stageInstance.js +19 -0
- package/lib/types/payloads/sticker.d.ts +123 -0
- package/lib/types/payloads/sticker.js +30 -0
- package/lib/types/payloads/teams.d.ts +78 -0
- package/lib/types/payloads/teams.js +23 -0
- package/lib/types/payloads/template.d.ts +62 -0
- package/lib/types/payloads/template.js +5 -0
- package/lib/types/payloads/user.d.ts +337 -0
- package/lib/types/payloads/user.js +167 -0
- package/lib/types/payloads/voice.d.ts +89 -0
- package/lib/types/payloads/voice.js +5 -0
- package/lib/types/payloads/webhook.d.ts +76 -0
- package/lib/types/payloads/webhook.js +21 -0
- package/lib/types/rest/application.d.ts +57 -0
- package/lib/types/rest/application.js +2 -0
- package/lib/types/rest/auditLog.d.ts +30 -0
- package/lib/types/rest/auditLog.js +2 -0
- package/lib/types/rest/autoModeration.d.ts +66 -0
- package/lib/types/rest/autoModeration.js +2 -0
- package/lib/types/rest/channel.d.ts +712 -0
- package/lib/types/rest/channel.js +11 -0
- package/lib/types/rest/emoji.d.ts +54 -0
- package/lib/types/rest/emoji.js +2 -0
- package/lib/types/rest/gateway.d.ts +9 -0
- package/lib/types/rest/gateway.js +2 -0
- package/lib/types/rest/guild.d.ts +865 -0
- package/lib/types/rest/guild.js +2 -0
- package/lib/types/rest/guildScheduledEvent.d.ts +126 -0
- package/lib/types/rest/guildScheduledEvent.js +2 -0
- package/lib/types/rest/index.d.ts +296 -0
- package/lib/types/rest/index.js +292 -0
- package/lib/types/rest/interactions.d.ts +194 -0
- package/lib/types/rest/interactions.js +2 -0
- package/lib/types/rest/invite.d.ts +24 -0
- package/lib/types/rest/invite.js +2 -0
- package/lib/types/rest/monetization.d.ts +82 -0
- package/lib/types/rest/monetization.js +11 -0
- package/lib/types/rest/oauth2.d.ts +172 -0
- package/lib/types/rest/oauth2.js +2 -0
- package/lib/types/rest/poll.d.ts +44 -0
- package/lib/types/rest/poll.js +2 -0
- package/lib/types/rest/stageInstance.d.ts +58 -0
- package/lib/types/rest/stageInstance.js +2 -0
- package/lib/types/rest/sticker.d.ts +77 -0
- package/lib/types/rest/sticker.js +2 -0
- package/lib/types/rest/template.d.ts +62 -0
- package/lib/types/rest/template.js +2 -0
- package/lib/types/rest/user.d.ts +120 -0
- package/lib/types/rest/user.js +2 -0
- package/lib/types/rest/voice.d.ts +17 -0
- package/lib/types/rest/voice.js +2 -0
- package/lib/types/rest/webhook.d.ts +250 -0
- package/lib/types/rest/webhook.js +2 -0
- package/lib/types/utils/index.d.ts +797 -0
- package/lib/types/utils/index.js +799 -0
- package/lib/websocket/SharedTypes.d.ts +4 -3
- package/lib/websocket/SharedTypes.js +1 -1
- package/lib/websocket/constants/index.d.ts +0 -1
- package/lib/websocket/discord/basesocket.d.ts +7 -6
- package/lib/websocket/discord/basesocket.js +35 -6
- package/lib/websocket/discord/events/memberUpdate.d.ts +1 -6
- package/lib/websocket/discord/events/memberUpdate.js +2 -1
- package/lib/websocket/discord/events/presenceUpdate.d.ts +5 -18
- package/lib/websocket/discord/events/presenceUpdate.js +5 -6
- package/lib/websocket/discord/shard.d.ts +9 -8
- package/lib/websocket/discord/shard.js +65 -47
- package/lib/websocket/discord/sharder.d.ts +6 -5
- package/lib/websocket/discord/sharder.js +11 -10
- package/lib/websocket/discord/shared.d.ts +13 -5
- package/lib/websocket/discord/socket/custom.d.ts +52 -0
- package/lib/websocket/discord/socket/custom.js +283 -0
- package/lib/websocket/discord/worker.d.ts +5 -10
- package/lib/websocket/discord/workermanager.d.ts +8 -15
- package/lib/websocket/discord/workermanager.js +35 -39
- package/lib/websocket/structures/index.d.ts +0 -1
- package/lib/websocket/structures/index.js +1 -1
- package/lib/websocket/structures/timeout.d.ts +0 -1
- package/package.json +65 -74
- package/lib/cache/adapters/redis.d.ts +0 -37
- package/lib/cache/adapters/redis.js +0 -218
- package/lib/client/oninteractioncreate.d.ts +0 -4
- package/lib/client/oninteractioncreate.js +0 -198
- package/lib/client/onmessagecreate.d.ts +0 -3
- package/lib/client/onmessagecreate.js +0 -395
- package/lib/structures/extra/functions.d.ts +0 -12
- package/lib/structures/extra/functions.js +0 -70
package/lib/cache/index.js
CHANGED
|
@@ -15,6 +15,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
exports.Cache = void 0;
|
|
18
|
+
const common_1 = require("../common");
|
|
18
19
|
const guilds_1 = require("./resources/guilds");
|
|
19
20
|
const users_1 = require("./resources/users");
|
|
20
21
|
const channels_1 = require("./resources/channels");
|
|
@@ -26,7 +27,8 @@ const stage_instances_1 = require("./resources/stage-instances");
|
|
|
26
27
|
const stickers_1 = require("./resources/stickers");
|
|
27
28
|
const threads_1 = require("./resources/threads");
|
|
28
29
|
const voice_states_1 = require("./resources/voice-states");
|
|
29
|
-
const
|
|
30
|
+
const bans_1 = require("./resources/bans");
|
|
31
|
+
const types_1 = require("../types");
|
|
30
32
|
const overwrites_1 = require("./resources/overwrites");
|
|
31
33
|
const messages_1 = require("./resources/messages");
|
|
32
34
|
__exportStar(require("./adapters/index"), exports);
|
|
@@ -50,52 +52,59 @@ class Cache {
|
|
|
50
52
|
presences;
|
|
51
53
|
stageInstances;
|
|
52
54
|
messages;
|
|
53
|
-
|
|
55
|
+
bans;
|
|
56
|
+
__logger__;
|
|
57
|
+
constructor(intents, adapter, disabledCache = {}, client) {
|
|
54
58
|
this.intents = intents;
|
|
55
59
|
this.adapter = adapter;
|
|
56
60
|
this.disabledCache = disabledCache;
|
|
57
61
|
// non-guild based
|
|
58
|
-
if (!this.disabledCache.
|
|
62
|
+
if (!this.disabledCache.users) {
|
|
59
63
|
this.users = new users_1.Users(this, client);
|
|
60
64
|
}
|
|
61
|
-
if (!this.disabledCache.
|
|
65
|
+
if (!this.disabledCache.guilds) {
|
|
62
66
|
this.guilds = new guilds_1.Guilds(this, client);
|
|
63
67
|
}
|
|
64
68
|
// guild related
|
|
65
|
-
if (!this.disabledCache.
|
|
69
|
+
if (!this.disabledCache.members) {
|
|
66
70
|
this.members = new members_1.Members(this, client);
|
|
67
71
|
}
|
|
68
|
-
if (!this.disabledCache.
|
|
72
|
+
if (!this.disabledCache.voiceStates) {
|
|
69
73
|
this.voiceStates = new voice_states_1.VoiceStates(this, client);
|
|
70
74
|
}
|
|
71
75
|
// guild based
|
|
72
|
-
if (!this.disabledCache.
|
|
76
|
+
if (!this.disabledCache.roles) {
|
|
73
77
|
this.roles = new roles_1.Roles(this, client);
|
|
74
78
|
}
|
|
75
|
-
if (!this.disabledCache.
|
|
79
|
+
if (!this.disabledCache.overwrites) {
|
|
76
80
|
this.overwrites = new overwrites_1.Overwrites(this, client);
|
|
77
81
|
}
|
|
78
|
-
if (!this.disabledCache.
|
|
82
|
+
if (!this.disabledCache.channels) {
|
|
79
83
|
this.channels = new channels_1.Channels(this, client);
|
|
80
84
|
}
|
|
81
|
-
if (!this.disabledCache.
|
|
85
|
+
if (!this.disabledCache.emojis) {
|
|
82
86
|
this.emojis = new emojis_1.Emojis(this, client);
|
|
83
87
|
}
|
|
84
|
-
if (!this.disabledCache.
|
|
88
|
+
if (!this.disabledCache.stickers) {
|
|
85
89
|
this.stickers = new stickers_1.Stickers(this, client);
|
|
86
90
|
}
|
|
87
|
-
if (!this.disabledCache.
|
|
91
|
+
if (!this.disabledCache.presences) {
|
|
88
92
|
this.presences = new presence_1.Presences(this, client);
|
|
89
93
|
}
|
|
90
|
-
if (!this.disabledCache.
|
|
94
|
+
if (!this.disabledCache.threads) {
|
|
91
95
|
this.threads = new threads_1.Threads(this, client);
|
|
92
96
|
}
|
|
93
|
-
if (!this.disabledCache.
|
|
97
|
+
if (!this.disabledCache.stageInstances) {
|
|
94
98
|
this.stageInstances = new stage_instances_1.StageInstances(this, client);
|
|
95
99
|
}
|
|
96
|
-
if (!this.disabledCache.
|
|
100
|
+
if (!this.disabledCache.messages) {
|
|
97
101
|
this.messages = new messages_1.Messages(this, client);
|
|
98
102
|
}
|
|
103
|
+
if (!this.disabledCache.bans) {
|
|
104
|
+
this.bans = new bans_1.Bans(this, client);
|
|
105
|
+
}
|
|
106
|
+
if (this.disabledCache.onPacket)
|
|
107
|
+
delete this.onPacket;
|
|
99
108
|
}
|
|
100
109
|
/** @internal */
|
|
101
110
|
__setClient(client) {
|
|
@@ -112,13 +121,14 @@ class Cache {
|
|
|
112
121
|
this.threads?.__setClient(client);
|
|
113
122
|
this.stageInstances?.__setClient(client);
|
|
114
123
|
this.messages?.__setClient(client);
|
|
124
|
+
this.bans?.__setClient(client);
|
|
115
125
|
}
|
|
116
126
|
flush() {
|
|
117
127
|
return this.adapter.flush();
|
|
118
128
|
}
|
|
119
129
|
// internal use ./structures
|
|
120
130
|
hasIntent(intent) {
|
|
121
|
-
return (this.intents &
|
|
131
|
+
return (this.intents & types_1.GatewayIntentBits[intent]) === types_1.GatewayIntentBits[intent];
|
|
122
132
|
}
|
|
123
133
|
get hasGuildsIntent() {
|
|
124
134
|
return this.hasIntent('Guilds');
|
|
@@ -144,6 +154,9 @@ class Cache {
|
|
|
144
154
|
get hasDirectMessages() {
|
|
145
155
|
return this.hasIntent('DirectMessages');
|
|
146
156
|
}
|
|
157
|
+
get hasBansIntent() {
|
|
158
|
+
return this.hasIntent('GuildBans');
|
|
159
|
+
}
|
|
147
160
|
async bulkGet(keys) {
|
|
148
161
|
const allData = {};
|
|
149
162
|
for (const [type, id, guildId] of keys) {
|
|
@@ -167,6 +180,7 @@ class Cache {
|
|
|
167
180
|
case 'users':
|
|
168
181
|
case 'guilds':
|
|
169
182
|
case 'overwrites':
|
|
183
|
+
case 'bans':
|
|
170
184
|
case 'messages':
|
|
171
185
|
{
|
|
172
186
|
if (!allData[type]) {
|
|
@@ -207,6 +221,7 @@ class Cache {
|
|
|
207
221
|
case 'stageInstances':
|
|
208
222
|
case 'emojis':
|
|
209
223
|
case 'overwrites':
|
|
224
|
+
case 'bans':
|
|
210
225
|
case 'messages':
|
|
211
226
|
{
|
|
212
227
|
if (!this[type]?.filter(data, id, guildId))
|
|
@@ -263,7 +278,7 @@ class Cache {
|
|
|
263
278
|
}
|
|
264
279
|
}
|
|
265
280
|
await this.adapter.bulkAddToRelationShip(relationshipsData);
|
|
266
|
-
await this.adapter.
|
|
281
|
+
await this.adapter.bulkPatch(false, allData);
|
|
267
282
|
}
|
|
268
283
|
async bulkSet(keys) {
|
|
269
284
|
const allData = [];
|
|
@@ -296,6 +311,7 @@ class Cache {
|
|
|
296
311
|
allData.push([this[type].hashId(id), this[type].parse(data, id, guildId)]);
|
|
297
312
|
}
|
|
298
313
|
break;
|
|
314
|
+
case 'bans':
|
|
299
315
|
case 'voiceStates':
|
|
300
316
|
case 'members':
|
|
301
317
|
{
|
|
@@ -334,7 +350,7 @@ class Cache {
|
|
|
334
350
|
}
|
|
335
351
|
}
|
|
336
352
|
await this.adapter.bulkAddToRelationShip(relationshipsData);
|
|
337
|
-
await this.adapter.
|
|
353
|
+
await this.adapter.bulkSet(allData);
|
|
338
354
|
}
|
|
339
355
|
async onPacket(event) {
|
|
340
356
|
switch (event.t) {
|
|
@@ -361,7 +377,7 @@ class Cache {
|
|
|
361
377
|
await this.overwrites?.set(event.d.id, event.d.guild_id, event.d.permission_overwrites);
|
|
362
378
|
break;
|
|
363
379
|
}
|
|
364
|
-
if (event.d.type ===
|
|
380
|
+
if (event.d.type === types_1.ChannelType.DM) {
|
|
365
381
|
await this.channels?.set(event.d.recipients[0]?.id, '@me', event.d);
|
|
366
382
|
break;
|
|
367
383
|
}
|
|
@@ -376,6 +392,12 @@ class Cache {
|
|
|
376
392
|
case 'GUILD_ROLE_DELETE':
|
|
377
393
|
await this.roles?.remove(event.d.role_id, event.d.guild_id);
|
|
378
394
|
break;
|
|
395
|
+
case 'GUILD_BAN_ADD':
|
|
396
|
+
await this.bans?.set(event.d.user.id, event.d.guild_id, event.d);
|
|
397
|
+
break;
|
|
398
|
+
case 'GUILD_BAN_REMOVE':
|
|
399
|
+
await this.bans?.remove(event.d.user.id, event.d.guild_id);
|
|
400
|
+
break;
|
|
379
401
|
case 'GUILD_EMOJIS_UPDATE':
|
|
380
402
|
await this.emojis?.remove(await this.emojis?.keys(event.d.guild_id), event.d.guild_id);
|
|
381
403
|
await this.emojis?.set(event.d.emojis.map(x => [x.id, x]), event.d.guild_id);
|
|
@@ -439,5 +461,299 @@ class Cache {
|
|
|
439
461
|
break;
|
|
440
462
|
}
|
|
441
463
|
}
|
|
464
|
+
async testAdapter() {
|
|
465
|
+
this.__logger__ ??= new common_1.Logger({
|
|
466
|
+
name: '[CACHE]',
|
|
467
|
+
});
|
|
468
|
+
await this.adapter.flush();
|
|
469
|
+
// this method will only check the cache for `users`, `members` y `channels`
|
|
470
|
+
// likewise these have the three types of resources (GuildRelatedResource, GuildBasedResource, BaseResource)
|
|
471
|
+
// will also check `overwrites`, since the latter stores an array not as an object but as data.
|
|
472
|
+
await this.testUsersAndMembers();
|
|
473
|
+
await this.testChannelsAndOverwrites();
|
|
474
|
+
this.__logger__.info('The adapter seems to work properly');
|
|
475
|
+
this.__logger__.debug('Flushing adapter');
|
|
476
|
+
delete this.__logger__;
|
|
477
|
+
await this.adapter.flush();
|
|
478
|
+
}
|
|
479
|
+
async testUsersAndMembers() {
|
|
480
|
+
if (!this.users)
|
|
481
|
+
throw new Error('Users cache disabled, you should enable it for this.');
|
|
482
|
+
if (!this.members)
|
|
483
|
+
throw new Error('Members cache disabled, you should enable it for this.');
|
|
484
|
+
function createUser(name) {
|
|
485
|
+
return {
|
|
486
|
+
avatar: 'xdxd',
|
|
487
|
+
discriminator: '0',
|
|
488
|
+
global_name: name,
|
|
489
|
+
id: `${Math.random()}`.slice(2),
|
|
490
|
+
username: `@seyfert/${name}`,
|
|
491
|
+
};
|
|
492
|
+
}
|
|
493
|
+
function createMember(name) {
|
|
494
|
+
return {
|
|
495
|
+
banner: null,
|
|
496
|
+
avatar: 'xdxd',
|
|
497
|
+
deaf: !false,
|
|
498
|
+
flags: types_1.GuildMemberFlags.StartedHomeActions,
|
|
499
|
+
joined_at: new Date().toISOString(),
|
|
500
|
+
mute: !true,
|
|
501
|
+
roles: ['111111111111'],
|
|
502
|
+
user: createUser(name),
|
|
503
|
+
};
|
|
504
|
+
}
|
|
505
|
+
const users = [
|
|
506
|
+
createUser('witherking_'),
|
|
507
|
+
createUser('vanecia'),
|
|
508
|
+
createUser('socram'),
|
|
509
|
+
createUser('free'),
|
|
510
|
+
createUser('justevil'),
|
|
511
|
+
createUser('nobody'),
|
|
512
|
+
createUser('aaron'),
|
|
513
|
+
createUser('simxnet'),
|
|
514
|
+
createUser('yuzu'),
|
|
515
|
+
createUser('vyrek'),
|
|
516
|
+
createUser('marcrock'),
|
|
517
|
+
];
|
|
518
|
+
for (const user of users) {
|
|
519
|
+
await this.users.set(user.id, user);
|
|
520
|
+
}
|
|
521
|
+
let count = 0;
|
|
522
|
+
if ((await this.users.values()).length !== users.length)
|
|
523
|
+
throw new Error('users.values() is not of the expected size.');
|
|
524
|
+
if ((await this.users.count()) !== users.length)
|
|
525
|
+
throw new Error('users.count() is not of the expected amount');
|
|
526
|
+
for (const user of users) {
|
|
527
|
+
const cache = await this.users.raw(user.id);
|
|
528
|
+
if (!cache)
|
|
529
|
+
throw new Error(`users.raw(${user.id}) has returned undefined!!!!!!`);
|
|
530
|
+
if (cache.username !== user.username)
|
|
531
|
+
throw new Error(`users.raw(${user.id}).username is not of the expected value!!!!! (cache (${cache.username})) (expected value: (${user.username}))`);
|
|
532
|
+
if (cache.id !== user.id)
|
|
533
|
+
throw new Error(`users.raw(${user.id}).id is not of the expected value!!!!!! (cache (${cache.id})) (expected value: (${user.id}))`);
|
|
534
|
+
await this.users.remove(user.id);
|
|
535
|
+
if ((await this.users.count()) !== users.length - ++count)
|
|
536
|
+
throw new Error(`users.count() should be ${users.length - count}!! please check your remove method`);
|
|
537
|
+
}
|
|
538
|
+
this.__logger__.info('the user cache seems to be alright.');
|
|
539
|
+
this.__logger__.debug('Flushing adapter to clear users cache.');
|
|
540
|
+
await this.adapter.flush();
|
|
541
|
+
// unexpected error message
|
|
542
|
+
if ((await this.users.count()) !== 0)
|
|
543
|
+
throw new Error('users.count() should be 0!! please check your flush method');
|
|
544
|
+
const guildMembers = {
|
|
545
|
+
'852531635252494346': [
|
|
546
|
+
createMember("witherking_'s member"),
|
|
547
|
+
createMember("vanecia's member"),
|
|
548
|
+
createMember("nobody's member"),
|
|
549
|
+
],
|
|
550
|
+
'1003825077969764412': [
|
|
551
|
+
createMember("free's member"),
|
|
552
|
+
createMember("socram's member"),
|
|
553
|
+
createMember("marcrock's member"),
|
|
554
|
+
createMember("justevil's member"),
|
|
555
|
+
createMember("vyrek's member"),
|
|
556
|
+
],
|
|
557
|
+
'876711213126520882': [
|
|
558
|
+
createMember("aaron's member"),
|
|
559
|
+
createMember("simxnet's member"),
|
|
560
|
+
createMember("yuzu's member"),
|
|
561
|
+
],
|
|
562
|
+
};
|
|
563
|
+
for (const guildId in guildMembers) {
|
|
564
|
+
const members = guildMembers[guildId];
|
|
565
|
+
for (const member of members) {
|
|
566
|
+
await this.members.set(member.user.id, guildId, member);
|
|
567
|
+
}
|
|
568
|
+
if ((await this.members.values(guildId)).length !== members.length)
|
|
569
|
+
throw new Error('members.values(guildId) is not of the expected size.');
|
|
570
|
+
if ((await this.members.count(guildId)) !== members.length)
|
|
571
|
+
throw new Error('members.count(guildId) is not of the expected amount');
|
|
572
|
+
for (const member of members) {
|
|
573
|
+
const cache = await this.members.raw(member.user.id, guildId);
|
|
574
|
+
if (!cache)
|
|
575
|
+
throw new Error(`members.raw(${member.user.id}, ${guildId}) has returned undefined.`);
|
|
576
|
+
if (cache.roles[0] !== member.roles[0])
|
|
577
|
+
throw new Error(`members.raw(${member.user.id}, ${guildId}).roles[0] is not the expected value: ${member.roles[0]} (cache: ${cache.roles[0]})`);
|
|
578
|
+
if (cache.user.username !== member.user.username)
|
|
579
|
+
throw new Error(`members.raw(${member.user.id}, ${guildId}).user.username is not the expected value!!!!!! (cache (${cache.user.username})) (expected value: (${member.user.username}))`);
|
|
580
|
+
if (cache.user.id !== member.user.id)
|
|
581
|
+
throw new Error(`members.raw(${member.user.id}, ${guildId}).user.id is not the expected value!!!!!! (cache (${cache.user.id})) (expected value: (${member.user.id}))`);
|
|
582
|
+
}
|
|
583
|
+
}
|
|
584
|
+
if ((await this.members.values('*')).length !== Object.values(guildMembers).flat().length)
|
|
585
|
+
throw new Error('members.values(*) is not of the expected size');
|
|
586
|
+
if ((await this.members.count('*')) !== Object.values(guildMembers).flat().length)
|
|
587
|
+
throw new Error('the global amount of members.count(*) is not the expected amount');
|
|
588
|
+
count = 0;
|
|
589
|
+
for (const guildId in guildMembers) {
|
|
590
|
+
const members = guildMembers[guildId];
|
|
591
|
+
for (const member of members) {
|
|
592
|
+
await this.members.remove(member.user.id, guildId);
|
|
593
|
+
if ((await this.members.count(guildId)) !== members.length - ++count)
|
|
594
|
+
throw new Error(`members.count(${guildId}) should be ${members.length - count}!! please check your remove method`);
|
|
595
|
+
}
|
|
596
|
+
count = 0;
|
|
597
|
+
}
|
|
598
|
+
await this.adapter.flush();
|
|
599
|
+
// unexpected error message
|
|
600
|
+
if ((await this.users.count()) !== 0)
|
|
601
|
+
throw new Error('users.count() should be zero!! please check your flush method');
|
|
602
|
+
// unexpected error message
|
|
603
|
+
if ((await this.members.count('*')) !== 0)
|
|
604
|
+
throw new Error("members.count('*') should be zero!! please check your flush method");
|
|
605
|
+
this.__logger__.info('the member cache seems to be alright.');
|
|
606
|
+
}
|
|
607
|
+
async testChannelsAndOverwrites() {
|
|
608
|
+
if (!this.channels)
|
|
609
|
+
throw new Error('Channels cache disabled, you should enable it for this.');
|
|
610
|
+
if (!this.overwrites)
|
|
611
|
+
throw new Error('Overwrites cache disabled, you should enable it for this.');
|
|
612
|
+
function createChannel(name) {
|
|
613
|
+
return {
|
|
614
|
+
id: `${Math.random()}`.slice(2),
|
|
615
|
+
name,
|
|
616
|
+
type: types_1.ChannelType.GuildText,
|
|
617
|
+
position: Math.random() > 0.5 ? 1 : 0,
|
|
618
|
+
};
|
|
619
|
+
}
|
|
620
|
+
function createOverwrites(name) {
|
|
621
|
+
const channel_id = `${Math.random()}`.slice(2);
|
|
622
|
+
return [
|
|
623
|
+
{
|
|
624
|
+
id: name,
|
|
625
|
+
allow: '8',
|
|
626
|
+
deny: '2',
|
|
627
|
+
type: types_1.OverwriteType.Role,
|
|
628
|
+
channel_id,
|
|
629
|
+
},
|
|
630
|
+
{
|
|
631
|
+
id: `${name}-2`,
|
|
632
|
+
allow: '8',
|
|
633
|
+
deny: '2',
|
|
634
|
+
type: types_1.OverwriteType.Role,
|
|
635
|
+
channel_id,
|
|
636
|
+
},
|
|
637
|
+
];
|
|
638
|
+
}
|
|
639
|
+
const guildChannels = {
|
|
640
|
+
'852531635252494346': [
|
|
641
|
+
createChannel("witherking_'s channel"),
|
|
642
|
+
createChannel("vanecia's channel"),
|
|
643
|
+
createChannel("nobody's channel"),
|
|
644
|
+
],
|
|
645
|
+
'1003825077969764412': [
|
|
646
|
+
createChannel("free's channel"),
|
|
647
|
+
createChannel("socram's channel"),
|
|
648
|
+
createChannel("marcrock's channel"),
|
|
649
|
+
createChannel("justevil's channel"),
|
|
650
|
+
createChannel("vyrek's channel"),
|
|
651
|
+
],
|
|
652
|
+
'876711213126520882': [
|
|
653
|
+
createChannel("aaron's channel"),
|
|
654
|
+
createChannel("simxnet's channel"),
|
|
655
|
+
createChannel("yuzu's channel"),
|
|
656
|
+
],
|
|
657
|
+
};
|
|
658
|
+
for (const guildId in guildChannels) {
|
|
659
|
+
const channels = guildChannels[guildId];
|
|
660
|
+
for (const channel of channels) {
|
|
661
|
+
await this.channels.set(channel.id, guildId, channel);
|
|
662
|
+
}
|
|
663
|
+
if ((await this.channels.values(guildId)).length !== channels.length)
|
|
664
|
+
throw new Error('channels.values(guildId) is not of the expected size');
|
|
665
|
+
if ((await this.channels.count(guildId)) !== channels.length)
|
|
666
|
+
throw new Error('channels.count(guildId) is not of the expected amount');
|
|
667
|
+
for (const channel of channels) {
|
|
668
|
+
const cache = await this.channels.raw(channel.id);
|
|
669
|
+
if (!cache)
|
|
670
|
+
throw new Error(`channels.raw(${channel.id}) has returned undefined!!!!!!`);
|
|
671
|
+
if (cache.type !== types_1.ChannelType.GuildText)
|
|
672
|
+
throw new Error(`channels.raw(${channel.id}).type is not of the expected type: ${channel.type}!!!!!!!! (mismatched type: ${cache.type})`);
|
|
673
|
+
if (cache.name !== channel.name)
|
|
674
|
+
throw new Error(`channels.raw(${channel.id}).name is not the expected value!!!!!! (cache (${cache.name})) (expected value: (${channel.name}))`);
|
|
675
|
+
if (cache.id !== channel.id)
|
|
676
|
+
throw new Error(`channels.raw(${channel.id}).id is not the expected value!!!!!! (cache (${cache.id})) (expected value: (${channel.id}))`);
|
|
677
|
+
}
|
|
678
|
+
}
|
|
679
|
+
if ((await this.channels.values('*')).length !== Object.values(guildChannels).flat().length)
|
|
680
|
+
throw new Error('channels.values(*) is not of the expected size');
|
|
681
|
+
if ((await this.channels.count('*')) !== Object.values(guildChannels).flat().length)
|
|
682
|
+
throw new Error('channels.count(*) is not of the expected amount');
|
|
683
|
+
let count = 0;
|
|
684
|
+
for (const guildId in guildChannels) {
|
|
685
|
+
const channels = guildChannels[guildId];
|
|
686
|
+
for (const channel of channels) {
|
|
687
|
+
await this.channels.remove(channel.id, guildId);
|
|
688
|
+
if ((await this.channels.count(guildId)) !== channels.length - ++count)
|
|
689
|
+
throw new Error(`channels.count(${guildId}) should be ${channels.length - count}!! please check your remove method`);
|
|
690
|
+
}
|
|
691
|
+
count = 0;
|
|
692
|
+
}
|
|
693
|
+
// unexpected error message
|
|
694
|
+
if ((await this.channels.count('*')) !== 0)
|
|
695
|
+
throw new Error(`channels.count('*') should be zero!! please check your remove method`);
|
|
696
|
+
this.__logger__.info('the channel cache seems to be alright');
|
|
697
|
+
const guildOverwrites = {
|
|
698
|
+
'852531635252494346': [
|
|
699
|
+
createOverwrites("witherking_'s channel"),
|
|
700
|
+
createOverwrites("vanecia's channel"),
|
|
701
|
+
createOverwrites("nobody's channel"),
|
|
702
|
+
],
|
|
703
|
+
'1003825077969764412': [
|
|
704
|
+
createOverwrites("free's channel"),
|
|
705
|
+
createOverwrites("socram's channel"),
|
|
706
|
+
createOverwrites("marcrock's channel"),
|
|
707
|
+
createOverwrites("justevil's channel"),
|
|
708
|
+
createOverwrites("vyrek's channel"),
|
|
709
|
+
],
|
|
710
|
+
'876711213126520882': [
|
|
711
|
+
createOverwrites("aaron's channel"),
|
|
712
|
+
createOverwrites("simxnet's channel"),
|
|
713
|
+
createOverwrites("yuzu's channel"),
|
|
714
|
+
],
|
|
715
|
+
};
|
|
716
|
+
for (const guildId in guildOverwrites) {
|
|
717
|
+
const bulkOverwrites = guildOverwrites[guildId];
|
|
718
|
+
for (const overwrites of bulkOverwrites) {
|
|
719
|
+
await this.overwrites.set(overwrites[0].channel_id, guildId, overwrites);
|
|
720
|
+
}
|
|
721
|
+
if ((await this.overwrites.values(guildId)).length !== bulkOverwrites.length)
|
|
722
|
+
throw new Error('overwrites.values(channelId) is not of the expected size');
|
|
723
|
+
if ((await this.overwrites.count(guildId)) !== bulkOverwrites.length)
|
|
724
|
+
throw new Error('overwrites.count(channelId) is not of the expected amount');
|
|
725
|
+
for (const overwrites of bulkOverwrites) {
|
|
726
|
+
const cache = await this.overwrites.raw(overwrites[0].channel_id);
|
|
727
|
+
if (!cache)
|
|
728
|
+
throw new Error(`overwrites.raw(${overwrites[0].channel_id}) has returned undefined!!!!!!`);
|
|
729
|
+
if (cache.length !== overwrites.length)
|
|
730
|
+
throw new Error(`overwrites.raw(${overwrites[0].channel_id}).length is not of the expected length!!!!!! (cache (${cache.length})) (expected value: (${overwrites.length}))`);
|
|
731
|
+
for (const overwrite of overwrites) {
|
|
732
|
+
if (!cache.some(x => {
|
|
733
|
+
return (x.allow === overwrite.allow &&
|
|
734
|
+
x.deny === overwrite.deny &&
|
|
735
|
+
x.guild_id === guildId &&
|
|
736
|
+
x.id === overwrite.id &&
|
|
737
|
+
x.type === overwrite.type);
|
|
738
|
+
}))
|
|
739
|
+
throw new Error("cache wasn't found in the overwrites cache");
|
|
740
|
+
}
|
|
741
|
+
}
|
|
742
|
+
}
|
|
743
|
+
count = 0;
|
|
744
|
+
for (const guildId in guildOverwrites) {
|
|
745
|
+
const bulkOverwrites = guildOverwrites[guildId];
|
|
746
|
+
for (const overwrites of bulkOverwrites) {
|
|
747
|
+
await this.overwrites.remove(overwrites[0].channel_id, guildId);
|
|
748
|
+
if ((await this.overwrites.count(guildId)) !== bulkOverwrites.length - ++count)
|
|
749
|
+
throw new Error(`overwrites.count(${guildId}) should be ${overwrites.length - count}!! please check your remove method`);
|
|
750
|
+
}
|
|
751
|
+
count = 0;
|
|
752
|
+
}
|
|
753
|
+
// unexpected error message
|
|
754
|
+
if ((await this.overwrites.count('*')) !== 0)
|
|
755
|
+
throw new Error(`overwrites.count('*') should be zero!! please check your remove method`);
|
|
756
|
+
this.__logger__.info('the overwrites cache seems to be alright.');
|
|
757
|
+
}
|
|
442
758
|
}
|
|
443
759
|
exports.Cache = Cache;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { APIBan, GatewayGuildBanModifyDispatchData } from '../../types';
|
|
2
|
+
import type { ReturnCache } from '../..';
|
|
3
|
+
import { GuildBasedResource } from './default/guild-based';
|
|
4
|
+
import { type GuildBanStructure } from '../../client/transformers';
|
|
5
|
+
export declare class Bans extends GuildBasedResource<any, GatewayGuildBanModifyDispatchData | APIBan> {
|
|
6
|
+
namespace: string;
|
|
7
|
+
filter(data: APIBan, id: string, guild_id: string): boolean;
|
|
8
|
+
parse(data: any, key: string, guild_id: string): any;
|
|
9
|
+
get(id: string, guild: string): ReturnCache<GuildBanStructure | undefined>;
|
|
10
|
+
raw(id: string, guild: string): ReturnCache<Omit<GatewayGuildBanModifyDispatchData | APIBan, 'user'> | undefined>;
|
|
11
|
+
bulk(ids: string[], guild: string): ReturnCache<GuildBanStructure[]>;
|
|
12
|
+
bulkRaw(ids: string[], guild: string): ReturnCache<Omit<GatewayGuildBanModifyDispatchData | APIBan, 'user'>[]>;
|
|
13
|
+
values(guild: string): ReturnCache<GuildBanStructure[]>;
|
|
14
|
+
valuesRaw(guild: string): ReturnCache<Omit<GatewayGuildBanModifyDispatchData | APIBan, 'user'>[]>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Bans = void 0;
|
|
4
|
+
const common_1 = require("../../common");
|
|
5
|
+
const guild_based_1 = require("./default/guild-based");
|
|
6
|
+
const transformers_1 = require("../../client/transformers");
|
|
7
|
+
class Bans extends guild_based_1.GuildBasedResource {
|
|
8
|
+
namespace = 'ban';
|
|
9
|
+
//@ts-expect-error
|
|
10
|
+
filter(data, id, guild_id) {
|
|
11
|
+
return true;
|
|
12
|
+
}
|
|
13
|
+
parse(data, key, guild_id) {
|
|
14
|
+
const { user, ...rest } = super.parse(data, data.user?.id ?? key, guild_id);
|
|
15
|
+
return rest;
|
|
16
|
+
}
|
|
17
|
+
get(id, guild) {
|
|
18
|
+
return (0, common_1.fakePromise)(super.get(id, guild)).then(rawBan => rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined);
|
|
19
|
+
}
|
|
20
|
+
raw(id, guild) {
|
|
21
|
+
return super.get(id, guild);
|
|
22
|
+
}
|
|
23
|
+
bulk(ids, guild) {
|
|
24
|
+
return (0, common_1.fakePromise)(super.bulk(ids, guild)).then(bans => bans
|
|
25
|
+
.map(rawBan => {
|
|
26
|
+
return rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined;
|
|
27
|
+
})
|
|
28
|
+
.filter(Boolean));
|
|
29
|
+
}
|
|
30
|
+
bulkRaw(ids, guild) {
|
|
31
|
+
return super.bulk(ids, guild);
|
|
32
|
+
}
|
|
33
|
+
values(guild) {
|
|
34
|
+
return (0, common_1.fakePromise)(super.values(guild)).then(bans => bans
|
|
35
|
+
.map(rawBan => {
|
|
36
|
+
return rawBan ? transformers_1.Transformers.GuildBan(this.client, rawBan, guild) : undefined;
|
|
37
|
+
})
|
|
38
|
+
.filter(Boolean));
|
|
39
|
+
}
|
|
40
|
+
valuesRaw(guild) {
|
|
41
|
+
return super.values(guild);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
exports.Bans = Bans;
|
|
@@ -1,12 +1,14 @@
|
|
|
1
|
-
import type { APIChannel } from '
|
|
2
|
-
import type
|
|
3
|
-
import channelFrom from '../../structures/channels';
|
|
1
|
+
import type { APIChannel } from '../../types';
|
|
2
|
+
import { channelFrom, type AllChannels } from '../../structures';
|
|
4
3
|
import type { ReturnCache } from '../index';
|
|
5
4
|
import { GuildRelatedResource } from './default/guild-related';
|
|
6
|
-
export declare class Channels extends GuildRelatedResource {
|
|
5
|
+
export declare class Channels extends GuildRelatedResource<any, APIChannel> {
|
|
7
6
|
namespace: string;
|
|
8
7
|
parse(data: APIChannel, id: string, guild_id: string): any;
|
|
9
8
|
get(id: string): ReturnCache<AllChannels | undefined>;
|
|
9
|
+
raw(id: string): ReturnCache<Omit<APIChannel, 'permission_overwrites'> | undefined>;
|
|
10
10
|
bulk(ids: string[]): ReturnCache<ReturnType<typeof channelFrom>[]>;
|
|
11
|
+
bulkRaw(ids: string[]): ReturnCache<Omit<APIChannel, 'permission_overwrites'>[]>;
|
|
11
12
|
values(guild: string): ReturnCache<ReturnType<typeof channelFrom>[]>;
|
|
13
|
+
valuesRaw(guild: string): ReturnCache<Omit<APIChannel, 'permission_overwrites'>[]>;
|
|
12
14
|
}
|
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
3
|
exports.Channels = void 0;
|
|
7
4
|
const common_1 = require("../../common");
|
|
8
|
-
const
|
|
5
|
+
const structures_1 = require("../../structures");
|
|
9
6
|
const guild_related_1 = require("./default/guild-related");
|
|
10
7
|
class Channels extends guild_related_1.GuildRelatedResource {
|
|
11
8
|
namespace = 'channel';
|
|
@@ -14,13 +11,22 @@ class Channels extends guild_related_1.GuildRelatedResource {
|
|
|
14
11
|
return rest;
|
|
15
12
|
}
|
|
16
13
|
get(id) {
|
|
17
|
-
return (0, common_1.fakePromise)(super.get(id)).then(rawChannel => rawChannel ? (0,
|
|
14
|
+
return (0, common_1.fakePromise)(super.get(id)).then(rawChannel => rawChannel ? (0, structures_1.channelFrom)(rawChannel, this.client) : undefined);
|
|
15
|
+
}
|
|
16
|
+
raw(id) {
|
|
17
|
+
return super.get(id);
|
|
18
18
|
}
|
|
19
19
|
bulk(ids) {
|
|
20
|
-
return (0, common_1.fakePromise)(super.bulk(ids)).then(channels => channels.map(rawChannel => (0,
|
|
20
|
+
return (0, common_1.fakePromise)(super.bulk(ids)).then(channels => channels.map(rawChannel => (0, structures_1.channelFrom)(rawChannel, this.client)));
|
|
21
|
+
}
|
|
22
|
+
bulkRaw(ids) {
|
|
23
|
+
return super.bulk(ids);
|
|
21
24
|
}
|
|
22
25
|
values(guild) {
|
|
23
|
-
return (0, common_1.fakePromise)(super.values(guild)).then(channels => channels.map(rawChannel => (0,
|
|
26
|
+
return (0, common_1.fakePromise)(super.values(guild)).then(channels => channels.map(rawChannel => (0, structures_1.channelFrom)(rawChannel, this.client)));
|
|
27
|
+
}
|
|
28
|
+
valuesRaw(guild) {
|
|
29
|
+
return super.values(guild);
|
|
24
30
|
}
|
|
25
31
|
}
|
|
26
32
|
exports.Channels = Channels;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { GatewayIntentBits } from 'discord-api-types/v10';
|
|
2
1
|
import type { UsingClient } from '../../../commands';
|
|
2
|
+
import type { GatewayIntentBits } from '../../../types';
|
|
3
3
|
import type { Cache, ReturnCache } from '../../index';
|
|
4
|
-
export declare class BaseResource<T = any> {
|
|
4
|
+
export declare class BaseResource<T = any, S = any> {
|
|
5
5
|
protected cache: Cache;
|
|
6
6
|
client: UsingClient;
|
|
7
7
|
namespace: string;
|
|
@@ -9,16 +9,16 @@ export declare class BaseResource<T = any> {
|
|
|
9
9
|
filter(data: any, id: string): boolean;
|
|
10
10
|
get adapter(): import("../../index").Adapter;
|
|
11
11
|
removeIfNI(intent: keyof typeof GatewayIntentBits, id: string): import("../../../common").Awaitable<void>;
|
|
12
|
-
setIfNI(intent: keyof typeof GatewayIntentBits, id: string, data:
|
|
12
|
+
setIfNI(intent: keyof typeof GatewayIntentBits, id: string, data: S): import("../../../common").Awaitable<void>;
|
|
13
13
|
get(id: string): ReturnCache<T | undefined>;
|
|
14
14
|
bulk(ids: string[]): ReturnCache<T[]>;
|
|
15
|
-
set(id: string, data:
|
|
16
|
-
patch(id: string, data:
|
|
15
|
+
set(id: string, data: S): import("../../../common").Awaitable<void>;
|
|
16
|
+
patch(id: string, data: S): import("../../../common").Awaitable<void>;
|
|
17
17
|
remove(id: string): import("../../../common").Awaitable<void>;
|
|
18
18
|
keys(): ReturnCache<string[]>;
|
|
19
19
|
values(): ReturnCache<T[]>;
|
|
20
|
-
count():
|
|
21
|
-
contains(id: string):
|
|
20
|
+
count(): ReturnCache<number>;
|
|
21
|
+
contains(id: string): ReturnCache<boolean>;
|
|
22
22
|
getToRelationship(): import("../../../common").Awaitable<string[]>;
|
|
23
23
|
addToRelationship(id: string | string[]): import("../../../common").Awaitable<void>;
|
|
24
24
|
removeToRelationship(id: string | string[]): import("../../../common").Awaitable<void>;
|
|
@@ -38,7 +38,7 @@ class BaseResource {
|
|
|
38
38
|
return this.adapter.get(this.hashId(id));
|
|
39
39
|
}
|
|
40
40
|
bulk(ids) {
|
|
41
|
-
return (0, common_1.fakePromise)(this.adapter.
|
|
41
|
+
return (0, common_1.fakePromise)(this.adapter.bulkGet(ids.map(id => this.hashId(id)))).then(x => x.filter(y => y));
|
|
42
42
|
}
|
|
43
43
|
set(id, data) {
|
|
44
44
|
if (!this.filter(data, id))
|
|
@@ -75,7 +75,7 @@ class BaseResource {
|
|
|
75
75
|
return this.adapter.removeToRelationship(this.namespace, id);
|
|
76
76
|
}
|
|
77
77
|
hashId(id) {
|
|
78
|
-
return `${this.namespace}.${id}`;
|
|
78
|
+
return id.startsWith(this.namespace) ? id : `${this.namespace}.${id}`;
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
81
|
exports.BaseResource = BaseResource;
|