mirror of
https://github.com/EngineHub/WorldGuard.git
synced 2024-12-20 16:19:37 +01:00
Added more region commands.
This commit is contained in:
parent
2b72a99608
commit
9272741a3c
@ -26,7 +26,7 @@
|
|||||||
public class ProtectionCommands {
|
public class ProtectionCommands {
|
||||||
@Command(aliases = {"region"},
|
@Command(aliases = {"region"},
|
||||||
desc = "Region management commands")
|
desc = "Region management commands")
|
||||||
@NestedCommand({RegionCommands.class})
|
@NestedCommand({RegionCommands.class, RegionMemberCommands.class})
|
||||||
public static void region(CommandContext args, WorldGuardPlugin plugin,
|
public static void region(CommandContext args, WorldGuardPlugin plugin,
|
||||||
CommandSender sender) throws CommandException {
|
CommandSender sender) throws CommandException {
|
||||||
}
|
}
|
||||||
|
@ -432,6 +432,48 @@ public static <V> void setFlag(ProtectedRegion region,
|
|||||||
region.setFlag(flag, flag.parseInput(plugin, sender, value));
|
region.setFlag(flag, flag.parseInput(plugin, sender, value));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Command(aliases = {"setpriority"},
|
||||||
|
usage = "<id> <priority>",
|
||||||
|
desc = "Set the priority of a region",
|
||||||
|
flags = "", min = 2, max = 2)
|
||||||
|
public static void setPriority(CommandContext args, WorldGuardPlugin plugin,
|
||||||
|
CommandSender sender) throws CommandException {
|
||||||
|
Player player = plugin.checkPlayer(sender);
|
||||||
|
World world = player.getWorld();
|
||||||
|
LocalPlayer localPlayer = plugin.wrapPlayer(player);
|
||||||
|
|
||||||
|
String id = args.getString(0);
|
||||||
|
int priority = args.getInteger(1);
|
||||||
|
|
||||||
|
RegionManager mgr = plugin.getGlobalRegionManager().get(world);
|
||||||
|
ProtectedRegion region = mgr.getRegion(id);
|
||||||
|
|
||||||
|
if (region == null) {
|
||||||
|
throw new CommandException("Could not find a region by that ID.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (region.isOwner(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.setpriority.own");
|
||||||
|
} else if (region.isMember(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.setpriority.member");
|
||||||
|
} else {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.setpriority");
|
||||||
|
}
|
||||||
|
|
||||||
|
region.setPriority(priority);
|
||||||
|
|
||||||
|
sender.sendMessage(ChatColor.YELLOW
|
||||||
|
+ "Priority of '" + region.getId() + "' set to "
|
||||||
|
+ priority + ".");
|
||||||
|
|
||||||
|
try {
|
||||||
|
mgr.save();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CommandException("Failed to write regions file: "
|
||||||
|
+ e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Command(aliases = {"setparent"},
|
@Command(aliases = {"setparent"},
|
||||||
usage = "<id> <parent-id>",
|
usage = "<id> <parent-id>",
|
||||||
desc = "Set the parent of a region",
|
desc = "Set the parent of a region",
|
||||||
@ -521,6 +563,9 @@ public static void remove(CommandContext args, WorldGuardPlugin plugin,
|
|||||||
|
|
||||||
mgr.removeRegion(id);
|
mgr.removeRegion(id);
|
||||||
|
|
||||||
|
sender.sendMessage(ChatColor.YELLOW
|
||||||
|
+ "Region '" + id + "' removed.");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
mgr.save();
|
mgr.save();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
|
@ -0,0 +1,203 @@
|
|||||||
|
// $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.bukkit.commands;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.World;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import com.sk89q.minecraft.util.commands.Command;
|
||||||
|
import com.sk89q.minecraft.util.commands.CommandContext;
|
||||||
|
import com.sk89q.minecraft.util.commands.CommandException;
|
||||||
|
import com.sk89q.worldguard.LocalPlayer;
|
||||||
|
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
|
||||||
|
import com.sk89q.worldguard.protection.managers.RegionManager;
|
||||||
|
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
||||||
|
import com.sk89q.worldguard.util.RegionUtil;
|
||||||
|
|
||||||
|
// @TODO: A lot of code duplication here! Need to fix.
|
||||||
|
|
||||||
|
public class RegionMemberCommands {
|
||||||
|
|
||||||
|
@Command(aliases = {"addmember", "addmember"},
|
||||||
|
usage = "<id> <members...>",
|
||||||
|
desc = "Add a member to a region",
|
||||||
|
flags = "", min = 2, max = -1)
|
||||||
|
public static void addMember(CommandContext args, WorldGuardPlugin plugin,
|
||||||
|
CommandSender sender) throws CommandException {
|
||||||
|
|
||||||
|
Player player = plugin.checkPlayer(sender);
|
||||||
|
World world = player.getWorld();
|
||||||
|
LocalPlayer localPlayer = plugin.wrapPlayer(player);
|
||||||
|
|
||||||
|
String id = args.getString(0);
|
||||||
|
|
||||||
|
RegionManager mgr = plugin.getGlobalRegionManager().get(world);
|
||||||
|
ProtectedRegion region = mgr.getRegion(id);
|
||||||
|
|
||||||
|
if (region == null) {
|
||||||
|
throw new CommandException("Could not find a region by that ID.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (region.isOwner(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.addmember.own");
|
||||||
|
} else if (region.isMember(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.addmember.member");
|
||||||
|
} else {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.addmember");
|
||||||
|
}
|
||||||
|
|
||||||
|
RegionUtil.addToDomain(region.getMembers(), args.getPaddedSlice(2, 0), 0);
|
||||||
|
|
||||||
|
sender.sendMessage(ChatColor.YELLOW
|
||||||
|
+ "Region '" + id + "' updated.");
|
||||||
|
|
||||||
|
try {
|
||||||
|
mgr.save();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CommandException("Failed to write regions file: "
|
||||||
|
+ e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Command(aliases = {"addowner", "addowner"},
|
||||||
|
usage = "<id> <owners...>",
|
||||||
|
desc = "Add an owner to a region",
|
||||||
|
flags = "", min = 2, max = -1)
|
||||||
|
public static void addOwner(CommandContext args, WorldGuardPlugin plugin,
|
||||||
|
CommandSender sender) throws CommandException {
|
||||||
|
|
||||||
|
Player player = plugin.checkPlayer(sender);
|
||||||
|
World world = player.getWorld();
|
||||||
|
LocalPlayer localPlayer = plugin.wrapPlayer(player);
|
||||||
|
|
||||||
|
String id = args.getString(0);
|
||||||
|
|
||||||
|
RegionManager mgr = plugin.getGlobalRegionManager().get(world);
|
||||||
|
ProtectedRegion region = mgr.getRegion(id);
|
||||||
|
|
||||||
|
if (region == null) {
|
||||||
|
throw new CommandException("Could not find a region by that ID.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (region.isOwner(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.addowner.own");
|
||||||
|
} else if (region.isMember(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.addowner.member");
|
||||||
|
} else {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.addowner");
|
||||||
|
}
|
||||||
|
|
||||||
|
RegionUtil.addToDomain(region.getOwners(), args.getPaddedSlice(2, 0), 0);
|
||||||
|
|
||||||
|
sender.sendMessage(ChatColor.YELLOW
|
||||||
|
+ "Region '" + id + "' updated.");
|
||||||
|
|
||||||
|
try {
|
||||||
|
mgr.save();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CommandException("Failed to write regions file: "
|
||||||
|
+ e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Command(aliases = {"removemember", "remmember", "removemem", "remmem"},
|
||||||
|
usage = "<id> <owners...>",
|
||||||
|
desc = "Remove an owner to a region",
|
||||||
|
flags = "", min = 2, max = -1)
|
||||||
|
public static void removeMember(CommandContext args, WorldGuardPlugin plugin,
|
||||||
|
CommandSender sender) throws CommandException {
|
||||||
|
|
||||||
|
Player player = plugin.checkPlayer(sender);
|
||||||
|
World world = player.getWorld();
|
||||||
|
LocalPlayer localPlayer = plugin.wrapPlayer(player);
|
||||||
|
|
||||||
|
String id = args.getString(0);
|
||||||
|
|
||||||
|
RegionManager mgr = plugin.getGlobalRegionManager().get(world);
|
||||||
|
ProtectedRegion region = mgr.getRegion(id);
|
||||||
|
|
||||||
|
if (region == null) {
|
||||||
|
throw new CommandException("Could not find a region by that ID.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (region.isOwner(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.removemember.own");
|
||||||
|
} else if (region.isMember(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.removemember.member");
|
||||||
|
} else {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.removemember");
|
||||||
|
}
|
||||||
|
|
||||||
|
RegionUtil.removeFromDomain(region.getMembers(), args.getPaddedSlice(2, 0), 0);
|
||||||
|
|
||||||
|
sender.sendMessage(ChatColor.YELLOW
|
||||||
|
+ "Region '" + id + "' updated.");
|
||||||
|
|
||||||
|
try {
|
||||||
|
mgr.save();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CommandException("Failed to write regions file: "
|
||||||
|
+ e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Command(aliases = {"removeowner", "remowner"},
|
||||||
|
usage = "<id> <owners...>",
|
||||||
|
desc = "Remove an owner to a region",
|
||||||
|
flags = "", min = 2, max = -1)
|
||||||
|
public static void removeOwner(CommandContext args, WorldGuardPlugin plugin,
|
||||||
|
CommandSender sender) throws CommandException {
|
||||||
|
|
||||||
|
Player player = plugin.checkPlayer(sender);
|
||||||
|
World world = player.getWorld();
|
||||||
|
LocalPlayer localPlayer = plugin.wrapPlayer(player);
|
||||||
|
|
||||||
|
String id = args.getString(0);
|
||||||
|
|
||||||
|
RegionManager mgr = plugin.getGlobalRegionManager().get(world);
|
||||||
|
ProtectedRegion region = mgr.getRegion(id);
|
||||||
|
|
||||||
|
if (region == null) {
|
||||||
|
throw new CommandException("Could not find a region by that ID.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (region.isOwner(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.removeowner.own");
|
||||||
|
} else if (region.isMember(localPlayer)) {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.removeowner.member");
|
||||||
|
} else {
|
||||||
|
plugin.checkPermission(sender, "worldguard.region.removeowner");
|
||||||
|
}
|
||||||
|
|
||||||
|
RegionUtil.removeFromDomain(region.getOwners(), args.getPaddedSlice(2, 0), 0);
|
||||||
|
|
||||||
|
sender.sendMessage(ChatColor.YELLOW
|
||||||
|
+ "Region '" + id + "' updated.");
|
||||||
|
|
||||||
|
try {
|
||||||
|
mgr.save();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CommandException("Failed to write regions file: "
|
||||||
|
+ e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user