mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-04 23:07:44 +01:00
Bleeding: Add capability to replace ActionFactory and actions.
This commit is contained in:
parent
318372b000
commit
a3eb7f576d
@ -25,7 +25,7 @@ import fr.neatmonster.nocheatplus.utilities.CheckUtils;
|
|||||||
* Helps with creating Actions out of text string definitions.
|
* Helps with creating Actions out of text string definitions.
|
||||||
*/
|
*/
|
||||||
public class ActionFactory {
|
public class ActionFactory {
|
||||||
private static final Map<String, Object> lib = new HashMap<String, Object>();
|
protected static final Map<String, Object> lib = new HashMap<String, Object>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiates a new action factory.
|
* Instantiates a new action factory.
|
||||||
@ -133,7 +133,7 @@ public class ActionFactory {
|
|||||||
* the definition
|
* the definition
|
||||||
* @return the action
|
* @return the action
|
||||||
*/
|
*/
|
||||||
private Action parseCmdAction(final String definition) {
|
protected Action parseCmdAction(final String definition) {
|
||||||
final String[] parts = definition.split(":");
|
final String[] parts = definition.split(":");
|
||||||
final String name = parts[0];
|
final String name = parts[0];
|
||||||
final Object command = lib.get(parts[0]);
|
final Object command = lib.get(parts[0]);
|
||||||
@ -165,7 +165,7 @@ public class ActionFactory {
|
|||||||
* the definition
|
* the definition
|
||||||
* @return the action
|
* @return the action
|
||||||
*/
|
*/
|
||||||
private Action parseLogAction(final String definition) {
|
protected Action parseLogAction(final String definition) {
|
||||||
final String[] parts = definition.split(":");
|
final String[] parts = definition.split(":");
|
||||||
final String name = parts[0];
|
final String name = parts[0];
|
||||||
final Object message = lib.get(parts[0]);
|
final Object message = lib.get(parts[0]);
|
||||||
|
@ -28,7 +28,7 @@ import fr.neatmonster.nocheatplus.checks.ViolationData;
|
|||||||
*/
|
*/
|
||||||
public abstract class ActionWithParameters extends Action {
|
public abstract class ActionWithParameters extends Action {
|
||||||
/** The parts of the message. */
|
/** The parts of the message. */
|
||||||
private final ArrayList<Object> messageParts;
|
protected final ArrayList<Object> messageParts;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiates a new action with parameters.
|
* Instantiates a new action with parameters.
|
||||||
@ -83,7 +83,7 @@ public abstract class ActionWithParameters extends Action {
|
|||||||
* @param message
|
* @param message
|
||||||
* the message
|
* the message
|
||||||
*/
|
*/
|
||||||
private void parseMessage(final String message) {
|
protected void parseMessage(final String message) {
|
||||||
final String parts[] = message.split("\\[", 2);
|
final String parts[] = message.split("\\[", 2);
|
||||||
|
|
||||||
// No opening braces left.
|
// No opening braces left.
|
||||||
|
@ -19,7 +19,7 @@ import fr.neatmonster.nocheatplus.checks.ViolationData;
|
|||||||
*/
|
*/
|
||||||
public class DummyAction extends Action {
|
public class DummyAction extends Action {
|
||||||
/** The original string used for this action definition. */
|
/** The original string used for this action definition. */
|
||||||
private final String definition;
|
protected final String definition;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiates a new dummy.
|
* Instantiates a new dummy.
|
||||||
|
@ -27,13 +27,13 @@ import fr.neatmonster.nocheatplus.utilities.CheckUtils;
|
|||||||
public class LogAction extends ActionWithParameters {
|
public class LogAction extends ActionWithParameters {
|
||||||
// Some flags to decide where the log message should show up, based on the configuration file.
|
// Some flags to decide where the log message should show up, based on the configuration file.
|
||||||
/** Log to chat? */
|
/** Log to chat? */
|
||||||
private final boolean toChat;
|
public final boolean toChat;
|
||||||
|
|
||||||
/** Log to console? */
|
/** Log to console? */
|
||||||
private final boolean toConsole;
|
public final boolean toConsole;
|
||||||
|
|
||||||
/** Log to file? */
|
/** Log to file? */
|
||||||
private final boolean toFile;
|
public final boolean toFile;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiates a new log action.
|
* Instantiates a new log action.
|
||||||
@ -59,6 +59,7 @@ public class LogAction extends ActionWithParameters {
|
|||||||
this.toChat = toChat;
|
this.toChat = toChat;
|
||||||
this.toConsole = toConsole;
|
this.toConsole = toConsole;
|
||||||
this.toFile = toFile;
|
this.toFile = toFile;
|
||||||
|
// TODO: already use && flagfromconfig.
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
|
@ -111,7 +111,7 @@ public class ConfigFile extends YamlConfiguration {
|
|||||||
* Do this after reading new data.
|
* Do this after reading new data.
|
||||||
*/
|
*/
|
||||||
public void regenerateActionLists() {
|
public void regenerateActionLists() {
|
||||||
factory = new ActionFactory(((MemorySection) this.get(ConfPaths.STRINGS)).getValues(false));
|
factory = ConfigManager.getActionFactory(((MemorySection) this.get(ConfPaths.STRINGS)).getValues(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
|
@ -18,6 +18,7 @@ import org.bukkit.Bukkit;
|
|||||||
import org.bukkit.configuration.MemoryConfiguration;
|
import org.bukkit.configuration.MemoryConfiguration;
|
||||||
|
|
||||||
import fr.neatmonster.nocheatplus.NoCheatPlus;
|
import fr.neatmonster.nocheatplus.NoCheatPlus;
|
||||||
|
import fr.neatmonster.nocheatplus.actions.ActionFactory;
|
||||||
import fr.neatmonster.nocheatplus.utilities.CheckUtils;
|
import fr.neatmonster.nocheatplus.utilities.CheckUtils;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -94,6 +95,43 @@ public class ConfigManager {
|
|||||||
/** The log file. */
|
/** The log file. */
|
||||||
public static File logFile = null;
|
public static File logFile = null;
|
||||||
|
|
||||||
|
public static interface ActionFactoryFactory{
|
||||||
|
public ActionFactory newActionFactory(Map<String, Object> library);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static ActionFactoryFactory actionFactoryFactory = new ActionFactoryFactory() {
|
||||||
|
@Override
|
||||||
|
public final ActionFactory newActionFactory(final Map<String, Object> library) {
|
||||||
|
return new ActionFactory(library);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Factory method.
|
||||||
|
* @param library
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static ActionFactory getActionFactory(final Map<String, Object> library){
|
||||||
|
return actionFactoryFactory.newActionFactory(library);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the factory to get actions from.
|
||||||
|
* @param factory
|
||||||
|
*/
|
||||||
|
public static void setActionFactoryFactory(ActionFactoryFactory factory){
|
||||||
|
if (factory != null) actionFactoryFactory = factory;
|
||||||
|
else actionFactoryFactory = new ActionFactoryFactory() {
|
||||||
|
@Override
|
||||||
|
public final ActionFactory newActionFactory(final Map<String, Object> library) {
|
||||||
|
return new ActionFactory(library);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
for (final ConfigFile config : worldsMap.values()){
|
||||||
|
config.regenerateActionLists();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Cleanup.
|
* Cleanup.
|
||||||
*/
|
*/
|
||||||
@ -103,6 +141,7 @@ public class ConfigManager {
|
|||||||
final Logger logger = Logger.getLogger("NoCheatPlus");
|
final Logger logger = Logger.getLogger("NoCheatPlus");
|
||||||
logger.removeHandler(fileHandler);
|
logger.removeHandler(fileHandler);
|
||||||
fileHandler = null;
|
fileHandler = null;
|
||||||
|
setActionFactoryFactory(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user