mirror of
https://github.com/TheDeus-Group/TFM-4.3-Reloaded.git
synced 2024-05-29 11:41:18 +00:00
4988140268
Doesn't make much sense to use string concatenation and a String.format to generate the same output. I believe this method is much more readable.
99 lines
3.3 KiB
Java
99 lines
3.3 KiB
Java
package me.StevenLawson.TotalFreedomMod.Commands;
|
|
|
|
import me.StevenLawson.TotalFreedomMod.Bridge.TFM_WorldEditBridge;
|
|
import me.StevenLawson.TotalFreedomMod.TFM_Ban;
|
|
import me.StevenLawson.TotalFreedomMod.TFM_BanManager;
|
|
import me.StevenLawson.TotalFreedomMod.TFM_RollbackManager;
|
|
import me.StevenLawson.TotalFreedomMod.TFM_Util;
|
|
import me.StevenLawson.TotalFreedomMod.TotalFreedomMod;
|
|
import net.minecraft.util.org.apache.commons.lang3.ArrayUtils;
|
|
import net.minecraft.util.org.apache.commons.lang3.StringUtils;
|
|
import org.bukkit.ChatColor;
|
|
import org.bukkit.GameMode;
|
|
import org.bukkit.Location;
|
|
import org.bukkit.command.Command;
|
|
import org.bukkit.command.CommandSender;
|
|
import org.bukkit.entity.Player;
|
|
|
|
@CommandPermissions(level = AdminLevel.SUPER, source = SourceType.BOTH)
|
|
@CommandParameters(description = "Makes someone GTFO (deop and ip ban by username).", usage = "/<command> <partialname>")
|
|
public class Command_gtfo extends TFM_Command
|
|
{
|
|
@Override
|
|
public boolean run(CommandSender sender, Player sender_p, Command cmd, String commandLabel, String[] args, boolean senderIsConsole)
|
|
{
|
|
if (args.length == 0)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
final Player player = getPlayer(args[0]);
|
|
|
|
if (player == null)
|
|
{
|
|
playerMsg(TotalFreedomMod.PLAYER_NOT_FOUND, ChatColor.RED);
|
|
return true;
|
|
}
|
|
|
|
String reason = null;
|
|
if (args.length >= 2)
|
|
{
|
|
reason = StringUtils.join(ArrayUtils.subarray(args, 1, args.length), " ");
|
|
}
|
|
|
|
TFM_Util.bcastMsg(player.getName() + " has been a VERY naughty, naughty boy.", ChatColor.RED);
|
|
|
|
// Undo WorldEdits:
|
|
try
|
|
{
|
|
TFM_WorldEditBridge.undo(player, 15);
|
|
}
|
|
catch (NoClassDefFoundError ex)
|
|
{
|
|
}
|
|
|
|
// rollback
|
|
TFM_RollbackManager.rollback(player.getName());
|
|
|
|
// deop
|
|
player.setOp(false);
|
|
|
|
// set gamemode to survival:
|
|
player.setGameMode(GameMode.SURVIVAL);
|
|
|
|
// clear inventory:
|
|
player.getInventory().clear();
|
|
|
|
// strike with lightning effect:
|
|
final Location targetPos = player.getLocation();
|
|
for (int x = -1; x <= 1; x++)
|
|
{
|
|
for (int z = -1; z <= 1; z++)
|
|
{
|
|
final Location strike_pos = new Location(targetPos.getWorld(), targetPos.getBlockX() + x, targetPos.getBlockY(), targetPos.getBlockZ() + z);
|
|
targetPos.getWorld().strikeLightning(strike_pos);
|
|
}
|
|
}
|
|
|
|
// ban IP address:
|
|
String ip = TFM_Util.getFuzzyIp(player.getAddress().getAddress().getHostAddress());
|
|
|
|
final StringBuilder bcast = new StringBuilder("Banning: ").append(player.getName()).append(", IP: ").append(ip);
|
|
if (reason != null)
|
|
{
|
|
bcast.append(ChatColor.RED).append(" - Reason: ").append(ChatColor.YELLOW).append(reason);
|
|
}
|
|
TFM_Util.bcastMsg(bcast.toString());
|
|
|
|
TFM_BanManager.addIpBan(new TFM_Ban(ip, player.getName(), sender.getName(), null, reason));
|
|
|
|
// ban username:
|
|
TFM_BanManager.addUuidBan(new TFM_Ban(TFM_Util.getUuid(player), player.getName(), sender.getName(), null, reason));
|
|
|
|
// kick Player:
|
|
player.kickPlayer(ChatColor.RED + "GTFO" + (reason != null ? ("\nReason: " + ChatColor.YELLOW + reason) : ""));
|
|
|
|
return true;
|
|
}
|
|
}
|