diff options
-rw-r--r-- | EssentialsXMPP/src/com/earth2me/essentials/xmpp/Commandxmpp.java | 2 | ||||
-rw-r--r-- | EssentialsXMPP/src/com/earth2me/essentials/xmpp/XMPPManager.java | 43 | ||||
-rw-r--r-- | EssentialsXMPP/src/plugin.yml | 8 |
3 files changed, 29 insertions, 24 deletions
diff --git a/EssentialsXMPP/src/com/earth2me/essentials/xmpp/Commandxmpp.java b/EssentialsXMPP/src/com/earth2me/essentials/xmpp/Commandxmpp.java index 49aa2a6ea..d78782f12 100644 --- a/EssentialsXMPP/src/com/earth2me/essentials/xmpp/Commandxmpp.java +++ b/EssentialsXMPP/src/com/earth2me/essentials/xmpp/Commandxmpp.java @@ -23,7 +23,6 @@ public class Commandxmpp extends EssentialsCommand throw new NotEnoughArgumentsException(); } - final String message = getFinalArg(args, 1); final String address = EssentialsXMPP.getInstance().getAddress(args[0]); if (address == null) { @@ -31,6 +30,7 @@ public class Commandxmpp extends EssentialsCommand } else { + final String message = getFinalArg(args, 1); final String senderName = sender instanceof Player ? ess.getUser(sender).getDisplayName() : Console.NAME; sender.sendMessage("[" + senderName + ">" + address + "] " + message); EssentialsXMPP.getInstance().sendMessage(address, "[" + senderName + "] " + message); diff --git a/EssentialsXMPP/src/com/earth2me/essentials/xmpp/XMPPManager.java b/EssentialsXMPP/src/com/earth2me/essentials/xmpp/XMPPManager.java index e9da61440..c92365c44 100644 --- a/EssentialsXMPP/src/com/earth2me/essentials/xmpp/XMPPManager.java +++ b/EssentialsXMPP/src/com/earth2me/essentials/xmpp/XMPPManager.java @@ -51,28 +51,20 @@ public class XMPPManager extends Handler implements MessageListener, ChatManager public void sendMessage(final String address, final String message) { - Chat chat = null; - try + if (address != null && !address.isEmpty()) { - if (address == null || address.isEmpty()) - { - return; - } - startChat(address); - chat = chats.get(address); - if (chat == null) + try { - return; + startChat(address); + final Chat chat = chats.get(address); + if (chat != null) + { + chat.sendMessage(message.replaceAll("§[0-9a-f]", "")); + } } - chat.sendMessage(message.replaceAll("§[0-9a-f]", "")); - } - catch (XMPPException ex) - { - if (chat != null) + catch (XMPPException ex) { - chat.removeMessageListener(this); - chats.remove(address); - LOGGER.log(Level.WARNING, "Failed to send xmpp message.", ex); + disableChat(address, ex); } } } @@ -260,7 +252,9 @@ public class XMPPManager extends Handler implements MessageListener, ChatManager { LOGGER.log(Level.WARNING, "Failed to send xmpp message.", ex); } - } else { + } + else + { for (Player p : matches) { p.sendMessage("[" + chat.getParticipant() + ">" + p.getDisplayName() + "] " + message); @@ -280,4 +274,15 @@ public class XMPPManager extends Handler implements MessageListener, ChatManager } } } + + private void disableChat(final String address, final XMPPException exception) + { + final Chat chat = chats.get(address); + if (chat != null) + { + chat.removeMessageListener(this); + chats.remove(address); + LOGGER.log(Level.WARNING, "Failed to send xmpp message.", exception); + } + } } diff --git a/EssentialsXMPP/src/plugin.yml b/EssentialsXMPP/src/plugin.yml index 3ccc0b55e..a193ba95f 100644 --- a/EssentialsXMPP/src/plugin.yml +++ b/EssentialsXMPP/src/plugin.yml @@ -11,10 +11,10 @@ depend: [Essentials] commands: setxmpp: description: set your xmpp address - usage: /<command> address + usage: /<command> <address> xmpp: description: send a message to a player - usage: /<command> player message + usage: /<command> <player> <message> xmppspy: - description: toggle xmpp spy for all message - usage: /<command> player
\ No newline at end of file + description: toggle xmpp spy for all messages + usage: /<command> <player>
\ No newline at end of file |