package org.opendaylight.netvirt.elan.internal;
import java.util.stream.Collectors;
-import javax.annotation.PostConstruct;
+import javax.annotation.PreDestroy;
import javax.inject.Inject;
import javax.inject.Singleton;
-import org.opendaylight.controller.md.sal.binding.api.DataBroker;
-import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
-import org.opendaylight.genius.datastoreutils.AsyncDataTreeChangeListenerBase;
+import org.opendaylight.infrautils.utils.concurrent.Executors;
+import org.opendaylight.mdsal.binding.api.DataBroker;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
import org.opendaylight.netvirt.elan.utils.TransportZoneNotificationUtil;
+import org.opendaylight.serviceutils.tools.listener.AbstractAsyncDataTreeChangeListener;
import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.elan.config.rev150710.ElanConfig;
import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.VpnInstanceOpData;
import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.vpn.instance.op.data.VpnInstanceOpDataEntry;
@Singleton
public class VpnDpnToTransportZoneListener
- extends AsyncDataTreeChangeListenerBase<VpnToDpnList, VpnDpnToTransportZoneListener> {
+ extends AbstractAsyncDataTreeChangeListener<VpnToDpnList> {
private static final Logger LOG = LoggerFactory.getLogger(VpnDpnToTransportZoneListener.class);
private final TransportZoneNotificationUtil transportZoneNotificationUtil;
@Inject
public VpnDpnToTransportZoneListener(final DataBroker dbx,
final ElanConfig elanConfig, final TransportZoneNotificationUtil tznu) {
+ super(dbx, LogicalDatastoreType.OPERATIONAL, InstanceIdentifier.create(VpnInstanceOpData.class)
+ .child(VpnInstanceOpDataEntry.class).child(VpnToDpnList.class),
+ Executors.newListeningSingleThreadExecutor("VpnDpnToTransportZoneListener", LOG));
useTransportZone = elanConfig.isAutoConfigTransportZones();
transportZoneNotificationUtil = tznu;
this.dbx = dbx;
+ start();
}
- @PostConstruct
public void start() {
-
if (useTransportZone) {
- registerListener(LogicalDatastoreType.OPERATIONAL, dbx);
LOG.info("{} registered", getClass().getSimpleName());
}
}
@Override
- protected InstanceIdentifier<VpnToDpnList> getWildCardPath() {
- return InstanceIdentifier.builder(VpnInstanceOpData.class).child(VpnInstanceOpDataEntry.class)
- .child(VpnToDpnList.class).build();
+ @PreDestroy
+ public void close() {
+ super.close();
+ Executors.shutdownAndAwaitTermination(getExecutorService());
}
@Override
- protected void remove(InstanceIdentifier<VpnToDpnList> identifier, VpnToDpnList del) {
+ public void remove(InstanceIdentifier<VpnToDpnList> identifier, VpnToDpnList del) {
+ if (!useTransportZone) {
+ return;
+ }
LOG.debug("Vpn dpn {} remove detected, SHOULD BE deleting transport zones", del.getDpnId());
}
@Override
- protected void update(InstanceIdentifier<VpnToDpnList> identifier, VpnToDpnList original, VpnToDpnList update) {
+ public void update(InstanceIdentifier<VpnToDpnList> identifier, VpnToDpnList original, VpnToDpnList update) {
+ if (!useTransportZone) {
+ return;
+ }
LOG.debug("Vpn dpn {} update detected, updating transport zones", update.getDpnId());
if (update.getVpnInterfaces() == null || update.getVpnInterfaces().isEmpty()) {
}
@Override
- protected void add(InstanceIdentifier<VpnToDpnList> identifier, VpnToDpnList add) {
+ public void add(InstanceIdentifier<VpnToDpnList> identifier, VpnToDpnList add) {
+ if (!useTransportZone) {
+ return;
+ }
LOG.debug("Vpn dpn {} add detected, updating transport zones", add.getDpnId());
boolean shouldCreateVtep = transportZoneNotificationUtil.shouldCreateVtep(add.getVpnInterfaces());
transportZoneNotificationUtil.updateTransportZone(vrfId, add.getDpnId());
}
}
-
- @Override
- protected VpnDpnToTransportZoneListener getDataTreeChangeListener() {
- return VpnDpnToTransportZoneListener.this;
- }
}