/* * Copyright (c) 2016 Ericsson India Global Services Pvt Ltd. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.genius.interfacemanager.listeners; import com.google.common.util.concurrent.ListenableFuture; import org.opendaylight.controller.md.sal.binding.api.DataBroker; import org.opendaylight.controller.md.sal.binding.api.DataChangeListener; import org.opendaylight.controller.md.sal.common.api.data.AsyncDataBroker; import org.opendaylight.genius.datastoreutils.AsyncClusteredDataTreeChangeListenerBase; import org.opendaylight.genius.datastoreutils.AsyncDataChangeListenerBase; import org.opendaylight.genius.datastoreutils.DataStoreJobCoordinator; import org.opendaylight.genius.interfacemanager.IfmConstants; import org.opendaylight.genius.interfacemanager.commons.InterfaceManagerCommonUtils; import org.opendaylight.genius.interfacemanager.renderer.ovs.statehelpers.OvsInterfaceTopologyStateUpdateHelper; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbTerminationPointAugmentation; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.NetworkTopology; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.Topology; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.Node; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.node.TerminationPoint; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.List; import java.util.concurrent.Callable; public class TerminationPointStateListener extends AsyncClusteredDataTreeChangeListenerBase { private static final Logger LOG = LoggerFactory.getLogger(TerminationPointStateListener.class); private DataBroker dataBroker; public TerminationPointStateListener(DataBroker dataBroker) { super(OvsdbTerminationPointAugmentation.class, TerminationPointStateListener.class); this.dataBroker = dataBroker; } @Override protected InstanceIdentifier getWildCardPath() { return InstanceIdentifier.builder(NetworkTopology.class).child(Topology.class) .child(Node.class).child(TerminationPoint.class).augmentation(OvsdbTerminationPointAugmentation.class).build(); } @Override protected TerminationPointStateListener getDataTreeChangeListener() { return TerminationPointStateListener.this; } @Override protected void remove(InstanceIdentifier identifier, OvsdbTerminationPointAugmentation tpOld) { LOG.debug("Received remove DataChange Notification for ovsdb termination point {}", tpOld.getName()); if (tpOld.getInterfaceBfdStatus() != null) { LOG.debug("Received termination point removed notification with bfd status values {}", tpOld.getName()); DataStoreJobCoordinator jobCoordinator = DataStoreJobCoordinator.getInstance(); RendererStateRemoveWorker rendererStateRemoveWorker = new RendererStateRemoveWorker(tpOld); jobCoordinator.enqueueJob(tpOld.getName(), rendererStateRemoveWorker); } } @Override protected void update(InstanceIdentifier identifier, OvsdbTerminationPointAugmentation tpOld, OvsdbTerminationPointAugmentation tpNew) { LOG.debug("Received Update DataChange Notification for ovsdb termination point {}", tpNew.getName()); if (tpNew.getInterfaceBfdStatus() != null && !tpNew.getInterfaceBfdStatus().equals(tpOld.getInterfaceBfdStatus())) { LOG.trace("Bfd Status changed for ovsdb termination point identifier: {}, old: {}, new: {}.", identifier, tpOld, tpNew); DataStoreJobCoordinator jobCoordinator = DataStoreJobCoordinator.getInstance(); RendererStateUpdateWorker rendererStateAddWorker = new RendererStateUpdateWorker(identifier, tpNew); jobCoordinator.enqueueJob(tpNew.getName(), rendererStateAddWorker, IfmConstants.JOB_MAX_RETRIES); } } @Override protected void add(InstanceIdentifier identifier, OvsdbTerminationPointAugmentation tpNew) { LOG.debug("Received add DataChange Notification for ovsdb termination point {}", tpNew.getName()); if (tpNew.getInterfaceBfdStatus() != null) { LOG.debug("Received termination point added notification with bfd status values {}", tpNew.getName()); DataStoreJobCoordinator jobCoordinator = DataStoreJobCoordinator.getInstance(); RendererStateUpdateWorker rendererStateUpdateWorker = new RendererStateUpdateWorker(identifier, tpNew); jobCoordinator.enqueueJob(tpNew.getName(), rendererStateUpdateWorker, IfmConstants.JOB_MAX_RETRIES); } } private class RendererStateUpdateWorker implements Callable>> { InstanceIdentifier instanceIdentifier; OvsdbTerminationPointAugmentation terminationPointNew; public RendererStateUpdateWorker(InstanceIdentifier instanceIdentifier, OvsdbTerminationPointAugmentation tpNew) { this.instanceIdentifier = instanceIdentifier; this.terminationPointNew = tpNew; } @Override public List> call() throws Exception { // If another renderer(for eg : CSS) needs to be supported, check can be performed here // to call the respective helpers. return OvsInterfaceTopologyStateUpdateHelper.updateTunnelState(dataBroker, terminationPointNew); } } private class RendererStateRemoveWorker implements Callable>> { OvsdbTerminationPointAugmentation terminationPointOld; public RendererStateRemoveWorker(OvsdbTerminationPointAugmentation tpNew) { this.terminationPointOld = tpNew; } @Override public List> call() throws Exception { LOG.debug("Removing bfd state from cache, if any, for {}", terminationPointOld.getName()); InterfaceManagerCommonUtils.removeBfdStateFromCache(terminationPointOld.getName()); return null; } } }