OFJResult2RequestCtxFuture uses listenable future
[openflowplugin.git] / openflowplugin-impl / src / main / java / org / opendaylight / openflowplugin / impl / statistics / services / OpendaylightQueueStatisticsServiceImpl.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 package org.opendaylight.openflowplugin.impl.statistics.services;
9
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 org.opendaylight.openflowplugin.api.OFConstants;
14 import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
15 import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
16 import org.opendaylight.openflowplugin.api.openflow.device.Xid;
17 import org.opendaylight.openflowplugin.api.openflow.md.util.OpenflowVersion;
18 import org.opendaylight.openflowplugin.impl.services.CommonService;
19 import org.opendaylight.openflowplugin.impl.services.DataCrate;
20 import org.opendaylight.openflowplugin.impl.services.RequestInputUtils;
21 import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInputBuilder;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestQueueCaseBuilder;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.queue._case.MultipartRequestQueueBuilder;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsInput;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsOutput;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortInput;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortOutput;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortInput;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortOutput;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.OpendaylightQueueStatisticsService;
33 import org.opendaylight.yangtools.yang.common.RpcResult;
34 import java.util.concurrent.Future;
35
36 /**
37  * @author joe
38  */
39 public class OpendaylightQueueStatisticsServiceImpl extends CommonService implements OpendaylightQueueStatisticsService {
40
41     public OpendaylightQueueStatisticsServiceImpl(final RequestContextStack requestContextStack, DeviceContext deviceContext) {
42         super(requestContextStack, deviceContext);
43     }
44
45     @Override
46     public Future<RpcResult<GetAllQueuesStatisticsFromAllPortsOutput>> getAllQueuesStatisticsFromAllPorts(
47             final GetAllQueuesStatisticsFromAllPortsInput input) {
48         return this.<GetAllQueuesStatisticsFromAllPortsOutput, Void>handleServiceCall(
49                 PRIMARY_CONNECTION, new Function<DataCrate<GetAllQueuesStatisticsFromAllPortsOutput>, ListenableFuture<RpcResult<Void>>>() {
50
51                     @Override
52                     public ListenableFuture<RpcResult<Void>> apply(final DataCrate<GetAllQueuesStatisticsFromAllPortsOutput> data) {
53
54
55                         MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
56                         MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
57                         // Select all ports
58                         mprQueueBuilder.setPortNo(OFConstants.OFPP_ANY);
59                         // Select all the ports
60                         mprQueueBuilder.setQueueId(OFConstants.OFPQ_ANY);
61                         caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
62
63                         // Set request body to main multipart request
64                         final Xid xid = deviceContext.getNextXid();
65                         data.getRequestContext().setXid(xid);
66                         MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(
67                                 MultipartType.OFPMPQUEUE, xid.getValue(), version);
68                         mprInput.setMultipartRequestBody(caseBuilder.build());
69                         Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext()
70                                 .getConnectionAdapter().multipartRequest(mprInput.build());
71                         return JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
72                     }
73                 });
74
75     }
76
77     @Override
78     public Future<RpcResult<GetAllQueuesStatisticsFromGivenPortOutput>> getAllQueuesStatisticsFromGivenPort(
79             final GetAllQueuesStatisticsFromGivenPortInput input) {
80         return this.<GetAllQueuesStatisticsFromGivenPortOutput, Void>handleServiceCall(
81                 PRIMARY_CONNECTION, new Function<DataCrate<GetAllQueuesStatisticsFromGivenPortOutput>, ListenableFuture<RpcResult<Void>>>() {
82
83                     @Override
84                     public ListenableFuture<RpcResult<Void>> apply(final DataCrate<GetAllQueuesStatisticsFromGivenPortOutput> data) {
85
86                         MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
87                         MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
88                         // Select all queues
89                         mprQueueBuilder.setQueueId(OFConstants.OFPQ_ANY);
90                         // Select specific port
91                         mprQueueBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
92                                 OpenflowVersion.get(version), input.getNodeConnectorId()));
93                         caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
94
95                         // Set request body to main multipart request
96                         final Xid xid = deviceContext.getNextXid();
97                         data.getRequestContext().setXid(xid);
98                         MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(
99                                 MultipartType.OFPMPQUEUE, xid.getValue(), version);
100                         mprInput.setMultipartRequestBody(caseBuilder.build());
101                         Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext()
102                                 .getConnectionAdapter().multipartRequest(mprInput.build());
103                         return JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
104
105                     }
106                 });
107     }
108
109     @Override
110     public Future<RpcResult<GetQueueStatisticsFromGivenPortOutput>> getQueueStatisticsFromGivenPort(
111             final GetQueueStatisticsFromGivenPortInput input) {
112         return this.<GetQueueStatisticsFromGivenPortOutput, Void>handleServiceCall(
113                 PRIMARY_CONNECTION, new Function<DataCrate<GetQueueStatisticsFromGivenPortOutput>, ListenableFuture<RpcResult<Void>>>() {
114
115                     @Override
116                     public ListenableFuture<RpcResult<Void>> apply(final DataCrate<GetQueueStatisticsFromGivenPortOutput> data) {
117
118                         MultipartRequestQueueCaseBuilder caseBuilder = new MultipartRequestQueueCaseBuilder();
119                         MultipartRequestQueueBuilder mprQueueBuilder = new MultipartRequestQueueBuilder();
120                         // Select specific queue
121                         mprQueueBuilder.setQueueId(input.getQueueId().getValue());
122                         // Select specific port
123                         mprQueueBuilder.setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
124                                 OpenflowVersion.get(version), input.getNodeConnectorId()));
125                         caseBuilder.setMultipartRequestQueue(mprQueueBuilder.build());
126
127                         // Set request body to main multipart request
128                         final Xid xid = deviceContext.getNextXid();
129                         data.getRequestContext().setXid(xid);
130                         MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(
131                                 MultipartType.OFPMPQUEUE, xid.getValue(), version);
132                         mprInput.setMultipartRequestBody(caseBuilder.build());
133                         Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext()
134                                 .getConnectionAdapter().multipartRequest(mprInput.build());
135                         return JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
136                     }
137                 });
138     }
139
140 }