2016-03-01 11:23:45 +11:00
|
|
|
From 2b3de9dd1ca7d6d57e840342da812740bc360e2f Mon Sep 17 00:00:00 2001
|
2014-07-21 15:46:54 -05:00
|
|
|
From: Thinkofdeath <thinkofdeath@spigotmc.org>
|
|
|
|
Date: Sat, 19 Jul 2014 19:54:41 +0100
|
|
|
|
Subject: [PATCH] Prevent a crash involving attributes
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2016-03-01 08:33:06 +11:00
|
|
|
index c5fdd6d..b1521b6 100644
|
2014-07-21 15:46:54 -05:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2016-03-01 08:33:06 +11:00
|
|
|
@@ -1308,7 +1308,15 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
2014-07-21 15:46:54 -05:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2014-11-27 17:17:45 -08:00
|
|
|
- collection.add(new AttributeModifiable(getHandle().getAttributeMap(), (new AttributeRanged(null, "generic.maxHealth", scaledHealth ? healthScale : getMaxHealth(), 0.0D, Float.MAX_VALUE)).a("Max Health").a(true)));
|
2014-07-21 15:46:54 -05:00
|
|
|
+ // Spigot start
|
|
|
|
+ double healthMod = scaledHealth ? healthScale : getMaxHealth();
|
|
|
|
+ if ( healthMod >= Float.MAX_VALUE || healthMod <= 0 )
|
|
|
|
+ {
|
|
|
|
+ healthMod = 20; // Reset health
|
|
|
|
+ getServer().getLogger().warning( getName() + " tried to crash the server with a large health attribute" );
|
|
|
|
+ }
|
2014-11-27 17:17:45 -08:00
|
|
|
+ collection.add(new AttributeModifiable(getHandle().getAttributeMap(), (new AttributeRanged(null, "generic.maxHealth", healthMod, 0.0D, Float.MAX_VALUE)).a("Max Health").a(true)));
|
2014-07-21 15:46:54 -05:00
|
|
|
+ // Spigot end
|
|
|
|
}
|
|
|
|
|
2015-06-09 09:16:01 +10:00
|
|
|
@Override
|
2014-07-21 15:46:54 -05:00
|
|
|
--
|
2016-03-01 08:33:06 +11:00
|
|
|
2.5.0
|
2014-07-21 15:46:54 -05:00
|
|
|
|