mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-08 00:38:27 +01:00
Further changes to logging and actions
This commit is contained in:
parent
6d9675cb6a
commit
7930bcb81d
@ -1,13 +1,15 @@
|
|||||||
package cc.co.evenprime.bukkit.nocheat.log;
|
package cc.co.evenprime.bukkit.nocheat;
|
||||||
|
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Somehow manage color codes in NoCheat
|
* Somehow manage color codes in NoCheat
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class Colors {
|
public class Colors {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Replace instances of &X with a color
|
* Replace instances of &X with a color
|
||||||
*
|
*
|
||||||
@ -22,4 +24,19 @@ public class Colors {
|
|||||||
|
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove instances of &X with a color
|
||||||
|
*
|
||||||
|
* @param text
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static String removeColors(String text) {
|
||||||
|
|
||||||
|
for(ChatColor c : ChatColor.values()) {
|
||||||
|
text = text.replace("&" + c.getChar(), "");
|
||||||
|
}
|
||||||
|
|
||||||
|
return text;
|
||||||
|
}
|
||||||
}
|
}
|
@ -15,6 +15,7 @@ import org.bukkit.event.EventPriority;
|
|||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.plugin.PluginDescriptionFile;
|
import org.bukkit.plugin.PluginDescriptionFile;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import cc.co.evenprime.bukkit.nocheat.checks.WorkaroundsListener;
|
||||||
import cc.co.evenprime.bukkit.nocheat.checks.blockbreak.BlockBreakCheckListener;
|
import cc.co.evenprime.bukkit.nocheat.checks.blockbreak.BlockBreakCheckListener;
|
||||||
import cc.co.evenprime.bukkit.nocheat.checks.blockplace.BlockPlaceCheckListener;
|
import cc.co.evenprime.bukkit.nocheat.checks.blockplace.BlockPlaceCheckListener;
|
||||||
import cc.co.evenprime.bukkit.nocheat.checks.chat.ChatCheckListener;
|
import cc.co.evenprime.bukkit.nocheat.checks.chat.ChatCheckListener;
|
||||||
@ -28,8 +29,6 @@ import cc.co.evenprime.bukkit.nocheat.config.Permissions;
|
|||||||
import cc.co.evenprime.bukkit.nocheat.data.PlayerManager;
|
import cc.co.evenprime.bukkit.nocheat.data.PlayerManager;
|
||||||
import cc.co.evenprime.bukkit.nocheat.debug.ActiveCheckPrinter;
|
import cc.co.evenprime.bukkit.nocheat.debug.ActiveCheckPrinter;
|
||||||
import cc.co.evenprime.bukkit.nocheat.debug.LagMeasureTask;
|
import cc.co.evenprime.bukkit.nocheat.debug.LagMeasureTask;
|
||||||
import cc.co.evenprime.bukkit.nocheat.events.WorkaroundsEventManager;
|
|
||||||
import cc.co.evenprime.bukkit.nocheat.log.NoCheatLogEvent;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@ -83,7 +82,7 @@ public class NoCheat extends JavaPlugin implements Listener {
|
|||||||
eventManagers = new ArrayList<EventManager>(8); // Big enough
|
eventManagers = new ArrayList<EventManager>(8); // Big enough
|
||||||
// Then set up the event listeners
|
// Then set up the event listeners
|
||||||
eventManagers.add(new MovingCheckListener(this));
|
eventManagers.add(new MovingCheckListener(this));
|
||||||
eventManagers.add(new WorkaroundsEventManager(this));
|
eventManagers.add(new WorkaroundsListener(this));
|
||||||
eventManagers.add(new ChatCheckListener(this));
|
eventManagers.add(new ChatCheckListener(this));
|
||||||
eventManagers.add(new BlockBreakCheckListener(this));
|
eventManagers.add(new BlockBreakCheckListener(this));
|
||||||
eventManagers.add(new BlockPlaceCheckListener(this));
|
eventManagers.add(new BlockPlaceCheckListener(this));
|
||||||
@ -197,18 +196,20 @@ public class NoCheat extends JavaPlugin implements Listener {
|
|||||||
@EventHandler(priority = EventPriority.MONITOR)
|
@EventHandler(priority = EventPriority.MONITOR)
|
||||||
public void logEvent(NoCheatLogEvent event) {
|
public void logEvent(NoCheatLogEvent event) {
|
||||||
if(event.toConsole()) {
|
if(event.toConsole()) {
|
||||||
System.out.println(event.getPrefix() + event.getMessage());
|
// Console logs are not colored
|
||||||
|
System.out.println(Colors.removeColors(event.getPrefix() + event.getMessage()));
|
||||||
}
|
}
|
||||||
if(event.toChat()) {
|
if(event.toChat()) {
|
||||||
for(Player player : Bukkit.getServer().getOnlinePlayers()) {
|
for(Player player : Bukkit.getServer().getOnlinePlayers()) {
|
||||||
if(player.hasPermission(Permissions.ADMIN_CHATLOG)) {
|
if(player.hasPermission(Permissions.ADMIN_CHATLOG)) {
|
||||||
player.sendMessage(event.getPrefix() + event.getMessage());
|
// Chat logs are potentially colored
|
||||||
|
player.sendMessage(Colors.replaceColors(event.getPrefix() + event.getMessage()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(event.toFile()) {
|
if(event.toFile()) {
|
||||||
fileLogger.info(event.getMessage());
|
// File logs are not colored
|
||||||
System.out.println("fileend");
|
fileLogger.info(Colors.removeColors(event.getMessage()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package cc.co.evenprime.bukkit.nocheat.log;
|
package cc.co.evenprime.bukkit.nocheat;
|
||||||
|
|
||||||
import org.bukkit.event.Event;
|
import org.bukkit.event.Event;
|
||||||
import org.bukkit.event.HandlerList;
|
import org.bukkit.event.HandlerList;
|
||||||
@ -23,6 +23,10 @@ public class NoCheatLogEvent extends Event {
|
|||||||
return prefix;
|
return prefix;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setPrefix(String prefix) {
|
||||||
|
this.prefix = prefix;
|
||||||
|
}
|
||||||
|
|
||||||
public String getMessage() {
|
public String getMessage() {
|
||||||
return message;
|
return message;
|
||||||
}
|
}
|
@ -27,7 +27,5 @@ public interface NoCheatPlayer {
|
|||||||
|
|
||||||
public boolean isCreative();
|
public boolean isCreative();
|
||||||
|
|
||||||
public void closeInventory();
|
|
||||||
|
|
||||||
public ExecutionHistory getExecutionHistory();
|
public ExecutionHistory getExecutionHistory();
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package cc.co.evenprime.bukkit.nocheat.actions.types;
|
package cc.co.evenprime.bukkit.nocheat.actions.types;
|
||||||
|
|
||||||
import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
|
import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
|
||||||
|
import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.ActionWithParameters;
|
import cc.co.evenprime.bukkit.nocheat.actions.ActionWithParameters;
|
||||||
import cc.co.evenprime.bukkit.nocheat.checks.Check;
|
import cc.co.evenprime.bukkit.nocheat.checks.Check;
|
||||||
|
|
||||||
@ -11,11 +12,41 @@ import cc.co.evenprime.bukkit.nocheat.checks.Check;
|
|||||||
*/
|
*/
|
||||||
public class ConsolecommandAction extends ActionWithParameters {
|
public class ConsolecommandAction extends ActionWithParameters {
|
||||||
|
|
||||||
public ConsolecommandAction(String name, int delay, int repeat, String command) {
|
private String command;
|
||||||
|
|
||||||
|
public ConsolecommandAction(String name, String command) {
|
||||||
|
super(name, 0, 1, command);
|
||||||
|
this.command = command;
|
||||||
|
}
|
||||||
|
|
||||||
|
private ConsolecommandAction(String name, int delay, int repeat, String command) {
|
||||||
|
// Log messages may have color codes now
|
||||||
super(name, delay, repeat, command);
|
super(name, delay, repeat, command);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getCommand(NoCheatPlayer player, Check check) {
|
public String getCommand(NoCheatPlayer player, Check check) {
|
||||||
return super.getMessage(player, check);
|
return super.getMessage(player, check);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make a copy of the action, with some modifications
|
||||||
|
* @param properties
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Action cloneWithProperties(String properties) {
|
||||||
|
String propertyFields[] = properties.split(":");
|
||||||
|
|
||||||
|
int delay = Integer.parseInt(propertyFields[0]);
|
||||||
|
int repeat = 5;
|
||||||
|
if(propertyFields.length > 1)
|
||||||
|
repeat = Integer.parseInt(propertyFields[1]);
|
||||||
|
|
||||||
|
return new ConsolecommandAction(name, delay, repeat, command);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getProperties() {
|
||||||
|
return delay + ":" + repeat;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,6 @@ import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
|
|||||||
import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.ActionWithParameters;
|
import cc.co.evenprime.bukkit.nocheat.actions.ActionWithParameters;
|
||||||
import cc.co.evenprime.bukkit.nocheat.checks.Check;
|
import cc.co.evenprime.bukkit.nocheat.checks.Check;
|
||||||
import cc.co.evenprime.bukkit.nocheat.log.Colors;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Print a message to various locations
|
* Print a message to various locations
|
||||||
@ -17,16 +16,16 @@ public class LogAction extends ActionWithParameters {
|
|||||||
private boolean toFile = true;
|
private boolean toFile = true;
|
||||||
private String message;
|
private String message;
|
||||||
|
|
||||||
public LogAction(String name, int delay, int repeat, String message) {
|
public LogAction(String name, String message) {
|
||||||
// Log messages may have color codes now
|
// Log messages may have color codes now
|
||||||
super(name, delay, repeat, Colors.replaceColors(message));
|
super(name, 0, 5, message);
|
||||||
this.message = message;
|
this.message = message;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private LogAction(String name, int delay, int repeat, boolean toChat, boolean toConsole, boolean toFile, String message) {
|
private LogAction(String name, int delay, int repeat, boolean toChat, boolean toConsole, boolean toFile, String message) {
|
||||||
// Log messages may have color codes now
|
// Log messages may have color codes now
|
||||||
super(name, delay, repeat, Colors.replaceColors(message));
|
super(name, delay, repeat, message);
|
||||||
this.toChat = toChat;
|
this.toChat = toChat;
|
||||||
this.toConsole = toConsole;
|
this.toConsole = toConsole;
|
||||||
this.toFile = toFile;
|
this.toFile = toFile;
|
||||||
@ -50,16 +49,30 @@ public class LogAction extends ActionWithParameters {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Action cloneWithProperties(String properties) {
|
public Action cloneWithProperties(String properties) {
|
||||||
boolean toChat = properties.toLowerCase().contains("ch");
|
String propertyFields[] = properties.split(":");
|
||||||
boolean toFile = properties.toLowerCase().contains("fi");
|
|
||||||
boolean toConsole = properties.toLowerCase().contains("co");
|
int delay = Integer.parseInt(propertyFields[0]);
|
||||||
|
int repeat = 5;
|
||||||
|
if(propertyFields.length > 1)
|
||||||
|
repeat = Integer.parseInt(propertyFields[1]);
|
||||||
|
|
||||||
|
boolean toChat = false;
|
||||||
|
boolean toFile = false;
|
||||||
|
boolean toConsole = false;
|
||||||
|
|
||||||
|
if(propertyFields.length > 2) {
|
||||||
|
toChat = propertyFields[2].toLowerCase().contains("ch");
|
||||||
|
toFile = propertyFields[2].toLowerCase().contains("fi");
|
||||||
|
toConsole = propertyFields[2].toLowerCase().contains("co");
|
||||||
|
}
|
||||||
|
|
||||||
return new LogAction(name, delay, repeat, toChat, toConsole, toFile, message);
|
return new LogAction(name, delay, repeat, toChat, toConsole, toFile, message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getProperties() {
|
public String getProperties() {
|
||||||
String props = (toChat ? "ch," : "") + (toFile ? "fi," : "") + (toConsole ? "co," : "");
|
String props = delay + ":" + repeat + ":" + ((toChat ? "ch," : "") + (toFile ? "fi," : "") + (toConsole ? "co," : ""));
|
||||||
if(props.length() > 0) {
|
if(props.endsWith(",")) {
|
||||||
return props.substring(0, props.length() - 1);
|
return props.substring(0, props.length() - 1);
|
||||||
} else {
|
} else {
|
||||||
return "";
|
return "";
|
||||||
|
@ -9,7 +9,32 @@ import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
|||||||
*/
|
*/
|
||||||
public class SpecialAction extends Action {
|
public class SpecialAction extends Action {
|
||||||
|
|
||||||
|
public SpecialAction(String name, String parameters) {
|
||||||
|
super(name, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
public SpecialAction(String name, int delay, int repeat) {
|
public SpecialAction(String name, int delay, int repeat) {
|
||||||
super(name, delay, repeat);
|
super(name, delay, repeat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make a copy of the action, with some modifications
|
||||||
|
* @param properties
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Action cloneWithProperties(String properties) {
|
||||||
|
String propertyFields[] = properties.split(":");
|
||||||
|
|
||||||
|
int delay = Integer.parseInt(propertyFields[0]);
|
||||||
|
int repeat = 5;
|
||||||
|
if(propertyFields.length > 1)
|
||||||
|
repeat = Integer.parseInt(propertyFields[1]);
|
||||||
|
|
||||||
|
return new SpecialAction(name, delay, repeat);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getProperties() {
|
||||||
|
return delay + ":" + repeat;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -6,6 +6,7 @@ import org.bukkit.Location;
|
|||||||
import org.bukkit.command.CommandException;
|
import org.bukkit.command.CommandException;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import cc.co.evenprime.bukkit.nocheat.NoCheat;
|
import cc.co.evenprime.bukkit.nocheat.NoCheat;
|
||||||
|
import cc.co.evenprime.bukkit.nocheat.NoCheatLogEvent;
|
||||||
import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
|
import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.NoCheatCommandSender;
|
import cc.co.evenprime.bukkit.nocheat.actions.NoCheatCommandSender;
|
||||||
@ -15,7 +16,6 @@ import cc.co.evenprime.bukkit.nocheat.actions.types.DummyAction;
|
|||||||
import cc.co.evenprime.bukkit.nocheat.actions.types.LogAction;
|
import cc.co.evenprime.bukkit.nocheat.actions.types.LogAction;
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.types.SpecialAction;
|
import cc.co.evenprime.bukkit.nocheat.actions.types.SpecialAction;
|
||||||
import cc.co.evenprime.bukkit.nocheat.config.ConfigurationCacheStore;
|
import cc.co.evenprime.bukkit.nocheat.config.ConfigurationCacheStore;
|
||||||
import cc.co.evenprime.bukkit.nocheat.log.NoCheatLogEvent;
|
|
||||||
|
|
||||||
public abstract class Check {
|
public abstract class Check {
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package cc.co.evenprime.bukkit.nocheat.events;
|
package cc.co.evenprime.bukkit.nocheat.checks;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -21,11 +21,11 @@ import cc.co.evenprime.bukkit.nocheat.config.ConfigurationCacheStore;
|
|||||||
* to relevant checks
|
* to relevant checks
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class WorkaroundsEventManager implements Listener, EventManager {
|
public class WorkaroundsListener implements Listener, EventManager {
|
||||||
|
|
||||||
private final NoCheat plugin;
|
private final NoCheat plugin;
|
||||||
|
|
||||||
public WorkaroundsEventManager(NoCheat plugin) {
|
public WorkaroundsListener(NoCheat plugin) {
|
||||||
|
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
}
|
}
|
@ -65,6 +65,8 @@ public class MovingData implements DataItem {
|
|||||||
|
|
||||||
public String checknamesuffix = "";
|
public String checknamesuffix = "";
|
||||||
|
|
||||||
|
public int onIce = 0;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void clearCriticalData() {
|
public void clearCriticalData() {
|
||||||
teleportTo.reset();
|
teleportTo.reset();
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
package cc.co.evenprime.bukkit.nocheat.checks.moving;
|
package cc.co.evenprime.bukkit.nocheat.checks.moving;
|
||||||
|
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.block.Block;
|
||||||
import cc.co.evenprime.bukkit.nocheat.NoCheat;
|
import cc.co.evenprime.bukkit.nocheat.NoCheat;
|
||||||
import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
|
import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.ParameterName;
|
import cc.co.evenprime.bukkit.nocheat.actions.ParameterName;
|
||||||
@ -144,6 +145,14 @@ public class RunningCheck extends MovingCheck {
|
|||||||
|
|
||||||
String suffix = null;
|
String suffix = null;
|
||||||
|
|
||||||
|
// Player on ice?
|
||||||
|
Block b = player.getPlayer().getLocation().getBlock();
|
||||||
|
if(b.getType() == Material.ICE || b.getRelative(0, -1, 0).getType() == Material.ICE) {
|
||||||
|
data.onIce = 20;
|
||||||
|
} else if(data.onIce > 0) {
|
||||||
|
data.onIce--;
|
||||||
|
}
|
||||||
|
|
||||||
if(cc.sneakingCheck && player.getPlayer().isSneaking() && !player.hasPermission(Permissions.MOVING_SNEAKING)) {
|
if(cc.sneakingCheck && player.getPlayer().isSneaking() && !player.hasPermission(Permissions.MOVING_SNEAKING)) {
|
||||||
limit = cc.sneakingSpeedLimit;
|
limit = cc.sneakingSpeedLimit;
|
||||||
suffix = "sneaking";
|
suffix = "sneaking";
|
||||||
@ -158,6 +167,10 @@ public class RunningCheck extends MovingCheck {
|
|||||||
suffix = "sprinting";
|
suffix = "sprinting";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(data.onIce > 0) {
|
||||||
|
limit *= 2.5;
|
||||||
|
}
|
||||||
|
|
||||||
// Taken directly from Minecraft code, should work
|
// Taken directly from Minecraft code, should work
|
||||||
limit *= player.getSpeedAmplifier();
|
limit *= player.getSpeedAmplifier();
|
||||||
|
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package cc.co.evenprime.bukkit.nocheat.config;
|
package cc.co.evenprime.bukkit.nocheat.config;
|
||||||
|
|
||||||
import cc.co.evenprime.bukkit.nocheat.log.Colors;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Configurations specific for logging. Every world gets one of these.
|
* Configurations specific for logging. Every world gets one of these.
|
||||||
@ -17,9 +16,9 @@ public class CCLogging {
|
|||||||
public CCLogging(Configuration data) {
|
public CCLogging(Configuration data) {
|
||||||
|
|
||||||
active = data.getBoolean(Configuration.LOGGING_ACTIVE);
|
active = data.getBoolean(Configuration.LOGGING_ACTIVE);
|
||||||
prefix = Colors.replaceColors(data.getString(Configuration.LOGGING_PREFIX));
|
prefix = data.getString(Configuration.LOGGING_PREFIX);
|
||||||
toFile = data.getBoolean(Configuration.LOGGING_LOGTOFILE);
|
toFile = data.getBoolean(Configuration.LOGGING_LOGTOFILE);
|
||||||
toConsole = data.getBoolean(Configuration.LOGGING_LOGTOCONSOLE);
|
toConsole = data.getBoolean(Configuration.LOGGING_LOGTOCONSOLE);
|
||||||
toChat = data.getBoolean(Configuration.LOGGING_LOGTOCHAT);
|
toChat = data.getBoolean(Configuration.LOGGING_LOGTOINGAMECHAT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,9 +22,9 @@ public abstract class Configuration {
|
|||||||
public final static OptionNode LOGGING_ACTIVE = new OptionNode("active", LOGGING, DataType.BOOLEAN);
|
public final static OptionNode LOGGING_ACTIVE = new OptionNode("active", LOGGING, DataType.BOOLEAN);
|
||||||
public final static OptionNode LOGGING_PREFIX = new OptionNode("prefix", LOGGING, DataType.STRING);
|
public final static OptionNode LOGGING_PREFIX = new OptionNode("prefix", LOGGING, DataType.STRING);
|
||||||
public final static OptionNode LOGGING_FILENAME = new OptionNode("filename", LOGGING, DataType.STRING);
|
public final static OptionNode LOGGING_FILENAME = new OptionNode("filename", LOGGING, DataType.STRING);
|
||||||
public final static OptionNode LOGGING_LOGTOFILE = new OptionNode("logtofile", LOGGING, DataType.BOOLEAN);
|
public final static OptionNode LOGGING_LOGTOFILE = new OptionNode("file", LOGGING, DataType.BOOLEAN);
|
||||||
public final static OptionNode LOGGING_LOGTOCONSOLE = new OptionNode("logtoconsole", LOGGING, DataType.BOOLEAN);
|
public final static OptionNode LOGGING_LOGTOCONSOLE = new OptionNode("console", LOGGING, DataType.BOOLEAN);
|
||||||
public final static OptionNode LOGGING_LOGTOCHAT = new OptionNode("logtochat", LOGGING, DataType.BOOLEAN);
|
public final static OptionNode LOGGING_LOGTOINGAMECHAT = new OptionNode("ingamechat", LOGGING, DataType.BOOLEAN);
|
||||||
|
|
||||||
private final static OptionNode DEBUG = new OptionNode("debug", ROOT, DataType.PARENT);
|
private final static OptionNode DEBUG = new OptionNode("debug", ROOT, DataType.PARENT);
|
||||||
public final static OptionNode DEBUG_SHOWACTIVECHECKS = new OptionNode("showactivechecks", DEBUG, DataType.BOOLEAN);
|
public final static OptionNode DEBUG_SHOWACTIVECHECKS = new OptionNode("showactivechecks", DEBUG, DataType.BOOLEAN);
|
||||||
|
@ -24,7 +24,7 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(LOGGING_FILENAME, "nocheat.log");
|
setValue(LOGGING_FILENAME, "nocheat.log");
|
||||||
setValue(LOGGING_LOGTOFILE, true);
|
setValue(LOGGING_LOGTOFILE, true);
|
||||||
setValue(LOGGING_LOGTOCONSOLE, true);
|
setValue(LOGGING_LOGTOCONSOLE, true);
|
||||||
setValue(LOGGING_LOGTOCHAT, true);
|
setValue(LOGGING_LOGTOINGAMECHAT, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*** DEBUG ***/
|
/*** DEBUG ***/
|
||||||
@ -42,7 +42,7 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(INVENTORY_DROP_LIMIT, 100);
|
setValue(INVENTORY_DROP_LIMIT, 100);
|
||||||
|
|
||||||
ActionList dropActionList = new ActionList();
|
ActionList dropActionList = new ActionList();
|
||||||
dropActionList.setActions(0, action.getActions("dropLog:co,ch,fi dropkick".split(" ")));
|
dropActionList.setActions(0, action.getActions("dropLog:0:1:co,ch,fi dropkick".split(" ")));
|
||||||
setValue(INVENTORY_DROP_ACTIONS, dropActionList);
|
setValue(INVENTORY_DROP_ACTIONS, dropActionList);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -66,16 +66,16 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(MOVING_RUNFLY_SWIMMINGSPEEDLIMIT, 18);
|
setValue(MOVING_RUNFLY_SWIMMINGSPEEDLIMIT, 18);
|
||||||
|
|
||||||
ActionList movingActionList = new ActionList();
|
ActionList movingActionList = new ActionList();
|
||||||
movingActionList.setActions(0, action.getActions("moveLogShort:fi moveCancel".split(" ")));
|
movingActionList.setActions(0, action.getActions("moveLogShort:3:5:fi moveCancel".split(" ")));
|
||||||
movingActionList.setActions(100, action.getActions("moveLogShort:ch,fi moveCancel".split(" ")));
|
movingActionList.setActions(100, action.getActions("moveLogShort:0:5:ch,fi moveCancel".split(" ")));
|
||||||
movingActionList.setActions(400, action.getActions("moveLogLong:co,ch,fi moveCancel".split(" ")));
|
movingActionList.setActions(400, action.getActions("moveLogLong:0:5:co,ch,fi moveCancel".split(" ")));
|
||||||
setValue(MOVING_RUNFLY_ACTIONS, movingActionList);
|
setValue(MOVING_RUNFLY_ACTIONS, movingActionList);
|
||||||
|
|
||||||
setValue(MOVING_RUNFLY_CHECKNOFALL, true);
|
setValue(MOVING_RUNFLY_CHECKNOFALL, true);
|
||||||
setValue(MOVING_RUNFLY_NOFALLMULTIPLIER, 200);
|
setValue(MOVING_RUNFLY_NOFALLMULTIPLIER, 200);
|
||||||
|
|
||||||
ActionList nofallActionList = new ActionList();
|
ActionList nofallActionList = new ActionList();
|
||||||
nofallActionList.setActions(0, action.getActions("nofallLog:co,ch,fi nofallDamage".split(" ")));
|
nofallActionList.setActions(0, action.getActions("nofallLog:0:5:co,ch,fi nofallDamage".split(" ")));
|
||||||
setValue(MOVING_RUNFLY_NOFALLACTIONS, nofallActionList);
|
setValue(MOVING_RUNFLY_NOFALLACTIONS, nofallActionList);
|
||||||
|
|
||||||
setValue(MOVING_RUNFLY_ALLOWLIMITEDFLYING, false);
|
setValue(MOVING_RUNFLY_ALLOWLIMITEDFLYING, false);
|
||||||
@ -84,17 +84,17 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(MOVING_RUNFLY_FLYINGHEIGHTLIMIT, 250);
|
setValue(MOVING_RUNFLY_FLYINGHEIGHTLIMIT, 250);
|
||||||
|
|
||||||
ActionList flyingActionList = new ActionList();
|
ActionList flyingActionList = new ActionList();
|
||||||
flyingActionList.setActions(0, action.getActions("moveLogShort:fi moveCancel".split(" ")));
|
flyingActionList.setActions(0, action.getActions("moveLogShort:3:5:fi moveCancel".split(" ")));
|
||||||
flyingActionList.setActions(100, action.getActions("moveLogShort:ch,fi moveCancel".split(" ")));
|
flyingActionList.setActions(100, action.getActions("moveLogShort:0:5:ch,fi moveCancel".split(" ")));
|
||||||
flyingActionList.setActions(400, action.getActions("moveLogShort:co,ch,fi moveCancel".split(" ")));
|
flyingActionList.setActions(400, action.getActions("moveLogShort:0:5:co,ch,fi moveCancel".split(" ")));
|
||||||
setValue(MOVING_RUNFLY_FLYINGACTIONS, flyingActionList);
|
setValue(MOVING_RUNFLY_FLYINGACTIONS, flyingActionList);
|
||||||
|
|
||||||
setValue(MOVING_MOREPACKETS_CHECK, true);
|
setValue(MOVING_MOREPACKETS_CHECK, true);
|
||||||
|
|
||||||
ActionList morepacketsActionList = new ActionList();
|
ActionList morepacketsActionList = new ActionList();
|
||||||
morepacketsActionList.setActions(0, action.getActions("morepackets:fi moveCancel".split(" ")));
|
morepacketsActionList.setActions(0, action.getActions("morepackets:3:2:fi moveCancel".split(" ")));
|
||||||
morepacketsActionList.setActions(30, action.getActions("morepackets:ch,fi moveCancel".split(" ")));
|
morepacketsActionList.setActions(30, action.getActions("morepackets:0:2:ch,fi moveCancel".split(" ")));
|
||||||
morepacketsActionList.setActions(60, action.getActions("morepackets:co,ch,fi moveCancel".split(" ")));
|
morepacketsActionList.setActions(60, action.getActions("morepackets:0:2:co,ch,fi moveCancel".split(" ")));
|
||||||
setValue(MOVING_MOREPACKETS_ACTIONS, morepacketsActionList);
|
setValue(MOVING_MOREPACKETS_ACTIONS, morepacketsActionList);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -107,7 +107,7 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
|
|
||||||
ActionList reachActionList = new ActionList();
|
ActionList reachActionList = new ActionList();
|
||||||
reachActionList.setActions(0, action.getActions("blockbreakCancel".split(" ")));
|
reachActionList.setActions(0, action.getActions("blockbreakCancel".split(" ")));
|
||||||
reachActionList.setActions(5, action.getActions("reachLog:fi,ch blockbreakCancel".split(" ")));
|
reachActionList.setActions(5, action.getActions("reachLog:0:2:fi,ch blockbreakCancel".split(" ")));
|
||||||
setValue(BLOCKBREAK_REACH_ACTIONS, reachActionList);
|
setValue(BLOCKBREAK_REACH_ACTIONS, reachActionList);
|
||||||
|
|
||||||
setValue(BLOCKBREAK_DIRECTION_CHECK, true);
|
setValue(BLOCKBREAK_DIRECTION_CHECK, true);
|
||||||
@ -116,12 +116,12 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(BLOCKBREAK_DIRECTION_PENALTYTIME, 300);
|
setValue(BLOCKBREAK_DIRECTION_PENALTYTIME, 300);
|
||||||
ActionList directionActionList = new ActionList();
|
ActionList directionActionList = new ActionList();
|
||||||
directionActionList.setActions(0, action.getActions("blockbreakCancel".split(" ")));
|
directionActionList.setActions(0, action.getActions("blockbreakCancel".split(" ")));
|
||||||
directionActionList.setActions(10, action.getActions("directionLog:fi,co,ch blockbreakCancel".split(" ")));
|
directionActionList.setActions(10, action.getActions("directionLog:0:5:fi,co,ch blockbreakCancel".split(" ")));
|
||||||
setValue(BLOCKBREAK_DIRECTION_ACTIONS, directionActionList);
|
setValue(BLOCKBREAK_DIRECTION_ACTIONS, directionActionList);
|
||||||
|
|
||||||
setValue(BLOCKBREAK_NOSWING_CHECK, true);
|
setValue(BLOCKBREAK_NOSWING_CHECK, true);
|
||||||
ActionList noswingActionList = new ActionList();
|
ActionList noswingActionList = new ActionList();
|
||||||
noswingActionList.setActions(0, action.getActions("noswingLog:fi,co,ch blockbreakCancel".split(" ")));
|
noswingActionList.setActions(0, action.getActions("noswingLog:0:2:fi,co,ch blockbreakCancel".split(" ")));
|
||||||
setValue(BLOCKBREAK_NOSWING_ACTIONS, noswingActionList);
|
setValue(BLOCKBREAK_NOSWING_ACTIONS, noswingActionList);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,7 +133,7 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
|
|
||||||
ActionList reachActionList = new ActionList();
|
ActionList reachActionList = new ActionList();
|
||||||
reachActionList.setActions(0, action.getActions("blockplaceCancel".split(" ")));
|
reachActionList.setActions(0, action.getActions("blockplaceCancel".split(" ")));
|
||||||
reachActionList.setActions(5, action.getActions("reachLog:fi,co,ch blockplaceCancel".split(" ")));
|
reachActionList.setActions(5, action.getActions("reachLog:0:2:fi,co,ch blockplaceCancel".split(" ")));
|
||||||
setValue(BLOCKPLACE_REACH_ACTIONS, reachActionList);
|
setValue(BLOCKPLACE_REACH_ACTIONS, reachActionList);
|
||||||
|
|
||||||
setValue(BLOCKPLACE_DIRECTION_CHECK, true);
|
setValue(BLOCKPLACE_DIRECTION_CHECK, true);
|
||||||
@ -141,7 +141,7 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(BLOCKPLACE_DIRECTION_PENALTYTIME, 100);
|
setValue(BLOCKPLACE_DIRECTION_PENALTYTIME, 100);
|
||||||
ActionList directionActionList = new ActionList();
|
ActionList directionActionList = new ActionList();
|
||||||
directionActionList.setActions(0, action.getActions("blockplaceCancel".split(" ")));
|
directionActionList.setActions(0, action.getActions("blockplaceCancel".split(" ")));
|
||||||
directionActionList.setActions(10, action.getActions("directionLog:fi,co,ch blockplaceCancel".split(" ")));
|
directionActionList.setActions(10, action.getActions("directionLog:0:3:fi,co,ch blockplaceCancel".split(" ")));
|
||||||
setValue(BLOCKPLACE_DIRECTION_ACTIONS, directionActionList);
|
setValue(BLOCKPLACE_DIRECTION_ACTIONS, directionActionList);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -151,7 +151,7 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
|
|
||||||
setValue(CHAT_COLOR_CHECK, true);
|
setValue(CHAT_COLOR_CHECK, true);
|
||||||
ActionList colorActionList = new ActionList();
|
ActionList colorActionList = new ActionList();
|
||||||
colorActionList.setActions(0, action.getActions("colorLog:fi,co,ch chatCancel".split(" ")));
|
colorActionList.setActions(0, action.getActions("colorLog:0:1:fi,co,ch chatCancel".split(" ")));
|
||||||
setValue(CHAT_COLOR_ACTIONS, colorActionList);
|
setValue(CHAT_COLOR_ACTIONS, colorActionList);
|
||||||
|
|
||||||
setValue(CHAT_SPAM_CHECK, true);
|
setValue(CHAT_SPAM_CHECK, true);
|
||||||
@ -160,8 +160,8 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(CHAT_SPAM_LIMIT, 5);
|
setValue(CHAT_SPAM_LIMIT, 5);
|
||||||
|
|
||||||
ActionList spamActionList = new ActionList();
|
ActionList spamActionList = new ActionList();
|
||||||
spamActionList.setActions(0, action.getActions("spamLog:fi,co,ch chatCancel".split(" ")));
|
spamActionList.setActions(0, action.getActions("spamLog:0:5:fi,co,ch chatCancel".split(" ")));
|
||||||
spamActionList.setActions(50, action.getActions("spamLog:fi,co,ch chatCancel spamkick".split(" ")));
|
spamActionList.setActions(50, action.getActions("spamLog:0:5:fi,co,ch chatCancel spamkick".split(" ")));
|
||||||
setValue(CHAT_SPAM_ACTIONS, spamActionList);
|
setValue(CHAT_SPAM_ACTIONS, spamActionList);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,14 +175,14 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
|
|
||||||
ActionList directionActionList = new ActionList();
|
ActionList directionActionList = new ActionList();
|
||||||
directionActionList.setActions(0, action.getActions("fightCancel".split(" ")));
|
directionActionList.setActions(0, action.getActions("fightCancel".split(" ")));
|
||||||
directionActionList.setActions(5, action.getActions("fightDirectionLog:fi fightCancel".split(" ")));
|
directionActionList.setActions(5, action.getActions("fightDirectionLog:3:5:fi fightCancel".split(" ")));
|
||||||
directionActionList.setActions(20, action.getActions("fightDirectionLog:fi,ch fightCancel".split(" ")));
|
directionActionList.setActions(20, action.getActions("fightDirectionLog:0:5:fi,ch fightCancel".split(" ")));
|
||||||
directionActionList.setActions(50, action.getActions("fightDirectionLog:fi,ch,co fightCancel".split(" ")));
|
directionActionList.setActions(50, action.getActions("fightDirectionLog:0:5:fi,ch,co fightCancel".split(" ")));
|
||||||
setValue(FIGHT_DIRECTION_ACTIONS, directionActionList);
|
setValue(FIGHT_DIRECTION_ACTIONS, directionActionList);
|
||||||
|
|
||||||
setValue(FIGHT_NOSWING_CHECK, true);
|
setValue(FIGHT_NOSWING_CHECK, true);
|
||||||
ActionList noswingActionList = new ActionList();
|
ActionList noswingActionList = new ActionList();
|
||||||
noswingActionList.setActions(0, action.getActions("noswingLog fightCancel".split(" ")));
|
noswingActionList.setActions(0, action.getActions("noswingLog:0:5:fi,ch,co fightCancel".split(" ")));
|
||||||
setValue(FIGHT_NOSWING_ACTIONS, noswingActionList);
|
setValue(FIGHT_NOSWING_ACTIONS, noswingActionList);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -242,21 +242,12 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
w(w, "# - Then comes the 'message', depending on where the action is used, different keywords in [ ] may be used");
|
w(w, "# - Then comes the 'message', depending on where the action is used, different keywords in [ ] may be used");
|
||||||
w(w, "");
|
w(w, "");
|
||||||
w(w, "# Gives a very short log message of the violation, only containing name, violation type and total violation value, at most once every 15 seconds, only if more than 3 violations happened within the last minute (low) and immediatly (med,high)");
|
w(w, "# Gives a very short log message of the violation, only containing name, violation type and total violation value, at most once every 15 seconds, only if more than 3 violations happened within the last minute (low) and immediatly (med,high)");
|
||||||
w(w, "log moveLogLowShort 3 15 [player] failed [check]. VL [violations]");
|
|
||||||
w(w, "log moveLogMedShort 0 15 [player] failed [check]. VL [violations]");
|
|
||||||
w(w, "log moveLogHighShort 0 15 [player] failed [check]. VL [violations]");
|
|
||||||
w(w, "log moveLogShort 0 5 [player] failed [check]. VL [violations]");
|
w(w, "log moveLogShort 0 5 [player] failed [check]. VL [violations]");
|
||||||
w(w, "");
|
w(w, "");
|
||||||
w(w, "# Gives a log message of the violation, only containing name, violation type and total violation value, at most once every second, only if more than 5 violations happened within the last minute (low) and immediatly (med,high)");
|
w(w, "# Gives a log message of the violation, only containing name, violation type and total violation value, at most once every second, only if more than 5 violations happened within the last minute (low) and immediatly (med,high)");
|
||||||
w(w, "log morepacketsLow 5 1 [player] failed [check]: Sent [packets] more packets than expected. Total violation level [violations].");
|
|
||||||
w(w, "log morepacketsMed 0 1 [player] failed [check]: Sent [packets] more packets than expected. Total violation level [violations].");
|
|
||||||
w(w, "log morepacketsHigh 0 1 [player] failed [check]: Sent [packets] more packets than expected. Total violation level [violations].");
|
|
||||||
w(w, "log morepackets 0 1 [player] failed [check]: Sent [packets] more packets than expected. Total violation level [violations].");
|
w(w, "log morepackets 0 1 [player] failed [check]: Sent [packets] more packets than expected. Total violation level [violations].");
|
||||||
w(w, "");
|
w(w, "");
|
||||||
w(w, "# Gives a lengthy log message of the violation, containing name, location, violation type and total violation, at most once every 15 seconds, only if more than 3 violations happened within the last minute (low) and immediatly (med,high)");
|
w(w, "# Gives a lengthy log message of the violation, containing name, location, violation type and total violation, at most once every 15 seconds, only if more than 3 violations happened within the last minute (low) and immediatly (med,high)");
|
||||||
w(w, "log moveLogLowLong 3 15 [player] in [world] at [location] moving to [locationto] over distance [movedistance] failed check [check]. Total violation level so far [violations].");
|
|
||||||
w(w, "log moveLogMedLong 0 15 [player] in [world] at [location] moving to [locationto] over distance [movedistance] failed check [check]. Total violation level so far [violations].");
|
|
||||||
w(w, "log moveLogHighLong 0 15 [player] in [world] at [location] moving to [locationto] over distance [movedistance] failed check [check]. Total violation level so far [violations].");
|
|
||||||
w(w, "log moveLogLong 0 5 [player] in [world] at [location] moving to [locationto] over distance [movedistance] failed check [check]. Total violation level so far [violations].");
|
w(w, "log moveLogLong 0 5 [player] in [world] at [location] moving to [locationto] over distance [movedistance] failed check [check]. Total violation level so far [violations].");
|
||||||
w(w, "");
|
w(w, "");
|
||||||
w(w, "# Some other log messages that are limited a bit by default, to avoid too extreme spam");
|
w(w, "# Some other log messages that are limited a bit by default, to avoid too extreme spam");
|
||||||
|
@ -20,7 +20,7 @@ public class Explainations {
|
|||||||
set(Configuration.LOGGING_PREFIX, "The short text that appears in front of messages by NoCheat. Color codes are &0-&9 and &A-&F");
|
set(Configuration.LOGGING_PREFIX, "The short text that appears in front of messages by NoCheat. Color codes are &0-&9 and &A-&F");
|
||||||
set(Configuration.LOGGING_FILENAME, "Where logs that go to the logfile are stored. You can have different files for different worlds.");
|
set(Configuration.LOGGING_FILENAME, "Where logs that go to the logfile are stored. You can have different files for different worlds.");
|
||||||
set(Configuration.LOGGING_LOGTOFILE, "Should messages get logged to the specified logfile?");
|
set(Configuration.LOGGING_LOGTOFILE, "Should messages get logged to the specified logfile?");
|
||||||
set(Configuration.LOGGING_LOGTOCHAT, "Should messages get logged to the ingame chat?");
|
set(Configuration.LOGGING_LOGTOINGAMECHAT, "Should messages get logged to the ingame chat?");
|
||||||
set(Configuration.LOGGING_LOGTOCONSOLE, "Should messages get logged to the server console?");
|
set(Configuration.LOGGING_LOGTOCONSOLE, "Should messages get logged to the server console?");
|
||||||
|
|
||||||
set(Configuration.DEBUG_SHOWACTIVECHECKS, "Print to the console an overview of all checks that are enabled when NoCheat gets loaded.");
|
set(Configuration.DEBUG_SHOWACTIVECHECKS, "Print to the console an overview of all checks that are enabled when NoCheat gets loaded.");
|
||||||
|
@ -56,47 +56,25 @@ public class FlatFileAction {
|
|||||||
private Action parseLine(String line) {
|
private Action parseLine(String line) {
|
||||||
|
|
||||||
// Split the line into some parts
|
// Split the line into some parts
|
||||||
String parts[] = line.split("\\s+", 5);
|
String parts[] = line.split("\\s+", 3);
|
||||||
|
|
||||||
// four pieces is the minimum we need, no matter what it is
|
// four pieces is the minimum we need, no matter what it is
|
||||||
if(parts.length < 4) {
|
if(parts.length < 3) {
|
||||||
throw new IllegalArgumentException("The line " + line + " of the file " + file.getName() + " is malformed. It has not enough parts.");
|
throw new IllegalArgumentException("The line " + line + " of the file " + file.getName() + " is malformed. It has not enough parts.");
|
||||||
}
|
}
|
||||||
|
|
||||||
String type = parts[0];
|
String type = parts[0];
|
||||||
String name = parts[1];
|
String name = parts[1];
|
||||||
|
String message = parts[2];
|
||||||
int delay = 0;
|
|
||||||
try {
|
|
||||||
delay = Integer.parseInt(parts[2]);
|
|
||||||
} catch(Exception e) {
|
|
||||||
throw new IllegalArgumentException("Couldn't parse third parameter of action " + name + " from file " + file.getName() + ". It is " + parts[2] + " but should be a number.");
|
|
||||||
}
|
|
||||||
|
|
||||||
int repeat = 0;
|
|
||||||
try {
|
|
||||||
repeat = Integer.parseInt(parts[3]);
|
|
||||||
} catch(Exception e) {
|
|
||||||
throw new IllegalArgumentException("Couldn't parse fourth parameter of action " + name + " from file " + file.getName() + ". It is " + parts[2] + " but should be a number.");
|
|
||||||
}
|
|
||||||
|
|
||||||
if(type.equalsIgnoreCase("log")) {
|
if(type.equalsIgnoreCase("log")) {
|
||||||
// A log action, it seems
|
// A log action, it seems
|
||||||
if(parts.length < 5) {
|
return new LogAction(name, message);
|
||||||
throw new IllegalArgumentException("Missing fifth parameter of action " + name + " from file " + file.getName() + ".");
|
|
||||||
}
|
|
||||||
|
|
||||||
return new LogAction(name, delay, repeat, parts[4]);
|
|
||||||
} else if(type.equalsIgnoreCase("consolecommand")) {
|
} else if(type.equalsIgnoreCase("consolecommand")) {
|
||||||
// A consolecommand action, it seems
|
// A consolecommand action, it seems
|
||||||
if(parts.length < 5) {
|
return new ConsolecommandAction(name, message);
|
||||||
throw new IllegalArgumentException("Missing fifth parameter of action " + name + " from file " + file.getName() + ".");
|
|
||||||
}
|
|
||||||
|
|
||||||
return new ConsolecommandAction(name, delay, repeat, parts[4]);
|
|
||||||
} else if(type.equalsIgnoreCase("special")) {
|
} else if(type.equalsIgnoreCase("special")) {
|
||||||
// A "special" actions, it seems
|
return new SpecialAction(name, message);
|
||||||
return new SpecialAction(name, delay, repeat);
|
|
||||||
} else {
|
} else {
|
||||||
throw new IllegalArgumentException("Unknown action type " + type + " of action with name " + name + ".");
|
throw new IllegalArgumentException("Unknown action type " + type + " of action with name " + name + ".");
|
||||||
}
|
}
|
||||||
|
@ -7,10 +7,7 @@ import java.io.FileInputStream;
|
|||||||
import java.io.FileWriter;
|
import java.io.FileWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.util.LinkedList;
|
|
||||||
import java.util.List;
|
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
||||||
import cc.co.evenprime.bukkit.nocheat.actions.types.DummyAction;
|
|
||||||
import cc.co.evenprime.bukkit.nocheat.config.util.ActionList;
|
import cc.co.evenprime.bukkit.nocheat.config.util.ActionList;
|
||||||
import cc.co.evenprime.bukkit.nocheat.config.util.ActionMapper;
|
import cc.co.evenprime.bukkit.nocheat.config.util.ActionMapper;
|
||||||
import cc.co.evenprime.bukkit.nocheat.config.util.OptionNode;
|
import cc.co.evenprime.bukkit.nocheat.config.util.OptionNode;
|
||||||
@ -99,22 +96,7 @@ public class FlatFileConfiguration extends Configuration {
|
|||||||
}
|
}
|
||||||
int th = Integer.parseInt(treshold);
|
int th = Integer.parseInt(treshold);
|
||||||
|
|
||||||
List<Action> actions = new LinkedList<Action>();
|
al.setActions(th, action.getActions(value.split("\\s+")));
|
||||||
|
|
||||||
for(String name : value.split("\\s+")) {
|
|
||||||
String nameParts[] = name.split(":", 2);
|
|
||||||
Action a2 = action.getAction(nameParts[0]);
|
|
||||||
if(a2 == null) {
|
|
||||||
System.out.println("Nocheat: Action with name " + nameParts[0] + " isn't defined. You need to define it in your actions.txt file to make it work.");
|
|
||||||
actions.add(new DummyAction(name, 0, 0));
|
|
||||||
} else if(nameParts.length == 2) {
|
|
||||||
actions.add(a2.cloneWithProperties(nameParts[1]));
|
|
||||||
} else {
|
|
||||||
actions.add(a2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
al.setActions(th, actions.toArray(new Action[actions.size()]));
|
|
||||||
return al;
|
return al;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ import cc.co.evenprime.bukkit.nocheat.actions.Action;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Store amount of action executions for last 60 seconds
|
* Store amount of action executions for last 60 seconds
|
||||||
|
* for various actions
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class ExecutionHistory {
|
public class ExecutionHistory {
|
||||||
|
@ -4,8 +4,7 @@ import org.bukkit.Location;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* A class to store x,y,z triple data, instead of using bukkits Location
|
* A class to store x,y,z triple data, instead of using bukkits Location
|
||||||
* objects,
|
* objects, which can't be easily recycled
|
||||||
* which can't be easily recycled
|
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public final class PreciseLocation {
|
public final class PreciseLocation {
|
||||||
|
@ -97,10 +97,6 @@ public class NoCheatPlayerImpl implements NoCheatPlayer {
|
|||||||
return player.getGameMode() == GameMode.CREATIVE;
|
return player.getGameMode() == GameMode.CREATIVE;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void closeInventory() {
|
|
||||||
((CraftPlayer) this.player).getHandle().closeInventory();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ExecutionHistory getExecutionHistory() {
|
public ExecutionHistory getExecutionHistory() {
|
||||||
return history;
|
return history;
|
||||||
|
Loading…
Reference in New Issue
Block a user