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;
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;
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
if (interfaceManager != null) {
interfaceManager.close();
}
+
+ if (vppGbpSubnetListener != null) {
+ vppGbpSubnetListener.close();
+ }
unregisterFromRendererManager();
}
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();
}
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);
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);
}
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);
}
}
});
}
+
+ public MountedDataBrokerProvider getMountedDataBroker() {
+ return mountDataProvider;
+ }
+
+ public InterfaceManager getInterfaceManager() {
+ return interfaceManager;
+ }
+
+ public BridgeDomainManager getBridgeDomainManager() {
+ return bdManager;
+ }
}