2 * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
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
8 package org.opendaylight.openflowplugin.impl.statistics.services;
10 import com.google.common.base.Function;
11 import com.google.common.util.concurrent.JdkFutureAdapters;
12 import com.google.common.util.concurrent.ListenableFuture;
13 import java.util.concurrent.Future;
14 import org.opendaylight.openflowplugin.api.OFConstants;
15 import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
16 import org.opendaylight.openflowplugin.api.openflow.device.RequestContext;
17 import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
18 import org.opendaylight.openflowplugin.api.openflow.device.Xid;
19 import org.opendaylight.openflowplugin.api.openflow.md.util.OpenflowVersion;
20 import org.opendaylight.openflowplugin.impl.services.CommonService;
21 import org.opendaylight.openflowplugin.impl.services.RequestInputUtils;
22 import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInputBuilder;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestQueueCaseBuilder;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.queue._case.MultipartRequestQueueBuilder;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsInput;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsOutput;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortInput;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortOutput;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortInput;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortOutput;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.OpendaylightQueueStatisticsService;
34 import org.opendaylight.yangtools.yang.common.RpcResult;
39 public class OpendaylightQueueStatisticsServiceImpl extends CommonService implements OpendaylightQueueStatisticsService {
41 public OpendaylightQueueStatisticsServiceImpl(final RequestContextStack requestContextStack, DeviceContext deviceContext) {
42 super(requestContextStack, deviceContext);
46 public Future<RpcResult<GetAllQueuesStatisticsFromAllPortsOutput>> getAllQueuesStatisticsFromAllPorts(
47 final GetAllQueuesStatisticsFromAllPortsInput input) {
48 return this.<GetAllQueuesStatisticsFromAllPortsOutput, Void>handleServiceCall(
49 new Function<RequestContext<GetAllQueuesStatisticsFromAllPortsOutput>, ListenableFuture<RpcResult<Void>>>() {
52 public ListenableFuture<RpcResult<Void>> apply(final RequestContext<GetAllQueuesStatisticsFromAllPortsOutput> requestContext) {
55 MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
56 MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
58 mprQueueBuilder.setPortNo(OFConstants.OFPP_ANY);
59 // Select all the ports
60 mprQueueBuilder.setQueueId(OFConstants.OFPQ_ALL);
61 caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
63 // Set request body to main multipart request
64 final Xid xid = requestContext.getXid();
65 MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(
66 MultipartType.OFPMPQUEUE, xid.getValue(), getVersion());
67 mprInput.setMultipartRequestBody(caseBuilder.build());
68 Future<RpcResult<Void>> resultFromOFLib = getDeviceContext().getPrimaryConnectionContext()
69 .getConnectionAdapter().multipartRequest(mprInput.build());
70 return JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
77 public Future<RpcResult<GetAllQueuesStatisticsFromGivenPortOutput>> getAllQueuesStatisticsFromGivenPort(
78 final GetAllQueuesStatisticsFromGivenPortInput input) {
79 return this.<GetAllQueuesStatisticsFromGivenPortOutput, Void>handleServiceCall(
80 new Function<RequestContext<GetAllQueuesStatisticsFromGivenPortOutput>, ListenableFuture<RpcResult<Void>>>() {
83 public ListenableFuture<RpcResult<Void>> apply(final RequestContext<GetAllQueuesStatisticsFromGivenPortOutput> requestContext) {
85 MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
86 MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
88 mprQueueBuilder.setQueueId(OFConstants.OFPQ_ALL);
89 // Select specific port
90 final short version = getVersion();
91 mprQueueBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
92 OpenflowVersion.get(version), input.getNodeConnectorId()));
93 caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
95 // Set request body to main multipart request
96 final Xid xid = requestContext.getXid();
97 MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(
98 MultipartType.OFPMPQUEUE, xid.getValue(), version);
99 mprInput.setMultipartRequestBody(caseBuilder.build());
100 Future<RpcResult<Void>> resultFromOFLib = getDeviceContext().getPrimaryConnectionContext()
101 .getConnectionAdapter().multipartRequest(mprInput.build());
102 return JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
109 public Future<RpcResult<GetQueueStatisticsFromGivenPortOutput>> getQueueStatisticsFromGivenPort(
110 final GetQueueStatisticsFromGivenPortInput input) {
111 return this.<GetQueueStatisticsFromGivenPortOutput, Void>handleServiceCall(
112 new Function<RequestContext<GetQueueStatisticsFromGivenPortOutput>, ListenableFuture<RpcResult<Void>>>() {
115 public ListenableFuture<RpcResult<Void>> apply(final RequestContext<GetQueueStatisticsFromGivenPortOutput> requestContext) {
117 MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
118 MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
119 // Select specific queue
120 mprQueueBuilder.setQueueId(input.getQueueId().getValue());
121 // Select specific port
122 final short version = getVersion();
123 mprQueueBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
124 OpenflowVersion.get(version), input.getNodeConnectorId()));
125 caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
127 // Set request body to main multipart request
128 final Xid xid = requestContext.getXid();
129 MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(
130 MultipartType.OFPMPQUEUE, xid.getValue(), version);
131 mprInput.setMultipartRequestBody(caseBuilder.build());
132 Future<RpcResult<Void>> resultFromOFLib = getDeviceContext().getPrimaryConnectionContext()
133 .getConnectionAdapter().multipartRequest(mprInput.build());
134 return JdkFutureAdapters.listenInPoolThread(resultFromOFLib);