diff --git a/pom.xml b/pom.xml
index 7a48c4c9..8d102968 100644
--- a/pom.xml
+++ b/pom.xml
@@ -2,7 +2,7 @@
4.0.0
com.esophose.playerparticles
PlayerParticles
- 6.4
+ 6.5
PlayerParticles
https://github.com/Esophose/PlayerParticles
Display particles around your player and blocks using customized styles and data!
@@ -11,10 +11,19 @@
src
+ false
**/*.java
+ **/*.yml
+
+ src
+ true
+
+ **/*.yml
+
+
@@ -101,7 +110,7 @@
org.spigotmc
spigot-api
- 1.14-R0.1-SNAPSHOT
+ 1.14.3-R0.1-SNAPSHOT
diff --git a/src/com/esophose/playerparticles/command/AddCommandModule.java b/src/com/esophose/playerparticles/command/AddCommandModule.java
index 7426411f..96de0e68 100644
--- a/src/com/esophose/playerparticles/command/AddCommandModule.java
+++ b/src/com/esophose/playerparticles/command/AddCommandModule.java
@@ -203,4 +203,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/CommandModule.java b/src/com/esophose/playerparticles/command/CommandModule.java
index 44be4b25..0b699c9b 100644
--- a/src/com/esophose/playerparticles/command/CommandModule.java
+++ b/src/com/esophose/playerparticles/command/CommandModule.java
@@ -52,6 +52,11 @@ public interface CommandModule {
* @return If the player must have effects to use this command
*/
boolean requiresEffects();
+
+ /**
+ * @return true if this command can be executed from console, otherwise false
+ */
+ boolean canConsoleExecute();
/**
* Displays a command's usage to the player
diff --git a/src/com/esophose/playerparticles/command/DataCommandModule.java b/src/com/esophose/playerparticles/command/DataCommandModule.java
index ef64757e..94c1cfca 100644
--- a/src/com/esophose/playerparticles/command/DataCommandModule.java
+++ b/src/com/esophose/playerparticles/command/DataCommandModule.java
@@ -67,4 +67,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/DefaultCommandModule.java b/src/com/esophose/playerparticles/command/DefaultCommandModule.java
index 9eefee81..ea25d560 100644
--- a/src/com/esophose/playerparticles/command/DefaultCommandModule.java
+++ b/src/com/esophose/playerparticles/command/DefaultCommandModule.java
@@ -16,7 +16,7 @@ public void onCommandExecute(PPlayer pplayer, String[] args) {
}
public List onTabComplete(PPlayer pplayer, String[] args) {
- List matches = new ArrayList();
+ List matches = new ArrayList<>();
List commandNames = ParticleCommandHandler.getCommandNames();
if (args.length == 0) return commandNames;
@@ -42,4 +42,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/EditCommandModule.java b/src/com/esophose/playerparticles/command/EditCommandModule.java
index 17197c93..bf5f6f50 100644
--- a/src/com/esophose/playerparticles/command/EditCommandModule.java
+++ b/src/com/esophose/playerparticles/command/EditCommandModule.java
@@ -314,4 +314,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/EffectsCommandModule.java b/src/com/esophose/playerparticles/command/EffectsCommandModule.java
index 9f72d0d9..97424c39 100644
--- a/src/com/esophose/playerparticles/command/EffectsCommandModule.java
+++ b/src/com/esophose/playerparticles/command/EffectsCommandModule.java
@@ -53,4 +53,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/FixedCommandModule.java b/src/com/esophose/playerparticles/command/FixedCommandModule.java
index 2c649a0f..b678bd28 100644
--- a/src/com/esophose/playerparticles/command/FixedCommandModule.java
+++ b/src/com/esophose/playerparticles/command/FixedCommandModule.java
@@ -793,4 +793,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/GUICommandModule.java b/src/com/esophose/playerparticles/command/GUICommandModule.java
index 09976723..a00c3b4d 100644
--- a/src/com/esophose/playerparticles/command/GUICommandModule.java
+++ b/src/com/esophose/playerparticles/command/GUICommandModule.java
@@ -62,4 +62,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/GroupCommandModule.java b/src/com/esophose/playerparticles/command/GroupCommandModule.java
index 284b8361..56aaecba 100644
--- a/src/com/esophose/playerparticles/command/GroupCommandModule.java
+++ b/src/com/esophose/playerparticles/command/GroupCommandModule.java
@@ -315,4 +315,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/HelpCommandModule.java b/src/com/esophose/playerparticles/command/HelpCommandModule.java
index 001ea9f8..ab1fd8c0 100644
--- a/src/com/esophose/playerparticles/command/HelpCommandModule.java
+++ b/src/com/esophose/playerparticles/command/HelpCommandModule.java
@@ -38,4 +38,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/ListCommandModule.java b/src/com/esophose/playerparticles/command/ListCommandModule.java
index c202c11d..13110ee1 100644
--- a/src/com/esophose/playerparticles/command/ListCommandModule.java
+++ b/src/com/esophose/playerparticles/command/ListCommandModule.java
@@ -50,4 +50,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/ParticleCommandHandler.java b/src/com/esophose/playerparticles/command/ParticleCommandHandler.java
index bae25282..7451e5dd 100644
--- a/src/com/esophose/playerparticles/command/ParticleCommandHandler.java
+++ b/src/com/esophose/playerparticles/command/ParticleCommandHandler.java
@@ -4,6 +4,7 @@
import java.util.Arrays;
import java.util.List;
+import com.esophose.playerparticles.particles.OtherPPlayer;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
@@ -96,27 +97,32 @@ public static List getCommandNames() {
*/
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
if (cmd.getName().equalsIgnoreCase("pp")) {
- if (!(sender instanceof Player)) {
- sender.sendMessage(ChatColor.RED + "Error: This command can only be executed by a player.");
+ String commandName = args.length > 0 ? args[0] : "";
+ CommandModule commandModule = findMatchingCommand(commandName);
+ if (commandModule == null) {
+ sender.sendMessage(LangManager.getText(Lang.COMMAND_ERROR_UNKNOWN));
+ return true;
+ }
+
+ String[] cmdArgs = args.length > 1 ? Arrays.copyOfRange(args, 1, args.length) : new String[0];
+
+ if (!commandModule.canConsoleExecute()) {
+ if (!(sender instanceof Player)) {
+ sender.sendMessage(ChatColor.RED + "Error: This command can only be executed by a player.");
+ return true;
+ }
+ } else {
+ commandModule.onCommandExecute(new OtherPPlayer(sender), cmdArgs);
return true;
}
Player p = (Player) sender;
DataManager.getPPlayer(p.getUniqueId(), (pplayer) -> {
- String commandName = args.length > 0 ? args[0] : "";
- CommandModule commandModule = findMatchingCommand(commandName);
-
- if (commandModule != null) {
- if (commandModule.requiresEffects() && PermissionManager.getEffectNamesUserHasPermissionFor(p).isEmpty()) {
- LangManager.sendMessage(pplayer, Lang.COMMAND_ERROR_NO_EFFECTS);
- } else {
- String[] cmdArgs = new String[0];
- if (args.length > 1) cmdArgs = Arrays.copyOfRange(args, 1, args.length);
- commandModule.onCommandExecute(pplayer, cmdArgs);
- }
+ if (commandModule.requiresEffects() && PermissionManager.getEffectNamesUserHasPermissionFor(p).isEmpty()) {
+ LangManager.sendMessage(pplayer, Lang.COMMAND_ERROR_NO_EFFECTS);
} else {
- LangManager.sendMessage(pplayer, Lang.COMMAND_ERROR_UNKNOWN);
+ commandModule.onCommandExecute(pplayer, cmdArgs);
}
});
} else if (cmd.getName().equalsIgnoreCase("ppo")) {
diff --git a/src/com/esophose/playerparticles/command/ReloadCommandModule.java b/src/com/esophose/playerparticles/command/ReloadCommandModule.java
index 3e508595..84bb72bd 100644
--- a/src/com/esophose/playerparticles/command/ReloadCommandModule.java
+++ b/src/com/esophose/playerparticles/command/ReloadCommandModule.java
@@ -12,7 +12,7 @@
public class ReloadCommandModule implements CommandModule {
public void onCommandExecute(PPlayer pplayer, String[] args) {
- if (PermissionManager.canReloadPlugin(pplayer.getPlayer())) {
+ if (PermissionManager.canReloadPlugin(pplayer.getMessageDestination())) {
PlayerParticles.getPlugin().reload(false);
LangManager.sendMessage(pplayer, Lang.RELOAD_SUCCESS);
PlayerParticles.getPlugin().getLogger().info("Reloaded configuration.");
@@ -41,4 +41,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return true;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/RemoveCommandModule.java b/src/com/esophose/playerparticles/command/RemoveCommandModule.java
index 37711cbe..bac2b176 100644
--- a/src/com/esophose/playerparticles/command/RemoveCommandModule.java
+++ b/src/com/esophose/playerparticles/command/RemoveCommandModule.java
@@ -130,4 +130,8 @@ public boolean requiresEffects() {
return true;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/ResetCommandModule.java b/src/com/esophose/playerparticles/command/ResetCommandModule.java
index bc9137c2..21dcfb83 100644
--- a/src/com/esophose/playerparticles/command/ResetCommandModule.java
+++ b/src/com/esophose/playerparticles/command/ResetCommandModule.java
@@ -37,4 +37,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/StylesCommandModule.java b/src/com/esophose/playerparticles/command/StylesCommandModule.java
index 8c23803f..c9e7c783 100644
--- a/src/com/esophose/playerparticles/command/StylesCommandModule.java
+++ b/src/com/esophose/playerparticles/command/StylesCommandModule.java
@@ -48,4 +48,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/ToggleCommandModule.java b/src/com/esophose/playerparticles/command/ToggleCommandModule.java
index 8693dedb..09328042 100644
--- a/src/com/esophose/playerparticles/command/ToggleCommandModule.java
+++ b/src/com/esophose/playerparticles/command/ToggleCommandModule.java
@@ -41,4 +41,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/VersionCommandModule.java b/src/com/esophose/playerparticles/command/VersionCommandModule.java
index a2851c2c..df5ae835 100644
--- a/src/com/esophose/playerparticles/command/VersionCommandModule.java
+++ b/src/com/esophose/playerparticles/command/VersionCommandModule.java
@@ -37,4 +37,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/command/WorldsCommandModule.java b/src/com/esophose/playerparticles/command/WorldsCommandModule.java
index d225cde0..9fbc37f1 100644
--- a/src/com/esophose/playerparticles/command/WorldsCommandModule.java
+++ b/src/com/esophose/playerparticles/command/WorldsCommandModule.java
@@ -45,4 +45,8 @@ public boolean requiresEffects() {
return false;
}
+ public boolean canConsoleExecute() {
+ return false;
+ }
+
}
diff --git a/src/com/esophose/playerparticles/manager/DataManager.java b/src/com/esophose/playerparticles/manager/DataManager.java
index 2d0bcd5e..31aae354 100644
--- a/src/com/esophose/playerparticles/manager/DataManager.java
+++ b/src/com/esophose/playerparticles/manager/DataManager.java
@@ -1,14 +1,5 @@
package com.esophose.playerparticles.manager;
-import java.sql.PreparedStatement;
-import java.sql.ResultSet;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.UUID;
-
-import org.bukkit.Material;
-import org.bukkit.scheduler.BukkitRunnable;
-
import com.esophose.playerparticles.PlayerParticles;
import com.esophose.playerparticles.particles.FixedParticleEffect;
import com.esophose.playerparticles.particles.PPlayer;
@@ -19,6 +10,14 @@
import com.esophose.playerparticles.particles.ParticlePair;
import com.esophose.playerparticles.styles.api.ParticleStyle;
import com.esophose.playerparticles.util.ParticleUtils;
+import org.bukkit.Bukkit;
+import org.bukkit.Material;
+
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.UUID;
/**
* All data changes to PPlayers such as group or fixed effect changes must be done through here,
@@ -55,6 +54,7 @@ public static PPlayer getPPlayer(UUID playerUUID) {
* @param callback The callback to execute with the found pplayer, or a newly generated one
*/
public static void getPPlayer(UUID playerUUID, ConfigurationCallback callback) {
+
// Try to get them from cache first
PPlayer fromCache = getPPlayer(playerUUID);
if (fromCache != null) {
@@ -471,12 +471,8 @@ public static void removeFixedEffect(UUID playerUUID, int id) {
*
* @param asyncCallback The callback to run on a separate thread
*/
- private static void async(SyncInterface asyncCallback) {
- new BukkitRunnable() {
- public void run() {
- asyncCallback.execute();
- }
- }.runTaskAsynchronously(PlayerParticles.getPlugin());
+ private static void async(Runnable asyncCallback) {
+ Bukkit.getScheduler().runTaskAsynchronously(PlayerParticles.getPlugin(), asyncCallback);
}
/**
@@ -484,20 +480,8 @@ public void run() {
*
* @param syncCallback The callback to run on the main thread
*/
- private static void sync(SyncInterface syncCallback) {
- new BukkitRunnable() {
- public void run() {
- syncCallback.execute();
- }
- }.runTask(PlayerParticles.getPlugin());
- }
-
- /**
- * Provides an easy way to run a section of code either synchronously or asynchronously using a callback
- */
- @FunctionalInterface
- private interface SyncInterface {
- void execute();
+ private static void sync(Runnable syncCallback) {
+ Bukkit.getScheduler().runTask(PlayerParticles.getPlugin(), syncCallback);
}
/**
diff --git a/src/com/esophose/playerparticles/manager/PermissionManager.java b/src/com/esophose/playerparticles/manager/PermissionManager.java
index e9f89e62..5fb810df 100644
--- a/src/com/esophose/playerparticles/manager/PermissionManager.java
+++ b/src/com/esophose/playerparticles/manager/PermissionManager.java
@@ -12,6 +12,7 @@
import com.esophose.playerparticles.styles.DefaultStyles;
import com.esophose.playerparticles.styles.api.ParticleStyle;
import com.esophose.playerparticles.styles.api.ParticleStyleManager;
+import org.bukkit.permissions.Permissible;
public class PermissionManager {
@@ -42,24 +43,24 @@ private enum PPermission {
}
/**
- * Checks if a Player has a PlayerParticles permission
+ * Checks if a Permissible has a PlayerParticles permission
*
- * @param p The Player
+ * @param p The Permissible
* @return True if the Player has permission
*/
- public boolean check(Player p) {
+ public boolean check(Permissible p) {
String permission = PERMISSION_PREFIX + this.permissionString;
return p.hasPermission(permission);
}
/**
- * Checks if a Player has a PlayerParticles permission with a sub-permission
+ * Checks if a Permissible has a PlayerParticles permission with a sub-permission
*
- * @param p The Player
+ * @param p The Permissibhle
* @param subPermission The sub-permission
* @return True if the Player has permission
*/
- public boolean check(Player p, String subPermission) {
+ public boolean check(Permissible p, String subPermission) {
String permission = PERMISSION_PREFIX + this.permissionString + '.' + subPermission;
return p.hasPermission(permission);
}
@@ -77,7 +78,7 @@ private PermissionManager() {
*/
public static boolean canOverride(CommandSender sender) {
if (!(sender instanceof Player)) return true;
- return PPermission.ALL.check((Player)sender);
+ return PPermission.ALL.check(sender);
}
/**
@@ -286,11 +287,11 @@ public static boolean canClearFixedEffects(Player player) {
/**
* Checks if a player has permission to use /pp reload
*
- * @param player The player to check the permission for
- * @return True if the player has permission to reload the plugin's settings
+ * @param sender The sender to check the permission for
+ * @return True if the sender has permission to reload the plugin's settings
*/
- public static boolean canReloadPlugin(Player player) {
- return PPermission.ALL.check(player) || PPermission.RELOAD.check(player);
+ public static boolean canReloadPlugin(CommandSender sender) {
+ return PPermission.ALL.check(sender) || PPermission.RELOAD.check(sender);
}
}
diff --git a/src/com/esophose/playerparticles/particles/OtherPPlayer.java b/src/com/esophose/playerparticles/particles/OtherPPlayer.java
index dad10365..13550e7e 100644
--- a/src/com/esophose/playerparticles/particles/OtherPPlayer.java
+++ b/src/com/esophose/playerparticles/particles/OtherPPlayer.java
@@ -2,9 +2,18 @@
import org.bukkit.command.CommandSender;
+import java.util.ArrayList;
+import java.util.UUID;
+
public class OtherPPlayer extends PPlayer {
private CommandSender sender;
+
+ public OtherPPlayer(CommandSender sender) {
+ super(UUID.randomUUID(), new ArrayList<>(), new ArrayList<>(), false);
+
+ this.sender = sender;
+ }
public OtherPPlayer(CommandSender sender, PPlayer other) {
super(other.getUniqueId(), other.getParticleGroups(), other.getFixedParticles(), !other.canSeeParticles());
diff --git a/src/com/esophose/playerparticles/particles/ParticleEffect.java b/src/com/esophose/playerparticles/particles/ParticleEffect.java
index 7b334d68..18c48e54 100644
--- a/src/com/esophose/playerparticles/particles/ParticleEffect.java
+++ b/src/com/esophose/playerparticles/particles/ParticleEffect.java
@@ -88,7 +88,7 @@ public enum ParticleEffect {
UNDERWATER("SUSPENDED_DEPTH", "SUSPENDED_DEPTH"),
WITCH("SPELL_WITCH", "SPELL_WTICH");
- public static boolean VERSION_13; // This is a particle unique to Minecraft 1.13, this is a reliable way of telling what server version is running
+ public static boolean VERSION_13;
private static final Map NAME_MAP = new HashMap<>();
private static Constructor> DustOptions_CONSTRUCTOR;
private static Method createBlockData_METHOD;
diff --git a/src/config.yml b/src/config.yml
index 16bbd5ba..71c0694d 100644
--- a/src/config.yml
+++ b/src/config.yml
@@ -13,7 +13,7 @@
# This value is the version of the plugin that last modified the config file
# Changing this value manually will likely result in data loss and errors!
# Do not change this manually unless specifically told to by the plugin author
-version: 6.4
+version: ${project.version}
# Check for new versions of the plugin
# Default: true
diff --git a/src/plugin.yml b/src/plugin.yml
index e9caf965..4aae68dd 100644
--- a/src/plugin.yml
+++ b/src/plugin.yml
@@ -1,6 +1,6 @@
name: PlayerParticles
main: com.esophose.playerparticles.PlayerParticles
-version: 6.4
+version: ${project.version}
api-version: 1.13
description: Display particles around your player and blocks using customized styles and data!
author: Esophose