75% completion

This commit is contained in:
Paldiu
2023-01-30 21:16:50 -06:00
parent 5a48fb7285
commit 8f84583e4e
16 changed files with 401 additions and 55 deletions

View File

@ -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());
}
}
}