Statistics services implementation and cleanup
[openflowplugin.git] / openflowplugin-impl / src / main / java / org / opendaylight / openflowplugin / impl / services / OpendaylightPortStatisticsServiceImpl.java
index e173f31922fc64e7ffb1a0b18f6682bd74eaeb8b..bf2a9b4c5353c1b1e7ef7bb5d19cb5d36aba9206 100644 (file)
 /**
  * Copyright (c) 2015 Cisco Systems, Inc. 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.services;
 
-import java.util.concurrent.Future;
-import org.opendaylight.openflowplugin.api.openflow.rpc.RpcContext;
+import com.google.common.util.concurrent.JdkFutureAdapters;
+import com.google.common.util.concurrent.ListenableFuture;
+import com.google.common.util.concurrent.SettableFuture;
+import org.opendaylight.openflowplugin.api.OFConstants;
+import org.opendaylight.openflowplugin.api.openflow.device.RequestContext;
+import org.opendaylight.openflowplugin.api.openflow.device.Xid;
+import org.opendaylight.openflowplugin.api.openflow.md.util.OpenflowVersion;
+import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.module.config.rev141015.SetConfigOutput;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInputBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestPortStatsCaseBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.port.stats._case.MultipartRequestPortStatsBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetAllNodeConnectorsStatisticsInput;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetAllNodeConnectorsStatisticsOutput;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetNodeConnectorStatisticsInput;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetNodeConnectorStatisticsOutput;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.OpendaylightPortStatisticsService;
 import org.opendaylight.yangtools.yang.common.RpcResult;
+import java.util.concurrent.Future;
 
 /**
  * @author joe
- * 
  */
-// TODO: implement this
 public class OpendaylightPortStatisticsServiceImpl extends CommonService implements OpendaylightPortStatisticsService {
 
-    /*
-         * (non-Javadoc)
-         *
-         * @see org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.OpendaylightPortStatisticsService#
-         * getAllNodeConnectorsStatistics
-         * (org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetAllNodeConnectorsStatisticsInput)
-         */
     @Override
     public Future<RpcResult<GetAllNodeConnectorsStatisticsOutput>> getAllNodeConnectorsStatistics(
             final GetAllNodeConnectorsStatisticsInput input) {
-        // TODO Auto-generated method stub
-        return null;
+        final RequestContext requestContext = rpcContext.createRequestContext();
+        final SettableFuture<RpcResult<GetAllNodeConnectorsStatisticsOutput>> result = rpcContext.storeOrFail(requestContext);
+
+        if (!result.isDone()) {
+
+            final Xid xid = deviceContext.getNextXid();
+
+            MultipartRequestPortStatsCaseBuilder caseBuilder =
+                    new MultipartRequestPortStatsCaseBuilder();
+            MultipartRequestPortStatsBuilder mprPortStatsBuilder =
+                    new MultipartRequestPortStatsBuilder();
+            // Select all ports
+            mprPortStatsBuilder.setPortNo(OFConstants.OFPP_ANY);
+            caseBuilder.setMultipartRequestPortStats(mprPortStatsBuilder.build());
+
+            MultipartRequestInputBuilder mprInput = RequestInputUtils
+                    .createMultipartHeader(MultipartType.OFPMPPORTSTATS, xid.getValue(), version);
+            mprInput.setMultipartRequestBody(caseBuilder.build());
+            Future<RpcResult<Void>> resultFromOFLib = deviceContext
+                    .getPrimaryConnectionContext().getConnectionAdapter().multipartRequest(mprInput.build());
+            ListenableFuture<RpcResult<Void>> futureResultFromOfLib = JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
+
+            final RpcResultConvertor<SetConfigOutput> rpcResultConvertor = new RpcResultConvertor<>(requestContext);
+            rpcResultConvertor.processResultFromOfJava(futureResultFromOfLib, provideWaitTime());
+
+        }
+        return result;
     }
 
-    /*
-     * (non-Javadoc)
-     * 
-     * @see org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.OpendaylightPortStatisticsService#
-     * getNodeConnectorStatistics
-     * (org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetNodeConnectorStatisticsInput)
-     */
     @Override
     public Future<RpcResult<GetNodeConnectorStatisticsOutput>> getNodeConnectorStatistics(
             final GetNodeConnectorStatisticsInput input) {
-        // TODO Auto-generated method stub
-        return null;
+        final RequestContext requestContext = rpcContext.createRequestContext();
+        final SettableFuture<RpcResult<GetNodeConnectorStatisticsOutput>> result = rpcContext.storeOrFail(requestContext);
+
+        if (!result.isDone()) {
+            final Xid xid = deviceContext.getNextXid();
+
+            MultipartRequestPortStatsCaseBuilder caseBuilder =
+                    new MultipartRequestPortStatsCaseBuilder();
+            MultipartRequestPortStatsBuilder mprPortStatsBuilder =
+                    new MultipartRequestPortStatsBuilder();
+            // Set specific port
+            mprPortStatsBuilder
+                    .setPortNo(InventoryDataServiceUtil.portNumberfromNodeConnectorId(
+                            OpenflowVersion.get(version),
+                            input.getNodeConnectorId()));
+            caseBuilder.setMultipartRequestPortStats(mprPortStatsBuilder.build());
+
+            MultipartRequestInputBuilder mprInput = RequestInputUtils
+                    .createMultipartHeader(MultipartType.OFPMPPORTSTATS, xid.getValue(), version);
+            mprInput.setMultipartRequestBody(caseBuilder.build());
+            Future<RpcResult<Void>> resultFromOFLib = deviceContext.getPrimaryConnectionContext()
+                    .getConnectionAdapter().multipartRequest(mprInput.build());
+            ListenableFuture<RpcResult<Void>> futureResultFromOfLib = JdkFutureAdapters.listenInPoolThread(resultFromOFLib);
+
+            final RpcResultConvertor<SetConfigOutput> rpcResultConvertor = new RpcResultConvertor<>(requestContext);
+            rpcResultConvertor.processResultFromOfJava(futureResultFromOfLib, provideWaitTime());
+        }
+        return result;
     }
 
 }