Fix errors in serializers and deserializers
[openflowplugin.git] / openflowplugin-impl / src / main / java / org / opendaylight / openflowplugin / impl / statistics / services / direct / NodeConnectorDirectStatisticsService.java
1 /*
2  * Copyright (c) 2015 Cisco Systems, Inc. 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
9 package org.opendaylight.openflowplugin.impl.statistics.services.direct;
10
11 import java.util.ArrayList;
12 import java.util.List;
13 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
14 import org.opendaylight.openflowplugin.api.OFConstants;
15 import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
16 import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
17 import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.ConvertorExecutor;
18 import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
19 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter32;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsInput;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsOutput;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsOutputBuilder;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeConnectorId;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.node.NodeConnector;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.node.NodeConnectorKey;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.duration.DurationBuilder;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.node.connector.statistics.BytesBuilder;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.node.connector.statistics.PacketsBuilder;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReply;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.MultipartReplyPortStatsCase;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.port.stats._case.MultipartReplyPortStats;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.port.stats._case.multipart.reply.port.stats.PortStats;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.MultipartRequestBody;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestPortStatsCaseBuilder;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.port.stats._case.MultipartRequestPortStatsBuilder;
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.FlowCapableNodeConnectorStatisticsData;
39 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.flow.capable.node.connector.statistics.FlowCapableNodeConnectorStatistics;
40 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.flow.capable.node.connector.statistics.FlowCapableNodeConnectorStatisticsBuilder;
41 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMap;
42 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMapBuilder;
43 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMapKey;
44 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
45
46 /**
47  * The Node connector direct statistics service.
48  */
49 public class NodeConnectorDirectStatisticsService extends AbstractDirectStatisticsService<GetNodeConnectorStatisticsInput, GetNodeConnectorStatisticsOutput> {
50     /**
51      * Instantiates a new Node connector direct statistics service.
52      *  @param requestContextStack the request context stack
53      * @param deviceContext       the device context
54      * @param convertorExecutor
55      */
56     public NodeConnectorDirectStatisticsService(RequestContextStack requestContextStack, DeviceContext deviceContext, ConvertorExecutor convertorExecutor) {
57         super(MultipartType.OFPMPPORTSTATS, requestContextStack, deviceContext, convertorExecutor);
58     }
59
60     @Override
61     protected MultipartRequestBody buildRequestBody(GetNodeConnectorStatisticsInput input) {
62         final MultipartRequestPortStatsBuilder mprPortStatsBuilder = new MultipartRequestPortStatsBuilder();
63
64         if (input.getNodeConnectorId() != null) {
65             mprPortStatsBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(getOfVersion(), input.getNodeConnectorId()));
66         } else {
67             mprPortStatsBuilder.setPortNo(OFConstants.OFPP_ANY);
68         }
69
70         return new MultipartRequestPortStatsCaseBuilder()
71                 .setMultipartRequestPortStats(mprPortStatsBuilder.build())
72                 .build();
73     }
74
75     @Override
76     protected GetNodeConnectorStatisticsOutput buildReply(List<MultipartReply> input, boolean success) {
77         final List<NodeConnectorStatisticsAndPortNumberMap> nodeConnectorStatisticsAndPortNumberMap = new ArrayList<>();
78
79         if (success) {
80             for (final MultipartReply mpReply : input) {
81                 final MultipartReplyPortStatsCase caseBody = (MultipartReplyPortStatsCase) mpReply.getMultipartReplyBody();
82                 final MultipartReplyPortStats replyBody = caseBody.getMultipartReplyPortStats();
83
84                 for (final PortStats portStats : replyBody.getPortStats()) {
85                     final NodeConnectorId nodeConnectorId = InventoryDataServiceUtil.nodeConnectorIdfromDatapathPortNo(
86                             getDatapathId(), portStats.getPortNo(), getOfVersion());
87
88                     final BytesBuilder bytesBuilder = new BytesBuilder()
89                             .setReceived(portStats.getRxBytes())
90                             .setTransmitted(portStats.getTxBytes());
91
92                     final PacketsBuilder packetsBuilder = new PacketsBuilder()
93                             .setReceived(portStats.getRxPackets())
94                             .setTransmitted(portStats.getTxPackets());
95
96                     final DurationBuilder durationBuilder = new DurationBuilder();
97
98                     if (portStats.getDurationSec() != null) {
99                         durationBuilder.setSecond(new Counter32(portStats.getDurationSec()));
100                     }
101
102                     if (portStats.getDurationNsec() != null) {
103                         durationBuilder.setNanosecond(new Counter32(portStats.getDurationNsec()));
104                     }
105
106                     final NodeConnectorStatisticsAndPortNumberMap stats = new NodeConnectorStatisticsAndPortNumberMapBuilder()
107                             .setBytes(bytesBuilder.build())
108                             .setPackets(packetsBuilder.build())
109                             .setNodeConnectorId(nodeConnectorId)
110                             .setDuration(durationBuilder.build())
111                             .setCollisionCount(portStats.getCollisions())
112                             .setKey(new NodeConnectorStatisticsAndPortNumberMapKey(nodeConnectorId))
113                             .setReceiveCrcError(portStats.getRxCrcErr()).setReceiveDrops(portStats.getRxDropped())
114                             .setReceiveErrors(portStats.getRxErrors())
115                             .setReceiveFrameError(portStats.getRxFrameErr())
116                             .setReceiveOverRunError(portStats.getRxOverErr())
117                             .setTransmitDrops(portStats.getTxDropped())
118                             .setTransmitErrors(portStats.getTxErrors())
119                             .build();
120
121                     nodeConnectorStatisticsAndPortNumberMap.add(stats);
122                 }
123             }
124         }
125
126         return new GetNodeConnectorStatisticsOutputBuilder()
127                 .setNodeConnectorStatisticsAndPortNumberMap(nodeConnectorStatisticsAndPortNumberMap)
128                 .build();
129     }
130
131     @Override
132     protected void storeStatistics(GetNodeConnectorStatisticsOutput output) throws Exception {
133         final InstanceIdentifier<Node> nodePath = getDeviceInfo().getNodeInstanceIdentifier();
134
135         for (final NodeConnectorStatisticsAndPortNumberMap nodeConnectorStatistics : output.getNodeConnectorStatisticsAndPortNumberMap()) {
136             final InstanceIdentifier<FlowCapableNodeConnectorStatistics> nodeConnectorPath = nodePath
137                     .child(NodeConnector.class, new NodeConnectorKey(nodeConnectorStatistics.getNodeConnectorId()))
138                     .augmentation(FlowCapableNodeConnectorStatisticsData.class)
139                     .child(FlowCapableNodeConnectorStatistics.class);
140
141             final FlowCapableNodeConnectorStatistics stats = new FlowCapableNodeConnectorStatisticsBuilder(nodeConnectorStatistics).build();
142             getTxFacade().writeToTransactionWithParentsSlow(LogicalDatastoreType.OPERATIONAL, nodeConnectorPath, stats);
143         }
144     }
145 }