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.openflow.common.types.rev130731.MultipartType;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInputBuilder;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestPortStatsCaseBuilder;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.port.stats._case.MultipartRequestPortStatsBuilder;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetAllNodeConnectorsStatisticsInput;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetAllNodeConnectorsStatisticsOutput;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetNodeConnectorStatisticsInput;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetNodeConnectorStatisticsOutput;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.OpendaylightPortStatisticsService;
27 import org.opendaylight.yangtools.yang.common.RpcResult;
28 import java.util.concurrent.Future;
33 public class OpendaylightPortStatisticsServiceImpl extends CommonService implements OpendaylightPortStatisticsService {
36 public Future<RpcResult<GetAllNodeConnectorsStatisticsOutput>> getAllNodeConnectorsStatistics(
37 final GetAllNodeConnectorsStatisticsInput input) {
38 final RequestContext<GetAllNodeConnectorsStatisticsOutput> requestContext = rpcContext.createRequestContext();
39 final SettableFuture<RpcResult<GetAllNodeConnectorsStatisticsOutput>> result = rpcContext.storeOrFail(requestContext);
41 if (!result.isDone()) {
43 final Xid xid = deviceContext.getNextXid();
45 MultipartRequestPortStatsCaseBuilder caseBuilder =
46 new MultipartRequestPortStatsCaseBuilder();
47 MultipartRequestPortStatsBuilder mprPortStatsBuilder =
48 new MultipartRequestPortStatsBuilder();
50 mprPortStatsBuilder.setPortNo(OFConstants.OFPP_ANY);
51 caseBuilder.setMultipartRequestPortStats(mprPortStatsBuilder.build());
53 MultipartRequestInputBuilder mprInput = RequestInputUtils
54 .createMultipartHeader(MultipartType.OFPMPPORTSTATS, xid.getValue(), version);
55 mprInput.setMultipartRequestBody(caseBuilder.build());
56 Future<RpcResult<Void>> resultFromOFLib = deviceContext
57 .getPrimaryConnectionContext().getConnectionAdapter().multipartRequest(mprInput.build());
58 ListenableFuture<RpcResult<Void>> futureResultFromOfLib = JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
60 final RpcResultConvertor<GetAllNodeConnectorsStatisticsOutput> rpcResultConvertor = new RpcResultConvertor<>(requestContext, deviceContext);
61 rpcResultConvertor.<Void>processResultFromOfJava(futureResultFromOfLib);
64 RequestContextUtil.closeRequstContext(requestContext);
70 public Future<RpcResult<GetNodeConnectorStatisticsOutput>> getNodeConnectorStatistics(
71 final GetNodeConnectorStatisticsInput input) {
72 final RequestContext<GetNodeConnectorStatisticsOutput> requestContext = rpcContext.createRequestContext();
73 final SettableFuture<RpcResult<GetNodeConnectorStatisticsOutput>> result = rpcContext.storeOrFail(requestContext);
75 if (!result.isDone()) {
76 final Xid xid = deviceContext.getNextXid();
78 MultipartRequestPortStatsCaseBuilder caseBuilder =
79 new MultipartRequestPortStatsCaseBuilder();
80 MultipartRequestPortStatsBuilder mprPortStatsBuilder =
81 new MultipartRequestPortStatsBuilder();
84 .setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
85 OpenflowVersion.get(version),
86 input.getNodeConnectorId()));
87 caseBuilder.setMultipartRequestPortStats(mprPortStatsBuilder.build());
89 MultipartRequestInputBuilder mprInput = RequestInputUtils
90 .createMultipartHeader(MultipartType.OFPMPPORTSTATS, xid.getValue(), version);
91 mprInput.setMultipartRequestBody(caseBuilder.build());
92 Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext()
93 .getConnectionAdapter().multipartRequest(mprInput.build());
94 ListenableFuture<RpcResult<Void>> futureResultFromOfLib = JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
96 final RpcResultConvertor<GetNodeConnectorStatisticsOutput> rpcResultConvertor = new RpcResultConvertor<>(requestContext, deviceContext);
97 rpcResultConvertor.processResultFromOfJava(futureResultFromOfLib);
99 RequestContextUtil.closeRequstContext(requestContext);