13
0
geforkt von Mirrors/Paper

Add support for transitive depends in load access warning

By: md_5 <git@md-5.net>
Dieser Commit ist enthalten in:
Bukkit/Spigot 2020-01-28 12:43:25 +11:00
Ursprung d1676c9727
Commit 99378a8c91
2 geänderte Dateien mit 31 neuen und 4 gelöschten Zeilen

Datei anzeigen

@ -1,6 +1,10 @@
package org.bukkit.plugin; package org.bukkit.plugin;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.graph.GraphBuilder;
import com.google.common.graph.Graphs;
import com.google.common.graph.MutableGraph;
import java.io.File; import java.io.File;
import java.lang.reflect.Constructor; import java.lang.reflect.Constructor;
import java.lang.reflect.Method; import java.lang.reflect.Method;
@ -44,6 +48,7 @@ public final class SimplePluginManager implements PluginManager {
private final Map<Pattern, PluginLoader> fileAssociations = new HashMap<Pattern, PluginLoader>(); private final Map<Pattern, PluginLoader> fileAssociations = new HashMap<Pattern, PluginLoader>();
private final List<Plugin> plugins = new ArrayList<Plugin>(); private final List<Plugin> plugins = new ArrayList<Plugin>();
private final Map<String, Plugin> lookupNames = new HashMap<String, Plugin>(); private final Map<String, Plugin> lookupNames = new HashMap<String, Plugin>();
private MutableGraph<String> dependencyGraph = GraphBuilder.directed().build();
private File updateDirectory; private File updateDirectory;
private final SimpleCommandMap commandMap; private final SimpleCommandMap commandMap;
private final Map<String, Permission> permissions = new HashMap<String, Permission>(); private final Map<String, Permission> permissions = new HashMap<String, Permission>();
@ -168,11 +173,19 @@ public final class SimplePluginManager implements PluginManager {
} else { } else {
softDependencies.put(description.getName(), new LinkedList<String>(softDependencySet)); softDependencies.put(description.getName(), new LinkedList<String>(softDependencySet));
} }
for (String depend : softDependencySet) {
dependencyGraph.putEdge(description.getName(), depend);
}
} }
Collection<String> dependencySet = description.getDepend(); Collection<String> dependencySet = description.getDepend();
if (dependencySet != null && !dependencySet.isEmpty()) { if (dependencySet != null && !dependencySet.isEmpty()) {
dependencies.put(description.getName(), new LinkedList<String>(dependencySet)); dependencies.put(description.getName(), new LinkedList<String>(dependencySet));
for (String depend : dependencySet) {
dependencyGraph.putEdge(description.getName(), depend);
}
} }
Collection<String> loadBeforeSet = description.getLoadBefore(); Collection<String> loadBeforeSet = description.getLoadBefore();
@ -186,6 +199,8 @@ public final class SimplePluginManager implements PluginManager {
shortSoftDependency.add(description.getName()); shortSoftDependency.add(description.getName());
softDependencies.put(loadBeforeTarget, shortSoftDependency); softDependencies.put(loadBeforeTarget, shortSoftDependency);
} }
dependencyGraph.putEdge(loadBeforeTarget, description.getName());
} }
} }
} }
@ -480,6 +495,7 @@ public final class SimplePluginManager implements PluginManager {
disablePlugins(); disablePlugins();
plugins.clear(); plugins.clear();
lookupNames.clear(); lookupNames.clear();
dependencyGraph = GraphBuilder.directed().build();
HandlerList.unregisterAll(); HandlerList.unregisterAll();
fileAssociations.clear(); fileAssociations.clear();
permissions.clear(); permissions.clear();
@ -780,6 +796,13 @@ public final class SimplePluginManager implements PluginManager {
return new HashSet<Permission>(permissions.values()); return new HashSet<Permission>(permissions.values());
} }
public boolean isTransitiveDepend(@NotNull PluginDescriptionFile plugin, @NotNull Plugin depend) {
Preconditions.checkArgument(plugin != null, "plugin");
Preconditions.checkArgument(depend != null, "depend");
return Graphs.reachableNodes(dependencyGraph, plugin.getName()).contains(depend.getName());
}
@Override @Override
public boolean useTimings() { public boolean useTimings() {
return useTimings; return useTimings;

Datei anzeigen

@ -22,6 +22,7 @@ import java.util.logging.Level;
import org.apache.commons.lang.Validate; import org.apache.commons.lang.Validate;
import org.bukkit.plugin.InvalidPluginException; import org.bukkit.plugin.InvalidPluginException;
import org.bukkit.plugin.PluginDescriptionFile; import org.bukkit.plugin.PluginDescriptionFile;
import org.bukkit.plugin.SimplePluginManager;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
@ -113,12 +114,15 @@ final class PluginClassLoader extends URLClassLoader {
if (provider != plugin if (provider != plugin
&& !seenIllegalAccess.contains(providerName) && !seenIllegalAccess.contains(providerName)
&& !description.getDepend().contains(providerName) && !((SimplePluginManager) loader.server.getPluginManager()).isTransitiveDepend(description, provider)) {
&& !description.getSoftDepend().contains(providerName)
&& !provider.getDescription().getLoadBefore().contains(description.getName())) {
seenIllegalAccess.add(providerName); seenIllegalAccess.add(providerName);
if (plugin != null) {
plugin.getLogger().log(Level.WARNING, "Loaded class {0} from {1} which is not a depend, softdepend or loadbefore of this plugin.", new Object[]{name, provider.getDescription().getFullName()}); plugin.getLogger().log(Level.WARNING, "Loaded class {0} from {1} which is not a depend, softdepend or loadbefore of this plugin.", new Object[]{name, provider.getDescription().getFullName()});
} else {
// In case the bad access occurs on construction
loader.server.getLogger().log(Level.WARNING, "[{0}] Loaded class {1} from {2} which is not a depend, softdepend or loadbefore of this plugin.", new Object[]{description.getName(), name, provider.getDescription().getFullName()});
}
} }
} }
} }