mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-03 22:37:44 +01:00
[Development] This is the result of one day of bug fixing. But there is
so many other bugs left...
This commit is contained in:
parent
b879002527
commit
06bd7c294d
2
pom.xml
2
pom.xml
@ -42,7 +42,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.bukkit</groupId>
|
<groupId>org.bukkit</groupId>
|
||||||
<artifactId>craftbukkit</artifactId>
|
<artifactId>craftbukkit</artifactId>
|
||||||
<version>1.3.1-R0.1-SNAPSHOT</version>
|
<version>1.3.1-R1.0</version>
|
||||||
<type>jar</type>
|
<type>jar</type>
|
||||||
<scope>compile</scope>
|
<scope>compile</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
@ -63,6 +63,7 @@ public class BlockBreakConfig {
|
|||||||
public final ActionList directionActions;
|
public final ActionList directionActions;
|
||||||
|
|
||||||
public final boolean fastBreakCheck;
|
public final boolean fastBreakCheck;
|
||||||
|
public final int fastBreakBuffer;
|
||||||
public final boolean fastBreakExperimental;
|
public final boolean fastBreakExperimental;
|
||||||
public final int fastBreakInterval;
|
public final int fastBreakInterval;
|
||||||
public final ActionList fastBreakActions;
|
public final ActionList fastBreakActions;
|
||||||
@ -84,6 +85,7 @@ public class BlockBreakConfig {
|
|||||||
directionActions = data.getActionList(ConfPaths.BLOCKBREAK_DIRECTION_ACTIONS, Permissions.BLOCKBREAK_DIRECTION);
|
directionActions = data.getActionList(ConfPaths.BLOCKBREAK_DIRECTION_ACTIONS, Permissions.BLOCKBREAK_DIRECTION);
|
||||||
|
|
||||||
fastBreakCheck = data.getBoolean(ConfPaths.BLOCKBREAK_FASTBREAK_CHECK);
|
fastBreakCheck = data.getBoolean(ConfPaths.BLOCKBREAK_FASTBREAK_CHECK);
|
||||||
|
fastBreakBuffer = data.getInt(ConfPaths.BLOCKBREAK_FASTBREAK_BUFFER);
|
||||||
fastBreakExperimental = data.getBoolean(ConfPaths.BLOCKBREAK_FASTBREAK_EXPERIMENTAL);
|
fastBreakExperimental = data.getBoolean(ConfPaths.BLOCKBREAK_FASTBREAK_EXPERIMENTAL);
|
||||||
fastBreakInterval = data.getInt(ConfPaths.BLOCKBREAK_FASTBREAK_INTERVAL);
|
fastBreakInterval = data.getInt(ConfPaths.BLOCKBREAK_FASTBREAK_INTERVAL);
|
||||||
fastBreakActions = data.getActionList(ConfPaths.BLOCKBREAK_FASTBREAK_ACTIONS, Permissions.BLOCKBREAK_FASTBREAK);
|
fastBreakActions = data.getActionList(ConfPaths.BLOCKBREAK_FASTBREAK_ACTIONS, Permissions.BLOCKBREAK_FASTBREAK);
|
||||||
|
@ -50,7 +50,7 @@ public class BlockBreakData {
|
|||||||
public double reachVL;
|
public double reachVL;
|
||||||
|
|
||||||
// Data of the fast break check.
|
// Data of the fast break check.
|
||||||
public int fastBreakBuffer = 3;
|
public int fastBreakBuffer = 5;
|
||||||
public long fastBreakBreakTime = System.currentTimeMillis() - 1000L;
|
public long fastBreakBreakTime = System.currentTimeMillis() - 1000L;
|
||||||
public long fastBreakDamageTime = System.currentTimeMillis();
|
public long fastBreakDamageTime = System.currentTimeMillis();
|
||||||
|
|
||||||
|
@ -95,7 +95,7 @@ public class FastBreak extends Check {
|
|||||||
data.fastBreakBuffer--;
|
data.fastBreakBuffer--;
|
||||||
} else {
|
} else {
|
||||||
// If the buffer isn't full.
|
// If the buffer isn't full.
|
||||||
if (data.fastBreakBuffer < 3)
|
if (data.fastBreakBuffer < data.fastBreakBuffer)
|
||||||
// Add one to the buffer.
|
// Add one to the buffer.
|
||||||
data.fastBreakBuffer++;
|
data.fastBreakBuffer++;
|
||||||
|
|
||||||
|
@ -62,10 +62,6 @@ public class BlockInteractConfig {
|
|||||||
public final boolean directionCheck;
|
public final boolean directionCheck;
|
||||||
public final ActionList directionActions;
|
public final ActionList directionActions;
|
||||||
|
|
||||||
public final boolean fastInteractCheck;
|
|
||||||
public final long fastInteractInterval;
|
|
||||||
public final ActionList fastInteractActions;
|
|
||||||
|
|
||||||
public final boolean noSwingCheck;
|
public final boolean noSwingCheck;
|
||||||
public final ActionList noSwingActions;
|
public final ActionList noSwingActions;
|
||||||
|
|
||||||
@ -83,11 +79,6 @@ public class BlockInteractConfig {
|
|||||||
directionActions = data.getActionList(ConfPaths.BLOCKINTERACT_DIRECTION_ACTIONS,
|
directionActions = data.getActionList(ConfPaths.BLOCKINTERACT_DIRECTION_ACTIONS,
|
||||||
Permissions.BLOCKINTERACT_DIRECTION);
|
Permissions.BLOCKINTERACT_DIRECTION);
|
||||||
|
|
||||||
fastInteractCheck = data.getBoolean(ConfPaths.BLOCKINTERACT_FASTINTERACT_CHECK);
|
|
||||||
fastInteractInterval = data.getLong(ConfPaths.BLOCKINTERACT_FASTINTERACT_INTERVAL);
|
|
||||||
fastInteractActions = data.getActionList(ConfPaths.BLOCKINTERACT_FASTINTERACT_ACTIONS,
|
|
||||||
Permissions.BLOCKINTERACT_FASTINTERACT);
|
|
||||||
|
|
||||||
noSwingCheck = data.getBoolean(ConfPaths.BLOCKINTERACT_NOSWING_CHECK);
|
noSwingCheck = data.getBoolean(ConfPaths.BLOCKINTERACT_NOSWING_CHECK);
|
||||||
noSwingActions = data.getActionList(ConfPaths.BLOCKINTERACT_NOSWING_ACTIONS, Permissions.BLOCKINTERACT_NOSWING);
|
noSwingActions = data.getActionList(ConfPaths.BLOCKINTERACT_NOSWING_ACTIONS, Permissions.BLOCKINTERACT_NOSWING);
|
||||||
|
|
||||||
|
@ -45,16 +45,12 @@ public class BlockInteractData {
|
|||||||
|
|
||||||
// Violation levels.
|
// Violation levels.
|
||||||
public double directionVL;
|
public double directionVL;
|
||||||
public double fastInteractVL;
|
|
||||||
public double noSwingVL;
|
public double noSwingVL;
|
||||||
public double reachVL;
|
public double reachVL;
|
||||||
|
|
||||||
// Data of the fast interact check.
|
|
||||||
public boolean fastInteractLastRefused;
|
|
||||||
public double fastInteractLastTime;
|
|
||||||
|
|
||||||
// Data of the no swing check.
|
// Data of the no swing check.
|
||||||
public boolean noSwingArmSwung;
|
public boolean noSwingArmSwung;
|
||||||
|
public long noSwingLastTime;
|
||||||
|
|
||||||
// Data of the reach check.
|
// Data of the reach check.
|
||||||
public double reachDistance;
|
public double reachDistance;
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
package fr.neatmonster.nocheatplus.checks.blockinteract;
|
package fr.neatmonster.nocheatplus.checks.blockinteract;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
import org.bukkit.Material;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
@ -33,10 +36,15 @@ import org.bukkit.event.player.PlayerInteractEvent;
|
|||||||
*/
|
*/
|
||||||
public class BlockInteractListener implements Listener {
|
public class BlockInteractListener implements Listener {
|
||||||
private final Direction direction = new Direction();
|
private final Direction direction = new Direction();
|
||||||
private final FastInteract fastInteract = new FastInteract();
|
|
||||||
private final NoSwing noSwing = new NoSwing();
|
private final NoSwing noSwing = new NoSwing();
|
||||||
private final Reach reach = new Reach();
|
private final Reach reach = new Reach();
|
||||||
|
|
||||||
|
private final Material[] materials = new Material[] {Material.BED_BLOCK, Material.BURNING_FURNACE,
|
||||||
|
Material.BREWING_STAND, Material.CAKE_BLOCK, Material.CAULDRON, Material.CHEST, Material.DIODE_BLOCK_OFF,
|
||||||
|
Material.DIODE_BLOCK_ON, Material.DISPENSER, Material.DRAGON_EGG, Material.ENCHANTMENT_TABLE,
|
||||||
|
Material.ENDER_CHEST, Material.FENCE_GATE, Material.FURNACE, Material.IRON_DOOR_BLOCK, Material.LEVER,
|
||||||
|
Material.NOTE_BLOCK, Material.STONE_BUTTON, Material.TRAP_DOOR, Material.WOODEN_DOOR, Material.WORKBENCH};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* We listen to PlayerAnimation events because it is (currently) equivalent to "player swings arm" and we want to
|
* We listen to PlayerAnimation events because it is (currently) equivalent to "player swings arm" and we want to
|
||||||
* check if he did that between interactions with blocks.
|
* check if he did that between interactions with blocks.
|
||||||
@ -60,7 +68,7 @@ public class BlockInteractListener implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* We listen to PlayerInteractEvent events for obvious reasons
|
* We listen to PlayerInteractEvent events for obvious reasons.
|
||||||
*
|
*
|
||||||
* @param event
|
* @param event
|
||||||
* the event
|
* the event
|
||||||
@ -86,19 +94,19 @@ public class BlockInteractListener implements Listener {
|
|||||||
|
|
||||||
boolean cancelled = false;
|
boolean cancelled = false;
|
||||||
|
|
||||||
// Do the actual checks, first the fast interact check.
|
// First the no swing check.
|
||||||
if (fastInteract.isEnabled(player) && fastInteract.check(player))
|
if (event.getAction() != Action.RIGHT_CLICK_BLOCK
|
||||||
|
|| Arrays.asList(materials).contains(event.getClickedBlock().getType())) {
|
||||||
|
if (noSwing.isEnabled(player) && noSwing.check(player))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
} else
|
||||||
|
BlockInteractData.getData(player).noSwingArmSwung = false;
|
||||||
|
|
||||||
// Second the no swing check.
|
// Second the reach check.
|
||||||
if (!cancelled && noSwing.isEnabled(player) && noSwing.check(player))
|
|
||||||
cancelled = true;
|
|
||||||
|
|
||||||
// Third the reach check
|
|
||||||
if (!cancelled && reach.isEnabled(player) && reach.check(player, block.getLocation()))
|
if (!cancelled && reach.isEnabled(player) && reach.check(player, block.getLocation()))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
// Fourth the direction check
|
// Third the direction check
|
||||||
if (!cancelled && direction.isEnabled(player) && direction.check(player, block.getLocation()))
|
if (!cancelled && direction.isEnabled(player) && direction.check(player, block.getLocation()))
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
|
|
||||||
|
@ -1,105 +0,0 @@
|
|||||||
package fr.neatmonster.nocheatplus.checks.blockinteract;
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
|
|
||||||
import fr.neatmonster.nocheatplus.actions.ParameterName;
|
|
||||||
import fr.neatmonster.nocheatplus.checks.Check;
|
|
||||||
import fr.neatmonster.nocheatplus.checks.CheckEvent;
|
|
||||||
import fr.neatmonster.nocheatplus.players.Permissions;
|
|
||||||
import fr.neatmonster.nocheatplus.utilities.LagMeasureTask;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* MM""""""""`M dP M""M dP dP
|
|
||||||
MM mmmmmmmM 88 M M 88 88
|
|
||||||
M' MMMM .d8888b. .d8888b. d8888P M M 88d888b. d8888P .d8888b. 88d888b. .d8888b. .d8888b. d8888P
|
|
||||||
MM MMMMMMMM 88' `88 Y8ooooo. 88 M M 88' `88 88 88ooood8 88' `88 88' `88 88' `"" 88
|
|
||||||
MM MMMMMMMM 88. .88 88 88 M M 88 88 88 88. ... 88 88. .88 88. ... 88
|
|
||||||
MM MMMMMMMM `88888P8 `88888P' dP M M dP dP dP `88888P' dP `88888P8 `88888P' dP
|
|
||||||
MMMMMMMMMMMM MMMM
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* A check used to verify if the player isn't interacting with blocks too quickly.
|
|
||||||
*/
|
|
||||||
public class FastInteract extends Check {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The event triggered by this check.
|
|
||||||
*/
|
|
||||||
public class FastInteractEvent extends CheckEvent {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new fast interact event.
|
|
||||||
*
|
|
||||||
* @param player
|
|
||||||
* the player
|
|
||||||
*/
|
|
||||||
public FastInteractEvent(final Player player) {
|
|
||||||
super(player);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks a player.
|
|
||||||
*
|
|
||||||
* @param player
|
|
||||||
* the player
|
|
||||||
* @return true, if successful
|
|
||||||
*/
|
|
||||||
public boolean check(final Player player) {
|
|
||||||
final BlockInteractConfig cc = BlockInteractConfig.getConfig(player);
|
|
||||||
final BlockInteractData data = BlockInteractData.getData(player);
|
|
||||||
|
|
||||||
boolean cancel = false;
|
|
||||||
|
|
||||||
// Has the player interacted with blocks too quickly?
|
|
||||||
if (data.fastInteractLastTime != 0
|
|
||||||
&& System.currentTimeMillis() - data.fastInteractLastTime < cc.fastInteractInterval) {
|
|
||||||
if (!LagMeasureTask.skipCheck()) {
|
|
||||||
if (data.fastInteractLastRefused) {
|
|
||||||
// He failed, increase his violation level.
|
|
||||||
data.fastInteractVL += cc.fastInteractInterval - System.currentTimeMillis()
|
|
||||||
+ data.fastInteractLastTime;
|
|
||||||
|
|
||||||
// Distance a fast interact event (API).
|
|
||||||
final FastInteractEvent e = new FastInteractEvent(player);
|
|
||||||
Bukkit.getPluginManager().callEvent(e);
|
|
||||||
|
|
||||||
// Execute whatever actions are associated with this check and the violation level and find out if
|
|
||||||
// we should cancel the event.
|
|
||||||
cancel = !e.isCancelled() && executeActions(player, cc.fastInteractActions, data.fastInteractVL);
|
|
||||||
}
|
|
||||||
|
|
||||||
data.fastInteractLastRefused = true;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Reward him by lowering his violation level.
|
|
||||||
data.fastInteractVL *= 0.9D;
|
|
||||||
data.fastInteractLastRefused = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
data.fastInteractLastTime = System.currentTimeMillis();
|
|
||||||
|
|
||||||
return cancel;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* (non-Javadoc)
|
|
||||||
* @see fr.neatmonster.nocheatplus.checks.Check#getParameter(fr.neatmonster.nocheatplus.actions.ParameterName, org.bukkit.entity.Player)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String getParameter(final ParameterName wildcard, final Player player) {
|
|
||||||
if (wildcard == ParameterName.VIOLATIONS)
|
|
||||||
return String.valueOf(Math.round(BlockInteractData.getData(player).fastInteractVL));
|
|
||||||
else
|
|
||||||
return super.getParameter(wildcard, player);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* (non-Javadoc)
|
|
||||||
* @see fr.neatmonster.nocheatplus.checks.Check#isEnabled(org.bukkit.entity.Player)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
protected boolean isEnabled(final Player player) {
|
|
||||||
return !player.hasPermission(Permissions.BLOCKINTERACT_FASTINTERACT)
|
|
||||||
&& BlockInteractConfig.getConfig(player).fastInteractCheck;
|
|
||||||
}
|
|
||||||
}
|
|
@ -52,6 +52,7 @@ public class NoSwing extends Check {
|
|||||||
|
|
||||||
boolean cancel = false;
|
boolean cancel = false;
|
||||||
|
|
||||||
|
if (System.currentTimeMillis() - data.noSwingLastTime > 3L)
|
||||||
// Did he swing his arm before?
|
// Did he swing his arm before?
|
||||||
if (data.noSwingArmSwung) {
|
if (data.noSwingArmSwung) {
|
||||||
// "Consume" the flag.
|
// "Consume" the flag.
|
||||||
@ -66,11 +67,14 @@ public class NoSwing extends Check {
|
|||||||
final NoSwingEvent e = new NoSwingEvent(player);
|
final NoSwingEvent e = new NoSwingEvent(player);
|
||||||
Bukkit.getPluginManager().callEvent(e);
|
Bukkit.getPluginManager().callEvent(e);
|
||||||
|
|
||||||
// Execute whatever actions are associated with this check and the violation level and find out if we should
|
// Execute whatever actions are associated with this check and the violation level and find out if we
|
||||||
|
// should
|
||||||
// cancel the event.
|
// cancel the event.
|
||||||
cancel = !e.isCancelled() && executeActions(player, cc.noSwingActions, data.noSwingVL);
|
cancel = !e.isCancelled() && executeActions(player, cc.noSwingActions, data.noSwingVL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
data.noSwingLastTime = System.currentTimeMillis();
|
||||||
|
|
||||||
return cancel;
|
return cancel;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -69,7 +69,8 @@ public class CreativeFly extends Check {
|
|||||||
final MovingData data = MovingData.getData(player);
|
final MovingData data = MovingData.getData(player);
|
||||||
|
|
||||||
// If we have no setback, define one now.
|
// If we have no setback, define one now.
|
||||||
data.setBack = data.setBack == null ? from.getLocation() : data.setBack;
|
if (data.setBack == null)
|
||||||
|
data.setBack = from.getLocation();
|
||||||
|
|
||||||
// Before doing anything, do a basic height check to determine if players are flying too high.
|
// Before doing anything, do a basic height check to determine if players are flying too high.
|
||||||
final int maximumHeight = cc.creativeFlyMaxHeight + player.getWorld().getMaxHeight();
|
final int maximumHeight = cc.creativeFlyMaxHeight + player.getWorld().getMaxHeight();
|
||||||
@ -135,6 +136,7 @@ public class CreativeFly extends Check {
|
|||||||
|
|
||||||
// The player went to far, either horizontal or vertical.
|
// The player went to far, either horizontal or vertical.
|
||||||
if (result > 0D) {
|
if (result > 0D) {
|
||||||
|
if (data.creativeFlyPreviousRefused) {
|
||||||
// Increment violation level.
|
// Increment violation level.
|
||||||
data.creativeFlyVL += result;
|
data.creativeFlyVL += result;
|
||||||
|
|
||||||
@ -142,14 +144,19 @@ public class CreativeFly extends Check {
|
|||||||
final CreativeFlyEvent e = new CreativeFlyEvent(player);
|
final CreativeFlyEvent e = new CreativeFlyEvent(player);
|
||||||
Bukkit.getPluginManager().callEvent(e);
|
Bukkit.getPluginManager().callEvent(e);
|
||||||
|
|
||||||
// Execute whatever actions are associated with this check and the violation level and find out if we should
|
// Execute whatever actions are associated with this check and the violation level and find out if we
|
||||||
|
// should
|
||||||
// cancel the event.
|
// cancel the event.
|
||||||
if (!e.isCancelled() && executeActions(player, cc.creativeFlyActions, data.creativeFlyVL))
|
if (!e.isCancelled() && executeActions(player, cc.creativeFlyActions, data.creativeFlyVL))
|
||||||
// Compose a new location based on coordinates of "newTo" and viewing direction of "event.getTo()" to
|
// Compose a new location based on coordinates of "newTo" and viewing direction of "event.getTo()"
|
||||||
|
// to
|
||||||
// allow the player to look somewhere else despite getting pulled back by NoCheatPlus.
|
// allow the player to look somewhere else despite getting pulled back by NoCheatPlus.
|
||||||
return new Location(player.getWorld(), data.setBack.getX(), data.setBack.getY(), data.setBack.getZ(),
|
return new Location(player.getWorld(), data.setBack.getX(), data.setBack.getY(),
|
||||||
to.getYaw(), to.getPitch());
|
data.setBack.getZ(), to.getYaw(), to.getPitch());
|
||||||
}
|
} else
|
||||||
|
data.creativeFlyPreviousRefused = true;
|
||||||
|
} else
|
||||||
|
data.creativeFlyPreviousRefused = false;
|
||||||
|
|
||||||
// Slowly reduce the violation level with each event.
|
// Slowly reduce the violation level with each event.
|
||||||
data.creativeFlyVL *= 0.97D;
|
data.creativeFlyVL *= 0.97D;
|
||||||
|
@ -56,6 +56,9 @@ public class MovingData {
|
|||||||
|
|
||||||
public Location[] lastSafeLocations = new Location[] {null, null};
|
public Location[] lastSafeLocations = new Location[] {null, null};
|
||||||
|
|
||||||
|
// Data of the creative check.
|
||||||
|
public boolean creativeFlyPreviousRefused;
|
||||||
|
|
||||||
// Data of the more packets check.
|
// Data of the more packets check.
|
||||||
public int morePacketsBuffer = 50;
|
public int morePacketsBuffer = 50;
|
||||||
public long morePacketsLastTime;
|
public long morePacketsLastTime;
|
||||||
@ -75,9 +78,9 @@ public class MovingData {
|
|||||||
// Data of the survival fly check.
|
// Data of the survival fly check.
|
||||||
public int survivalFlyJumpPhase;
|
public int survivalFlyJumpPhase;
|
||||||
public int survivalFlyOnIce;
|
public int survivalFlyOnIce;
|
||||||
public long survivalInLavaSince;
|
public long survivalFlyInLavaSince;
|
||||||
public long survivalInWaterSince;
|
public long survivalFlyInWaterSince;
|
||||||
public long survivalOnLadderSince;
|
public long survivalFlyOnLadderSince;
|
||||||
|
|
||||||
// Locations shared between all checks.
|
// Locations shared between all checks.
|
||||||
public Location from;
|
public Location from;
|
||||||
|
@ -66,8 +66,7 @@ public class NoFall extends Check {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// This check is pretty much always a step behind for technical reasons.
|
// This check is pretty much always a step behind for technical reasons.
|
||||||
if (from.isInLiquid() || to.isInLiquid() || from.isOnGround() || to.isOnGround() || from.isOnLadder()
|
if (from.isInLiquid() || from.isOnGround() || from.isOnLadder())
|
||||||
|| to.isOnLadder())
|
|
||||||
// Start with zero fall distance.
|
// Start with zero fall distance.
|
||||||
data.noFallDistance = 0F;
|
data.noFallDistance = 0F;
|
||||||
|
|
||||||
|
@ -62,13 +62,13 @@ public class SurvivalFly extends Check {
|
|||||||
private static final double COBWEB_DESCEND = 0.062D + MARGIN;
|
private static final double COBWEB_DESCEND = 0.062D + MARGIN;
|
||||||
|
|
||||||
/** The horizontal speed limit when moving into web. */
|
/** The horizontal speed limit when moving into web. */
|
||||||
private static final double COBWEB_MOVE = 0.08D;
|
private static final double COBWEB_MOVE = 0.11D;
|
||||||
|
|
||||||
/** The horizontal speed amplifier when being on ice. */
|
/** The horizontal speed amplifier when being on ice. */
|
||||||
private static final double ICE_AMPLIFIER = 2.5D;
|
private static final double ICE_AMPLIFIER = 2.5D;
|
||||||
|
|
||||||
/** The number of events contained in a jump phase. */
|
/** The number of events contained in a jump phase. */
|
||||||
private static final int JUMP_PHASE = 7;
|
private static final int JUMP_PHASE = 6;
|
||||||
|
|
||||||
/** The distance removed after each jumping event. */
|
/** The distance removed after each jumping event. */
|
||||||
private static final double JUMP_STEP = 0.15D;
|
private static final double JUMP_STEP = 0.15D;
|
||||||
@ -95,10 +95,10 @@ public class SurvivalFly extends Check {
|
|||||||
private static final double SNEAKING_MOVE = 0.14D;
|
private static final double SNEAKING_MOVE = 0.14D;
|
||||||
|
|
||||||
/** The horizontal speed limit when moving on soul sand. */
|
/** The horizontal speed limit when moving on soul sand. */
|
||||||
private static final double SOULSAND_MOVE = 0.11D;
|
private static final double SOULSAND_MOVE = 0.13D;
|
||||||
|
|
||||||
/** The horizontal speed limit when sprinting on soul sand. */
|
/** The horizontal speed limit when sprinting on soul sand. */
|
||||||
private static final double SOULSAND_SPRINTING_MOVE = 0.14D;
|
private static final double SOULSAND_SPRINTING_MOVE = 0.18D;
|
||||||
|
|
||||||
/** The horizontal speed limit when sprinting. */
|
/** The horizontal speed limit when sprinting. */
|
||||||
private static final double SPRINTING_MOVE = 0.37D;
|
private static final double SPRINTING_MOVE = 0.37D;
|
||||||
@ -130,7 +130,8 @@ public class SurvivalFly extends Check {
|
|||||||
final MovingConfig cc = MovingConfig.getConfig(player);
|
final MovingConfig cc = MovingConfig.getConfig(player);
|
||||||
final MovingData data = MovingData.getData(player);
|
final MovingData data = MovingData.getData(player);
|
||||||
|
|
||||||
data.setBack = data.setBack == null ? from.getLocation() : data.setBack;
|
if (data.setBack == null)
|
||||||
|
data.setBack = from.getLocation();
|
||||||
|
|
||||||
// Player on ice? Give him higher max speed.
|
// Player on ice? Give him higher max speed.
|
||||||
if (from.isOnIce() || to.isOnIce())
|
if (from.isOnIce() || to.isOnIce())
|
||||||
@ -220,30 +221,30 @@ public class SurvivalFly extends Check {
|
|||||||
|
|
||||||
// Remember since when the player is in lava/in water/on ladder.
|
// Remember since when the player is in lava/in water/on ladder.
|
||||||
if (from.isInLava() && !to.isInLava())
|
if (from.isInLava() && !to.isInLava())
|
||||||
data.survivalInLavaSince = 0L;
|
data.survivalFlyInLavaSince = 0L;
|
||||||
else if (!from.isInLava() && to.isInLava())
|
else if (!from.isInLava() && to.isInLava())
|
||||||
data.survivalInLavaSince = System.currentTimeMillis();
|
data.survivalFlyInLavaSince = System.currentTimeMillis();
|
||||||
if (from.isInWater() && !to.isInWater())
|
if (from.isInWater() && !to.isInWater())
|
||||||
data.survivalInWaterSince = 0L;
|
data.survivalFlyInWaterSince = 0L;
|
||||||
else if (!from.isInWater() && to.isInWater())
|
else if (!from.isInWater() && to.isInWater())
|
||||||
data.survivalInWaterSince = System.currentTimeMillis();
|
data.survivalFlyInWaterSince = System.currentTimeMillis();
|
||||||
if (from.isOnLadder() && !to.isOnLadder())
|
if (from.isOnLadder() && !to.isOnLadder())
|
||||||
data.survivalOnLadderSince = 0L;
|
data.survivalFlyOnLadderSince = 0L;
|
||||||
else if (!from.isOnLadder() && to.isOnLadder())
|
else if (!from.isOnLadder() && to.isOnLadder())
|
||||||
data.survivalOnLadderSince = System.currentTimeMillis();
|
data.survivalFlyOnLadderSince = System.currentTimeMillis();
|
||||||
|
|
||||||
double vDistance = to.getY() - from.getY();
|
double vDistance = to.getY() - from.getY();
|
||||||
|
|
||||||
// Handle all the special cases.
|
// Handle all the special cases.
|
||||||
double vDistanceAboveLimit = 0D;
|
double vDistanceAboveLimit = 0D;
|
||||||
if (from.isInLava() && to.isInLava() && data.survivalInLavaSince > 0L
|
if (from.isInLava() && to.isInLava() && data.survivalFlyInLavaSince > 0L
|
||||||
&& System.currentTimeMillis() - data.survivalInLavaSince > 1000L) {
|
&& System.currentTimeMillis() - data.survivalFlyInLavaSince > 1000L) {
|
||||||
if (vDistance > cc.survivalFlyLavaSpeed / 100D * LAVA_ASCEND)
|
if (vDistance > cc.survivalFlyLavaSpeed / 100D * LAVA_ASCEND)
|
||||||
vDistanceAboveLimit = vDistance - cc.survivalFlyLavaSpeed / 100D * LAVA_ASCEND;
|
vDistanceAboveLimit = vDistance - cc.survivalFlyLavaSpeed / 100D * LAVA_ASCEND;
|
||||||
else if (vDistance < cc.survivalFlyLavaSpeed / 100D * -LAVA_DESCEND)
|
else if (vDistance < cc.survivalFlyLavaSpeed / 100D * -LAVA_DESCEND)
|
||||||
vDistanceAboveLimit = cc.survivalFlyLavaSpeed / 100D * -LAVA_DESCEND - vDistance;
|
vDistanceAboveLimit = cc.survivalFlyLavaSpeed / 100D * -LAVA_DESCEND - vDistance;
|
||||||
} else if (from.isInWater() && to.isInWater() && data.survivalInWaterSince > 0L
|
} else if (from.isInWater() && to.isInWater() && data.survivalFlyInWaterSince > 0L
|
||||||
&& System.currentTimeMillis() - data.survivalInWaterSince > 1000L) {
|
&& System.currentTimeMillis() - data.survivalFlyInWaterSince > 1000L) {
|
||||||
if (vDistance > cc.survivalFlyWaterSpeed / 100D * WATER_ASCEND)
|
if (vDistance > cc.survivalFlyWaterSpeed / 100D * WATER_ASCEND)
|
||||||
vDistanceAboveLimit = vDistance - cc.survivalFlyWaterSpeed / 100D * WATER_ASCEND;
|
vDistanceAboveLimit = vDistance - cc.survivalFlyWaterSpeed / 100D * WATER_ASCEND;
|
||||||
else if (vDistance < cc.survivalFlyWaterSpeed / 100D * -WATER_DESCEND)
|
else if (vDistance < cc.survivalFlyWaterSpeed / 100D * -WATER_DESCEND)
|
||||||
@ -253,14 +254,16 @@ public class SurvivalFly extends Check {
|
|||||||
vDistanceAboveLimit = vDistance - cc.survivalFlyCobWebSpeed / 100D * COBWEB_ASCEND;
|
vDistanceAboveLimit = vDistance - cc.survivalFlyCobWebSpeed / 100D * COBWEB_ASCEND;
|
||||||
else if (vDistance < cc.survivalFlyCobWebSpeed / 100D * -COBWEB_DESCEND)
|
else if (vDistance < cc.survivalFlyCobWebSpeed / 100D * -COBWEB_DESCEND)
|
||||||
vDistanceAboveLimit = cc.survivalFlyCobWebSpeed / 100D * -COBWEB_DESCEND - vDistance;
|
vDistanceAboveLimit = cc.survivalFlyCobWebSpeed / 100D * -COBWEB_DESCEND - vDistance;
|
||||||
} else if (from.isOnLadder(true) && to.isOnLadder(true) && data.survivalOnLadderSince > 0L
|
} else if (from.isOnLadder(true) && to.isOnLadder(true) && data.survivalFlyOnLadderSince > 0L
|
||||||
&& System.currentTimeMillis() - data.survivalOnLadderSince > 1000L) {
|
&& System.currentTimeMillis() - data.survivalFlyOnLadderSince > 1000L) {
|
||||||
if (vDistance > cc.survivalFlyLadderSpeed / 100D * LADDER_ASCEND)
|
if (vDistance > cc.survivalFlyLadderSpeed / 100D * LADDER_ASCEND)
|
||||||
vDistanceAboveLimit = vDistance - cc.survivalFlyLadderSpeed / 100D * LADDER_ASCEND;
|
vDistanceAboveLimit = vDistance - cc.survivalFlyLadderSpeed / 100D * LADDER_ASCEND;
|
||||||
else if (vDistance < cc.survivalFlyLadderSpeed / 100D * -LADDER_DESCEND)
|
else if (vDistance < cc.survivalFlyLadderSpeed / 100D * -LADDER_DESCEND)
|
||||||
vDistanceAboveLimit = cc.survivalFlyLadderSpeed / 100D * -LADDER_DESCEND - vDistance;
|
vDistanceAboveLimit = cc.survivalFlyLadderSpeed / 100D * -LADDER_DESCEND - vDistance;
|
||||||
} else {
|
} else {
|
||||||
vDistance = to.getY() - data.setBack.getY();
|
vDistance = to.getY() - data.setBack.getY();
|
||||||
|
if (vDistance <= 0D)
|
||||||
|
data.survivalFlyJumpPhase = 0;
|
||||||
|
|
||||||
double vAllowedDistance = (data.verticalFreedom + 1.35D) * data.jumpAmplifier;
|
double vAllowedDistance = (data.verticalFreedom + 1.35D) * data.jumpAmplifier;
|
||||||
if (data.survivalFlyJumpPhase > JUMP_PHASE + data.jumpAmplifier)
|
if (data.survivalFlyJumpPhase > JUMP_PHASE + data.jumpAmplifier)
|
||||||
@ -269,6 +272,13 @@ public class SurvivalFly extends Check {
|
|||||||
vDistanceAboveLimit = Math.max(0D, vDistance - vAllowedDistance);
|
vDistanceAboveLimit = Math.max(0D, vDistance - vAllowedDistance);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Handle slabs placed into a liquid.
|
||||||
|
if (from.isInLiquid()
|
||||||
|
&& to.isInLiquid()
|
||||||
|
&& (to.isOnGround() && to.getY() - from.getY() == 0.5D || !from.isOnGround() && to.isOnGround() || from
|
||||||
|
.isOnGround() && !to.isOnGround()))
|
||||||
|
vDistanceAboveLimit = 0D;
|
||||||
|
|
||||||
if (from.isOnGround() || to.isOnGround())
|
if (from.isOnGround() || to.isOnGround())
|
||||||
data.jumpAmplifier = 0D;
|
data.jumpAmplifier = 0D;
|
||||||
|
|
||||||
@ -309,16 +319,20 @@ public class SurvivalFly extends Check {
|
|||||||
data.setBack = to.getLocation();
|
data.setBack = to.getLocation();
|
||||||
data.setBack.setY(Math.ceil(data.setBack.getY()));
|
data.setBack.setY(Math.ceil(data.setBack.getY()));
|
||||||
data.survivalFlyJumpPhase = 0;
|
data.survivalFlyJumpPhase = 0;
|
||||||
} else if (to.isInWeb() || to.isOnLadder() || to.isOnGround()
|
} else if ((to.isInWeb() || to.isOnLadder() || to.isOnGround())
|
||||||
&& (from.getY() >= to.getY() || data.setBack.getY() <= Math.floor(to.getY()))) {
|
&& (from.getY() >= to.getY() || data.setBack.getY() <= Math.floor(to.getY()))) {
|
||||||
// If the player moved down "onto" the ground and the new setback point is higher up than the old or at
|
// If the player moved down "onto" the ground and the new setback point is higher up than the old or at
|
||||||
// least at the same height, or if the player is in web or on a ladder.
|
// least at the same height, or if the player is in web or on a ladder.
|
||||||
data.setBack = to.getLocation();
|
data.setBack = to.getLocation();
|
||||||
data.survivalFlyJumpPhase = 0;
|
data.survivalFlyJumpPhase = 0;
|
||||||
} else if (from.isInLiquid() || to.isInLiquid() || from.isInWeb() || to.isInWeb() || from.isOnGround()
|
} else {
|
||||||
|
if (from.isInLiquid() || from.isOnGround() || from.isInWeb() || from.isOnGround())
|
||||||
|
data.setBack = from.getLocation();
|
||||||
|
if (from.isInLiquid() || to.isInLiquid() || from.isInWeb() || to.isInWeb() || from.isOnGround()
|
||||||
|| to.isOnGround() || from.isOnLadder() || to.isOnLadder())
|
|| to.isOnGround() || from.isOnLadder() || to.isOnLadder())
|
||||||
// The player at least touched the ground somehow.
|
// The player at least touched the ground somehow.
|
||||||
data.survivalFlyJumpPhase = 0;
|
data.survivalFlyJumpPhase = 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (noFall.isEnabled(player))
|
if (noFall.isEnabled(player))
|
||||||
// Execute the NoFall check.
|
// Execute the NoFall check.
|
||||||
|
@ -58,6 +58,7 @@ public abstract class ConfPaths {
|
|||||||
|
|
||||||
private static final String BLOCKBREAK_FASTBREAK = BLOCKBREAK + "fastbreak.";
|
private static final String BLOCKBREAK_FASTBREAK = BLOCKBREAK + "fastbreak.";
|
||||||
public static final String BLOCKBREAK_FASTBREAK_CHECK = BLOCKBREAK_FASTBREAK + "active";
|
public static final String BLOCKBREAK_FASTBREAK_CHECK = BLOCKBREAK_FASTBREAK + "active";
|
||||||
|
public static final String BLOCKBREAK_FASTBREAK_BUFFER = BLOCKBREAK_FASTBREAK + "buffer";
|
||||||
public static final String BLOCKBREAK_FASTBREAK_EXPERIMENTAL = BLOCKBREAK_FASTBREAK + "experimental";
|
public static final String BLOCKBREAK_FASTBREAK_EXPERIMENTAL = BLOCKBREAK_FASTBREAK + "experimental";
|
||||||
public static final String BLOCKBREAK_FASTBREAK_INTERVAL = BLOCKBREAK_FASTBREAK + "interval";
|
public static final String BLOCKBREAK_FASTBREAK_INTERVAL = BLOCKBREAK_FASTBREAK + "interval";
|
||||||
public static final String BLOCKBREAK_FASTBREAK_ACTIONS = BLOCKBREAK_FASTBREAK + "actions";
|
public static final String BLOCKBREAK_FASTBREAK_ACTIONS = BLOCKBREAK_FASTBREAK + "actions";
|
||||||
@ -83,11 +84,6 @@ public abstract class ConfPaths {
|
|||||||
public static final String BLOCKINTERACT_DIRECTION_CHECK = BLOCKINTERACT_DIRECTION + "active";
|
public static final String BLOCKINTERACT_DIRECTION_CHECK = BLOCKINTERACT_DIRECTION + "active";
|
||||||
public static final String BLOCKINTERACT_DIRECTION_ACTIONS = BLOCKINTERACT_DIRECTION + "actions";
|
public static final String BLOCKINTERACT_DIRECTION_ACTIONS = BLOCKINTERACT_DIRECTION + "actions";
|
||||||
|
|
||||||
private static final String BLOCKINTERACT_FASTINTERACT = BLOCKINTERACT + "fastinteract.";
|
|
||||||
public static final String BLOCKINTERACT_FASTINTERACT_CHECK = BLOCKINTERACT_FASTINTERACT + "active";
|
|
||||||
public static final String BLOCKINTERACT_FASTINTERACT_INTERVAL = BLOCKINTERACT_FASTINTERACT + "interval";
|
|
||||||
public static final String BLOCKINTERACT_FASTINTERACT_ACTIONS = BLOCKINTERACT_FASTINTERACT + "actions";
|
|
||||||
|
|
||||||
private static final String BLOCKINTERACT_NOSWING = BLOCKINTERACT + "noswing.";
|
private static final String BLOCKINTERACT_NOSWING = BLOCKINTERACT + "noswing.";
|
||||||
public static final String BLOCKINTERACT_NOSWING_CHECK = BLOCKINTERACT_NOSWING + "active";
|
public static final String BLOCKINTERACT_NOSWING_CHECK = BLOCKINTERACT_NOSWING + "active";
|
||||||
public static final String BLOCKINTERACT_NOSWING_ACTIONS = BLOCKINTERACT_NOSWING + "actions";
|
public static final String BLOCKINTERACT_NOSWING_ACTIONS = BLOCKINTERACT_NOSWING + "actions";
|
||||||
|
@ -60,6 +60,7 @@ public class DefaultConfig extends ConfigFile {
|
|||||||
set(ConfPaths.BLOCKBREAK_DIRECTION_ACTIONS, "cancel vl>10 log:bdirection:0:5:if cancel");
|
set(ConfPaths.BLOCKBREAK_DIRECTION_ACTIONS, "cancel vl>10 log:bdirection:0:5:if cancel");
|
||||||
|
|
||||||
set(ConfPaths.BLOCKBREAK_FASTBREAK_CHECK, true);
|
set(ConfPaths.BLOCKBREAK_FASTBREAK_CHECK, true);
|
||||||
|
set(ConfPaths.BLOCKBREAK_FASTBREAK_BUFFER, 5);
|
||||||
set(ConfPaths.BLOCKBREAK_FASTBREAK_EXPERIMENTAL, true);
|
set(ConfPaths.BLOCKBREAK_FASTBREAK_EXPERIMENTAL, true);
|
||||||
set(ConfPaths.BLOCKBREAK_FASTBREAK_INTERVAL, 100);
|
set(ConfPaths.BLOCKBREAK_FASTBREAK_INTERVAL, 100);
|
||||||
set(ConfPaths.BLOCKBREAK_FASTBREAK_ACTIONS, "cancel vl>100 log:fastinteract:3:5:cif cancel");
|
set(ConfPaths.BLOCKBREAK_FASTBREAK_ACTIONS, "cancel vl>100 log:fastinteract:3:5:cif cancel");
|
||||||
@ -80,10 +81,6 @@ public class DefaultConfig extends ConfigFile {
|
|||||||
set(ConfPaths.BLOCKINTERACT_DIRECTION_CHECK, true);
|
set(ConfPaths.BLOCKINTERACT_DIRECTION_CHECK, true);
|
||||||
set(ConfPaths.BLOCKINTERACT_DIRECTION_ACTIONS, "cancel vl>10 log:bdirection:0:3:if cancel");
|
set(ConfPaths.BLOCKINTERACT_DIRECTION_ACTIONS, "cancel vl>10 log:bdirection:0:3:if cancel");
|
||||||
|
|
||||||
set(ConfPaths.BLOCKINTERACT_FASTINTERACT_CHECK, true);
|
|
||||||
set(ConfPaths.BLOCKINTERACT_FASTINTERACT_INTERVAL, 95L);
|
|
||||||
set(ConfPaths.BLOCKINTERACT_FASTINTERACT_ACTIONS, "cancel vl>100 log:fastplace:3:5:cif cancel");
|
|
||||||
|
|
||||||
set(ConfPaths.BLOCKINTERACT_NOSWING_CHECK, true);
|
set(ConfPaths.BLOCKINTERACT_NOSWING_CHECK, true);
|
||||||
set(ConfPaths.BLOCKINTERACT_NOSWING_ACTIONS, "log:noswing:3:2:if cancel");
|
set(ConfPaths.BLOCKINTERACT_NOSWING_ACTIONS, "log:noswing:3:2:if cancel");
|
||||||
|
|
||||||
@ -319,7 +316,6 @@ public class DefaultConfig extends ConfigFile {
|
|||||||
set(ConfPaths.STRINGS + ".critical", start + "tried to do a critical hit but wasn't technically jumping" + end);
|
set(ConfPaths.STRINGS + ".critical", start + "tried to do a critical hit but wasn't technically jumping" + end);
|
||||||
set(ConfPaths.STRINGS + ".drop", start + "tried to drop more items than allowed" + end);
|
set(ConfPaths.STRINGS + ".drop", start + "tried to drop more items than allowed" + end);
|
||||||
set(ConfPaths.STRINGS + ".fastbreak", start + "tried to break too much blocks" + end);
|
set(ConfPaths.STRINGS + ".fastbreak", start + "tried to break too much blocks" + end);
|
||||||
set(ConfPaths.STRINGS + ".fastinteract", start + "tried to interact with too much blocks" + end);
|
|
||||||
set(ConfPaths.STRINGS + ".fastplace", start + "tried to place too much blocks" + end);
|
set(ConfPaths.STRINGS + ".fastplace", start + "tried to place too much blocks" + end);
|
||||||
set(ConfPaths.STRINGS + ".fdirection", start + "tried to hit an entity out of line of sight" + end);
|
set(ConfPaths.STRINGS + ".fdirection", start + "tried to hit an entity out of line of sight" + end);
|
||||||
set(ConfPaths.STRINGS + ".flyshort", start + "tried to move unexpectedly" + end);
|
set(ConfPaths.STRINGS + ".flyshort", start + "tried to move unexpectedly" + end);
|
||||||
|
@ -87,7 +87,6 @@ public class Permissions {
|
|||||||
*/
|
*/
|
||||||
private static final String BLOCKINTERACT = CHECKS + ".blockinteract";
|
private static final String BLOCKINTERACT = CHECKS + ".blockinteract";
|
||||||
public static final String BLOCKINTERACT_DIRECTION = BLOCKINTERACT + ".direction";
|
public static final String BLOCKINTERACT_DIRECTION = BLOCKINTERACT + ".direction";
|
||||||
public static final String BLOCKINTERACT_FASTINTERACT = BLOCKINTERACT + ".fastinteract";
|
|
||||||
public static final String BLOCKINTERACT_NOSWING = BLOCKINTERACT + ".noswing";
|
public static final String BLOCKINTERACT_NOSWING = BLOCKINTERACT + ".noswing";
|
||||||
public static final String BLOCKINTERACT_REACH = BLOCKINTERACT + ".reach";
|
public static final String BLOCKINTERACT_REACH = BLOCKINTERACT + ".reach";
|
||||||
|
|
||||||
|
@ -268,6 +268,9 @@ public class PlayerLocation {
|
|||||||
*/
|
*/
|
||||||
public boolean isOnIce() {
|
public boolean isOnIce() {
|
||||||
if (!onIce.isSet())
|
if (!onIce.isSet())
|
||||||
|
if (entity.getBukkitEntity().isSneaking() || entity.getBukkitEntity().isBlocking())
|
||||||
|
onIce.set(world.getTypeId(x, (int) Math.floor(boundingBox.b - 0.1D), z) == Block.ICE.id);
|
||||||
|
else
|
||||||
onIce.set(world.getTypeId(x, y - 1, z) == Block.ICE.id);
|
onIce.set(world.getTypeId(x, y - 1, z) == Block.ICE.id);
|
||||||
return onIce.get();
|
return onIce.get();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user