/* * Copyright (c) 2017 Pantheon Technologies s.r.o. 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.openflowplugin.impl.statistics.services.direct.multilayer; import java.util.List; import org.opendaylight.openflowplugin.api.OFConstants; import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext; import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack; import org.opendaylight.openflowplugin.api.openflow.device.Xid; import org.opendaylight.openflowplugin.impl.datastore.MultipartWriterProvider; import org.opendaylight.openflowplugin.impl.services.util.RequestInputUtils; import org.opendaylight.openflowplugin.impl.statistics.services.direct.AbstractQueueDirectStatisticsService; import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.ConvertorExecutor; import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter32; 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.direct.statistics.rev160511.GetQueueStatisticsInput; import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetQueueStatisticsOutput; import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetQueueStatisticsOutputBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.queue.rev130925.QueueId; import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeConnectorId; import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.duration.DurationBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReply; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OfHeader; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.MultipartReplyQueueCase; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.queue._case.MultipartReplyQueue; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.queue._case.multipart.reply.queue.QueueStats; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestQueueCaseBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.queue._case.MultipartRequestQueueBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.queue.id.and.statistics.map.QueueIdAndStatisticsMap; import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.queue.id.and.statistics.map.QueueIdAndStatisticsMapBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.queue.id.and.statistics.map.QueueIdAndStatisticsMapKey; import org.opendaylight.yangtools.yang.binding.util.BindingMap; public class QueueDirectStatisticsService extends AbstractQueueDirectStatisticsService { public QueueDirectStatisticsService(final RequestContextStack requestContextStack, final DeviceContext deviceContext, final ConvertorExecutor convertorExecutor, final MultipartWriterProvider statisticsWriterProvider) { super(requestContextStack, deviceContext, convertorExecutor, statisticsWriterProvider); } @Override protected GetQueueStatisticsOutput buildReply(final List input, final boolean success) { if (!success) { return new GetQueueStatisticsOutputBuilder().build(); } final var queueIdAndStatisticsMap = BindingMap.orderedBuilder(); for (final MultipartReply mpReply : input) { final MultipartReplyQueueCase caseBody = (MultipartReplyQueueCase) mpReply.getMultipartReplyBody(); final MultipartReplyQueue replyBody = caseBody.getMultipartReplyQueue(); for (final QueueStats queueStats : replyBody.nonnullQueueStats()) { final DurationBuilder durationBuilder = new DurationBuilder() .setSecond(new Counter32(queueStats.getDurationSec())) .setNanosecond(new Counter32(queueStats.getDurationNsec())); final QueueId queueId = new QueueId(queueStats.getQueueId()); final NodeConnectorId nodeConnectorId = InventoryDataServiceUtil.nodeConnectorIdfromDatapathPortNo( getDatapathId(), queueStats.getPortNo(), getOfVersion()); final QueueIdAndStatisticsMapBuilder statsBuilder = new QueueIdAndStatisticsMapBuilder() .setNodeConnectorId(nodeConnectorId) .setQueueId(queueId) .setTransmissionErrors(new Counter64(queueStats.getTxErrors())) .setTransmittedBytes(new Counter64(queueStats.getTxBytes())) .setTransmittedPackets(new Counter64(queueStats.getTxPackets())) .setDuration(durationBuilder.build()); queueIdAndStatisticsMap.add(statsBuilder.build()); } } return new GetQueueStatisticsOutputBuilder() .setQueueIdAndStatisticsMap(queueIdAndStatisticsMap.build()) .build(); } @Override protected OfHeader buildRequest(final Xid xid, final GetQueueStatisticsInput input) { final MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder(); if (input.getQueueId() != null) { mprQueueBuilder.setQueueId(input.getQueueId().getValue()); } else { mprQueueBuilder.setQueueId(OFConstants.OFPQ_ALL); } if (input.getNodeConnectorId() != null) { mprQueueBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(getOfVersion(), input.getNodeConnectorId())); } else { mprQueueBuilder.setPortNo(OFConstants.OFPP_ANY); } return RequestInputUtils.createMultipartHeader(getMultipartType(), xid.getValue(), getVersion()) .setMultipartRequestBody(new MultipartRequestQueueCaseBuilder() .setMultipartRequestQueue(mprQueueBuilder.build()) .build()) .build(); } }