package org.opennaas.extensions.power.capabilities.shell;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import org.apache.felix.gogo.commands.Argument;
import org.apache.felix.gogo.commands.Command;
import org.opennaas.core.resources.IResource;
import org.opennaas.core.resources.shell.GenericKarafCommand;
import org.opennaas.extensions.gim.model.load.MeasuredLoad;
import org.opennaas.extensions.power.capabilities.IPowerMonitoringCapability;
@Command(scope = "power", name = "getPowerMetrics", description = "Reads power metrics of specified resource")
public class GetCurrentPowerMetricsCommand extends GenericKarafCommand {
@Argument(index = 0, name = "resourceType:resourceName", description = "The resource id where given port is.", required = true, multiValued = false)
private String resourceId;
private DateFormat dateFormat = new SimpleDateFormat("dd-MM-yyyy HH:mm:ss");
@Override
protected Object doExecute() throws Exception {
printInitCommand("getPowerMetrics of resource: " + resourceId);
IResource resource = getResourceFromFriendlyName(resourceId);
MeasuredLoad metrics = ((IPowerMonitoringCapability) resource.getCapabilityByInterface(IPowerMonitoringCapability.class))
.getCurrentPowerMetrics();
printMetrics(metrics);
printEndCommand();
return null;
}
private void printMetrics(MeasuredLoad metrics) {
String readTime = dateFormat.format(metrics.getReadingTime());
printSymbol("Power Consumption Metrics for resource " + resourceId + " @ " + readTime + ":");
printSymbol("Voltage: " + metrics.getVoltage() + " Volts");
printSymbol("Current: " + metrics.getCurrent() + " Amps");
printSymbol("Power: " + metrics.getPower() + " KW");
printSymbol("Energy: " + metrics.getEnergy() + " KWh");
}
}