mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-08 00:38:27 +01:00
Bleeding: Split off Relog check from nopwnage.
This commit is contained in:
parent
0574530c45
commit
b34aec55b4
@ -79,6 +79,8 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
public final boolean colorCheck;
|
public final boolean colorCheck;
|
||||||
public final ActionList colorActions;
|
public final ActionList colorActions;
|
||||||
|
|
||||||
|
private final boolean commandsCheck;
|
||||||
|
|
||||||
public final boolean globalChatCheck;
|
public final boolean globalChatCheck;
|
||||||
public final boolean globalChatGlobalCheck;
|
public final boolean globalChatGlobalCheck;
|
||||||
public final boolean globalChatPlayerCheck;
|
public final boolean globalChatPlayerCheck;
|
||||||
@ -92,6 +94,8 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
public final boolean globalChatDebug;
|
public final boolean globalChatDebug;
|
||||||
public final ActionList globalChatActions;
|
public final ActionList globalChatActions;
|
||||||
|
|
||||||
|
private final boolean loginsCheck;
|
||||||
|
|
||||||
public final boolean noPwnageCheck;
|
public final boolean noPwnageCheck;
|
||||||
public final boolean noPwnageDebug;
|
public final boolean noPwnageDebug;
|
||||||
public final int noPwnageLevel;
|
public final int noPwnageLevel;
|
||||||
@ -113,13 +117,6 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
public final long noPwnageMoveTimeout;
|
public final long noPwnageMoveTimeout;
|
||||||
public final int noPwnageMoveWeight;
|
public final int noPwnageMoveWeight;
|
||||||
|
|
||||||
public final boolean noPwnageReloginCheck;
|
|
||||||
public final String noPwnageReloginKickMessage;
|
|
||||||
public final long noPwnageReloginTimeout;
|
|
||||||
public final String noPwnageReloginWarningMessage;
|
|
||||||
public final int noPwnageReloginWarningNumber;
|
|
||||||
public final long noPwnageReloginWarningTimeout;
|
|
||||||
|
|
||||||
public final boolean noPwnageRepeatCheck;
|
public final boolean noPwnageRepeatCheck;
|
||||||
public final long noPwnageRepeatTimeout;
|
public final long noPwnageRepeatTimeout;
|
||||||
public final int noPwnageRepeatWeight;
|
public final int noPwnageRepeatWeight;
|
||||||
@ -141,6 +138,15 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
|
|
||||||
public final boolean protectPlugins;
|
public final boolean protectPlugins;
|
||||||
|
|
||||||
|
|
||||||
|
public final boolean relogCheck;
|
||||||
|
public final String relogKickMessage;
|
||||||
|
public final long relogTimeout;
|
||||||
|
public final String relogWarningMessage;
|
||||||
|
public final int relogWarningNumber;
|
||||||
|
public final long relogWarningTimeout;
|
||||||
|
public ActionList relogActions;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiates a new chat configuration.
|
* Instantiates a new chat configuration.
|
||||||
*
|
*
|
||||||
@ -166,6 +172,8 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
colorCheck = config.getBoolean(ConfPaths.CHAT_COLOR_CHECK);
|
colorCheck = config.getBoolean(ConfPaths.CHAT_COLOR_CHECK);
|
||||||
colorActions = config.getActionList(ConfPaths.CHAT_COLOR_ACTIONS, Permissions.CHAT_COLOR);
|
colorActions = config.getActionList(ConfPaths.CHAT_COLOR_ACTIONS, Permissions.CHAT_COLOR);
|
||||||
|
|
||||||
|
commandsCheck = config.getBoolean(ConfPaths.CHAT_COMMANDS_CHECK);
|
||||||
|
|
||||||
globalChatCheck = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_CHECK);
|
globalChatCheck = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_CHECK);
|
||||||
globalChatGlobalCheck = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_GL_CHECK, true);
|
globalChatGlobalCheck = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_GL_CHECK, true);
|
||||||
globalChatPlayerCheck = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_PP_CHECK, true);
|
globalChatPlayerCheck = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_PP_CHECK, true);
|
||||||
@ -179,6 +187,8 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
globalChatDebug = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_DEBUG, false);
|
globalChatDebug = config.getBoolean(ConfPaths.CHAT_GLOBALCHAT_DEBUG, false);
|
||||||
globalChatActions = config.getActionList(ConfPaths.CHAT_GLOBALCHAT_ACTIONS, Permissions.CHAT_GLOBALCHAT);
|
globalChatActions = config.getActionList(ConfPaths.CHAT_GLOBALCHAT_ACTIONS, Permissions.CHAT_GLOBALCHAT);
|
||||||
|
|
||||||
|
loginsCheck = config.getBoolean(ConfPaths.CHAT_LOGINS_CHECK);
|
||||||
|
|
||||||
noPwnageCheck = config.getBoolean(ConfPaths.CHAT_NOPWNAGE_CHECK);
|
noPwnageCheck = config.getBoolean(ConfPaths.CHAT_NOPWNAGE_CHECK);
|
||||||
noPwnageDebug = config.getBoolean(ConfPaths.CHAT_NOPWNAGE_DEBUG, false);
|
noPwnageDebug = config.getBoolean(ConfPaths.CHAT_NOPWNAGE_DEBUG, false);
|
||||||
noPwnageLevel = config.getInt(ConfPaths.CHAT_NOPWNAGE_LEVEL);
|
noPwnageLevel = config.getInt(ConfPaths.CHAT_NOPWNAGE_LEVEL);
|
||||||
@ -201,13 +211,6 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
noPwnageMoveTimeout = config.getLong(ConfPaths.CHAT_NOPWNAGE_MOVE_TIMEOUT);
|
noPwnageMoveTimeout = config.getLong(ConfPaths.CHAT_NOPWNAGE_MOVE_TIMEOUT);
|
||||||
noPwnageMoveWeight = config.getInt(ConfPaths.CHAT_NOPWNAGE_MOVE_WEIGHT);
|
noPwnageMoveWeight = config.getInt(ConfPaths.CHAT_NOPWNAGE_MOVE_WEIGHT);
|
||||||
|
|
||||||
noPwnageReloginCheck = config.getBoolean(ConfPaths.CHAT_NOPWNAGE_RELOGIN_CHECK);
|
|
||||||
noPwnageReloginKickMessage = config.getString(ConfPaths.CHAT_NOPWNAGE_RELOGIN_KICKMESSAGE);
|
|
||||||
noPwnageReloginTimeout = config.getLong(ConfPaths.CHAT_NOPWNAGE_RELOGIN_TIMEOUT);
|
|
||||||
noPwnageReloginWarningMessage = config.getString(ConfPaths.CHAT_NOPWNAGE_RELOGIN_WARNING_MESSAGE);
|
|
||||||
noPwnageReloginWarningNumber = config.getInt(ConfPaths.CHAT_NOPWNAGE_RELOGIN_WARNING_NUMBER);
|
|
||||||
noPwnageReloginWarningTimeout = config.getLong(ConfPaths.CHAT_NOPWNAGE_RELOGIN_WARNING_TIMEOUT);
|
|
||||||
|
|
||||||
noPwnageRepeatCheck = config.getBoolean(ConfPaths.CHAT_NOPWNAGE_REPEAT_CHECK);
|
noPwnageRepeatCheck = config.getBoolean(ConfPaths.CHAT_NOPWNAGE_REPEAT_CHECK);
|
||||||
noPwnageRepeatTimeout = config.getLong(ConfPaths.CHAT_NOPWNAGE_REPEAT_TIMEOUT);
|
noPwnageRepeatTimeout = config.getLong(ConfPaths.CHAT_NOPWNAGE_REPEAT_TIMEOUT);
|
||||||
noPwnageRepeatWeight = config.getInt(ConfPaths.CHAT_NOPWNAGE_REPEAT_WEIGHT);
|
noPwnageRepeatWeight = config.getInt(ConfPaths.CHAT_NOPWNAGE_REPEAT_WEIGHT);
|
||||||
@ -225,6 +228,14 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
|
|
||||||
noPwnageActions = config.getActionList(ConfPaths.CHAT_NOPWNAGE_ACTIONS, Permissions.CHAT_NOPWNAGE);
|
noPwnageActions = config.getActionList(ConfPaths.CHAT_NOPWNAGE_ACTIONS, Permissions.CHAT_NOPWNAGE);
|
||||||
|
|
||||||
|
relogCheck = config.getBoolean(ConfPaths.CHAT_RELOG_CHECK);
|
||||||
|
relogKickMessage = config.getString(ConfPaths.CHAT_RELOG_KICKMESSAGE);
|
||||||
|
relogTimeout = config.getLong(ConfPaths.CHAT_RELOG_TIMEOUT);
|
||||||
|
relogWarningMessage = config.getString(ConfPaths.CHAT_RELOG_WARNING_MESSAGE);
|
||||||
|
relogWarningNumber = config.getInt(ConfPaths.CHAT_RELOG_WARNING_NUMBER);
|
||||||
|
relogWarningTimeout = config.getLong(ConfPaths.CHAT_RELOG_WARNING_TIMEOUT);
|
||||||
|
relogActions = config.getActionList(ConfPaths.CHAT_RELOG_ACTIONS, Permissions.CHAT_RELOG);
|
||||||
|
|
||||||
opInConsoleOnly = config.getBoolean(ConfPaths.MISCELLANEOUS_OPINCONSOLEONLY);
|
opInConsoleOnly = config.getBoolean(ConfPaths.MISCELLANEOUS_OPINCONSOLEONLY);
|
||||||
|
|
||||||
protectPlugins = config.getBoolean(ConfPaths.MISCELLANEOUS_PROTECTPLUGINS);
|
protectPlugins = config.getBoolean(ConfPaths.MISCELLANEOUS_PROTECTPLUGINS);
|
||||||
@ -242,6 +253,14 @@ public class ChatConfig extends AsyncCheckConfig {
|
|||||||
return globalChatCheck;
|
return globalChatCheck;
|
||||||
case CHAT_NOPWNAGE:
|
case CHAT_NOPWNAGE:
|
||||||
return noPwnageCheck;
|
return noPwnageCheck;
|
||||||
|
case CHAT_COMMANDS:
|
||||||
|
return commandsCheck;
|
||||||
|
case CHAT_CAPTCHA:
|
||||||
|
return captchaCheck;
|
||||||
|
case CHAT_RELOG:
|
||||||
|
return relogCheck;
|
||||||
|
case CHAT_LOGINS:
|
||||||
|
return loginsCheck;
|
||||||
default:
|
default:
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -71,6 +71,7 @@ public class ChatData extends AsyncCheckData {
|
|||||||
public double colorVL;
|
public double colorVL;
|
||||||
public double globalChatVL;
|
public double globalChatVL;
|
||||||
public double noPwnageVL;
|
public double noPwnageVL;
|
||||||
|
public double relogVL;
|
||||||
|
|
||||||
// Captcha data.
|
// Captcha data.
|
||||||
public int captchTries;
|
public int captchTries;
|
||||||
@ -81,29 +82,29 @@ public class ChatData extends AsyncCheckData {
|
|||||||
public final ActionFrequency globalChatFrequency = new ActionFrequency(10, 3000);
|
public final ActionFrequency globalChatFrequency = new ActionFrequency(10, 3000);
|
||||||
|
|
||||||
// Data of the no pwnage check.
|
// Data of the no pwnage check.
|
||||||
public long noPwnageJoinTime;
|
|
||||||
|
|
||||||
public String noPwnageLastMessage;
|
public String noPwnageLastMessage;
|
||||||
public long noPwnageLastMessageTime;
|
public long noPwnageLastMessageTime;
|
||||||
public long noPwnageLastWarningTime;
|
public long noPwnageLastWarningTime;
|
||||||
public long noPwnageLeaveTime;
|
|
||||||
|
|
||||||
|
|
||||||
public int noPwnageReloginWarnings;
|
|
||||||
public long noPwnageReloginWarningTime;
|
|
||||||
|
|
||||||
public final ActionFrequency noPwnageSpeed = new ActionFrequency(5, 1000);
|
public final ActionFrequency noPwnageSpeed = new ActionFrequency(5, 1000);
|
||||||
|
|
||||||
|
public int relogWarnings;
|
||||||
|
public long relogWarningTime;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clear the data of the no pwnage check.
|
* Clear the data of the no pwnage check.
|
||||||
*/
|
*/
|
||||||
public synchronized void clearNoPwnageData() {
|
public synchronized void clearNoPwnageData() {
|
||||||
captchTries = noPwnageReloginWarnings = 0;
|
captchTries = relogWarnings = 0;
|
||||||
captchaVL = 0D;
|
captchaVL = 0D;
|
||||||
// colorVL <- is spared to avoid problems with spam + captcha success.
|
// colorVL <- is spared to avoid problems with spam + captcha success.
|
||||||
noPwnageVL = 0;
|
noPwnageVL = 0;
|
||||||
noPwnageSpeed.clear(System.currentTimeMillis());
|
noPwnageSpeed.clear(System.currentTimeMillis());
|
||||||
noPwnageJoinTime = noPwnageLastMessageTime = noPwnageLastWarningTime = noPwnageLeaveTime = noPwnageReloginWarningTime = 0L;
|
noPwnageLastMessageTime = noPwnageLastWarningTime = relogWarningTime = 0L;
|
||||||
captchaGenerated = noPwnageLastMessage = "";
|
captchaGenerated = noPwnageLastMessage = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,6 +53,8 @@ public class ChatListener implements Listener, INotifyReload {
|
|||||||
|
|
||||||
private final SimpleCharPrefixTree chatCommands = new SimpleCharPrefixTree();
|
private final SimpleCharPrefixTree chatCommands = new SimpleCharPrefixTree();
|
||||||
|
|
||||||
|
private final Relog relog = new Relog();
|
||||||
|
|
||||||
public ChatListener(){
|
public ChatListener(){
|
||||||
ConfigFile config = ConfigManager.getConfigFile();
|
ConfigFile config = ConfigManager.getConfigFile();
|
||||||
initFilters(config);
|
initFilters(config);
|
||||||
@ -202,8 +204,8 @@ public class ChatListener implements Listener, INotifyReload {
|
|||||||
captcha.resetCaptcha(player);
|
captcha.resetCaptcha(player);
|
||||||
|
|
||||||
// Execute the no pwnage check.
|
// Execute the no pwnage check.
|
||||||
if (noPwnage.isEnabled(player) && noPwnage.checkLogin(player))
|
if (relog.isEnabled(player) && relog.checkLogin(player))
|
||||||
event.disallow(Result.KICK_OTHER, cc.noPwnageReloginKickMessage);
|
event.disallow(Result.KICK_OTHER, cc.relogKickMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(
|
@EventHandler(
|
||||||
|
@ -70,27 +70,6 @@ public class NoPwnage extends AsyncCheck{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks a player (join).
|
|
||||||
*
|
|
||||||
* Only called from the main thread.
|
|
||||||
*
|
|
||||||
* @param player
|
|
||||||
* the player
|
|
||||||
* @return true, if successful
|
|
||||||
*/
|
|
||||||
public boolean checkLogin(final Player player) {
|
|
||||||
if (!isEnabled(player))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
final ChatConfig cc = ChatConfig.getConfig(player);
|
|
||||||
final ChatData data = ChatData.getData(player);
|
|
||||||
|
|
||||||
// Keep related to ChatData/NoPwnage/Color used lock.
|
|
||||||
synchronized (data) {
|
|
||||||
return unsafeLoginCheck(player, cc, data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Only to be called form synchronized code.
|
* Only to be called form synchronized code.
|
||||||
@ -120,6 +99,8 @@ public class NoPwnage extends AsyncCheck{
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CombinedData cData = CombinedData.getData(player);
|
||||||
|
|
||||||
int suspicion = 0;
|
int suspicion = 0;
|
||||||
// NoPwnage will remember the last message that caused someone to get banned. If a player repeats that
|
// NoPwnage will remember the last message that caused someone to get banned. If a player repeats that
|
||||||
// message within "timeout" milliseconds, the suspicion will be increased by "weight".
|
// message within "timeout" milliseconds, the suspicion will be increased by "weight".
|
||||||
@ -129,7 +110,7 @@ public class NoPwnage extends AsyncCheck{
|
|||||||
|
|
||||||
// NoPwnage will check if a player sends his first message within "timeout" milliseconds after his login. If
|
// NoPwnage will check if a player sends his first message within "timeout" milliseconds after his login. If
|
||||||
// he does, increase suspicion by "weight".
|
// he does, increase suspicion by "weight".
|
||||||
if (cc.noPwnageFirstCheck && now - data.noPwnageJoinTime < cc.noPwnageFirstTimeout)
|
if (cc.noPwnageFirstCheck && now - cData.lastJoinTime < cc.noPwnageFirstTimeout)
|
||||||
suspicion += cc.noPwnageFirstWeight;
|
suspicion += cc.noPwnageFirstWeight;
|
||||||
|
|
||||||
// NoPwnage will check if a player repeats a message that has been sent by another player just before,
|
// NoPwnage will check if a player repeats a message that has been sent by another player just before,
|
||||||
@ -159,7 +140,7 @@ public class NoPwnage extends AsyncCheck{
|
|||||||
|
|
||||||
// NoPwnage will check if a player moved within the "timeout" timeframe. If he did not move, the suspicion will
|
// NoPwnage will check if a player moved within the "timeout" timeframe. If he did not move, the suspicion will
|
||||||
// be increased by "weight" value.
|
// be increased by "weight" value.
|
||||||
if (!isCommand && cc.noPwnageMoveCheck && now - CombinedData.getData(player).lastMoveTime > cc.noPwnageMoveTimeout)
|
if (!isCommand && cc.noPwnageMoveCheck && now - cData.lastMoveTime > cc.noPwnageMoveTimeout)
|
||||||
suspicion += cc.noPwnageMoveWeight;
|
suspicion += cc.noPwnageMoveWeight;
|
||||||
|
|
||||||
// Should a player that reaches the "warnLevel" get a text message telling him that he is under suspicion of
|
// Should a player that reaches the "warnLevel" get a text message telling him that he is under suspicion of
|
||||||
@ -211,42 +192,7 @@ public class NoPwnage extends AsyncCheck{
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check (Join), only call from synchronized code.
|
|
||||||
*
|
|
||||||
* @param player
|
|
||||||
* the player
|
|
||||||
* @param cc
|
|
||||||
* the cc
|
|
||||||
* @param data
|
|
||||||
* the data
|
|
||||||
* @return true, if successful
|
|
||||||
*/
|
|
||||||
private boolean unsafeLoginCheck(final Player player, final ChatConfig cc, final ChatData data) {
|
|
||||||
boolean cancel = false;
|
|
||||||
|
|
||||||
final long now = System.currentTimeMillis();
|
|
||||||
|
|
||||||
// NoPwnage will remember the time when a player leaves the server. If he returns within "time" milliseconds, he
|
|
||||||
// will get warned. If he has been warned "warnings" times already, the "commands" will be executed for him.
|
|
||||||
// Warnings get removed if the time of the last warning was more than "timeout" milliseconds ago.
|
|
||||||
if (cc.noPwnageReloginCheck && now - data.noPwnageLeaveTime < cc.noPwnageReloginTimeout) {
|
|
||||||
if (now - data.noPwnageReloginWarningTime > cc.noPwnageReloginWarningTimeout)
|
|
||||||
data.noPwnageReloginWarnings = 0;
|
|
||||||
if (data.noPwnageReloginWarnings < cc.noPwnageReloginWarningNumber) {
|
|
||||||
player.sendMessage(CheckUtils.replaceColors(cc.noPwnageReloginWarningMessage));
|
|
||||||
data.noPwnageReloginWarningTime = now;
|
|
||||||
data.noPwnageReloginWarnings++;
|
|
||||||
} else if (now - data.noPwnageReloginWarningTime < cc.noPwnageReloginWarningTimeout)
|
|
||||||
// Find out if we need to ban the player or not.
|
|
||||||
cancel = executeActions(player, (double) data.noPwnageVL, 0D, cc.noPwnageActions, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Store his joining time.
|
|
||||||
data.noPwnageJoinTime = now;
|
|
||||||
|
|
||||||
return cancel;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Map<ParameterName, String> getParameterMap(final ViolationData violationData) {
|
protected Map<ParameterName, String> getParameterMap(final ViolationData violationData) {
|
||||||
|
@ -1,7 +1,11 @@
|
|||||||
package fr.neatmonster.nocheatplus.checks.chat;
|
package fr.neatmonster.nocheatplus.checks.chat;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import fr.neatmonster.nocheatplus.checks.Check;
|
import fr.neatmonster.nocheatplus.checks.Check;
|
||||||
import fr.neatmonster.nocheatplus.checks.CheckType;
|
import fr.neatmonster.nocheatplus.checks.CheckType;
|
||||||
|
import fr.neatmonster.nocheatplus.checks.combined.CombinedData;
|
||||||
|
import fr.neatmonster.nocheatplus.utilities.CheckUtils;
|
||||||
|
|
||||||
public class Relog extends Check {
|
public class Relog extends Check {
|
||||||
|
|
||||||
@ -9,4 +13,66 @@ public class Relog extends Check {
|
|||||||
super(CheckType.CHAT_RELOG);
|
super(CheckType.CHAT_RELOG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks a player (join).
|
||||||
|
*
|
||||||
|
* Only called from the main thread.
|
||||||
|
*
|
||||||
|
* @param player
|
||||||
|
* the player
|
||||||
|
* @return true, if successful
|
||||||
|
*/
|
||||||
|
public boolean checkLogin(final Player player) {
|
||||||
|
if (!isEnabled(player))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
final ChatConfig cc = ChatConfig.getConfig(player);
|
||||||
|
final ChatData data = ChatData.getData(player);
|
||||||
|
|
||||||
|
// Keep related to ChatData/NoPwnage/Color used lock.
|
||||||
|
synchronized (data) {
|
||||||
|
return unsafeLoginCheck(player, cc, data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check (Join), only call from synchronized code.
|
||||||
|
*
|
||||||
|
* @param player
|
||||||
|
* the player
|
||||||
|
* @param cc
|
||||||
|
* the cc
|
||||||
|
* @param data
|
||||||
|
* the data
|
||||||
|
* @return true, if successful
|
||||||
|
*/
|
||||||
|
private boolean unsafeLoginCheck(final Player player, final ChatConfig cc, final ChatData data) {
|
||||||
|
boolean cancel = false;
|
||||||
|
|
||||||
|
final long now = System.currentTimeMillis();
|
||||||
|
|
||||||
|
final CombinedData cData = CombinedData.getData(player);
|
||||||
|
|
||||||
|
// NoPwnage will remember the time when a player leaves the server. If he returns within "time" milliseconds, he
|
||||||
|
// will get warned. If he has been warned "warnings" times already, the "commands" will be executed for him.
|
||||||
|
// Warnings get removed if the time of the last warning was more than "timeout" milliseconds ago.
|
||||||
|
if (now - cData.lastLogoutTime < cc.relogTimeout) {
|
||||||
|
if (now - data.relogWarningTime > cc.relogWarningTimeout)
|
||||||
|
data.relogWarnings = 0;
|
||||||
|
if (data.relogWarnings < cc.relogWarningNumber) {
|
||||||
|
player.sendMessage(CheckUtils.replaceColors(cc.relogWarningMessage));
|
||||||
|
data.relogWarningTime = now;
|
||||||
|
data.relogWarnings++;
|
||||||
|
} else{
|
||||||
|
// Find out if we need to ban the player or not.
|
||||||
|
data.relogVL += 1D;
|
||||||
|
cancel = executeActions(player, (double) data.relogVL, 1D, cc.relogActions, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// TODO: decrease relog vl ?
|
||||||
|
|
||||||
|
return cancel;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -51,7 +51,6 @@ public class CombinedData extends ACheckData {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public double improbableVL = 0;
|
public double improbableVL = 0;
|
||||||
public double speedVL = 0;
|
|
||||||
|
|
||||||
public float lastYaw;
|
public float lastYaw;
|
||||||
public long lastYawTime;
|
public long lastYawTime;
|
||||||
@ -63,6 +62,10 @@ public class CombinedData extends ACheckData {
|
|||||||
|
|
||||||
public String lastWorld = "";
|
public String lastWorld = "";
|
||||||
|
|
||||||
|
public long lastJoinTime;
|
||||||
|
|
||||||
|
public long lastLogoutTime;
|
||||||
|
|
||||||
public long lastMoveTime;
|
public long lastMoveTime;
|
||||||
|
|
||||||
public CombinedData(final Player player){
|
public CombinedData(final Player player){
|
||||||
|
@ -193,6 +193,9 @@ public abstract class ConfPaths {
|
|||||||
public static final String CHAT_COLOR_CHECK = CHAT_COLOR + "active";
|
public static final String CHAT_COLOR_CHECK = CHAT_COLOR + "active";
|
||||||
public static final String CHAT_COLOR_ACTIONS = CHAT_COLOR + "actions";
|
public static final String CHAT_COLOR_ACTIONS = CHAT_COLOR + "actions";
|
||||||
|
|
||||||
|
private static final String CHAT_COMMANDS = CHAT + "commands.";
|
||||||
|
public static final String CHAT_COMMANDS_CHECK = CHAT_COMMANDS + "active";
|
||||||
|
|
||||||
// globalchat
|
// globalchat
|
||||||
private static final String CHAT_GLOBALCHAT = CHAT + "globalchat.";
|
private static final String CHAT_GLOBALCHAT = CHAT + "globalchat.";
|
||||||
public static final String CHAT_GLOBALCHAT_CHECK = CHAT_GLOBALCHAT + "active";
|
public static final String CHAT_GLOBALCHAT_CHECK = CHAT_GLOBALCHAT + "active";
|
||||||
@ -230,7 +233,10 @@ public abstract class ConfPaths {
|
|||||||
public static final String CHAT_GLOBALCHAT_PP_SIMILARITY = CHAT_GLOBALCHAT_PP + "similarity.";
|
public static final String CHAT_GLOBALCHAT_PP_SIMILARITY = CHAT_GLOBALCHAT_PP + "similarity.";
|
||||||
public static final String CHAT_GLOBALCHAT_PP_SIMILARITY_CHECK = CHAT_GLOBALCHAT_PP_SIMILARITY + "active";
|
public static final String CHAT_GLOBALCHAT_PP_SIMILARITY_CHECK = CHAT_GLOBALCHAT_PP_SIMILARITY + "active";
|
||||||
// globalchat actions
|
// globalchat actions
|
||||||
public static final String CHAT_GLOBALCHAT_ACTIONS = CHAT_GLOBALCHAT + "actions";
|
public static final String CHAT_GLOBALCHAT_ACTIONS = CHAT_GLOBALCHAT + "actions";
|
||||||
|
|
||||||
|
private static final String CHAT_LOGINS = CHAT + "logins.";
|
||||||
|
public static final String CHAT_LOGINS_CHECK = CHAT_LOGINS + "active";
|
||||||
|
|
||||||
// nopwnage
|
// nopwnage
|
||||||
private static final String CHAT_NOPWNAGE = CHAT + "nopwnage.";
|
private static final String CHAT_NOPWNAGE = CHAT + "nopwnage.";
|
||||||
@ -260,16 +266,6 @@ public abstract class ConfPaths {
|
|||||||
public static final String CHAT_NOPWNAGE_MOVE_TIMEOUT = CHAT_NOPWNAGE_MOVE + "timeout";
|
public static final String CHAT_NOPWNAGE_MOVE_TIMEOUT = CHAT_NOPWNAGE_MOVE + "timeout";
|
||||||
public static final String CHAT_NOPWNAGE_MOVE_WEIGHT = CHAT_NOPWNAGE_MOVE + "weight";
|
public static final String CHAT_NOPWNAGE_MOVE_WEIGHT = CHAT_NOPWNAGE_MOVE + "weight";
|
||||||
|
|
||||||
private static final String CHAT_NOPWNAGE_RELOGIN = CHAT_NOPWNAGE + "relogin.";
|
|
||||||
public static final String CHAT_NOPWNAGE_RELOGIN_CHECK = CHAT_NOPWNAGE_RELOGIN + "active";
|
|
||||||
public static final String CHAT_NOPWNAGE_RELOGIN_KICKMESSAGE = CHAT_NOPWNAGE_RELOGIN + "kickmessage";
|
|
||||||
public static final String CHAT_NOPWNAGE_RELOGIN_TIMEOUT = CHAT_NOPWNAGE_RELOGIN + "timeout";
|
|
||||||
|
|
||||||
private static final String CHAT_NOPWNAGE_RELOGIN_WARNING = CHAT_NOPWNAGE_RELOGIN + "warning.";
|
|
||||||
public static final String CHAT_NOPWNAGE_RELOGIN_WARNING_MESSAGE = CHAT_NOPWNAGE_RELOGIN_WARNING + "message";
|
|
||||||
public static final String CHAT_NOPWNAGE_RELOGIN_WARNING_NUMBER = CHAT_NOPWNAGE_RELOGIN_WARNING + "number";
|
|
||||||
public static final String CHAT_NOPWNAGE_RELOGIN_WARNING_TIMEOUT = CHAT_NOPWNAGE_RELOGIN_WARNING + "timeout";
|
|
||||||
|
|
||||||
private static final String CHAT_NOPWNAGE_REPEAT = CHAT_NOPWNAGE + "repeat.";
|
private static final String CHAT_NOPWNAGE_REPEAT = CHAT_NOPWNAGE + "repeat.";
|
||||||
public static final String CHAT_NOPWNAGE_REPEAT_CHECK = CHAT_NOPWNAGE_REPEAT + "active";
|
public static final String CHAT_NOPWNAGE_REPEAT_CHECK = CHAT_NOPWNAGE_REPEAT + "active";
|
||||||
public static final String CHAT_NOPWNAGE_REPEAT_TIMEOUT = CHAT_NOPWNAGE_REPEAT + "timeout";
|
public static final String CHAT_NOPWNAGE_REPEAT_TIMEOUT = CHAT_NOPWNAGE_REPEAT + "timeout";
|
||||||
@ -297,6 +293,16 @@ public abstract class ConfPaths {
|
|||||||
|
|
||||||
public static final String CHAT_NOPWNAGE_ACTIONS = CHAT_NOPWNAGE + "actions";
|
public static final String CHAT_NOPWNAGE_ACTIONS = CHAT_NOPWNAGE + "actions";
|
||||||
|
|
||||||
|
private static final String CHAT_RELOG = CHAT + "relog.";
|
||||||
|
public static final String CHAT_RELOG_CHECK = CHAT_RELOG + "active";
|
||||||
|
public static final String CHAT_RELOG_KICKMESSAGE = CHAT_RELOG + "kickmessage";
|
||||||
|
public static final String CHAT_RELOG_TIMEOUT = CHAT_RELOG + "timeout";
|
||||||
|
private static final String CHAT_RELOG_WARNING = CHAT_RELOG + "warning.";
|
||||||
|
public static final String CHAT_RELOG_WARNING_MESSAGE = CHAT_RELOG_WARNING + "message";
|
||||||
|
public static final String CHAT_RELOG_WARNING_NUMBER = CHAT_RELOG_WARNING + "number";
|
||||||
|
public static final String CHAT_RELOG_WARNING_TIMEOUT = CHAT_RELOG_WARNING + "timeout";
|
||||||
|
public static final String CHAT_RELOG_ACTIONS = CHAT_RELOG + "actions";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Combined !
|
* Combined !
|
||||||
*/
|
*/
|
||||||
|
@ -200,15 +200,6 @@ public class DefaultConfig extends ConfigFile {
|
|||||||
set(ConfPaths.CHAT_NOPWNAGE_MOVE_TIMEOUT, 30000L);
|
set(ConfPaths.CHAT_NOPWNAGE_MOVE_TIMEOUT, 30000L);
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_MOVE_WEIGHT, 200);
|
set(ConfPaths.CHAT_NOPWNAGE_MOVE_WEIGHT, 200);
|
||||||
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_RELOGIN_CHECK, true);
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_RELOGIN_TIMEOUT, 1500L);
|
|
||||||
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_RELOGIN_WARNING_MESSAGE,
|
|
||||||
"&cYou relogged really fast! If you keep doing that, you're going to be banned.");
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_RELOGIN_WARNING_NUMBER, 1);
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_RELOGIN_KICKMESSAGE, "You've relogged too fast, joining cancelled!");
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_RELOGIN_WARNING_TIMEOUT, 60000L);
|
|
||||||
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_REPEAT_CHECK, true);
|
set(ConfPaths.CHAT_NOPWNAGE_REPEAT_CHECK, true);
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_REPEAT_TIMEOUT, 5000L);
|
set(ConfPaths.CHAT_NOPWNAGE_REPEAT_TIMEOUT, 5000L);
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_REPEAT_WEIGHT, 150);
|
set(ConfPaths.CHAT_NOPWNAGE_REPEAT_WEIGHT, 150);
|
||||||
@ -229,6 +220,14 @@ public class DefaultConfig extends ConfigFile {
|
|||||||
|
|
||||||
set(ConfPaths.CHAT_NOPWNAGE_ACTIONS, "cancel log:nopwnage:0:5:cf cmd:kicknopwnage vl>150 cancel log:nopwnage:0:5:cf cmd:tempkick5");
|
set(ConfPaths.CHAT_NOPWNAGE_ACTIONS, "cancel log:nopwnage:0:5:cf cmd:kicknopwnage vl>150 cancel log:nopwnage:0:5:cf cmd:tempkick5");
|
||||||
|
|
||||||
|
// Reload
|
||||||
|
set(ConfPaths.CHAT_RELOG_CHECK, true);
|
||||||
|
set(ConfPaths.CHAT_RELOG_TIMEOUT, 1500L);
|
||||||
|
set(ConfPaths.CHAT_RELOG_WARNING_MESSAGE, "&cYou relogged really fast! If you keep doing that, you're going to be banned.");
|
||||||
|
set(ConfPaths.CHAT_RELOG_WARNING_NUMBER, 1);
|
||||||
|
set(ConfPaths.CHAT_RELOG_KICKMESSAGE, "You've relogged too fast, joining cancelled!");
|
||||||
|
set(ConfPaths.CHAT_RELOG_WARNING_TIMEOUT, 60000L);
|
||||||
|
set(ConfPaths.CHAT_RELOG_ACTIONS, "log:relog:0:10 cancel vl>20 log:relog:0:10 cancel tempkick5");
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Combined !
|
* Combined !
|
||||||
@ -414,6 +413,7 @@ public class DefaultConfig extends ConfigFile {
|
|||||||
set(ConfPaths.STRINGS + ".nopwnage", start + "acted like spamming (IP: [ip])" + end);
|
set(ConfPaths.STRINGS + ".nopwnage", start + "acted like spamming (IP: [ip])" + end);
|
||||||
set(ConfPaths.STRINGS + ".noswing", start + "didn't swing arm" + end);
|
set(ConfPaths.STRINGS + ".noswing", start + "didn't swing arm" + end);
|
||||||
set(ConfPaths.STRINGS + ".passable", start + "moved into a block ([blockid])" + end);
|
set(ConfPaths.STRINGS + ".passable", start + "moved into a block ([blockid])" + end);
|
||||||
|
set(ConfPaths.STRINGS + ".relog", start + "relogs too fast" + end);
|
||||||
set(ConfPaths.STRINGS + ".tellglchat", tell + "&cNCP: &eChat can by annoying at times...");
|
set(ConfPaths.STRINGS + ".tellglchat", tell + "&cNCP: &eChat can by annoying at times...");
|
||||||
set(ConfPaths.STRINGS + ".tempkick1", "ncp tempkick [player] 1 Wait a minute!");
|
set(ConfPaths.STRINGS + ".tempkick1", "ncp tempkick [player] 1 Wait a minute!");
|
||||||
set(ConfPaths.STRINGS + ".tempkick5", "ncp tempkick [player] 5 You have five minutes to think about it!");
|
set(ConfPaths.STRINGS + ".tempkick5", "ncp tempkick [player] 5 You have five minutes to think about it!");
|
||||||
|
@ -9,6 +9,7 @@ import java.util.Map;
|
|||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.EventPriority;
|
import org.bukkit.event.EventPriority;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
@ -19,6 +20,7 @@ import org.bukkit.event.player.PlayerQuitEvent;
|
|||||||
import fr.neatmonster.nocheatplus.checks.CheckType;
|
import fr.neatmonster.nocheatplus.checks.CheckType;
|
||||||
import fr.neatmonster.nocheatplus.checks.ViolationHistory;
|
import fr.neatmonster.nocheatplus.checks.ViolationHistory;
|
||||||
import fr.neatmonster.nocheatplus.checks.access.CheckDataFactory;
|
import fr.neatmonster.nocheatplus.checks.access.CheckDataFactory;
|
||||||
|
import fr.neatmonster.nocheatplus.checks.combined.CombinedData;
|
||||||
import fr.neatmonster.nocheatplus.command.INotifyReload;
|
import fr.neatmonster.nocheatplus.command.INotifyReload;
|
||||||
import fr.neatmonster.nocheatplus.config.ConfPaths;
|
import fr.neatmonster.nocheatplus.config.ConfPaths;
|
||||||
import fr.neatmonster.nocheatplus.config.ConfigFile;
|
import fr.neatmonster.nocheatplus.config.ConfigFile;
|
||||||
@ -83,19 +85,26 @@ public class DataManager implements Listener, INotifyReload, INeedConfig{
|
|||||||
|
|
||||||
@EventHandler(priority = EventPriority.LOWEST)
|
@EventHandler(priority = EventPriority.LOWEST)
|
||||||
public void onPlayerJoin(final PlayerJoinEvent event){
|
public void onPlayerJoin(final PlayerJoinEvent event){
|
||||||
lastLogout.remove(event.getPlayer().getName());
|
final Player player = event.getPlayer();
|
||||||
|
lastLogout.remove(player.getName());
|
||||||
|
CombinedData.getData(player).lastJoinTime = System.currentTimeMillis();
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR)
|
@EventHandler(priority = EventPriority.MONITOR)
|
||||||
public void onPlayerQuit(final PlayerQuitEvent event){
|
public void onPlayerQuit(final PlayerQuitEvent event){
|
||||||
lastLogout.put(event.getPlayer().getName(), System.currentTimeMillis());
|
onLeave(event.getPlayer());
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
||||||
public void onPlayerKick(final PlayerKickEvent event){
|
public void onPlayerKick(final PlayerKickEvent event){
|
||||||
lastLogout.put(event.getPlayer().getName(), System.currentTimeMillis());
|
onLeave(event.getPlayer());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private final void onLeave(final Player player) {
|
||||||
|
final long now = System.currentTimeMillis();
|
||||||
|
lastLogout.put(player.getName(), now);
|
||||||
|
CombinedData.getData(player).lastLogoutTime = now;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onReload() {
|
public void onReload() {
|
||||||
|
Loading…
Reference in New Issue
Block a user