diff --git a/src/com/sk89q/worldguard/blacklist/BlacklistEntry.java b/src/com/sk89q/worldguard/blacklist/BlacklistEntry.java index 09fc04c1..eda60328 100644 --- a/src/com/sk89q/worldguard/blacklist/BlacklistEntry.java +++ b/src/com/sk89q/worldguard/blacklist/BlacklistEntry.java @@ -272,7 +272,7 @@ private String[] getActions(BlacklistEvent event) { * @param silent * @return */ - public boolean check(Boolean useAsWhitelist, BlacklistEvent event, boolean forceRepeat, boolean silent) { + public boolean check(boolean useAsWhitelist, BlacklistEvent event, boolean forceRepeat, boolean silent) { LocalPlayer player = event.getPlayer(); if (shouldIgnore(player)) { diff --git a/src/com/sk89q/worldguard/bukkit/WorldGuardBlockListener.java b/src/com/sk89q/worldguard/bukkit/WorldGuardBlockListener.java index ccdcc4cb..4d462277 100644 --- a/src/com/sk89q/worldguard/bukkit/WorldGuardBlockListener.java +++ b/src/com/sk89q/worldguard/bukkit/WorldGuardBlockListener.java @@ -137,7 +137,7 @@ public void onBlockBreak(BlockBreakEvent event) { return; } - if (wcfg.getBlacklist().check( + if (!wcfg.getBlacklist().check( new DestroyWithBlacklistEvent(plugin.wrapPlayer(player), toVector(event.getBlock()), player.getItemInHand().getTypeId()), false, false)) { diff --git a/src/com/sk89q/worldguard/bukkit/WorldGuardInteractHandler.java b/src/com/sk89q/worldguard/bukkit/WorldGuardInteractHandler.java deleted file mode 100644 index 811ba218..00000000 --- a/src/com/sk89q/worldguard/bukkit/WorldGuardInteractHandler.java +++ /dev/null @@ -1,331 +0,0 @@ -// $Id$ -/* - * WorldGuard - * Copyright (C) 2010 sk89q - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see . - */ - -package com.sk89q.worldguard.bukkit; - -import static com.sk89q.worldguard.bukkit.BukkitUtil.toVector; - -import java.util.Iterator; -import java.util.List; - -import org.bukkit.ChatColor; -import org.bukkit.Material; -import org.bukkit.block.Block; -import org.bukkit.entity.Player; -import org.bukkit.event.block.Action; -import org.bukkit.event.player.PlayerInteractEvent; -import org.bukkit.inventory.ItemStack; - -import com.sk89q.worldedit.Vector; -import com.sk89q.worldguard.LocalPlayer; -import com.sk89q.worldguard.blacklist.events.BlockInteractBlacklistEvent; -import com.sk89q.worldguard.blacklist.events.ItemUseBlacklistEvent; -import com.sk89q.worldguard.protection.ApplicableRegionSet; -import com.sk89q.worldguard.protection.flags.DefaultFlag; -import com.sk89q.worldguard.protection.managers.RegionManager; - - -/** - * - * @author DarkLiKally - */ -public class WorldGuardInteractHandler { - /** - * Plugin - */ - WorldGuardPlugin plugin; - - public WorldGuardInteractHandler(WorldGuardPlugin plugin) { - this.plugin = plugin; - } - - public boolean onBlockRightclick(PlayerInteractEvent event, ConfigurationManager cfg, WorldConfiguration wcfg, - Action action, Player player, Block block, ItemStack item, int itemId) { - if (wcfg.useRegions && !event.hasBlock() && block != null) { - Vector pt = toVector(block.getRelative(event.getBlockFace())); - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - - if (block.getType() == Material.WALL_SIGN) { - pt = pt.subtract(0, 1, 0); - } - - if (!mgr.getApplicableRegions(pt).canBuild(new BukkitPlayer(plugin, player))) { - player.sendMessage(ChatColor.DARK_RED - + "You don't have permission for this area."); - event.setCancelled(true); - return false; - } - } - - if (wcfg.getBlacklist() != null && item != null && block != null) { - if (!wcfg.getBlacklist().check( - new ItemUseBlacklistEvent(new BukkitPlayer(plugin, player), - toVector(block.getRelative(event.getBlockFace())), - item.getTypeId()), false, false)) { - event.setCancelled(true); - return false; - } - } - - if (wcfg.useRegions && item != null && block != null && item.getTypeId() == 259) { - Vector pt = toVector(block.getRelative(event.getBlockFace())); - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - - if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.LIGHTER)) { - event.setCancelled(true); - return false; - } - } - - - // onBlockInteract - if ((block.getType() == Material.CHEST - || block.getType() == Material.DISPENSER - || block.getType() == Material.FURNACE - || block.getType() == Material.BURNING_FURNACE - || block.getType() == Material.NOTE_BLOCK)) { - if (wcfg.useRegions) { - Vector pt = toVector(block); - LocalPlayer localPlayer = new BukkitPlayer(plugin, player); - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - - if (!plugin.hasPermission(player, "region.bypass")) { - ApplicableRegionSet set = mgr.getApplicableRegions(pt); - if (!set.allows(DefaultFlag.CHEST_ACCESS) && !set.canBuild(localPlayer)) { - player.sendMessage(ChatColor.DARK_RED + "You don't have permission for this area."); - event.setCancelled(true); - return false; - } - } - } - } - - if (wcfg.useRegions && (block.getType() == Material.LEVER - || block.getType() == Material.STONE_BUTTON)) { - Vector pt = toVector(block); - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - ApplicableRegionSet set = mgr.getApplicableRegions(pt); - - if (!set.allows(DefaultFlag.USE)) { - player.sendMessage(ChatColor.DARK_RED + "You don't have permission for this area."); - event.setCancelled(true); - return false; - } - } - - if (wcfg.getBlacklist() != null) { - if (!wcfg.getBlacklist().check( - new BlockInteractBlacklistEvent(new BukkitPlayer(plugin, player), toVector(block), - block.getTypeId()), false, false)) { - event.setCancelled(true); - return false; - } - } - - // onBlockRightClick - if (wcfg.useRegions && itemId == wcfg.regionWand) { - Vector pt = toVector(block); - - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - ApplicableRegionSet set = mgr.getApplicableRegions(pt); - List regions = mgr.getApplicableRegionsIDs(pt); - - if (regions.size() > 0) { - player.sendMessage(ChatColor.YELLOW + "Can you build? " - + (set.canBuild(new BukkitPlayer(plugin, player)) ? "Yes" : "No")); - - StringBuilder str = new StringBuilder(); - for (Iterator it = regions.iterator(); it.hasNext();) { - str.append(it.next()); - if (it.hasNext()) { - str.append(", "); - } - } - - player.sendMessage(ChatColor.YELLOW + "Applicable regions: " + str.toString()); - } else { - player.sendMessage(ChatColor.YELLOW + "WorldGuard: No defined regions here!"); - } - } - - Material type = block.getType(); - - if (wcfg.useRegions && type == Material.CAKE_BLOCK) { - Vector pt = toVector(block); - - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - ApplicableRegionSet set = mgr.getApplicableRegions(pt); - - if (!set.canBuild(new BukkitPlayer(plugin, player))) { - player.sendMessage(ChatColor.DARK_RED + "You don't have permission for this area."); - - byte newData = (byte) (block.getData() - 1); - newData = newData < 0 ? 0 : newData; - - block.setData(newData); - player.setHealth(player.getHealth() - 3); - - return true; - } - } - - /*if (wcfg.useRegions && wcfg.useiConomy && cfg.getiConomy() != null - && (type == Material.SIGN_POST || type == Material.SIGN || type == Material.WALL_SIGN)) { - BlockState blockState = block.getState(); - - if (((Sign)blockState).getLine(0).equalsIgnoreCase("[WorldGuard]") - && ((Sign)blockState).getLine(1).equalsIgnoreCase("For sale")) { - String regionId = ((Sign)blockState).getLine(2); - //String regionComment = ((Sign)block).getLine(3); - - if (regionId != null && regionId != "") { - RegionManager mgr = cfg.getWorldGuardPlugin().getGlobalRegionManager().getRegionManager(player.getWorld().getName()); - ProtectedRegion region = mgr.getRegion(regionId); - - if (region != null) { - RegionFlagContainer flags = region.getFlags(); - - if (flags.getBooleanFlag(Flags.BUYABLE).getValue(false)) { - if (iConomy.getBank().hasAccount(player.getName())) { - Account account = iConomy.getBank().getAccount(player.getName()); - double balance = account.getBalance(); - double regionPrice = flags.getDoubleFlag(Flags.PRICE).getValue(); - - if (balance >= regionPrice) { - account.subtract(regionPrice); - player.sendMessage(ChatColor.YELLOW + "You have bought the region " + regionId + " for " + - iConomy.getBank().format(regionPrice)); - DefaultDomain owners = region.getOwners(); - owners.addPlayer(player.getName()); - region.setOwners(owners); - flags.getBooleanFlag(Flags.BUYABLE).setValue(false); - try{ - account.save(); - } catch(Exception e) {} - } else { - player.sendMessage(ChatColor.YELLOW + "You have not enough money."); - } - } else { - player.sendMessage(ChatColor.YELLOW + "You have not enough money."); - } - } else { - player.sendMessage(ChatColor.RED + "Region: " + regionId + " is not buyable"); - } - } else { - player.sendMessage(ChatColor.DARK_RED + "The region " + regionId + " does not exist."); - } - } else { - player.sendMessage(ChatColor.DARK_RED + "No region specified."); - } - } - }*/ - - return true; - } - - public boolean onBlockClick(PlayerInteractEvent event, ConfigurationManager cfg, WorldConfiguration wcfg, - Action action, Player player, Block block, ItemStack item, int itemId) { - if (wcfg.useRegions && !event.hasBlock() && block != null) { - Vector pt = toVector(block.getRelative(event.getBlockFace())); - - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - ApplicableRegionSet set = mgr.getApplicableRegions(pt); - - if (block.getType() == Material.WALL_SIGN) { - pt = pt.subtract(0, 1, 0); - } - - if (!set.canBuild(new BukkitPlayer(plugin, player))) { - player.sendMessage(ChatColor.DARK_RED - + "You don't have permission for this area."); - event.setCancelled(true); - return false; - } - } - - if (wcfg.getBlacklist() != null && item != null && block != null) { - if (!wcfg.getBlacklist().check( - new ItemUseBlacklistEvent(new BukkitPlayer(plugin, player), - toVector(block.getRelative(event.getBlockFace())), - item.getTypeId()), false, false)) { - event.setCancelled(true); - return false; - } - } - - if (wcfg.useRegions && item != null && block != null && item.getTypeId() == 259) { - Vector pt = toVector(block.getRelative(event.getBlockFace())); - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - - if (!mgr.getApplicableRegions(pt).allows(DefaultFlag.LIGHTER)) { - event.setCancelled(true); - return false; - } - } - - // onBlockInteract - if (wcfg.useRegions && (block.getType() == Material.LEVER - || block.getType() == Material.STONE_BUTTON)) { - Vector pt = toVector(block); - RegionManager mgr = plugin.getGlobalRegionManager().get(player.getWorld()); - ApplicableRegionSet applicableRegions = mgr.getApplicableRegions(pt); - - if (!applicableRegions.allows(DefaultFlag.USE)) { - player.sendMessage(ChatColor.DARK_RED + "You don't have permission for this area."); - event.setCancelled(true); - return false; - } - } - - if (wcfg.getBlacklist() != null) { - if (!wcfg.getBlacklist().check( - new BlockInteractBlacklistEvent(new BukkitPlayer(plugin, player), toVector(block), - block.getTypeId()), false, false)) { - event.setCancelled(true); - return false; - } - } - - return true; - } - - public boolean onBlockPlace(PlayerInteractEvent event, ConfigurationManager cfg, WorldConfiguration wcfg, - Action action, Player player, Block block, ItemStack item, int itemId) { - return true; - } - - public boolean itemInHand(PlayerInteractEvent event, WorldConfiguration wcfg, - Action action, Player player, Block block, ItemStack item, int itemId) { - if (wcfg.useRegions - && (itemId == 322 || itemId == 320 || itemId == 319 || itemId == 297 || itemId == 260 - || itemId == 350 || itemId == 349 || itemId == 354) ) { - return true; - } - - if (!wcfg.itemDurability) { - // Hoes - if (item.getTypeId() >= 290 && item.getTypeId() <= 294) { - item.setDurability((byte) -1); - player.setItemInHand(item); - } - } - - return false; - } -} \ No newline at end of file diff --git a/src/com/sk89q/worldguard/bukkit/WorldGuardPlayerListener.java b/src/com/sk89q/worldguard/bukkit/WorldGuardPlayerListener.java index cc5e432c..be595ad3 100644 --- a/src/com/sk89q/worldguard/bukkit/WorldGuardPlayerListener.java +++ b/src/com/sk89q/worldguard/bukkit/WorldGuardPlayerListener.java @@ -72,6 +72,8 @@ public void registerEvents() { pm.registerEvent(Event.Type.PLAYER_JOIN, this, Priority.Normal, plugin); pm.registerEvent(Event.Type.PLAYER_LOGIN, this, Priority.Normal, plugin); pm.registerEvent(Event.Type.PLAYER_QUIT, this, Priority.Normal, plugin); + pm.registerEvent(Event.Type.PLAYER_BUCKET_FILL, this, Priority.High, plugin); + pm.registerEvent(Event.Type.PLAYER_BUCKET_EMPTY, this, Priority.High, plugin); pm.registerEvent(Event.Type.PLAYER_RESPAWN, this, Priority.High, plugin); } @@ -83,7 +85,9 @@ public void registerEvents() { @Override public void onPlayerInteract(PlayerInteractEvent event) { if (event.getAction() == Action.RIGHT_CLICK_BLOCK) { - handleblockRightClick(event); + handleBlockRightClick(event); + } else if (event.getAction() == Action.RIGHT_CLICK_AIR) { + handleAirRightClick(event); } } @@ -92,7 +96,35 @@ public void onPlayerInteract(PlayerInteractEvent event) { * * @param event */ - public void handleblockRightClick(PlayerInteractEvent event) { + public void handleAirRightClick(PlayerInteractEvent event) { + /*if (event.isCancelled()) { + return; + }*/ + + Player player = event.getPlayer(); + World world = player.getWorld(); + ItemStack item = player.getItemInHand(); + + ConfigurationManager cfg = plugin.getGlobalConfiguration(); + WorldConfiguration wcfg = cfg.get(world); + + if (wcfg.getBlacklist() != null) { + if (!wcfg.getBlacklist().check( + new ItemUseBlacklistEvent(plugin.wrapPlayer(player), + toVector(player.getLocation()), + item.getTypeId()), false, false)) { + event.setCancelled(true); + return; + } + } + } + + /** + * Called when a block is damaged. + * + * @param event + */ + public void handleBlockRightClick(PlayerInteractEvent event) { if (event.isCancelled()) { return; } @@ -179,13 +211,11 @@ public void handleblockRightClick(PlayerInteractEvent event) { } if (wcfg.getBlacklist() != null) { - if (item.getType() == Material.FLINT_AND_STEEL) { - if (!wcfg.getBlacklist().check( - new ItemUseBlacklistEvent(plugin.wrapPlayer(player), toVector(block), - item.getTypeId()), false, false)) { - event.setCancelled(true); - return; - } + if (!wcfg.getBlacklist().check( + new ItemUseBlacklistEvent(plugin.wrapPlayer(player), toVector(block), + item.getTypeId()), false, false)) { + event.setCancelled(true); + return; } if (!wcfg.getBlacklist().check( @@ -388,7 +418,8 @@ public void onPlayerDropItem(PlayerDropItemEvent event) { Item ci = event.getItemDrop(); if (!wcfg.getBlacklist().check( - new ItemDropBlacklistEvent(plugin.wrapPlayer(event.getPlayer()), toVector(ci.getLocation()), ci.getItemStack().getTypeId()), false, false)) { + new ItemDropBlacklistEvent(plugin.wrapPlayer(event.getPlayer()), + toVector(ci.getLocation()), ci.getItemStack().getTypeId()), false, false)) { event.setCancelled(true); return; } @@ -415,12 +446,68 @@ public void onPlayerPickupItem(PlayerPickupItemEvent event) { Item ci = event.getItem(); if (!wcfg.getBlacklist().check( - new ItemAcquireBlacklistEvent(plugin.wrapPlayer(event.getPlayer()), toVector(ci.getLocation()), ci.getItemStack().getTypeId()), false, false)) { + new ItemAcquireBlacklistEvent(plugin.wrapPlayer(event.getPlayer()), + toVector(ci.getLocation()), ci.getItemStack().getTypeId()), false, true)) { event.setCancelled(true); return; } } } + + /** + * Called when a bucket is filled. + */ + @Override + public void onPlayerBucketFill(PlayerBucketFillEvent event) { + Player player = event.getPlayer(); + World world = player.getWorld(); + + ConfigurationManager cfg = plugin.getGlobalConfiguration(); + WorldConfiguration wcfg = cfg.get(world); + + if (!plugin.getGlobalRegionManager().canBuild(player, event.getBlockClicked())) { + player.sendMessage(ChatColor.DARK_RED + "You don't have permission for this area."); + event.setCancelled(true); + return; + } + + if (wcfg.getBlacklist() != null) { + if (!wcfg.getBlacklist().check( + new ItemUseBlacklistEvent(plugin.wrapPlayer(player), + toVector(player.getLocation()), event.getBucket().getId()), false, false)) { + event.setCancelled(true); + return; + } + } + } + + /** + * Called when a bucket is empty. + */ + @Override + public void onPlayerBucketEmpty(PlayerBucketEmptyEvent event) { + Player player = event.getPlayer(); + World world = player.getWorld(); + + ConfigurationManager cfg = plugin.getGlobalConfiguration(); + WorldConfiguration wcfg = cfg.get(world); + + if (!plugin.getGlobalRegionManager().canBuild(player, event.getBlockClicked())) { + player.sendMessage(ChatColor.DARK_RED + "You don't have permission for this area."); + event.setCancelled(true); + return; + } + + if (wcfg.getBlacklist() != null) { + if (!wcfg.getBlacklist().check( + new ItemUseBlacklistEvent(plugin.wrapPlayer(player), + toVector(player.getLocation()), event.getBucket().getId()), false, false)) { + event.setCancelled(true); + return; + } + } + } + /* @Override public void onPlayerRespawn(PlayerRespawnEvent event) {