mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-03 22:37:44 +01:00
Remove old compatibility workaround (skipnext).
This commit is contained in:
parent
20065d0baf
commit
12f8d3036e
@ -79,8 +79,6 @@ public class FightData extends ACheckData {
|
||||
public double reachVL;
|
||||
public double speedVL;
|
||||
|
||||
public boolean skipNext;
|
||||
|
||||
public long damageTakenTick;
|
||||
|
||||
// Shared
|
||||
|
@ -62,43 +62,22 @@ public class FightListener implements Listener {
|
||||
/** The speed check. */
|
||||
private final Speed speed = new Speed();
|
||||
|
||||
/**
|
||||
* There is an unofficial agreement that if a plugin wants an attack to not get checked by NoCheatPlus, it either
|
||||
* has to use a damage type different from ENTITY_ATTACK or fire an event with damage type CUSTOM and damage 0
|
||||
* directly before the to-be-ignored event.
|
||||
*
|
||||
* @param event
|
||||
* the event
|
||||
*/
|
||||
private void handleCustomDamage(final EntityDamageByEntityEvent event) {
|
||||
if (event.getDamager() instanceof Player)
|
||||
// Skip the next damage event, because it is with high probability something from the Heroes plugin.
|
||||
FightData.getData((Player) event.getDamager()).skipNext = true;
|
||||
}
|
||||
|
||||
/**
|
||||
* A player attacked something with DamageCause ENTITY_ATTACK. That's most likely what we want to really check.
|
||||
*
|
||||
* @param event
|
||||
* The EntityDamageByEntityEvent
|
||||
* @return
|
||||
*/
|
||||
private void handleNormalDamage(final EntityDamageByEntityEvent event) {
|
||||
final Player player = (Player) event.getDamager();
|
||||
private boolean handleNormalDamage(final Player player, final Entity cbEntity) {
|
||||
final FightConfig cc = FightConfig.getConfig(player);
|
||||
final FightData data = FightData.getData(player);
|
||||
|
||||
// For some reason we decided to skip this event anyway.
|
||||
if (data.skipNext) {
|
||||
data.skipNext = false;
|
||||
return;
|
||||
}
|
||||
|
||||
boolean cancelled = false;
|
||||
|
||||
final String worldName = player.getWorld().getName();
|
||||
|
||||
// Check for self hit exploits (mind that projectiles should be excluded)
|
||||
final Entity cbEntity = event.getEntity();
|
||||
if (cbEntity instanceof Player){
|
||||
final Player damagedPlayer = (Player) cbEntity;
|
||||
if (selfHit.isEnabled(player) && selfHit.check(player, damagedPlayer, data, cc))
|
||||
@ -162,11 +141,8 @@ public class FightListener implements Listener {
|
||||
if (!cancelled && player.isBlocking() && !player.hasPermission(Permissions.MOVING_SURVIVALFLY_BLOCKING))
|
||||
cancelled = true;
|
||||
|
||||
// One of the checks requested the event to be cancelled, so do it.
|
||||
if (cancelled)
|
||||
event.setCancelled(cancelled);
|
||||
|
||||
data.lastWorld = worldName;
|
||||
return cancelled;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -191,15 +167,15 @@ public class FightListener implements Listener {
|
||||
final EntityDamageByEntityEvent e = (EntityDamageByEntityEvent) event;
|
||||
final Entity damaged = e.getEntity();
|
||||
if (damaged instanceof Player){
|
||||
// TODO: check once more when to set this (!) in terms of order.
|
||||
FightData.getData((Player) damaged).damageTakenTick = TickTask.getTick();
|
||||
}
|
||||
|
||||
if (e.getDamager() instanceof Player){
|
||||
final Entity damager = e.getDamager();
|
||||
if (damager instanceof Player){
|
||||
final Player player = (Player) damager;
|
||||
if (e.getCause() == DamageCause.ENTITY_ATTACK){
|
||||
handleNormalDamage(e);
|
||||
if (handleNormalDamage(player, damaged)) e.setCancelled(true);
|
||||
}
|
||||
else if (e.getCause() == DamageCause.CUSTOM)
|
||||
handleCustomDamage(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user