All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.fabric8.elasticsearch.plugin.OpenShiftElasticSearchService Maven / Gradle / Ivy

/**
 * Copyright (C) 2015 Red Hat, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.fabric8.elasticsearch.plugin;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

import org.elasticsearch.ElasticsearchException;
import org.elasticsearch.client.Client;
import org.elasticsearch.common.component.AbstractLifecycleComponent;
import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.common.logging.ESLogger;
import org.elasticsearch.common.logging.Loggers;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.util.concurrent.EsExecutors;
import org.elasticsearch.common.util.concurrent.FutureUtils;
import org.elasticsearch.rest.RestController;

import io.fabric8.elasticsearch.plugin.acl.ACLNotifierService;
import io.fabric8.elasticsearch.plugin.acl.DynamicACLFilter;
import io.fabric8.elasticsearch.plugin.acl.UserProjectCache;

/**
 * Service to handle spawning threads, lifecycles,
 * and REST filter registrations
 * @author jeff.cantrill
 *
 */
public class OpenShiftElasticSearchService 
	extends AbstractLifecycleComponent
	implements ConfigurationSettings {


	private final ESLogger logger;
	private final UserProjectCache cache;
	private final Settings settings;
	private ScheduledThreadPoolExecutor scheduler;
	
	@SuppressWarnings("rawtypes")
	private ScheduledFuture scheduledFuture;
	private ExecutorService notifier;
	private ACLNotifierService aclNotifier;

	@Inject
	protected OpenShiftElasticSearchService(final Settings settings, final Client esClient, final RestController restController, 
			final UserProjectCache cache, final ACLNotifierService aclNotifer, final DynamicACLFilter aclFilter) {
		super(settings);
		this.settings = settings;
		this.logger = Loggers.getLogger(getClass(), settings);
		this.cache = cache;
		this.aclNotifier = aclNotifer;
		restController.registerFilter(aclFilter);
		
		boolean reindexEnabled = settings.getAsBoolean(OPENSHIFT_KIBANA_REWRITE_ENABLED_FLAG, OPENSHIFT_KIBANA_REWRITE_ENABLED_DEFAULT);
		logger.debug("Starting with Kibana reindexing feature enabled: {}", reindexEnabled);
		
		if ( reindexEnabled ) {
			restController.registerFilter(new KibanaUserReindexFilter(settings, logger));
		}
	}

	@Override
	protected void doStart() throws ElasticsearchException {
		
		boolean dynamicEnabled = settings.getAsBoolean(OPENSHIFT_DYNAMIC_ENABLED_FLAG, OPENSHIFT_DYNAMIC_ENABLED_DEFAULT);
		logger.debug("Starting with Dynamic ACL feature enabled: {}", dynamicEnabled);
		
        //thread for ACL load callbacks
        logger.debug("Starting the acl notification thread...");
		notifier = Executors.newSingleThreadExecutor(
                EsExecutors.daemonThreadFactory(settings, "openshift_acl_notifier"));	
		aclNotifier.setExecutorService(notifier);
			
		if ( dynamicEnabled ) {
			//expiration thread
			logger.debug("Starting the expiration thread...");
	        this.scheduler = (ScheduledThreadPoolExecutor) Executors.newScheduledThreadPool(1,
	                EsExecutors.daemonThreadFactory(settings, "openshift_elasticsearch_service"));
	        this.scheduler.setExecuteExistingDelayedTasksAfterShutdownPolicy(false);
	        this.scheduler.setContinueExistingPeriodicTasksAfterShutdownPolicy(false);
	        
	        Runnable expire = new Runnable() {
				@Override
				public void run() {
					cache.expire();
				}
			};
	        this.scheduledFuture = this.scheduler.scheduleWithFixedDelay(expire, 5, 60, TimeUnit.SECONDS);
		}
		
		logger.debug("Started");
  
	}

	@Override
	protected void doStop() throws ElasticsearchException {
		if(notifier != null){
			notifier.shutdownNow();
		}		
		//cleanup expire thread
        FutureUtils.cancel(this.scheduledFuture);
        if(scheduler != null){
        	this.scheduler.shutdown();
        }
		logger.debug("Stopped");
	}

	@Override
	protected void doClose() throws ElasticsearchException {
        FutureUtils.cancel(this.scheduledFuture);
        if(this.scheduler != null){
        	this.scheduler.shutdown();
        }
		logger.debug("Closed");
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy