User/Owner Buggs fixed, first final version

This commit is contained in:
Mochaccino 2013-03-19 19:18:41 +01:00
parent 28d9e89ab6
commit 8b5e3a4342
5 changed files with 155 additions and 98 deletions

View File

@ -30,15 +30,15 @@ public class BlockPlaceListener implements Listener
@EventHandler(priority = EventPriority.MONITOR)
public void onBlockPlaced( BlockPlaceEvent event )
{
ArrayList<Location> replicators = Replicator.getReplicators(event.getBlockPlaced().getLocation());
ArrayList<Location> replicators = Replicator.getReplicatorLocations(event.getBlockPlaced().getLocation());
if ( !replicators.isEmpty() )
{
for ( Location loc : replicators )
{
Replicator rep = Replicator.getOrCreate(loc, event.getPlayer().getName());
Replicator rep = Replicator.getOrCreate(loc, event.getPlayer());
if ( rep != null )
{
event.getPlayer().sendMessage(Messages.newReplicator(rep));
}
}
}

View File

@ -79,23 +79,16 @@ public class Commands implements CommandExecutor
if ( args.length == 1 )
{
// get block where the player is looking at
Block potentialReplicatorBlock = player.getTargetBlock(BlockUtil.transparentBlocks, 100);
Block potentialReplicatorBlock = player.getTargetBlock(null, 100);
Replicator.mochaccino.sendMessage("You are looking at "+potentialReplicatorBlock.getLocation().getBlockX()+","+potentialReplicatorBlock.getLocation().getBlockY()+","+potentialReplicatorBlock.getLocation().getBlockZ());
// get zero or more valid replicator centers
ArrayList<Location> replicatorCenters = Replicator
.getReplicators(potentialReplicatorBlock.getLocation());
ArrayList<Replicator> replicators = Replicator.getReplicators(potentialReplicatorBlock.getLocation());
if ( replicatorCenters.size() == 0 )
if ( replicators.size() == 0 )
{
sender.sendMessage(Messages.noReplicatorInSight);
return true;
}
ArrayList<Replicator> replicators = new ArrayList<Replicator>();
for ( Location replicatorCenter : replicatorCenters )
{
replicators.add(Replicator.getOrCreate(replicatorCenter, player.getName()));
}
sender.sendMessage(Messages.info(replicators));
return true;
}
@ -131,44 +124,36 @@ public class Commands implements CommandExecutor
if ( args.length == 2 )
{
// get block where the player is looking at
Block potentialReplicatorBlock = player.getTargetBlock(BlockUtil.transparentBlocks, 100);
Block potentialReplicatorBlock = player.getTargetBlock(null, 100);
// get zero or more valid replicator centers
ArrayList<Location> replicatorCenters = Replicator
.getReplicators(potentialReplicatorBlock.getLocation());
ArrayList<Replicator> replicators = Replicator
.getOwnReplicators(potentialReplicatorBlock.getLocation(),player.getName());
// no replicator in sight
if ( replicatorCenters.size() == 0 )
if ( replicators.isEmpty() )
{
sender.sendMessage(Messages.noReplicatorInSight);
return true;
}
for ( Location replicatorCenter : replicatorCenters )
for ( Replicator replicator : replicators )
{
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],player.getName());
}
else if ( args[0].equalsIgnoreCase("delowner") )
{
replicator.rmOwner(args[1]);
replicator.rmOwner(args[1],player.getName());
}
else if ( args[0].equalsIgnoreCase("adduser") )
{
replicator.addUser(args[1]);
replicator.addUser(args[1],player.getName());
}
else if ( args[0].equalsIgnoreCase("deluser") )
{
replicator.rmUser(args[1]);
replicator.rmUser(args[1],player.getName());
}
sender.sendMessage(Messages.addedOwner(args[1], replicator));
}
return true;
@ -186,19 +171,19 @@ public class Commands implements CommandExecutor
if ( args[0].equalsIgnoreCase("addowner") )
{
replicator.addOwner(args[1]);
replicator.addOwner(args[1],player.getName());
}
else if ( args[0].equalsIgnoreCase("delowner") )
{
replicator.rmOwner(args[1]);
replicator.rmOwner(args[1],player.getName());
}
else if ( args[0].equalsIgnoreCase("adduser") )
{
replicator.addUser(args[1]);
replicator.addUser(args[1],player.getName());
}
else if ( args[0].equalsIgnoreCase("deluser") )
{
replicator.rmUser(args[1]);
replicator.rmUser(args[1],player.getName());
}
sender.sendMessage(Messages.addedOwner(player.getName(), replicator));

