Require a player be specified when using /papi parse command

This commit is contained in:
extendedclip 2018-06-14 15:17:46 -04:00
parent 46839c4bf2
commit e4a672e57e

View File

@ -20,238 +20,246 @@
*/ */
package me.clip.placeholderapi.commands; package me.clip.placeholderapi.commands;
import java.util.Set;
import me.clip.placeholderapi.PlaceholderAPI; import me.clip.placeholderapi.PlaceholderAPI;
import me.clip.placeholderapi.PlaceholderAPIPlugin; import me.clip.placeholderapi.PlaceholderAPIPlugin;
import me.clip.placeholderapi.expansion.PlaceholderExpansion; import me.clip.placeholderapi.expansion.PlaceholderExpansion;
import me.clip.placeholderapi.util.Msg; import me.clip.placeholderapi.util.Msg;
import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.StringUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.OfflinePlayer;
import org.bukkit.command.Command; import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import java.util.Set;
public class PlaceholderAPICommands implements CommandExecutor { public class PlaceholderAPICommands implements CommandExecutor {
private PlaceholderAPIPlugin plugin; private PlaceholderAPIPlugin plugin;
private CommandExecutor eCloud; private CommandExecutor eCloud;
public PlaceholderAPICommands(PlaceholderAPIPlugin i) { public PlaceholderAPICommands(PlaceholderAPIPlugin i) {
plugin = i; plugin = i;
eCloud = new ExpansionCloudCommands(i); eCloud = new ExpansionCloudCommands(i);
} }
@Override @Override
public boolean onCommand(CommandSender s, Command c, String label, String[] args) { public boolean onCommand(CommandSender s, Command c, String label, String[] args) {
if (args.length == 0) { if (args.length == 0) {
Msg.msg(s, "PlaceholderAPI &7version &b&o" + plugin.getDescription().getVersion(), Msg.msg(s, "PlaceholderAPI &7version &b&o" + plugin.getDescription().getVersion(),
"&fCreated by&7: &bextended_clip"); "&fCreated by&7: &bextended_clip");
return true; return true;
} else { } else {
if (args[0].equalsIgnoreCase("help")) { if (args[0].equalsIgnoreCase("help")) {
Msg.msg(s, "PlaceholderAPI &aHelp &e(&f" + plugin.getDescription().getVersion() + "&e)", Msg.msg(s, "PlaceholderAPI &aHelp &e(&f" + plugin.getDescription().getVersion() + "&e)",
"&b/papi", "&b/papi",
"&fView plugin info/version info", "&fView plugin info/version info",
"&b/papi list", "&b/papi list",
"&fList all placeholder expansions that are currently active", "&fList all placeholder expansions that are currently active",
"&b/papi info <placeholder name>", "&b/papi info <placeholder name>",
"&fView information for a specific expansion", "&fView information for a specific expansion",
"&b/papi parse <...args>", "&b/papi parse <(playername)/me> <...args>",
"&fParse a String with placeholders", "&fParse a String with placeholders",
"&b/papi parserel <player one> <player two> <...args>", "&b/papi parserel <player one> <player two> <...args>",
"&fParse a String with relational placeholders", "&fParse a String with relational placeholders",
"&b/papi reload", "&b/papi reload",
"&fReload the config settings"); "&fReload the config settings");
if (s.hasPermission("placeholderapi.ecloud")) { if (s.hasPermission("placeholderapi.ecloud")) {
if (plugin.getExpansionCloud() == null) { if (plugin.getExpansionCloud() == null) {
Msg.msg(s, "&b/papi enablecloud", Msg.msg(s, "&b/papi enablecloud",
"&fEnable the expansion cloud"); "&fEnable the expansion cloud");
} else { } else {
Msg.msg(s, "&b/papi disablecloud", Msg.msg(s, "&b/papi disablecloud",
"&fDisable the expansion cloud", "&fDisable the expansion cloud",
"&b/papi ecloud", "&b/papi ecloud",
"&fView ecloud command usage"); "&fView ecloud command usage");
} }
} }
return true; return true;
} else if (args[0].equalsIgnoreCase("ecloud")) { } else if (args[0].equalsIgnoreCase("ecloud")) {
if (!s.hasPermission("placeholderapi.ecloud")) { if (!s.hasPermission("placeholderapi.ecloud")) {
Msg.msg(s, "&cYou don't have permission to do that!"); Msg.msg(s, "&cYou don't have permission to do that!");
return true; return true;
} }
if (plugin.getExpansionCloud() == null) { if (plugin.getExpansionCloud() == null) {
Msg.msg(s, "&7The expansion cloud is not enabled!"); Msg.msg(s, "&7The expansion cloud is not enabled!");
return true; return true;
} }
return eCloud.onCommand(s, c, label, args); return eCloud.onCommand(s, c, label, args);
} else if (args[0].equalsIgnoreCase("enablecloud")) { } else if (args[0].equalsIgnoreCase("enablecloud")) {
if (!s.hasPermission("placeholderapi.ecloud")) { if (!s.hasPermission("placeholderapi.ecloud")) {
Msg.msg(s, "&cYou don't have permission to do that!"); Msg.msg(s, "&cYou don't have permission to do that!");
return true; return true;
} }
if (plugin.getExpansionCloud() != null) { if (plugin.getExpansionCloud() != null) {
Msg.msg(s, "&7The cloud is already enabled!"); Msg.msg(s, "&7The cloud is already enabled!");
return true; return true;
} }
plugin.enableCloud(); plugin.enableCloud();
plugin.getPlaceholderAPIConfig().setCloudEnabled(true); plugin.getPlaceholderAPIConfig().setCloudEnabled(true);
Msg.msg(s, "&aThe cloud has been enabled!"); Msg.msg(s, "&aThe cloud has been enabled!");
return true; return true;
} else if (args[0].equalsIgnoreCase("disablecloud")) { } else if (args[0].equalsIgnoreCase("disablecloud")) {
if (!s.hasPermission("placeholderapi.ecloud")) { if (!s.hasPermission("placeholderapi.ecloud")) {
Msg.msg(s, "&cYou don't have permission to do that!"); Msg.msg(s, "&cYou don't have permission to do that!");
return true; return true;
} }
if (plugin.getExpansionCloud() == null) { if (plugin.getExpansionCloud() == null) {
Msg.msg(s, "&7The cloud is already disabled!"); Msg.msg(s, "&7The cloud is already disabled!");
return true; return true;
} }
plugin.disableCloud(); plugin.disableCloud();
plugin.getPlaceholderAPIConfig().setCloudEnabled(false); plugin.getPlaceholderAPIConfig().setCloudEnabled(false);
Msg.msg(s, "&aThe cloud has been disabled!"); Msg.msg(s, "&aThe cloud has been disabled!");
return true; return true;
} else if (args.length > 1 && args[0].equalsIgnoreCase("info")) { } else if (args.length > 1 && args[0].equalsIgnoreCase("info")) {
if (!s.hasPermission("placeholderapi.info")) { if (!s.hasPermission("placeholderapi.info")) {
Msg.msg(s, "&cYou don't have permission to do that!"); Msg.msg(s, "&cYou don't have permission to do that!");
return true; return true;
} }
PlaceholderExpansion ex = plugin.getExpansionManager().getRegisteredExpansion(args[1]); PlaceholderExpansion ex = plugin.getExpansionManager().getRegisteredExpansion(args[1]);
if (ex == null) { if (ex == null) {
Msg.msg(s, "&cThere is no expansion loaded with the identifier: &f" + args[1]); Msg.msg(s, "&cThere is no expansion loaded with the identifier: &f" + args[1]);
return true; return true;
} }
Msg.msg(s, "&7Placeholder expansion info for: &f" + ex.getName()); Msg.msg(s, "&7Placeholder expansion info for: &f" + ex.getName());
Msg.msg(s, "&7Status: " + (ex.isRegistered() ? "&aRegistered" : "&cNot registered")); Msg.msg(s, "&7Status: " + (ex.isRegistered() ? "&aRegistered" : "&cNot registered"));
if (ex.getAuthor() != null) { if (ex.getAuthor() != null) {
Msg.msg(s, "&7Created by: &f" + ex.getAuthor()); Msg.msg(s, "&7Created by: &f" + ex.getAuthor());
} }
if (ex.getVersion() != null) { if (ex.getVersion() != null) {
Msg.msg(s, "&7Version: &f" + ex.getVersion()); Msg.msg(s, "&7Version: &f" + ex.getVersion());
} }
if (ex.getRequiredPlugin() != null) { if (ex.getRequiredPlugin() != null) {
Msg.msg(s, "&7Requires plugin: &f" + ex.getRequiredPlugin()); Msg.msg(s, "&7Requires plugin: &f" + ex.getRequiredPlugin());
} }
if (ex.getPlaceholders() != null) { if (ex.getPlaceholders() != null) {
Msg.msg(s, "&8&m-- &r&7Placeholders &8&m--"); Msg.msg(s, "&8&m-- &r&7Placeholders &8&m--");
for (String placeholder : ex.getPlaceholders()) { for (String placeholder : ex.getPlaceholders()) {
Msg.msg(s, placeholder); Msg.msg(s, placeholder);
} }
} }
return true; return true;
} else if (args.length > 1 && args[0].equalsIgnoreCase("parse")) { } else if (args.length > 2 && args[0].equalsIgnoreCase("parse")) {
if (!(s instanceof Player)) { if (!(s instanceof Player)) {
Msg.msg(s, "&cThis command can only be used in game!"); Msg.msg(s, "&cThis command can only be used in game!");
return true; return true;
} else { } else {
if (!s.hasPermission("placeholderapi.parse")) { if (!s.hasPermission("placeholderapi.parse")) {
Msg.msg(s, "&cYou don't have permission to do that!"); Msg.msg(s, "&cYou don't have permission to do that!");
return true; return true;
} }
} }
Player p = (Player) s; OfflinePlayer pl = null;
String parse = StringUtils.join(args, " ", 1, args.length); if (args[1].equalsIgnoreCase("me")) {
pl = ((Player) s).getPlayer();
} else {
pl = Bukkit.getOfflinePlayer(args[1]);
}
Msg.msg(s, "&r" + PlaceholderAPI.setPlaceholders(p, parse)); if (pl == null || !pl.hasPlayedBefore()) {
Msg.msg(s, "&cFailed to find player: &f" + args[1]);
return true;
}
String parse = StringUtils.join(args, " ", 2, args.length);
Msg.msg(s, "&r" + PlaceholderAPI.setPlaceholders(pl, parse));
return true;
} else if (args.length > 3 && args[0].equalsIgnoreCase("parserel")) {
return true; if (!(s instanceof Player)) {
} else if (args.length > 3 && args[0].equalsIgnoreCase("parserel")) { Msg.msg(s, "&cThis command can only be used in game!");
return true;
} else {
if (!s.hasPermission("placeholderapi.parse")) {
Msg.msg(s, "&cYou don't have permission to do that!");
return true;
}
}
if (!(s instanceof Player)) { Player one = Bukkit.getPlayer(args[1]);
Msg.msg(s, "&cThis command can only be used in game!"); if (one == null) {
return true; Msg.msg(s, args[1] + " &cis not online!");
} else { return true;
if (!s.hasPermission("placeholderapi.parse")) { }
Msg.msg(s, "&cYou don't have permission to do that!");
return true;
}
}
Player one = Bukkit.getPlayer(args[1]); Player two = Bukkit.getPlayer(args[2]);
if (one == null) {
Msg.msg(s, args[1] + " &cis not online!");
return true;
}
Player two = Bukkit.getPlayer(args[2]); if (two == null) {
Msg.msg(s, args[2] + " &cis not online!");
return true;
}
if (two == null) { String parse = StringUtils.join(args, " ", 3, args.length);
Msg.msg(s, args[2] + " &cis not online!");
return true;
}
String parse = StringUtils.join(args, " ", 3, args.length); Msg.msg(s, "&r" + PlaceholderAPI.setRelationalPlaceholders(one, two, parse));
Msg.msg(s, "&r" + PlaceholderAPI.setRelationalPlaceholders(one, two, parse)); return true;
} else if (args[0].equalsIgnoreCase("reload")) {
return true; if (s instanceof Player) {
} else if (args[0].equalsIgnoreCase("reload")) { if (!s.hasPermission("placeholderapi.reload")) {
Msg.msg(s, "&cYou don't have permission to do that!");
return true;
}
}
if (s instanceof Player) { Msg.msg(s, "&fPlaceholder&7API &bconfiguration reloaded!");
if (!s.hasPermission("placeholderapi.reload")) {
Msg.msg(s, "&cYou don't have permission to do that!");
return true;
}
}
Msg.msg(s, "&fPlaceholder&7API &bconfiguration reloaded!"); plugin.reloadConf(s);
plugin.reloadConf(s); } else if (args[0].equalsIgnoreCase("list")) {
} else if (args[0].equalsIgnoreCase("list")) { if (s instanceof Player) {
if (!s.hasPermission("placeholderapi.list")) {
Msg.msg(s, "&cYou don't have permission to do that!");
return true;
}
}
if (s instanceof Player) { Set<String> registered = PlaceholderAPI.getRegisteredIdentifiers();
if (!s.hasPermission("placeholderapi.list")) {
Msg.msg(s, "&cYou don't have permission to do that!");
return true;
}
}
Set<String> registered = PlaceholderAPI.getRegisteredIdentifiers(); if (registered.isEmpty()) {
Msg.msg(s, "&7There are no placeholder hooks currently registered!");
return true;
}
Msg.msg(s, registered.size() + " &7Placeholder hooks registered:");
Msg.msg(s, registered.toString());
} else {
Msg.msg(s, "&cIncorrect usage! &7/papi help");
}
}
if (registered.isEmpty()) { return true;
Msg.msg(s, "&7There are no placeholder hooks currently registered!"); }
return true;
}
Msg.msg(s, registered.size()+" &7Placeholder hooks registered:");
Msg.msg(s, registered.toString());
} else {
Msg.msg(s, "&cIncorrect usage! &7/papi help");
}
}
return true;
}
} }