mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-04 23:07:44 +01:00
Set an absolute maximum flight height for players.
This commit is contained in:
parent
91f730d731
commit
dc03c84025
@ -34,6 +34,17 @@ public class FlyingCheck extends MovingCheck {
|
|||||||
setBack.set(from);
|
setBack.set(from);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PreciseLocation newToLocation = null;
|
||||||
|
|
||||||
|
// Before doing anything, do a basic height check
|
||||||
|
// This is silent for now, will log messages later
|
||||||
|
if(to.y - data.vertFreedom > ccmoving.flyingHeightLimit) {
|
||||||
|
newToLocation = new PreciseLocation();
|
||||||
|
newToLocation.set(setBack);
|
||||||
|
newToLocation.y = ccmoving.flyingHeightLimit - 5;
|
||||||
|
return newToLocation;
|
||||||
|
}
|
||||||
|
|
||||||
final double yDistance = to.y - from.y;
|
final double yDistance = to.y - from.y;
|
||||||
|
|
||||||
// Calculate some distances
|
// Calculate some distances
|
||||||
@ -44,7 +55,6 @@ public class FlyingCheck extends MovingCheck {
|
|||||||
double resultHoriz = 0;
|
double resultHoriz = 0;
|
||||||
double resultVert = 0;
|
double resultVert = 0;
|
||||||
double result = 0;
|
double result = 0;
|
||||||
PreciseLocation newToLocation = null;
|
|
||||||
|
|
||||||
// In case of creative gamemode, give at least 0.60 speed limit
|
// In case of creative gamemode, give at least 0.60 speed limit
|
||||||
// horizontal
|
// horizontal
|
||||||
|
@ -56,6 +56,7 @@ public abstract class Configuration {
|
|||||||
public final static OptionNode MOVING_RUNFLY_ALLOWLIMITEDFLYING = new OptionNode("allowlimitedflying", MOVING_RUNFLY, DataType.BOOLEAN);
|
public final static OptionNode MOVING_RUNFLY_ALLOWLIMITEDFLYING = new OptionNode("allowlimitedflying", MOVING_RUNFLY, DataType.BOOLEAN);
|
||||||
public final static OptionNode MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL = new OptionNode("flyingspeedlimitvertical", MOVING_RUNFLY, DataType.INTEGER);
|
public final static OptionNode MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL = new OptionNode("flyingspeedlimitvertical", MOVING_RUNFLY, DataType.INTEGER);
|
||||||
public final static OptionNode MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL = new OptionNode("flyingspeedlimithorizontal", MOVING_RUNFLY, DataType.INTEGER);
|
public final static OptionNode MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL = new OptionNode("flyingspeedlimithorizontal", MOVING_RUNFLY, DataType.INTEGER);
|
||||||
|
public final static OptionNode MOVING_RUNFLY_FLYINGHEIGHTLIMIT = new OptionNode("flyingheightlimit", MOVING_RUNFLY, DataType.INTEGER);
|
||||||
public final static OptionNode MOVING_RUNFLY_FLYINGACTIONS = new OptionNode("flyingactions", MOVING_RUNFLY, DataType.ACTIONLIST);
|
public final static OptionNode MOVING_RUNFLY_FLYINGACTIONS = new OptionNode("flyingactions", MOVING_RUNFLY, DataType.ACTIONLIST);
|
||||||
|
|
||||||
private final static OptionNode MOVING_MOREPACKETS = new OptionNode("morepackets", MOVING, DataType.PARENT);
|
private final static OptionNode MOVING_MOREPACKETS = new OptionNode("morepackets", MOVING, DataType.PARENT);
|
||||||
|
@ -74,6 +74,7 @@ public class DefaultConfiguration extends Configuration {
|
|||||||
setValue(MOVING_RUNFLY_ALLOWLIMITEDFLYING, false);
|
setValue(MOVING_RUNFLY_ALLOWLIMITEDFLYING, false);
|
||||||
setValue(MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL, 100);
|
setValue(MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL, 100);
|
||||||
setValue(MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL, 60);
|
setValue(MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL, 60);
|
||||||
|
setValue(MOVING_RUNFLY_FLYINGHEIGHTLIMIT, 500);
|
||||||
|
|
||||||
ActionList flyingActionList = new ActionList();
|
ActionList flyingActionList = new ActionList();
|
||||||
flyingActionList.setActions(0, action.getActions("moveLogLowShort moveCancel".split(" ")));
|
flyingActionList.setActions(0, action.getActions("moveLogLowShort moveCancel".split(" ")));
|
||||||
|
@ -6,8 +6,8 @@ import java.util.Map;
|
|||||||
import cc.co.evenprime.bukkit.nocheat.config.util.OptionNode;
|
import cc.co.evenprime.bukkit.nocheat.config.util.OptionNode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Textual explainations of options, will be displayed in the gui tool and the
|
* Textual explainations of options, will be displayed at the end of the
|
||||||
* descriptions.txt file.
|
* config.txt file
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class Explainations {
|
public class Explainations {
|
||||||
@ -50,6 +50,7 @@ public class Explainations {
|
|||||||
set(Configuration.MOVING_RUNFLY_ALLOWLIMITEDFLYING, "If true, instead of doing the above checks for walking/sprinting/swimming/sneaking,\nallow flying and only limit the flying speed.");
|
set(Configuration.MOVING_RUNFLY_ALLOWLIMITEDFLYING, "If true, instead of doing the above checks for walking/sprinting/swimming/sneaking,\nallow flying and only limit the flying speed.");
|
||||||
set(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL, "Set the speed limit for moving vertical while flying.\nUnit is 1/100 of a block, default is 100.");
|
set(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL, "Set the speed limit for moving vertical while flying.\nUnit is 1/100 of a block, default is 100.");
|
||||||
set(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL, "Set the speed limit for moving horizontal while flying.\nUnit is 1/100 of a block, default is 60.");
|
set(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL, "Set the speed limit for moving horizontal while flying.\nUnit is 1/100 of a block, default is 60.");
|
||||||
|
set(Configuration.MOVING_RUNFLY_FLYINGHEIGHTLIMIT, "Set the absolute height limit that a player may go to when flying.\nUnit is number of blocks, default is 500");
|
||||||
set(Configuration.MOVING_RUNFLY_FLYINGACTIONS, "What should be done if a player flies faster than the speed limit(s). \nUnits are in 1/100 of a block above the speedlimit.");
|
set(Configuration.MOVING_RUNFLY_FLYINGACTIONS, "What should be done if a player flies faster than the speed limit(s). \nUnits are in 1/100 of a block above the speedlimit.");
|
||||||
|
|
||||||
set(Configuration.MOVING_MOREPACKETS_CHECK, "If true, check if a player is sending too many 'move-packets' per second. In a normal game, the player won't send more than 22 packets per second.");
|
set(Configuration.MOVING_MOREPACKETS_CHECK, "If true, check if a player is sending too many 'move-packets' per second. In a normal game, the player won't send more than 22 packets per second.");
|
||||||
|
@ -35,6 +35,8 @@ public class CCMoving {
|
|||||||
public final boolean morePacketsCheck;
|
public final boolean morePacketsCheck;
|
||||||
public final ActionList morePacketsActions;
|
public final ActionList morePacketsActions;
|
||||||
|
|
||||||
|
public final double flyingHeightLimit;
|
||||||
|
|
||||||
public CCMoving(Configuration data) {
|
public CCMoving(Configuration data) {
|
||||||
|
|
||||||
check = data.getBoolean(Configuration.MOVING_CHECK);
|
check = data.getBoolean(Configuration.MOVING_CHECK);
|
||||||
@ -55,6 +57,7 @@ public class CCMoving {
|
|||||||
allowFlying = data.getBoolean(Configuration.MOVING_RUNFLY_ALLOWLIMITEDFLYING);
|
allowFlying = data.getBoolean(Configuration.MOVING_RUNFLY_ALLOWLIMITEDFLYING);
|
||||||
flyingSpeedLimitVertical = ((double) data.getInteger(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL)) / 100D;
|
flyingSpeedLimitVertical = ((double) data.getInteger(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITVERTICAL)) / 100D;
|
||||||
flyingSpeedLimitHorizontal = ((double) data.getInteger(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL)) / 100D;
|
flyingSpeedLimitHorizontal = ((double) data.getInteger(Configuration.MOVING_RUNFLY_FLYINGSPEEDLIMITHORIZONTAL)) / 100D;
|
||||||
|
flyingHeightLimit = data.getInteger(Configuration.MOVING_RUNFLY_FLYINGHEIGHTLIMIT);
|
||||||
flyingActions = data.getActionList(Configuration.MOVING_RUNFLY_FLYINGACTIONS);
|
flyingActions = data.getActionList(Configuration.MOVING_RUNFLY_FLYINGACTIONS);
|
||||||
|
|
||||||
nofallCheck = data.getBoolean(Configuration.MOVING_RUNFLY_CHECKNOFALL);
|
nofallCheck = data.getBoolean(Configuration.MOVING_RUNFLY_CHECKNOFALL);
|
||||||
|
Loading…
Reference in New Issue
Block a user