View File

@ -116,6 +116,8 @@ public class Messages
{
StringBuilder sb = new StringBuilder();
sb.append(ChatColor.YELLOW + "The following replicators have been found:" + NEWLINE);
if(replicators.size()>0)
{
for ( Replicator r : replicators )
{
sb.append(ChatColor.GOLD + r.getName() + ":" + NEWLINE);
@ -131,6 +133,7 @@ public class Messages
}
sb.append(NEWLINE);
}
}
return sb.toString();
}

View File

@ -25,6 +25,7 @@ import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerInteractEntityEvent;
import org.bukkit.inventory.ItemStack;
import java.util.ArrayList;
@ -51,7 +52,7 @@ public class PlayerInteractEntityListener implements Listener
break;
}
}
//Replicator.mochaccino.sendMessage("ItemFrame found "+itemFrame.getEntityId());
// if no item frame was found: return! (strange and should NEVER happen as long as the world is not upside down!)
if ( itemFrame == null )
{
@ -65,33 +66,30 @@ public class PlayerInteractEntityListener implements Listener
}
// find replicator centers which are suitable for this item frame
ArrayList<Location> replicatorCenters = Replicator.getReplicators(event.getRightClicked().getLocation());
//Replicator.mochaccino.sendMessage(itemFrame.getAttachedFace() + "");
ArrayList<Replicator> replicators = Replicator.getUsableReplicators(event.getRightClicked().getLocation().getBlock().getRelative(itemFrame.getAttachedFace()).getLocation(),event.getPlayer().getName());
// do nothing if no replicator centers have been found
if ( replicatorCenters.isEmpty() )
if ( replicators.isEmpty() )
{
//Replicator.mochaccino.sendMessage("No replicator found.");
return;
}
// get the replicators from database for these centers
for ( Location replicatorCenter : replicatorCenters )
for ( Replicator replicator : replicators )
{
Replicator replicator = Replicator.getOrCreate(replicatorCenter, event.getPlayer().getName());
// replicator can be null if the player is not user and not owner
if ( replicator == null )
{
continue;
}
// from here on we have a valid replicator and a valid item
// that's why we cancel the event
event.setCancelled(true);
// and spawn the items at the center location of the replicator
ItemStack stack = itemFrame.getItem();
stack.setAmount(64);
event.getPlayer().getWorld().dropItemNaturally(
replicatorCenter.getBlock().getRelative(Replicator.getDirection(replicatorCenter)).getLocation(),
itemFrame.getItem());
replicator.getCenter().getBlock().getRelative(Replicator.getDirection(replicator.getCenter())).getLocation(),
stack);
}
}
}

View File

