package org.opendaylight.controller.config.yang.config.vpp_provider.impl;
-import java.util.List;
-
+import com.google.common.base.Preconditions;
+import com.google.common.collect.ImmutableList;
+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 org.opendaylight.controller.md.sal.binding.api.DataBroker;
import org.opendaylight.controller.md.sal.binding.api.MountPointService;
import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
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.loopback.LoopbackManager;
+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.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.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 org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.renderers.Renderer;
import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.renderers.RendererBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.renderers.RendererKey;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
-import com.google.common.base.Preconditions;
-import com.google.common.collect.ImmutableList;
-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 javax.annotation.Nonnull;
+import javax.annotation.Nullable;
+import java.util.ArrayList;
+import java.util.List;
public class VppRenderer implements AutoCloseable, BindingAwareProvider {
+ public static final RendererName NAME = new RendererName("vpp-renderer");
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 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 (vppEndpointListener != null) {
vppEndpointListener.close();
}
+ if (rendererPolicyListener != null) {
+ rendererPolicyListener.close();
+ }
if (interfaceManager != null) {
interfaceManager.close();
}
+
+ if (vppGbpSubnetListener != null) {
+ vppGbpSubnetListener.close();
+ }
unregisterFromRendererManager();
}
public void onSessionInitiated(BindingAwareBroker.ProviderContext providerContext) {
LOG.info("starting vpp renderer");
- MountPointService mountService = Preconditions.checkNotNull(providerContext.getSALService(MountPointService.class));
- MountedDataBrokerProvider mountDataProvider = new MountedDataBrokerProvider(mountService);
- vppNodeManager = new VppNodeManager(dataBroker, providerContext);
+ MountPointService mountService =
+ Preconditions.checkNotNull(providerContext.getSALService(MountPointService.class));
+ mountDataProvider = new MountedDataBrokerProvider(mountService, dataBroker);
+ VppNodeManager vppNodeManager = new VppNodeManager(dataBroker, providerContext, publicInterfaces);
- EventBus dtoEventBus = new EventBus("DTO events");
+ EventBus dtoEventBus = new EventBus((exception, context) -> LOG.error("Could not dispatch event: {} to {}",
+ context.getSubscriber(), context.getSubscriberMethod(), exception));
interfaceManager = new InterfaceManager(mountDataProvider, dataBroker);
+ AclManager aclManager = new AclManager(mountDataProvider);
+ NatManager natManager = new NatManager(dataBroker, mountDataProvider);
+ LispStateManager lispStateManager = new LispStateManager(mountDataProvider);
+ FlatOverlayManager flatOverlayManager = new FlatOverlayManager(mountDataProvider);
+ LoopbackManager loopbackManager = new LoopbackManager(mountDataProvider);
+ subnetEventManager = new GbpSubnetEventManager(loopbackManager);
dtoEventBus.register(interfaceManager);
+ dtoEventBus.register(subnetEventManager);
+ RoutingManager routingManager = new RoutingManager(dataBroker, mountDataProvider);
+ DhcpRelayHandler dhcpRelayHandler = new DhcpRelayHandler(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();
}
private void registerToRendererManager() {
WriteTransaction writeTransaction = dataBroker.newWriteOnlyTransaction();
- Renderer renderer = new RendererBuilder().setName(VppNodeManager.vppRenderer)
- .setRendererNodes(new RendererNodesBuilder().build())
- .setCapabilities(new CapabilitiesBuilder().setSupportedActionDefinition(actionDefinitions)
- .setSupportedClassifierDefinition(classifierDefinitions)
- .build())
- .build();
+ Renderer renderer = new RendererBuilder().setName(VppRenderer.NAME)
+ .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);
}
});
}
-
private void unregisterFromRendererManager() {
WriteTransaction writeTransaction = dataBroker.newWriteOnlyTransaction();
- writeTransaction.delete(LogicalDatastoreType.OPERATIONAL, VppIidFactory.getRendererIID(new RendererKey(VppNodeManager.vppRenderer)));
+ writeTransaction.delete(LogicalDatastoreType.OPERATIONAL,
+ VppIidFactory.getRendererIID(new RendererKey(VppRenderer.NAME)));
CheckedFuture<Void, TransactionCommitFailedException> future = writeTransaction.submit();
Futures.addCallback(future, new FutureCallback<Void>() {
@Override
- public void onFailure(Throwable throwable) {
- LOG.error("Could not unregister renderer {}: {}", VppNodeManager.vppRenderer, throwable);
+ public void onFailure(@Nonnull Throwable throwable) {
+ LOG.error("Could not unregister renderer {}: {}", VppRenderer.NAME, throwable);
}
@Override
public void onSuccess(Void result) {
- LOG.debug("Renderer {} successfully unregistered.", VppNodeManager.vppRenderer);
+ LOG.debug("Renderer {} successfully unregistered.", VppRenderer.NAME);
}
});
}
+
+ public MountedDataBrokerProvider getMountedDataBroker() {
+ return mountDataProvider;
+ }
+
+ public InterfaceManager getInterfaceManager() {
+ return interfaceManager;
+ }
+
+ public BridgeDomainManager getBridgeDomainManager() {
+ return bdManager;
+ }
}