/*
* Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.tsdr.osc.handlers;
import java.math.BigInteger;
import java.util.List;
import org.opendaylight.tsdr.osc.TSDRBaseDataHandler;
import org.opendaylight.tsdr.osc.TSDRDOMCollector;
import org.opendaylight.tsdr.osc.TSDRMetricRecordBuilderContainer;
import org.opendaylight.tsdr.spi.util.FormatUtil;
import org.opendaylight.yang.gen.v1.opendaylight.tsdr.rev150219.DataCategory;
import org.opendaylight.yang.gen.v1.opendaylight.tsdr.rev150219.tsdrrecord.RecordKeys;
import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter64;
import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.collector.spi.rev150915.inserttsdrmetricrecord.input.TSDRMetricRecordBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.FlowCapableNodeConnectorQueueStatisticsData;
import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.flow.capable.node.connector.queue.statistics.FlowCapableNodeConnectorQueueStatistics;
import org.opendaylight.yangtools.yang.binding.DataObject;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
/**
* @author Sharon Aicler(saichler@gmail.com)
**/
/*
* A handler for FlowCapableNodeConnectorQueueStatisticsData metric
*/
public class FlowCapableNodeConnectorQueueStatisticsDataHandler extends TSDRBaseDataHandler {
public FlowCapableNodeConnectorQueueStatisticsDataHandler(TSDRDOMCollector _collector) {
super(_collector);
}
@Override
public void handleData(InstanceIdentifier<Node> nodeID,InstanceIdentifier<?> id, DataObject dataObject) {
FlowCapableNodeConnectorQueueStatisticsData stData = (FlowCapableNodeConnectorQueueStatisticsData) dataObject;
FlowCapableNodeConnectorQueueStatistics gs = stData.getFlowCapableNodeConnectorQueueStatistics();
if(gs==null){
//no data yet, ignore
return;
}
TSDRMetricRecordBuilderContainer bc = getCollector().getTSDRMetricRecordBuilderContainer(id);
if (bc != null) {
TSDRMetricRecordBuilder builder[] = bc.getBuilders();
long timeStamp = getTimeStamp();
builder[0].setMetricValue(FormatUtil.toMetricValue(gs.getTransmissionErrors()));
builder[0].setTimeStamp(timeStamp);
builder[1].setMetricValue(FormatUtil.toMetricValue(gs.getTransmittedBytes()));
builder[1].setTimeStamp(timeStamp);
builder[2].setMetricValue(FormatUtil.toMetricValue(gs.getTransmittedPackets()));
builder[2].setTimeStamp(timeStamp);
} else {
List<RecordKeys> recKeys = createRecordKeys(id);
getCollector().createTSDRMetricRecordBuilder(nodeID,id, recKeys,
"TransmissionErrors",
FormatUtil.toMetricValue(gs.getTransmissionErrors()),
DataCategory.QUEUESTATS);
getCollector().createTSDRMetricRecordBuilder(nodeID,id, recKeys,
"TransmittedBytes",
FormatUtil.toMetricValue(gs.getTransmittedBytes()),
DataCategory.QUEUESTATS);
getCollector().createTSDRMetricRecordBuilder(nodeID,id, recKeys,
"TransmittedPackets",
FormatUtil.toMetricValue(gs.getTransmittedPackets()),
DataCategory.QUEUESTATS);
}
}
}