mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-21 06:51:26 +01:00
Fix issue with replacing broken blocks.
This commit is contained in:
parent
c1195c630a
commit
19ca256c30
@ -75,34 +75,48 @@ public class BlockBreakListener implements Listener {
|
|||||||
|
|
||||||
// Do the actual checks, if still needed. It's a good idea to make computationally cheap checks first, because
|
// Do the actual checks, if still needed. It's a good idea to make computationally cheap checks first, because
|
||||||
// it may save us from doing the computationally expensive checks.
|
// it may save us from doing the computationally expensive checks.
|
||||||
|
|
||||||
|
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
|
||||||
|
final BlockBreakData data = BlockBreakData.getData(player);
|
||||||
|
final long now = System.currentTimeMillis();
|
||||||
|
|
||||||
// Has the player broken a block that was not damaged before?
|
// Has the player broken a block that was not damaged before?
|
||||||
if (wrongBlock.isEnabled(player) && wrongBlock.check(player, block))
|
if (wrongBlock.isEnabled(player) && wrongBlock.check(player, block, cc, data))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
// Has the player broken more blocks per second than allowed?
|
// Has the player broken more blocks per second than allowed?
|
||||||
if (!cancelled && frequency.isEnabled(player) && frequency.check(player))
|
if (!cancelled && frequency.isEnabled(player) && frequency.check(player, cc, data))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
// Has the player broken blocks faster than possible?
|
// Has the player broken blocks faster than possible?
|
||||||
if (!cancelled && fastBreak.isEnabled(player) && fastBreak.check(player, block))
|
if (!cancelled && fastBreak.isEnabled(player) && fastBreak.check(player, block, cc, data))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
// Did the arm of the player move before breaking this block?
|
// Did the arm of the player move before breaking this block?
|
||||||
if (!cancelled && noSwing.isEnabled(player) && noSwing.check(player))
|
if (!cancelled && noSwing.isEnabled(player) && noSwing.check(player, data))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
// Is the block really in reach distance?
|
// Is the block really in reach distance?
|
||||||
if (!cancelled && reach.isEnabled(player) && reach.check(player, block.getLocation()))
|
if (!cancelled && reach.isEnabled(player) && reach.check(player, block.getLocation(), data))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
// Did the player look at the block at all?
|
// Did the player look at the block at all?
|
||||||
if (!cancelled && direction.isEnabled(player) && direction.check(player, block.getLocation()))
|
if (!cancelled && direction.isEnabled(player) && direction.check(player, block.getLocation(), data))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
// At least one check failed and demanded to cancel the event.
|
// At least one check failed and demanded to cancel the event.
|
||||||
if (cancelled)
|
if (cancelled){
|
||||||
event.setCancelled(cancelled);
|
event.setCancelled(cancelled);
|
||||||
|
// Reset damage position:
|
||||||
|
data.fastBreakDamageTime = now;
|
||||||
|
data.clickedX = block.getX();
|
||||||
|
data.clickedY = block.getY();
|
||||||
|
data.clickedZ = block.getZ();
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
// Invalidate last damage position:
|
||||||
|
data.clickedX = Integer.MAX_VALUE;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,8 +38,7 @@ public class Direction extends Check {
|
|||||||
* the location
|
* the location
|
||||||
* @return true, if successful
|
* @return true, if successful
|
||||||
*/
|
*/
|
||||||
public boolean check(final Player player, final Location location) {
|
public boolean check(final Player player, final Location location, final BlockBreakData data) {
|
||||||
final BlockBreakData data = BlockBreakData.getData(player);
|
|
||||||
|
|
||||||
boolean cancel = false;
|
boolean cancel = false;
|
||||||
|
|
||||||
|
@ -38,13 +38,13 @@ public class FastBreak extends Check {
|
|||||||
* the player
|
* the player
|
||||||
* @param block
|
* @param block
|
||||||
* the block
|
* the block
|
||||||
|
* @param data
|
||||||
|
* @param cc
|
||||||
* @param elaspedTime
|
* @param elaspedTime
|
||||||
* @return true, if successful
|
* @return true, if successful
|
||||||
*/
|
*/
|
||||||
public boolean check(final Player player, final Block block) {
|
public boolean check(final Player player, final Block block, final BlockBreakConfig cc, final BlockBreakData data) {
|
||||||
final long now = System.currentTimeMillis();
|
final long now = System.currentTimeMillis();
|
||||||
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
|
|
||||||
final BlockBreakData data = BlockBreakData.getData(player);
|
|
||||||
|
|
||||||
boolean cancel = false;
|
boolean cancel = false;
|
||||||
|
|
||||||
|
@ -17,9 +17,7 @@ public class Frequency extends Check {
|
|||||||
super(CheckType.BLOCKBREAK_FREQUENCY);
|
super(CheckType.BLOCKBREAK_FREQUENCY);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean check(final Player player){
|
public boolean check(final Player player, final BlockBreakConfig cc, final BlockBreakData data){
|
||||||
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
|
|
||||||
final BlockBreakData data = BlockBreakData.getData(player);
|
|
||||||
|
|
||||||
final float interval = (float) ((player.getGameMode() == GameMode.CREATIVE)?(cc.frequencyIntervalCreative):(cc.frequencyIntervalSurvival));
|
final float interval = (float) ((player.getGameMode() == GameMode.CREATIVE)?(cc.frequencyIntervalCreative):(cc.frequencyIntervalSurvival));
|
||||||
data.frequencyBuckets.add(System.currentTimeMillis(), interval);
|
data.frequencyBuckets.add(System.currentTimeMillis(), interval);
|
||||||
|
@ -34,8 +34,7 @@ public class NoSwing extends Check {
|
|||||||
* the player
|
* the player
|
||||||
* @return true, if successful
|
* @return true, if successful
|
||||||
*/
|
*/
|
||||||
public boolean check(final Player player) {
|
public boolean check(final Player player, final BlockBreakData data) {
|
||||||
final BlockBreakData data = BlockBreakData.getData(player);
|
|
||||||
|
|
||||||
boolean cancel = false;
|
boolean cancel = false;
|
||||||
|
|
||||||
|
@ -47,8 +47,7 @@ public class Reach extends Check {
|
|||||||
* the location
|
* the location
|
||||||
* @return true, if successful
|
* @return true, if successful
|
||||||
*/
|
*/
|
||||||
public boolean check(final Player player, final Location location) {
|
public boolean check(final Player player, final Location location, final BlockBreakData data) {
|
||||||
final BlockBreakData data = BlockBreakData.getData(player);
|
|
||||||
|
|
||||||
boolean cancel = false;
|
boolean cancel = false;
|
||||||
|
|
||||||
|
@ -19,11 +19,11 @@ public class WrongBlock extends Check {
|
|||||||
* probably due to packet delaying issues for insta breaking. very effective against some nuker techniques.
|
* probably due to packet delaying issues for insta breaking. very effective against some nuker techniques.
|
||||||
* @param player
|
* @param player
|
||||||
* @param block
|
* @param block
|
||||||
|
* @param data
|
||||||
|
* @param cc
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public boolean check(final Player player, final Block block){
|
public boolean check(final Player player, final Block block, final BlockBreakConfig cc, final BlockBreakData data){
|
||||||
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
|
|
||||||
final BlockBreakData data = BlockBreakData.getData(player);
|
|
||||||
|
|
||||||
boolean cancel = false;
|
boolean cancel = false;
|
||||||
if (data.clickedX != block.getX() || data.clickedZ != block.getZ() || data.clickedY != block.getY()){
|
if (data.clickedX != block.getX() || data.clickedZ != block.getZ() || data.clickedY != block.getY()){
|
||||||
@ -33,11 +33,6 @@ public class WrongBlock extends Check {
|
|||||||
cancel = true;
|
cancel = true;
|
||||||
if (Improbable.check(player, 5.0f, now))
|
if (Improbable.check(player, 5.0f, now))
|
||||||
cancel = true;
|
cancel = true;
|
||||||
// Reset, to prevent endless violation level farming.
|
|
||||||
data.fastBreakDamageTime = now;
|
|
||||||
data.clickedX = block.getX();
|
|
||||||
data.clickedY = block.getY();
|
|
||||||
data.clickedZ = block.getZ();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return cancel;
|
return cancel;
|
||||||
|
Loading…
Reference in New Issue
Block a user