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.services;
10 import com.google.common.util.concurrent.JdkFutureAdapters;
11 import com.google.common.util.concurrent.ListenableFuture;
12 import com.google.common.util.concurrent.SettableFuture;
13 import org.opendaylight.openflowplugin.api.OFConstants;
14 import org.opendaylight.openflowplugin.api.openflow.device.RequestContext;
15 import org.opendaylight.openflowplugin.api.openflow.device.Xid;
16 import org.opendaylight.openflowplugin.api.openflow.md.util.OpenflowVersion;
17 import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.module.config.rev141015.SetConfigOutput;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInputBuilder;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestQueueCaseBuilder;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.queue._case.MultipartRequestQueueBuilder;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsInput;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsOutput;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortInput;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortOutput;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortInput;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortOutput;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.OpendaylightQueueStatisticsService;
30 import org.opendaylight.yangtools.yang.common.RpcResult;
31 import java.util.concurrent.Future;
36 public class OpendaylightQueueStatisticsServiceImpl extends CommonService implements OpendaylightQueueStatisticsService {
40 public Future<RpcResult<GetAllQueuesStatisticsFromAllPortsOutput>> getAllQueuesStatisticsFromAllPorts(
41 final GetAllQueuesStatisticsFromAllPortsInput input) {
42 final RequestContext requestContext = rpcContext.createRequestContext();
43 final SettableFuture<RpcResult<GetAllQueuesStatisticsFromAllPortsOutput>> result = rpcContext.storeOrFail(requestContext);
45 if (!result.isDone()) {
46 final Xid xid = deviceContext.getNextXid();
48 MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
49 MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
51 mprQueueBuilder.setPortNo(OFConstants.OFPP_ANY);
52 // Select all the ports
53 mprQueueBuilder.setQueueId(OFConstants.OFPQ_ANY);
54 caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
56 // Set request body to main multipart request
57 MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(MultipartType.OFPMPQUEUE, xid.getValue(), version);
58 mprInput.setMultipartRequestBody(caseBuilder.build());
59 Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext().getConnectionAdapter().multipartRequest(mprInput.build());
60 ListenableFuture<RpcResult<Void>> futureResultFromOfLib = JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
62 final RpcResultConvertor<SetConfigOutput> rpcResultConvertor = new RpcResultConvertor<>(requestContext);
63 rpcResultConvertor.processResultFromOfJava(futureResultFromOfLib, provideWaitTime());
65 RequestContextUtil.closeRequstContext(requestContext);
71 public Future<RpcResult<GetAllQueuesStatisticsFromGivenPortOutput>> getAllQueuesStatisticsFromGivenPort(
72 final GetAllQueuesStatisticsFromGivenPortInput input) {
73 final RequestContext requestContext = rpcContext.createRequestContext();
74 final SettableFuture<RpcResult<GetAllQueuesStatisticsFromGivenPortOutput>> result = rpcContext.storeOrFail(requestContext);
76 if (!result.isDone()) {
77 final Xid xid = deviceContext.getNextXid();
80 MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
81 MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
83 mprQueueBuilder.setQueueId(OFConstants.OFPQ_ANY);
84 // Select specific port
85 mprQueueBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
86 OpenflowVersion.get(version),
87 input.getNodeConnectorId()));
88 caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
90 // Set request body to main multipart request
91 MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(MultipartType.OFPMPQUEUE, xid.getValue(), version);
92 mprInput.setMultipartRequestBody(caseBuilder.build());
93 Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext().getConnectionAdapter().multipartRequest(mprInput.build());
94 ListenableFuture<RpcResult<Void>> futureResultFromOfLib = JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
96 final RpcResultConvertor<SetConfigOutput> rpcResultConvertor = new RpcResultConvertor<>(requestContext);
97 rpcResultConvertor.processResultFromOfJava(futureResultFromOfLib, provideWaitTime());
99 RequestContextUtil.closeRequstContext(requestContext);
105 public Future<RpcResult<GetQueueStatisticsFromGivenPortOutput>> getQueueStatisticsFromGivenPort(
106 final GetQueueStatisticsFromGivenPortInput input) {
107 final RequestContext requestContext = rpcContext.createRequestContext();
108 final SettableFuture<RpcResult<GetQueueStatisticsFromGivenPortOutput>> result = rpcContext.storeOrFail(requestContext);
110 if (!result.isDone()) {
111 final Xid xid = deviceContext.getNextXid();
113 MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
114 MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
115 // Select specific queue
116 mprQueueBuilder.setQueueId(input.getQueueId().getValue());
117 // Select specific port
118 mprQueueBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
119 OpenflowVersion.get(version),
120 input.getNodeConnectorId()));
121 caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
123 // Set request body to main multipart request
124 MultipartRequestInputBuilder mprInput = RequestInputUtils
125 .createMultipartHeader(MultipartType.OFPMPQUEUE, xid.getValue(), version);
126 mprInput.setMultipartRequestBody(caseBuilder.build());
127 Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext()
128 .getConnectionAdapter().multipartRequest(mprInput.build());
129 ListenableFuture<RpcResult<Void>> futureResultFromOfLib = JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
131 final RpcResultConvertor<SetConfigOutput> rpcResultConvertor = new RpcResultConvertor<>(requestContext);
132 rpcResultConvertor.processResultFromOfJava(futureResultFromOfLib, provideWaitTime());
134 RequestContextUtil.closeRequstContext(requestContext);