Remove unused routedRpcRegistration
[openflowplugin.git] / openflowplugin-impl / src / main / java / org / opendaylight / openflowplugin / impl / statistics / services / direct / multilayer / MultiGetNodeConnectorStatistics.java
1 /*
2  * Copyright (c) 2017 Pantheon Technologies s.r.o. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.openflowplugin.impl.statistics.services.direct.multilayer;
9
10 import java.util.List;
11 import org.opendaylight.openflowplugin.api.OFConstants;
12 import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
13 import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
14 import org.opendaylight.openflowplugin.api.openflow.device.Xid;
15 import org.opendaylight.openflowplugin.impl.datastore.MultipartWriterProvider;
16 import org.opendaylight.openflowplugin.impl.services.util.RequestInputUtils;
17 import org.opendaylight.openflowplugin.impl.statistics.services.direct.AbstractGetNodeConnectorStatistics;
18 import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.ConvertorExecutor;
19 import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
20 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter32;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsInput;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsOutput;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsOutputBuilder;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.duration.DurationBuilder;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.node.connector.statistics.BytesBuilder;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.node.connector.statistics.PacketsBuilder;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReply;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OfHeader;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.MultipartReplyPortStatsCase;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestPortStatsCaseBuilder;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.port.stats._case.MultipartRequestPortStatsBuilder;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMap;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMapBuilder;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMapKey;
35 import org.opendaylight.yangtools.yang.binding.util.BindingMap;
36
37 public final class MultiGetNodeConnectorStatistics extends AbstractGetNodeConnectorStatistics<MultipartReply> {
38     public MultiGetNodeConnectorStatistics(final RequestContextStack requestContextStack,
39             final DeviceContext deviceContext, final ConvertorExecutor convertorExecutor,
40             final MultipartWriterProvider statisticsWriterProvider) {
41         super(requestContextStack, deviceContext, convertorExecutor, statisticsWriterProvider);
42     }
43
44     @Override
45     protected GetNodeConnectorStatisticsOutput buildReply(final List<MultipartReply> input, final boolean success) {
46         if (!success) {
47             return new GetNodeConnectorStatisticsOutputBuilder().build();
48         }
49
50         final var nodeConnectorStatisticsAndPortNumberMap = BindingMap.<NodeConnectorStatisticsAndPortNumberMapKey,
51             NodeConnectorStatisticsAndPortNumberMap>orderedBuilder();
52         for (var mpReply : input) {
53             final var caseBody = (MultipartReplyPortStatsCase) mpReply.getMultipartReplyBody();
54             final var replyBody = caseBody.getMultipartReplyPortStats();
55
56             for (var portStats : replyBody.nonnullPortStats()) {
57                 final var durationBuilder = new DurationBuilder();
58                 if (portStats.getDurationSec() != null) {
59                     durationBuilder.setSecond(new Counter32(portStats.getDurationSec()));
60                 }
61                 if (portStats.getDurationNsec() != null) {
62                     durationBuilder.setNanosecond(new Counter32(portStats.getDurationNsec()));
63                 }
64
65                 nodeConnectorStatisticsAndPortNumberMap.add(new NodeConnectorStatisticsAndPortNumberMapBuilder()
66                     .setBytes(new BytesBuilder()
67                         .setReceived(portStats.getRxBytes())
68                         .setTransmitted(portStats.getTxBytes())
69                         .build())
70                     .setPackets(new PacketsBuilder()
71                         .setReceived(portStats.getRxPackets())
72                         .setTransmitted(portStats.getTxPackets())
73                         .build())
74                     .setNodeConnectorId(InventoryDataServiceUtil.nodeConnectorIdfromDatapathPortNo(getDatapathId(),
75                         portStats.getPortNo(), getOfVersion()))
76                     .setDuration(durationBuilder.build())
77                     .setCollisionCount(portStats.getCollisions())
78                     .setReceiveCrcError(portStats.getRxCrcErr()).setReceiveDrops(portStats.getRxDropped())
79                     .setReceiveErrors(portStats.getRxErrors())
80                     .setReceiveFrameError(portStats.getRxFrameErr())
81                     .setReceiveOverRunError(portStats.getRxOverErr())
82                     .setTransmitDrops(portStats.getTxDropped())
83                     .setTransmitErrors(portStats.getTxErrors())
84                     .build());
85             }
86         }
87
88         return new GetNodeConnectorStatisticsOutputBuilder()
89             .setNodeConnectorStatisticsAndPortNumberMap(nodeConnectorStatisticsAndPortNumberMap.build())
90             .build();
91     }
92
93     @Override
94     protected OfHeader buildRequest(final Xid xid, final GetNodeConnectorStatisticsInput input) {
95         final var mprPortStatsBuilder = new MultipartRequestPortStatsBuilder();
96
97         if (input.getNodeConnectorId() != null) {
98             mprPortStatsBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(getOfVersion(),
99                     input.getNodeConnectorId()));
100         } else {
101             mprPortStatsBuilder.setPortNo(OFConstants.OFPP_ANY);
102         }
103
104         return RequestInputUtils.createMultipartHeader(getMultipartType(), xid.getValue(), getVersion())
105             .setMultipartRequestBody(new MultipartRequestPortStatsCaseBuilder()
106                 .setMultipartRequestPortStats(mprPortStatsBuilder.build())
107                 .build())
108             .build();
109     }
110 }