From 7112d4368f0993f4e83941bfa4fc3d1c78287d38 Mon Sep 17 00:00:00 2001 From: Ryan Ernst Date: Mon, 19 Mar 2018 19:58:03 -0700 Subject: [PATCH] Plugins: Fix module name conflict check for meta plugins (#29146) This commit moves the check for plugin names conflicting with builtin modules to a location that also applies to meta plugins. --- .../elasticsearch/plugins/InstallPluginCommand.java | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/distribution/tools/plugin-cli/src/main/java/org/elasticsearch/plugins/InstallPluginCommand.java b/distribution/tools/plugin-cli/src/main/java/org/elasticsearch/plugins/InstallPluginCommand.java index b7f201b70aa46..84f3764880243 100644 --- a/distribution/tools/plugin-cli/src/main/java/org/elasticsearch/plugins/InstallPluginCommand.java +++ b/distribution/tools/plugin-cli/src/main/java/org/elasticsearch/plugins/InstallPluginCommand.java @@ -532,6 +532,12 @@ private Path stagingDirectoryWithoutPosixPermissions(Path pluginsDir) throws IOE // checking for existing version of the plugin private void verifyPluginName(Path pluginPath, String pluginName, Path candidateDir) throws UserException, IOException { + // don't let user install plugin conflicting with module... + // they might be unavoidably in maven central and are packaged up the same way) + if (MODULES.contains(pluginName)) { + throw new UserException(ExitCodes.USAGE, "plugin '" + pluginName + "' cannot be installed as a plugin, it is a system module"); + } + final Path destination = pluginPath.resolve(pluginName); if (Files.exists(destination)) { final String message = String.format( @@ -574,13 +580,6 @@ private PluginInfo loadPluginInfo(Terminal terminal, Path pluginRoot, boolean is terminal.println(VERBOSE, info.toString()); - // don't let user install plugin as a module... - // they might be unavoidably in maven central and are packaged up the same way) - if (MODULES.contains(info.getName())) { - throw new UserException(ExitCodes.USAGE, "plugin '" + info.getName() + - "' cannot be installed like this, it is a system module"); - } - // check for jar hell before any copying jarHellCheck(info, pluginRoot, env.pluginsFile(), env.modulesFile());