NPE in PluginsService when starting elasticsearch with a wrong user
When starting elasticsearch with a wrong linux user, it could generate a `NullPointerException` when `PluginsService` tries to list available plugins in `./plugins` dir. To reproduce: * create a plugins directory with `rwx` rights for root user only * launch elasticsearch from another account (elasticsearch for example) It was supposed to be fixed with #4186, but sadly it's not :-( Closes #5195.
This commit is contained in:
parent
03ad168b24
commit
ad8a482d19
|
@ -228,6 +228,28 @@ public class FileSystemUtils {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Check that a directory exists, is a directory and is readable
|
||||
* by the current user
|
||||
*/
|
||||
public static boolean isAccessibleDirectory(File directory, ESLogger logger) {
|
||||
assert directory != null && logger != null;
|
||||
|
||||
if (!directory.exists()) {
|
||||
logger.debug("[{}] directory does not exist.", directory.getAbsolutePath());
|
||||
return false;
|
||||
}
|
||||
if (!directory.isDirectory()) {
|
||||
logger.debug("[{}] should be a directory but is not.", directory.getAbsolutePath());
|
||||
return false;
|
||||
}
|
||||
if (!directory.canRead()) {
|
||||
logger.debug("[{}] directory is not readable.", directory.getAbsolutePath());
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
private FileSystemUtils() {
|
||||
|
||||
}
|
||||
|
|
|
@ -44,6 +44,8 @@ import java.lang.reflect.Method;
|
|||
import java.net.URL;
|
||||
import java.util.*;
|
||||
|
||||
import static org.elasticsearch.common.io.FileSystemUtils.isAccessibleDirectory;
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
|
@ -316,11 +318,8 @@ public class PluginsService extends AbstractComponent {
|
|||
}
|
||||
|
||||
private void loadPluginsIntoClassLoader() {
|
||||
File pluginsFile = environment.pluginsFile();
|
||||
if (!pluginsFile.exists()) {
|
||||
return;
|
||||
}
|
||||
if (!pluginsFile.isDirectory()) {
|
||||
File pluginsDirectory = environment.pluginsFile();
|
||||
if (!isAccessibleDirectory(pluginsDirectory, logger)) {
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -342,22 +341,23 @@ public class PluginsService extends AbstractComponent {
|
|||
return;
|
||||
}
|
||||
|
||||
File[] pluginsFiles = pluginsFile.listFiles();
|
||||
if (pluginsFile != null) {
|
||||
for (File pluginFile : pluginsFiles) {
|
||||
if (pluginFile.isDirectory()) {
|
||||
if (logger.isTraceEnabled()) {
|
||||
logger.trace("--- adding plugin [" + pluginFile.getAbsolutePath() + "]");
|
||||
for (File plugin : pluginsDirectory.listFiles()) {
|
||||
// We check that subdirs are directories and readable
|
||||
if (!isAccessibleDirectory(plugin, logger)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
logger.trace("--- adding plugin [{}]", plugin.getAbsolutePath());
|
||||
|
||||
try {
|
||||
// add the root
|
||||
addURL.invoke(classLoader, pluginFile.toURI().toURL());
|
||||
addURL.invoke(classLoader, plugin.toURI().toURL());
|
||||
// gather files to add
|
||||
List<File> libFiles = Lists.newArrayList();
|
||||
if (pluginFile.listFiles() != null) {
|
||||
libFiles.addAll(Arrays.asList(pluginFile.listFiles()));
|
||||
if (plugin.listFiles() != null) {
|
||||
libFiles.addAll(Arrays.asList(plugin.listFiles()));
|
||||
}
|
||||
File libLocation = new File(pluginFile, "lib");
|
||||
File libLocation = new File(plugin, "lib");
|
||||
if (libLocation.exists() && libLocation.isDirectory() && libLocation.listFiles() != null) {
|
||||
libFiles.addAll(Arrays.asList(libLocation.listFiles()));
|
||||
}
|
||||
|
@ -370,14 +370,10 @@ public class PluginsService extends AbstractComponent {
|
|||
addURL.invoke(classLoader, libFile.toURI().toURL());
|
||||
}
|
||||
} catch (Throwable e) {
|
||||
logger.warn("failed to add plugin [" + pluginFile + "]", e);
|
||||
logger.warn("failed to add plugin [" + plugin + "]", e);
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
logger.debug("failed to list plugins from {}. Check your right access.", pluginsFile.getAbsolutePath());
|
||||
}
|
||||
}
|
||||
|
||||
private ImmutableList<Tuple<PluginInfo,Plugin>> loadPluginsFromClasspath(Settings settings) {
|
||||
ImmutableList.Builder<Tuple<PluginInfo, Plugin>> plugins = ImmutableList.builder();
|
||||
|
@ -398,7 +394,7 @@ public class PluginsService extends AbstractComponent {
|
|||
|
||||
// Is it a site plugin as well? Does it have also an embedded _site structure
|
||||
File siteFile = new File(new File(environment.pluginsFile(), plugin.name()), "_site");
|
||||
boolean isSite = siteFile.exists() && siteFile.isDirectory();
|
||||
boolean isSite = isAccessibleDirectory(siteFile, logger);
|
||||
if (logger.isTraceEnabled()) {
|
||||
logger.trace("found a jvm plugin [{}], [{}]{}",
|
||||
plugin.name(), plugin.description(), isSite ? ": with _site structure" : "");
|
||||
|
@ -441,7 +437,7 @@ public class PluginsService extends AbstractComponent {
|
|||
for (File pluginFile : pluginsFile.listFiles()) {
|
||||
if (!loadedJvmPlugins.contains(pluginFile.getName())) {
|
||||
File sitePluginDir = new File(pluginFile, "_site");
|
||||
if (sitePluginDir.exists()) {
|
||||
if (isAccessibleDirectory(sitePluginDir, logger)) {
|
||||
// We have a _site plugin. Let's try to get more information on it
|
||||
String name = pluginFile.getName();
|
||||
String version = PluginInfo.VERSION_NOT_AVAILABLE;
|
||||
|
@ -491,7 +487,7 @@ public class PluginsService extends AbstractComponent {
|
|||
}
|
||||
|
||||
File sitePluginDir = new File(pluginsFile, name + "/_site");
|
||||
return sitePluginDir.exists();
|
||||
return isAccessibleDirectory(sitePluginDir, logger);
|
||||
}
|
||||
|
||||
private Plugin loadPlugin(String className, Settings settings) {
|
||||
|
|
Loading…
Reference in New Issue