From e3dd03c36365919b73389223fc1d308e2f69675b Mon Sep 17 00:00:00 2001 From: Luke Darling Date: Tue, 29 Jul 2014 11:17:55 -0400 Subject: [PATCH] Update Main.php --- src/LDX/iProtector/Main.php | 180 ++++++++++++++++++++++++++++++++---- 1 file changed, 161 insertions(+), 19 deletions(-) diff --git a/src/LDX/iProtector/Main.php b/src/LDX/iProtector/Main.php index ff5ff39..c166ef5 100644 --- a/src/LDX/iProtector/Main.php +++ b/src/LDX/iProtector/Main.php @@ -10,10 +10,20 @@ use pocketmine\Server; use pocketmine\utils\TextFormat as Color; use pocketmine\event\entity\EntityDamageEvent; +use pocketmine\event\block\BlockPlaceEvent; +use pocketmine\event\block\BlockBreakEvent; class Main extends PluginBase implements Listener { public function onEnable() { $this->getServer()->getPluginManager()->registerEvents($this,$this); - + @mkdir($this->getDataFolder()); + if(!file_exists($this->getDataFolder() . "areas.dat")) { + file_put_contents($this->getDataFolder() . "areas.dat",yaml_emit(array())); + } + $this->areas = array(); + $this->areadata = yaml_parse(file_get_contents($this->getDataFolder() . "areas.dat")); + foreach($this->areadata as $data) { + $area = new Area($data,$this); + } } public function onCommand(CommandSender $p,Command $cmd,$label,array $args) { if(!($p instanceof Player)) { @@ -23,36 +33,115 @@ public function onCommand(CommandSender $p,Command $cmd,$label,array $args) { if(!isset($args[0])) { return false; } - $n = strtolower($p->getname()); + $n = strtolower($p->getName()); $action = strtolower($args[0]); switch($action) { case "pos1": - $this->pos1[$n] = new Vector3(round($p->getX()),round($p->getY()),round($p->getZ())); - $o = "Position 1 set to: (" . $this->pos1[$n]->getX() . "," . $this->pos1[$n]->getY() . "," . $this->pos1[$n]->getZ() . ")"; + if($p->hasPermission("iprotector") || $p->hasPermission("iprotector.command") || $p->hasPermission("iprotector.command.area") || $p->hasPermission("iprotector.command.area.pos1")) { + $this->pos1[$n] = new Vector3(round($p->getX()),round($p->getY()),round($p->getZ())); + $o = "Position 1 set to: (" . $this->pos1[$n]->getX() . "," . $this->pos1[$n]->getY() . "," . $this->pos1[$n]->getZ() . ")"; + } else { + $o = "You do not have permission to use this subcommand."; + } break; case "pos2": - $this->pos2[$n] = new Vector3($p->getX(),$p->getY(),$p->getZ()); - $o = "Position 2 set to: (" . $this->pos2[$n]->getX() . "," . $this->pos2[$n]->getY() . "," . $this->pos2[$n]->getZ() . ")"; + if($p->hasPermission("iprotector") || $p->hasPermission("iprotector.command") || $p->hasPermission("iprotector.command.area") || $p->hasPermission("iprotector.command.area.pos2")) { + $this->pos2[$n] = new Vector3(round($p->getX()),round($p->getY()),round($p->getZ())); + $o = "Position 2 set to: (" . $this->pos2[$n]->getX() . "," . $this->pos2[$n]->getY() . "," . $this->pos2[$n]->getZ() . ")"; + } else { + $o = "You do not have permission to use this subcommand."; + } break; case "create": - if(isset($args[1])) { - if(isset($this->pos1[$n]) && isset($this->pos2[$n])) { - if(!isset($this->areas[strtolower($args[1])])) { - $area = new Area(array("name" => strtolower($args[1]),"flags" => array("edit" => true,"god" => false,"chest" => false),"pos" => array($this->pos1[$n],$this->pos2[$n]),$this)); - $area->save(); - $o = "Area created!"; + if($p->hasPermission("iprotector") || $p->hasPermission("iprotector.command") || $p->hasPermission("iprotector.command.area") || $p->hasPermission("iprotector.command.area.create")) { + if(isset($args[1])) { + if(isset($this->pos1[$n]) && isset($this->pos2[$n])) { + if(!isset($this->areas[strtolower($args[1])])) { + $area = new Area(array("name" => strtolower($args[1]),"flags" => array("edit" => true,"god" => false,"chest" => false),"pos1" => array($this->pos1[$n]->getX(),$this->pos1[$n]->getY(),$this->pos1[$n]->getZ()),"pos2" => array($this->pos2[$n]->getX(),$this->pos2[$n]->getY(),$this->pos2[$n]->getZ())),$this); + unset($this->pos1[$n]); + unset($this->pos2[$n]); + $o = "Area created!"; + } else { + $o = "An area with that name already exists."; + } } else { - $o = "An area with that name already exists."; + $o = "Please select both positions first."; } } else { - $o = "Please select both positions first."; + $o = "Please specify a name for this area."; } } else { - $o = "Please specify a name for this area."; + $o = "You do not have permission to use this subcommand."; + } + break; + case "list": + if($p->hasPermission("iprotector") || $p->hasPermission("iprotector.command") || $p->hasPermission("iprotector.command.area") || $p->hasPermission("iprotector.command.area.list")) { + $o = "Areas:"; + foreach($this->areas as $area) { + $o = $o . " " . $area->getName() . ";"; + } } break; case "flag": - + if($p->hasPermission("iprotector") || $p->hasPermission("iprotector.command") || $p->hasPermission("iprotector.command.area") || $p->hasPermission("iprotector.command.area.flag")) { + if(isset($args[1])) { + if(isset($this->areas[strtolower($args[1])])) { + $area = $this->areas[strtolower($args[1])]; + if(isset($args[2])) { + if(isset($area->flags[strtolower($args[2])])) { + $flag = strtolower($args[2]); + if(isset($args[3]) && strtolower($args[3]) == ("on" || "off" || "true" || "false")) { + $mode = strtolower($args[3]); + if($mode == ("true" || "on")) { + $mode = true; + } else { + $mode = false; + } + $area->setFlag($flag,$mode); + } else { + $area->toggleFlag($flag); + } + if($area->getFlag($flag)) { + $status = "on"; + } else { + $status = "off"; + } + $o = "Flag " . $flag . " set to " . $status . " for area " . $area->getName() . "!"; + } else { + $o = "Flag not found. (Flags: edit, god)"; + } + } else { + $o = "Please specify a flag. (Flags: edit, god)"; + } + } else { + $o = "Area doesn't exist."; + } + } else { + $o = "Please specify the area you would like to flag."; + } + } else { + $o = "You do not have permission to use this subcommand."; + } + break; + case "delete": + if($p->hasPermission("iprotector") || $p->hasPermission("iprotector.command") || $p->hasPermission("iprotector.command.area") || $p->hasPermission("iprotector.command.area.delete")) { + if(isset($args[1])) { + if(isset($this->areas[strtolower($args[1])])) { + $area = $this->areas[strtolower($args[1])]; + $area->delete(); + $o = "Area deleted!"; + } else { + $o = "Area does not exist."; + } + } else { + $o = "Please specify an area to delete."; + } + } else { + $o = "You do not have permission to use this subcommand."; + } + break; + default: + return false; break; } $p->sendMessage($o); @@ -65,12 +154,65 @@ public function onCommand(CommandSender $p,Command $cmd,$label,array $args) { * @ignoreCancelled true */ public function onHurt(EntityDamageEvent $event) { - + if($event->getEntity() instanceof Player) { + $p = $event->getEntity(); + $cancel = false; + $pos = new Vector3($p->getX(),$p->getY(),$p->getZ()); + foreach($this->areas as $area) { + if($area->contains($pos) && $area->getFlag("god")) { + $cancel = true; + } + } + if($cancel) { + $event->setCancelled(); + } + } } - public function onDisable() { + /** + * @param BlockBreakEvent $event + * + * @priority HIGHEST + * @ignoreCancelled true + */ + public function onBlockBreak(BlockBreakEvent $event) { + $b = $event->getBlock(); + $p = $event->getPlayer(); + $cancel = false; + $pos = new Vector3($b->x,$b->y,$b->z); + foreach($this->areas as $area) { + if($area->contains($pos) && $area->getFlag("edit") && !($p->hasPermission("iprotector") || $p->hasPermission("iprotector.access"))) { + $cancel = true; + } + } + if($cancel) { + $event->setCancelled(); + } + } + /** + * @param BlockPlaceEvent $event + * + * @priority HIGHEST + * @ignoreCancelled true + */ + public function onBlockPlace(BlockPlaceEvent $event) { + $b = $event->getBlock(); + $p = $event->getPlayer(); + $cancel = false; + $pos = new Vector3($b->x,$b->y,$b->z); foreach($this->areas as $area) { - $area->save(); + if($area->contains($pos) && $area->getFlag("edit") && !($p->hasPermission("iprotector") || $p->hasPermission("iprotector.access"))) { + $cancel = true; + } + } + if($cancel) { + $event->setCancelled(); } } + public function saveAreas() { + file_put_contents($this->getDataFolder() . "areas.dat",yaml_emit($this->areadata)); + } + public function onDisable() { + $this->saveAreas(); + } } ?>