mirror of
https://e.coding.net/circlecloud/Residence.git
synced 2024-10-31 22:38:48 +00:00
Merge branch 'master' of git@git.coding.net:502647092/Residence-Fix.git
This commit is contained in:
commit
d7c16fd25a
23
.classpath
Normal file
23
.classpath
Normal file
@ -0,0 +1,23 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry including="**/*.java" kind="src" output="target/classes" path="src">
|
||||
<attributes>
|
||||
<attribute name="optional" value="true"/>
|
||||
<attribute name="maven.pomderived" value="true"/>
|
||||
</attributes>
|
||||
</classpathentry>
|
||||
<classpathentry kind="lib" path="lib/Essentials.jar"/>
|
||||
<classpathentry kind="lib" path="lib/Vault.jar"/>
|
||||
<classpathentry kind="lib" path="lib/WorldEdit.jar"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.7">
|
||||
<attributes>
|
||||
<attribute name="maven.pomderived" value="true"/>
|
||||
</attributes>
|
||||
</classpathentry>
|
||||
<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
|
||||
<attributes>
|
||||
<attribute name="maven.pomderived" value="true"/>
|
||||
</attributes>
|
||||
</classpathentry>
|
||||
<classpathentry kind="output" path="target/classes"/>
|
||||
</classpath>
|
5
.gitignore
vendored
5
.gitignore
vendored
@ -1,8 +1,3 @@
|
||||
# Eclipse stuff
|
||||
/.classpath
|
||||
/.project
|
||||
/.settings
|
||||
|
||||
# netbeans
|
||||
/nbproject
|
||||
|
||||
|
23
.project
Normal file
23
.project
Normal file
@ -0,0 +1,23 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>Residence-Fix</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.m2e.core.maven2Builder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.m2e.core.maven2Nature</nature>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
3
.settings/org.eclipse.core.resources.prefs
Normal file
3
.settings/org.eclipse.core.resources.prefs
Normal file
@ -0,0 +1,3 @@
|
||||
eclipse.preferences.version=1
|
||||
encoding/<project>=UTF-8
|
||||
encoding/src=UTF-8
|
5
.settings/org.eclipse.jdt.core.prefs
Normal file
5
.settings/org.eclipse.jdt.core.prefs
Normal file
@ -0,0 +1,5 @@
|
||||
eclipse.preferences.version=1
|
||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7
|
||||
org.eclipse.jdt.core.compiler.compliance=1.7
|
||||
org.eclipse.jdt.core.compiler.problem.forbiddenReference=warning
|
||||
org.eclipse.jdt.core.compiler.source=1.7
|
4
.settings/org.eclipse.m2e.core.prefs
Normal file
4
.settings/org.eclipse.m2e.core.prefs
Normal file
@ -0,0 +1,4 @@
|
||||
activeProfiles=
|
||||
eclipse.preferences.version=1
|
||||
resolveWorkspaceProjects=true
|
||||
version=1
|
@ -4,6 +4,7 @@
|
||||
*/
|
||||
|
||||
package com.bekvon.bukkit.residence.listeners;
|
||||
|
||||
import org.bukkit.ChatColor;
|
||||
import org.bukkit.Location;
|
||||
|
||||
@ -66,13 +67,19 @@ public class ResidenceEntityListener implements Listener {
|
||||
|
||||
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
|
||||
public void onEndermanChangeBlock(EntityChangeBlockEvent event) {
|
||||
if (event.getEntityType() != EntityType.ENDERMAN && event.getEntityType() != EntityType.WITHER) {
|
||||
if (event.getEntityType() != EntityType.ENDERMAN
|
||||
&& event.getEntityType() != EntityType.WITHER) {
|
||||
return;
|
||||
}
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getBlock().getLocation());
|
||||
FlagPermissions world = Residence.getWorldFlags().getPerms(event.getBlock().getWorld().getName());
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getBlock()
|
||||
.getLocation());
|
||||
FlagPermissions world = Residence.getWorldFlags().getPerms(
|
||||
event.getBlock().getWorld().getName());
|
||||
if (event.getEntityType() == EntityType.WITHER) {
|
||||
if (!perms.has("wither", perms.has("explode", world.has("wither", world.has("explode", true))))) {
|
||||
if (!perms.has(
|
||||
"wither",
|
||||
perms.has("explode",
|
||||
world.has("wither", world.has("explode", true))))) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
} else if (!perms.has("build", true)) {
|
||||
@ -81,13 +88,14 @@ public class ResidenceEntityListener implements Listener {
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.LOWEST)
|
||||
public void onEntityInteract(EntityInteractEvent event){
|
||||
public void onEntityInteract(EntityInteractEvent event) {
|
||||
Block block = event.getBlock();
|
||||
Material mat = block.getType();
|
||||
Entity entity = event.getEntity();
|
||||
FlagPermissions perms = Residence.getPermsByLoc(block.getLocation());
|
||||
boolean hastrample = perms.has("trample", perms.has("hasbuild", true));
|
||||
if(!hastrample && !(entity.getType() == EntityType.FALLING_BLOCK) && (mat == Material.SOIL || mat == Material.SOUL_SAND)){
|
||||
if (!hastrample && !(entity.getType() == EntityType.FALLING_BLOCK)
|
||||
&& (mat == Material.SOIL || mat == Material.SOUL_SAND)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
@ -97,11 +105,16 @@ public class ResidenceEntityListener implements Listener {
|
||||
}
|
||||
|
||||
private boolean isAnimal(Entity ent) {
|
||||
return (ent instanceof Horse || ent instanceof Bat || ent instanceof Snowman || ent instanceof IronGolem || ent instanceof Ocelot || ent instanceof Pig || ent instanceof Sheep || ent instanceof Chicken || ent instanceof Wolf || ent instanceof Cow || ent instanceof Squid || ent instanceof Villager || ent instanceof Rabbit);
|
||||
return (ent instanceof Horse || ent instanceof Bat
|
||||
|| ent instanceof Snowman || ent instanceof IronGolem
|
||||
|| ent instanceof Ocelot || ent instanceof Pig
|
||||
|| ent instanceof Sheep || ent instanceof Chicken
|
||||
|| ent instanceof Wolf || ent instanceof Cow
|
||||
|| ent instanceof Squid || ent instanceof Villager || ent instanceof Rabbit);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.LOWEST)
|
||||
public void AnimalKilling (EntityDamageByEntityEvent event){
|
||||
public void AnimalKilling(EntityDamageByEntityEvent event) {
|
||||
Entity damager = event.getDamager();
|
||||
|
||||
if ((!(damager instanceof Arrow)) && (!(damager instanceof Player))) {
|
||||
@ -109,7 +122,8 @@ public class ResidenceEntityListener implements Listener {
|
||||
}
|
||||
|
||||
Player cause;
|
||||
if ((damager instanceof Arrow) && (!(((Arrow) damager).getShooter() instanceof Player))) {
|
||||
if ((damager instanceof Arrow)
|
||||
&& (!(((Arrow) damager).getShooter() instanceof Player))) {
|
||||
return;
|
||||
|
||||
} else if (damager instanceof Player) {
|
||||
@ -123,11 +137,15 @@ public class ResidenceEntityListener implements Listener {
|
||||
}
|
||||
|
||||
Entity entity = event.getEntity();
|
||||
ClaimedResidence res = Residence.getResidenceManager().getByLoc(entity.getLocation());
|
||||
ClaimedResidence res = Residence.getResidenceManager().getByLoc(
|
||||
entity.getLocation());
|
||||
|
||||
if (res != null && !res.getPermissions().playerHas(cause.getName(), "animalkilling", true)) {
|
||||
if (res != null
|
||||
&& !res.getPermissions().playerHas(cause.getName(),
|
||||
"animalkilling", true)) {
|
||||
if (isAnimal(entity)) {
|
||||
cause.sendMessage(ChatColor.RED + Residence.getLanguage().getPhrase("NoPermission"));
|
||||
cause.sendMessage(ChatColor.RED
|
||||
+ Residence.getLanguage().getPhrase("NoPermission"));
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
@ -137,8 +155,8 @@ public class ResidenceEntityListener implements Listener {
|
||||
public void onCreatureSpawn(CreatureSpawnEvent event) {
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getLocation());
|
||||
Entity ent = event.getEntity();
|
||||
if(isAnimal(ent)){
|
||||
if(!perms.has("animals", true)){
|
||||
if (isAnimal(ent)) {
|
||||
if (!perms.has("animals", true)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
} else {
|
||||
@ -154,12 +172,15 @@ public class ResidenceEntityListener implements Listener {
|
||||
if (Residence.isResAdminOn(player)) {
|
||||
return;
|
||||
}
|
||||
FlagPermissions perms = Residence.getPermsByLocForPlayer(event.getEntity().getLocation(), player);
|
||||
FlagPermissions perms = Residence.getPermsByLocForPlayer(event
|
||||
.getEntity().getLocation(), player);
|
||||
String pname = player.getName();
|
||||
String world = player.getWorld().getName();
|
||||
if (!perms.playerHas(pname, world, "place", perms.playerHas(pname, world, "build", true))) {
|
||||
if (!perms.playerHas(pname, world, "place",
|
||||
perms.playerHas(pname, world, "build", true))) {
|
||||
event.setCancelled(true);
|
||||
player.sendMessage(ChatColor.RED + Residence.getLanguage().getPhrase("NoPermission"));
|
||||
player.sendMessage(ChatColor.RED
|
||||
+ Residence.getLanguage().getPhrase("NoPermission"));
|
||||
}
|
||||
}
|
||||
|
||||
@ -173,11 +194,14 @@ public class ResidenceEntityListener implements Listener {
|
||||
return;
|
||||
}
|
||||
String pname = player.getName();
|
||||
FlagPermissions perms = Residence.getPermsByLocForPlayer(event.getEntity().getLocation(), player);
|
||||
FlagPermissions perms = Residence.getPermsByLocForPlayer(event
|
||||
.getEntity().getLocation(), player);
|
||||
String world = event.getEntity().getWorld().getName();
|
||||
if (!perms.playerHas(pname, world, "destroy", perms.playerHas(pname, world, "build", true))) {
|
||||
if (!perms.playerHas(pname, world, "destroy",
|
||||
perms.playerHas(pname, world, "build", true))) {
|
||||
event.setCancelled(true);
|
||||
player.sendMessage(ChatColor.RED + Residence.getLanguage().getPhrase("NoPermission"));
|
||||
player.sendMessage(ChatColor.RED
|
||||
+ Residence.getLanguage().getPhrase("NoPermission"));
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -185,7 +209,8 @@ public class ResidenceEntityListener implements Listener {
|
||||
|
||||
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
|
||||
public void onEntityCombust(EntityCombustEvent event) {
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getEntity().getLocation());
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getEntity()
|
||||
.getLocation());
|
||||
if (!perms.has("burn", true)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
@ -194,14 +219,16 @@ public class ResidenceEntityListener implements Listener {
|
||||
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
|
||||
public void onExplosionPrime(ExplosionPrimeEvent event) {
|
||||
EntityType entity = event.getEntityType();
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getEntity().getLocation());
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getEntity()
|
||||
.getLocation());
|
||||
if (entity == EntityType.CREEPER) {
|
||||
if (!perms.has("creeper", perms.has("explode", true))) {
|
||||
event.setCancelled(true);
|
||||
event.getEntity().remove();
|
||||
}
|
||||
}
|
||||
if (entity == EntityType.PRIMED_TNT || entity == EntityType.MINECART_TNT) {
|
||||
if (entity == EntityType.PRIMED_TNT
|
||||
|| entity == EntityType.MINECART_TNT) {
|
||||
if (!perms.has("tnt", perms.has("explode", true))) {
|
||||
event.setCancelled(true);
|
||||
event.getEntity().remove();
|
||||
@ -233,14 +260,17 @@ public class ResidenceEntityListener implements Listener {
|
||||
return;
|
||||
Boolean cancel = false;
|
||||
EntityType entity = event.getEntityType();
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getEntity().getLocation());
|
||||
FlagPermissions world = Residence.getWorldFlags().getPerms(event.getEntity().getWorld().getName());
|
||||
FlagPermissions perms = Residence.getPermsByLoc(event.getEntity()
|
||||
.getLocation());
|
||||
FlagPermissions world = Residence.getWorldFlags().getPerms(
|
||||
event.getEntity().getWorld().getName());
|
||||
if (entity == EntityType.CREEPER) {
|
||||
if (!perms.has("creeper", perms.has("explode", true))) {
|
||||
cancel = true;
|
||||
}
|
||||
}
|
||||
if (entity == EntityType.PRIMED_TNT || entity == EntityType.MINECART_TNT) {
|
||||
if (entity == EntityType.PRIMED_TNT
|
||||
|| entity == EntityType.MINECART_TNT) {
|
||||
if (!perms.has("tnt", perms.has("explode", true))) {
|
||||
cancel = true;
|
||||
}
|
||||
@ -256,7 +286,10 @@ public class ResidenceEntityListener implements Listener {
|
||||
}
|
||||
}
|
||||
if (entity == EntityType.WITHER_SKULL || entity == EntityType.WITHER) {
|
||||
if (!perms.has("wither", perms.has("explode", world.has("wither", world.has("explode", true))))) {
|
||||
if (!perms.has(
|
||||
"wither",
|
||||
perms.has("explode",
|
||||
world.has("wither", world.has("explode", true))))) {
|
||||
cancel = true;
|
||||
}
|
||||
}
|
||||
@ -266,8 +299,16 @@ public class ResidenceEntityListener implements Listener {
|
||||
} else {
|
||||
List<Block> preserve = new ArrayList<Block>();
|
||||
for (Block block : event.blockList()) {
|
||||
FlagPermissions blockperms = Residence.getPermsByLoc(block.getLocation());
|
||||
if ((!blockperms.has("wither", blockperms.has("explode", world.has("wither", world.has("explode", true)))) && (entity == EntityType.WITHER || entity == EntityType.WITHER_SKULL) || (!blockperms.has("fireball", blockperms.has("explode", true)) && (entity == EntityType.FIREBALL || entity == EntityType.SMALL_FIREBALL)) || (!blockperms.has("tnt", blockperms.has("explode", true)) && (entity == EntityType.PRIMED_TNT || entity == EntityType.MINECART_TNT)) || (!blockperms.has("creeper", blockperms.has("explode", true)) && entity == EntityType.CREEPER))) {
|
||||
FlagPermissions blockperms = Residence.getPermsByLoc(block
|
||||
.getLocation());
|
||||
if ((!blockperms.has("wither", blockperms.has("explode",
|
||||
world.has("wither", world.has("explode", true))))
|
||||
&& (entity == EntityType.WITHER || entity == EntityType.WITHER_SKULL)
|
||||
|| (!blockperms.has("fireball",
|
||||
blockperms.has("explode", true)) && (entity == EntityType.FIREBALL || entity == EntityType.SMALL_FIREBALL))
|
||||
|| (!blockperms.has("tnt",
|
||||
blockperms.has("explode", true)) && (entity == EntityType.PRIMED_TNT || entity == EntityType.MINECART_TNT)) || (!blockperms
|
||||
.has("creeper", blockperms.has("explode", true)) && entity == EntityType.CREEPER))) {
|
||||
if (block != null) {
|
||||
preserve.add(block);
|
||||
}
|
||||
@ -281,16 +322,18 @@ public class ResidenceEntityListener implements Listener {
|
||||
|
||||
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
|
||||
public void onSplashPotion(PotionSplashEvent event) {
|
||||
if(event.isCancelled())
|
||||
if (event.isCancelled())
|
||||
return;
|
||||
Entity ent = event.getEntity();
|
||||
boolean srcpvp = Residence.getPermsByLoc(ent.getLocation()).has("pvp", true);
|
||||
boolean srcpvp = Residence.getPermsByLoc(ent.getLocation()).has("pvp",
|
||||
true);
|
||||
Iterator<LivingEntity> it = event.getAffectedEntities().iterator();
|
||||
while(it.hasNext()){
|
||||
while (it.hasNext()) {
|
||||
LivingEntity target = it.next();
|
||||
if(target.getType()==EntityType.PLAYER){
|
||||
Boolean tgtpvp = Residence.getPermsByLoc(target.getLocation()).has("pvp", true);
|
||||
if(!srcpvp || !tgtpvp){
|
||||
if (target.getType() == EntityType.PLAYER) {
|
||||
Boolean tgtpvp = Residence.getPermsByLoc(target.getLocation())
|
||||
.has("pvp", true);
|
||||
if (!srcpvp || !tgtpvp) {
|
||||
event.setIntensity(target, 0);
|
||||
}
|
||||
}
|
||||
@ -299,13 +342,15 @@ public class ResidenceEntityListener implements Listener {
|
||||
|
||||
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
|
||||
public void onEntityDamageByEntityEvent(EntityDamageByEntityEvent event) {
|
||||
if (event.getEntityType() == EntityType.ITEM_FRAME || event.getEntityType() == EntityType.ARMOR_STAND) {
|
||||
if (event.getEntityType() == EntityType.ITEM_FRAME
|
||||
|| event.getEntityType() == EntityType.ARMOR_STAND) {
|
||||
Entity dmgr = event.getDamager();
|
||||
Player player;
|
||||
if (event.getDamager() instanceof Player) {
|
||||
if (dmgr instanceof Player) {
|
||||
player = (Player) event.getDamager();
|
||||
} else {
|
||||
if (dmgr instanceof Projectile && ((Projectile) dmgr).getShooter() instanceof Player) {
|
||||
if (dmgr instanceof Projectile
|
||||
&& ((Projectile) dmgr).getShooter() instanceof Player) {
|
||||
player = (Player) ((Projectile) dmgr).getShooter();
|
||||
} else
|
||||
return;
|
||||
@ -314,12 +359,26 @@ public class ResidenceEntityListener implements Listener {
|
||||
if (Residence.isResAdminOn(player))
|
||||
return;
|
||||
|
||||
// Note: Location of entity, not player; otherwise player could stand outside of res and still damage
|
||||
// Note: Location of entity, not player; otherwise player could
|
||||
// stand outside of res and still damage
|
||||
Location loc = event.getEntity().getLocation();
|
||||
ClaimedResidence res = Residence.getResidenceManager().getByLoc(loc);
|
||||
if (res != null && !res.getPermissions().playerHas(player.getName(), "container", false)) {
|
||||
ClaimedResidence res = Residence.getResidenceManager()
|
||||
.getByLoc(loc);
|
||||
if (res != null) {
|
||||
if (!res.getPermissions().has("container", false)) {
|
||||
if (isMonster(dmgr)) {
|
||||
event.setCancelled(true);
|
||||
player.sendMessage(ChatColor.RED + Residence.getLanguage().getPhrase("FlagDeny", "container"));
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (!res.getPermissions().playerHas(player.getName(),
|
||||
"container", false)) {
|
||||
event.setCancelled(true);
|
||||
player.sendMessage(ChatColor.RED
|
||||
+ Residence.getLanguage().getPhrase("FlagDeny",
|
||||
"container"));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -327,54 +386,69 @@ public class ResidenceEntityListener implements Listener {
|
||||
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
|
||||
public void onEntityDamage(EntityDamageEvent event) {
|
||||
Entity ent = event.getEntity();
|
||||
if(ent.hasMetadata("NPC")) {
|
||||
if (ent.hasMetadata("NPC")) {
|
||||
return;
|
||||
}
|
||||
boolean tamedWolf = ent instanceof Wolf ? ((Wolf)ent).isTamed() : false;
|
||||
ClaimedResidence area = Residence.getResidenceManager().getByLoc(ent.getLocation());
|
||||
boolean tamedWolf = ent instanceof Wolf ? ((Wolf) ent).isTamed()
|
||||
: false;
|
||||
ClaimedResidence area = Residence.getResidenceManager().getByLoc(
|
||||
ent.getLocation());
|
||||
/* Living Entities */
|
||||
if (event instanceof EntityDamageByEntityEvent) {
|
||||
EntityDamageByEntityEvent attackevent = (EntityDamageByEntityEvent) event;
|
||||
Entity damager = attackevent.getDamager();
|
||||
ClaimedResidence srcarea = null;
|
||||
if (damager != null) {
|
||||
srcarea = Residence.getResidenceManager().getByLoc(damager.getLocation());
|
||||
srcarea = Residence.getResidenceManager().getByLoc(
|
||||
damager.getLocation());
|
||||
}
|
||||
boolean srcpvp = true;
|
||||
if (srcarea != null) {
|
||||
srcpvp = srcarea.getPermissions().has("pvp", true);
|
||||
}
|
||||
ent = attackevent.getEntity();
|
||||
if ((ent instanceof Player || tamedWolf) && (damager instanceof Player || (damager instanceof Arrow && (((Arrow)damager).getShooter() instanceof Player)))) {
|
||||
if ((ent instanceof Player || tamedWolf)
|
||||
&& (damager instanceof Player || (damager instanceof Arrow && (((Arrow) damager)
|
||||
.getShooter() instanceof Player)))) {
|
||||
Player attacker = null;
|
||||
if (damager instanceof Player) {
|
||||
attacker = (Player) damager;
|
||||
} else if (damager instanceof Arrow) {
|
||||
attacker = (Player)((Arrow)damager).getShooter();
|
||||
attacker = (Player) ((Arrow) damager).getShooter();
|
||||
}
|
||||
if(!srcpvp) {
|
||||
attacker.sendMessage(ChatColor.RED+Residence.getLanguage().getPhrase("NoPVPZone"));
|
||||
if (!srcpvp) {
|
||||
attacker.sendMessage(ChatColor.RED
|
||||
+ Residence.getLanguage().getPhrase("NoPVPZone"));
|
||||
event.setCancelled(true);
|
||||
return;
|
||||
}
|
||||
/* Check for Player vs Player */
|
||||
if (area == null) {
|
||||
/* World PvP */
|
||||
if (!Residence.getWorldFlags().getPerms(damager.getWorld().getName()).has("pvp", true)) {
|
||||
attacker.sendMessage(ChatColor.RED+Residence.getLanguage().getPhrase("WorldPVPDisabled"));
|
||||
if (!Residence.getWorldFlags()
|
||||
.getPerms(damager.getWorld().getName())
|
||||
.has("pvp", true)) {
|
||||
attacker.sendMessage(ChatColor.RED
|
||||
+ Residence.getLanguage().getPhrase(
|
||||
"WorldPVPDisabled"));
|
||||
event.setCancelled(true);
|
||||
}
|
||||
} else {
|
||||
/* Normal PvP */
|
||||
if (!area.getPermissions().has("pvp", true)) {
|
||||
attacker.sendMessage(ChatColor.RED+Residence.getLanguage().getPhrase("NoPVPZone"));
|
||||
attacker.sendMessage(ChatColor.RED
|
||||
+ Residence.getLanguage()
|
||||
.getPhrase("NoPVPZone"));
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
return;
|
||||
} else if ((ent instanceof Player || tamedWolf) && (damager instanceof Creeper)) {
|
||||
} else if ((ent instanceof Player || tamedWolf)
|
||||
&& (damager instanceof Creeper)) {
|
||||
if (area == null) {
|
||||
if (!Residence.getWorldFlags().getPerms(damager.getWorld().getName()).has("creeper", true)) {
|
||||
if (!Residence.getWorldFlags()
|
||||
.getPerms(damager.getWorld().getName())
|
||||
.has("creeper", true)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
} else {
|
||||
@ -385,19 +459,22 @@ public class ResidenceEntityListener implements Listener {
|
||||
}
|
||||
}
|
||||
if (area == null) {
|
||||
if (!Residence.getWorldFlags().getPerms(ent.getWorld().getName()).has("damage", true) && (ent instanceof Player || tamedWolf)) {
|
||||
if (!Residence.getWorldFlags().getPerms(ent.getWorld().getName())
|
||||
.has("damage", true)
|
||||
&& (ent instanceof Player || tamedWolf)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
} else {
|
||||
if (!area.getPermissions().has("damage", true) && (ent instanceof Player || tamedWolf)) {
|
||||
if (!area.getPermissions().has("damage", true)
|
||||
&& (ent instanceof Player || tamedWolf)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
if (event.isCancelled()) {
|
||||
/* Put out a fire on a player */
|
||||
if ((ent instanceof Player || tamedWolf)
|
||||
&& (event.getCause() == EntityDamageEvent.DamageCause.FIRE
|
||||
|| event.getCause() == EntityDamageEvent.DamageCause.FIRE_TICK)) {
|
||||
&& (event.getCause() == EntityDamageEvent.DamageCause.FIRE || event
|
||||
.getCause() == EntityDamageEvent.DamageCause.FIRE_TICK)) {
|
||||
ent.setFireTicks(0);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user