Added region claiming, some fixes.

This commit is contained in:
sk89q 2011-01-16 10:44:37 -08:00
parent c82ee055e7
commit 5db7f124ac
6 changed files with 247 additions and 31 deletions

View File

@ -297,7 +297,7 @@ public boolean handleCommand(PlayerChatEvent event) {
} else if (split[0].equalsIgnoreCase("/rg") } else if (split[0].equalsIgnoreCase("/rg")
|| split[0].equalsIgnoreCase("/region")) { || split[0].equalsIgnoreCase("/region")) {
if (split.length < 2) { if (split.length < 2) {
player.sendMessage(ChatColor.RED + "/rg <define|flag|delete|info|add|remove|list|save|load> ..."); player.sendMessage(ChatColor.RED + "/region <define|flag|delete|info|add|remove|list|save|load> ...");
return true; return true;
} }
@ -321,10 +321,19 @@ public boolean handleCommand(PlayerChatEvent event) {
* @param args * @param args
*/ */
private void handleRegionCommand(Player player, String action, String[] args) { private void handleRegionCommand(Player player, String action, String[] args) {
if (action.equalsIgnoreCase("define") if (!plugin.useRegions) {
&& canUseRegionCommand(player, "/regiondefine")) { player.sendMessage(ChatColor.RED + "Regions are disabled.");
return;
}
if (action.equalsIgnoreCase("define")) {
if (!canUseRegionCommand(player, "/regiondefine")) {
player.sendMessage(ChatColor.RED + "You don't have the /regiondefine permission.");
return;
}
if (args.length < 2) { if (args.length < 2) {
player.sendMessage(ChatColor.RED + "/rg define <id> [owner1 [owner2 [owners...]]]"); player.sendMessage(ChatColor.RED + "/region define <id> [owner1 [owner2 [owners...]]]");
return; return;
} }
@ -358,10 +367,68 @@ && canUseRegionCommand(player, "/regiondefine")) {
player.sendMessage(ChatColor.RED + "Region database failed to save: " player.sendMessage(ChatColor.RED + "Region database failed to save: "
+ e.getMessage()); + e.getMessage());
} }
} else if (action.equalsIgnoreCase("flag") } else if (action.equalsIgnoreCase("claim")) {
&& canUseRegionCommand(player, "/regiondefine")) { if (!canUseRegionCommand(player, "/regionclaim")) {
player.sendMessage(ChatColor.RED + "You don't have the /regionclaim permission.");
return;
}
if (args.length < 1) {
player.sendMessage(ChatColor.RED + "/region claim <id>");
return;
}
try {
String id = args[1].toLowerCase();
Plugin wePlugin = plugin.getServer().getPluginManager().getPlugin("WorldEdit");
if (plugin == null) {
player.sendMessage(ChatColor.RED + "WorldEdit must be installed and enabled as a plugin.");
return;
}
ProtectedRegion existing = plugin.regionManager.getRegion(id);
if (existing != null) {
if (!existing.getOwners().contains(plugin.wrapPlayer(player))) {
player.sendMessage(ChatColor.RED + "You don't own this region.");
return;
}
}
WorldEditPlugin worldEdit = (WorldEditPlugin)wePlugin;
WorldEditAPI api = worldEdit.getAPI();
LocalSession session = api.getSession(player);
Region weRegion = session.getRegion();
BlockVector min = weRegion.getMinimumPoint().toBlockVector();
BlockVector max = weRegion.getMaximumPoint().toBlockVector();
ProtectedRegion region = new ProtectedCuboidRegion(min, max);
if (!plugin.regionManager.overlapsUnownedRegion(region, plugin.wrapPlayer(player))) {
player.sendMessage(ChatColor.RED + "This region overlaps with someone else's region.");
return;
}
plugin.regionManager.addRegion(id, region);
plugin.regionLoader.save(plugin.regionManager);
player.sendMessage(ChatColor.YELLOW + "Region saved as " + id + ".");
} catch (IncompleteRegionException e) {
player.sendMessage(ChatColor.RED + "You must first define an area in WorldEdit.");
} catch (IOException e) {
player.sendMessage(ChatColor.RED + "Region database failed to save: "
+ e.getMessage());
}
} else if (action.equalsIgnoreCase("flag")) {
if (!canUseRegionCommand(player, "/regiondefine")) {
player.sendMessage(ChatColor.RED + "You don't have the /regiondefine permission.");
return;
}
if (args.length < 4) { if (args.length < 4) {
player.sendMessage(ChatColor.RED + "/rg flag <id> <build|pvp|tnt|lighter> <none|allow|deny>"); player.sendMessage(ChatColor.RED + "/region flag <id> <lighter> <none|allow|deny>");
player.sendMessage(ChatColor.RED + "Other flags not supported in Bukkit at the moment.");
return; return;
} }
@ -391,13 +458,13 @@ && canUseRegionCommand(player, "/regiondefine")) {
AreaFlags flags = region.getFlags(); AreaFlags flags = region.getFlags();
if (flagStr.equalsIgnoreCase("build")) { /*if (flagStr.equalsIgnoreCase("build")) {
flags.allowBuild = state; flags.allowBuild = state;
} else if (flagStr.equalsIgnoreCase("pvp")) { } else if (flagStr.equalsIgnoreCase("pvp")) {
flags.allowPvP = state; flags.allowPvP = state;
} else if (flagStr.equalsIgnoreCase("tnt")) { } else if (flagStr.equalsIgnoreCase("tnt")) {
flags.allowTNT = state; flags.allowTNT = state;
} else if (flagStr.equalsIgnoreCase("lighter")) { } else*/ if (flagStr.equalsIgnoreCase("lighter")) {
flags.allowLighter = state; flags.allowLighter = state;
} else { } else {
player.sendMessage(ChatColor.RED + "Acceptable flags: build, pvp, tnt, lighter"); player.sendMessage(ChatColor.RED + "Acceptable flags: build, pvp, tnt, lighter");
@ -410,10 +477,14 @@ && canUseRegionCommand(player, "/regiondefine")) {
player.sendMessage(ChatColor.RED + "Region database failed to save: " player.sendMessage(ChatColor.RED + "Region database failed to save: "
+ e.getMessage()); + e.getMessage());
} }
} else if (action.equalsIgnoreCase("info") } else if (action.equalsIgnoreCase("info")) {
&& canUseRegionCommand(player, "/regioninfo")) { if (!canUseRegionCommand(player, "/regioninfo")) {
player.sendMessage(ChatColor.RED + "You don't have the /regioninfo permission.");
return;
}
if (args.length < 2) { if (args.length < 2) {
player.sendMessage(ChatColor.RED + "/rg info <id>"); player.sendMessage(ChatColor.RED + "/region info <id>");
return; return;
} }
@ -436,10 +507,15 @@ && canUseRegionCommand(player, "/regioninfo")) {
player.sendMessage(ChatColor.BLUE + "Lighter: " + flags.allowLighter.name()); player.sendMessage(ChatColor.BLUE + "Lighter: " + flags.allowLighter.name());
player.sendMessage(ChatColor.LIGHT_PURPLE + "Players: " + domain.toPlayersString()); player.sendMessage(ChatColor.LIGHT_PURPLE + "Players: " + domain.toPlayersString());
player.sendMessage(ChatColor.LIGHT_PURPLE + "Groups: " + domain.toGroupsString()); player.sendMessage(ChatColor.LIGHT_PURPLE + "Groups: " + domain.toGroupsString());
} else if (action.equalsIgnoreCase("add") } else if (action.equalsIgnoreCase("addowner")) {
&& canUseRegionCommand(player, "/regiondefine")) { if (!canUseRegionCommand(player, "/regiondefine")
&& !canUseRegionCommand(player, "/regionclaim")) {
player.sendMessage(ChatColor.RED + "You don't have the /regiondefine permission.");
return;
}
if (args.length < 2) { if (args.length < 2) {
player.sendMessage(ChatColor.RED + "/rg add <id>"); player.sendMessage(ChatColor.RED + "/region addowner <id>");
return; return;
} }
@ -451,7 +527,15 @@ && canUseRegionCommand(player, "/regiondefine")) {
return; return;
} }
addToDomain(plugin.regionManager.getRegion(id).getOwners(), args, 1); ProtectedRegion existing = plugin.regionManager.getRegion(id);
if (!canUseRegionCommand(player, "/regiondefine")
&& !existing.getOwners().contains(plugin.wrapPlayer(player))) {
player.sendMessage(ChatColor.RED + "You don't own this region.");
return;
}
addToDomain(existing.getOwners(), args, 2);
plugin.regionLoader.save(plugin.regionManager); plugin.regionLoader.save(plugin.regionManager);
player.sendMessage(ChatColor.YELLOW + "Region updated!"); player.sendMessage(ChatColor.YELLOW + "Region updated!");
@ -459,10 +543,15 @@ && canUseRegionCommand(player, "/regiondefine")) {
player.sendMessage(ChatColor.RED + "Region database failed to save: " player.sendMessage(ChatColor.RED + "Region database failed to save: "
+ e.getMessage()); + e.getMessage());
} }
} else if (action.equalsIgnoreCase("remove") } else if (action.equalsIgnoreCase("removeowner")) {
&& canUseRegionCommand(player, "/regiondefine")) { if (!canUseRegionCommand(player, "/regiondefine")
&& !canUseRegionCommand(player, "/regionclaim")) {
player.sendMessage(ChatColor.RED + "You don't have the /regiondefine permission.");
return;
}
if (args.length < 2) { if (args.length < 2) {
player.sendMessage(ChatColor.RED + "/rg remove <id>"); player.sendMessage(ChatColor.RED + "/region removeowner <id>");
return; return;
} }
@ -474,7 +563,15 @@ && canUseRegionCommand(player, "/regiondefine")) {
return; return;
} }
removeFromDomain(plugin.regionManager.getRegion(id).getOwners(), args, 1); ProtectedRegion existing = plugin.regionManager.getRegion(id);
if (!canUseRegionCommand(player, "/regiondefine")
&& !existing.getOwners().contains(plugin.wrapPlayer(player))) {
player.sendMessage(ChatColor.RED + "You don't own this region.");
return;
}
removeFromDomain(existing.getOwners(), args, 2);
plugin.regionLoader.save(plugin.regionManager); plugin.regionLoader.save(plugin.regionManager);
player.sendMessage(ChatColor.YELLOW + "Region updated!"); player.sendMessage(ChatColor.YELLOW + "Region updated!");
@ -482,8 +579,12 @@ && canUseRegionCommand(player, "/regiondefine")) {
player.sendMessage(ChatColor.RED + "Region database failed to save: " player.sendMessage(ChatColor.RED + "Region database failed to save: "
+ e.getMessage()); + e.getMessage());
} }
} else if (action.equalsIgnoreCase("list") } else if (action.equalsIgnoreCase("list")) {
&& canUseRegionCommand(player, "/regionlist")) { if (!canUseRegionCommand(player, "/regiondefine")) {
player.sendMessage(ChatColor.RED + "You don't have the /regiondefine permission.");
return;
}
int page = 0; int page = 0;
if (args.length >= 2) { if (args.length >= 2) {
@ -516,10 +617,15 @@ && canUseRegionCommand(player, "/regionlist")) {
player.sendMessage(ChatColor.YELLOW.toString() + (i + 1) + ". " + regionIDList[i]); player.sendMessage(ChatColor.YELLOW.toString() + (i + 1) + ". " + regionIDList[i]);
} }
} }
} else if (action.equalsIgnoreCase("delete") } else if (action.equalsIgnoreCase("delete")) {
&& canUseRegionCommand(player, "/regiondelete")) { if (!canUseRegionCommand(player, "/regiondelete")
&& !canUseRegionCommand(player, "/regionclaim")) {
player.sendMessage(ChatColor.RED + "You don't have the /regiondelete permission.");
return;
}
if (args.length < 2) { if (args.length < 2) {
player.sendMessage(ChatColor.RED + "/rg delete <id>"); player.sendMessage(ChatColor.RED + "/region delete <id>");
return; return;
} }
@ -530,6 +636,15 @@ && canUseRegionCommand(player, "/regiondelete")) {
+ id + "' doesn't exist."); + id + "' doesn't exist.");
return; return;
} }
ProtectedRegion existing = plugin.regionManager.getRegion(id);
if (!canUseRegionCommand(player, "/regiondelete")
&& !existing.getOwners().contains(plugin.wrapPlayer(player))) {
player.sendMessage(ChatColor.RED + "You don't own this region.");
return;
}
plugin.regionManager.removeRegion(id); plugin.regionManager.removeRegion(id);
plugin.regionLoader.save(plugin.regionManager); plugin.regionLoader.save(plugin.regionManager);
player.sendMessage(ChatColor.YELLOW + "Region removed!"); player.sendMessage(ChatColor.YELLOW + "Region removed!");
@ -537,8 +652,12 @@ && canUseRegionCommand(player, "/regiondelete")) {
player.sendMessage(ChatColor.RED + "Region database failed to save: " player.sendMessage(ChatColor.RED + "Region database failed to save: "
+ e.getMessage()); + e.getMessage());
} }
} else if (action.equalsIgnoreCase("save") } else if (action.equalsIgnoreCase("save")) {
&& canUseRegionCommand(player, "/regionsave")) { if (!canUseRegionCommand(player, "/regionsave")) {
player.sendMessage(ChatColor.RED + "You don't have the /regionsave permission.");
return;
}
try { try {
plugin.regionLoader.save(plugin.regionManager); plugin.regionLoader.save(plugin.regionManager);
player.sendMessage(ChatColor.YELLOW + "Region database saved to file!"); player.sendMessage(ChatColor.YELLOW + "Region database saved to file!");
@ -546,8 +665,12 @@ && canUseRegionCommand(player, "/regionsave")) {
player.sendMessage(ChatColor.RED + "Region database failed to save: " player.sendMessage(ChatColor.RED + "Region database failed to save: "
+ e.getMessage()); + e.getMessage());
} }
} else if (action.equalsIgnoreCase("load") } else if (action.equalsIgnoreCase("load")) {
&& canUseRegionCommand(player, "/regionload")) { if (!canUseRegionCommand(player, "/regiondelete")) {
player.sendMessage(ChatColor.RED + "You don't have the /regiondelete permission.");
return;
}
try { try {
plugin.regionLoader.load(plugin.regionManager); plugin.regionLoader.load(plugin.regionManager);
player.sendMessage(ChatColor.YELLOW + "Region database loaded from file!"); player.sendMessage(ChatColor.YELLOW + "Region database loaded from file!");
@ -556,7 +679,7 @@ && canUseRegionCommand(player, "/regionload")) {
+ e.getMessage()); + e.getMessage());
} }
} else { } else {
player.sendMessage(ChatColor.RED + "/rg <define|flag|delete|info|add|remove|list|save|load> ..."); player.sendMessage(ChatColor.RED + "/region <define|claim|flag|delete|info|addowner|removeowner|list|save|load> ...");
} }
} }

