on the way to 1.0.0
https://github.com/craftinc/craftinc-borderprotection/issues/6 fixed (change storage mechanism) bugfix: now player is always teleported to a place where he can stand
This commit is contained in:
		
							
								
								
									
										2
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								pom.xml
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | |||||||
|     <groupId>de.craftinc</groupId> |     <groupId>de.craftinc</groupId> | ||||||
|     <artifactId>CraftincBorderProtection</artifactId> |     <artifactId>CraftincBorderProtection</artifactId> | ||||||
|     <packaging>jar</packaging> |     <packaging>jar</packaging> | ||||||
|     <version>0.9.9</version> |     <version>1.0.0</version> | ||||||
|  |  | ||||||
|     <properties> |     <properties> | ||||||
|         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> |         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> | ||||||
|   | |||||||
							
								
								
									
										104
									
								
								src/main/java/de/craftinc/borderprotection/Border.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								src/main/java/de/craftinc/borderprotection/Border.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | |||||||
|  | package de.craftinc.borderprotection; | ||||||
|  |  | ||||||
|  | import org.bukkit.Location; | ||||||
|  | import org.bukkit.World; | ||||||
|  | import org.bukkit.configuration.file.FileConfiguration; | ||||||
|  | import org.bukkit.configuration.file.YamlConfiguration; | ||||||
|  |  | ||||||
|  | import java.io.File; | ||||||
|  | import java.util.HashMap; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | public class Border | ||||||
|  | { | ||||||
|  |     private static final String dataFileName = "borders.json"; | ||||||
|  |  | ||||||
|  |     private Location rectPoint1; | ||||||
|  |     private Location rectPoint2; | ||||||
|  |  | ||||||
|  |     private static String rectPoint1Name = "p1"; | ||||||
|  |     private static String rectPoint2Name = "p2"; | ||||||
|  |     private static String rectBordersKey = "rectBorders"; | ||||||
|  |  | ||||||
|  |     private static final HashMap<World, Border> borders = new HashMap<World, Border>(); | ||||||
|  |  | ||||||
|  |     private static File              bordersFile     = new File(Plugin.getPlugin().getDataFolder(), dataFileName); | ||||||
|  |     private static FileConfiguration bordersFileConf = YamlConfiguration.loadConfiguration(bordersFile); | ||||||
|  |  | ||||||
|  |     public static HashMap<World, Border> getBorders() | ||||||
|  |     { | ||||||
|  |         return borders; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Location getRectPoint1() | ||||||
|  |     { | ||||||
|  |         return rectPoint1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Location getRectPoint2() | ||||||
|  |     { | ||||||
|  |         return rectPoint2; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @SuppressWarnings("unchecked") | ||||||
|  |     public Border( Map<String, Object> map ) | ||||||
|  |     { | ||||||
|  |         try | ||||||
|  |         { | ||||||
|  |             rectPoint1 = LocationSerializer.deserializeLocation((Map<String, Object>) map.get(rectPoint1Name)); | ||||||
|  |             rectPoint2 = LocationSerializer.deserializeLocation((Map<String, Object>) map.get(rectPoint2Name)); | ||||||
|  |  | ||||||
|  |             if ( rectPoint1.getWorld().equals(rectPoint2.getWorld()) ) | ||||||
|  |             { | ||||||
|  |                 borders.put(rectPoint1.getWorld(), this); | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 throw new Exception("Border points are at different worlds."); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         catch ( Exception e ) | ||||||
|  |         { | ||||||
|  |             Plugin.getPlugin().getLogger().severe(e.getMessage()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Border( Location p1, Location p2 ) throws Exception | ||||||
|  |     { | ||||||
|  |         rectPoint1 = p1; | ||||||
|  |         rectPoint2 = p2; | ||||||
|  |         if ( rectPoint1.getWorld().equals(rectPoint2.getWorld()) ) | ||||||
|  |         { | ||||||
|  |             borders.put(rectPoint1.getWorld(), this); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             throw new Exception("Border points are at different worlds."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     public Map<String, Object> serialize() | ||||||
|  |     { | ||||||
|  |         HashMap<String, Object> map = new HashMap<String, Object>(); | ||||||
|  |         map.put(rectPoint1Name, LocationSerializer.serializeLocation(rectPoint1)); | ||||||
|  |         map.put(rectPoint2Name, LocationSerializer.serializeLocation(rectPoint2)); | ||||||
|  |  | ||||||
|  |         return map; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static void loadBorders() | ||||||
|  |     { | ||||||
|  |         bordersFileConf.getList(rectBordersKey); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static void saveBorders() | ||||||
|  |     { | ||||||
|  |         bordersFileConf.set(rectBordersKey, borders.values()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String toString() | ||||||
|  |     { | ||||||
|  |         return rectPoint1.getX() + "," + rectPoint1.getZ() + " " + rectPoint2.getX() + "," + rectPoint2.getZ(); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -20,9 +20,6 @@ import org.bukkit.Location; | |||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
|  |  | ||||||
| import java.io.File; |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.Calendar; | import java.util.Calendar; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
|  |  | ||||||
| @@ -34,13 +31,6 @@ public class BorderManager | |||||||
|      * ********************************************************** |      * ********************************************************** | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     private final String dataFileName = "data.json"; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Borders of all Worlds. String is World.getName(). Location is one point of the border. A border |  | ||||||
|      * consists of two points which create a rectangle. |  | ||||||
|      */ |  | ||||||
|     private HashMap<String, ArrayList<Location>> borders = null; |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * For every player save the time when he got the last borderMessage |      * For every player save the time when he got the last borderMessage | ||||||
| @@ -51,18 +41,14 @@ public class BorderManager | |||||||
|      * The buffer in blocks which applies when a player is teleported inside the border. 0 means the player |      * The buffer in blocks which applies when a player is teleported inside the border. 0 means the player | ||||||
|      * will be teleported directly to the border. |      * will be teleported directly to the border. | ||||||
|      */ |      */ | ||||||
|     private double buffer = 0.5; |     public static final double buffer = 0.5; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * A timeout for the border message. When a player tries to cross the border and sees the border message, |      * A timeout for the border message. When a player tries to cross the border and sees the border message, | ||||||
|      * the earliest possible time the message will show up again is after <code>timeout</code> milliseconds. |      * the earliest possible time the message will show up again is after <code>timeout</code> milliseconds. | ||||||
|      */ |      */ | ||||||
|     private Long timeout = 10000L; |     public static final Long timeout = 10000L; | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Serializer, which is used for loading and saving data to harddisk |  | ||||||
|      */ |  | ||||||
|     private Serializer serializer; |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * ********************************************************* |      * ********************************************************* | ||||||
| @@ -71,9 +57,8 @@ public class BorderManager | |||||||
|      */ |      */ | ||||||
|     public BorderManager() |     public BorderManager() | ||||||
|     { |     { | ||||||
|         // initialize Serializer and load data file |         // load borders | ||||||
|         serializer = new Serializer(new File(Plugin.getPlugin().getDataFolder(), dataFileName)); |         Border.loadBorders(); | ||||||
|         borders = serializer.loadDataFile(); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -83,59 +68,21 @@ public class BorderManager | |||||||
|      * ********************************************************** |      * ********************************************************** | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     public Serializer getSerializer() |     public void setBorder( World world, double border ) throws Exception | ||||||
|     { |     { | ||||||
|         return serializer; |         new Border(new Location(world, border, 0, border), new Location(world, -border, 0, -border)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public double getBuffer() |     public void setBorder( World world, String p1, String p2 ) throws Exception | ||||||
|     { |     { | ||||||
|         return buffer; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public Long getTimeout() |         String[] coordinatesP1 = p1.split(","); | ||||||
|     { |         Location l1 = new Location(world, Double.parseDouble(coordinatesP1[0]), 0, Double.parseDouble(coordinatesP1[1])); | ||||||
|         return timeout; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public HashMap<String, ArrayList<Location>> getBorders() |         String[] coordinatesP2 = p2.split(","); | ||||||
|     { |         Location l2 = new Location(world, Double.parseDouble(coordinatesP2[0]), 0, Double.parseDouble(coordinatesP2[1])); | ||||||
|         return borders; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void setBorder( String worldName, double border ) |         new Border(l1, l2); | ||||||
|     { |  | ||||||
|         if ( borders == null ) |  | ||||||
|         { |  | ||||||
|             borders = new HashMap<String, ArrayList<Location>>(); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         World world = Plugin.getPlugin().getServer().getWorld(worldName); |  | ||||||
|  |  | ||||||
|         // set two points which define a square |  | ||||||
|         borders.put(worldName, new ArrayList<Location>(Arrays.asList( |  | ||||||
|                 new Location(world, border, 0, border), |  | ||||||
|                 new Location(world, -border, 0, -border) |  | ||||||
|                                                                     ))); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void setBorder( String worldName, String[] borderPoints ) |  | ||||||
|     { |  | ||||||
|         if ( borders == null ) |  | ||||||
|         { |  | ||||||
|             borders = new HashMap<String, ArrayList<Location>>(); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ArrayList<Location> locations = new ArrayList<Location>(); |  | ||||||
|         World world = Plugin.getPlugin().getServer().getWorld(worldName); |  | ||||||
|  |  | ||||||
|         for ( String borderPoint : borderPoints ) |  | ||||||
|         { |  | ||||||
|             String[] point = borderPoint.split(","); |  | ||||||
|             locations.add(new Location(world, Double.parseDouble(point[0]), 0, Double.parseDouble(point[1]))); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         borders.put(worldName, locations); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -143,20 +90,20 @@ public class BorderManager | |||||||
|      * Checks if the given location is inside the border rectangle. Returns null if yes, otherwise new coordinates. |      * Checks if the given location is inside the border rectangle. Returns null if yes, otherwise new coordinates. | ||||||
|      * |      * | ||||||
|      * @param location     location to check |      * @param location     location to check | ||||||
|      * @param borderPoints points which define the border rectangle |      * @param border       Border object which defines the border | ||||||
|      * @param buffer       if the player will be teleported back, then he will be <code>buffer</code> far away |      * @param buffer       if the player will be teleported back, then he will be <code>buffer</code> far away | ||||||
|      *                     from the border he tried to cross |      *                     from the border he tried to cross | ||||||
|      * @return null if the player is inside, otherwise a new player location |      * @return null if the player is inside, otherwise a new player location | ||||||
|      */ |      */ | ||||||
|     public Double[] checkBorder( Location location, ArrayList<Location> borderPoints, double buffer ) |     public Double[] checkBorder( Location location, Border border, double buffer ) | ||||||
|     { |     { | ||||||
|         // New x and z: null by default |         // New x and z: null by default | ||||||
|         Double[] newXZ = { null, null }; |         Double[] newXZ = { null, null }; | ||||||
|  |  | ||||||
|         // check if player is withing the X borders |         // check if player is withing the X borders | ||||||
|         newXZ[0] = _checkBorder(location.getX(), borderPoints.get(0).getX(), borderPoints.get(1).getX(), buffer); |         newXZ[0] = _checkBorder(location.getX(), border.getRectPoint1().getX(), border.getRectPoint2().getX(), buffer); | ||||||
|         // check if player is withing the Z borders |         // check if player is withing the Z borders | ||||||
|         newXZ[1] = _checkBorder(location.getZ(), borderPoints.get(0).getZ(), borderPoints.get(1).getZ(), buffer); |         newXZ[1] = _checkBorder(location.getZ(), border.getRectPoint1().getZ(), border.getRectPoint2().getZ(), buffer); | ||||||
|  |  | ||||||
|         // Do nothing, if no new coordinates have been calculated. |         // Do nothing, if no new coordinates have been calculated. | ||||||
|         if ( newXZ[0] == null && newXZ[1] == null ) |         if ( newXZ[0] == null && newXZ[1] == null ) | ||||||
| @@ -212,7 +159,7 @@ public class BorderManager | |||||||
|         Long now = Calendar.getInstance().getTimeInMillis(); |         Long now = Calendar.getInstance().getTimeInMillis(); | ||||||
|  |  | ||||||
|         if ( ( lastBorderMessage.get(player.getName()) != null && |         if ( ( lastBorderMessage.get(player.getName()) != null && | ||||||
|                now - getTimeout() > lastBorderMessage.get(player.getName()) ) || |                now - timeout > lastBorderMessage.get(player.getName()) ) || | ||||||
|              lastBorderMessage.get(player.getName()) == null ) |              lastBorderMessage.get(player.getName()) == null ) | ||||||
|         { |         { | ||||||
|             // show message |             // show message | ||||||
|   | |||||||
| @@ -16,14 +16,12 @@ | |||||||
| */ | */ | ||||||
| package de.craftinc.borderprotection; | package de.craftinc.borderprotection; | ||||||
|  |  | ||||||
| import org.bukkit.Location; | import org.bukkit.World; | ||||||
| import org.bukkit.command.Command; | import org.bukkit.command.Command; | ||||||
| import org.bukkit.command.CommandExecutor; | import org.bukkit.command.CommandExecutor; | ||||||
| import org.bukkit.command.CommandSender; | import org.bukkit.command.CommandSender; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
|  |  | ||||||
| import java.util.ArrayList; |  | ||||||
|  |  | ||||||
| public class Commands implements CommandExecutor | public class Commands implements CommandExecutor | ||||||
| { | { | ||||||
|     private BorderManager borderManager; |     private BorderManager borderManager; | ||||||
| @@ -56,45 +54,54 @@ public class Commands implements CommandExecutor | |||||||
|             // set |             // set | ||||||
|             if ( ( args.length == 2 || args.length == 3 ) && args[0].equalsIgnoreCase("set") ) |             if ( ( args.length == 2 || args.length == 3 ) && args[0].equalsIgnoreCase("set") ) | ||||||
|             { |             { | ||||||
|                 if ( !sender.hasPermission("craftinc.borderprotection.set") ) |                 if ( ! sender.hasPermission("craftinc.borderprotection.set") ) | ||||||
|                 { |                 { | ||||||
|                     sender.sendMessage(Messages.noPermissionSet); |                     sender.sendMessage(Messages.noPermissionSet); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if ( args.length == 2 ) |                 if ( args.length == 2 ) | ||||||
|                 { |                 { | ||||||
|                     borderManager.setBorder(( (Player) sender ).getWorld().getName(), Double.parseDouble(args[1])); |                     try | ||||||
|                 } |  | ||||||
|                 else if ( args.length == 3 ) |  | ||||||
|                     { |                     { | ||||||
|                     String[] borderDefinition = { args[1], args[2] }; |                         borderManager.setBorder(( (Player) sender ).getWorld(), Double.parseDouble(args[1])); | ||||||
|                     borderManager.setBorder(( (Player) sender ).getWorld().getName(), borderDefinition); |                     } | ||||||
|  |                     catch ( Exception e ) | ||||||
|  |                     { | ||||||
|  |                         sender.sendMessage(e.getMessage()); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     try | ||||||
|  |                     { | ||||||
|  |                         borderManager.setBorder(( (Player) sender ).getWorld(), args[1], args[2]); | ||||||
|  |                     } | ||||||
|  |                     catch ( Exception e ) | ||||||
|  |                     { | ||||||
|  |                         sender.sendMessage(e.getMessage()); | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 // save the new border |                 // save the new border | ||||||
|                 borderManager.getSerializer().saveDataFile(borderManager.getBorders()); |                 Border.saveBorders(); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             // get |             // get | ||||||
|             if ( args.length == 1 && ( args[0].equalsIgnoreCase("get") || args[0].equalsIgnoreCase("info") ) ) |             if ( args.length == 1 && ( args[0].equalsIgnoreCase("get") || args[0].equalsIgnoreCase("info") ) ) | ||||||
|             { |             { | ||||||
|                 String worldName = ( (Player) sender ).getWorld().getName(); |                 World world = ( (Player) sender ).getWorld(); | ||||||
|  |  | ||||||
|                 // exit and send the player a message if no border is set |                 // exit and send the player a message if no border is set | ||||||
|                 if ( borderManager.getBorders() == null || |                 if ( ! Border.getBorders().containsKey(world) ) | ||||||
|                      borderManager.getBorders().get(worldName) == null ) |  | ||||||
|                 { |                 { | ||||||
|                     sender.sendMessage(Messages.borderInfoNoBorderSet); |                     sender.sendMessage(Messages.borderInfoNoBorderSet); | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 ArrayList<Location> borderPoints = borderManager.getBorders() |                 Border border = Border.getBorders().get(world); | ||||||
|                                                                 .get(worldName); |  | ||||||
|                 String borderDef = borderPoints.get(0).getX() + "," + borderPoints.get(0).getZ() + " " + |  | ||||||
|                                    borderPoints.get(1).getX() + "," + borderPoints.get(1).getZ(); |  | ||||||
|  |  | ||||||
|                 sender.sendMessage(Messages.borderInfo(worldName, borderDef)); |                 sender.sendMessage(Messages.borderInfo(world.getName(), border.toString())); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -0,0 +1,84 @@ | |||||||
|  | package de.craftinc.borderprotection; | ||||||
|  |  | ||||||
|  | import org.bukkit.Location; | ||||||
|  | import org.bukkit.World; | ||||||
|  |  | ||||||
|  | import java.util.HashMap; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * NOTE: We do not care about yaw and pitch for gate locations. So we won't serialize them. | ||||||
|  |  */ | ||||||
|  | public class LocationSerializer  | ||||||
|  | { | ||||||
|  | 	protected static String worldKey = "world"; | ||||||
|  | 	protected static String xKey = "x"; | ||||||
|  | 	protected static String yKey = "y"; | ||||||
|  | 	protected static String zKey = "z"; | ||||||
|  |  | ||||||
|  | 	 | ||||||
|  | 	protected static World getWorld(String name) throws Exception  | ||||||
|  | 	{ | ||||||
|  | 		World world = Plugin.getPlugin().getServer().getWorld(name); | ||||||
|  |  | ||||||
|  | 		if (world == null) { | ||||||
|  | 			throw new Exception("World '" + name + "' does not exists anymore! Cannot get instance!"); | ||||||
|  | 		} | ||||||
|  | 		 | ||||||
|  | 		return world; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	 | ||||||
|  | 	public static Map<String, Object> serializeLocation(Location l) | ||||||
|  | 	{ | ||||||
|  | 		if (l == null) { | ||||||
|  | 			return null; | ||||||
|  | 		} | ||||||
|  | 		 | ||||||
|  | 		Map<String, Object> serializedLocation = new HashMap<String, Object>(); | ||||||
|  | 		 | ||||||
|  | 		serializedLocation.put(worldKey, l.getWorld().getName()); | ||||||
|  | 		serializedLocation.put(xKey, l.getX()); | ||||||
|  | 		serializedLocation.put(yKey, l.getY()); | ||||||
|  | 		serializedLocation.put(zKey, l.getZ()); | ||||||
|  | 		 | ||||||
|  | 		return serializedLocation; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  |  | ||||||
|  | 	public static Location deserializeLocation(Map<String, Object> map) throws Exception | ||||||
|  | 	{ | ||||||
|  | 		if (map == null) { | ||||||
|  | 			return null; | ||||||
|  | 		} | ||||||
|  | 		 | ||||||
|  | 		World w = getWorld((String)map.get(worldKey)); | ||||||
|  | 		 | ||||||
|  | 		 | ||||||
|  | 		// verbose loading of coordinates (they might be Double or Integer) | ||||||
|  | 		Object objX =  map.get(xKey); | ||||||
|  | 		Object objY =  map.get(yKey); | ||||||
|  | 		Object objZ =  map.get(zKey); | ||||||
|  | 		 | ||||||
|  | 		double x,y,z; | ||||||
|  | 		 | ||||||
|  | 		if (objX instanceof Integer) | ||||||
|  | 			x = (double)(Integer)objX; | ||||||
|  | 		else | ||||||
|  | 			x = (Double)objX; | ||||||
|  | 		 | ||||||
|  | 		if (objY instanceof Integer) | ||||||
|  | 			y = (double)(Integer)objY; | ||||||
|  | 		else | ||||||
|  | 			y = (Double)objY; | ||||||
|  | 		 | ||||||
|  | 		if (objZ instanceof Integer) | ||||||
|  | 			z = (double)(Integer)objZ; | ||||||
|  | 		else | ||||||
|  | 			z = (Double)objZ; | ||||||
|  | 		 | ||||||
|  | 		 | ||||||
|  | 		return new Location(w, x, y, z); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -18,15 +18,14 @@ package de.craftinc.borderprotection; | |||||||
|  |  | ||||||
| import org.bukkit.Location; | import org.bukkit.Location; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
|  | import org.bukkit.World; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.event.EventHandler; | import org.bukkit.event.EventHandler; | ||||||
| import org.bukkit.event.EventPriority; | import org.bukkit.event.EventPriority; | ||||||
| import org.bukkit.event.Listener; | import org.bukkit.event.Listener; | ||||||
| import org.bukkit.event.player.PlayerMoveEvent; | import org.bukkit.event.player.PlayerMoveEvent; | ||||||
|  |  | ||||||
| import java.util.ArrayList; |  | ||||||
|  |  | ||||||
| public class PlayerMoveListener implements Listener | public class PlayerMoveListener implements Listener | ||||||
| { | { | ||||||
|  |  | ||||||
| @@ -37,11 +36,11 @@ public class PlayerMoveListener implements Listener | |||||||
|         this.borderManager = borderManager; |         this.borderManager = borderManager; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private Double goUpUntilFreeSpot( Player player ) |     private Double goUpUntilFreeSpot( Location newLocation ) | ||||||
|     { |     { | ||||||
|         // go up in height until the player can stand in AIR |         // go up in height until the player can stand in AIR | ||||||
|         Block footBlock = player.getLocation().getBlock(); |         Block footBlock = newLocation.getBlock(); | ||||||
|         Block headBlock = player.getEyeLocation().getBlock(); |         Block headBlock = newLocation.getBlock().getRelative(BlockFace.UP); | ||||||
|         while ( footBlock.getType() != Material.AIR || headBlock.getType() != Material.AIR ) |         while ( footBlock.getType() != Material.AIR || headBlock.getType() != Material.AIR ) | ||||||
|         { |         { | ||||||
|             byte offset = 1; |             byte offset = 1; | ||||||
| @@ -66,7 +65,7 @@ public class PlayerMoveListener implements Listener | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // do nothing if there are no border definitions at all |         // do nothing if there are no border definitions at all | ||||||
|         if ( borderManager.getBorders() == null ) |         if ( Border.getBorders().isEmpty() ) | ||||||
|         { |         { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -75,20 +74,20 @@ public class PlayerMoveListener implements Listener | |||||||
|         Location playerLocation = e.getPlayer().getLocation(); |         Location playerLocation = e.getPlayer().getLocation(); | ||||||
|  |  | ||||||
|         // world where the player is in |         // world where the player is in | ||||||
|         String worldName = e.getPlayer().getWorld().getName(); |         World world= e.getPlayer().getWorld(); | ||||||
|  |  | ||||||
|         // borders of this world |         // border of this world | ||||||
|         ArrayList<Location> borderPoints = borderManager.getBorders().get(worldName); |         Border border = Border.getBorders().get(world); | ||||||
|  |  | ||||||
|         // do nothing if there are no borders for this specific world |         // do nothing if there are no borders for this specific world | ||||||
|         if ( borderPoints == null ) |         if ( border == null ) | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         // change x or z. default: do not change |         // change x or z. default: do not change | ||||||
|         Double[] newXZ; |         Double[] newXZ; | ||||||
|  |  | ||||||
|         // check if player is inside the borders. null if yes, otherwise a tuple which defines the new player position |         // check if player is inside the borders. null if yes, otherwise a tuple which defines the new player position | ||||||
|         newXZ = borderManager.checkBorder(playerLocation, borderPoints, borderManager.getBuffer()); |         newXZ = borderManager.checkBorder(playerLocation, border, BorderManager.buffer); | ||||||
|  |  | ||||||
|         // Do nothing, if no new coordinates have been calculated. |         // Do nothing, if no new coordinates have been calculated. | ||||||
|         if ( newXZ == null ) |         if ( newXZ == null ) | ||||||
| @@ -101,7 +100,7 @@ public class PlayerMoveListener implements Listener | |||||||
|         newXZ[1] = newXZ[1] == null ? playerLocation.getZ() : newXZ[1]; |         newXZ[1] = newXZ[1] == null ? playerLocation.getZ() : newXZ[1]; | ||||||
|  |  | ||||||
|         // change Y if necessary (when there is no free spot) |         // change Y if necessary (when there is no free spot) | ||||||
|         Double newY = goUpUntilFreeSpot(e.getPlayer()); |         Double newY = goUpUntilFreeSpot(new Location(world, newXZ[0], e.getPlayer().getLocation().getY(), newXZ[1])); | ||||||
|  |  | ||||||
|         // teleport the player to the new X and Z coordinates |         // teleport the player to the new X and Z coordinates | ||||||
|         e.getPlayer().teleport( |         e.getPlayer().teleport( | ||||||
|   | |||||||
| @@ -17,13 +17,12 @@ | |||||||
| package de.craftinc.borderprotection; | package de.craftinc.borderprotection; | ||||||
|  |  | ||||||
| import org.bukkit.Location; | import org.bukkit.Location; | ||||||
|  | import org.bukkit.World; | ||||||
| import org.bukkit.event.EventHandler; | import org.bukkit.event.EventHandler; | ||||||
| import org.bukkit.event.EventPriority; | import org.bukkit.event.EventPriority; | ||||||
| import org.bukkit.event.Listener; | import org.bukkit.event.Listener; | ||||||
| import org.bukkit.event.player.PlayerTeleportEvent; | import org.bukkit.event.player.PlayerTeleportEvent; | ||||||
|  |  | ||||||
| import java.util.ArrayList; |  | ||||||
|  |  | ||||||
| public class PlayerTeleportListener implements Listener | public class PlayerTeleportListener implements Listener | ||||||
| { | { | ||||||
|     private BorderManager borderManager; |     private BorderManager borderManager; | ||||||
| @@ -43,7 +42,7 @@ public class PlayerTeleportListener implements Listener | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // do nothing if there are no border definitions at all |         // do nothing if there are no border definitions at all | ||||||
|         if ( borderManager.getBorders() == null ) |         if ( Border.getBorders().isEmpty() ) | ||||||
|         { |         { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -52,13 +51,13 @@ public class PlayerTeleportListener implements Listener | |||||||
|         Location targetLocation = e.getTo(); |         Location targetLocation = e.getTo(); | ||||||
|  |  | ||||||
|         // world where the player is in |         // world where the player is in | ||||||
|         String worldName = targetLocation.getWorld().getName(); |         World world = targetLocation.getWorld(); | ||||||
|  |  | ||||||
|         // borders of this world |         // borders of this world | ||||||
|         ArrayList<Location> borderPoints = borderManager.getBorders().get(worldName); |         Border border = Border.getBorders().get(world); | ||||||
|  |  | ||||||
|         // do nothing if there are no borders for this specific world |         // do nothing if there are no borders for this specific world | ||||||
|         if ( borderPoints == null ) |         if ( border == null ) | ||||||
|         { |         { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -67,7 +66,7 @@ public class PlayerTeleportListener implements Listener | |||||||
|         Double[] newXZ; |         Double[] newXZ; | ||||||
|  |  | ||||||
|         // check if target is inside the borders. null if yes, otherwise a tuple which defines the new position |         // check if target is inside the borders. null if yes, otherwise a tuple which defines the new position | ||||||
|         newXZ = borderManager.checkBorder(targetLocation, borderPoints, borderManager.getBuffer()); |         newXZ = borderManager.checkBorder(targetLocation, border, BorderManager.buffer); | ||||||
|  |  | ||||||
|  |  | ||||||
|         // Cancel event, if new coordinates have been calculated. |         // Cancel event, if new coordinates have been calculated. | ||||||
|   | |||||||
| @@ -1,113 +0,0 @@ | |||||||
| /*  CraftInc BorderProtection |  | ||||||
|     Copyright (C) 2012  Paul Schulze |  | ||||||
|  |  | ||||||
|     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 de.craftinc.borderprotection; |  | ||||||
|  |  | ||||||
| import org.bukkit.Location; |  | ||||||
| import org.json.simple.JSONArray; |  | ||||||
| import org.json.simple.parser.JSONParser; |  | ||||||
| import org.json.simple.parser.ParseException; |  | ||||||
|  |  | ||||||
| import java.io.*; |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.HashMap; |  | ||||||
|  |  | ||||||
| public class Serializer |  | ||||||
| { |  | ||||||
|     private File dataFile; |  | ||||||
|  |  | ||||||
|     public Serializer( File dataFile ) |  | ||||||
|     { |  | ||||||
|         this.dataFile = dataFile; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public HashMap<String, ArrayList<Location>> loadDataFile() |  | ||||||
|     { |  | ||||||
|         try |  | ||||||
|         { |  | ||||||
|             FileReader fr = new FileReader(dataFile); |  | ||||||
|             BufferedReader br = new BufferedReader(fr); |  | ||||||
|             StringBuilder fileContents = new StringBuilder(); |  | ||||||
|  |  | ||||||
|             String line; |  | ||||||
|             while ( ( line = br.readLine() ) != null ) |  | ||||||
|             { |  | ||||||
|                 fileContents.append(line); |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             JSONParser jsonParser = new JSONParser(); |  | ||||||
|             JSONArray json = (JSONArray) jsonParser.parse(fileContents.toString()); |  | ||||||
|  |  | ||||||
|             return Util.decodeJSON(json); |  | ||||||
|         } |  | ||||||
|         catch ( IOException e ) |  | ||||||
|         { |  | ||||||
|             if ( e instanceof FileNotFoundException ) |  | ||||||
|             { |  | ||||||
|                 Plugin.getPlugin().getLogger().info("Data file not found."); |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 e.printStackTrace(); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         catch ( ParseException e ) |  | ||||||
|         { |  | ||||||
|             Plugin.getPlugin().getLogger() |  | ||||||
|                   .severe("Could not parse json data file. When you set up a new border, the corrupt data file will be overwritten!"); |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void saveDataFile( HashMap<String, ArrayList<Location>> data ) |  | ||||||
|     { |  | ||||||
|         // if there is not data, do nothing and log it to console |  | ||||||
|         if ( data == null ) |  | ||||||
|         { |  | ||||||
|             Plugin.getPlugin().getLogger().severe("Could not save data, because it is null"); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // create plugin directory if it doesn't exists |  | ||||||
|         if ( !Plugin.getPlugin().getDataFolder().exists() ) |  | ||||||
|         { |  | ||||||
|             Plugin.getPlugin().getLogger().info("Creating plugin directory..."); |  | ||||||
|             if ( !Plugin.getPlugin().getDataFolder().mkdir() ) |  | ||||||
|             { |  | ||||||
|                 Plugin.getPlugin().getLogger().severe("Could not create plugin directory"); |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 Plugin.getPlugin().getLogger().info("Plugin directory created successfully"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         JSONArray json = Util.encodeJSON(data); |  | ||||||
|  |  | ||||||
|         // Write to file |  | ||||||
|         try |  | ||||||
|         { |  | ||||||
|             FileWriter fw = new FileWriter(dataFile); |  | ||||||
|             fw.write(json.toJSONString()); |  | ||||||
|             fw.close(); |  | ||||||
|         } |  | ||||||
|         catch ( IOException e ) |  | ||||||
|         { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,106 +0,0 @@ | |||||||
| /*  CraftInc BorderProtection |  | ||||||
|     Copyright (C) 2012  Paul Schulze |  | ||||||
|  |  | ||||||
|     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 de.craftinc.borderprotection; |  | ||||||
|  |  | ||||||
| import org.bukkit.Bukkit; |  | ||||||
| import org.bukkit.Location; |  | ||||||
| import org.json.simple.JSONArray; |  | ||||||
| import org.json.simple.JSONObject; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.HashMap; |  | ||||||
|  |  | ||||||
| public class Util |  | ||||||
| { |  | ||||||
|     public static HashMap<String, ArrayList<Location>> decodeJSON( JSONArray json ) |  | ||||||
|     { |  | ||||||
|         HashMap<String, ArrayList<Location>> data = new HashMap<String, ArrayList<Location>>(); |  | ||||||
|  |  | ||||||
|         for ( Object jsonEntry : json.toArray() ) |  | ||||||
|         { |  | ||||||
|             JSONObject j = (JSONObject) jsonEntry; |  | ||||||
| //            // check if border for this world is enabled. continue if not |  | ||||||
| //            String enabled = (String) j.get("enabled"); |  | ||||||
| //            if (enabled != "1") { |  | ||||||
| //                continue; |  | ||||||
| //            } |  | ||||||
|             String worldname = (String) j.get("worldname"); |  | ||||||
|             ArrayList<Location> locations = new ArrayList<Location>(); |  | ||||||
|             JSONArray borderPoints = (JSONArray) j.get("borderPoints"); |  | ||||||
|  |  | ||||||
|             for ( Object pointObj : borderPoints ) |  | ||||||
|             { |  | ||||||
|                 JSONArray point = (JSONArray) pointObj; |  | ||||||
|  |  | ||||||
|                 locations |  | ||||||
|                         .add(new Location(Bukkit.getWorld(worldname), (Double) point.get(0), 0, (Double) point.get(1))); |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             data.put(worldname, locations); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if ( data.size() > 0 ) |  | ||||||
|         { |  | ||||||
|             return data; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static JSONArray encodeJSON( HashMap<String, ArrayList<Location>> data ) |  | ||||||
|     { |  | ||||||
|         JSONArray json = new JSONArray(); |  | ||||||
|         int i = 0; |  | ||||||
|         for ( ArrayList<Location> border : data.values() ) |  | ||||||
|         { |  | ||||||
|  |  | ||||||
|             // add point 1 as json array |  | ||||||
|             JSONArray point1 = new JSONArray(); |  | ||||||
|             point1.add(0, border.get(0).getX()); |  | ||||||
|             point1.add(1, border.get(0).getZ()); |  | ||||||
|  |  | ||||||
|             // add point 2 as json array |  | ||||||
|             JSONArray point2 = new JSONArray(); |  | ||||||
|             point2.add(0, border.get(1).getX()); |  | ||||||
|             point2.add(1, border.get(1).getZ()); |  | ||||||
|  |  | ||||||
|             // add both points to points json array |  | ||||||
|             JSONArray points = new JSONArray(); |  | ||||||
|             points.add(point1); |  | ||||||
|             points.add(point2); |  | ||||||
|  |  | ||||||
|             // Add points and worldname to world json object |  | ||||||
|             JSONObject borderOfAWorld = new JSONObject(); |  | ||||||
|             try |  | ||||||
|             { |  | ||||||
|                 borderOfAWorld.put("worldname", border.get(0).getWorld().getName()); |  | ||||||
|                 borderOfAWorld.put("borderPoints", points); |  | ||||||
|                 json.add(i, borderOfAWorld); |  | ||||||
|                 i++; |  | ||||||
|             } |  | ||||||
|             catch ( NullPointerException e ) |  | ||||||
|             { |  | ||||||
|                 if ( border.get(0).getWorld() == null ) |  | ||||||
|                 { |  | ||||||
|                     Plugin.getPlugin().getLogger() |  | ||||||
|                           .warning("A world is null. Ignoring this border (not saving this border)."); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return json; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -14,9 +14,9 @@ | |||||||
| #    You should have received a copy of the GNU General Public License | #    You should have received a copy of the GNU General Public License | ||||||
| #    along with this program.  If not, see <http://www.gnu.org/licenses/>. | #    along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| name: CraftincBorderProtection | name: Craft Inc. BorderProtection | ||||||
| main: de.craftinc.borderprotection.Plugin | main: de.craftinc.borderprotection.Plugin | ||||||
| version: 0.9.9 | version: 1.0.0 | ||||||
| author: ddidderr | author: ddidderr | ||||||
| website: http://www.craftinc.de/plugins/borderprotection | website: http://www.craftinc.de/plugins/borderprotection | ||||||
|  |  | ||||||
| @@ -27,8 +27,8 @@ commands: | |||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   craftinc.borderprotection.set: |   craftinc.borderprotection.set: | ||||||
|     default: false |     default: op | ||||||
|     description: Allows to set the border for a world. |     description: Allows to set the border for a world. | ||||||
|   craftinc.borderprotection.ignoreborders: |   craftinc.borderprotection.ignoreborders: | ||||||
|     default: false |     default: op | ||||||
|     description: Allows to be everywhere on the map (ignoring the borders). |     description: Allows to be everywhere on the map (ignoring the borders). | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Paul Schulze
					Paul Schulze