Work around circular dependency in core

There is a circular dependency in core 1.4.0 that cause plugins to fail depending on their constructors injection. We have ClusterService in InternalAuthorizationService that triggers this problem, solved for now replacing the dependency with a Provider. The original bug is already fixed in core: https://github.com/elasticsearch/elasticsearch/pull/8415 .

The problem manifested when enablieng a tribe node having shield installed on that node at the same time.

Closes elastic/elasticsearch#363

Original commit: elastic/x-pack-elasticsearch@ac339ef247
This commit is contained in:
javanna 2014-11-21 10:45:10 +01:00 committed by Luca Cavanna
parent 8397112422
commit f2abfb35f9
1 changed files with 12 additions and 5 deletions

View File

@ -5,6 +5,7 @@
*/ */
package org.elasticsearch.shield.authz; package org.elasticsearch.shield.authz;
import org.elasticsearch.Version;
import org.elasticsearch.action.CompositeIndicesRequest; import org.elasticsearch.action.CompositeIndicesRequest;
import org.elasticsearch.action.IndicesRequest; import org.elasticsearch.action.IndicesRequest;
import org.elasticsearch.cluster.ClusterService; import org.elasticsearch.cluster.ClusterService;
@ -14,6 +15,7 @@ import org.elasticsearch.common.base.Predicates;
import org.elasticsearch.common.collect.ImmutableList; import org.elasticsearch.common.collect.ImmutableList;
import org.elasticsearch.common.component.AbstractComponent; import org.elasticsearch.common.component.AbstractComponent;
import org.elasticsearch.common.inject.Inject; import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.common.inject.Provider;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.shield.User; import org.elasticsearch.shield.User;
import org.elasticsearch.shield.audit.AuditTrail; import org.elasticsearch.shield.audit.AuditTrail;
@ -31,16 +33,21 @@ import java.util.Set;
*/ */
public class InternalAuthorizationService extends AbstractComponent implements AuthorizationService { public class InternalAuthorizationService extends AbstractComponent implements AuthorizationService {
private final ClusterService clusterService; private final Provider<ClusterService> clusterServiceProvider;
private final RolesStore rolesStore; private final RolesStore rolesStore;
private final AuditTrail auditTrail; private final AuditTrail auditTrail;
private final IndicesResolver[] indicesResolvers; private final IndicesResolver[] indicesResolvers;
static {
//see https://github.com/elasticsearch/elasticsearch/pull/8415
assert Version.CURRENT.onOrBefore(Version.V_1_4_0) : "replace the Provider<ClusterService> with ClusterService";
}
@Inject @Inject
public InternalAuthorizationService(Settings settings, RolesStore rolesStore, ClusterService clusterService, AuditTrail auditTrail) { public InternalAuthorizationService(Settings settings, RolesStore rolesStore, Provider<ClusterService> clusterServiceProvider, AuditTrail auditTrail) {
super(settings); super(settings);
this.rolesStore = rolesStore; this.rolesStore = rolesStore;
this.clusterService = clusterService; this.clusterServiceProvider = clusterServiceProvider;
this.auditTrail = auditTrail; this.auditTrail = auditTrail;
this.indicesResolvers = new IndicesResolver[] { this.indicesResolvers = new IndicesResolver[] {
new DefaultIndicesResolver(this) new DefaultIndicesResolver(this)
@ -63,7 +70,7 @@ public class InternalAuthorizationService extends AbstractComponent implements A
ImmutableList.Builder<String> indicesAndAliases = ImmutableList.builder(); ImmutableList.Builder<String> indicesAndAliases = ImmutableList.builder();
Predicate<String> predicate = Predicates.or(predicates.build()); Predicate<String> predicate = Predicates.or(predicates.build());
MetaData metaData = clusterService.state().metaData(); MetaData metaData = clusterServiceProvider.get().state().metaData();
for (String index : metaData.concreteAllIndices()) { for (String index : metaData.concreteAllIndices()) {
if (predicate.apply(index)) { if (predicate.apply(index)) {
indicesAndAliases.add(index); indicesAndAliases.add(index);
@ -176,7 +183,7 @@ public class InternalAuthorizationService extends AbstractComponent implements A
} }
private Set<String> resolveIndices(User user, String action, TransportRequest request) { private Set<String> resolveIndices(User user, String action, TransportRequest request) {
MetaData metaData = clusterService.state().metaData(); MetaData metaData = clusterServiceProvider.get().state().metaData();
// some APIs are indices requests that are not actually associated with indices. For example, // some APIs are indices requests that are not actually associated with indices. For example,
// search scroll request, is categorized under the indices context, but doesn't hold indices names // search scroll request, is categorized under the indices context, but doesn't hold indices names