mirror of
https://github.com/TheDeus-Group/TFM-4.3-Reloaded.git
synced 2024-06-01 02:21:17 +00:00
bc722b3b7b
This should fix the memory leak I suspect.
160 lines
5.1 KiB
Java
160 lines
5.1 KiB
Java
package me.totalfreedom.totalfreedommod.command;
|
|
|
|
import com.google.common.collect.Lists;
|
|
import java.util.Collection;
|
|
import java.util.List;
|
|
import me.totalfreedom.totalfreedommod.config.ConfigEntry;
|
|
import me.totalfreedom.totalfreedommod.player.FPlayer;
|
|
import me.totalfreedom.totalfreedommod.blocking.PlayerBlocker;
|
|
import me.totalfreedom.totalfreedommod.rank.Rank;
|
|
import me.totalfreedom.totalfreedommod.util.FLog;
|
|
import me.totalfreedom.totalfreedommod.util.FUtil;
|
|
import org.apache.commons.lang3.StringUtils;
|
|
import org.bukkit.ChatColor;
|
|
import org.bukkit.command.Command;
|
|
import org.bukkit.command.CommandSender;
|
|
import org.bukkit.entity.Player;
|
|
|
|
@CommandPermissions(level = Rank.OP, source = SourceType.BOTH)
|
|
@CommandParameters(description = "Sets yourself a prefix", usage = "/<command> <set <tag> | off | clear <player> | clearall | list>")
|
|
public class Command_tag extends FreedomCommand
|
|
{
|
|
|
|
@Override
|
|
public boolean run(CommandSender sender, Player playerSender, Command cmd, String commandLabel, String[] args, boolean senderIsConsole)
|
|
{
|
|
|
|
if (args.length == 1)
|
|
{
|
|
if ("list".equalsIgnoreCase(args[0]))
|
|
{
|
|
msg("Tags for all online players:");
|
|
|
|
for (final Player player : server.getOnlinePlayers())
|
|
{
|
|
final FPlayer playerdata = plugin.pl.getPlayer(player);
|
|
if (playerdata.getTag() != null)
|
|
{
|
|
msg(player.getName() + ": " + playerdata.getTag());
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
else if ("clearall".equalsIgnoreCase(args[0]))
|
|
{
|
|
if (!plugin.al.isAdmin(sender))
|
|
{
|
|
noPerms();
|
|
return true;
|
|
}
|
|
|
|
FUtil.adminAction(sender.getName(), "Removing all tags", false);
|
|
|
|
int count = 0;
|
|
for (final Player player : server.getOnlinePlayers())
|
|
{
|
|
final FPlayer playerdata = plugin.pl.getPlayer(player);
|
|
if (playerdata.getTag() != null)
|
|
{
|
|
count++;
|
|
playerdata.setTag(null);
|
|
}
|
|
}
|
|
|
|
msg(count + " tag(s) removed.");
|
|
|
|
return true;
|
|
}
|
|
else if ("off".equalsIgnoreCase(args[0]))
|
|
{
|
|
if (senderIsConsole)
|
|
{
|
|
msg("\"/tag off\" can't be used from the console. Use \"/tag clear <player>\" or \"/tag clearall\" instead.");
|
|
}
|
|
else
|
|
{
|
|
plugin.pl.getPlayer(playerSender).setTag(null);
|
|
msg("Your tag has been removed.");
|
|
}
|
|
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
else if (args.length >= 2)
|
|
{
|
|
if ("clear".equalsIgnoreCase(args[0]))
|
|
{
|
|
if (!plugin.al.isAdmin(sender))
|
|
{
|
|
noPerms();
|
|
return true;
|
|
}
|
|
|
|
final Player player = getPlayer(args[1]);
|
|
|
|
if (player == null)
|
|
{
|
|
msg(FreedomCommand.PLAYER_NOT_FOUND);
|
|
return true;
|
|
}
|
|
|
|
plugin.pl.getPlayer(player).setTag(null);
|
|
msg("Removed " + player.getName() + "'s tag.");
|
|
|
|
return true;
|
|
}
|
|
else if ("set".equalsIgnoreCase(args[0]))
|
|
{
|
|
final String inputTag = StringUtils.join(args, " ", 1, args.length);
|
|
final String outputTag = FUtil.colorize(StringUtils.replaceEachRepeatedly(StringUtils.strip(inputTag),
|
|
new String[]
|
|
{
|
|
"" + ChatColor.COLOR_CHAR, "&k"
|
|
},
|
|
new String[]
|
|
{
|
|
"", ""
|
|
})) + ChatColor.RESET;
|
|
|
|
if (!plugin.al.isAdmin(sender))
|
|
{
|
|
final String rawTag = ChatColor.stripColor(outputTag).toLowerCase();
|
|
|
|
if (rawTag.length() > 20)
|
|
{
|
|
msg("That tag is too long (Max is 20 characters).");
|
|
return true;
|
|
}
|
|
|
|
for (String word : PlayerBlocker.blockedTags)
|
|
{
|
|
if (rawTag.contains(word))
|
|
{
|
|
msg("That tag contains a forbidden word.");
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
|
|
plugin.pl.getPlayer(playerSender).setTag(outputTag);
|
|
msg("Tag set to '" + outputTag + "'.");
|
|
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
}
|