summaryrefslogtreecommitdiffstats
path: root/v3po/v3po2vpp/src/main/java/io/fd/hc2vpp/v3po/interfacesstate/InterfaceStatisticsCustomizer.java
diff options
context:
space:
mode:
Diffstat (limited to 'v3po/v3po2vpp/src/main/java/io/fd/hc2vpp/v3po/interfacesstate/InterfaceStatisticsCustomizer.java')
-rw-r--r--v3po/v3po2vpp/src/main/java/io/fd/hc2vpp/v3po/interfacesstate/InterfaceStatisticsCustomizer.java116
1 files changed, 116 insertions, 0 deletions
diff --git a/v3po/v3po2vpp/src/main/java/io/fd/hc2vpp/v3po/interfacesstate/InterfaceStatisticsCustomizer.java b/v3po/v3po2vpp/src/main/java/io/fd/hc2vpp/v3po/interfacesstate/InterfaceStatisticsCustomizer.java
new file mode 100644
index 000000000..090aa0625
--- /dev/null
+++ b/v3po/v3po2vpp/src/main/java/io/fd/hc2vpp/v3po/interfacesstate/InterfaceStatisticsCustomizer.java
@@ -0,0 +1,116 @@
+/*
+ * Copyright (c) 2019 PANTHEON.tech.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at:
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package io.fd.hc2vpp.v3po.interfacesstate;
+
+import io.fd.hc2vpp.common.translate.util.JvppReplyConsumer;
+import io.fd.hc2vpp.common.translate.util.NamingContext;
+import io.fd.hc2vpp.v3po.interfacesstate.cache.InterfaceCacheStatisticsDumpManager;
+import io.fd.hc2vpp.v3po.interfacesstate.cache.InterfaceCacheStatisticsSample;
+import io.fd.honeycomb.translate.read.ReadContext;
+import io.fd.honeycomb.translate.read.ReadFailedException;
+import io.fd.honeycomb.translate.spi.read.ReaderCustomizer;
+import java.math.BigInteger;
+import javax.annotation.Nonnull;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.state.Interface;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.state.InterfaceBuilder;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.state.InterfaceKey;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.state._interface.Statistics;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.state._interface.StatisticsBuilder;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter64;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.v3po.rev181128.VppInterfaceStatisticsAugmentation;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.v3po.rev181128.VppInterfaceStatisticsAugmentationBuilder;
+import org.opendaylight.yangtools.concepts.Builder;
+import org.opendaylight.yangtools.yang.binding.DataObject;
+import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
+
+public class InterfaceStatisticsCustomizer implements
+ ReaderCustomizer<Statistics, StatisticsBuilder>, JvppReplyConsumer {
+
+ private NamingContext interfaceContext;
+ private InterfaceCacheStatisticsDumpManager ifcStatisticsManager;
+
+ public InterfaceStatisticsCustomizer(@Nonnull final NamingContext interfaceContext,
+ InterfaceCacheStatisticsDumpManager ifcStatisticsManager) {
+ this.interfaceContext = interfaceContext;
+ this.ifcStatisticsManager = ifcStatisticsManager;
+ }
+
+ @Nonnull
+ @Override
+ public StatisticsBuilder getBuilder(@Nonnull final InstanceIdentifier<Statistics> id) {
+ return new StatisticsBuilder();
+ }
+
+ @Override
+ public void readCurrentAttributes(@Nonnull final InstanceIdentifier<Statistics> id,
+ @Nonnull final StatisticsBuilder builder,
+ @Nonnull final ReadContext ctx) throws ReadFailedException {
+
+ final InterfaceKey key = id.firstKeyOf(Interface.class);
+ final int index = interfaceContext.getIndex(key.getName(), ctx.getMappingContext());
+ final InterfaceCacheStatisticsSample statisticsDetails = this.ifcStatisticsManager.getStatisticsData(index);
+ if (statisticsDetails != null) {
+ transformStatistics(statisticsDetails, builder);
+ } else {
+ memsetStatistics(builder);
+ }
+ builder.build();
+ }
+
+ private void memsetStatistics(final StatisticsBuilder builder) {
+ Counter64 defaultValue = (new Counter64(BigInteger.ZERO));
+ builder.setOutBroadcastPkts(defaultValue)
+ .setOutMulticastPkts(defaultValue)
+ .setOutUnicastPkts(defaultValue)
+ .setOutOctets(defaultValue)
+ .setInBroadcastPkts(defaultValue)
+ .setInMulticastPkts(defaultValue)
+ .setInUnicastPkts(defaultValue)
+ .setInOctets(defaultValue)
+ .addAugmentation(VppInterfaceStatisticsAugmentation.class,
+ new VppInterfaceStatisticsAugmentationBuilder()
+ .setCaptureTime(DateAndTime.getDefaultInstance("0000-00-00T00:00:00.0Z"))
+ .build());
+ }
+
+ private void transformStatistics(InterfaceCacheStatisticsSample statisticsDetails, StatisticsBuilder builder) {
+ builder.setOutBroadcastPkts(
+ new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].txBroadcastPackets)))
+ .setOutMulticastPkts(
+ new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].txMulticastPackets)))
+ .setOutUnicastPkts(
+ new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].txUnicastPackets)))
+ .setOutOctets(new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].txBytes)))
+ .setInBroadcastPkts(
+ new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].rxBroadcastPackets)))
+ .setInMulticastPkts(
+ new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].rxMulticastPackets)))
+ .setInUnicastPkts(
+ new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].rxUnicastPackets)))
+ .setInOctets(new Counter64(BigInteger.valueOf(statisticsDetails.getData().data[0].rxBytes)))
+ .addAugmentation(VppInterfaceStatisticsAugmentation.class,
+ new VppInterfaceStatisticsAugmentationBuilder()
+ .setCaptureTime(statisticsDetails.getCaptureTime())
+ .build());
+ }
+
+ @Override
+ public void merge(@Nonnull final Builder<? extends DataObject> parentBuilder, @Nonnull final Statistics readValue) {
+ ((InterfaceBuilder) parentBuilder).setStatistics(readValue);
+ }
+}