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 57fc210aa9..fa303abf98 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 @@ -115,7 +115,7 @@ public boolean canTalk() } @Override - public void checkCanAccessChannel() {} + public void checkCanAccess() {} @Override public void checkCanSendMessage() { @@ -158,8 +158,6 @@ public PrivateChannelImpl setLatestMessageIdLong(long latestMessageId) return this; } - // -- Object -- - @Override public int hashCode() { 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 158da44ae9..5f28819a10 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/ChannelMixin.java b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/ChannelMixin.java index 7f24ef5e51..ea68d8dfdd 100644 --- a/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/ChannelMixin.java +++ b/src/main/java/net/dv8tion/jda/internal/entities/channel/mixin/ChannelMixin.java @@ -42,4 +42,7 @@ default RestAction delete() // ---- State Accessors ---- T setName(String name); + + // ---- Hooks ---- + void checkCanAccess(); } 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 90ccf18753..60b1e02b2e 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,14 @@ public interface AudioChannelMixin> T setUserLimit(int userlimit); T setRegion(String region); + + // AudioChannels also require connect permission to grant access + @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 c157e3a207..bd2825a1bb 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,11 @@ default void checkCanManage() { checkPermission(Permission.MANAGE_CHANNEL); } + + // Overridden by AudioChannelMixin + 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 d9578d8eca..c93ac2f481 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 @@ -46,6 +46,7 @@ public interface GuildMessageChannelMixin> @CheckReturnValue default RestAction deleteMessagesByIds(@Nonnull Collection messageIds) { + checkCanAccess(); checkPermission(Permission.MESSAGE_MANAGE, "Must have MESSAGE_MANAGE in order to bulk delete messages in this channel regardless of author."); if (messageIds.size() < 2 || messageIds.size() > 100) @@ -66,6 +67,7 @@ default RestAction removeReactionById(@Nonnull String messageId, @Nonnull Checks.notNull(emoji, "Emoji"); Checks.notNull(user, "User"); + checkCanAccess(); if (!getJDA().getSelfUser().equals(user)) checkPermission(Permission.MESSAGE_MANAGE); @@ -85,6 +87,7 @@ default RestAction clearReactionsById(@Nonnull String messageId) { Checks.isSnowflake(messageId, "Message ID"); + checkCanAccess(); checkPermission(Permission.MESSAGE_MANAGE); final Route.CompiledRoute route = Route.Messages.REMOVE_ALL_REACTIONS.compile(getId(), messageId); @@ -98,6 +101,7 @@ default RestAction clearReactionsById(@Nonnull String messageId, @Nonnull Checks.notNull(messageId, "Message ID"); Checks.notNull(emoji, "Emoji"); + checkCanAccess(); checkPermission(Permission.MESSAGE_MANAGE); Route.CompiledRoute route = Route.Messages.CLEAR_EMOJI_REACTIONS.compile(getId(), messageId, emoji.getAsReactionCode()); @@ -108,7 +112,6 @@ default RestAction clearReactionsById(@Nonnull String messageId, @Nonnull @Override default MessageCreateAction sendStickers(@Nonnull Collection stickers) { - checkCanAccessChannel(); checkCanSendMessage(); Checks.notEmpty(stickers, "Stickers"); Checks.noneNull(stickers, "Stickers"); @@ -116,13 +119,10 @@ default MessageCreateAction sendStickers(@Nonnull Collection> extends MessageChannel, - MessageChannelUnion + MessageChannelUnion, + ChannelMixin { // ---- Default implementations of interface ---- @Nonnull default List> purgeMessages(@Nonnull List messages) { + checkCanAccess(); if (messages == null || messages.isEmpty()) return Collections.emptyList(); @@ -80,6 +83,7 @@ default List> purgeMessages(@Nonnull List> purgeMessagesById(@Nonnull long... messageIds) { + checkCanAccess(); if (messageIds == null || messageIds.length == 0) return Collections.emptyList(); @@ -132,7 +136,6 @@ else if (!toDelete.isEmpty()) @CheckReturnValue default MessageCreateAction sendMessage(@Nonnull CharSequence text) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.sendMessage(text); } @@ -141,7 +144,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 +153,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 +162,6 @@ default MessageCreateAction sendMessageEmbeds(@Nonnull Collection components) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.sendMessageComponents(components); } @@ -179,7 +178,6 @@ default MessageCreateAction sendMessageComponents(@Nonnull Collection files) { - checkCanAccessChannel(); checkCanSendMessage(); checkCanSendFiles(); return MessageChannelUnion.super.sendFiles(files); @@ -207,7 +203,6 @@ default MessageCreateAction sendFiles(@Nonnull Collection @CheckReturnValue default RestAction retrieveMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.retrieveMessageById(messageId); } @@ -216,7 +211,7 @@ default RestAction retrieveMessageById(@Nonnull String messageId) @CheckReturnValue default AuditableRestAction deleteMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); + checkCanAccess(); //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 +220,6 @@ default AuditableRestAction deleteMessageById(@Nonnull String messageId) @Override default MessageHistory getHistory() { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getHistory(); } @@ -234,7 +228,6 @@ default MessageHistory getHistory() @CheckReturnValue default MessagePaginationAction getIterableHistory() { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getIterableHistory(); } @@ -243,7 +236,6 @@ default MessagePaginationAction getIterableHistory() @CheckReturnValue default MessageHistory.MessageRetrieveAction getHistoryAround(@Nonnull String messageId, int limit) { - checkCanAccessChannel(); checkCanViewHistory(); return MessageChannelUnion.super.getHistoryAround(messageId, limit); } @@ -252,7 +244,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 +252,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 +260,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 +268,7 @@ default MessageHistory.MessageRetrieveAction getHistoryFromBeginning(int limit) @CheckReturnValue default RestAction sendTyping() { - checkCanAccessChannel(); + checkCanAccess(); return MessageChannelUnion.super.sendTyping(); } @@ -287,7 +276,6 @@ default RestAction sendTyping() @CheckReturnValue default RestAction addReactionById(@Nonnull String messageId, @Nonnull Emoji emoji) { - checkCanAccessChannel(); checkCanAddReactions(); return MessageChannelUnion.super.addReactionById(messageId, emoji); } @@ -296,7 +284,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 +292,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 +300,6 @@ default ReactionPaginationAction retrieveReactionUsersById(@Nonnull String messa @CheckReturnValue default RestAction pinMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); checkCanControlMessagePins(); return MessageChannelUnion.super.pinMessageById(messageId); } @@ -323,7 +308,6 @@ default RestAction pinMessageById(@Nonnull String messageId) @CheckReturnValue default RestAction unpinMessageById(@Nonnull String messageId) { - checkCanAccessChannel(); checkCanControlMessagePins(); return MessageChannelUnion.super.unpinMessageById(messageId); } @@ -332,7 +316,7 @@ default RestAction unpinMessageById(@Nonnull String messageId) @CheckReturnValue default RestAction> retrievePinnedMessages() { - checkCanAccessChannel(); + checkCanAccess(); return MessageChannelUnion.super.retrievePinnedMessages(); } @@ -340,7 +324,6 @@ default RestAction> retrievePinnedMessages() @CheckReturnValue default MessageEditAction editMessageById(@Nonnull String messageId, @Nonnull CharSequence newContent) { - checkCanAccessChannel(); checkCanSendMessage(); return MessageChannelUnion.super.editMessageById(messageId, newContent); } @@ -349,7 +332,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 +341,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 +350,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 +358,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); } @@ -387,7 +366,6 @@ default MessageEditAction editMessageAttachmentsById(@Nonnull String messageId, T setLatestMessageIdLong(long latestMessageId); // ---- Mixin Hooks ---- - void checkCanAccessChannel(); void checkCanSendMessage(); void checkCanSendMessageEmbeds(); void checkCanSendFiles();