FIXED tellraw json serializing - mostly
This commit is contained in:
parent
e83e4724f7
commit
6648bc6901
4 changed files with 108 additions and 45 deletions
|
@ -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(
|
||||||
.setHoverEvent(TellrawEvent.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT,
|
new TellrawPart(("[" + currentchannel.DisplayName) + "]" + (mp != null && !mp.RPMode ? "[OOC]" : ""))
|
||||||
new TellrawPart("Copy message").setColor(Color.Blue)))
|
.setHoverEvent(TellrawEvent.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT,
|
||||||
.setClickEvent(TellrawEvent.create(TellrawEvent.ClickAC, TellrawEvent.ClickAction.SUGGEST_COMMAND,
|
new TellrawPart("Copy message").setColor(Color.Blue)))
|
||||||
suggestmsg)));
|
.setClickEvent(TellrawEvent.create(TellrawEvent.ClickAC,
|
||||||
|
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
|
||||||
.addExtra(new TellrawPart(
|
.create(TellrawEvent.HoverAC, TellrawEvent.HoverAction.SHOW_TEXT,
|
||||||
String.format("World: %s\n", (player != null ? player.getWorld().getName() : "-"))))
|
new TellrawPart("")
|
||||||
.addExtra(new TellrawPart(String.format("Respect: %s%s%s",
|
.addExtra(new TellrawPart(String.format("Flair: %s",
|
||||||
(mp != null ? (mp.FCount / (double) mp.FDeaths) : "Infinite"),
|
(mp != null ? mp.GetFormattedFlair() : "-"))))
|
||||||
(mp != null && mp.UserName != null && !mp.UserName.isEmpty()
|
.addExtra(new TellrawPart(
|
||||||
? "\nUserName: " + mp.UserName : ""),
|
String.format("\nPlayername: %s\n",
|
||||||
(mp != null && mp.PlayerName.equals("\nAlpha_Bacca44")
|
(player != null ? player.getName()
|
||||||
? "\nDeaths: " + PlayerListener.AlphaDeaths
|
: sender.getName())))
|
||||||
: "")))))));
|
.setColor(Color.Aqua))
|
||||||
|
.addExtra(new TellrawPart(String.format("World: %s\n",
|
||||||
|
(player != null ? player.getWorld().getName()
|
||||||
|
: "-"))))
|
||||||
|
.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()),
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,21 +1,42 @@
|
||||||
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
|
||||||
|
public TellrawSerializableEnum read(JsonReader reader) throws IOException {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TellrawSerializableEnum read(JsonReader reader) throws IOException {
|
public void write(JsonWriter writer, TellrawSerializableEnum enumval) throws IOException {
|
||||||
throw new UnsupportedOperationException();
|
if (enumval == null)
|
||||||
|
writer.nullValue();
|
||||||
|
else
|
||||||
|
writer.value(enumval.getName());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public static class TwCollection implements JsonSerializer<Collection<?>> {
|
||||||
public void write(JsonWriter writer, TellrawSerializableEnum enumval) throws IOException {
|
@Override
|
||||||
writer.value(enumval.getName());
|
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;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue