Commands finished (maybe), Serialization added, Plugin should work for a

first test (maybe) :)
This commit is contained in:
Paul Schulze 2013-03-19 11:36:26 +01:00
parent abec8e11ef
commit 9b17060d32
7 changed files with 491 additions and 70 deletions

View File

@ -23,14 +23,19 @@ import org.bukkit.event.block.BlockPlaceEvent;
import java.util.ArrayList; import java.util.ArrayList;
public class BlockPlaceListener implements Listener { @SuppressWarnings("UnusedDeclaration")
public class BlockPlaceListener implements Listener
public void onBlockPlaced(BlockPlaceEvent event){ {
public void onBlockPlaced( BlockPlaceEvent event )
{
ArrayList<Location> replicators = Replicator.getReplicators(event.getBlockPlaced().getLocation()); ArrayList<Location> replicators = Replicator.getReplicators(event.getBlockPlaced().getLocation());
if(!replicators.isEmpty()){ if ( !replicators.isEmpty() )
for(Location loc:replicators){ {
for ( Location loc : replicators )
{
Replicator rep = Replicator.getOrCreate(loc, event.getPlayer().getName()); Replicator rep = Replicator.getOrCreate(loc, event.getPlayer().getName());
if(rep!=null){ if ( rep != null )
{
event.getPlayer().sendMessage(Messages.newReplicator(rep)); event.getPlayer().sendMessage(Messages.newReplicator(rep));
} }
} }

View File

@ -94,7 +94,7 @@ public class Commands implements CommandExecutor
ArrayList<Replicator> replicators = new ArrayList<Replicator>(); ArrayList<Replicator> replicators = new ArrayList<Replicator>();
for ( Location replicatorCenter : replicatorCenters ) for ( Location replicatorCenter : replicatorCenters )
{ {
replicators.add(Replicator.getOrCreate(replicatorCenter)); replicators.add(Replicator.getOrCreate(replicatorCenter, player.getName()));
} }
sender.sendMessage(Messages.info(replicators)); sender.sendMessage(Messages.info(replicators));
return true; return true;
@ -102,13 +102,14 @@ public class Commands implements CommandExecutor
// replicator specified as argument // replicator specified as argument
else if ( args.length == 2 ) else if ( args.length == 2 )
{ {
Replicator rep = Replicator.getByName(args[1], player); Replicator rep = Replicator.getByName(args[1], player.getName());
if ( rep == null ) if ( rep == null )
{ {
sender.sendMessage(Messages.noReplicatorWithName(args[1])); sender.sendMessage(Messages.noReplicatorWithName(args[1]));
return true; return true;
} }
sender.sendMessage(Messages.info(new ArrayList<Replicator>(Arrays.asList(new Replicator[]{rep})))); sender.sendMessage(
Messages.info(new ArrayList<Replicator>(Arrays.asList(new Replicator[] { rep }))));
return true; return true;
} }
} }
@ -116,12 +117,15 @@ public class Commands implements CommandExecutor
// list // list
if ( args.length == 1 && args[0].equalsIgnoreCase("list") ) if ( args.length == 1 && args[0].equalsIgnoreCase("list") )
{ {
sender.sendMessage(Messages.list(Replicator.getReplicatorsByOwner(), Replicator.getReplicatorsByUser())); sender.sendMessage(
Messages.list(Replicator.getReplicatorsByOwner(player.getName()),
Replicator.getReplicatorsByUser(player.getName())));
return true; return true;
} }
// addowner // addowner, delowner, adduser, deluser
if (args.length > 1 && args[0].equalsIgnoreCase("addowner")) if ( args.length > 1 && ( args[0].equalsIgnoreCase("addowner") || args[0].equalsIgnoreCase("delowner") ||
args[0].equalsIgnoreCase("adduser") || args[0].equalsIgnoreCase("deluser") ) )
{ {
// looking at replicator // looking at replicator
if ( args.length == 2 ) if ( args.length == 2 )
@ -140,17 +144,67 @@ public class Commands implements CommandExecutor
return true; return true;
} }
ArrayList<Replicator> replicators = new ArrayList<Replicator>();
for ( Location replicatorCenter : replicatorCenters ) for ( Location replicatorCenter : replicatorCenters )
{ {
Replicator replicator = Replicator.getOrCreate(); Replicator replicator = Replicator.getOrCreate(replicatorCenter, player.getName());
if ( replicator == null )
{
sender.sendMessage(Messages.noReplicatorInSight);
continue;
}
if ( args[0].equalsIgnoreCase("addowner") )
{
replicator.addOwner(args[1]); replicator.addOwner(args[1]);
}
else if ( args[0].equalsIgnoreCase("delowner") )
{
replicator.rmOwner(args[1]);
}
else if ( args[0].equalsIgnoreCase("adduser") )
{
replicator.addUser(args[1]);
}
else if ( args[0].equalsIgnoreCase("deluser") )
{
replicator.rmUser(args[1]);
}
sender.sendMessage(Messages.addedOwner(args[1], replicator)); sender.sendMessage(Messages.addedOwner(args[1], replicator));
} }
return true; return true;
} }
// replicator name specified as argument
else if ( args.length == 3 )
{
Replicator replicator = Replicator.getByName(args[2], player.getName());
if ( replicator == null )
{
sender.sendMessage(Messages.noReplicatorWithName(args[2]));
return true;
} }
if ( args[0].equalsIgnoreCase("addowner") )
{
replicator.addOwner(args[1]);
}
else if ( args[0].equalsIgnoreCase("delowner") )
{
replicator.rmOwner(args[1]);
}
else if ( args[0].equalsIgnoreCase("adduser") )
{
replicator.addUser(args[1]);
}
else if ( args[0].equalsIgnoreCase("deluser") )
{
replicator.rmUser(args[1]);
}
sender.sendMessage(Messages.addedOwner(player.getName(), replicator));
return true;
}
}
} }

