mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 21:31:25 +01:00
Fix plugin updater logic, allow null update directory (#8864)
This commit is contained in:
parent
6915dee3e3
commit
b0ce047eae
@ -467,9 +467,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import joptsimple.OptionSet;
|
+import joptsimple.OptionSet;
|
||||||
+import org.bukkit.configuration.file.YamlConfiguration;
|
+import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
+import org.jetbrains.annotations.NotNull;
|
+import org.jetbrains.annotations.NotNull;
|
||||||
|
+import org.jetbrains.annotations.Nullable;
|
||||||
+import org.slf4j.Logger;
|
+import org.slf4j.Logger;
|
||||||
+
|
+
|
||||||
+import java.io.File;
|
+import java.io.File;
|
||||||
|
+import java.io.IOException;
|
||||||
|
+import java.nio.file.Files;
|
||||||
+import java.nio.file.Path;
|
+import java.nio.file.Path;
|
||||||
+
|
+
|
||||||
+public class PluginInitializerManager {
|
+public class PluginInitializerManager {
|
||||||
@ -483,7 +486,37 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ // We have to load the bukkit configuration inorder to get the update folder location.
|
+ // We have to load the bukkit configuration inorder to get the update folder location.
|
||||||
+ File configFileLocationBukkit = (File) minecraftOptionSet.valueOf("bukkit-settings");
|
+ File configFileLocationBukkit = (File) minecraftOptionSet.valueOf("bukkit-settings");
|
||||||
+ this.pluginDirectory = ((File) minecraftOptionSet.valueOf("plugins")).toPath();
|
+ this.pluginDirectory = ((File) minecraftOptionSet.valueOf("plugins")).toPath();
|
||||||
+ this.updateDirectory = this.pluginDirectory.resolve(YamlConfiguration.loadConfiguration(configFileLocationBukkit).getString("settings.update-folder", "update"));
|
+
|
||||||
|
+ String updateDirectory = YamlConfiguration.loadConfiguration(configFileLocationBukkit).getString("settings.update-folder", "update");
|
||||||
|
+ if (updateDirectory.isBlank()) {
|
||||||
|
+ this.updateDirectory = null;
|
||||||
|
+ } else {
|
||||||
|
+ Path resolvedUpdateDirectory = this.pluginDirectory.resolve(updateDirectory);
|
||||||
|
+ if (!Files.isDirectory(resolvedUpdateDirectory)) {
|
||||||
|
+ this.updateDirectory = null;
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ boolean isSameFile = true;
|
||||||
|
+ try {
|
||||||
|
+ isSameFile = Files.isSameFile(resolvedUpdateDirectory, this.pluginDirectory);
|
||||||
|
+ } catch (IOException e) {
|
||||||
|
+ LOGGER.error("Misconfigured update directory!");
|
||||||
|
+ LOGGER.error("Failed to compare update/plugin directory", e);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (isSameFile) {
|
||||||
|
+ LOGGER.error("Misconfigured update directory!");
|
||||||
|
+ LOGGER.error(("Your configured update directory (%s) in bukkit.yml is pointing to the same location as the plugin directory (%s). " +
|
||||||
|
+ "Disabling auto updating functionality.").formatted(resolvedUpdateDirectory, this.pluginDirectory));
|
||||||
|
+
|
||||||
|
+ this.updateDirectory = null;
|
||||||
|
+ } else {
|
||||||
|
+ this.updateDirectory = resolvedUpdateDirectory;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ }
|
||||||
|
+
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public static PluginInitializerManager init(OptionSet optionSet) {
|
+ public static PluginInitializerManager init(OptionSet optionSet) {
|
||||||
@ -500,7 +533,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ return pluginDirectory;
|
+ return pluginDirectory;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @NotNull
|
+ @Nullable
|
||||||
+ public Path pluginUpdatePath() {
|
+ public Path pluginUpdatePath() {
|
||||||
+ return updateDirectory;
|
+ return updateDirectory;
|
||||||
+ }
|
+ }
|
||||||
@ -4691,10 +4724,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ try {
|
+ try {
|
||||||
+ this.checkUpdate(context);
|
+ context = this.checkUpdate(context);
|
||||||
+
|
+
|
||||||
+ JarFile file = new JarFile(context.toFile());
|
+ JarFile file = new JarFile(context.toFile());
|
||||||
+ PluginFileType<?,?> type = PluginFileType.guessType(file);
|
+ PluginFileType<?, ?> type = PluginFileType.guessType(file);
|
||||||
+ if (type == null) {
|
+ if (type == null) {
|
||||||
+ throw new IllegalArgumentException(source + " is not a valid plugin file, cannot load a plugin from it!");
|
+ throw new IllegalArgumentException(source + " is not a valid plugin file, cannot load a plugin from it!");
|
||||||
+ }
|
+ }
|
||||||
@ -4712,14 +4745,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ */
|
+ */
|
||||||
+ private Path checkUpdate(Path file) throws Exception {
|
+ private Path checkUpdate(Path file) throws Exception {
|
||||||
+ PluginInitializerManager pluginSystem = PluginInitializerManager.instance();
|
+ PluginInitializerManager pluginSystem = PluginInitializerManager.instance();
|
||||||
+ if (!Files.isDirectory(pluginSystem.pluginUpdatePath())) {
|
+ Path updateDirectory = pluginSystem.pluginUpdatePath();
|
||||||
|
+ if (updateDirectory == null || !Files.isDirectory(updateDirectory)) {
|
||||||
+ return file;
|
+ return file;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ try {
|
+ try {
|
||||||
+ String pluginName = this.getPluginName(file);
|
+ String pluginName = this.getPluginName(file);
|
||||||
+ UpdateFileVisitor visitor = new UpdateFileVisitor(pluginName);
|
+ UpdateFileVisitor visitor = new UpdateFileVisitor(pluginName);
|
||||||
+ Files.walkFileTree(pluginSystem.pluginUpdatePath(), Set.of(), 1, visitor);
|
+ Files.walkFileTree(updateDirectory, Set.of(), 1, visitor);
|
||||||
+ if (visitor.getValidPlugin() != null) {
|
+ if (visitor.getValidPlugin() != null) {
|
||||||
+ Path updateLocation = visitor.getValidPlugin();
|
+ Path updateLocation = visitor.getValidPlugin();
|
||||||
+
|
+
|
||||||
@ -4733,6 +4767,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ File newName = new File(file.toFile().getParentFile(), updateLocation.toFile().getName());
|
+ File newName = new File(file.toFile().getParentFile(), updateLocation.toFile().getName());
|
||||||
+ file.toFile().renameTo(newName);
|
+ file.toFile().renameTo(newName);
|
||||||
+ updateLocation.toFile().delete();
|
+ updateLocation.toFile().delete();
|
||||||
|
+ return newName.toPath();
|
||||||
+ }
|
+ }
|
||||||
+ } catch (Exception e) {
|
+ } catch (Exception e) {
|
||||||
+ throw new InvalidPluginException(e);
|
+ throw new InvalidPluginException(e);
|
||||||
|
Loading…
Reference in New Issue
Block a user