Decompose RPC implementation classes
[openflowplugin.git] / openflowplugin-impl / src / main / java / org / opendaylight / openflowplugin / impl / statistics / services / direct / AbstractGetNodeConnectorStatistics.java
@@ -8,25 +8,27 @@
 
 package org.opendaylight.openflowplugin.impl.statistics.services.direct;
 
+import com.google.common.util.concurrent.ListenableFuture;
 import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
 import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
 import org.opendaylight.openflowplugin.impl.datastore.MultipartWriterProvider;
 import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.ConvertorExecutor;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatistics;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsInput;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsOutput;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OfHeader;
+import org.opendaylight.yangtools.yang.common.RpcResult;
 
 /**
  * The Node connector direct statistics service.
  */
-public abstract class AbstractPortDirectStatisticsService<T extends OfHeader>
-        extends AbstractDirectStatisticsService<GetNodeConnectorStatisticsInput, GetNodeConnectorStatisticsOutput, T> {
-
-    public AbstractPortDirectStatisticsService(final RequestContextStack requestContextStack,
-                                               final DeviceContext deviceContext,
-                                               final ConvertorExecutor convertorExecutor,
-                                               final MultipartWriterProvider statisticsWriterProvider) {
+public abstract class AbstractGetNodeConnectorStatistics<T extends OfHeader>
+        extends AbstractDirectStatisticsService<GetNodeConnectorStatisticsInput, GetNodeConnectorStatisticsOutput, T>
+        implements GetNodeConnectorStatistics {
+    protected AbstractGetNodeConnectorStatistics(final RequestContextStack requestContextStack,
+            final DeviceContext deviceContext, final ConvertorExecutor convertorExecutor,
+            final MultipartWriterProvider statisticsWriterProvider) {
         super(MultipartType.OFPMPPORTSTATS,
                 requestContextStack,
                 deviceContext,
@@ -34,4 +36,9 @@ public abstract class AbstractPortDirectStatisticsService<T extends OfHeader>
                 statisticsWriterProvider);
     }
 
+    @Override
+    public final ListenableFuture<RpcResult<GetNodeConnectorStatisticsOutput>> invoke(
+            final GetNodeConnectorStatisticsInput input) {
+        return handleAndReply(input);
+    }
 }