mirror of
https://github.com/plexusorg/Plex.git
synced 2025-01-08 16:37:38 +00:00
- Fix login messages to match with titles
This commit is contained in:
parent
137bc44212
commit
a2aea5bf1c
@ -73,7 +73,7 @@ public class MongoPlayerData
|
|||||||
Update<PlexPlayer> updateOps = filter
|
Update<PlexPlayer> updateOps = filter
|
||||||
.update(
|
.update(
|
||||||
UpdateOperators.set("name", player.getName()),
|
UpdateOperators.set("name", player.getName()),
|
||||||
UpdateOperators.set("loginMSG", player.getLoginMSG()),
|
UpdateOperators.set("loginMSG", player.getLoginMessage()),
|
||||||
UpdateOperators.set("prefix", player.getPrefix()),
|
UpdateOperators.set("prefix", player.getPrefix()),
|
||||||
UpdateOperators.set("rank", player.getRank().toLowerCase()),
|
UpdateOperators.set("rank", player.getRank().toLowerCase()),
|
||||||
UpdateOperators.set("ips", player.getIps()),
|
UpdateOperators.set("ips", player.getIps()),
|
||||||
|
@ -75,7 +75,7 @@ public class SQLPlayerData
|
|||||||
{
|
{
|
||||||
}.getType());
|
}.getType());
|
||||||
plexPlayer.setName(name);
|
plexPlayer.setName(name);
|
||||||
plexPlayer.setLoginMSG(loginMSG);
|
plexPlayer.setLoginMessage(loginMSG);
|
||||||
plexPlayer.setPrefix(prefix);
|
plexPlayer.setPrefix(prefix);
|
||||||
plexPlayer.setRank(rankName);
|
plexPlayer.setRank(rankName);
|
||||||
plexPlayer.setIps(ips);
|
plexPlayer.setIps(ips);
|
||||||
@ -104,7 +104,7 @@ public class SQLPlayerData
|
|||||||
{
|
{
|
||||||
PreparedStatement statement = con.prepareStatement(UPDATE);
|
PreparedStatement statement = con.prepareStatement(UPDATE);
|
||||||
statement.setString(1, player.getName());
|
statement.setString(1, player.getName());
|
||||||
statement.setString(2, player.getLoginMSG());
|
statement.setString(2, player.getLoginMessage());
|
||||||
statement.setString(3, player.getPrefix());
|
statement.setString(3, player.getPrefix());
|
||||||
statement.setString(4, player.getRank().toLowerCase());
|
statement.setString(4, player.getRank().toLowerCase());
|
||||||
statement.setString(5, new Gson().toJson(player.getIps()));
|
statement.setString(5, new Gson().toJson(player.getIps()));
|
||||||
@ -133,7 +133,7 @@ public class SQLPlayerData
|
|||||||
PreparedStatement statement = con.prepareStatement(INSERT);
|
PreparedStatement statement = con.prepareStatement(INSERT);
|
||||||
statement.setString(1, player.getUuid());
|
statement.setString(1, player.getUuid());
|
||||||
statement.setString(2, player.getName());
|
statement.setString(2, player.getName());
|
||||||
statement.setString(3, player.getLoginMSG());
|
statement.setString(3, player.getLoginMessage());
|
||||||
statement.setString(4, player.getPrefix());
|
statement.setString(4, player.getPrefix());
|
||||||
statement.setString(5, player.getRank().toLowerCase());
|
statement.setString(5, player.getRank().toLowerCase());
|
||||||
statement.setString(6, new Gson().toJson(player.getIps()));
|
statement.setString(6, new Gson().toJson(player.getIps()));
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package dev.plex.listener.impl;
|
package dev.plex.listener.impl;
|
||||||
|
|
||||||
import dev.plex.admin.Admin;
|
|
||||||
import dev.plex.cache.DataUtils;
|
import dev.plex.cache.DataUtils;
|
||||||
import dev.plex.cache.MongoPlayerData;
|
import dev.plex.cache.MongoPlayerData;
|
||||||
import dev.plex.cache.PlayerCache;
|
import dev.plex.cache.PlayerCache;
|
||||||
@ -8,11 +7,9 @@ import dev.plex.cache.SQLPlayerData;
|
|||||||
import dev.plex.listener.PlexListener;
|
import dev.plex.listener.PlexListener;
|
||||||
import dev.plex.player.PlexPlayer;
|
import dev.plex.player.PlexPlayer;
|
||||||
import dev.plex.player.PunishedPlayer;
|
import dev.plex.player.PunishedPlayer;
|
||||||
import dev.plex.rank.enums.Title;
|
|
||||||
import dev.plex.util.PlexLog;
|
import dev.plex.util.PlexLog;
|
||||||
import dev.plex.util.PlexUtils;
|
import net.kyori.adventure.text.Component;
|
||||||
import java.util.Collections;
|
import net.kyori.adventure.text.format.NamedTextColor;
|
||||||
import java.util.UUID;
|
|
||||||
import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer;
|
import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -21,6 +18,9 @@ import org.bukkit.event.EventPriority;
|
|||||||
import org.bukkit.event.player.PlayerJoinEvent;
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
import org.bukkit.event.player.PlayerQuitEvent;
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
public class PlayerListener extends PlexListener
|
public class PlayerListener extends PlexListener
|
||||||
{
|
{
|
||||||
private final MongoPlayerData mongoPlayerData = plugin.getMongoPlayerData() != null ? plugin.getMongoPlayerData() : null;
|
private final MongoPlayerData mongoPlayerData = plugin.getMongoPlayerData() != null ? plugin.getMongoPlayerData() : null;
|
||||||
@ -38,8 +38,7 @@ public class PlayerListener extends PlexListener
|
|||||||
{
|
{
|
||||||
player.setOp(true);
|
player.setOp(true);
|
||||||
PlexLog.debug("Automatically opped " + player.getName() + " since ranks are enabled.");
|
PlexLog.debug("Automatically opped " + player.getName() + " since ranks are enabled.");
|
||||||
}
|
} else if (plugin.getSystem().equalsIgnoreCase("permissions"))
|
||||||
else if (plugin.getSystem().equalsIgnoreCase("permissions"))
|
|
||||||
{
|
{
|
||||||
player.setOp(false);
|
player.setOp(false);
|
||||||
PlexLog.debug("Automatically deopped " + player.getName() + " since ranks are disabled.");
|
PlexLog.debug("Automatically deopped " + player.getName() + " since ranks are disabled.");
|
||||||
@ -52,8 +51,7 @@ public class PlayerListener extends PlexListener
|
|||||||
plexPlayer.setName(player.getName()); //set the name of the player
|
plexPlayer.setName(player.getName()); //set the name of the player
|
||||||
plexPlayer.setIps(Collections.singletonList(player.getAddress().getAddress().getHostAddress().trim())); //set the arraylist of ips
|
plexPlayer.setIps(Collections.singletonList(player.getAddress().getAddress().getHostAddress().trim())); //set the arraylist of ips
|
||||||
DataUtils.insert(plexPlayer); // insert data in some wack db
|
DataUtils.insert(plexPlayer); // insert data in some wack db
|
||||||
}
|
} else
|
||||||
else
|
|
||||||
{
|
{
|
||||||
plexPlayer = DataUtils.getPlayer(player.getUniqueId());
|
plexPlayer = DataUtils.getPlayer(player.getUniqueId());
|
||||||
}
|
}
|
||||||
@ -64,8 +62,7 @@ public class PlayerListener extends PlexListener
|
|||||||
{
|
{
|
||||||
punishedPlayer = new PunishedPlayer(player.getUniqueId());
|
punishedPlayer = new PunishedPlayer(player.getUniqueId());
|
||||||
PlayerCache.getPunishedPlayerMap().put(player.getUniqueId(), punishedPlayer);
|
PlayerCache.getPunishedPlayerMap().put(player.getUniqueId(), punishedPlayer);
|
||||||
}
|
} else
|
||||||
else
|
|
||||||
{
|
{
|
||||||
punishedPlayer = PlayerCache.getPunishedPlayer(player.getUniqueId());
|
punishedPlayer = PlayerCache.getPunishedPlayer(player.getUniqueId());
|
||||||
}
|
}
|
||||||
@ -73,29 +70,15 @@ public class PlayerListener extends PlexListener
|
|||||||
|
|
||||||
assert plexPlayer != null;
|
assert plexPlayer != null;
|
||||||
|
|
||||||
if (PlexUtils.DEVELOPERS.contains(plexPlayer.getUuid())) // don't remove or we will front door ur mother
|
String loginMessage = plugin.getRankManager().getLoginMessage(plexPlayer);
|
||||||
|
|
||||||
|
if (!loginMessage.isEmpty())
|
||||||
{
|
{
|
||||||
PlexUtils.broadcast(LegacyComponentSerializer.legacyAmpersand().deserialize(ChatColor.AQUA + player.getName() + " is " + Title.DEV.getLoginMessage()));
|
event.joinMessage(
|
||||||
}
|
Component.text(ChatColor.AQUA + player.getName() + " is ").color(NamedTextColor.AQUA).append(LegacyComponentSerializer.legacyAmpersand().deserialize(loginMessage))
|
||||||
|
.append(Component.newline())
|
||||||
if (plugin.getSystem().equalsIgnoreCase("ranks"))
|
.append(Component.text(player.getName() + " joined the game").color(NamedTextColor.YELLOW))
|
||||||
{
|
);
|
||||||
if (plugin.getRankManager().isAdmin(plexPlayer))
|
|
||||||
{
|
|
||||||
Admin admin = new Admin(UUID.fromString(plexPlayer.getUuid()));
|
|
||||||
admin.setRank(plexPlayer.getRankFromString());
|
|
||||||
|
|
||||||
plugin.getAdminList().addToCache(admin);
|
|
||||||
|
|
||||||
if (!plexPlayer.getLoginMSG().isEmpty())
|
|
||||||
{
|
|
||||||
event.joinMessage(LegacyComponentSerializer.legacyAmpersand().deserialize(ChatColor.AQUA + player.getName() + " is " + plexPlayer.getLoginMSG()));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
event.joinMessage(LegacyComponentSerializer.legacyAmpersand().deserialize(ChatColor.AQUA + player.getName() + " is " + plexPlayer.getRankFromString().getLoginMessage()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,8 +96,7 @@ public class PlayerListener extends PlexListener
|
|||||||
if (mongoPlayerData != null) //back to mongo checking
|
if (mongoPlayerData != null) //back to mongo checking
|
||||||
{
|
{
|
||||||
mongoPlayerData.update(plexPlayer); //update the player's document
|
mongoPlayerData.update(plexPlayer); //update the player's document
|
||||||
}
|
} else if (sqlPlayerData != null) //sql checking
|
||||||
else if (sqlPlayerData != null) //sql checking
|
|
||||||
{
|
{
|
||||||
sqlPlayerData.update(plexPlayer);
|
sqlPlayerData.update(plexPlayer);
|
||||||
}
|
}
|
||||||
|
@ -33,7 +33,7 @@ public class PlexPlayer
|
|||||||
private String name;
|
private String name;
|
||||||
private Player player;
|
private Player player;
|
||||||
|
|
||||||
private String loginMSG;
|
private String loginMessage;
|
||||||
private String prefix;
|
private String prefix;
|
||||||
|
|
||||||
private boolean vanished;
|
private boolean vanished;
|
||||||
@ -58,7 +58,7 @@ public class PlexPlayer
|
|||||||
this.name = "";
|
this.name = "";
|
||||||
this.player = Bukkit.getPlayer(name);
|
this.player = Bukkit.getPlayer(name);
|
||||||
|
|
||||||
this.loginMSG = "";
|
this.loginMessage = "";
|
||||||
this.prefix = "";
|
this.prefix = "";
|
||||||
|
|
||||||
this.vanished = false;
|
this.vanished = false;
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package dev.plex.rank;
|
package dev.plex.rank;
|
||||||
|
|
||||||
import com.google.gson.Gson;
|
|
||||||
import dev.plex.Plex;
|
import dev.plex.Plex;
|
||||||
import dev.plex.player.PlexPlayer;
|
import dev.plex.player.PlexPlayer;
|
||||||
import dev.plex.rank.enums.Rank;
|
import dev.plex.rank.enums.Rank;
|
||||||
@ -11,9 +10,11 @@ import org.json.JSONArray;
|
|||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
import org.json.JSONTokener;
|
import org.json.JSONTokener;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
public class RankManager
|
public class RankManager
|
||||||
@ -65,7 +66,8 @@ public class RankManager
|
|||||||
JSONObject object = new JSONObject(tokener);
|
JSONObject object = new JSONObject(tokener);
|
||||||
|
|
||||||
JSONArray ranks = object.getJSONArray("ranks");
|
JSONArray ranks = object.getJSONArray("ranks");
|
||||||
ranks.forEach(r -> {
|
ranks.forEach(r ->
|
||||||
|
{
|
||||||
JSONObject rank = new JSONObject(r.toString());
|
JSONObject rank = new JSONObject(r.toString());
|
||||||
String key = rank.keys().next();
|
String key = rank.keys().next();
|
||||||
Rank.valueOf(key).setLoginMessage(rank.getJSONObject(key).getString("loginMessage"));
|
Rank.valueOf(key).setLoginMessage(rank.getJSONObject(key).getString("loginMessage"));
|
||||||
@ -73,7 +75,8 @@ public class RankManager
|
|||||||
});
|
});
|
||||||
|
|
||||||
JSONArray titles = object.getJSONArray("titles");
|
JSONArray titles = object.getJSONArray("titles");
|
||||||
titles.forEach(t -> {
|
titles.forEach(t ->
|
||||||
|
{
|
||||||
JSONObject title = new JSONObject(t.toString());
|
JSONObject title = new JSONObject(t.toString());
|
||||||
String key = title.keys().next();
|
String key = title.keys().next();
|
||||||
Title.valueOf(key).setLoginMessage(title.getJSONObject(key).getString("loginMessage"));
|
Title.valueOf(key).setLoginMessage(title.getJSONObject(key).getString("loginMessage"));
|
||||||
@ -110,6 +113,31 @@ public class RankManager
|
|||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getLoginMessage(PlexPlayer player)
|
||||||
|
{
|
||||||
|
if (!player.getLoginMessage().isEmpty())
|
||||||
|
{
|
||||||
|
return player.getLoginMessage();
|
||||||
|
}
|
||||||
|
if (Plex.get().config.contains("titles.owners") && Plex.get().config.getStringList("titles.owners").contains(player.getName()))
|
||||||
|
{
|
||||||
|
return Title.OWNER.getLoginMessage();
|
||||||
|
}
|
||||||
|
if (PlexUtils.DEVELOPERS.contains(player.getUuid())) // don't remove or we will front door ur mother
|
||||||
|
{
|
||||||
|
return Title.DEV.getLoginMessage();
|
||||||
|
}
|
||||||
|
if (Plex.get().config.contains("titles.masterbuilders") && Plex.get().config.getStringList("titles.masterbuilders").contains(player.getName()))
|
||||||
|
{
|
||||||
|
return Title.MASTER_BUILDER.getLoginMessage();
|
||||||
|
}
|
||||||
|
if (Plex.get().getSystem().equalsIgnoreCase("ranks") && isAdmin(player))
|
||||||
|
{
|
||||||
|
return player.getRankFromString().getLoginMessage();
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isAdmin(PlexPlayer plexPlayer)
|
public boolean isAdmin(PlexPlayer plexPlayer)
|
||||||
{
|
{
|
||||||
return !plexPlayer.getRank().isEmpty() && plexPlayer.getRankFromString().isAtLeast(Rank.ADMIN);
|
return !plexPlayer.getRank().isEmpty() && plexPlayer.getRankFromString().isAtLeast(Rank.ADMIN);
|
||||||
|
Loading…
Reference in New Issue
Block a user