Mute fixed, re-enabled /minecraft:me except when muted, admin and mod channel added, links implemented

This commit is contained in:
Norbi Peti 2015-12-31 17:32:54 +01:00
parent 43ca6c1930
commit 29b3c8830a
12 changed files with 180 additions and 29 deletions

Binary file not shown.

View file

@ -23,5 +23,6 @@
</attributes> </attributes>
</classpathentry> </classpathentry>
<classpathentry kind="lib" path="D:/Downloads/htmlcleaner-2.16/htmlcleaner-2.16.jar"/> <classpathentry kind="lib" path="D:/Downloads/htmlcleaner-2.16/htmlcleaner-2.16.jar"/>
<classpathentry kind="lib" path="D:/Z - Norbi cucca/0 Projektek/TheButtonMCAutoFlairProto/Spigot server/plugins/_/PermissionsEx-1.23.3.jar"/>
<classpathentry kind="output" path="target/classes"/> <classpathentry kind="output" path="target/classes"/>
</classpath> </classpath>

View file

@ -14,4 +14,6 @@ public class Channel {
public static Channel GlobalChat = new Channel("§fg§f", "white", "g"); public static Channel GlobalChat = new Channel("§fg§f", "white", "g");
public static Channel TownChat = new Channel("§3TC§f", "dark_aqua", "tc"); public static Channel TownChat = new Channel("§3TC§f", "dark_aqua", "tc");
public static Channel NationChat = new Channel("§6NC§f", "gold", "nc"); public static Channel NationChat = new Channel("§6NC§f", "gold", "nc");
public static Channel AdminChat = new Channel("§cADMIN§f", "red", "a");
public static Channel ModChat = new Channel("§9MOD§f", "blue", "mod");
} }

View file

