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:
parent
8397112422
commit
f2abfb35f9
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue