package com.earth2me.essentials.spawn; import com.earth2me.essentials.Kit; import com.earth2me.essentials.OfflinePlayer; import com.earth2me.essentials.User; import com.earth2me.essentials.textreader.IText; import com.earth2me.essentials.textreader.KeywordReplacer; import com.earth2me.essentials.textreader.SimpleTextPager; import io.papermc.lib.PaperLib; import net.ess3.api.IEssentials; import org.bukkit.Location; import org.bukkit.entity.Player; import org.bukkit.event.Listener; import org.bukkit.event.player.PlayerJoinEvent; import org.bukkit.event.player.PlayerRespawnEvent; import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause; import java.util.List; import java.util.Locale; import java.util.logging.Level; import java.util.logging.Logger; import static com.earth2me.essentials.I18n.tl; class EssentialsSpawnPlayerListener implements Listener { private static final Logger logger = Logger.getLogger("EssentialsSpawn"); private final transient IEssentials ess; private final transient SpawnStorage spawns; EssentialsSpawnPlayerListener(final IEssentials ess, final SpawnStorage spawns) { super(); this.ess = ess; this.spawns = spawns; } void onPlayerRespawn(final PlayerRespawnEvent event) { final User user = ess.getUser(event.getPlayer()); if (user.isJailed() && user.getJail() != null && !user.getJail().isEmpty()) { return; } if (ess.getSettings().getRespawnAtHome()) { Location home; final Location bed = user.getBase().getBedSpawnLocation(); if (bed != null) { home = bed; } else { home = user.getHome(user.getLocation()); } if (home != null) { event.setRespawnLocation(home); return; } } final Location spawn = spawns.getSpawn(user.getGroup()); if (spawn != null) { event.setRespawnLocation(spawn); } } void onPlayerJoin(final PlayerJoinEvent event) { ess.runTaskAsynchronously(() -> delayedJoin(event.getPlayer())); } private void delayedJoin(final Player player) { if (player.hasPlayedBefore()) { logger.log(Level.FINE, "Old player join"); List spawnOnJoinGroups = ess.getSettings().getSpawnOnJoinGroups(); if (!spawnOnJoinGroups.isEmpty()) { final User user = ess.getUser(player); if (ess.getSettings().isUserInSpawnOnJoinGroup(user) && !user.isAuthorized("essentials.spawn-on-join.exempt")) { ess.scheduleSyncDelayedTask(() -> { Location spawn = spawns.getSpawn(user.getGroup()); try { // We don't use user.getTeleport() because it stores last location, which is unwanted in this case. PaperLib.teleportAsync(user.getBase(), spawn); } catch (Exception e) { ess.showError(user.getSource(), e, "spawn-on-join"); } }); } } return; } final User user = ess.getUser(player); if (!"none".equalsIgnoreCase(ess.getSettings().getNewbieSpawn())) { ess.scheduleSyncDelayedTask(new NewPlayerTeleport(user), 1L); } ess.scheduleSyncDelayedTask(() -> { if (!user.getBase().isOnline()) { return; } //This method allows for multiple line player announce messages using multiline yaml syntax #EasterEgg if (ess.getSettings().getAnnounceNewPlayers()) { final IText output = new KeywordReplacer(ess.getSettings().getAnnounceNewPlayerFormat(), user.getSource(), ess); final SimpleTextPager pager = new SimpleTextPager(output); for (String line : pager.getLines()) { ess.broadcastMessage(user, line); } } final String kitName = ess.getSettings().getNewPlayerKit(); if (!kitName.isEmpty()) { try { final Kit kit = new Kit(kitName.toLowerCase(Locale.ENGLISH), ess); kit.expandItems(user); } catch (Exception ex) { logger.log(Level.WARNING, ex.getMessage()); } } logger.log(Level.FINE, "New player join"); }, 2L); } private class NewPlayerTeleport implements Runnable { private final transient User user; NewPlayerTeleport(final User user) { this.user = user; } @Override public void run() { if (user.getBase() instanceof OfflinePlayer || !user.getBase().isOnline()) { return; } try { final Location spawn = spawns.getSpawn(ess.getSettings().getNewbieSpawn()); if (spawn != null) { user.getTeleport().now(spawn, false, TeleportCause.PLUGIN); } } catch (Exception ex) { logger.log(Level.WARNING, tl("teleportNewPlayerError"), ex); } } } }