Policy exclusions & parallel netconf transactions
[groupbasedpolicy.git] / renderers / vpp / src / main / java / org / opendaylight / controller / config / yang / config / vpp_provider / impl / VppRenderer.java
index cf90406a2971cf72bf9ff25035f4db9ea62944de..c6fbf448108b922da34321de1f9ce8fde3e5caba 100644 (file)
@@ -8,9 +8,11 @@
 
 package org.opendaylight.controller.config.yang.config.vpp_provider.impl;
 
+import java.util.ArrayList;
 import java.util.List;
-import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
+
+import javax.annotation.Nonnull;
+import javax.annotation.Nullable;
 
 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
 import org.opendaylight.controller.md.sal.binding.api.MountPointService;
@@ -19,16 +21,29 @@ import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
 import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;
 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker;
 import org.opendaylight.controller.sal.binding.api.BindingAwareProvider;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.api.BridgeDomainManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.dhcp.DhcpRelayHandler;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.iface.InterfaceManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.lisp.LispStateManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.lisp.event.manager.GbpSubnetEventManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.lisp.flat.overlay.FlatOverlayManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.lisp.loopback.LoopbackManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.listener.GbpSubnetListener;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.listener.RendererPolicyListener;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.listener.VppEndpointListener;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.listener.VppNodeListener;
-import org.opendaylight.groupbasedpolicy.renderer.vpp.manager.BridgeDomainManagerImpl;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.manager.VppNodeManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.nat.NatManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.policy.BridgeDomainManagerImpl;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.policy.ForwardingManager;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.policy.VppRendererPolicyManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.policy.acl.AclManager;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.routing.RoutingManager;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.sf.AllowAction;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.sf.Classifier;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.sf.EtherTypeClassifier;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.sf.IpProtoClassifier;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.sf.L4Classifier;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.util.MountedDataBrokerProvider;
 import org.opendaylight.groupbasedpolicy.renderer.vpp.util.VppIidFactory;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.RendererName;
@@ -50,41 +65,51 @@ import com.google.common.eventbus.EventBus;
 import com.google.common.util.concurrent.CheckedFuture;
 import com.google.common.util.concurrent.FutureCallback;
 import com.google.common.util.concurrent.Futures;
-import com.google.common.util.concurrent.ThreadFactoryBuilder;
 
 public class VppRenderer implements AutoCloseable, BindingAwareProvider {
 
-    private static final Logger LOG = LoggerFactory.getLogger(VppRenderer.class);
-
     public static final RendererName NAME = new RendererName("vpp-renderer");
-    /**
-     * Should be used for processing netconf responses so we do not consume netty thread.
-     */
-    private static final ExecutorService NETCONF_WORKER = Executors.newSingleThreadExecutor(
-            new ThreadFactoryBuilder().setNameFormat("netconf-processing-worker-%d").setDaemon(true).build());
-
+    private static final Logger LOG = LoggerFactory.getLogger(VppRenderer.class);
     private final List<SupportedActionDefinition> actionDefinitions =
             ImmutableList.of(new SupportedActionDefinitionBuilder().setActionDefinitionId(new AllowAction().getId())
-                .setSupportedParameterValues(new AllowAction().getSupportedParameterValues())
-                .build());
-    private final List<SupportedClassifierDefinition> classifierDefinitions = ImmutableList
-        .of(new SupportedClassifierDefinitionBuilder().setClassifierDefinitionId(new EtherTypeClassifier(null).getId())
-            .setSupportedParameterValues(new EtherTypeClassifier(null).getSupportedParameterValues())
-            .build());
+                    .setSupportedParameterValues(new AllowAction().getSupportedParameterValues())
+                    .build());
+    private final List<SupportedClassifierDefinition> classifierDefinitions;
 
     private final DataBroker dataBroker;
-
-    private VppNodeManager vppNodeManager;
+    private final String publicInterfaces;
     private InterfaceManager interfaceManager;
