mirror of
https://github.com/SimplexDevelopment/Traverse.git
synced 2025-07-06 09:16:42 +00:00
75% completion
This commit is contained in:
@ -6,8 +6,11 @@ import mc.unraveled.reforged.listening.AbstractListener;
|
||||
import mc.unraveled.reforged.plugin.Traverse;
|
||||
import mc.unraveled.reforged.storage.DBUser;
|
||||
import mc.unraveled.reforged.util.Pair;
|
||||
import net.kyori.adventure.text.Component;
|
||||
import org.bukkit.OfflinePlayer;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.player.PlayerJoinEvent;
|
||||
import org.bukkit.event.player.PlayerLoginEvent;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
@ -18,25 +21,31 @@ import java.util.stream.Collectors;
|
||||
@Getter
|
||||
public class LoginManager implements Baker {
|
||||
private final Traverse plugin;
|
||||
private Set<Pair<Player, CustomLoginData>> dataSet = new HashSet<>(); // VALUE ONLY MODIFIED BY BAKER
|
||||
private Set<Pair<OfflinePlayer, LoginInfo>> dataSet = new HashSet<>(); // VALUE ONLY MODIFIED BY BAKER
|
||||
private boolean baked = false;
|
||||
|
||||
public LoginManager(Traverse plugin) {
|
||||
this.plugin = plugin;
|
||||
|
||||
DBUser user = new DBUser(plugin.getSQLManager().establish());
|
||||
user.getLoginMessages().forEach((oPlayer, info) -> dataSet.add(new Pair<>(oPlayer, info)));
|
||||
user.close();
|
||||
|
||||
bake();
|
||||
|
||||
new LoginListener(plugin);
|
||||
}
|
||||
|
||||
public void add(Player player, CustomLoginData data) {
|
||||
public void add(OfflinePlayer player, LoginInfo data) {
|
||||
dataSet.add(new Pair<>(player, data));
|
||||
}
|
||||
|
||||
public void remove(Player player) {
|
||||
public void remove(OfflinePlayer player) {
|
||||
dataSet.removeIf(pair -> pair.getFirst().equals(player));
|
||||
}
|
||||
|
||||
@Nullable
|
||||
public CustomLoginData get(Player player) {
|
||||
public LoginInfo get(OfflinePlayer player) {
|
||||
return dataSet.stream()
|
||||
.filter(pair -> pair.getFirst().equals(player))
|
||||
.map(Pair::getSecond)
|
||||
@ -44,7 +53,7 @@ public class LoginManager implements Baker {
|
||||
.orElse(null);
|
||||
}
|
||||
|
||||
public void set(Player player, CustomLoginData data) {
|
||||
public void set(OfflinePlayer player, LoginInfo data) {
|
||||
remove(player);
|
||||
add(player, data);
|
||||
}
|
||||
@ -54,8 +63,8 @@ public class LoginManager implements Baker {
|
||||
if (baked) return;
|
||||
|
||||
dataSet.forEach(pair -> {
|
||||
Player player = pair.getFirst();
|
||||
CustomLoginData data = pair.getSecond();
|
||||
OfflinePlayer player = pair.getFirst();
|
||||
LoginInfo data = pair.getSecond();
|
||||
|
||||
DBUser user = new DBUser(plugin.getSQLManager().establish());
|
||||
user.setLoginMessage(player.getUniqueId().toString(), data.getLoginMessage().toString());
|
||||
@ -74,14 +83,18 @@ public class LoginManager implements Baker {
|
||||
this.baked = false;
|
||||
}
|
||||
|
||||
private final class LoginListener extends AbstractListener {
|
||||
private static final class LoginListener extends AbstractListener {
|
||||
public LoginListener(Traverse plugin) {
|
||||
super(plugin);
|
||||
}
|
||||
|
||||
@EventHandler
|
||||
public void onLogin(PlayerLoginEvent event) {
|
||||
public void onLogin(PlayerJoinEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
DBUser user = new DBUser(getPlugin().getSQLManager().establish());
|
||||
LoginInfo info = user.getLoginInfo(player.getUniqueId().toString());
|
||||
user.close();
|
||||
event.joinMessage(info.getLoginMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user