mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-21 23:11:29 +01:00
Hack for cobwebs. Add permission for placing blocks against fluids.
This commit is contained in:
parent
77c50efce2
commit
a7e0069595
@ -94,6 +94,11 @@ permissions:
|
|||||||
nocheatplus.checks.blockplace:
|
nocheatplus.checks.blockplace:
|
||||||
description: Allow the player to bypass all BlockPlace checks.
|
description: Allow the player to bypass all BlockPlace checks.
|
||||||
children:
|
children:
|
||||||
|
nocheatplus.checks.blockplace.against:
|
||||||
|
description: Allow the player to place blocks against other blocks.
|
||||||
|
children:
|
||||||
|
nocheatplus.checks.blockplace.against.liquids:
|
||||||
|
description: Allow the player to place blocks against liquids.
|
||||||
nocheatplus.checks.blockplace.direction:
|
nocheatplus.checks.blockplace.direction:
|
||||||
description: Allow the player to bypass to Direction check.
|
description: Allow the player to bypass to Direction check.
|
||||||
nocheatplus.checks.blockplace.fastplace:
|
nocheatplus.checks.blockplace.fastplace:
|
||||||
|
@ -91,6 +91,7 @@ public class MovingConfig extends ACheckConfig {
|
|||||||
public final int survivalFlySprintingSpeed;
|
public final int survivalFlySprintingSpeed;
|
||||||
public final int survivalFlySwimmingSpeed;
|
public final int survivalFlySwimmingSpeed;
|
||||||
public final int survivalFlyWalkingSpeed;
|
public final int survivalFlyWalkingSpeed;
|
||||||
|
public final boolean survivalFlyCobwebHack;
|
||||||
public final ActionList survivalFlyActions;
|
public final ActionList survivalFlyActions;
|
||||||
|
|
||||||
// Special tolerance values:
|
// Special tolerance values:
|
||||||
@ -136,6 +137,7 @@ public class MovingConfig extends ACheckConfig {
|
|||||||
survivalFlySprintingSpeed = data.getInt(ConfPaths.MOVING_SURVIVALFLY_SPRINTINGSPEED, 100);
|
survivalFlySprintingSpeed = data.getInt(ConfPaths.MOVING_SURVIVALFLY_SPRINTINGSPEED, 100);
|
||||||
survivalFlySwimmingSpeed = data.getInt(ConfPaths.MOVING_SURVIVALFLY_SWIMMINGSPEED, 100);
|
survivalFlySwimmingSpeed = data.getInt(ConfPaths.MOVING_SURVIVALFLY_SWIMMINGSPEED, 100);
|
||||||
survivalFlyWalkingSpeed = data.getInt(ConfPaths.MOVING_SURVIVALFLY_WALKINGSPEED, 100);
|
survivalFlyWalkingSpeed = data.getInt(ConfPaths.MOVING_SURVIVALFLY_WALKINGSPEED, 100);
|
||||||
|
survivalFlyCobwebHack = data.getBoolean(ConfPaths.MOVING_SURVIVALFLY_COBWEBHACK, true);
|
||||||
survivalFlyActions = data.getActionList(ConfPaths.MOVING_SURVIVALFLY_ACTIONS, Permissions.MOVING_SURVIVALFLY);
|
survivalFlyActions = data.getActionList(ConfPaths.MOVING_SURVIVALFLY_ACTIONS, Permissions.MOVING_SURVIVALFLY);
|
||||||
|
|
||||||
yOnGround = data.getDouble(ConfPaths.MOVING_YONGROUND, 0.001, 2.0, 0.001);
|
yOnGround = data.getDouble(ConfPaths.MOVING_YONGROUND, 0.001, 2.0, 0.001);
|
||||||
|
@ -113,6 +113,8 @@ public class MovingData extends ACheckData {
|
|||||||
public double survivalFlyLastFromY;
|
public double survivalFlyLastFromY;
|
||||||
public int survivalFlyOnIce;
|
public int survivalFlyOnIce;
|
||||||
public boolean survivalFlyWasInBed;
|
public boolean survivalFlyWasInBed;
|
||||||
|
public long survivalFlyCobwebTime;
|
||||||
|
public double survivalFlyCobwebVL;
|
||||||
|
|
||||||
// Locations shared between all checks.
|
// Locations shared between all checks.
|
||||||
public final PlayerLocation from = new PlayerLocation();
|
public final PlayerLocation from = new PlayerLocation();
|
||||||
|
@ -113,7 +113,7 @@ public class MovingListener implements Listener {
|
|||||||
final Material mat = block.getType();
|
final Material mat = block.getType();
|
||||||
|
|
||||||
if (BlockProperties.isLiquid(event.getBlockAgainst().getTypeId())
|
if (BlockProperties.isLiquid(event.getBlockAgainst().getTypeId())
|
||||||
&& mat != Material.WATER_LILY)
|
&& mat != Material.WATER_LILY && !player.hasPermission(Permissions.BLOCKPLACE_AGAINST_LIQUIDS))
|
||||||
// The block was placed against a liquid block, cancel its
|
// The block was placed against a liquid block, cancel its
|
||||||
// placement.
|
// placement.
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
|
@ -42,7 +42,7 @@ public class SurvivalFly extends Check {
|
|||||||
|
|
||||||
public static final double blockingSpeed = 0.16D;
|
public static final double blockingSpeed = 0.16D;
|
||||||
public static final double swimmingSpeed = 0.11D;
|
public static final double swimmingSpeed = 0.11D;
|
||||||
public static final double webSpeed = walkingSpeed * 0.15D;
|
public static final double webSpeed = 0.105D; // TODO: walkingSpeed * 0.15D; <- does not work
|
||||||
|
|
||||||
public static final double modIce = 2.5D;
|
public static final double modIce = 2.5D;
|
||||||
|
|
||||||
@ -223,10 +223,22 @@ public class SurvivalFly extends Check {
|
|||||||
double vAllowedDistance, vDistanceAboveLimit;
|
double vAllowedDistance, vDistanceAboveLimit;
|
||||||
if (from.isInWeb()){
|
if (from.isInWeb()){
|
||||||
// Very simple: force players to descend or stay.
|
// Very simple: force players to descend or stay.
|
||||||
vAllowedDistance = 0;
|
vAllowedDistance = from.isOnGround() ? 0.1D : 0;
|
||||||
data.jumpAmplifier = 0;
|
data.jumpAmplifier = 0;
|
||||||
final double vy = player.getVelocity().getY();
|
vDistanceAboveLimit = to.getY() - from.getY();
|
||||||
vDistanceAboveLimit = vy;
|
if (cc.survivalFlyCobwebHack && vDistanceAboveLimit > 0 && hDistanceAboveLimit <= 0){
|
||||||
|
final long now = System.currentTimeMillis();
|
||||||
|
if (now - data.survivalFlyCobwebTime > 3000){
|
||||||
|
data.survivalFlyCobwebTime = now;
|
||||||
|
data.survivalFlyCobwebVL = vDistanceAboveLimit * 100D;
|
||||||
|
}
|
||||||
|
else data.survivalFlyCobwebVL += vDistanceAboveLimit * 100D;
|
||||||
|
if (data.survivalFlyCobwebVL < 325) { // Totally random !
|
||||||
|
if (data.setBack == null) data.setBack = player.getLocation();
|
||||||
|
data.survivalFlyJumpPhase = 0;
|
||||||
|
return data.setBack;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
vAllowedDistance = (!fromOnGround && !toOnGround ? 1.45D : 1.35D) + data.verticalFreedom;
|
vAllowedDistance = (!fromOnGround && !toOnGround ? 1.45D : 1.35D) + data.verticalFreedom;
|
||||||
@ -257,6 +269,8 @@ public class SurvivalFly extends Check {
|
|||||||
data.survivalFlyVL *= 0.95D;
|
data.survivalFlyVL *= 0.95D;
|
||||||
// System.out.println("vertical freedom: " + data.verticalFreedom + " ("+data.verticalVelocity+"/"+data.verticalVelocityCounter+")");
|
// System.out.println("vertical freedom: " + data.verticalFreedom + " ("+data.verticalVelocity+"/"+data.verticalVelocityCounter+")");
|
||||||
// Did the player move in unexpected ways?
|
// Did the player move in unexpected ways?
|
||||||
|
// System.out.println("hDist: " + hDistance + " / " + hAllowedDistance + " , vDist: " + (to.getY() - from.getY()) + " ("+player.getVelocity().getY()+")" + " / " + vAllowedDistance + " / from passable: " + BlockProperties.isPassable(from));
|
||||||
|
// System.out.println(from.getY() +"(" + player.getLocation().getY() + ") -> " + to.getY()) ;
|
||||||
if (result > 0D) {
|
if (result > 0D) {
|
||||||
// Increment violation counter.
|
// Increment violation counter.
|
||||||
data.survivalFlyVL += result;
|
data.survivalFlyVL += result;
|
||||||
|
@ -463,6 +463,7 @@ public abstract class ConfPaths {
|
|||||||
public static final String MOVING_SURVIVALFLY_SPRINTINGSPEED = MOVING_SURVIVALFLY + "sprintingspeed";
|
public static final String MOVING_SURVIVALFLY_SPRINTINGSPEED = MOVING_SURVIVALFLY + "sprintingspeed";
|
||||||
public static final String MOVING_SURVIVALFLY_SWIMMINGSPEED = MOVING_SURVIVALFLY + "swimmingspeed";
|
public static final String MOVING_SURVIVALFLY_SWIMMINGSPEED = MOVING_SURVIVALFLY + "swimmingspeed";
|
||||||
public static final String MOVING_SURVIVALFLY_WALKINGSPEED = MOVING_SURVIVALFLY + "walkingspeed";
|
public static final String MOVING_SURVIVALFLY_WALKINGSPEED = MOVING_SURVIVALFLY + "walkingspeed";
|
||||||
|
public static final String MOVING_SURVIVALFLY_COBWEBHACK = MOVING_SURVIVALFLY + "cobwebhack";
|
||||||
public static final String MOVING_SURVIVALFLY_ACTIONS = MOVING_SURVIVALFLY + "actions";
|
public static final String MOVING_SURVIVALFLY_ACTIONS = MOVING_SURVIVALFLY + "actions";
|
||||||
|
|
||||||
// Special (to be sorted in or factored out).
|
// Special (to be sorted in or factored out).
|
||||||
|
@ -88,6 +88,8 @@ public class Permissions {
|
|||||||
* 888 88P' 888 "88 88" "88,e8' 888 8b 888 888 "88 888 "88,e8' "YeeP"
|
* 888 88P' 888 "88 88" "88,e8' 888 8b 888 888 "88 888 "88,e8' "YeeP"
|
||||||
*/
|
*/
|
||||||
private static final String BLOCKPLACE = CHECKS + ".blockplace";
|
private static final String BLOCKPLACE = CHECKS + ".blockplace";
|
||||||
|
public static final String BLOCKPLACE_AGAINST = BLOCKPLACE + ".against";
|
||||||
|
public static final String BLOCKPLACE_AGAINST_LIQUIDS = BLOCKPLACE_AGAINST + ".liquids";
|
||||||
public static final String BLOCKPLACE_DIRECTION = BLOCKPLACE + ".direction";
|
public static final String BLOCKPLACE_DIRECTION = BLOCKPLACE + ".direction";
|
||||||
public static final String BLOCKPLACE_FASTPLACE = BLOCKPLACE + ".fastplace";
|
public static final String BLOCKPLACE_FASTPLACE = BLOCKPLACE + ".fastplace";
|
||||||
public static final String BLOCKPLACE_NOSWING = BLOCKPLACE + ".noswing";
|
public static final String BLOCKPLACE_NOSWING = BLOCKPLACE + ".noswing";
|
||||||
|
Loading…
Reference in New Issue
Block a user