2011-03-19 23:39:51 +01:00
|
|
|
package com.earth2me.essentials.spawn;
|
|
|
|
|
2022-06-27 20:54:10 +02:00
|
|
|
import com.earth2me.essentials.EssentialsLogger;
|
2020-07-05 20:30:01 +02:00
|
|
|
import com.earth2me.essentials.metrics.MetricsWrapper;
|
2013-07-13 18:40:50 +02:00
|
|
|
import net.ess3.api.IEssentials;
|
2013-10-24 13:40:58 +02:00
|
|
|
import org.bukkit.Location;
|
2011-07-16 01:33:22 +02:00
|
|
|
import org.bukkit.command.Command;
|
|
|
|
import org.bukkit.command.CommandSender;
|
2017-09-16 16:23:56 +02:00
|
|
|
import org.bukkit.event.EventPriority;
|
2012-01-20 05:34:28 +01:00
|
|
|
import org.bukkit.event.player.PlayerJoinEvent;
|
|
|
|
import org.bukkit.event.player.PlayerRespawnEvent;
|
2011-07-16 01:33:22 +02:00
|
|
|
import org.bukkit.plugin.PluginManager;
|
|
|
|
import org.bukkit.plugin.java.JavaPlugin;
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
import java.util.logging.Level;
|
2022-06-27 20:54:10 +02:00
|
|
|
import java.util.logging.Logger;
|
2015-04-15 06:06:16 +02:00
|
|
|
|
|
|
|
import static com.earth2me.essentials.I18n.tl;
|
|
|
|
|
|
|
|
public class EssentialsSpawn extends JavaPlugin implements IEssentialsSpawn {
|
|
|
|
private transient IEssentials ess;
|
|
|
|
private transient SpawnStorage spawns;
|
2020-07-05 20:30:01 +02:00
|
|
|
private transient MetricsWrapper metrics = null;
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
@Override
|
|
|
|
public void onEnable() {
|
2022-07-02 20:50:45 +02:00
|
|
|
EssentialsLogger.updatePluginLogger(this);
|
2015-04-15 06:06:16 +02:00
|
|
|
final PluginManager pluginManager = getServer().getPluginManager();
|
|
|
|
ess = (IEssentials) pluginManager.getPlugin("Essentials");
|
|
|
|
if (!this.getDescription().getVersion().equals(ess.getDescription().getVersion())) {
|
2019-01-05 19:42:09 +01:00
|
|
|
getLogger().log(Level.WARNING, tl("versionMismatchAll"));
|
2015-04-15 06:06:16 +02:00
|
|
|
}
|
|
|
|
if (!ess.isEnabled()) {
|
|
|
|
this.setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2011-12-06 13:41:29 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
spawns = new SpawnStorage(ess);
|
|
|
|
ess.addReloadListener(spawns);
|
2011-12-06 13:41:29 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
final EssentialsSpawnPlayerListener playerListener = new EssentialsSpawnPlayerListener(ess, spawns);
|
2017-09-16 16:23:56 +02:00
|
|
|
|
2020-10-03 19:46:05 +02:00
|
|
|
final EventPriority respawnPriority = ess.getSettings().getRespawnPriority();
|
2017-09-16 16:23:56 +02:00
|
|
|
if (respawnPriority != null) {
|
2019-01-05 19:42:09 +01:00
|
|
|
pluginManager.registerEvent(PlayerRespawnEvent.class, playerListener, respawnPriority, (ll, event) ->
|
2020-10-03 19:46:05 +02:00
|
|
|
((EssentialsSpawnPlayerListener) ll).onPlayerRespawn((PlayerRespawnEvent) event), this);
|
2017-09-16 16:23:56 +02:00
|
|
|
}
|
|
|
|
|
2020-10-03 19:46:05 +02:00
|
|
|
final EventPriority joinPriority = ess.getSettings().getSpawnJoinPriority();
|
2017-09-16 16:23:56 +02:00
|
|
|
if (joinPriority != null) {
|
2019-01-05 19:42:09 +01:00
|
|
|
pluginManager.registerEvent(PlayerJoinEvent.class, playerListener, joinPriority, (ll, event) ->
|
2020-10-03 19:46:05 +02:00
|
|
|
((EssentialsSpawnPlayerListener) ll).onPlayerJoin((PlayerJoinEvent) event), this);
|
2017-09-16 16:23:56 +02:00
|
|
|
}
|
2019-01-05 18:48:44 +01:00
|
|
|
|
|
|
|
if (metrics == null) {
|
2020-07-05 20:30:01 +02:00
|
|
|
metrics = new MetricsWrapper(this, 3817, true);
|
2019-01-05 18:48:44 +01:00
|
|
|
}
|
2015-04-15 06:06:16 +02:00
|
|
|
}
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2022-06-27 20:54:10 +02:00
|
|
|
public static Logger getWrappedLogger() {
|
|
|
|
try {
|
|
|
|
return EssentialsLogger.getLoggerProvider("EssentialsSpawn");
|
|
|
|
} catch (Throwable ignored) {
|
|
|
|
// In case Essentials isn't installed/loaded
|
|
|
|
return Logger.getLogger("EssentialsSpawn");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
@Override
|
|
|
|
public void onDisable() {
|
|
|
|
}
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
@Override
|
|
|
|
public boolean onCommand(final CommandSender sender, final Command command, final String commandLabel, final String[] args) {
|
2020-07-05 20:30:01 +02:00
|
|
|
metrics.markCommand(command.getName(), true);
|
2015-04-15 06:06:16 +02:00
|
|
|
return ess.onCommandEssentials(sender, command, commandLabel, args, EssentialsSpawn.class.getClassLoader(), "com.earth2me.essentials.spawn.Command", "essentials.", spawns);
|
|
|
|
}
|
2013-10-24 13:40:58 +02:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
@Override
|
2020-10-03 19:46:05 +02:00
|
|
|
public void setSpawn(final Location loc, final String group) {
|
2015-04-15 06:06:16 +02:00
|
|
|
if (group == null) {
|
|
|
|
throw new IllegalArgumentException("Null group");
|
|
|
|
}
|
|
|
|
spawns.setSpawn(loc, group);
|
|
|
|
}
|
2013-10-24 13:40:58 +02:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
@Override
|
2020-10-03 19:46:05 +02:00
|
|
|
public Location getSpawn(final String group) {
|
2015-04-15 06:06:16 +02:00
|
|
|
if (group == null) {
|
|
|
|
throw new IllegalArgumentException("Null group");
|
|
|
|
}
|
|
|
|
return spawns.getSpawn(group);
|
|
|
|
}
|
2011-03-19 23:39:51 +01:00
|
|
|
}
|