/* * Copyright 2016 ThoughtWorks, 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 com.thoughtworks.go.plugin.access.elastic; import com.thoughtworks.go.plugin.access.common.AbstractPluginRegistry; import com.thoughtworks.go.plugin.access.elastic.models.AgentMetadata; import com.thoughtworks.go.plugin.api.info.PluginDescriptor; import com.thoughtworks.go.plugin.infra.PluginManager; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Map; @Component public class ElasticAgentPluginRegistry extends AbstractPluginRegistry<ElasticAgentExtension> { @Autowired public ElasticAgentPluginRegistry(PluginManager pluginManager, ElasticAgentExtension elasticAgentExtension) { super(pluginManager, elasticAgentExtension); } public void createAgent(final String pluginId, String autoRegisterKey, String environment, Map<String, String> configuration) { PluginDescriptor plugin = findPlugin(pluginId); if (plugin != null) { LOGGER.debug("Processing create agent for plugin: {} with environment: {} with configuration: {}", pluginId, environment, configuration); extension.createAgent(pluginId, autoRegisterKey, environment, configuration); LOGGER.debug("Done processing create agent for plugin: {} with environment: {} with configuration: {}", pluginId, environment, configuration); } else { LOGGER.warn("Could not find plugin with id: {}", pluginId); } } public void serverPing(String pluginId) { LOGGER.debug("Processing server ping for plugin {}", pluginId); extension.serverPing(pluginId); LOGGER.debug("Done processing server ping for plugin {}", pluginId); } public boolean shouldAssignWork(PluginDescriptor plugin, AgentMetadata agent, String environment, Map<String, String> configuration) { LOGGER.debug("Processing should assign work for plugin: {} with agent: {} with environment: {} with configuration: {}", plugin.id(), agent, environment, configuration); boolean result = extension.shouldAssignWork(plugin.id(), agent, environment, configuration); LOGGER.debug("Done processing should assign work (result: {}) for plugin: {} with agent: {} with environment: {} with configuration {}", result, plugin.id(), agent, environment, configuration); return result; } public boolean has(String pluginId) { return findPlugin(pluginId) != null; } }