Merge branch 'master' of github.com:elastic/x-plugins

Original commit: elastic/x-pack-elasticsearch@338f72d58b
This commit is contained in:
Timothy Sullivan 2015-12-07 10:15:43 -07:00
commit c040840e7e
10 changed files with 42 additions and 69 deletions

View File

@ -10,5 +10,6 @@ integTest {
plugin 'x-pack', project(':x-plugins:elasticsearch:x-pack')
systemProperty 'es.script.inline', 'on'
systemProperty 'es.shield.enabled', 'false'
systemProperty 'es.marvel.enabled', 'false'
}
}

View File

@ -22,7 +22,7 @@ import org.elasticsearch.marvel.agent.settings.MarvelModule;
import org.elasticsearch.marvel.agent.settings.MarvelSettings;
import org.elasticsearch.marvel.license.LicenseModule;
import org.elasticsearch.marvel.license.MarvelLicensee;
import org.elasticsearch.marvel.shield.MarvelInternalUserHolder;
import org.elasticsearch.marvel.shield.InternalMarvelUser;
import org.elasticsearch.marvel.shield.MarvelShieldIntegration;
import org.elasticsearch.marvel.shield.MarvelShieldModule;
import org.elasticsearch.plugins.Plugin;
@ -106,7 +106,7 @@ public class MarvelPlugin extends Plugin {
// is enabled. This is a temporary solution until inter-plugin-communication can be worked out.
public void onModule(Module module) {
if (enabled && MarvelShieldIntegration.enabled(settings) && module instanceof AuthorizationModule) {
((AuthorizationModule)module).registerReservedRole(MarvelInternalUserHolder.ROLE);
((AuthorizationModule)module).registerReservedRole(InternalMarvelUser.ROLE);
}
}

View File

@ -11,16 +11,17 @@ import org.elasticsearch.marvel.agent.settings.MarvelSettings;
import org.elasticsearch.shield.User;
import org.elasticsearch.shield.authz.Permission;
import org.elasticsearch.shield.authz.Privilege;
import org.elasticsearch.transport.TransportMessage;
/**
*
*/
public class MarvelInternalUserHolder {
public class InternalMarvelUser extends User.Simple {
static final String NAME = "__marvel_user";
static final String[] ROLE_NAMES = new String[] { "__marvel_role" };
public static final InternalMarvelUser INSTANCE = new InternalMarvelUser(NAME, ROLE_NAMES);
public static final Permission.Global.Role ROLE = Permission.Global.Role.builder(ROLE_NAMES[0])
.cluster(Privilege.Cluster.get(new Privilege.Name(
PutIndexTemplateAction.NAME + "*",
@ -38,9 +39,7 @@ public class MarvelInternalUserHolder {
.build();
final User user = new User.Simple(NAME, ROLE_NAMES);
public void bindUser(TransportMessage<?> message) {
InternalMarvelUser(String username, String[] roles) {
super(username, roles);
}
}

View File

@ -6,12 +6,10 @@
package org.elasticsearch.marvel.shield;
import org.elasticsearch.ElasticsearchException;
import org.elasticsearch.common.HasContext;
import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.common.inject.Injector;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.shield.ShieldPlugin;
import org.elasticsearch.xpack.XPackPlugin;
import org.elasticsearch.shield.ShieldSettingsFilter;
import org.elasticsearch.shield.authc.AuthenticationService;
import org.elasticsearch.transport.TransportMessage;
@ -23,45 +21,35 @@ import java.io.IOException;
*/
public class MarvelShieldIntegration {
private final Object authcService;
private final Object userHolder;
private final Object settingsFilter;
private final boolean enabled;
private final AuthenticationService authcService;
private final ShieldSettingsFilter settingsFilter;
@Inject
public MarvelShieldIntegration(Settings settings, Injector injector) {
boolean enabled = enabled(settings);
enabled = enabled(settings);
authcService = enabled ? injector.getInstance(AuthenticationService.class) : null;
userHolder = enabled ? injector.getInstance(MarvelInternalUserHolder.class) : null;
settingsFilter = enabled ? injector.getInstance(ShieldSettingsFilter.class) : null;
}
public void bindInternalMarvelUser(TransportMessage message) {
if (authcService != null) {
try {
((AuthenticationService) authcService).attachUserHeaderIfMissing(message, ((MarvelInternalUserHolder) userHolder).user);
authcService.attachUserHeaderIfMissing(message, InternalMarvelUser.INSTANCE);
} catch (IOException e) {
throw new ElasticsearchException("failed to attach watcher user to request", e);
throw new ElasticsearchException("failed to attach marvel user to request", e);
}
}
}
public void filterOutSettings(String... patterns) {
if (settingsFilter != null) {
((ShieldSettingsFilter) settingsFilter).filterOut(patterns);
}
}
static boolean installed() {
try {
MarvelShieldIntegration.class.getClassLoader().loadClass("org.elasticsearch.shield.ShieldPlugin");
return true;
} catch (ClassNotFoundException e) {
return false;
settingsFilter.filterOut(patterns);
}
}
public static boolean enabled(Settings settings) {
return installed() && ShieldPlugin.shieldEnabled(settings);
return ShieldPlugin.shieldEnabled(settings);
}
}

View File

@ -6,7 +6,6 @@
package org.elasticsearch.marvel.shield;
import org.elasticsearch.common.inject.AbstractModule;
import org.elasticsearch.common.inject.util.Providers;
import org.elasticsearch.common.settings.Settings;
/**
@ -14,19 +13,16 @@ import org.elasticsearch.common.settings.Settings;
*/
public class MarvelShieldModule extends AbstractModule {
private final MarvelInternalUserHolder userHolder;
private final boolean enabled;
public MarvelShieldModule(Settings settings) {
this.enabled = MarvelShieldIntegration.enabled(settings);
userHolder = enabled ? new MarvelInternalUserHolder() : null;
}
@Override
protected void configure() {
bind(MarvelShieldIntegration.class).asEagerSingleton();
bind(SecuredClient.class).asEagerSingleton();
bind(MarvelInternalUserHolder.class).toProvider(Providers.of(userHolder));
if (enabled) {
bind(MarvelSettingsFilter.Shield.class).asEagerSingleton();
bind(MarvelSettingsFilter.class).to(MarvelSettingsFilter.Shield.class);

View File

@ -36,9 +36,9 @@ import org.elasticsearch.watcher.input.InputModule;
import org.elasticsearch.watcher.license.LicenseModule;
import org.elasticsearch.watcher.license.WatcherLicensee;
import org.elasticsearch.watcher.rest.action.*;
import org.elasticsearch.watcher.shield.InternalWatcherUser;
import org.elasticsearch.watcher.shield.ShieldIntegration;
import org.elasticsearch.watcher.shield.WatcherShieldModule;
import org.elasticsearch.watcher.shield.WatcherUserHolder;
import org.elasticsearch.watcher.support.WatcherIndexTemplateRegistry.TemplateConfig;
import org.elasticsearch.watcher.support.clock.ClockModule;
import org.elasticsearch.watcher.support.http.HttpClient;
@ -211,7 +211,7 @@ public class WatcherPlugin extends Plugin {
// is enabled. This is a temporary solution until inter-plugin-communication can be worked out.
public void onModule(Module module) {
if (enabled && ShieldIntegration.enabled(settings) && module instanceof AuthorizationModule) {
((AuthorizationModule)module).registerReservedRole(WatcherUserHolder.ROLE);
((AuthorizationModule)module).registerReservedRole(InternalWatcherUser.ROLE);
}
}

View File

@ -12,13 +12,15 @@ import org.elasticsearch.shield.authz.Privilege;
/**
*
*/
public class WatcherUserHolder {
public class InternalWatcherUser extends User.Simple {
static final String NAME = "__watcher_user";
static final String[] ROLE_NAMES = new String[] { "__watcher_role" };
public static final InternalWatcherUser INSTANCE = new InternalWatcherUser(NAME, ROLE_NAMES);
public static final Permission.Global.Role ROLE = Permission.Global.Role.builder(ROLE_NAMES[0])
.cluster(Privilege.Cluster.action("indices:admin/template/put"))
.cluster(Privilege.Cluster.action("indices:admin/template/put"))
// for now, the watches will be executed under the watcher user, meaning, all actions
// taken as part of the execution will be executed on behalf of this user. this includes
@ -27,10 +29,11 @@ public class WatcherUserHolder {
//
// at later phases we'll want to execute the watch on behalf of the user who registers
// it. this will require some work to attache/persist that user to/with the watch.
.add(Privilege.Index.ALL, "*")
.add(Privilege.Index.ALL, "*")
.build();
final User user = new User.Simple(NAME, ROLE_NAMES);
.build();
InternalWatcherUser(String username, String[] roles) {
super(username, roles);
}
}

View File

@ -11,7 +11,6 @@ import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.common.inject.Injector;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.shield.ShieldPlugin;
import org.elasticsearch.xpack.XPackPlugin;
import org.elasticsearch.shield.ShieldSettingsFilter;
import org.elasticsearch.shield.authc.AuthenticationService;
import org.elasticsearch.transport.TransportMessage;
@ -23,24 +22,21 @@ import java.io.IOException;
*/
public class ShieldIntegration {
private static final int MIN_SHIELD_VERSION = /*00*/2000001; // 2.0.0_beta1
private final Object authcService;
private final Object userHolder;
private final Object settingsFilter;
private final boolean enabled;
private final AuthenticationService authcService;
private final ShieldSettingsFilter settingsFilter;
@Inject
public ShieldIntegration(Settings settings, Injector injector) {
boolean enabled = enabled(settings);
enabled = enabled(settings);
authcService = enabled ? injector.getInstance(AuthenticationService.class) : null;
userHolder = enabled ? injector.getInstance(WatcherUserHolder.class) : null;
settingsFilter = enabled ? injector.getInstance(ShieldSettingsFilter.class) : null;
}
public void bindWatcherUser(TransportMessage message) {
if (authcService != null) {
try {
((AuthenticationService) authcService).attachUserHeaderIfMissing(message, ((WatcherUserHolder) userHolder).user);
authcService.attachUserHeaderIfMissing(message, InternalWatcherUser.INSTANCE);
} catch (IOException e) {
throw new ElasticsearchException("failed to attach watcher user to request", e);
}
@ -49,28 +45,19 @@ public class ShieldIntegration {
public void filterOutSettings(String... patterns) {
if (settingsFilter != null) {
((ShieldSettingsFilter) settingsFilter).filterOut(patterns);
settingsFilter.filterOut(patterns);
}
}
// TODO this is a hack that needs to go away with proper fixes in core
public void putUserInContext(HasContext context) {
if (userHolder != null) {
context.putInContext("_shield_user", ((WatcherUserHolder) userHolder).user);
}
}
static boolean installed() {
try {
ShieldIntegration.class.getClassLoader().loadClass("org.elasticsearch.shield.ShieldPlugin");
return true;
} catch (ClassNotFoundException e) {
return false;
if (enabled) {
context.putInContext("_shield_user", InternalWatcherUser.INSTANCE);
}
}
public static boolean enabled(Settings settings) {
return installed() && ShieldPlugin.shieldEnabled(settings);
return ShieldPlugin.shieldEnabled(settings);
}
}

View File

@ -6,7 +6,6 @@
package org.elasticsearch.watcher.shield;
import org.elasticsearch.common.inject.AbstractModule;
import org.elasticsearch.common.inject.util.Providers;
import org.elasticsearch.common.logging.ESLogger;
import org.elasticsearch.common.logging.Loggers;
import org.elasticsearch.common.settings.Settings;
@ -21,17 +20,12 @@ public class WatcherShieldModule extends AbstractModule {
private final boolean enabled;
private final WatcherUserHolder userHolder;
public WatcherShieldModule(Settings settings) {
this.logger = Loggers.getLogger(WatcherShieldModule.class, settings);
this.enabled = ShieldIntegration.enabled(settings);
if (enabled) {
userHolder = new WatcherUserHolder();
registerClusterPrivilege("manage_watcher", "cluster:admin/watcher/*", "cluster:monitor/watcher/*");
registerClusterPrivilege("monitor_watcher", "cluster:monitor/watcher/*");
} else {
userHolder = null;
}
}
@ -50,7 +44,6 @@ public class WatcherShieldModule extends AbstractModule {
@Override
protected void configure() {
bind(ShieldIntegration.class).asEagerSingleton();
bind(WatcherUserHolder.class).toProvider(Providers.of(userHolder));
if (enabled) {
bind(WatcherSettingsFilter.Shield.class).asEagerSingleton();
bind(WatcherSettingsFilter.class).to(WatcherSettingsFilter.Shield.class);

View File

@ -31,6 +31,12 @@ import static org.mockito.Mockito.when;
/**
*/
public class CompareConditionSearchTests extends AbstractWatcherIntegrationTestCase {
@Override
protected boolean enableShield() {
return true;
}
public void testExecuteWithAggs() throws Exception {
client().admin().indices().prepareCreate("my-index")
.addMapping("my-type", "_timestamp", "enabled=true")