-
Notifications
You must be signed in to change notification settings - Fork 25k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Mandate X-Pack REST handler installed #71061
Changes from all commits
a19e287
8bc8643
7fe071c
e6b1581
f707583
b7bb95b
b18a6be
cc5bce6
b1b00f0
d0f0252
a0fba39
065fb8e
75dc96b
0e99823
9fd1481
6e176b4
7651421
e3f28ff
b1b51fd
7ca2084
6bfc65c
80d75b3
356636d
e90511c
16dcd6c
5713478
4a8aa48
4fa2895
81b64d3
f729748
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -235,8 +235,6 @@ | |
import org.elasticsearch.common.inject.AbstractModule; | ||
import org.elasticsearch.common.inject.TypeLiteral; | ||
import org.elasticsearch.common.inject.multibindings.MapBinder; | ||
import org.elasticsearch.common.logging.DeprecationCategory; | ||
import org.elasticsearch.common.logging.DeprecationLogger; | ||
import org.elasticsearch.common.settings.ClusterSettings; | ||
import org.elasticsearch.common.settings.IndexScopedSettings; | ||
import org.elasticsearch.common.settings.Settings; | ||
|
@@ -403,7 +401,6 @@ | |
public class ActionModule extends AbstractModule { | ||
|
||
private static final Logger logger = LogManager.getLogger(ActionModule.class); | ||
private static final DeprecationLogger deprecationLogger = DeprecationLogger.getLogger(logger.getName()); | ||
|
||
private final Settings settings; | ||
private final IndexNameExpressionResolver indexNameExpressionResolver; | ||
|
@@ -444,17 +441,15 @@ public ActionModule(Settings settings, IndexNameExpressionResolver indexNameExpr | |
UnaryOperator<RestHandler> newRestWrapper = plugin.getRestHandlerWrapper(threadPool.getThreadContext()); | ||
if (newRestWrapper != null) { | ||
logger.debug("Using REST wrapper from plugin " + plugin.getClass().getName()); | ||
if (plugin.getClass().getCanonicalName() == null || | ||
plugin.getClass().getCanonicalName().startsWith("org.elasticsearch.xpack") == false) { | ||
throw new IllegalArgumentException("The " + plugin.getClass().getName() + " plugin tried to install a custom REST " + | ||
"wrapper. This functionality is not available anymore."); | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Per #73329, there should be tests for this functionality in ActionModuleTests. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Moved it to ActionModuleTests |
||
if (restWrapper != null) { | ||
throw new IllegalArgumentException("Cannot have more than one plugin implementing a REST wrapper"); | ||
} | ||
restWrapper = newRestWrapper; | ||
if (restWrapper.getClass().getCanonicalName() == null || | ||
restWrapper.getClass().getCanonicalName().startsWith("org.elasticsearch") == false) { | ||
deprecationLogger.deprecate(DeprecationCategory.PLUGINS, "3rd_party_rest_deprecation", "The " + | ||
plugin.getClass().getName() + "plugin installs a custom REST wrapper. This functionality is deprecated and will " + | ||
"not be possible in Elasticsearch 8.0. If this plugin is intended to provide security features for Elasticsearch " + | ||
"then you should switch to using the built-in Elasticsearch features instead."); | ||
} | ||
} | ||
} | ||
mappingRequestValidators = new RequestValidators<>( | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nit: I probably missed the discussion about why we prefer
getCanonicalName
over justgetName
here. But it seems to me thatgetName
is more consistent since that is what we report in the error message (and also the debug log above)?