View File

@ -0,0 +1,83 @@
package de.craftinc.replicator;
import org.bukkit.Location;
import org.bukkit.World;
import java.util.HashMap;
import java.util.Map;
public class LocationSerializer
{
private static String worldKey = "world";
private static String xKey = "x";
private static String yKey = "y";
private static String zKey = "z";
private static World getWorld( String name ) throws Exception
{
World world = Plugin.instance.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);
}
}

View File

@ -71,11 +71,18 @@ public class Messages
{ {
return ChatColor.GREEN + pluginName + " - Usage:" + NEWLINE + return ChatColor.GREEN + pluginName + " - Usage:" + NEWLINE +
makeCmd(player, "help", "shows this help", null) + makeCmd(player, "help", "shows this help", null) +
makeCmd(player, "adduser | deluser", "Add or remove a player's right to use the replicator in front of you or the replicator given by \"id\".", null, "<player>", "[id]") + makeCmd(player, "adduser | deluser",
makeCmd(player, "addowner | delowner", "Add or remove a player's right to use AND add or remove other users and owners to the replicator in front of you or the replicator given by \"id\".", null, "<player>", "[id]") + "Add or remove a player's right to use the replicator in front of you or the replicator given by \"id\".",
null, "<player>", "[id]") +
makeCmd(player, "addowner | delowner",
"Add or remove a player's right to use AND add or remove other users and owners to the replicator in front of you or the replicator given by \"id\".",
null, "<player>", "[id]") +
makeCmd(player, "list", "Lists all your replicators.", null) + makeCmd(player, "list", "Lists all your replicators.", null) +
makeCmd(player, "info", "Get information about the replicator in front of you or the replicator given by \"id\".", null, "[id]") + makeCmd(player, "info",
makeCmd(player, "checkversion", "Checks for a newer version.", new String[] { "craftinc.replicator.update" }); "Get information about the replicator in front of you or the replicator given by \"id\".", null,
"[id]") +
makeCmd(player, "checkversion", "Checks for a newer version.",
new String[] { "craftinc.replicator.update" });
} }
public static String commandIssuedByNonPlayer public static String commandIssuedByNonPlayer
@ -88,7 +95,7 @@ public class Messages
ChatColor.RED + "Sorry, you don't have permission to check for new versions."; ChatColor.RED + "Sorry, you don't have permission to check for new versions.";
public static String noReplicatorInSight = public static String noReplicatorInSight =
ChatColor.RED + "You are not looking at an replicator."; ChatColor.RED + "You are not looking at an replicator or you do not have permission to do this.";
public static String updateMessage( String newVersion, String curVersion ) public static String updateMessage( String newVersion, String curVersion )
{ {
@ -109,7 +116,7 @@ public class Messages
sb.append(ChatColor.YELLOW + "The following replicators have been found:" + NEWLINE); sb.append(ChatColor.YELLOW + "The following replicators have been found:" + NEWLINE);
for ( Replicator r : replicators ) for ( Replicator r : replicators )
{ {
sb.append(ChatColor.GOLD + r.id + " @ " + r.center.getX() + "," + r.center.getZ() + ":" + NEWLINE); sb.append(ChatColor.GOLD + r.getName() + ":" + NEWLINE);
sb.append(ChatColor.GREEN + "Owners:" + NEWLINE); sb.append(ChatColor.GREEN + "Owners:" + NEWLINE);
for ( String owner : r.getOwners() ) for ( String owner : r.getOwners() )
{ {
@ -132,14 +139,14 @@ public class Messages
sb.append(ChatColor.YELLOW + "Replicators where you are owner:" + NEWLINE); sb.append(ChatColor.YELLOW + "Replicators where you are owner:" + NEWLINE);
for ( Replicator r : repByOwner ) for ( Replicator r : repByOwner )
{ {
sb.append(ChatColor.WHITE + r.id + " @ " + r.center.getX() + "," + r.center.getZ() + NEWLINE); sb.append(ChatColor.WHITE + r.getName() + NEWLINE);
} }
sb.append(NEWLINE); sb.append(NEWLINE);
sb.append(ChatColor.YELLOW + "Replicators where you are user:" + NEWLINE); sb.append(ChatColor.YELLOW + "Replicators where you are user:" + NEWLINE);
for ( Replicator r : repByUser ) for ( Replicator r : repByUser )
{ {
sb.append(ChatColor.WHITE + r.id + " @ " + r.center.getX() + "," + r.center.getZ() + NEWLINE); sb.append(ChatColor.WHITE + r.getName() + NEWLINE);
} }
return sb.toString(); return sb.toString();
@ -147,11 +154,27 @@ public class Messages
public static String noReplicatorWithName( String replicatorName ) public static String noReplicatorWithName( String replicatorName )
{ {
return ChatColor.RED + "No replicator with name: " + replicatorName + " found or you don't have permission for that replicator."; return ChatColor.RED + "No replicator with name: " + replicatorName +
" found or you don't have permission for that replicator.";
} }
public static String addedOwner( String newOwner, Replicator replicator ) public static String addedOwner( String newOwner, Replicator replicator )
{ {
return ChatColor.GREEN + "New owner for " + replicator.id + return ChatColor.GREEN + "Added " + ChatColor.GOLD + newOwner + " as owner for " + ChatColor.GOLD +
replicator.getName();
} }
public static String newReplicator( Replicator replicator )
{
return ChatColor.GREEN + "Congratulations!" + ChatColor.YELLOW + " You have just built a working replicator with id: " +
ChatColor.GREEN + replicator.getName() + NEWLINE +
" Put item frames with items you want to replicate onto the front side and right click them to replicate." + NEWLINE +
" Use " + ChatColor.GOLD + "/repli adduser|deluser" + ChatColor.YELLOW + " while looking at it to give" +
" give other players permission to use your replicator." + NEWLINE +
" Use " + ChatColor.GOLD + "/repli help" + " to see a full list of commands you can use.";
}
public static String couldNotSave = ChatColor.RED + "Sorry! Could not save the replicators to disk. After a server " +
"reload or restart the information about this replicator will be lost. You will " +
"still be able to use it. Tell a mod or admin about that problem.";
} }

View File

@ -40,7 +40,11 @@ public class Plugin extends JavaPlugin
{ {
Plugin.instance = this; Plugin.instance = this;
// load replicators
Replicator.loadReplicators();
// create listeners // create listeners
BlockPlaceListener blockPlaceListener = new BlockPlaceListener();
// commands // commands
Commands commandExecutor = new Commands(); Commands commandExecutor = new Commands();
@ -48,5 +52,6 @@ public class Plugin extends JavaPlugin
// register listeners // register listeners
PluginManager pm = this.getServer().getPluginManager(); PluginManager pm = this.getServer().getPluginManager();
pm.registerEvents(blockPlaceListener, this);
} }
} }

View File

@ -18,68 +18,201 @@
package de.craftinc.replicator; package de.craftinc.replicator;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.block.BlockFace;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.block.BlockFace;
import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.configuration.file.YamlConfiguration;
import org.bukkit.configuration.serialization.ConfigurationSerializable;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
public class Replicator { public class Replicator implements ConfigurationSerializable
{
/**
* Filename where to store the replicators.
*/
private static final String dataFileName = "replicators.yml";
private static final String keyReplicators = "replicators";
private static final String keyName = "name";
private static final String keyCenter = "center";
private static final String keyOwners = "owners";
private static final String keyUsers = "users";
/**
* List of owners. An owner is able to use the replicator and is able to add other users/owners.
*/
private ArrayList<String> owners; private ArrayList<String> owners;
/**
* List of users. A user is able to use the replicator.
*/
private ArrayList<String> users; private ArrayList<String> users;
/**
* Name of the replicator. It will always be in the format "world,x,y,z".
*/
private String name;
/**
* Center location of the replicator.
*/
private Location center; private Location center;
public Replicator(String firstOwner, Location spawn, Location center) { /**
* List of all replicators accessible by center location.
*/
private static HashMap<Location, Replicator> allReplicators;
private static File replicatorsFile = new File(Plugin.instance.getDataFolder(), dataFileName);
private static FileConfiguration replicatorsFileConf = YamlConfiguration.loadConfiguration(replicatorsFile);
public Replicator( String firstOwner, Location center )
{
this.owners = new ArrayList<String>(); this.owners = new ArrayList<String>();
this.users = new ArrayList<String>(); this.users = new ArrayList<String>();
this.owners.add(firstOwner); this.owners.add(firstOwner);
this.center = center; this.center = center;
name = center.getWorld() + "," + center.getBlockX() + "," + center.getBlockY() + "," + center.getBlockZ();
} }
public void addUser(String user) { @SuppressWarnings("unchecked unused")
public Replicator( Map<String, Object> map )
{
try
{
name = (String) map.get(keyName);
center = LocationSerializer.deserializeLocation((Map<String, Object>) map.get(keyCenter));
owners = (ArrayList<String>) map.get(keyOwners);
users = (ArrayList<String>) map.get(keyUsers);
allReplicators.put(center, this);
}
catch ( Exception e )
{
Plugin.instance.getLogger().severe(e.getMessage());
}
}
public ArrayList<String> getOwners()
{
return owners;
}
public ArrayList<String> getUsers()
{
return users;
}
public void addUser( String user )
{
this.users.add(user); this.users.add(user);
} }
public void addOwner(String owner) { public void addOwner( String owner )
{
this.users.add(owner); this.users.add(owner);
} }
public boolean rmUser(String user) { public boolean rmUser( String user )
if(this.users.remove(user)) return true; {
else return false; if ( this.users.remove(user) )
return true;
else
return false;
} }
public boolean rmOwner(String owner) { public boolean rmOwner( String owner )
if(this.owners.remove(owner)) return true; {
else return false; if ( this.owners.remove(owner) )
return true;
else
return false;
} }
public static ArrayList<Location> getReplicators(Location currentBlock){ public boolean isOwner( String player )
{
for ( String owner : owners )
{
if ( owner.equals(player) )
{
return true;
}
}
return false;
}
public boolean isUser( String player )
{
for ( String user : users )
{
if ( user.equals(player) )
{
return true;
}
}
return false;
}
public void setName( String newName )
{
this.name = newName;
//TODO: Save List
}
public String getName()
{
return name;
}
public static ArrayList<Location> getReplicators( Location currentBlock )
{
ArrayList<Location> replicators = new ArrayList<Location>(); ArrayList<Location> replicators = new ArrayList<Location>();
ArrayList<Location> centers = getCenters(currentBlock); ArrayList<Location> centers = getCenters(currentBlock);
for(Location center:centers){ for ( Location center : centers )
if(isValid(center)){ {
if ( isValid(center) )
{
replicators.add(center); replicators.add(center);
} }
} }
return replicators; return replicators;
} }
private static Material[][][] getPattern(Location center){ private static Material[][][] getPattern( Location center )
if(center.getBlock().getRelative(BlockFace.NORTH).getType().equals(Material.AIR)) return Pattern.getNorth(); {
if(center.getBlock().getRelative(BlockFace.SOUTH).getType().equals(Material.AIR)) return Pattern.getSouth(); if ( center.getBlock().getRelative(BlockFace.NORTH).getType().equals(Material.AIR) )
if(center.getBlock().getRelative(BlockFace.WEST).getType().equals(Material.AIR)) return Pattern.getWest(); return Pattern.getNorth();
if(center.getBlock().getRelative(BlockFace.EAST).getType().equals(Material.AIR)) return Pattern.getEast(); if ( center.getBlock().getRelative(BlockFace.SOUTH).getType().equals(Material.AIR) )
return Pattern.getSouth();
if ( center.getBlock().getRelative(BlockFace.WEST).getType().equals(Material.AIR) )
return Pattern.getWest();
if ( center.getBlock().getRelative(BlockFace.EAST).getType().equals(Material.AIR) )
return Pattern.getEast();
return null; return null;
} }
private static boolean isValid(Location center){ private static boolean isValid( Location center )
{
Material[][][] pattern = getPattern(center); Material[][][] pattern = getPattern(center);
for(int x=0;x<=2;x++){ if ( pattern == null )
for(int y=0;y<=2;y++){ {
for(int z=0;z<=2;z++){ return false;
if((pattern[x][y][z]!=center.getBlock().getRelative(x-1,y-1,z-1).getType())&&((pattern[x][y][z]!=null))){ }
for ( int x = 0; x <= 2; x++ )
{
for ( int y = 0; y <= 2; y++ )
{
for ( int z = 0; z <= 2; z++ )
{
if ( ( pattern[x][y][z] != center.getBlock().getRelative(x - 1, y - 1, z - 1).getType() ) &&
( ( pattern[x][y][z] != null ) ) )
{
return false; return false;
} }
} }
@ -88,18 +221,136 @@ public class Replicator {
return true; return true;
} }
private static ArrayList<Location> getCenters(Location currentBlock){ private static ArrayList<Location> getCenters( Location currentBlock )
{
ArrayList<Location> centers = new ArrayList<Location>(); ArrayList<Location> centers = new ArrayList<Location>();
Location nextBlock; Location nextBlock;
for(int x=-1;x<=1;x++){ for ( int x = -1; x <= 1; x++ )
for(int y=-1;y<=1;y++){ {
for(int z=-1;z<=1;z++){ for ( int y = -1; y <= 1; y++ )
{
for ( int z = -1; z <= 1; z++ )
{
nextBlock = currentBlock.getBlock().getRelative(x, y, z).getLocation(); nextBlock = currentBlock.getBlock().getRelative(x, y, z).getLocation();
if(nextBlock.getBlock().getType().equals(Pattern.getCenter())) centers.add(nextBlock); if ( nextBlock.getBlock().getType().equals(Pattern.getCenter()) )
centers.add(nextBlock);
} }
} }
} }
return centers; return centers;
} }
/**
* Gets a replicator with the given location. If no replicator exists a new one is created.
* Returns null if player is not owner or user of the replicator.
*
* @param loc center of the replicator
* @param playerName name of the player
* @return Replicator
*/
public static Replicator getOrCreate( Location loc, String playerName )
{
Replicator rep = allReplicators.get(loc);
// replicator already exists
if ( rep != null )
{
if ( rep.isOwner(playerName) || rep.isUser(playerName) )
{
return rep;
}
else
{
return null;
}
}
// replicator does not exist, create one
else
{
rep = new Replicator(playerName, loc);
allReplicators.put(loc, rep);
try {
Replicator.saveReplicators();
}
catch ( IOException e )
{
Plugin.instance.getServer().getPlayer(playerName).sendMessage(Messages.couldNotSave);
Plugin.instance.getLogger().severe("Could not save replicators to file: " + e.getMessage());
}
return rep;
}
}
/**
* Get a replicator with the specified name. Returns null if player
* is not owner or user or if replicator does not exist.
*
* @param repName name of the replicator
* @param playerName name of the player
* @return Replicator
*/
public static Replicator getByName( String repName, String playerName )
{
for ( Replicator rep : allReplicators.values() )
{
if ( rep.getName().equals(repName) )
{
if ( rep.isOwner(playerName) || rep.isUser(playerName) )
{
return rep;
}
}
}
return null;
}
public static ArrayList<Replicator> getReplicatorsByOwner( String playerName )
{
ArrayList<Replicator> reps = new ArrayList<Replicator>();
for ( Replicator rep : allReplicators.values() )
{
if ( rep.isOwner(playerName) )
{
reps.add(rep);
}
}
return reps;
}
public static ArrayList<Replicator> getReplicatorsByUser( String playerName )
{
ArrayList<Replicator> reps = new ArrayList<Replicator>();
for ( Replicator rep : allReplicators.values() )
{
if ( rep.isUser(playerName) )
{
reps.add(rep);
}
}
return reps;
}
@SuppressWarnings("unused")
public Map<String, Object> serialize()
{
Map<String, Object> map = new HashMap<String, Object>();
map.put(keyName, name);
map.put(keyCenter, LocationSerializer.serializeLocation(center));
map.put(keyOwners, owners);
map.put(keyUsers, users);
return map;
}
public static void loadReplicators()
{
replicatorsFileConf.getList(keyReplicators);
}
public static void saveReplicators() throws IOException
{
replicatorsFileConf.set(keyReplicators, new ArrayList<Object>(allReplicators.values()));
replicatorsFileConf.save(replicatorsFile);
}
} }

View File

@ -1,4 +1,4 @@
/* Craft Inc. BorderProtection /* Craft Inc. Replicator
Copyright (C) 2013 Paul Schulze Copyright (C) 2013 Paul Schulze
This program is free software: you can redistribute it and/or modify This program is free software: you can redistribute it and/or modify
@ -29,7 +29,7 @@ public class UpdateHelper
* The URL from which the Plugin tries to get the latest version. * The URL from which the Plugin tries to get the latest version.
*/ */
@SuppressWarnings("FieldCanBeLocal") @SuppressWarnings("FieldCanBeLocal")
private static final String updateUrl = "http://www.craftinc.de/plugins/update/craftinc-borderprotection"; private static final String updateUrl = "http://www.craftinc.de/plugins/update/craftinc-replicator";
/** /**
* The latest version which was seen on last check. * The latest version which was seen on last check.