package org.opennaas.extensions.pdu.capability.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.gim.model.log.PowerMonitorLog;
import org.opennaas.extensions.pdu.capability.IPDUPowerMonitoringIDsCapability;
@Command(scope = "pdu", name = "getPowerMetricsLog", description = "Reads power metrics from specified port")
public class GetPowerMetricsLogCommand extends GenericKarafCommand {
@Argument(index = 0, name = "resourceType:resourceName", description = "The resource id where given port is.", required = true, multiValued = false)
private String resourceId;
@Argument(index = 1, name = "port", description = "Port to read metrics from", required = true, multiValued = false)
private String portId;
@Argument(index = 2, name = "from", description = "Beginning date", required = true, multiValued = false)
private String from;
@Argument(index = 3, name = "to", description = "End date", required = true, multiValued = false)
private String to;
private DateFormat dateFormat = new SimpleDateFormat("dd-MM-yyyy HH:mm:ss");
@Override
protected Object doExecute() throws Exception {
printInitCommand("getPowerMetricsLog of port : " + portId + " in resource: " + resourceId);
IResource resource = getResourceFromFriendlyName(resourceId);
PowerMonitorLog log = ((IPDUPowerMonitoringIDsCapability) resource.getCapabilityByInterface(IPDUPowerMonitoringIDsCapability.class))
.getPowerMetricsByTimeRange(portId, dateFormat.parse(from), dateFormat.parse(to));
printLog(log);
printEndCommand();
return null;
}
private void printLog(PowerMonitorLog log) {
for (MeasuredLoad metrics : log.getMeasuredLoads()) {
printMetrics(metrics);
}
}
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");
}
}