Implemented a PvM Flag

This commit is contained in:
Dark Arc 2013-10-18 15:48:39 -04:00 committed by Wyatt Childers
parent d827e01760
commit 82cde6b5ec
2 changed files with 97 additions and 21 deletions

View File

@ -20,12 +20,14 @@
import static com.sk89q.worldguard.bukkit.BukkitUtil.toVector; import static com.sk89q.worldguard.bukkit.BukkitUtil.toVector;
import java.util.HashSet;
import java.util.Set; import java.util.Set;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.World; import org.bukkit.World;
import org.bukkit.block.Block; import org.bukkit.block.Block;
import org.bukkit.entity.Creature;
import org.bukkit.entity.Creeper; import org.bukkit.entity.Creeper;
import org.bukkit.entity.EnderDragon; import org.bukkit.entity.EnderDragon;
import org.bukkit.entity.EnderPearl; import org.bukkit.entity.EnderPearl;
@ -37,6 +39,7 @@
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.entity.Projectile; import org.bukkit.entity.Projectile;
import org.bukkit.entity.Slime;
import org.bukkit.entity.TNTPrimed; import org.bukkit.entity.TNTPrimed;
import org.bukkit.entity.Tameable; import org.bukkit.entity.Tameable;
import org.bukkit.entity.ThrownPotion; import org.bukkit.entity.ThrownPotion;
@ -223,6 +226,7 @@ private void onEntityDamageByEntity(EntityDamageByEntityEvent event) {
if (attacker instanceof Player) { if (attacker instanceof Player) {
Player player = (Player) attacker; Player player = (Player) attacker;
LocalPlayer localPlayer = plugin.wrapPlayer(player);
ConfigurationManager cfg = plugin.getGlobalStateManager(); ConfigurationManager cfg = plugin.getGlobalStateManager();
WorldConfiguration wcfg = cfg.get(player.getWorld()); WorldConfiguration wcfg = cfg.get(player.getWorld());
@ -239,6 +243,29 @@ private void onEntityDamageByEntity(EntityDamageByEntityEvent event) {
} }
} }
} }
// Bukkit doesn't consider Slimes to be Creatures for whatever reason
if (defender instanceof Creature || defender instanceof Slime) {
if (wcfg.useRegions) {
Vector pt = toVector(defender.getLocation());
Vector pt2 = toVector(attacker.getLocation());
RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld());
// Accumulate all entities that aren't allowed to be attacked here
Set<EntityType> entityTypes = new HashSet<EntityType>();
Set<EntityType> es = mgr.getApplicableRegions(pt).getFlag(DefaultFlag.DENY_PVM, localPlayer);
Set<EntityType> es2 = mgr.getApplicableRegions(pt2).getFlag(DefaultFlag.DENY_PVM, localPlayer);
if (es != null) entityTypes.addAll(es);
if (es2 != null) entityTypes.addAll(es2);
if (entityTypes.contains(defender.getType())) {
player.sendMessage(ChatColor.DARK_RED + "You may not attack that mob here.");
event.setCancelled(true);
return;
}
}
}
} }
if (defender instanceof ItemFrame) { if (defender instanceof ItemFrame) {
@ -281,17 +308,30 @@ private void onEntityDamageByEntity(EntityDamageByEntityEvent event) {
} }
if (attacker != null) { if (attacker != null) {
if (attacker instanceof Player) { if (wcfg.useRegions) {
if (wcfg.useRegions) { Vector pt = toVector(defender.getLocation());
Vector pt = toVector(defender.getLocation()); Vector pt2 = toVector(attacker.getLocation());
Vector pt2 = toVector(attacker.getLocation()); RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld());
RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld());
if (attacker instanceof Player) {
if (!mgr.getApplicableRegions(pt2).allows(DefaultFlag.PVP, plugin.wrapPlayer((Player) attacker))) { if (!mgr.getApplicableRegions(pt2).allows(DefaultFlag.PVP, plugin.wrapPlayer((Player) attacker))) {
tryCancelPVPEvent((Player) attacker, player, event, true); tryCancelPVPEvent((Player) attacker, player, event, true);
} else if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.PVP ,localPlayer)) { } else if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.PVP ,localPlayer)) {
tryCancelPVPEvent((Player) attacker, player, event, false); tryCancelPVPEvent((Player) attacker, player, event, false);
} }
} else {
// Accumulate all entities that aren't allowed to be attacked here
Set<EntityType> entityTypes = new HashSet<EntityType>();
Set<EntityType> es = mgr.getApplicableRegions(pt).getFlag(DefaultFlag.DENY_PVM, localPlayer);
Set<EntityType> es2 = mgr.getApplicableRegions(pt2).getFlag(DefaultFlag.DENY_PVM, localPlayer);
if (es != null) entityTypes.addAll(es);
if (es2 != null) entityTypes.addAll(es2);
if (entityTypes.contains(attacker.getType())) {
event.setCancelled(true);
return;
}
} }
} }
@ -408,6 +448,43 @@ private void onEntityDamageByProjectile(EntityDamageByEntityEvent event) {
return; return;
} }
if (attacker instanceof Player) {
Player player = (Player) attacker;
LocalPlayer localPlayer = plugin.wrapPlayer(player);
ConfigurationManager cfg = plugin.getGlobalStateManager();
WorldConfiguration wcfg = cfg.get(player.getWorld());
if (event.getDamager() instanceof EnderPearl && attacker.equals(defender)) return;
if (wcfg.useRegions) {
Vector pt = toVector(defender.getLocation());
Vector pt2 = toVector(attacker.getLocation());
RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld());
if (defender instanceof Player) {
if (!mgr.getApplicableRegions(pt2).allows(DefaultFlag.PVP, plugin.wrapPlayer((Player) attacker))) {
tryCancelPVPEvent((Player) attacker, player, event, true);
} else if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.PVP, localPlayer)) {
tryCancelPVPEvent((Player) attacker, player, event, false);
}
} else {
// Accumulate all entities that aren't allowed to be attacked here
Set<EntityType> entityTypes = new HashSet<EntityType>();
Set<EntityType> es = mgr.getApplicableRegions(pt).getFlag(DefaultFlag.DENY_PVM, localPlayer);
Set<EntityType> es2 = mgr.getApplicableRegions(pt2).getFlag(DefaultFlag.DENY_PVM, localPlayer);
if (es != null) entityTypes.addAll(es);
if (es2 != null) entityTypes.addAll(es2);
if (entityTypes.contains(defender.getType())) {
player.sendMessage(ChatColor.DARK_RED + "You may not attack that mob here.");
event.setCancelled(true);
return;
}
}
}
}
if (defender instanceof Player) { if (defender instanceof Player) {
Player player = (Player) defender; Player player = (Player) defender;
LocalPlayer localPlayer = plugin.wrapPlayer(player); LocalPlayer localPlayer = plugin.wrapPlayer(player);
@ -422,35 +499,33 @@ private void onEntityDamageByProjectile(EntityDamageByEntityEvent event) {
} }
// Check Mob // Check Mob
if (attacker != null && !(attacker instanceof Player)) { if (!(attacker instanceof Player)) {
if (wcfg.disableMobDamage) { if (wcfg.disableMobDamage) {
event.setCancelled(true); event.setCancelled(true);
return; return;
} }
if (wcfg.useRegions) { if (wcfg.useRegions) {
Vector pt = toVector(defender.getLocation()); Vector pt = toVector(defender.getLocation());
Vector pt2 = toVector(attacker.getLocation());
RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld());
if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.MOB_DAMAGE, localPlayer)) { if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.MOB_DAMAGE, localPlayer)) {
event.setCancelled(true); event.setCancelled(true);
return; return;
} }
}
}
// Check Player // Accumulate all entities that aren't allowed to be attacked here
// if (event.getDamager() instanceof EnderPearl || event.getDamager() instanceof Snowball) return; Set<EntityType> entityTypes = new HashSet<EntityType>();
if (attacker != null && attacker instanceof Player) { Set<EntityType> es = mgr.getApplicableRegions(pt).getFlag(DefaultFlag.DENY_PVM, localPlayer);
if (event.getDamager() instanceof EnderPearl && attacker == player) return; Set<EntityType> es2 = mgr.getApplicableRegions(pt2).getFlag(DefaultFlag.DENY_PVM, localPlayer);
if (wcfg.useRegions) {
Vector pt = toVector(defender.getLocation());
Vector pt2 = toVector(attacker.getLocation());
RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld());
if (!mgr.getApplicableRegions(pt2).allows(DefaultFlag.PVP, plugin.wrapPlayer((Player) attacker))) { if (es != null) entityTypes.addAll(es);
tryCancelPVPEvent((Player) attacker, player, event, true); if (es2 != null) entityTypes.addAll(es2);
} else if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.PVP, localPlayer)) {
tryCancelPVPEvent((Player) attacker, player, event, false); if (entityTypes.contains(attacker.getType())) {
event.setCancelled(true);
return;
} }
} }
} }