@ -19,6 +19,8 @@ import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.SkullMeta; import org.bukkit.inventory.meta.SkullMeta;
import org.bukkit.scoreboard.Objective; import org.bukkit.scoreboard.Objective;
import ru.tehkode.permissions.bukkit.PermissionsEx;
import com.palmergames.bukkit.towny.exceptions.NotRegisteredException; import com.palmergames.bukkit.towny.exceptions.NotRegisteredException;
import com.palmergames.bukkit.towny.object.Nation; import com.palmergames.bukkit.towny.object.Nation;
import com.palmergames.bukkit.towny.object.Resident; import com.palmergames.bukkit.towny.object.Resident;
@ -29,6 +31,8 @@ import au.com.mineauz.minigames.Minigames;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.Random; import java.util.Random;
@ -37,6 +41,8 @@ import java.util.TimerTask;
import java.util.UUID; import java.util.UUID;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import com.earth2me.essentials.*;
public class PlayerListener implements Listener { // 2015.07.16. public class PlayerListener implements Listener { // 2015.07.16.
public static HashMap<String, UUID> nicknames = new HashMap<>(); public static HashMap<String, UUID> nicknames = new HashMap<>();
@ -44,6 +50,9 @@ public class PlayerListener implements Listener { // 2015.07.16.
@EventHandler @EventHandler
public void onPlayerJoin(PlayerJoinEvent event) { public void onPlayerJoin(PlayerJoinEvent event) {
if (essentials == null)
essentials = ((Essentials) Bukkit.getPluginManager().getPlugin(
"Essentials"));
Player p = event.getPlayer(); Player p = event.getPlayer();
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
.getUniqueId()); .getUniqueId());
@ -122,13 +131,18 @@ public class PlayerListener implements Listener { // 2015.07.16.
nicknames.remove(deletenick); nicknames.remove(deletenick);
} }
public static String NotificationSound; // 2015.08.14. public static String NotificationSound;
public static double NotificationPitch; // 2015.08.14. public static double NotificationPitch;
public static boolean ShowRPTag = false; // 2015.08.31. public static boolean ShowRPTag = false;
private Essentials essentials = null;
@EventHandler @EventHandler
public void onPlayerChat(AsyncPlayerChatEvent event) { public void onPlayerChat(AsyncPlayerChatEvent event) {
if (essentials == null)
essentials = ((Essentials) Bukkit.getPluginManager().getPlugin(
"Essentials"));
if (event.getMessage().equalsIgnoreCase("F")) { if (event.getMessage().equalsIgnoreCase("F")) {
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(event MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(event
.getPlayer().getUniqueId()); .getPlayer().getUniqueId());
@ -143,31 +157,32 @@ public class PlayerListener implements Listener { // 2015.07.16.
boolean greentext = event.getMessage().startsWith(">"); boolean greentext = event.getMessage().startsWith(">");
if (event.getMessage().contains("lol")) if (event.getMessage().contains("lol"))
Commands.Lastlol = MaybeOfflinePlayer.AllPlayers.get(event Commands.Lastlol = MaybeOfflinePlayer.AllPlayers.get(event
.getPlayer().getUniqueId()); //TODO: Formatting after nicknames .getPlayer().getUniqueId());
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
.getPlayer().getUniqueId()); .getPlayer().getUniqueId());
String flair = player.GetFormattedFlair();
String message = event.getMessage(); // 2015.08.08. String message = event.getMessage(); // 2015.08.08.
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12. for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
String color = ""; // 2015.08.17. String color = ""; // 2015.08.17.
if (message.contains(p.getName())) { if (message.matches("(?i).*" + Pattern.quote(p.getName()) + ".*")) {
if (NotificationSound == null) if (NotificationSound == null)
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12. p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
else else
p.playSound(p.getLocation(), NotificationSound, 1.0f, p.playSound(p.getLocation(), NotificationSound, 1.0f,
(float) NotificationPitch); // 2015.08.14. (float) NotificationPitch); // 2015.08.14.
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
.getUniqueId()); // 2015.08.17. .getUniqueId());
color = String.format("§%x", (mp.GetFlairColor() == 0x00 ? 0xb color = String.format("§%x", (mp.GetFlairColor() == 0x00 ? 0xb
: mp.GetFlairColor())); // TODO: Quiz queue : mp.GetFlairColor())); // TODO: Quiz queue
} }
message = message.replaceAll("(?i)" + Pattern.quote(p.getName()), message = message.replaceAll(
"(?i)" + Pattern.quote(p.getName()),
color color
+ p.getName() + p.getName()
+ (event.getMessage().startsWith("§2>") ? "§2" + (greentext ? "§2"
: "§r")); : player.CurrentChannel.DisplayName
.substring(0, 2)));
} }
for (String n : nicknames.keySet()) { for (String n : nicknames.keySet()) {
Player p = null; Player p = null;
@ -183,7 +198,8 @@ public class PlayerListener implements Listener { // 2015.07.16.
while ((index = nwithoutformatting.indexOf('§')) != -1) while ((index = nwithoutformatting.indexOf('§')) != -1)
nwithoutformatting = nwithoutformatting.replace("§" nwithoutformatting = nwithoutformatting.replace("§"
+ nwithoutformatting.charAt(index + 1), ""); + nwithoutformatting.charAt(index + 1), "");
if (message.contains(nwithoutformatting)) { if (message.matches("(?i).*" + Pattern.quote(nwithoutformatting)
+ ".*")) {
p = Bukkit.getPlayer(nicknames.get(n)); p = Bukkit.getPlayer(nicknames.get(n));
if (NotificationSound == null) if (NotificationSound == null)
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12. p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
@ -194,27 +210,28 @@ public class PlayerListener implements Listener { // 2015.07.16.
} }
if (p != null) { if (p != null) {
message = message.replaceAll( message = message.replaceAll(
"(?i)" + Pattern.quote(nwithoutformatting), n "(?i)" + Pattern.quote(nwithoutformatting),
+ (event.getMessage().startsWith("§2>") ? "§2" n
: "§r")); + (greentext ? "§2"
: player.CurrentChannel.DisplayName
.substring(0, 2)));
} }
} }
event.setMessage(message); // 2015.09.05. event.setMessage(message);
event.setFormat(event /*
.getFormat() * event.setFormat(event .getFormat() .replace( "{rptag}",
.replace( * (player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "") : "§8[OOC]§r"))
"{rptag}", * .replace("{buttonflair}", flair) .replace( "{isitwilds}",
(player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "") * (event.getPlayer().getWorld().getName() .equalsIgnoreCase("wilds") ?
: "§8[OOC]§r")) * "[PVP]" : ""))); // 2015.09.04.
.replace("{buttonflair}", flair) */
.replace(
"{isitwilds}",
(event.getPlayer().getWorld().getName()
.equalsIgnoreCase("wilds") ? "[PVP]" : ""))); // 2015.09.04.
event.setCancelled(true); event.setCancelled(true);
if (essentials.getUser(event.getPlayer()).isMuted())
return;
StringBuilder json = new StringBuilder(); StringBuilder json = new StringBuilder();
json.append("[\"\","); json.append("[\"\",");
json.append(String.format("{\"text\":\"[%s]%s <\"},", json.append(String.format("{\"text\":\"[%s]%s <\"},",
@ -249,7 +266,7 @@ public class PlayerListener implements Listener { // 2015.07.16.
String original = event.getMessage().substring(index + 1, index2); String original = event.getMessage().substring(index + 1, index2);
list.add(original); list.add(original);
} }
String finalstring = event.getMessage().replace('"', '\''); String finalstring = event.getMessage().replace("\"", "''");
for (String original : list) for (String original : list)
// Hashtags // Hashtags
finalstring = finalstring finalstring = finalstring
@ -260,10 +277,31 @@ public class PlayerListener implements Listener { // 2015.07.16.
(greentext ? "dark_green" (greentext ? "dark_green"
: player.CurrentChannel.Color), : player.CurrentChannel.Color),
original, original)); original, original));
String[] parts = finalstring.split("\\s+");
// URLs
for (String item : parts)
try {
URL url = new URL(item);
finalstring = finalstring
.replace(
item,
String.format(
"\",\"color\":\"%s\"},{\"text\":\"%s\",\"color\":\"%s\",\"underlined\":\"true\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open URL\",\"color\":\"blue\"}]}}},{\"text\":\"",
(greentext ? "dark_green"
: player.CurrentChannel.Color),
url, (greentext ? "dark_green"
: player.CurrentChannel.Color),
url));
} catch (MalformedURLException e) {
}
json.append(String.format("{\"text\":\"%s\",\"color\":\"%s\"}]", json.append(String.format("{\"text\":\"%s\",\"color\":\"%s\"}]",
finalstring, (greentext ? "dark_green" finalstring, (greentext ? "dark_green"
: player.CurrentChannel.Color))); : player.CurrentChannel.Color)));
if (!player.CurrentChannel.equals(Channel.GlobalChat)) if (player.CurrentChannel.equals(Channel.TownChat)
|| player.CurrentChannel.equals(Channel.NationChat))
// for (Resident resident : // for (Resident resident :
// PluginMain.Instance.TU.getResidentMap().values()) { // PluginMain.Instance.TU.getResidentMap().values()) {
for (Player p : PluginMain.GetPlayers()) { for (Player p : PluginMain.GetPlayers()) {
@ -305,7 +343,9 @@ public class PlayerListener implements Listener { // 2015.07.16.
Objective obj = PluginMain.SB.getObjective("town"); Objective obj = PluginMain.SB.getObjective("town");
// System.out.println("obj: " + obj); // System.out.println("obj: " + obj);
for (Player p : PluginMain.GetPlayers()) { for (Player p : PluginMain.GetPlayers()) {
//System.out.println(town.getName()); // System.out.println(town.getName()); //Mute fixed,
// re-enabled /minecraft:me except when muted, admin and mod
// channel added, links implemented
try { try {
if (PluginMain.Instance.TU.getResidentMap() if (PluginMain.Instance.TU.getResidentMap()
.get(p.getName().toLowerCase()).getTown() .get(p.getName().toLowerCase()).getTown()
@ -397,6 +437,72 @@ public class PlayerListener implements Listener { // 2015.07.16.
"§cAn error occured while sending the message. (IllegalArgumentException)"); "§cAn error occured while sending the message. (IllegalArgumentException)");
return; return;
} }
} else if (player.CurrentChannel.equals(Channel.AdminChat)) {
try {
if (!event.getPlayer().isOp()) {
event.getPlayer().sendMessage(
"§cYou need to be an OP to use this channel.");
return;
}
Objective obj = PluginMain.SB.getObjective("admin");
for (Player p : PluginMain.GetPlayers()) {
if (p.isOp())
obj.getScore(p.getName()).setScore(1);
else
obj.getScore(p.getName()).setScore(0);
}
PluginMain.Instance
.getServer()
.dispatchCommand(
PluginMain.Console,
String.format(
"tellraw @a[score_admin=%d,score_admin_min=%d] %s",
1, 1, json.toString()));
} catch (IllegalStateException e) {
e.printStackTrace();
event.getPlayer()
.sendMessage(
"§cAn error occured while sending the message. (IllegalStateException)");
return;
} catch (IllegalArgumentException e) {
e.printStackTrace();
event.getPlayer()
.sendMessage(
"§cAn error occured while sending the message. (IllegalArgumentException)");
return;
}
} else if (player.CurrentChannel.equals(Channel.ModChat)) {
try {
if (!PermissionsEx.getUser(event.getPlayer()).inGroup("mod")) {
event.getPlayer().sendMessage(
"§cYou need to be a mod to use this channel.");
return;
}
Objective obj = PluginMain.SB.getObjective("mod");
for (Player p : PluginMain.GetPlayers()) {
if (PermissionsEx.getUser(p).inGroup("mod"))
obj.getScore(p.getName()).setScore(1);
else
obj.getScore(p.getName()).setScore(0);
}
PluginMain.Instance.getServer().dispatchCommand(
PluginMain.Console,
String.format(
"tellraw @a[score_mod=%d,score_mod_min=%d] %s",
1, 1, json.toString()));
} catch (IllegalStateException e) {
e.printStackTrace();
event.getPlayer()
.sendMessage(
"§cAn error occured while sending the message. (IllegalStateException)");
return;
} catch (IllegalArgumentException e) {
e.printStackTrace();
event.getPlayer()
.sendMessage(
"§cAn error occured while sending the message. (IllegalArgumentException)");
return;
}
} else } else
PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console, PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console,
String.format("tellraw @a %s", json.toString())); String.format("tellraw @a %s", json.toString()));
@ -444,6 +550,24 @@ public class PlayerListener implements Listener { // 2015.07.16.
"§6You are now talking in: §b" "§6You are now talking in: §b"
+ mp.CurrentChannel.DisplayName); + mp.CurrentChannel.DisplayName);
event.setCancelled(true); event.setCancelled(true);
} else if (cmd.equalsIgnoreCase(Channel.AdminChat.Command)) {
if (mp.CurrentChannel.equals(Channel.AdminChat))
mp.CurrentChannel = Channel.GlobalChat;
else
mp.CurrentChannel = Channel.AdminChat;
event.getPlayer().sendMessage(
"§6You are now talking in: §b"
+ mp.CurrentChannel.DisplayName);
event.setCancelled(true);
} else if (cmd.equalsIgnoreCase(Channel.ModChat.Command)) {
if (mp.CurrentChannel.equals(Channel.ModChat))
mp.CurrentChannel = Channel.GlobalChat;
else
mp.CurrentChannel = Channel.ModChat;
event.getPlayer().sendMessage(
"§6You are now talking in: §b"
+ mp.CurrentChannel.DisplayName);
event.setCancelled(true);
} }
} else { } else {
String cmd = event.getMessage().substring(1, index); String cmd = event.getMessage().substring(1, index);
@ -466,6 +590,18 @@ public class PlayerListener implements Listener { // 2015.07.16.
mp.CurrentChannel = Channel.NationChat; mp.CurrentChannel = Channel.NationChat;
event.getPlayer().chat(event.getMessage().substring(index + 1)); event.getPlayer().chat(event.getMessage().substring(index + 1));
mp.CurrentChannel = c; mp.CurrentChannel = c;
} else if (cmd.equalsIgnoreCase(Channel.AdminChat.Command)) {
event.setCancelled(true);
Channel c = mp.CurrentChannel;
mp.CurrentChannel = Channel.AdminChat;
event.getPlayer().chat(event.getMessage().substring(index + 1));
mp.CurrentChannel = c;
} else if (cmd.equalsIgnoreCase(Channel.ModChat.Command)) {
event.setCancelled(true);
Channel c = mp.CurrentChannel;
mp.CurrentChannel = Channel.ModChat;
event.getPlayer().chat(event.getMessage().substring(index + 1));
mp.CurrentChannel = c;
} else if (cmd.equalsIgnoreCase("tpahere")) { } else if (cmd.equalsIgnoreCase("tpahere")) {
Player player = Bukkit.getPlayer(event.getMessage().substring( Player player = Bukkit.getPlayer(event.getMessage().substring(
index + 1)); index + 1));
@ -474,6 +610,14 @@ public class PlayerListener implements Listener { // 2015.07.16.
+ event.getPlayer().getDisplayName() + event.getPlayer().getDisplayName()
+ " §bis in this world: " + " §bis in this world: "
+ event.getPlayer().getWorld().getName()); + event.getPlayer().getWorld().getName());
} else if (cmd.equalsIgnoreCase("minecraft:me")) {
if (!essentials.getUser(event.getPlayer()).isMuted()) {
event.setCancelled(true);
String message = event.getMessage().substring(index + 1);
for (Player p : PluginMain.GetPlayers())
p.sendMessage(String.format("* %s %s", event
.getPlayer().getDisplayName(), message));
}
} }
} }
} }

View file

@ -92,6 +92,10 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
SB.registerNewObjective("town", "dummy"); SB.registerNewObjective("town", "dummy");
if (SB.getObjective("nation") == null) if (SB.getObjective("nation") == null)
SB.registerNewObjective("nation", "dummy"); SB.registerNewObjective("nation", "dummy");
if (SB.getObjective("admin") == null)
SB.registerNewObjective("admin", "dummy");
if (SB.getObjective("mod") == null)
SB.registerNewObjective("mod", "dummy");
TU = ((Towny) Bukkit.getPluginManager().getPlugin("Towny")) TU = ((Towny) Bukkit.getPluginManager().getPlugin("Towny"))
.getTownyUniverse(); .getTownyUniverse();
Towns = new ArrayList<Town>(TU.getTownsMap().values()); Towns = new ArrayList<Town>(TU.getTownsMap().values());