import org.opendaylight.controller.sal.binding.api.BindingAwareBroker;
import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry;
import org.opendaylight.groupbasedpolicy.renderer.vpp.adapter.VppRpcServiceImpl;
+import org.opendaylight.groupbasedpolicy.renderer.vpp.config.ConfigUtil;
import org.opendaylight.groupbasedpolicy.renderer.vpp.config.ConfigurationService;
import org.opendaylight.mdsal.singleton.common.api.ClusterSingletonService;
import org.opendaylight.mdsal.singleton.common.api.ClusterSingletonServiceProvider;
import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.vpp_adapter.rev161201.DeleteInterfaceFromNodeInput;
import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.vpp_adapter.rev161201.DeleteVirtualBridgeDomainFromNodesInput;
import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.vpp_adapter.rev161201.VppAdapterService;
+import org.opendaylight.yangtools.yang.common.RpcError;
import org.opendaylight.yangtools.yang.common.RpcResult;
+import org.opendaylight.yangtools.yang.common.RpcResultBuilder;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
private static final ServiceGroupIdentifier IDENTIFIER =
ServiceGroupIdentifier.create(GroupbasedpolicyInstance.GBP_SERVICE_GROUP_IDENTIFIER);
+ private static final RpcResult<Void> L2_DISABLED_RESULT =
+ RpcResultBuilder.<Void>status(false).withWarning(RpcError.ErrorType.APPLICATION, "L2 disabled",
+ "Bridge domains are disabled because L3Flat mode is enabled. Check VPP startup config.").build();
private final DataBroker dataBroker;
private final BindingAwareBroker bindingAwareBroker;
private final ClusterSingletonServiceProvider clusterSingletonService;
this.clusterSingletonService = Preconditions.checkNotNull(clusterSingletonService);
this.publicInterfaces = publicInterfaces;
this.rpcProviderRegistry = Preconditions.checkNotNull(rpcProviderRegistry);
- configurationService = new ConfigurationService();
+ this.configurationService = new ConfigurationService();
}
public void initialize() {
LOG.info("Clustering session initiated for {}", this.getClass().getSimpleName());
- singletonServiceRegistration = clusterSingletonService.registerClusterSingletonService(this);
+ try {
+ singletonServiceRegistration = clusterSingletonService.registerClusterSingletonService(this);
+ } catch (Exception e) {
+ LOG.warn("Exception thrown while registering cluster singleton service in {}", this.getClass(), e.getMessage());
+ }
}
@Override
@Override
public Future<RpcResult<Void>> addInterfaceToBridgeDomain(AddInterfaceToBridgeDomainInput input) {
+ if (!ConfigUtil.getInstance().isL3FlatEnabled()) {
return vppRpcService.addInterfaceToBridgeDomain(input);
+ }
+ return Futures.immediateFuture(L2_DISABLED_RESULT);
}
@Override
public Future<RpcResult<Void>> delInterfaceFromBridgeDomain(DelInterfaceFromBridgeDomainInput input) {
- return vppRpcService.delInterfaceFromBridgeDomain(input);
+ if (!ConfigUtil.getInstance().isL3FlatEnabled()) {
+ return vppRpcService.delInterfaceFromBridgeDomain(input);
+ }
+ return Futures.immediateFuture(L2_DISABLED_RESULT);
}
@Override
public Future<RpcResult<Void>> cloneVirtualBridgeDomainOnNodes(CloneVirtualBridgeDomainOnNodesInput input) {
- return vppRpcService.cloneVirtualBridgeDomainOnNodes(input);
+ if (!ConfigUtil.getInstance().isL3FlatEnabled()) {
+ return vppRpcService.cloneVirtualBridgeDomainOnNodes(input);
+ }
+ return Futures.immediateFuture(L2_DISABLED_RESULT);
}
@Override