summaryrefslogtreecommitdiffstats
path: root/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatWorker.java
diff options
context:
space:
mode:
authorZenexer <Zenexer@e251c2fe-e539-e718-e476-b85c1f46cddb>2011-03-30 04:03:21 +0000
committerZenexer <Zenexer@e251c2fe-e539-e718-e476-b85c1f46cddb>2011-03-30 04:03:21 +0000
commit71c5e8c54eb51e8eb8176f807a6205abdd02f5ae (patch)
tree1c750b9fa65224abc02ba4db9b569bba979fa5d1 /EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatWorker.java
downloadEssentials-71c5e8c54eb51e8eb8176f807a6205abdd02f5ae.tar
Essentials-71c5e8c54eb51e8eb8176f807a6205abdd02f5ae.tar.gz
Essentials-71c5e8c54eb51e8eb8176f807a6205abdd02f5ae.tar.lz
Essentials-71c5e8c54eb51e8eb8176f807a6205abdd02f5ae.tar.xz
Essentials-71c5e8c54eb51e8eb8176f807a6205abdd02f5ae.zip
2.1 prerelease, part 2 of 3
git-svn-id: https://svn.java.net/svn/essentials~svn/trunk2.1@1015 e251c2fe-e539-e718-e476-b85c1f46cddb
Diffstat (limited to 'EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatWorker.java')
-rw-r--r--EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatWorker.java122
1 files changed, 122 insertions, 0 deletions
diff --git a/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatWorker.java b/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatWorker.java
new file mode 100644
index 000000000..e11504259
--- /dev/null
+++ b/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatWorker.java
@@ -0,0 +1,122 @@
+package com.earth2me.essentials.chat;
+
+import com.earth2me.essentials.Essentials;
+import com.earth2me.essentials.User;
+import com.nijikokun.bukkit.Permissions.Permissions;
+import java.util.logging.Logger;
+import org.bukkit.Location;
+import org.bukkit.Server;
+import org.bukkit.entity.Player;
+import org.bukkit.event.player.PlayerChatEvent;
+import org.bukkit.event.player.PlayerEvent;
+import org.bukkit.event.player.PlayerRespawnEvent;
+
+
+public class EssentialsChatWorker
+{
+ private static final Logger logger = Logger.getLogger("Minecraft");
+
+ public static void onPlayerRespawn(Server server, PlayerRespawnEvent event)
+ {
+ User user = User.get(event.getPlayer());
+ updateDisplayName(user);
+ }
+
+ public static void onPlayerJoin(Server server, PlayerEvent event)
+ {
+ User user = User.get(event.getPlayer());
+ updateDisplayName(user);
+ }
+
+ private static void updateDisplayName(User user)
+ {
+ try
+ {
+ String group = user.getGroup();
+ try
+ {
+ String prefix = Permissions.Security.getGroupPrefix(user.getWorld().getName(), group).replace('&', '§').replace("{WORLDNAME}", user.getWorld().getName());
+ String suffix = Permissions.Security.getGroupSuffix(user.getWorld().getName(), group).replace('&', '§').replace("{WORLDNAME}", user.getWorld().getName());
+ user.setDisplayName(prefix + user.getNick() + suffix + (suffix.endsWith("§f") ? "" : "§f"));
+ }
+ catch (Throwable ex)
+ {
+ logger.warning("Missing a prefix or suffix for " + group);
+ }
+ }
+ catch (Throwable ex)
+ {
+ logger.warning("Missing Permissions/GroupManager; chat prefixes/suffixes will be disabled.");
+ }
+ }
+
+ public static void onPlayerChat(Server server, PlayerChatEvent event)
+ {
+ User user = User.get(event.getPlayer());
+ updateDisplayName(user);
+
+ if (user.isAuthorized("essentials.chat.color"))
+ event.setMessage(event.getMessage().replaceAll("&([0-9a-f])", "§$1"));
+
+ event.setFormat(Essentials.getSettings().getChatFormat(user.getGroup())
+ .replace('&', '§')
+ .replace("§§", "&")
+ .replace("{DISPLAYNAME}", "%1$s")
+ .replace("{GROUP}", user.getGroup())
+ .replace("{MESSAGE}", "%2$s")
+ .replace("{WORLDNAME}", user.getWorld().getName()));
+
+ int radius = Essentials.getSettings().getChatRadius();
+ if (radius < 1) return;
+
+ if (event.getMessage().startsWith("!") && event.getMessage().length() > 1)
+ {
+ if (user.isAuthorized("essentials.chat.shout"))
+ {
+ event.setMessage(event.getMessage().substring(1));
+ event.setFormat("§7[Shout]§f " + event.getFormat());
+ return;
+ }
+ user.sendMessage("§cYou are not authorized to shout.");
+ event.setCancelled(true);
+ return;
+ }
+
+ if (event.getMessage().startsWith("?") && event.getMessage().length() > 1)
+ {
+ if (user.isAuthorized("essentials.chat.question"))
+ {
+ event.setMessage(event.getMessage().substring(1));
+ event.setFormat("§7[Question]§f " + event.getFormat());
+ return;
+ }
+ user.sendMessage("§cYou are not authorized to use question.");
+ event.setCancelled(true);
+ return;
+ }
+
+ event.setCancelled(true);
+ logger.info("Local: <" + user.getName() + "> " + event.getMessage());
+
+ Location loc = user.getLocation();
+ int x = loc.getBlockX();
+ int y = loc.getBlockY();
+ int z = loc.getBlockZ();
+
+ for (Player p : server.getOnlinePlayers())
+ {
+ User u = User.get(p);
+ if (u != user && !u.isAuthorized("essentials.chat.spy"))
+ {
+ Location l = u.getLocation();
+ int dx = Math.abs(x - l.getBlockX());
+ int dy = Math.abs(y - l.getBlockY());
+ int dz = Math.abs(z - l.getBlockZ());
+ int delta = dx + dy + dz;
+ if (delta > radius) continue;
+ }
+
+ u.sendMessage(String.format(event.getFormat(), user.getDisplayName(), event.getMessage()));
+ }
+ }
+}