/* * RHQ Management Platform * Copyright (C) 2005-2014 Red Hat, Inc. * All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License, version 2, as * published by the Free Software Foundation, and/or the GNU Lesser * General Public License, version 2.1, also as published by the Free * Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License and the GNU Lesser General Public License * for more details. * * You should have received a copy of the GNU General Public License * and the GNU Lesser General Public License along with this program; * if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package org.rhq.plugins.jbossas5; import java.util.HashSet; import java.util.Set; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.rhq.core.domain.configuration.PropertySimple; import org.rhq.core.domain.resource.ResourceType; import org.rhq.core.pluginapi.inventory.DiscoveredResourceDetails; import org.rhq.core.pluginapi.inventory.ResourceDiscoveryComponent; import org.rhq.core.pluginapi.inventory.ResourceDiscoveryContext; import org.rhq.plugins.jbossas5.util.ConversionUtils; import org.jboss.deployers.spi.management.KnownDeploymentTypes; import org.jboss.deployers.spi.management.ManagementView; import org.jboss.managed.api.ManagedDeployment; import org.jboss.profileservice.spi.NoSuchDeploymentException; /** * Discovery class for discovering deployable resources like ear/war/jar/sar * * @author Mark Spritzler * @author Ian Springer * * @deprecated as of 4.13. Not used at least since 4.12. */ @Deprecated public abstract class ManagedDeploymentDiscoveryComponent implements ResourceDiscoveryComponent<ApplicationServerComponent<?>> { private final Log log = LogFactory.getLog(this.getClass()); public Set<DiscoveredResourceDetails> discoverResources( ResourceDiscoveryContext<ApplicationServerComponent<?>> discoveryContext) { Set<DiscoveredResourceDetails> discoveredResources = new HashSet<DiscoveredResourceDetails>(); ResourceType resourceType = discoveryContext.getResourceType(); log.trace("Discovering " + resourceType.getName() + " Resources..."); KnownDeploymentTypes deploymentType = ConversionUtils.getDeploymentType(resourceType); String deploymentTypeString = deploymentType.getType(); ManagementView managementView = discoveryContext.getParentResourceComponent().getConnection().getManagementView(); // TODO (ips): Only refresh the ManagementView *once* per runtime discovery scan, rather than every time this // method is called. Do this by providing a runtime scan id in the ResourceDiscoveryContext. managementView.load(); Set<String> deploymentNames = null; try { deploymentNames = managementView.getDeploymentNamesForType(deploymentTypeString); } catch (Exception e) { log.error("Unable to get deployment for type " + deploymentTypeString, e); } if (deploymentNames != null) { discoveredResources = new HashSet<DiscoveredResourceDetails>(deploymentNames.size()); /* Create a resource for each managed component found. We know all managed components will be of a type we're interested in, so we can just add them all. There may be need for multiple iterations over lists retrieved from different component types, but that is possible through the current API. */ for (String deploymentName : deploymentNames) { try { ManagedDeployment managedDeployment = managementView.getDeployment(deploymentName); if (!accept(managedDeployment)) continue; String resourceName = managedDeployment.getSimpleName(); // @TODO remove this when AS5 actually implements this for sars, and some other DeploymentTypes that haven't implemented getSimpleName() if (resourceName.equals("%Generated%")) { resourceName = getResourceName(deploymentName); } String version = null; // TODO DiscoveredResourceDetails resource = new DiscoveredResourceDetails(resourceType, deploymentName, resourceName, version, resourceType.getDescription(), discoveryContext.getDefaultPluginConfiguration(), null); // example of a deployment name: vfszip:/C:/opt/jboss-5.1.0.CR1/server/default/deploy/foo.war resource.getPluginConfiguration().put( new PropertySimple(AbstractManagedDeploymentComponent.DEPLOYMENT_NAME_PROPERTY, deploymentName)); discoveredResources.add(resource); } catch (NoSuchDeploymentException e) { // This is a bug in the profile service that occurs often, so don't log the stack trace. log.error("ManagementView.getDeploymentNamesForType() returned [" + deploymentName + "] as a deployment name, but calling getDeployment() with that name failed."); } catch (Exception e) { log.error("An error occurred while discovering " + resourceType + " Resources.", e); } } } log.trace("Discovered " + discoveredResources.size() + " " + resourceType.getName() + " Resources."); return discoveredResources; } protected abstract boolean accept(ManagedDeployment managedDeployment); private static String getResourceName(String fullPath) { int lastSlashIndex = fullPath.lastIndexOf("/"); return fullPath.substring(lastSlashIndex + 1); } }