24 |
import org.bukkit.event.Listener; |
import org.bukkit.event.Listener; |
25 |
import org.bukkit.event.block.Action; |
import org.bukkit.event.block.Action; |
26 |
import org.bukkit.event.block.BlockBreakEvent; |
import org.bukkit.event.block.BlockBreakEvent; |
27 |
|
import org.bukkit.event.block.BlockBurnEvent; |
28 |
import org.bukkit.event.block.BlockPlaceEvent; |
import org.bukkit.event.block.BlockPlaceEvent; |
29 |
import org.bukkit.event.entity.EntityExplodeEvent; |
import org.bukkit.event.entity.EntityExplodeEvent; |
30 |
import org.bukkit.event.inventory.InventoryCloseEvent; |
import org.bukkit.event.inventory.InventoryCloseEvent; |
77 |
|
|
78 |
if (args.length == 0) { |
if (args.length == 0) { |
79 |
player.sendMessage("Usage:"); |
player.sendMessage("Usage:"); |
80 |
player.sendMessage("/chest (status|lock|snitch|remove|addplayer|removeplayer) [player]"); |
player.sendMessage("/chest (status|lock|snitch|remove|addplayer|removeplayer|setowner|comment) [player]"); |
81 |
return true; |
return true; |
82 |
} |
} |
83 |
|
|
111 |
|
|
112 |
player.sendMessage(ChatColor.GREEN + "Chest is a " + mode + " chest owned by " + chest.getOwner()); |
player.sendMessage(ChatColor.GREEN + "Chest is a " + mode + " chest owned by " + chest.getOwner()); |
113 |
player.sendMessage(ChatColor.GREEN + "Allowed players: " + chest.getModifyPlayers() ); |
player.sendMessage(ChatColor.GREEN + "Allowed players: " + chest.getModifyPlayers() ); |
114 |
|
player.sendMessage(ChatColor.GREEN + "Comment: " + chest.getComment() ); |
115 |
} else { |
} else { |
116 |
player.sendMessage(ChatColor.GREEN + "The chest is not protected"); |
player.sendMessage(ChatColor.GREEN + "The chest is not protected"); |
117 |
} |
} |
133 |
modeStr = "snitching"; |
modeStr = "snitching"; |
134 |
} |
} |
135 |
chest.setModifyPlayers(""); |
chest.setModifyPlayers(""); |
136 |
|
chest.setComment(""); |
137 |
addChest(loc, chest); |
addChest(loc, chest); |
138 |
player.sendMessage("Chest is now " + modeStr); |
player.sendMessage("Chest is now " + modeStr); |
139 |
} else { |
} else { |
140 |
|
server.getLogger().info( player.getName() + " tried to protect a chest owned by " + chest.getOwner() ); |
141 |
player.sendMessage("This chest is already protected"); |
player.sendMessage("This chest is already protected"); |
142 |
} |
} |
143 |
return true; |
return true; |
144 |
} |
} |
145 |
|
|
146 |
if (cmd.equals("remove")) { |
if (cmd.equals("remove")) { |
147 |
|
if (chest == null) { |
148 |
|
player.sendMessage("This chest is not protected"); |
149 |
|
return true; |
150 |
|
} |
151 |
if (! chest.getOwner().equals( player.getName() ) ) { |
if (! chest.getOwner().equals( player.getName() ) ) { |
152 |
player.sendMessage("You can not remove lock from a chest you don't own"); |
player.sendMessage("You can not remove lock from a chest you don't own"); |
153 |
|
server.getLogger().info( player.getName() + " tried to remove protection froma chest owned by " + chest.getOwner() ); |
154 |
return true; |
return true; |
155 |
} |
} |
156 |
if (chest != null) { |
|
157 |
player.sendMessage("[LockedChest] Removing protection from chest"); |
player.sendMessage("[LockedChest] Removing protection from chest"); |
158 |
removeChest(loc); |
removeChest(loc); |
159 |
} else { |
|
160 |
player.sendMessage("This chest is not protected"); |
return true; |
161 |
|
} |
162 |
|
|
163 |
|
if (cmd.equals("setowner")) { |
164 |
|
if (chest == null) { |
165 |
|
player.sendMessage("This chest is not protected"); |
166 |
|
return true; |
167 |
|
} |
168 |
|
if (! chest.getOwner().equals( player.getName() ) ) { |
169 |
|
player.sendMessage("You can not set new owner of a chest you dont own"); |
170 |
|
server.getLogger().info( player.getName() + " tried to set owner on a chest owned by " + chest.getOwner() ); |
171 |
|
return true; |
172 |
|
} |
173 |
|
if (args.length != 2) { |
174 |
|
player.sendMessage("You need to specify which player should own this chest"); |
175 |
|
return true; |
176 |
|
} |
177 |
|
OfflinePlayer p2 = server.getOfflinePlayer(args[1]); |
178 |
|
if ( p2.hasPlayedBefore() == false && p2.isOnline() == false) { |
179 |
|
player.sendMessage("Unknown user: " + args[1] ); |
180 |
|
return true; |
181 |
} |
} |
182 |
|
chest.setOwner( p2.getName() ); |
183 |
|
plugin.getDatabase().save( chest ); |
184 |
|
player.sendMessage("ok"); |
185 |
return true; |
return true; |
186 |
} |
} |
187 |
|
|
192 |
} |
} |
193 |
if (! chest.getOwner().equals( player.getName() ) ) { |
if (! chest.getOwner().equals( player.getName() ) ) { |
194 |
player.sendMessage("You can not add/remove players from a chest you don't own"); |
player.sendMessage("You can not add/remove players from a chest you don't own"); |
195 |
|
server.getLogger().info( player.getName() + " tried to add/remove player on a chest owned by " + chest.getOwner() ); |
196 |
return true; |
return true; |
197 |
} |
} |
198 |
if (args.length != 2) { |
if (args.length != 2) { |
217 |
player.sendMessage("ok"); |
player.sendMessage("ok"); |
218 |
return true; |
return true; |
219 |
} |
} |
220 |
|
if (cmd.equals("comment")) { |
221 |
|
if (chest == null) { |
222 |
|
player.sendMessage("This chest is not protected"); |
223 |
|
return true; |
224 |
|
} |
225 |
|
if (! chest.getOwner().equals( player.getName() ) ) { |
226 |
|
player.sendMessage("You can not comment a chest you don't own"); |
227 |
|
server.getLogger().info( player.getName() + " tried to comment on a chest owned by " + chest.getOwner() ); |
228 |
|
return true; |
229 |
|
} |
230 |
|
|
231 |
|
StringBuilder sb = new StringBuilder(); |
232 |
|
for (int i=1; i<args.length; i++) { |
233 |
|
sb.append(args[i]).append(" "); |
234 |
|
} |
235 |
|
String comment = sb.toString().trim(); |
236 |
|
|
237 |
|
chest.setComment( comment ); |
238 |
|
plugin.getDatabase().save( chest ); |
239 |
|
player.sendMessage("Comment set"); |
240 |
|
|
241 |
|
return true; |
242 |
|
} |
243 |
|
|
244 |
/* |
/* |
245 |
if (chest != null) { |
if (chest != null) { |
280 |
} else { |
} else { |
281 |
event.setCancelled(true); |
event.setCancelled(true); |
282 |
event.getPlayer().sendMessage("You can't destroy that chest"); |
event.getPlayer().sendMessage("You can't destroy that chest"); |
283 |
server.getLogger().info( "[AdvancedChest] " + event.getPlayer().getName() + " tried breaking a chest owned by " + chest.getOwner() ); |
server.getLogger().info( "[AdvancedChest] " + event.getPlayer().getName() + " tried breaking a chest owned by " + chest.getOwner() + chest.getCommentString() ); |
284 |
} |
} |
285 |
} |
} |
286 |
} |
} |
430 |
for (Block b : event.blockList() ) { |
for (Block b : event.blockList() ) { |
431 |
ChestBean chest = chestMap.get( b.getLocation() ); |
ChestBean chest = chestMap.get( b.getLocation() ); |
432 |
if (chest != null) { |
if (chest != null) { |
433 |
server.getLogger().info( "[AdvancedChest] Prevented an explosion from destroying chest owned by " + chest.getOwner() ); |
server.getLogger().info( "[AdvancedChest] Prevented an explosion from destroying chest owned by " + chest.getOwner() + chest.getCommentString() ); |
434 |
event.setCancelled( true ); |
event.setCancelled( true ); |
435 |
return; |
return; |
436 |
} |
} |
437 |
} |
} |
438 |
} |
} |
439 |
|
|
440 |
|
@EventHandler |
441 |
|
public void onChestBurn(BlockBurnEvent event) { |
442 |
|
ChestBean chest = chestMap.get( event.getBlock().getLocation() ); |
443 |
|
if (chest != null) { |
444 |
|
server.getLogger().info( "[AdvancedChest] prevented a fire from destrying chest owned by " + chest.getOwner() + chest.getCommentString() ); |
445 |
|
event.setCancelled( true); |
446 |
|
} |
447 |
|
} |
448 |
|
|
449 |
// prevent a user from opening a chest |
// prevent a user from opening a chest |
450 |
@EventHandler |
@EventHandler |
470 |
return; //chest is opened by it's owner |
return; //chest is opened by it's owner |
471 |
} |
} |
472 |
|
|
473 |
Set<String> players = Util.stringToSet( chest.getModifyPlayers() ); |
Set<String> players = chest.getModifyPlayersSet() ; |
474 |
if ( players.contains(player.getName()) ) { |
if ( players.contains(player.getName()) ) { |
475 |
return; //this player is on the whitelist so he may open |
return; //this player is on the whitelist so he may open |
476 |
} |
} |
477 |
|
|
478 |
|
|
479 |
server.getLogger().info( "[AdvancedChest] " + event.getPlayer().getName() + " tried opening a chest owned by " + chest.getOwner() ); |
server.getLogger().info( "[AdvancedChest] " + event.getPlayer().getName() + " tried opening a chest owned by " + chest.getOwner() + chest.getCommentString() ); |
480 |
player.sendMessage( ChatColor.BLUE + "Sorry but this chest is locked !"); |
player.sendMessage( ChatColor.BLUE + "Sorry but this chest is locked !"); |
481 |
event.setCancelled(true); |
event.setCancelled(true); |
482 |
} |
} |
511 |
return; //chest is owned by it's own player |
return; //chest is owned by it's own player |
512 |
} |
} |
513 |
|
|
514 |
Set<String> players = Util.stringToSet( chest.getModifyPlayers() ); |
Set<String> players = chest.getModifyPlayersSet(); |
515 |
if ( players.contains(player.getName()) ) { |
if ( players.contains(player.getName()) ) { |
516 |
return; //this player is on the whitelist so he may open |
return; //this player is on the whitelist so he may open |
517 |
} |
} |
518 |
|
|
519 |
|
|
520 |
|
server.getLogger().info( "[AdvancedChest] " + event.getPlayer().getName() + " opened a snitching chest owned by " + chest.getOwner() + chest.getCommentString() ); |
521 |
|
|
522 |
ItemCount contents = countItems( event.getInventory().getContents() ); |
ItemCount contents = countItems( event.getInventory().getContents() ); |
523 |
|
|
524 |
contentMap.put(player.getName(), contents ); |
contentMap.put(player.getName(), contents ); |