/*
* RHQ Management Platform
* Copyright (C) 2005-2012 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 as published by
* the Free Software Foundation version 2 of the License.
*
* 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 for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
package org.rhq.plugins.hadoop;
import java.io.File;
import java.io.InputStream;
import java.util.List;
import java.util.Set;
import org.rhq.core.domain.configuration.Configuration;
import org.rhq.core.domain.configuration.PropertySimple;
import org.rhq.core.domain.content.PackageType;
import org.rhq.core.domain.content.transfer.DeployPackageStep;
import org.rhq.core.domain.content.transfer.DeployPackagesResponse;
import org.rhq.core.domain.content.transfer.RemovePackagesResponse;
import org.rhq.core.domain.content.transfer.ResourcePackageDetails;
import org.rhq.core.domain.measurement.AvailabilityType;
import org.rhq.core.pluginapi.content.ContentFacet;
import org.rhq.core.pluginapi.content.ContentServices;
import org.rhq.core.pluginapi.inventory.DeleteResourceFacet;
import org.rhq.core.pluginapi.inventory.InvalidPluginConfigurationException;
import org.rhq.core.pluginapi.inventory.ResourceComponent;
import org.rhq.core.pluginapi.inventory.ResourceContext;
import org.rhq.core.pluginapi.operation.OperationFacet;
import org.rhq.core.pluginapi.operation.OperationResult;
/**
*
*
* @author Lukas Krejci
*/
public class JobJarComponent implements ResourceComponent<JobTrackerServerComponent>, OperationFacet, DeleteResourceFacet, ContentFacet {
public static final String RESOURCE_TYPE_NAME = "Job Jar";
public static final String CONTENT_TYPE_NAME = "jobJar";
public static final String JOB_JAR_PROP_NAME = "jobJar";
private static final String SUBMIT_OP = "submit";
private File jobJar;
private ResourceContext<JobTrackerServerComponent> context;
private HadoopOperationsDelegate operationsDelegate;
@Override
public AvailabilityType getAvailability() {
return jobJar.exists() ? AvailabilityType.UP : AvailabilityType.DOWN;
}
@Override
public void start(ResourceContext<JobTrackerServerComponent> context) throws InvalidPluginConfigurationException,
Exception {
jobJar = new File(context.getResourceKey());
this.context = context;
operationsDelegate = new HadoopOperationsDelegate(context.getParentResourceComponent().getResourceContext());
}
@Override
public void stop() {
}
@Override
public OperationResult invokeOperation(String name, Configuration parameters) throws InterruptedException,
Exception {
if (SUBMIT_OP.equals(name)) {
String args = parameters.getSimpleValue("args", "");
args = context.getResourceKey() + " " + args;
parameters.put(new PropertySimple("args", args));
return operationsDelegate.invoke(HadoopSupportedOperations.JAR, parameters, null);
}
return null;
}
@Override
public void deleteResource() throws Exception {
jobJar.delete();
}
@Override
public DeployPackagesResponse deployPackages(Set<ResourcePackageDetails> details, ContentServices services) {
return null;
}
@Override
public Set<ResourcePackageDetails> discoverDeployedPackages(PackageType type) {
return null;
}
@Override
public List<DeployPackageStep> generateInstallationSteps(ResourcePackageDetails details) {
return null;
}
@Override
public RemovePackagesResponse removePackages(Set<ResourcePackageDetails> details) {
return null;
}
@Override
public InputStream retrievePackageBits(ResourcePackageDetails details) {
return null;
}
}