View File

@ -285,7 +285,7 @@ boolean inGroup(Player player, String group) {
} }
boolean hasPermission(Player player, String perm) { boolean hasPermission(Player player, String perm) {
return !perm.equals("/regionbypass"); return perm.equals("/regionclaim");
} }
List<String> getGroups(Player player) { List<String> getGroups(Player player) {

View File

@ -24,6 +24,7 @@
import java.util.Map; import java.util.Map;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import com.sk89q.worldedit.Vector; import com.sk89q.worldedit.Vector;
import com.sk89q.worldguard.LocalPlayer;
/** /**
* A very simple implementation of the region manager that uses a flat list * A very simple implementation of the region manager that uses a flat list
@ -129,6 +130,32 @@ public List<String> getApplicableRegionsIDs(Vector pt) {
return applicable; return applicable;
} }
/**
* Returns true if the provided region overlaps with any other region that
* is not owned by the player.
*
* @param region
* @param player
* @return
*/
public boolean overlapsUnownedRegion(ProtectedRegion region, LocalPlayer player) {
for (ProtectedRegion other : regions.values()) {
if (other.getOwners().contains(player)) {
continue;
}
try {
if (ProtectedRegion.intersects(region, other)) {
return true;
}
} catch (UnsupportedIntersectionException e) {
// TODO: Maybe do something here
}
}
return false;
}
/** /**
* Get the number of regions. * Get the number of regions.
* *

View File

@ -19,6 +19,7 @@
package com.sk89q.worldguard.protection; package com.sk89q.worldguard.protection;
import com.sk89q.worldedit.BlockVector;
import com.sk89q.worldedit.Vector; import com.sk89q.worldedit.Vector;
import com.sk89q.worldguard.domains.DefaultDomain; import com.sk89q.worldguard.domains.DefaultDomain;
@ -125,4 +126,34 @@ public AreaFlags getFlags() {
* @return * @return
*/ */
public abstract boolean contains(Vector pt); public abstract boolean contains(Vector pt);
/**
* Checks if two region intersects.
*
* @param region1
* @param region2
* @throws UnsupportedIntersectionException
* @return
*/
public static boolean intersects(ProtectedRegion region1, ProtectedRegion region2)
throws UnsupportedIntersectionException {
if (region1 instanceof ProtectedCuboidRegion
&& region2 instanceof ProtectedCuboidRegion) {
ProtectedCuboidRegion r1 = (ProtectedCuboidRegion)region1;
ProtectedCuboidRegion r2 = (ProtectedCuboidRegion)region2;
BlockVector min1 = r1.getMinimumPoint();
BlockVector max1 = r1.getMinimumPoint();
BlockVector min2 = r2.getMinimumPoint();
BlockVector max2 = r2.getMinimumPoint();
return !(min1.getBlockX() > max2.getBlockX()
|| min1.getBlockY() > max2.getBlockY()
|| min1.getBlockZ() > max2.getBlockZ()
|| max1.getBlockX() < min2.getBlockX()
|| max1.getBlockY() < min2.getBlockY()
|| max1.getBlockZ() < min2.getBlockZ());
} else {
throw new UnsupportedIntersectionException();
}
}
} }

View File

@ -22,6 +22,7 @@
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import com.sk89q.worldedit.Vector; import com.sk89q.worldedit.Vector;
import com.sk89q.worldguard.LocalPlayer;
/** /**
* An interface for getting, setting, and looking up regions. The most * An interface for getting, setting, and looking up regions. The most
@ -92,6 +93,16 @@ public interface RegionManager {
*/ */
public List<String> getApplicableRegionsIDs(Vector pt); public List<String> getApplicableRegionsIDs(Vector pt);
/**
* Returns true if the provided region overlaps with any other region that
* is not owned by the player.
*
* @param region
* @param player
* @return
*/
public boolean overlapsUnownedRegion(ProtectedRegion region, LocalPlayer player);
/** /**
* Get the number of regions. * Get the number of regions.
* *

View File

@ -0,0 +1,24 @@
// $Id$
/*
* WorldGuard
* Copyright (C) 2010 sk89q <http://www.sk89q.com>
*
* 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 <http://www.gnu.org/licenses/>.
*/
package com.sk89q.worldguard.protection;
public class UnsupportedIntersectionException extends Exception {
private static final long serialVersionUID = 6423189392345575148L;
}