mirror of
https://github.com/essentials/Essentials.git
synced 2025-09-29 15:49:21 +02:00
197 lines
6.1 KiB
Java
197 lines
6.1 KiB
Java
package com.earth2me.essentials.update;
|
|
|
|
import com.earth2me.essentials.update.states.Changelog;
|
|
import com.earth2me.essentials.update.states.EssentialsChat;
|
|
import com.earth2me.essentials.update.states.InstallationFinishedEvent;
|
|
import com.earth2me.essentials.update.states.StateMachine;
|
|
import com.earth2me.essentials.update.states.UpdateOrInstallation;
|
|
import com.earth2me.essentials.update.tasks.SelfUpdate;
|
|
import java.util.List;
|
|
import java.util.logging.Level;
|
|
import org.bukkit.Bukkit;
|
|
import org.bukkit.command.CommandSender;
|
|
import org.bukkit.entity.Player;
|
|
import org.bukkit.event.CustomEventListener;
|
|
import org.bukkit.event.Event;
|
|
import org.bukkit.event.Event.Priority;
|
|
import org.bukkit.event.Event.Type;
|
|
import org.bukkit.event.player.PlayerChatEvent;
|
|
import org.bukkit.event.player.PlayerJoinEvent;
|
|
import org.bukkit.event.player.PlayerListener;
|
|
import org.bukkit.plugin.Plugin;
|
|
import org.bukkit.plugin.PluginManager;
|
|
|
|
|
|
public class UpdateProcess extends PlayerListener
|
|
{
|
|
private transient Player currentPlayer;
|
|
private final transient Plugin plugin;
|
|
private final transient UpdateCheck updateCheck;
|
|
private transient StateMachine stateMachine;
|
|
|
|
public UpdateProcess(final Plugin plugin, final UpdateCheck updateCheck)
|
|
{
|
|
super();
|
|
this.plugin = plugin;
|
|
this.updateCheck = updateCheck;
|
|
}
|
|
|
|
public void registerEvents()
|
|
{
|
|
final PluginManager pluginManager = plugin.getServer().getPluginManager();
|
|
pluginManager.registerEvent(Type.PLAYER_QUIT, this, Priority.Low, plugin);
|
|
pluginManager.registerEvent(Type.PLAYER_CHAT, this, Priority.Lowest, plugin);
|
|
pluginManager.registerEvent(Type.PLAYER_JOIN, this, Priority.Normal, plugin);
|
|
pluginManager.registerEvent(Type.CUSTOM_EVENT, new CustomEventListener()
|
|
{
|
|
@Override
|
|
public void onCustomEvent(final Event event)
|
|
{
|
|
if (event instanceof InstallationFinishedEvent)
|
|
{
|
|
UpdateProcess.this.currentPlayer = null;
|
|
}
|
|
}
|
|
}, Priority.Normal, plugin);
|
|
}
|
|
|
|
public boolean selfUpdate()
|
|
{
|
|
if (new Version(plugin.getDescription().getVersion()).compareTo(updateCheck.getNewVersion()) < 0)
|
|
{
|
|
if (currentPlayer != null)
|
|
{
|
|
currentPlayer.sendMessage("A newer version of EssentialsUpdate is found. Downloading new file and reloading server.");
|
|
}
|
|
Bukkit.getLogger().log(Level.INFO, "A newer version of EssentialsUpdate is found. Downloading new file and reloading server.");
|
|
new SelfUpdate(new WorkListener(plugin, updateCheck.getNewVersionInfo())
|
|
{
|
|
@Override
|
|
public void onWorkAbort(final String message)
|
|
{
|
|
Bukkit.getLogger().log(Level.SEVERE, message);
|
|
}
|
|
|
|
@Override
|
|
public void onWorkDone(final String message)
|
|
{
|
|
Bukkit.getLogger().log(Level.INFO, message);
|
|
}
|
|
}).start();
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public void onPlayerChat(final PlayerChatEvent event)
|
|
{
|
|
if (event.getPlayer() == currentPlayer)
|
|
{
|
|
final StateMachine.MachineResult result = stateMachine.reactOnMessage(event.getMessage());
|
|
if (result == StateMachine.MachineResult.ABORT)
|
|
{
|
|
currentPlayer.sendMessage("Installation wizard aborted. You can restart it using /essentialsupdate.");
|
|
currentPlayer = null;
|
|
}
|
|
if (result == StateMachine.MachineResult.DONE)
|
|
{
|
|
startWork();
|
|
}
|
|
event.setCancelled(true);
|
|
return;
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void onPlayerJoin(final PlayerJoinEvent event)
|
|
{
|
|
final Player player = event.getPlayer();
|
|
if (currentPlayer.getName().equals(player.getName()))
|
|
{
|
|
currentPlayer = player;
|
|
player.sendMessage("You quit the game, while the installion wizard was running.");
|
|
player.sendMessage("The installation wizard will now resume.");
|
|
player.sendMessage("You can exit the wizard by typing quit into the chat.");
|
|
stateMachine.resumeInstallation(player);
|
|
}
|
|
if (player.hasPermission("essentials.update") && !updateCheck.isEssentialsInstalled())
|
|
{
|
|
player.sendMessage("Hello " + player.getDisplayName());
|
|
player.sendMessage("Please type /essentialsupdate into the chat to start the installation of Essentials.");
|
|
}
|
|
if (player.hasPermission("essentials.update"))
|
|
{
|
|
final UpdateCheck.CheckResult result = updateCheck.getResult();
|
|
switch (result)
|
|
{
|
|
case NEW_ESS:
|
|
player.sendMessage("The new version " + updateCheck.getNewVersion().toString() + " for Essentials is available. Please type /essentialsupdate to update.");
|
|
break;
|
|
case NEW_BUKKIT:
|
|
player.sendMessage("Your bukkit version is not the recommended build for Essentials, please update to version " + updateCheck.getNewBukkitVersion() + ".");
|
|
break;
|
|
case NEW_ESS_BUKKIT:
|
|
player.sendMessage("There is a new version " + updateCheck.getNewVersion().toString() + " of Essentials for Bukkit " + updateCheck.getNewBukkitVersion());
|
|
break;
|
|
default:
|
|
}
|
|
}
|
|
}
|
|
|
|
public void doAutomaticUpdate()
|
|
{
|
|
final VersionInfo info = updateCheck.getNewVersionInfo();
|
|
final List<String> changelog = info.getChangelog();
|
|
Bukkit.getLogger().log(Level.INFO, "Essentials changelog {0}", updateCheck.getNewVersion().toString());
|
|
for (String line : changelog)
|
|
{
|
|
Bukkit.getLogger().log(Level.INFO, " - {0}", line);
|
|
}
|
|
final UpdatesDownloader downloader = new UpdatesDownloader(plugin, info);
|
|
downloader.start();
|
|
}
|
|
|
|
public void onCommand(final CommandSender sender)
|
|
{
|
|
if (sender instanceof Player && sender.hasPermission("essentials.update"))
|
|
{
|
|
if (currentPlayer == null)
|
|
{
|
|
currentPlayer = (Player)sender;
|
|
if (selfUpdate())
|
|
{
|
|
return;
|
|
}
|
|
stateMachine = new StateMachine(plugin, currentPlayer, updateCheck);
|
|
final StateMachine.MachineResult result = stateMachine.askQuestion();
|
|
if (result == StateMachine.MachineResult.DONE)
|
|
{
|
|
startWork();
|
|
}
|
|
}
|
|
if (!currentPlayer.equals(sender))
|
|
{
|
|
sender.sendMessage("The player " + currentPlayer.getDisplayName() + " is already using the wizard.");
|
|
}
|
|
}
|
|
else
|
|
{
|
|
sender.sendMessage("Please run the command as op from in game.");
|
|
}
|
|
}
|
|
|
|
private void startWork()
|
|
{
|
|
currentPlayer.sendMessage("Installation wizard done. Starting installation.");
|
|
Bukkit.getScheduler().scheduleSyncDelayedTask(plugin, new Runnable()
|
|
{
|
|
@Override
|
|
public void run()
|
|
{
|
|
stateMachine.startWork();
|
|
}
|
|
});
|
|
}
|
|
}
|