Ignore invalid jars inside of the updates folder (Fixes #7751)

This really needs a deeper look here, the way updates are handled is
fairly immature, but, this wasn't ever intended to be a large scale thing

Ideally, imho, we'd collect the list of update files into some form of Map,
that way we just have a reference of Name > File refs, and can filter out
cases where there are two versions of a plugin in there and warn expectidely,
but, that creates some complications, you would need to fall back to a dir
scan in the case of a plugin calling loadPlugin, but, it would at least
give us more defined behavior, as well as improve performance here vs
repeatidely trying to deserialise the plugin.yml defs for every file
in there on every load
This commit is contained in:
Shane Freeder 2022-04-20 10:00:50 +01:00
parent 68ff86040e
commit 2b927737c9

View File

@ -32,7 +32,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
if (updateDirectory == null || !updateDirectory.isDirectory()) { if (updateDirectory == null || !updateDirectory.isDirectory()) {
- return; - return;
+ return file; + return file;
} + }
+ PluginLoader pluginLoader = getPluginLoader(file); + PluginLoader pluginLoader = getPluginLoader(file);
+ try { + try {
+ String pluginName = pluginLoader.getPluginDescription(file).getName(); + String pluginName = pluginLoader.getPluginDescription(file).getName();
@ -40,7 +40,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+ if (!updateFile.isFile()) continue; + if (!updateFile.isFile()) continue;
+ PluginLoader updatePluginLoader = getPluginLoader(updateFile); + PluginLoader updatePluginLoader = getPluginLoader(updateFile);
+ if (updatePluginLoader == null) continue; + if (updatePluginLoader == null) continue;
+ String updatePluginName = updatePluginLoader.getPluginDescription(updateFile).getName(); + String updatePluginName;
+ try {
+ updatePluginName = updatePluginLoader.getPluginDescription(updateFile).getName();
+ // We failed to load this data for some reason, so, we'll skip over this
+ } catch (InvalidDescriptionException ex) {
+ continue;
+ }
+ if (!pluginName.equals(updatePluginName)) continue; + if (!pluginName.equals(updatePluginName)) continue;
+ if (!FileUtil.copy(updateFile, file)) continue; + if (!FileUtil.copy(updateFile, file)) continue;
+ File newName = new File(file.getParentFile(), updateFile.getName()); + File newName = new File(file.getParentFile(), updateFile.getName());
@ -51,7 +57,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+ } + }
+ catch (InvalidDescriptionException e) { + catch (InvalidDescriptionException e) {
+ throw new InvalidPluginException(e); + throw new InvalidPluginException(e);
+ } }
+ return file; + return file;
+ } + }