mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-13 11:01:20 +01:00
Process captcha for cancelled chat events as well.
This commit is contained in:
parent
4957f2875a
commit
d24a13ed12
@ -39,16 +39,16 @@ public class Captcha extends AsyncCheck implements ICaptcha{
|
||||
// Have they failed too man times?
|
||||
if (data.captchTries > cc.captchaTries) {
|
||||
// Find out if we need to kick the player or not.
|
||||
executeActions(player, data.captchaVL, 1, cc.captchaActions,
|
||||
isMainThread);
|
||||
executeActions(player, data.captchaVL, 1, cc.captchaActions, isMainThread);
|
||||
// (Resetting captcha tries is done on quit/kick).
|
||||
}
|
||||
|
||||
// Display the question again (if not kicked).
|
||||
if (player.isOnline())
|
||||
if (player.isOnline()) {
|
||||
sendCaptcha(player, cc, data);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendNewCaptcha(Player player, ChatConfig cc, ChatData data) {
|
||||
|
@ -121,53 +121,37 @@ public class ChatListener extends CheckListener implements INotifyReload, JoinLe
|
||||
* @param event
|
||||
* the event
|
||||
*/
|
||||
@EventHandler(
|
||||
ignoreCancelled = true, priority = EventPriority.LOWEST)
|
||||
@EventHandler(ignoreCancelled = false, priority = EventPriority.LOWEST)
|
||||
public void onPlayerChat(final AsyncPlayerChatEvent event) {
|
||||
/*
|
||||
* ____ _ ____ _ _
|
||||
* | _ \| | __ _ _ _ ___ _ __ / ___| |__ __ _| |_
|
||||
* | |_) | |/ _` | | | |/ _ \ '__| | | | '_ \ / _` | __|
|
||||
* | __/| | (_| | |_| | __/ | | |___| | | | (_| | |_
|
||||
* |_| |_|\__,_|\__, |\___|_| \____|_| |_|\__,_|\__|
|
||||
* |___/
|
||||
*/
|
||||
|
||||
final Player player = event.getPlayer();
|
||||
final boolean alreadyCancelled = event.isCancelled();
|
||||
|
||||
// Tell TickTask to update cached permissions.
|
||||
// (Might omit this if already cancelled.)
|
||||
TickTask.requestPermissionUpdate(player.getName(), CheckType.CHAT);
|
||||
|
||||
// First the color check.
|
||||
if (color.isEnabled(player)) event.setMessage(color.check(player, event.getMessage(), false));
|
||||
if (!alreadyCancelled && color.isEnabled(player)) {
|
||||
event.setMessage(color.check(player, event.getMessage(), false));
|
||||
}
|
||||
|
||||
// Then the no chat check.
|
||||
if (text.isEnabled(player) && text.check(player, event.getMessage(), captcha, false))
|
||||
// TODO: isMainThread: Could consider event.isAsync ?
|
||||
if (textChecks(player, event.getMessage(), false, alreadyCancelled)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* We listen to PlayerCommandPreprocess events because commands can be used for spamming too.
|
||||
*
|
||||
* @param event
|
||||
* the event
|
||||
*/
|
||||
@EventHandler(
|
||||
priority = EventPriority.LOWEST)
|
||||
@EventHandler(priority = EventPriority.LOWEST)
|
||||
public void onPlayerCommandPreprocess(final PlayerCommandPreprocessEvent event) {
|
||||
/*
|
||||
* ____ _ ____ _
|
||||
* | _ \| | __ _ _ _ ___ _ __ / ___|___ _ __ ___ _ __ ___ __ _ _ __ __| |
|
||||
* | |_) | |/ _` | | | |/ _ \ '__| | | / _ \| '_ ` _ \| '_ ` _ \ / _` | '_ \ / _` |
|
||||
* | __/| | (_| | |_| | __/ | | |__| (_) | | | | | | | | | | | (_| | | | | (_| |
|
||||
* |_| |_|\__,_|\__, |\___|_| \____\___/|_| |_| |_|_| |_| |_|\__,_|_| |_|\__,_|
|
||||
* |___/
|
||||
* ____
|
||||
* | _ \ _ __ ___ _ __ _ __ ___ ___ ___ ___ ___
|
||||
* | |_) | '__/ _ \ '_ \| '__/ _ \ / __/ _ \/ __/ __|
|
||||
* | __/| | | __/ |_) | | | (_) | (_| __/\__ \__ \
|
||||
* |_| |_| \___| .__/|_| \___/ \___\___||___/___/
|
||||
* |_|
|
||||
*/
|
||||
final Player player = event.getPlayer();
|
||||
|
||||
// Tell TickTask to update cached permissions.
|
||||
@ -207,18 +191,25 @@ public class ChatListener extends CheckListener implements INotifyReload, JoinLe
|
||||
final boolean handleAsChat = chatCommands.hasAnyPrefixWords(lcMessage, lcAltMessage);
|
||||
if (handleAsChat){
|
||||
// Treat as chat.
|
||||
// TODO: At least cut off the command (!).
|
||||
if (text.isEnabled(player) && text.check(player, message, captcha, true))
|
||||
// TODO: Consider requesting permission updates on these, for consistency.
|
||||
// TODO: Cut off the command (?).
|
||||
if (textChecks(player, message, true, false)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
else if (!commandExclusions.hasAnyPrefixWords(lcMessage, lcAltMessage)){
|
||||
// Treat as command.
|
||||
if (commands.isEnabled(player) && commands.check(player, message, captcha))
|
||||
if (commands.isEnabled(player) && commands.check(player, message, captcha)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private boolean textChecks(final Player player, final String message, final boolean isMainThread, final boolean alreadyCancelled) {
|
||||
return text.isEnabled(player) && text.check(player, message, captcha, isMainThread, alreadyCancelled);
|
||||
}
|
||||
|
||||
/**
|
||||
* We listen to this type of events to prevent spambots from login to the server.
|
||||
*
|
||||
|
@ -53,15 +53,16 @@ public class Text extends AsyncCheck implements INotifyReload{
|
||||
* The message to check.
|
||||
* @param captcha
|
||||
* Used for starting captcha on failure, if configured so.
|
||||
* @param alreadyCancelled
|
||||
* @return
|
||||
*/
|
||||
public boolean check(final Player player, final String message, final ICaptcha captcha, boolean isMainThread) {
|
||||
public boolean check(final Player player, final String message, final ICaptcha captcha, boolean isMainThread, final boolean alreadyCancelled) {
|
||||
|
||||
final ChatConfig cc = ChatConfig.getConfig(player);
|
||||
final ChatData data = ChatData.getData(player);
|
||||
|
||||
synchronized (data) {
|
||||
return unsafeCheck(player, message, captcha, cc, data, isMainThread);
|
||||
return unsafeCheck(player, message, captcha, cc, data, isMainThread, alreadyCancelled);
|
||||
}
|
||||
}
|
||||
|
||||
@ -93,15 +94,20 @@ public class Text extends AsyncCheck implements INotifyReload{
|
||||
* @param cc
|
||||
* @param data
|
||||
* @param isMainThread
|
||||
* @param alreadyCancelled
|
||||
* @return
|
||||
*/
|
||||
private boolean unsafeCheck(final Player player, final String message, final ICaptcha captcha,
|
||||
final ChatConfig cc, final ChatData data, boolean isMainThread) {
|
||||
final ChatConfig cc, final ChatData data, boolean isMainThread, final boolean alreadyCancelled) {
|
||||
|
||||
// Test captcha.
|
||||
if (captcha.shouldCheckCaptcha(cc, data)){
|
||||
// TODO: Skip captcha for "handleaschat" commands? [controversial potential]
|
||||
if (captcha.shouldCheckCaptcha(cc, data)) {
|
||||
captcha.checkCaptcha(player, message, cc, data, isMainThread);
|
||||
return true;
|
||||
} else if (alreadyCancelled) {
|
||||
// Skip checking.
|
||||
return true;
|
||||
}
|
||||
|
||||
// Take time once:
|
||||
|
Loading…
Reference in New Issue
Block a user