FIXED tellraw json serializing - mostly

This commit is contained in:
Norbi Peti 2016-09-08 18:27:10 +02:00
parent e83e4724f7
commit 6648bc6901
4 changed files with 108 additions and 45 deletions

View file

@ -1,6 +1,7 @@
package buttondevteam.chat; package buttondevteam.chat;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
@ -11,9 +12,7 @@ import org.bukkit.scoreboard.Objective;
import com.earth2me.essentials.Essentials; import com.earth2me.essentials.Essentials;
import com.google.gson.Gson; import com.google.gson.Gson;
import com.google.gson.JsonArray; import com.google.gson.GsonBuilder;
import com.google.gson.JsonObject;
import com.google.gson.JsonPrimitive;
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;
@ -25,6 +24,8 @@ import buttondevteam.chat.formatting.ChatFormatter;
import buttondevteam.chat.formatting.ChatFormatterBuilder; import buttondevteam.chat.formatting.ChatFormatterBuilder;
import buttondevteam.chat.formatting.TellrawEvent; import buttondevteam.chat.formatting.TellrawEvent;
import buttondevteam.chat.formatting.TellrawPart; import buttondevteam.chat.formatting.TellrawPart;
import buttondevteam.chat.formatting.TellrawSerializableEnum;
import buttondevteam.chat.formatting.TellrawSerializer;
import buttondevteam.chat.formatting.ChatFormatter.Color; import buttondevteam.chat.formatting.ChatFormatter.Color;
import buttondevteam.chat.formatting.ChatFormatter.Priority; import buttondevteam.chat.formatting.ChatFormatter.Priority;
@ -193,29 +194,49 @@ public class ChatProcessing {
json.addExtra(new TellrawPart("[C]").setHoverEvent( json.addExtra(new TellrawPart("[C]").setHoverEvent(
TellrawEvent.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT, "Chat only"))); TellrawEvent.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT, "Chat only")));
} }
json.addExtra(new TellrawPart((currentchannel.DisplayName) + (mp != null && !mp.RPMode ? "[OOC]" : "")) json.addExtra(
new TellrawPart(("[" + currentchannel.DisplayName) + "]" + (mp != null && !mp.RPMode ? "[OOC]" : ""))
.setHoverEvent(TellrawEvent.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT, .setHoverEvent(TellrawEvent.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT,
new TellrawPart("Copy message").setColor(Color.Blue))) new TellrawPart("Copy message").setColor(Color.Blue)))
.setClickEvent(TellrawEvent.create(TellrawEvent.ClickAC, TellrawEvent.ClickAction.SUGGEST_COMMAND, .setClickEvent(TellrawEvent.create(TellrawEvent.ClickAC,
suggestmsg))); TellrawEvent.ClickAction.SUGGEST_COMMAND, suggestmsg)));
json.addExtra(new TellrawPart(" <")); json.addExtra(new TellrawPart(" <"));
json.addExtra(new TellrawPart((player != null ? player.getDisplayName() : sender.getName())).setHoverEvent( json.addExtra(
TellrawEvent.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT, new TellrawPart("") new TellrawPart(
.addExtra(new TellrawPart(String.format("Flair: %s", mp.GetFormattedFlair()))) (player != null ? player.getDisplayName() : sender.getName()))
.addExtra(new TellrawPart(String.format("Playername: %s\n", .setHoverEvent(
(player != null ? player.getName() : sender.getName()))).setColor(Color.Aqua)) TellrawEvent
.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT,
new TellrawPart("")
.addExtra(new TellrawPart(String.format("Flair: %s",
(mp != null ? mp.GetFormattedFlair() : "-"))))
.addExtra(new TellrawPart( .addExtra(new TellrawPart(
String.format("World: %s\n", (player != null ? player.getWorld().getName() : "-")))) String.format("\nPlayername: %s\n",
.addExtra(new TellrawPart(String.format("Respect: %s%s%s", (player != null ? player.getName()
(mp != null ? (mp.FCount / (double) mp.FDeaths) : "Infinite"), : sender.getName())))
(mp != null && mp.UserName != null && !mp.UserName.isEmpty() .setColor(Color.Aqua))
? "\nUserName: " + mp.UserName : ""), .addExtra(new TellrawPart(String.format("World: %s\n",
(mp != null && mp.PlayerName.equals("\nAlpha_Bacca44") (player != null ? player.getWorld().getName()
? "\nDeaths: " + PlayerListener.AlphaDeaths : "-"))))
.addExtra(new TellrawPart(String.format(
"Respect: %s%s%s",
(mp != null ? (mp.FCount / (double) mp.FDeaths)
: "Infinite"),
(mp != null && mp.UserName != null
&& !mp.UserName.isEmpty()
? "\nUserName: " + mp.UserName
: ""),
(mp != null && mp.PlayerName.equals(
"\nAlpha_Bacca44") ? "\nDeaths: "
+ PlayerListener.AlphaDeaths
: ""))))))); : "")))))));
json.addExtra(new TellrawPart("> ")); json.addExtra(new TellrawPart("> "));
ChatFormatter.Combine(formatters, formattedmessage, json); ChatFormatter.Combine(formatters, formattedmessage, json);
String jsonstr = new Gson().toJson(json); Gson gson = new GsonBuilder()
.registerTypeHierarchyAdapter(TellrawSerializableEnum.class, new TellrawSerializer.TwEnum())
.registerTypeHierarchyAdapter(Collection.class, new TellrawSerializer.TwCollection())
.disableHtmlEscaping().create();
String jsonstr = gson.toJson(json);
if (jsonstr.length() >= 32767) { if (jsonstr.length() >= 32767) {
sender.sendMessage( sender.sendMessage(
"§cError: Message too long. Try shortening it, or remove hashtags and other formatting."); "§cError: Message too long. Try shortening it, or remove hashtags and other formatting.");
@ -266,7 +287,7 @@ public class ChatProcessing {
} }
} }
PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console, PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console,
String.format("tellraw @a[score_town=%d,score_town_min=%d] %s", index, index, json.toString())); String.format("tellraw @a[score_town=%d,score_town_min=%d] %s", index, index, jsonstr));
} catch (IllegalStateException e) { } catch (IllegalStateException e) {
e.printStackTrace(); e.printStackTrace();
player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)"); player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)");
@ -312,8 +333,8 @@ public class ChatProcessing {
} catch (Exception e) { } catch (Exception e) {
} }
} }
PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console, String PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console,
.format("tellraw @a[score_nation=%d,score_nation_min=%d] %s", index, index, json.toString())); String.format("tellraw @a[score_nation=%d,score_nation_min=%d] %s", index, index, jsonstr));
} catch (IllegalStateException e) { } catch (IllegalStateException e) {
e.printStackTrace(); e.printStackTrace();
player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)"); player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)");
@ -337,7 +358,7 @@ public class ChatProcessing {
obj.getScore(p.getName()).setScore(0); obj.getScore(p.getName()).setScore(0);
} }
PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console, PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console,
String.format("tellraw @a[score_admin=%d,score_admin_min=%d] %s", 1, 1, json.toString())); String.format("tellraw @a[score_admin=%d,score_admin_min=%d] %s", 1, 1, jsonstr));
} catch (IllegalStateException e) { } catch (IllegalStateException e) {
e.printStackTrace(); e.printStackTrace();
player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)"); player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)");
@ -361,7 +382,7 @@ public class ChatProcessing {
obj.getScore(p.getName()).setScore(0); obj.getScore(p.getName()).setScore(0);
} }
PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console, PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console,
String.format("tellraw @a[score_mod=%d,score_mod_min=%d] %s", 1, 1, json.toString())); String.format("tellraw @a[score_mod=%d,score_mod_min=%d] %s", 1, 1, jsonstr));
} catch (IllegalStateException e) { } catch (IllegalStateException e) {
e.printStackTrace(); e.printStackTrace();
player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)"); player.sendMessage("§cAn error occured while sending the message. (IllegalStateException)");
@ -373,7 +394,7 @@ public class ChatProcessing {
} }
} 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", jsonstr));
PluginMain.Instance.getServer().getConsoleSender() PluginMain.Instance.getServer().getConsoleSender()
.sendMessage(String.format("[%s] <%s%s> %s", currentchannel.DisplayName, .sendMessage(String.format("[%s] <%s%s> %s", currentchannel.DisplayName,
(player != null ? player.getDisplayName() : sender.getName()), (player != null ? player.getDisplayName() : sender.getName()),

View file

@ -6,8 +6,7 @@ public final class TellrawEvent<T extends TellrawEvent.Action> implements Serial
private static final long serialVersionUID = -1681364161210561505L; private static final long serialVersionUID = -1681364161210561505L;
private boolean hoverEvent; private boolean hoverEvent;
private T action; private T action;
private String value; private Object value;
private TellrawPart valueobj; // TODO: FIx serializer, actually add own serializer, etc.
private TellrawEvent(Class<T> cl, T action, String value) { private TellrawEvent(Class<T> cl, T action, String value) {
this.hoverEvent = HoverAction.class.equals(cl); this.hoverEvent = HoverAction.class.equals(cl);
@ -18,7 +17,7 @@ public final class TellrawEvent<T extends TellrawEvent.Action> implements Serial
private TellrawEvent(Class<T> cl, T action, TellrawPart value) { private TellrawEvent(Class<T> cl, T action, TellrawPart value) {
this.hoverEvent = HoverAction.class.equals(cl); this.hoverEvent = HoverAction.class.equals(cl);
this.action = action; this.action = action;
this.valueobj = value; this.value = value;
} }
public static final Class<HoverAction> HoverAC = HoverAction.class; public static final Class<HoverAction> HoverAC = HoverAction.class;
@ -40,7 +39,7 @@ public final class TellrawEvent<T extends TellrawEvent.Action> implements Serial
return action; return action;
} }
public String getValue() { public Object getValue() {
return value; return value;
} }

View file

@ -7,7 +7,12 @@ import java.util.List;
public final class TellrawPart implements Serializable { public final class TellrawPart implements Serializable {
private static final long serialVersionUID = 4125357644462144024L; private static final long serialVersionUID = 4125357644462144024L;
private ChatFormatter.Color color; private ChatFormatter.Color color;
private ChatFormatter.Format format; private transient ChatFormatter.Format format;
private boolean italics;
private boolean bold;
private boolean underlined;
private boolean strikethrough;
private boolean obfuscated;
private List<TellrawPart> extra = new ArrayList<>(); private List<TellrawPart> extra = new ArrayList<>();
private String text; private String text;
private TellrawEvent<TellrawEvent.HoverAction> hoverEvent; private TellrawEvent<TellrawEvent.HoverAction> hoverEvent;
@ -32,6 +37,23 @@ public final class TellrawPart implements Serializable {
public TellrawPart setFormat(ChatFormatter.Format format) { public TellrawPart setFormat(ChatFormatter.Format format) {
this.format = format; this.format = format;
this.italics = false;
this.bold = false;
this.underlined = false;
this.strikethrough = false;
this.obfuscated = false;
if (format.equals(ChatFormatter.Format.Italic))
this.italics = true;
else if (format.equals(ChatFormatter.Format.Bold))
this.bold = true;
else if (format.equals(ChatFormatter.Format.Underlined))
this.underlined = true;
else if (format.equals(ChatFormatter.Format.Strikethrough))
this.strikethrough = true;
else if (format.equals(ChatFormatter.Format.Obfuscated))
this.obfuscated = true;
else // TODO: Don't serialize false values, find out why is it bugging
throw new UnsupportedOperationException("Trying to set to an unknown format!");
return this; return this;
} }

View file

@ -1,13 +1,14 @@
package buttondevteam.chat.formatting; package buttondevteam.chat.formatting;
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.Type;
import java.util.Collection;
import com.google.gson.TypeAdapter; import com.google.gson.*;
import com.google.gson.stream.JsonReader; import com.google.gson.stream.*;
import com.google.gson.stream.JsonWriter;
public class TellrawSerializer extends TypeAdapter<TellrawSerializableEnum> {
public abstract class TellrawSerializer {
public static class TwEnum extends TypeAdapter<TellrawSerializableEnum> {
@Override @Override
public TellrawSerializableEnum read(JsonReader reader) throws IOException { public TellrawSerializableEnum read(JsonReader reader) throws IOException {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
@ -15,7 +16,27 @@ public class TellrawSerializer extends TypeAdapter<TellrawSerializableEnum> {
@Override @Override
public void write(JsonWriter writer, TellrawSerializableEnum enumval) throws IOException { public void write(JsonWriter writer, TellrawSerializableEnum enumval) throws IOException {
if (enumval == null)
writer.nullValue();
else
writer.value(enumval.getName()); writer.value(enumval.getName());
} }
}
public static class TwCollection implements JsonSerializer<Collection<?>> {
@Override
public JsonElement serialize(Collection<?> src, Type typeOfSrc, JsonSerializationContext context) {
if (src == null || src.isEmpty())
return null;
JsonArray array = new JsonArray();
for (Object child : src) {
JsonElement element = context.serialize(child);
array.add(element);
}
return array;
}
}
} }