display a properly parsed nickname with the hover events removed

This commit is contained in:
Taah 2022-04-24 16:34:42 -07:00
parent 2a94bd8c6c
commit 3d850d3698
9 changed files with 203 additions and 8 deletions

View File

@ -1,5 +1,6 @@
package dev.plex.util;
import dev.plex.plugin.SunburstPlugin;
import net.kyori.adventure.text.minimessage.MiniMessage;
import org.bukkit.Bukkit;
@ -8,7 +9,7 @@ public class Logger
public static void log(String message)
{
Bukkit.getConsoleSender().sendMessage(MiniMessage.miniMessage().deserialize("<green>[Sunburst] <gold>" + message));
Bukkit.getScheduler().runTask(SunburstPlugin.getPlugin(), () -> Bukkit.getConsoleSender().sendMessage(MiniMessage.miniMessage().deserialize("<green>[Sunburst] <gold>" + message)));
}
public static void error(String message)

View File

@ -12,6 +12,7 @@ dependencies {
annotationProcessor("org.projectlombok:lombok:1.18.22")
library("org.json:json:20220320")
library("org.apache.httpcomponents:httpclient:4.5.13")
}
bukkit {

View File

@ -12,8 +12,10 @@ import dev.plex.plugin.SunburstPlugin;
import dev.plex.storage.FileStorage;
import dev.plex.util.ComponentUtil;
import dev.plex.util.Configuration;
import dev.plex.util.Logger;
import lombok.Getter;
import lombok.Setter;
import lombok.extern.java.Log;
import net.kyori.adventure.text.minimessage.MiniMessage;
import net.kyori.adventure.text.serializer.plain.PlainTextComponentSerializer;
import org.bukkit.Bukkit;
@ -41,7 +43,16 @@ public final class Sunburst extends SunburstPlugin
this.messages.load();
this.getObjectHolder().setPermissionHandler(new PermissionHandlerImpl());
this.getObjectHolder().setChatRenderer((source, sourceDisplayName, message, viewer) -> ComponentUtil.configComponent("chatFormat", MiniMessage.miniMessage().serialize(source.displayName()), PlainTextComponentSerializer.plainText().serialize(message)));
this.getObjectHolder().setChatRenderer((source, sourceDisplayName, message, viewer) -> {
Logger.log("Spokenz");
Logger.log(ComponentUtil.mmCustom(sourceDisplayName, ComponentUtil.REGULAR_TAGS));
return ComponentUtil.configComponent("chatFormat",
ComponentUtil.REGULAR_TAGS,
ComponentUtil.mmCustom(sourceDisplayName, ComponentUtil.REGULAR_TAGS),
PlainTextComponentSerializer.plainText().serialize(message));
});
Logger.debug("Loading");
}
@Override

View File

