From 13d9fa87d8b072a8c06ad6916c506ed6868a0ce9 Mon Sep 17 00:00:00 2001 From: Michaili K <39029839+MichailiK@users.noreply.github.com> Date: Sun, 30 Jun 2019 14:54:42 +0200 Subject: [PATCH 1/6] Added ForceRemoveCmd --- .../java/com/jagrosh/jmusicbot/JMusicBot.java | 3 +- .../jmusicbot/commands/dj/ForceRemoveCmd.java | 63 +++++++++++++++++++ 2 files changed, 65 insertions(+), 1 deletion(-) create mode 100644 src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java diff --git a/src/main/java/com/jagrosh/jmusicbot/JMusicBot.java b/src/main/java/com/jagrosh/jmusicbot/JMusicBot.java index 3d9a8322e..de23e6ec6 100644 --- a/src/main/java/com/jagrosh/jmusicbot/JMusicBot.java +++ b/src/main/java/com/jagrosh/jmusicbot/JMusicBot.java @@ -112,7 +112,8 @@ public static void main(String[] args) new SCSearchCmd(bot, config.getSearching()), new ShuffleCmd(bot), new SkipCmd(bot), - + + new ForceRemoveCmd(bot), new ForceskipCmd(bot), new MoveTrackCmd(bot), new PauseCmd(bot), diff --git a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java new file mode 100644 index 000000000..1b3e5d0d0 --- /dev/null +++ b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java @@ -0,0 +1,63 @@ +package com.jagrosh.jmusicbot.commands.dj; + +import com.jagrosh.jdautilities.command.CommandEvent; +import com.jagrosh.jmusicbot.Bot; +import com.jagrosh.jmusicbot.audio.AudioHandler; +import com.jagrosh.jmusicbot.commands.MusicCommand; + + +public class ForceRemoveCmd extends MusicCommand { + public ForceRemoveCmd(Bot bot) { + super(bot); + this.name = "forceremove"; + this.help = "removes all entries by the mentioned user from the queue"; + this.arguments = "<@user|id>"; + this.aliases = new String[]{"forcedelete"}; + this.beListening = true; + this.bePlaying = true; + } + + @Override + public void doCommand(CommandEvent event) { + if (event.getArgs().isEmpty()) { + event.replyError("You need to mention a user!"); + } + + AudioHandler handler = (AudioHandler) event.getGuild().getAudioManager().getSendingHandler(); + if (handler.getQueue().isEmpty()) { + event.replyError("There is nothing in the queue!"); + return; + } + + long target = -1; + String args = event.getArgs(); + + if (args.startsWith("<@") && args.endsWith(">")) { + try { + target = Long.parseLong(args.substring(2, args.length() - 1)); + } catch (NumberFormatException ignored) {} + } else if (args.startsWith("<@!") && args.endsWith(">")) { + try { + target = Long.parseLong(args.substring(3, args.length() - 1)); + } catch (NumberFormatException ignored) {} + } else { + try { + target = Long.parseLong(args); + } catch (NumberFormatException ignored) { + event.replyError("You need to mention a user!"); + return; + } + } + if (target <= 0) { + event.replyError("You need to mention a user!"); + return; + } + + int count = handler.getQueue().removeAll(target); + if (count == 0) + event.replyWarning("This user doesn't have any songs in the queue!"); + else + event.replySuccess("Successfully removed their " + count + " entries."); + + } +} From 75abab2832e14c3eed382d069d9e90346323960a Mon Sep 17 00:00:00 2001 From: Michaili K <39029839+MichailiK@users.noreply.github.com> Date: Sun, 30 Jun 2019 19:09:43 +0200 Subject: [PATCH 2/6] Removed redundant code. --- .../com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java index 1b3e5d0d0..3d5fb551c 100644 --- a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java +++ b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java @@ -43,10 +43,7 @@ public void doCommand(CommandEvent event) { } else { try { target = Long.parseLong(args); - } catch (NumberFormatException ignored) { - event.replyError("You need to mention a user!"); - return; - } + } catch (NumberFormatException ignored) {} } if (target <= 0) { event.replyError("You need to mention a user!"); From bc85fb959726580832cdbe2f1affbfc69b92f8fd Mon Sep 17 00:00:00 2001 From: MichailiK <39029839+MichailiK@users.noreply.github.com> Date: Thu, 12 Sep 2019 14:44:13 +0200 Subject: [PATCH 3/6] Apply requested changes --- .../jmusicbot/commands/dj/ForceRemoveCmd.java | 74 +++++++++++-------- 1 file changed, 44 insertions(+), 30 deletions(-) diff --git a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java index 3d5fb551c..2ca3e6ea1 100644 --- a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java +++ b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java @@ -1,60 +1,74 @@ package com.jagrosh.jmusicbot.commands.dj; import com.jagrosh.jdautilities.command.CommandEvent; +import com.jagrosh.jdautilities.commons.utils.FinderUtil; import com.jagrosh.jmusicbot.Bot; import com.jagrosh.jmusicbot.audio.AudioHandler; -import com.jagrosh.jmusicbot.commands.MusicCommand; +import com.jagrosh.jmusicbot.commands.DJCommand; +import net.dv8tion.jda.core.entities.Member; +import net.dv8tion.jda.core.entities.User; +import java.util.List; -public class ForceRemoveCmd extends MusicCommand { - public ForceRemoveCmd(Bot bot) { + +public class ForceRemoveCmd extends DJCommand +{ + public ForceRemoveCmd(Bot bot) + { super(bot); this.name = "forceremove"; - this.help = "removes all entries by the mentioned user from the queue"; - this.arguments = "<@user|id>"; - this.aliases = new String[]{"forcedelete"}; - this.beListening = true; + this.help = "removes all entries by a user from the queue"; + this.arguments = ""; + this.aliases = new String[]{"forcedelete", "modremove", "moddelete"}; + this.beListening = false; this.bePlaying = true; } @Override - public void doCommand(CommandEvent event) { - if (event.getArgs().isEmpty()) { + public void doCommand(CommandEvent event) + { + if (event.getArgs().isEmpty()) + { event.replyError("You need to mention a user!"); + return; } AudioHandler handler = (AudioHandler) event.getGuild().getAudioManager().getSendingHandler(); - if (handler.getQueue().isEmpty()) { + if (handler.getQueue().isEmpty()) + { event.replyError("There is nothing in the queue!"); return; } - long target = -1; - String args = event.getArgs(); - - if (args.startsWith("<@") && args.endsWith(">")) { - try { - target = Long.parseLong(args.substring(2, args.length() - 1)); - } catch (NumberFormatException ignored) {} - } else if (args.startsWith("<@!") && args.endsWith(">")) { - try { - target = Long.parseLong(args.substring(3, args.length() - 1)); - } catch (NumberFormatException ignored) {} - } else { - try { - target = Long.parseLong(args); - } catch (NumberFormatException ignored) {} + + User target; + List found = FinderUtil.findMembers(event.getArgs(), event.getGuild()); + + if(found.isEmpty()) + { + event.replyError("Unable to find the user!"); + return; } - if (target <= 0) { - event.replyError("You need to mention a user!"); + else if(found.size()>1) + { + event.replyWarning("Found multiple users!"); return; } + else + { + target = found.get(0).getUser(); + } + - int count = handler.getQueue().removeAll(target); + int count = handler.getQueue().removeAll(target.getIdLong()); if (count == 0) - event.replyWarning("This user doesn't have any songs in the queue!"); + { + event.replyWarning(target.getName() + " doesn't have any songs in the queue!"); + } else - event.replySuccess("Successfully removed their " + count + " entries."); + { + event.replySuccess("Successfully removed `" + count + "` entries from **" + target.getName() + "**#" + target.getDiscriminator() + "."); + } } } From fbfea7ab1f1cf135601b6aecc04adc5efec9980e Mon Sep 17 00:00:00 2001 From: MichailiK <39029839+MichailiK@users.noreply.github.com> Date: Fri, 4 Oct 2019 17:19:11 +0200 Subject: [PATCH 4/6] Apply requested changes (Pass 2) --- .../jmusicbot/commands/dj/ForceRemoveCmd.java | 34 +++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java index 2ca3e6ea1..09446f647 100644 --- a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java +++ b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java @@ -2,6 +2,7 @@ import com.jagrosh.jdautilities.command.CommandEvent; import com.jagrosh.jdautilities.commons.utils.FinderUtil; +import com.jagrosh.jdautilities.menu.OrderedMenu; import com.jagrosh.jmusicbot.Bot; import com.jagrosh.jmusicbot.audio.AudioHandler; import com.jagrosh.jmusicbot.commands.DJCommand; @@ -51,7 +52,36 @@ public void doCommand(CommandEvent event) } else if(found.size()>1) { - event.replyWarning("Found multiple users!"); + OrderedMenu.Builder builder = new OrderedMenu.Builder(); + for(int i=0; i + { + User selectedUser = found.get(i-1).getUser(); + int count = handler.getQueue().removeAll(selectedUser.getIdLong()); + if (count == 0) + { + event.replyWarning("**"+selectedUser.getName()+"** doesn't have any songs in the queue!"); + } + else + { + event.replySuccess("Successfully removed `"+count+"` entries from **"+selectedUser.getName()+"**#"+selectedUser.getDiscriminator()+"."); + } + }) + .setText("Found multiple users:") + .setColor(event.getSelfMember().getColor()) + .useNumbers() + .setUsers(event.getAuthor()) + .useCancelButton(true) + .setCancel((msg) -> {}) + .setEventWaiter(bot.getWaiter()) + + .build().display(event.getChannel()); + return; } else @@ -67,7 +97,7 @@ else if(found.size()>1) } else { - event.replySuccess("Successfully removed `" + count + "` entries from **" + target.getName() + "**#" + target.getDiscriminator() + "."); + event.replySuccess("Successfully removed `"+count+"` entries from **"+target.getName()+"**#"+target.getDiscriminator()+"."); } } From e6f2b23ca926c284ebf9dd322c36788b7f0382f4 Mon Sep 17 00:00:00 2001 From: MichailiK <39029839+MichailiK@users.noreply.github.com> Date: Sat, 5 Oct 2019 10:30:59 +0200 Subject: [PATCH 5/6] Fix minor oversight --- .../java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java index 09446f647..7ef30e875 100644 --- a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java +++ b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java @@ -93,7 +93,7 @@ else if(found.size()>1) int count = handler.getQueue().removeAll(target.getIdLong()); if (count == 0) { - event.replyWarning(target.getName() + " doesn't have any songs in the queue!"); + event.replyWarning("**"+target.getName()+"** doesn't have any songs in the queue!"); } else { From d616c1e386b5247a15ee7fe5b88da1ff7d040b8e Mon Sep 17 00:00:00 2001 From: MichailiK <39029839+MichailiK@users.noreply.github.com> Date: Sat, 5 Oct 2019 19:37:19 +0200 Subject: [PATCH 6/6] Apply requested changes (Pass 3) --- .../jmusicbot/commands/dj/ForceRemoveCmd.java | 27 +++++++++---------- 1 file changed, 12 insertions(+), 15 deletions(-) diff --git a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java index 7ef30e875..69d90d0cc 100644 --- a/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java +++ b/src/main/java/com/jagrosh/jmusicbot/commands/dj/ForceRemoveCmd.java @@ -6,10 +6,12 @@ import com.jagrosh.jmusicbot.Bot; import com.jagrosh.jmusicbot.audio.AudioHandler; import com.jagrosh.jmusicbot.commands.DJCommand; +import net.dv8tion.jda.core.Permission; import net.dv8tion.jda.core.entities.Member; import net.dv8tion.jda.core.entities.User; import java.util.List; +import java.util.concurrent.TimeUnit; public class ForceRemoveCmd extends DJCommand @@ -23,6 +25,7 @@ public ForceRemoveCmd(Bot bot) this.aliases = new String[]{"forcedelete", "modremove", "moddelete"}; this.beListening = false; this.bePlaying = true; + this.botPermissions = new Permission[]{Permission.MESSAGE_EMBED_LINKS}; } @Override @@ -59,19 +62,8 @@ else if(found.size()>1) builder.addChoice("**"+member.getUser().getName()+"**#"+member.getUser().getDiscriminator()); } - builder.setSelection((msg, i) -> - { - User selectedUser = found.get(i-1).getUser(); - int count = handler.getQueue().removeAll(selectedUser.getIdLong()); - if (count == 0) - { - event.replyWarning("**"+selectedUser.getName()+"** doesn't have any songs in the queue!"); - } - else - { - event.replySuccess("Successfully removed `"+count+"` entries from **"+selectedUser.getName()+"**#"+selectedUser.getDiscriminator()+"."); - } - }) + builder + .setSelection((msg, i) -> removeAllEntries(found.get(i-1).getUser(), event)) .setText("Found multiple users:") .setColor(event.getSelfMember().getColor()) .useNumbers() @@ -79,6 +71,7 @@ else if(found.size()>1) .useCancelButton(true) .setCancel((msg) -> {}) .setEventWaiter(bot.getWaiter()) + .setTimeout(1, TimeUnit.MINUTES) .build().display(event.getChannel()); @@ -89,8 +82,13 @@ else if(found.size()>1) target = found.get(0).getUser(); } + removeAllEntries(target, event); + + } - int count = handler.getQueue().removeAll(target.getIdLong()); + private void removeAllEntries(User target, CommandEvent event) + { + int count = ((AudioHandler) event.getGuild().getAudioManager().getSendingHandler()).getQueue().removeAll(target.getIdLong()); if (count == 0) { event.replyWarning("**"+target.getName()+"** doesn't have any songs in the queue!"); @@ -99,6 +97,5 @@ else if(found.size()>1) { event.replySuccess("Successfully removed `"+count+"` entries from **"+target.getName()+"**#"+target.getDiscriminator()+"."); } - } }