Added API driven Rooms
This commit is contained in:
@ -1,5 +1,7 @@
|
||||
package eu.mhsl.minenet.minigames.handler.global;
|
||||
|
||||
import eu.mhsl.minenet.minigames.Main;
|
||||
import eu.mhsl.minenet.minigames.api.QueuedPlayerRooms;
|
||||
import eu.mhsl.minenet.minigames.instance.room.Room;
|
||||
import eu.mhsl.minenet.minigames.message.Icon;
|
||||
import eu.mhsl.minenet.minigames.message.type.ChatMessage;
|
||||
@ -11,7 +13,10 @@ import net.minestom.server.event.player.PlayerLoginEvent;
|
||||
import eu.mhsl.minenet.minigames.instance.hub.Hub;
|
||||
import net.minestom.server.permission.Permission;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.spongepowered.configurate.serialize.SerializationException;
|
||||
|
||||
import java.util.Objects;
|
||||
import java.util.UUID;
|
||||
import java.util.logging.Logger;
|
||||
|
||||
public class PlayerLoginHandler implements EventListener<PlayerLoginEvent> {
|
||||
@ -24,15 +29,24 @@ public class PlayerLoginHandler implements EventListener<PlayerLoginEvent> {
|
||||
public @NotNull Result run(@NotNull PlayerLoginEvent event) {
|
||||
Player p = event.getPlayer();
|
||||
|
||||
p.setRespawnPoint(Hub.INSTANCE.getSpawn());
|
||||
event.setSpawningInstance(Hub.INSTANCE);
|
||||
UUID pushQueue = QueuedPlayerRooms.pullQueue(event.getPlayer().getUuid());
|
||||
if(pushQueue != null) {
|
||||
Room target = Room.getRoom(pushQueue).orElseThrow();
|
||||
p.setRespawnPoint(target.getSpawn());
|
||||
event.setSpawningInstance(Hub.INSTANCE);
|
||||
MinecraftServer.getSchedulerManager().scheduleNextTick(() -> Room.setRoom(p, target));
|
||||
} else {
|
||||
p.setRespawnPoint(Hub.INSTANCE.getSpawn());
|
||||
event.setSpawningInstance(Hub.INSTANCE);
|
||||
}
|
||||
|
||||
SkinCache.applySkin(p);
|
||||
|
||||
|
||||
if(p.getUsername().equalsIgnoreCase("minetec")) {
|
||||
p.addPermission(new Permission("admin"));
|
||||
MinecraftServer.getSchedulerManager().scheduleNextTick(() -> Room.createRoom(p));
|
||||
}
|
||||
try {
|
||||
if(Objects.requireNonNull(Main.globalConfig.node("admins").getList(String.class)).stream().anyMatch(s -> s.equalsIgnoreCase(p.getUsername()))) {
|
||||
p.addPermission(new Permission("admin"));
|
||||
}
|
||||
} catch (SerializationException | NullPointerException ignored) {}
|
||||
|
||||
Logger.getLogger("user").info(p.getUsername() + " joined");
|
||||
|
||||
|
Reference in New Issue
Block a user