TF-EssentialsX/Essentials/src/com/earth2me/essentials/commands/Commandsudo.java

62 lines
1.6 KiB
Java
Raw Normal View History

package com.earth2me.essentials.commands;
2012-03-12 15:35:20 +00:00
import static com.earth2me.essentials.I18n._;
import com.earth2me.essentials.User;
2012-09-08 20:10:26 +00:00
import java.util.logging.Level;
import java.util.logging.Logger;
import org.bukkit.Server;
import org.bukkit.command.CommandSender;
import org.bukkit.command.PluginCommand;
public class Commandsudo extends EssentialsCommand
{
public Commandsudo()
{
super("sudo");
}
2012-09-08 20:10:26 +00:00
private static final Logger LOGGER = Logger.getLogger("Minecraft");
@Override
public void run(final Server server, final CommandSender sender, final String commandLabel, final String[] args) throws Exception
{
if (args.length < 2)
{
throw new NotEnoughArgumentsException();
}
final User user = getPlayer(server, args, 0, false);
final String command = args[1];
final String[] arguments = new String[args.length - 2];
if (arguments.length > 0)
{
System.arraycopy(args, 2, arguments, 0, args.length - 2);
}
if (user.isAuthorized("essentials.sudo.exempt"))
{
2012-03-12 15:35:20 +00:00
throw new Exception(_("sudoExempt"));
}
2012-03-12 15:35:20 +00:00
sender.sendMessage(_("sudoRun", user.getDisplayName(), command, getFinalArg(arguments, 0)));
2011-11-18 19:30:05 +00:00
final PluginCommand execCommand = ess.getServer().getPluginCommand(command);
if (execCommand != null)
{
2012-09-08 20:10:26 +00:00
ess.scheduleSyncDelayedTask(
new Runnable()
{
@Override
public void run()
{
LOGGER.log(Level.INFO, String.format("[Sudo] %s issued server command: /%s %s", user.getName(), command, getFinalArg(arguments, 0)));
execCommand.execute(user.getBase(), command, arguments);
}
});
}
else {
sender.sendMessage(_("errorCallingCommand", command));
}
}
}