View File

@ -78,6 +78,7 @@ public final class DefaultFlag {
public static final BooleanFlag NOTIFY_ENTER = new BooleanFlag("notify-enter", RegionGroup.ALL); public static final BooleanFlag NOTIFY_ENTER = new BooleanFlag("notify-enter", RegionGroup.ALL);
public static final BooleanFlag NOTIFY_LEAVE = new BooleanFlag("notify-leave", RegionGroup.ALL); public static final BooleanFlag NOTIFY_LEAVE = new BooleanFlag("notify-leave", RegionGroup.ALL);
public static final SetFlag<EntityType> DENY_SPAWN = new SetFlag<EntityType>("deny-spawn", RegionGroup.ALL, new EntityTypeFlag(null)); public static final SetFlag<EntityType> DENY_SPAWN = new SetFlag<EntityType>("deny-spawn", RegionGroup.ALL, new EntityTypeFlag(null));
public static final SetFlag<EntityType> DENY_PVM = new SetFlag<EntityType>("deny-pvm", new EntityTypeFlag(null));
public static final EnumFlag<GameMode> GAME_MODE = new EnumFlag<GameMode>("game-mode", GameMode.class, RegionGroup.ALL); public static final EnumFlag<GameMode> GAME_MODE = new EnumFlag<GameMode>("game-mode", GameMode.class, RegionGroup.ALL);
public static final IntegerFlag HEAL_DELAY = new IntegerFlag("heal-delay", RegionGroup.ALL); public static final IntegerFlag HEAL_DELAY = new IntegerFlag("heal-delay", RegionGroup.ALL);
public static final IntegerFlag HEAL_AMOUNT = new IntegerFlag("heal-amount", RegionGroup.ALL); public static final IntegerFlag HEAL_AMOUNT = new IntegerFlag("heal-amount", RegionGroup.ALL);
@ -100,7 +101,7 @@ public final class DefaultFlag {
public static final Flag<?>[] flagsList = new Flag<?>[] { public static final Flag<?>[] flagsList = new Flag<?>[] {
PASSTHROUGH, BUILD, CONSTRUCT, PVP, CHEST_ACCESS, PISTONS, PASSTHROUGH, BUILD, CONSTRUCT, PVP, CHEST_ACCESS, PISTONS,
TNT, LIGHTER, USE, PLACE_VEHICLE, DESTROY_VEHICLE, SLEEP, TNT, LIGHTER, USE, PLACE_VEHICLE, DESTROY_VEHICLE, SLEEP,
MOB_DAMAGE, MOB_SPAWNING, DENY_SPAWN, INVINCIBILITY, EXP_DROPS, MOB_DAMAGE, MOB_SPAWNING, DENY_SPAWN, DENY_PVM, INVINCIBILITY, EXP_DROPS,
CREEPER_EXPLOSION, OTHER_EXPLOSION, ENDERDRAGON_BLOCK_DAMAGE, GHAST_FIREBALL, ENDER_BUILD, CREEPER_EXPLOSION, OTHER_EXPLOSION, ENDERDRAGON_BLOCK_DAMAGE, GHAST_FIREBALL, ENDER_BUILD,
GREET_MESSAGE, FAREWELL_MESSAGE, NOTIFY_ENTER, NOTIFY_LEAVE, GREET_MESSAGE, FAREWELL_MESSAGE, NOTIFY_ENTER, NOTIFY_LEAVE,
EXIT, ENTRY, LIGHTNING, ENTITY_PAINTING_DESTROY, ENDERPEARL, EXIT, ENTRY, LIGHTNING, ENTITY_PAINTING_DESTROY, ENDERPEARL,