@ -9,6 +9,7 @@ import dev.plex.util.CommandUtil;
import dev.plex.util.ComponentUtil;
import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.minimessage.MiniMessage;
import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandSender;
@ -114,6 +115,11 @@ public abstract class SunburstCommand extends Command implements PluginIdentifia
return ComponentUtil.configComponent(entry, objects);
}
protected Component confMsg(String entry, TagResolver[] tagResolvers, Object... objects)
{
return ComponentUtil.configComponent(entry, tagResolvers, objects);
}
protected Component usage()
{
return confMsg("incorrectUsage", getUsage());

View File

@ -5,8 +5,12 @@ import dev.plex.command.util.CommandInfo;
import dev.plex.command.util.CommandPerms;
import dev.plex.player.ISunburstPlayer;
import dev.plex.util.ComponentUtil;
import dev.plex.util.Logger;
import dev.plex.util.MojangUtils;
import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.minimessage.MiniMessage;
import net.kyori.adventure.text.serializer.plain.PlainTextComponentSerializer;
import org.apache.commons.lang.StringUtils;
import org.bukkit.Bukkit;
import org.bukkit.command.CommandSender;
import org.bukkit.command.ConsoleCommandSender;
@ -32,7 +36,7 @@ public class NicknameCMD extends SunburstCommand
{
return confMsg("nicknameNotFound");
}
return confMsg("nickname", miniString(sunburstPlayer.displayName()));
return confMsg("nickname", ComponentUtil.REGULAR_TAGS, ComponentUtil.mmCustom(sunburstPlayer.displayName(), ComponentUtil.REGULAR_TAGS));
}
if (Bukkit.getOnlinePlayers().stream().anyMatch(p -> p.getName().equalsIgnoreCase(args[0])))
{
@ -48,12 +52,20 @@ public class NicknameCMD extends SunburstCommand
target.sendMessage(confMsg("nicknameRemoved"));
return confMsg("nicknameRemovedOther", target.getName());
}
String nickname = args[1];
String nickname = StringUtils.join(args, " ", 1, args.length);
nickname = nickname.replace("<newline>", "").replace("<br>", "");
Component newNickname = MiniMessage.miniMessage().deserialize(nickname, ComponentUtil.REGULAR_TAGS);
String rawNick = PlainTextComponentSerializer.plainText().serialize(newNickname);
if (!rawNick.equalsIgnoreCase(target.getName()) && Bukkit.getOfflinePlayer(rawNick).hasPlayedBefore())
{
if (Bukkit.getOfflinePlayer(nickname).hasPlayedBefore())
{
return confMsg("nicknameMatchesPlayer");
}
}
sunburstPlayer.displayName(newNickname);
target.sendMessage(confMsg("nicknameSet", nickname));
return confMsg("nicknameSetOther", target.getName(), nickname);
target.sendMessage(confMsg("nicknameSet", ComponentUtil.REGULAR_TAGS, ComponentUtil.mmCustom(newNickname, ComponentUtil.REGULAR_TAGS)));
return confMsg("nicknameSetOther", ComponentUtil.REGULAR_TAGS, target.getName(), ComponentUtil.mmCustom(newNickname, ComponentUtil.REGULAR_TAGS));
}
if (args[0].equalsIgnoreCase("off"))
@ -71,10 +83,15 @@ public class NicknameCMD extends SunburstCommand
return confMsg("commandCheckConsole", this.getUsage());
}
ISunburstPlayer sunburstPlayer = plugin.getObjectHolder().getStorageSystem().getPlayer(player.getUniqueId());
String nickname = args[0];
String nickname = StringUtils.join(args, " ");
nickname = nickname.replace("<newline>", "").replace("<br>", "");
Component newNickname = MiniMessage.miniMessage().deserialize(nickname, ComponentUtil.REGULAR_TAGS);
String rawNick = PlainTextComponentSerializer.plainText().serialize(newNickname);
if (!rawNick.equalsIgnoreCase(player.getName()) && MojangUtils.getInfo(rawNick) != null)
{
return confMsg("nicknameMatchesPlayer");
}
sunburstPlayer.displayName(newNickname);
return confMsg("nicknameSet", nickname);
return confMsg("nicknameSet", ComponentUtil.REGULAR_TAGS, ComponentUtil.mmCustom(newNickname, ComponentUtil.REGULAR_TAGS));
}
}

View File

@ -0,0 +1,51 @@
package dev.plex.util;
import com.google.gson.annotations.SerializedName;
import java.time.LocalDateTime;
import java.time.ZonedDateTime;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
@Getter
@Setter
public class AshconInfo
{
private String uuid;
private String username;
@SerializedName("username_history")
private UsernameHistory[] usernameHistories;
private Textures textures;
@Getter
@Setter
@NoArgsConstructor
public static class UsernameHistory
{
private String username;
@SerializedName("changed_at")
private ZonedDateTime zonedDateTime;
}
@Getter
@Setter
@NoArgsConstructor
public static class Textures
{
private boolean custom;
private boolean slim;
private SkinData raw;
}
@Getter
@Setter
@NoArgsConstructor
public static class SkinData
{
private String value;
private String signature;
}
}