-    private VppRendererPolicyManager vppRendererPolicyManager;
-
+    private MountedDataBrokerProvider mountDataProvider;
+    private BridgeDomainManager bdManager;
     private VppNodeListener vppNodeListener;
     private VppEndpointListener vppEndpointListener;
     private RendererPolicyListener rendererPolicyListener;
+    private GbpSubnetListener vppGbpSubnetListener;
+    private GbpSubnetEventManager subnetEventManager;
 
-    public VppRenderer(DataBroker dataBroker, BindingAwareBroker bindingAwareBroker) {
+    VppRenderer(@Nonnull DataBroker dataBroker, @Nonnull BindingAwareBroker bindingAwareBroker,
+                       @Nullable String publicInterfaces) {
         this.dataBroker = Preconditions.checkNotNull(dataBroker);
+        this.publicInterfaces = publicInterfaces;
         bindingAwareBroker.registerProvider(this);
+        EtherTypeClassifier etherTypeClassifier = new EtherTypeClassifier(null);
+        IpProtoClassifier ipProtoClassifier = new IpProtoClassifier(etherTypeClassifier);
+        classifierDefinitions =
+                buildClassifierDefinitions(etherTypeClassifier, ipProtoClassifier, new L4Classifier(ipProtoClassifier));
+    }
+
+    private List<SupportedClassifierDefinition> buildClassifierDefinitions(Classifier... classifs) {
+        List<SupportedClassifierDefinition> clDefs = new ArrayList<>();
+        SupportedClassifierDefinitionBuilder clDefBuilder = new SupportedClassifierDefinitionBuilder();
+        for (Classifier classif : classifs) {
+            if (classif.getParent() != null) {
+                clDefBuilder.setParentClassifierDefinitionId(classif.getParent().getId());
+            }
+            clDefs.add(clDefBuilder.setClassifierDefinitionId(classif.getId())
+                    .setSupportedParameterValues(classif.getSupportedParameterValues())
+                    .build());
+        }
+        return clDefs;
     }
 
     @Override
@@ -102,6 +127,10 @@ public class VppRenderer implements AutoCloseable, BindingAwareProvider {
         if (interfaceManager != null) {
             interfaceManager.close();
         }
+
+        if (vppGbpSubnetListener != null) {
+            vppGbpSubnetListener.close();
+        }
         unregisterFromRendererManager();
     }
 
@@ -111,20 +140,34 @@ public class VppRenderer implements AutoCloseable, BindingAwareProvider {
 
         MountPointService mountService =
                 Preconditions.checkNotNull(providerContext.getSALService(MountPointService.class));
-        MountedDataBrokerProvider mountDataProvider = new MountedDataBrokerProvider(mountService);
-        vppNodeManager = new VppNodeManager(dataBroker, providerContext);
-
-        EventBus dtoEventBus = new EventBus("DTO events");
-        interfaceManager = new InterfaceManager(mountDataProvider, dataBroker, NETCONF_WORKER);
+        mountDataProvider = new MountedDataBrokerProvider(mountService, dataBroker);
+        VppNodeManager vppNodeManager = new VppNodeManager(dataBroker, providerContext, publicInterfaces);
+
+        EventBus dtoEventBus = new EventBus((exception, context) -> LOG.error("Could not dispatch event: {} to {}",
+                context.getSubscriber(), context.getSubscriberMethod(), exception));
+        LispStateManager lispStateManager = new LispStateManager(mountDataProvider);
+        FlatOverlayManager flatOverlayManager = new FlatOverlayManager(dataBroker, mountDataProvider);
+        LoopbackManager loopbackManager = new LoopbackManager(mountDataProvider);
+
+        interfaceManager = new InterfaceManager(mountDataProvider, dataBroker, flatOverlayManager);
+        AclManager aclManager = new AclManager(mountDataProvider, interfaceManager);
+        NatManager natManager = new NatManager(dataBroker, mountDataProvider);
+        subnetEventManager = new GbpSubnetEventManager(loopbackManager);
         dtoEventBus.register(interfaceManager);
-        ForwardingManager fwManager = new ForwardingManager(interfaceManager, new BridgeDomainManagerImpl(dataBroker));
-        vppRendererPolicyManager = new VppRendererPolicyManager(fwManager, dataBroker);
+        dtoEventBus.register(subnetEventManager);
+        RoutingManager routingManager = new RoutingManager(dataBroker, mountDataProvider);
+        DhcpRelayHandler dhcpRelayHandler = new DhcpRelayHandler(dataBroker, mountDataProvider);
+        bdManager = new BridgeDomainManagerImpl(dataBroker);
+        ForwardingManager fwManager =
+                new ForwardingManager(interfaceManager, aclManager, natManager, routingManager, bdManager,
+                        lispStateManager, loopbackManager, flatOverlayManager, dhcpRelayHandler, dataBroker);
+        VppRendererPolicyManager vppRendererPolicyManager = new VppRendererPolicyManager(fwManager, aclManager, dataBroker);
         dtoEventBus.register(vppRendererPolicyManager);
 
         vppNodeListener = new VppNodeListener(dataBroker, vppNodeManager, dtoEventBus);
         vppEndpointListener = new VppEndpointListener(dataBroker, dtoEventBus);
         rendererPolicyListener = new RendererPolicyListener(dataBroker, dtoEventBus);
-
+        vppGbpSubnetListener = new GbpSubnetListener(dataBroker, dtoEventBus);
         registerToRendererManager();
     }
 
@@ -132,11 +175,11 @@ public class VppRenderer implements AutoCloseable, BindingAwareProvider {
         WriteTransaction writeTransaction = dataBroker.newWriteOnlyTransaction();
 
         Renderer renderer = new RendererBuilder().setName(VppRenderer.NAME)
-            .setRendererNodes(new RendererNodesBuilder().build())
-            .setCapabilities(new CapabilitiesBuilder().setSupportedActionDefinition(actionDefinitions)
-                .setSupportedClassifierDefinition(classifierDefinitions)
-                .build())
-            .build();
+                .setRendererNodes(new RendererNodesBuilder().build())
+                .setCapabilities(new CapabilitiesBuilder().setSupportedActionDefinition(actionDefinitions)
+                        .setSupportedClassifierDefinition(classifierDefinitions)
+                        .build())
+                .build();
 
         writeTransaction.put(LogicalDatastoreType.OPERATIONAL, VppIidFactory.getRendererIID(renderer.getKey()),
                 renderer, true);
@@ -144,7 +187,7 @@ public class VppRenderer implements AutoCloseable, BindingAwareProvider {
         Futures.addCallback(future, new FutureCallback<Void>() {
 
             @Override
-            public void onFailure(Throwable throwable) {
+            public void onFailure(@Nonnull Throwable throwable) {
                 LOG.error("Could not register renderer {}: {}", renderer, throwable);
             }
 
@@ -164,7 +207,7 @@ public class VppRenderer implements AutoCloseable, BindingAwareProvider {
         Futures.addCallback(future, new FutureCallback<Void>() {
 
             @Override
-            public void onFailure(Throwable throwable) {
+            public void onFailure(@Nonnull Throwable throwable) {
                 LOG.error("Could not unregister renderer {}: {}", VppRenderer.NAME, throwable);
             }
 
@@ -174,4 +217,16 @@ public class VppRenderer implements AutoCloseable, BindingAwareProvider {
             }
         });
     }
+
+    public MountedDataBrokerProvider getMountedDataBroker() {
+        return mountDataProvider;
+    }
+
+    public InterfaceManager getInterfaceManager() {
+        return interfaceManager;
+    }
+
+    public BridgeDomainManager getBridgeDomainManager() {
+        return bdManager;
+    }
 }