@ -29,6 +29,7 @@ import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
public class Replicator implements ConfigurationSerializable
@ -43,23 +44,28 @@ public class Replicator implements ConfigurationSerializable
private static final String keyCenter = "center";
private static final String keyOwners = "owners";
private static final String keyUsers = "users";
private static final Player mochaccino = Plugin.instance.getServer().getPlayer("Mochaccino");
//public static final Player mochaccino = Plugin.instance.getServer().getPlayer("Mochaccino");
/**
* List of owners. An owner is able to use the replicator and is able to add other users/owners.
*/
private ArrayList<String> owners;
private HashSet<String> owners;
/**
* List of users. A user is able to use the replicator.
*/
private ArrayList<String> users;
private HashSet<String> users;
/**
* Name of the replicator. It will always be in the format "world,x,y,z".
*/
private String name;
public Location getCenter()
{
return center;
}
/**
* Center location of the replicator.
*/
@ -76,11 +82,11 @@ public class Replicator implements ConfigurationSerializable
public Replicator( String firstOwner, Location center )
{
this.owners = new ArrayList<String>();
this.users = new ArrayList<String>();
this.owners = new HashSet<String>();
this.users = new HashSet<String>();
this.owners.add(firstOwner);
this.center = center;
name = center.getWorld() + "," + center.getBlockX() + "," + center.getBlockY() + "," + center.getBlockZ();
name = center.getWorld().getName() + "," + center.getBlockX() + "," + center.getBlockY() + "," + center.getBlockZ();
}
@SuppressWarnings("unchecked unused")
@ -90,8 +96,8 @@ public class Replicator implements ConfigurationSerializable
{
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);
owners = (HashSet<String>) map.get(keyOwners);
users = (HashSet<String>) map.get(keyUsers);
allReplicators.put(center, this);
}
@ -101,38 +107,50 @@ public class Replicator implements ConfigurationSerializable
}
}
public ArrayList<String> getOwners()
public HashSet<String> getOwners()
{
return owners;
}
public ArrayList<String> getUsers()
public HashSet<String> getUsers()
{
return users;
}
public void addUser( String user )
public void addUser( String user, String player )
{
this.users.add(user);
Replicator.saveReplicators(player);
}
public void addOwner( String owner )
public void addOwner( String owner, String player )
{
this.users.add(owner);
this.owners.add(owner);
Replicator.saveReplicators(player);
}
public boolean rmUser( String user )
public boolean rmUser( String user, String player )
{
if ( this.users.remove(user) )
{
Replicator.saveReplicators(player);
return true;
}
else
return false;
}
public boolean rmOwner( String owner )
public boolean rmOwner( String owner, String player )
{
if ( this.owners.remove(owner) )
{
if(owners.isEmpty())
{
allReplicators.remove(this.center);
}
Replicator.saveReplicators(player);
return true;
}
else
return false;
}
@ -141,7 +159,7 @@ public class Replicator implements ConfigurationSerializable
{
for ( String owner : owners )
{
if ( owner.equals(player) )
if ( owner.equalsIgnoreCase(player) )
{
return true;
}
@ -153,7 +171,7 @@ public class Replicator implements ConfigurationSerializable
{
for ( String user : users )
{
if ( user.equals(player) )
if ( user.equalsIgnoreCase(player) )
{
return true;
}
@ -172,7 +190,16 @@ public class Replicator implements ConfigurationSerializable
return name;
}
public static ArrayList<Location> getReplicators( Location currentBlock )
public boolean isUsable(String player)
{
if ( this.isOwner(player) || this.isUser(player) )
{
return true;
}
return false;
}
public static ArrayList<Location> getReplicatorLocations(Location currentBlock)
{
//mochaccino.sendMessage("Hello Mochaccino!");
ArrayList<Location> replicators = new ArrayList<Location>();
@ -216,7 +243,7 @@ public class Replicator implements ConfigurationSerializable
private static boolean isValid( Location center )
{
Material[][][] pattern = getPattern(center);
mochaccino.sendMessage("Direction: "+getDirection(center));
//mochaccino.sendMessage("Direction: "+getDirection(center));
if ( pattern == null )
{
return false;
@ -227,17 +254,17 @@ public class Replicator implements ConfigurationSerializable
{
for ( int z = 0; z <= 2; z++ )
{
mochaccino.sendMessage("Expected "+pattern[x][y][z]+", found "+center.getBlock().getRelative(x - 1, y - 1, z - 1).getType()+" at "+x+","+y+","+z+".");
//mochaccino.sendMessage("Expected "+pattern[x][y][z]+", found "+center.getBlock().getRelative(x - 1, y - 1, z - 1).getType()+" at "+x+","+y+","+z+".");
if ( ( pattern[x][y][z] != center.getBlock().getRelative(x - 1, y - 1, z - 1).getType() ) &&
( ( pattern[x][y][z] != null ) ) )
{
mochaccino.sendMessage("Pattern don't match.");
//mochaccino.sendMessage("Pattern don't match.");
return false;
}
}
}
}
mochaccino.sendMessage("Pattern matched.");
//mochaccino.sendMessage("Pattern matched.");
return true;
}
@ -255,7 +282,7 @@ public class Replicator implements ConfigurationSerializable
if ( nextBlock.getBlock().getType().equals(Pattern.getCenter()) )
{
centers.add(nextBlock);
mochaccino.sendMessage(nextBlock.getBlock().getType()+" found at "+nextBlock.getBlockX()+","+nextBlock.getBlockY()+","+nextBlock.getBlockZ());
//mochaccino.sendMessage(nextBlock.getBlock().getType()+" found at "+nextBlock.getBlockX()+","+nextBlock.getBlockY()+","+nextBlock.getBlockZ());
}
}
}
@ -268,17 +295,17 @@ public class Replicator implements ConfigurationSerializable
* Returns null if player is not owner or user of the replicator.
*
* @param loc center of the replicator
* @param playerName name of the player
* @param player the player entity
* @return Replicator
*/
public static Replicator getOrCreate( Location loc, String playerName )
public static Replicator getOrCreate( Location loc, Player player )
{
Replicator rep = allReplicators.get(loc);
// replicator already exists
if ( rep != null )
{
if ( rep.isOwner(playerName) || rep.isUser(playerName) )
if ( rep.isOwner(player.getName()) || rep.isUser(player.getName()) )
{
return rep;
}
@ -290,20 +317,56 @@ public class Replicator implements ConfigurationSerializable
// replicator does not exist, create one
else
{
rep = new Replicator(playerName, loc);
rep = new Replicator(player.getName(), 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());
}
player.sendMessage(Messages.newReplicator(rep));
Replicator.saveReplicators(player.getName());
return rep;
}
}
/**
* Returns all Replicators, which includes the Block at Location loc.
* @param loc Location of the current Block
* @return ArrayList of Replicators
*/
public static ArrayList<Replicator> getReplicators(Location loc)
{
ArrayList<Location> locs = getReplicatorLocations(loc);
ArrayList<Replicator> reps = new ArrayList<Replicator>();
for(Location center:locs)
{
if(allReplicators.get(center)!=null)
reps.add(allReplicators.get(center));
}
return reps;
}
public static ArrayList<Replicator> getUsableReplicators(Location loc, String player)
{
ArrayList<Location> locs = getReplicatorLocations(loc);
ArrayList<Replicator> reps = new ArrayList<Replicator>();
for(Location center:locs)
{
Replicator rep = allReplicators.get(center);
if(rep!=null&&rep.isUsable(player))
reps.add(rep);
}
return reps;
}
public static ArrayList<Replicator> getOwnReplicators(Location loc, String player)
{
ArrayList<Location> locs = getReplicatorLocations(loc);
ArrayList<Replicator> reps = new ArrayList<Replicator>();
for(Location center:locs)
{
Replicator rep = allReplicators.get(center);
if(rep!=null&&rep.isOwner(player))
reps.add(rep);
}
return reps;
}
/**
* Get a replicator with the specified name. Returns null if player
* is not owner or user or if replicator does not exist.
@ -318,7 +381,7 @@ public class Replicator implements ConfigurationSerializable
{
if ( rep.getName().equals(repName) )
{
if ( rep.isOwner(playerName) || rep.isUser(playerName) )
if(rep.isUsable(playerName))
{
return rep;
}
@ -347,6 +410,7 @@ public class Replicator implements ConfigurationSerializable
{
if ( rep.isUser(playerName) )
{
//mochaccino.sendMessage("You are User for "+rep.getName());
reps.add(rep);
}
}
@ -371,9 +435,16 @@ public class Replicator implements ConfigurationSerializable
replicatorsFileConf.getList(keyReplicators);
}
public static void saveReplicators() throws IOException
public static void saveReplicators(String playerName)
{
try {
replicatorsFileConf.set(keyReplicators, new ArrayList<Object>(allReplicators.values()));
replicatorsFileConf.save(replicatorsFile);
}
catch ( IOException e )
{
Plugin.instance.getServer().getPlayer(playerName).sendMessage(Messages.couldNotSave);
Plugin.instance.getLogger().severe("Could not save replicators to file: " + e.getMessage());
}
}
}