View File

@ -31,6 +31,31 @@ public class ComponentUtil
return value;
}
public static String miniString(Component component)
{
return mmCustom(component, TagResolver.standard());
}
public static String mmCustom(Component component, TagResolver... tags)
{
return MiniMessage.builder().tags(TagResolver.resolver(tags)).build().serialize(component);
}
public static Component mini(String message)
{
return mmCustom(message, TagResolver.standard());
}
public static Component mmCustom(String message, TagResolver... tags)
{
return MiniMessage.builder().tags(TagResolver.resolver(tags)).build().deserialize(message);
}
public static Component configComponent(String entry, TagResolver[] tagResolvers, Object... objects)
{
return MiniMessage.builder().tags(TagResolver.resolver(tagResolvers)).build().deserialize(configMessage(entry, objects));
}
public static Component configComponent(String entry, Object... objects)
{
return MiniMessage.miniMessage().deserialize(configMessage(entry, objects));

View File

@ -0,0 +1,82 @@
package dev.plex.util;
import com.google.common.collect.Maps;
import com.google.gson.GsonBuilder;
import com.google.gson.JsonDeserializer;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.time.Instant;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Arrays;
import java.util.Map;
import dev.plex.Sunburst;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.bukkit.scheduler.BukkitRunnable;
import org.json.JSONObject;
public class MojangUtils
{
private static final Map<String, AshconInfo> CACHED_INFO = Maps.newHashMap();
public static AshconInfo getInfo(String nameOrUuid)
{
if (CACHED_INFO.containsKey(nameOrUuid))
{
return CACHED_INFO.get(nameOrUuid);
}
CloseableHttpClient client = HttpClients.createDefault();
HttpGet get = new HttpGet("https://api.ashcon.app/mojang/v2/user/" + nameOrUuid);
try
{
HttpResponse response = client.execute(get);
if (response == null || response.getEntity() == null)
{
return null;
}
String json = EntityUtils.toString(response.getEntity(), StandardCharsets.UTF_8);
JSONObject object = new JSONObject(json);
if (!object.isNull("code") && object.getInt("code") == 404)
{
return null;
}
client.close();
AshconInfo ashconInfo = new GsonBuilder().registerTypeAdapter(ZonedDateTime.class, (JsonDeserializer<ZonedDateTime>)(json1, typeOfT, context) ->
ZonedDateTime.ofInstant(Instant.from(DateTimeFormatter.ISO_INSTANT.parse(json1.getAsJsonPrimitive().getAsString())), ZoneId.systemDefault())).create().fromJson(json, AshconInfo.class);
CACHED_INFO.put(ashconInfo.getUuid(), ashconInfo);
CACHED_INFO.put(ashconInfo.getUsername(), ashconInfo);
new BukkitRunnable()
{
@Override
public void run()
{
CACHED_INFO.remove(ashconInfo.getUsername());
CACHED_INFO.remove(ashconInfo.getUuid());
}
}.runTaskLater(Sunburst.inst(), 20 * 60 * 2);
Arrays.sort(ashconInfo.getUsernameHistories(), (o1, o2) ->
{
if (o1.getZonedDateTime() == null || o2.getZonedDateTime() == null)
{
return 1;
}
return o1.getZonedDateTime().compareTo(o2.getZonedDateTime());
});
return ashconInfo;
}
catch (IOException e)
{
e.printStackTrace();
return null;
}
}
}

View File

@ -28,6 +28,7 @@ nicknameSet: "<aqua>Your nickname has been set to {0}"
# 0 - The targeted player
# 1 - The nickname
nicknameSetOther: "<aqua>You have set {0}'s nickname to {1}"
nicknameMatchesPlayer: "<red>This nickname is the same as another player's username"
# 0 - Player username
# 1 - Message