package com.earth2me.essentials.chat; import com.earth2me.essentials.ChargeException; import static com.earth2me.essentials.I18n._; import com.earth2me.essentials.IEssentials; import com.earth2me.essentials.Trade; import com.earth2me.essentials.User; import java.util.Map; import java.util.logging.Level; import java.util.logging.Logger; import org.bukkit.Location; import org.bukkit.Server; import org.bukkit.World; import org.bukkit.entity.Player; import org.bukkit.event.Listener; import org.bukkit.event.player.AsyncPlayerChatEvent; //TODO: Translate the local/spy tags public abstract class EssentialsChatPlayer implements Listener { protected transient IEssentials ess; protected final static Logger logger = Logger.getLogger("Minecraft"); protected final transient Map listeners; protected final transient Server server; protected final transient Map chatStorage; public EssentialsChatPlayer(final Server server, final IEssentials ess, final Map listeners, final Map chatStorage) { this.ess = ess; this.listeners = listeners; this.server = server; this.chatStorage = chatStorage; } public void onPlayerChat(final AsyncPlayerChatEvent event) { } public boolean isAborted(final AsyncPlayerChatEvent event) { if (event.isCancelled()) { return true; } synchronized (listeners) { for (Map.Entry listener : listeners.entrySet()) { try { if (listener.getValue().shouldHandleThisChat(event)) { return true; } } catch (Throwable t) { if (ess.getSettings().isDebug()) { logger.log(Level.WARNING, "Error with EssentialsChat listener of " + listener.getKey() + ": " + t.getMessage(), t); } else { logger.log(Level.WARNING, "Error with EssentialsChat listener of " + listener.getKey() + ": " + t.getMessage()); } } } } return false; } public String getChatType(final String message) { switch (message.charAt(0)) { case '!': return "shout"; case '?': return "question"; //case '@': //return "admin"; default: return ""; } } public ChatStore getChatStore(final AsyncPlayerChatEvent event) { return chatStorage.get(event); } public void setChatStore(final AsyncPlayerChatEvent event, final ChatStore chatStore) { chatStorage.put(event, chatStore); } public ChatStore delChatStore(final AsyncPlayerChatEvent event) { return chatStorage.remove(event); } protected void charge(final User user, final Trade charge) throws ChargeException { charge.charge(user); } protected boolean charge(final AsyncPlayerChatEvent event, final ChatStore chatStore) { try { charge(chatStore.getUser(), chatStore.getCharge()); } catch (ChargeException e) { ess.showError(chatStore.getUser(), e, chatStore.getLongType()); event.setCancelled(true); return false; } return true; } protected void sendLocalChat(final AsyncPlayerChatEvent event, final ChatStore chatStore) { event.setCancelled(true); final User sender = chatStore.getUser(); logger.info(_("localFormat", sender.getName(), event.getMessage())); final Location loc = sender.getLocation(); final World world = loc.getWorld(); if (charge(event, chatStore) == false) { return; } for (Player onlinePlayer : server.getOnlinePlayers()) { String type = _("chatTypeLocal"); final User onlineUser = ess.getUser(onlinePlayer); if (onlineUser.isIgnoredPlayer(sender)) { continue; } if (!onlineUser.equals(sender)) { boolean abort = false; final Location playerLoc = onlineUser.getLocation(); if (playerLoc.getWorld() != world) { abort = true; } else { final double delta = playerLoc.distanceSquared(loc); if (delta > chatStore.getRadius()) { abort = true; } } if (abort) { if (onlineUser.isAuthorized("essentials.chat.spy")) { type = type.concat(_("chatTypeSpy")); } else { continue; } } } String message = type.concat(String.format(event.getFormat(), sender.getDisplayName(), event.getMessage())); synchronized (listeners) { for (Map.Entry listener : listeners.entrySet()) { try { message = listener.getValue().modifyMessage(event, onlinePlayer, message); } catch (Throwable t) { if (ess.getSettings().isDebug()) { logger.log(Level.WARNING, "Error with EssentialsChat listener of " + listener.getKey() + ": " + t.getMessage(), t); } else { logger.log(Level.WARNING, "Error with EssentialsChat listener of " + listener.getKey() + ": " + t.getMessage()); } } } } onlineUser.sendMessage(message); } } }