diff --git a/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/PrivateChannelImpl.java b/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/PrivateChannelImpl.java index 57fc210aa91..cc8d32508a3 100644 --- a/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/PrivateChannelImpl.java +++ b/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/PrivateChannelImpl.java @@ -114,9 +114,6 @@ public boolean canTalk() return user == null || !user.isBot(); } - @Override - public void checkCanAccessChannel() {} - @Override public void checkCanSendMessage() { checkBot(); diff --git a/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/VoiceChannelImpl.java b/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/VoiceChannelImpl.java index 158da44ae9f..5f28819a10f 100644 --- a/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/VoiceChannelImpl.java +++ b/src/main/java/net/dv8tion/jda/internal/entities/channel/concrete/VoiceChannelImpl.java @@ -179,7 +179,7 @@ public String getStatus() public AuditableRestAction modifyStatus(@Nonnull String status) { Checks.notLonger(status, MAX_STATUS_LENGTH, "Voice Status"); - checkCanAccessChannel(); + checkCanAccess(); if (this.equals(getGuild().getSelfMember().getVoiceState().getChannel())) checkPermission(Permission.VOICE_SET_STATUS); else diff --git a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/AudioChannelMixin.java b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/AudioChannelMixin.java index 90ccf18753e..5e74d1a6d93 100644 --- a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/AudioChannelMixin.java +++ b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/AudioChannelMixin.java @@ -17,8 +17,10 @@ package net.dv8tion.jda.internal.entities.channel.mixin.middleman; import gnu.trove.map.TLongObjectMap; +import net.dv8tion.jda.api.Permission; import net.dv8tion.jda.api.entities.Member; import net.dv8tion.jda.api.entities.channel.unions.AudioChannelUnion; +import net.dv8tion.jda.api.exceptions.MissingAccessException; public interface AudioChannelMixin> extends AudioChannelUnion, StandardGuildChannelMixin @@ -31,4 +33,13 @@ public interface AudioChannelMixin> T setUserLimit(int userlimit); T setRegion(String region); + + @Override + default void checkCanAccess() + { + if (!hasPermission(Permission.VIEW_CHANNEL)) + throw new MissingAccessException(this, Permission.VIEW_CHANNEL); + if (!hasPermission(Permission.VOICE_CONNECT)) + throw new MissingAccessException(this, Permission.VOICE_CONNECT); + } } diff --git a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildChannelMixin.java b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildChannelMixin.java index c157e3a2070..889fcfc5179 100644 --- a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildChannelMixin.java +++ b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildChannelMixin.java @@ -21,6 +21,7 @@ import net.dv8tion.jda.api.entities.channel.middleman.GuildChannel; import net.dv8tion.jda.api.entities.channel.unions.GuildChannelUnion; import net.dv8tion.jda.api.exceptions.InsufficientPermissionException; +import net.dv8tion.jda.api.exceptions.MissingAccessException; import net.dv8tion.jda.api.requests.Route; import net.dv8tion.jda.api.requests.restaction.AuditableRestAction; import net.dv8tion.jda.internal.entities.channel.mixin.ChannelMixin; @@ -40,6 +41,7 @@ public interface GuildChannelMixin> extends @CheckReturnValue default AuditableRestAction delete() { + checkCanAccess(); checkCanManage(); Route.CompiledRoute route = Route.Channels.DELETE_CHANNEL.compile(getId()); @@ -70,4 +72,10 @@ default void checkCanManage() { checkPermission(Permission.MANAGE_CHANNEL); } + + default void checkCanAccess() + { + if (!hasPermission(Permission.VIEW_CHANNEL)) + throw new MissingAccessException(this, Permission.VIEW_CHANNEL); + } } diff --git a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildMessageChannelMixin.java b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildMessageChannelMixin.java index d9578d8eca2..ef4c6281efa 100644 --- a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildMessageChannelMixin.java +++ b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/GuildMessageChannelMixin.java @@ -108,21 +108,15 @@ default RestAction clearReactionsById(@Nonnull String messageId, @Nonnull @Override default MessageCreateAction sendStickers(@Nonnull Collection stickers) { - checkCanAccessChannel(); checkCanSendMessage(); Checks.notEmpty(stickers, "Stickers"); Checks.noneNull(stickers, "Stickers"); return new MessageCreateActionImpl(this).setStickers(stickers); } - // ---- Default implementation of parent mixins hooks ---- - default void checkCanAccessChannel() - { - checkPermission(Permission.VIEW_CHANNEL); - } - default void checkCanSendMessage() { + checkCanAccess(); if (getType().isThread()) checkPermission(Permission.MESSAGE_SEND_IN_THREADS); else @@ -131,32 +125,38 @@ default void checkCanSendMessage() default void checkCanSendMessageEmbeds() { + checkCanAccess(); checkPermission(Permission.MESSAGE_EMBED_LINKS); } default void checkCanSendFiles() { + checkCanAccess(); checkPermission(Permission.MESSAGE_ATTACH_FILES); } default void checkCanViewHistory() { + checkCanAccess(); checkPermission(Permission.MESSAGE_HISTORY); } default void checkCanAddReactions() { + checkCanAccess(); checkPermission(Permission.MESSAGE_ADD_REACTION); checkPermission(Permission.MESSAGE_HISTORY, "You need MESSAGE_HISTORY to add reactions to a message"); } default void checkCanRemoveReactions() { + checkCanAccess(); checkPermission(Permission.MESSAGE_HISTORY, "You need MESSAGE_HISTORY to remove reactions from a message"); } default void checkCanControlMessagePins() { + checkCanAccess(); checkPermission(Permission.MESSAGE_MANAGE, "You need MESSAGE_MANAGE to pin or unpin messages."); } diff --git a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/MessageChannelMixin.java b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/MessageChannelMixin.java index e2992ae8428..4268df91f1f 100644 --- a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/MessageChannelMixin.java +++ b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/middleman/MessageChannelMixin.java @@ -132,7 +132,6 @@ else if (!toDelete.isEmpty()) @CheckReturnValue default MessageCreateAction sendMessage(@Nonnull CharSequence text) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.sendMessage(text); } @@ -141,7 +140,6 @@ default MessageCreateAction sendMessage(@Nonnull CharSequence text) @CheckReturnValue default MessageCreateAction sendMessageEmbeds(@Nonnull MessageEmbed embed, @Nonnull MessageEmbed... other) { - checkCanAccessChannel(); checkCanSendMessage(); checkCanSendMessageEmbeds(); return MessageChannelUnion.super.sendMessageEmbeds(embed, other); @@ -151,7 +149,6 @@ default MessageCreateAction sendMessageEmbeds(@Nonnull MessageEmbed embed, @Nonn @CheckReturnValue default MessageCreateAction sendMessageEmbeds(@Nonnull Collection embeds) { - checkCanAccessChannel(); checkCanSendMessage(); checkCanSendMessageEmbeds(); return MessageChannelUnion.super.sendMessageEmbeds(embeds); @@ -161,7 +158,6 @@ default MessageCreateAction sendMessageEmbeds(@Nonnull Collection components) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.sendMessageComponents(components); } @@ -179,7 +174,6 @@ default MessageCreateAction sendMessageComponents(@Nonnull Collection files) { - checkCanAccessChannel(); checkCanSendMessage(); checkCanSendFiles(); return MessageChannelUnion.super.sendFiles(files); @@ -207,7 +199,6 @@ default MessageCreateAction sendFiles(@Nonnull Collection @CheckReturnValue default RestAction retrieveMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.retrieveMessageById(messageId); } @@ -216,7 +207,6 @@ default RestAction retrieveMessageById(@Nonnull String messageId) @CheckReturnValue default AuditableRestAction deleteMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); //We don't know if this is a Message sent by us or another user, so we can't run checks for Permission.MESSAGE_MANAGE return MessageChannelUnion.super.deleteMessageById(messageId); } @@ -225,7 +215,6 @@ default AuditableRestAction deleteMessageById(@Nonnull String messageId) @Override default MessageHistory getHistory() { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getHistory(); } @@ -234,7 +223,6 @@ default MessageHistory getHistory() @CheckReturnValue default MessagePaginationAction getIterableHistory() { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getIterableHistory(); } @@ -243,7 +231,6 @@ default MessagePaginationAction getIterableHistory() @CheckReturnValue default MessageHistory.MessageRetrieveAction getHistoryAround(@Nonnull String messageId, int limit) { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getHistoryAround(messageId, limit); } @@ -252,7 +239,6 @@ default MessageHistory.MessageRetrieveAction getHistoryAround(@Nonnull String me @CheckReturnValue default MessageHistory.MessageRetrieveAction getHistoryAfter(@Nonnull String messageId, int limit) { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getHistoryAfter(messageId, limit); } @@ -261,7 +247,6 @@ default MessageHistory.MessageRetrieveAction getHistoryAfter(@Nonnull String mes @CheckReturnValue default MessageHistory.MessageRetrieveAction getHistoryBefore(@Nonnull String messageId, int limit) { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getHistoryBefore(messageId, limit); } @@ -270,7 +255,6 @@ default MessageHistory.MessageRetrieveAction getHistoryBefore(@Nonnull String me @CheckReturnValue default MessageHistory.MessageRetrieveAction getHistoryFromBeginning(int limit) { - checkCanAccessChannel(); checkCanViewHistory(); return MessageHistory.getHistoryFromBeginning(this).limit(limit); } @@ -279,7 +263,6 @@ default MessageHistory.MessageRetrieveAction getHistoryFromBeginning(int limit) @CheckReturnValue default RestAction sendTyping() { - checkCanAccessChannel(); return MessageChannelUnion.super.sendTyping(); } @@ -287,7 +270,6 @@ default RestAction sendTyping() @CheckReturnValue default RestAction addReactionById(@Nonnull String messageId, @Nonnull Emoji emoji) { - checkCanAccessChannel(); checkCanAddReactions(); return MessageChannelUnion.super.addReactionById(messageId, emoji); } @@ -296,7 +278,6 @@ default RestAction addReactionById(@Nonnull String messageId, @Nonnull Emo @CheckReturnValue default RestAction removeReactionById(@Nonnull String messageId, @Nonnull Emoji emoji) { - checkCanAccessChannel(); checkCanRemoveReactions(); return MessageChannelUnion.super.removeReactionById(messageId, emoji); } @@ -305,7 +286,6 @@ default RestAction removeReactionById(@Nonnull String messageId, @Nonnull @CheckReturnValue default ReactionPaginationAction retrieveReactionUsersById(@Nonnull String messageId, @Nonnull Emoji emoji) { - checkCanAccessChannel(); checkCanRemoveReactions(); return MessageChannelUnion.super.retrieveReactionUsersById(messageId, emoji); } @@ -314,7 +294,6 @@ default ReactionPaginationAction retrieveReactionUsersById(@Nonnull String messa @CheckReturnValue default RestAction pinMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); checkCanControlMessagePins(); return MessageChannelUnion.super.pinMessageById(messageId); } @@ -323,7 +302,6 @@ default RestAction pinMessageById(@Nonnull String messageId) @CheckReturnValue default RestAction unpinMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); checkCanControlMessagePins(); return MessageChannelUnion.super.unpinMessageById(messageId); } @@ -332,7 +310,6 @@ default RestAction unpinMessageById(@Nonnull String messageId) @CheckReturnValue default RestAction> retrievePinnedMessages() { - checkCanAccessChannel(); return MessageChannelUnion.super.retrievePinnedMessages(); } @@ -340,7 +317,6 @@ default RestAction> retrievePinnedMessages() @CheckReturnValue default MessageEditAction editMessageById(@Nonnull String messageId, @Nonnull CharSequence newContent) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.editMessageById(messageId, newContent); } @@ -349,7 +325,6 @@ default MessageEditAction editMessageById(@Nonnull String messageId, @Nonnull Ch @CheckReturnValue default MessageEditAction editMessageById(@Nonnull String messageId, @Nonnull MessageEditData data) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.editMessageById(messageId, data); } @@ -359,7 +334,6 @@ default MessageEditAction editMessageById(@Nonnull String messageId, @Nonnull Me @CheckReturnValue default MessageEditAction editMessageEmbedsById(@Nonnull String messageId, @Nonnull Collection newEmbeds) { - checkCanAccessChannel(); checkCanSendMessage(); checkCanSendMessageEmbeds(); return MessageChannelUnion.super.editMessageEmbedsById(messageId, newEmbeds); @@ -369,7 +343,6 @@ default MessageEditAction editMessageEmbedsById(@Nonnull String messageId, @Nonn @CheckReturnValue default MessageEditAction editMessageComponentsById(@Nonnull String messageId, @Nonnull Collection components) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.editMessageComponentsById(messageId, components); } @@ -378,7 +351,6 @@ default MessageEditAction editMessageComponentsById(@Nonnull String messageId, @ @Override default MessageEditAction editMessageAttachmentsById(@Nonnull String messageId, @Nonnull Collection attachments) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.editMessageAttachmentsById(messageId, attachments); } @@ -386,8 +358,6 @@ default MessageEditAction editMessageAttachmentsById(@Nonnull String messageId, // ---- State Accessors ---- T setLatestMessageIdLong(long latestMessageId); - // ---- Mixin Hooks ---- - void checkCanAccessChannel(); void checkCanSendMessage(); void checkCanSendMessageEmbeds(); void checkCanSendFiles();