/* * Copyright (c) 2016, 2017 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 java.util.List; import java.util.concurrent.Callable; 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.genius.interfacemanager.IfmConstants; import org.opendaylight.genius.interfacemanager.renderer.hwvtep.confighelpers.HwVTEPConfigRemoveHelper; import org.opendaylight.genius.interfacemanager.renderer.hwvtep.confighelpers.HwVTEPInterfaceConfigAddHelper; import org.opendaylight.genius.interfacemanager.renderer.hwvtep.confighelpers.HwVTEPInterfaceConfigUpdateHelper; import org.opendaylight.genius.interfacemanager.renderer.hwvtep.utilities.SouthboundUtils; import org.opendaylight.infrautils.jobcoordinator.JobCoordinator; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.Interfaces; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.Interface; import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.rev160406.IfTunnel; import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.rev160406.ParentRefs; import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.rev160406.TunnelTypeVxlan; import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.rev160406.interfaces._interface.NodeIdentifier; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.Node; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @Singleton public class HwVTEPConfigListener extends AsyncDataTreeChangeListenerBase { private static final Logger LOG = LoggerFactory.getLogger(HwVTEPConfigListener.class); private final DataBroker dataBroker; private final JobCoordinator coordinator; @Inject public HwVTEPConfigListener(final DataBroker dataBroker, final JobCoordinator coordinator) { super(Interface.class, HwVTEPConfigListener.class); this.dataBroker = dataBroker; this.coordinator = coordinator; this.registerListener(LogicalDatastoreType.CONFIGURATION, dataBroker); } @Override protected InstanceIdentifier getWildCardPath() { return InstanceIdentifier.create(Interfaces.class).child(Interface.class); } @Override protected void remove(InstanceIdentifier key, Interface interfaceOld) { // HwVTEPs support only vxlan IfTunnel ifTunnel = interfaceOld.getAugmentation(IfTunnel.class); if (ifTunnel != null && ifTunnel.getTunnelInterfaceType().isAssignableFrom(TunnelTypeVxlan.class)) { ParentRefs parentRefs = interfaceOld.getAugmentation(ParentRefs.class); if (parentRefs != null && parentRefs.getNodeIdentifier() != null) { LOG.debug("Received HwVTEP Interface Remove Event: {}", interfaceOld.getName()); LOG.trace("Received HwVTEP Interface Remove Event: {}, {}", key, interfaceOld); for (NodeIdentifier nodeIdentifier : parentRefs.getNodeIdentifier()) { if (SouthboundUtils.HWVTEP_TOPOLOGY.equals(nodeIdentifier.getTopologyId())) { RendererConfigRemoveWorker configWorker = new RendererConfigRemoveWorker(key, interfaceOld, SouthboundUtils.createPhysicalSwitchInstanceIdentifier(nodeIdentifier.getNodeId()), SouthboundUtils.createGlobalNodeInstanceIdentifier(nodeIdentifier.getNodeId())); coordinator.enqueueJob(interfaceOld.getName(), configWorker, IfmConstants.JOB_MAX_RETRIES); } } } } } @Override protected void update(InstanceIdentifier key, Interface interfaceOld, Interface interfaceNew) { // HwVTEPs support only vxlan IfTunnel ifTunnel = interfaceNew.getAugmentation(IfTunnel.class); if (ifTunnel != null && ifTunnel.getTunnelInterfaceType().isAssignableFrom(TunnelTypeVxlan.class)) { ParentRefs parentRefs = interfaceNew.getAugmentation(ParentRefs.class); if (parentRefs != null && parentRefs.getNodeIdentifier() != null) { LOG.debug("Received HwVTEP Interface Update Event: {}", interfaceNew.getName()); LOG.trace("Received HwVTEP Interface Update Event: {}, {}, {}", key, interfaceOld, interfaceNew); for (NodeIdentifier nodeIdentifier : parentRefs.getNodeIdentifier()) { if (SouthboundUtils.HWVTEP_TOPOLOGY.equals(nodeIdentifier.getTopologyId())) { RendererConfigUpdateWorker configWorker = new RendererConfigUpdateWorker(key, interfaceNew, SouthboundUtils.createPhysicalSwitchInstanceIdentifier(nodeIdentifier.getNodeId()), SouthboundUtils.createGlobalNodeInstanceIdentifier(nodeIdentifier.getNodeId()), ifTunnel); coordinator.enqueueJob(interfaceNew.getName(), configWorker, IfmConstants.JOB_MAX_RETRIES); } } } } } @Override protected void add(InstanceIdentifier key, Interface interfaceNew) { // HwVTEPs support only vxlan IfTunnel ifTunnel = interfaceNew.getAugmentation(IfTunnel.class); if (ifTunnel != null && ifTunnel.getTunnelInterfaceType().isAssignableFrom(TunnelTypeVxlan.class)) { ParentRefs parentRefs = interfaceNew.getAugmentation(ParentRefs.class); if (parentRefs != null && parentRefs.getNodeIdentifier() != null) { LOG.debug("Received HwVTEP Interface Add Event: {}", interfaceNew.getName()); LOG.trace("Received HwVTEP Interface Add Event: {}, {}", key, interfaceNew); for (NodeIdentifier nodeIdentifier : parentRefs.getNodeIdentifier()) { if (SouthboundUtils.HWVTEP_TOPOLOGY.equals(nodeIdentifier.getTopologyId())) { RendererConfigAddWorker configWorker = new RendererConfigAddWorker(key, interfaceNew, SouthboundUtils.createPhysicalSwitchInstanceIdentifier(nodeIdentifier.getNodeId()), SouthboundUtils.createGlobalNodeInstanceIdentifier(nodeIdentifier.getNodeId()), ifTunnel); coordinator.enqueueJob(interfaceNew.getName(), configWorker, IfmConstants.JOB_MAX_RETRIES); } } } } } @Override protected HwVTEPConfigListener getDataTreeChangeListener() { return HwVTEPConfigListener.this; } private class RendererConfigAddWorker implements Callable>> { InstanceIdentifier key; Interface interfaceNew; InstanceIdentifier physicalSwitchNodeId; InstanceIdentifier globalNodeId; IfTunnel ifTunnel; RendererConfigAddWorker(InstanceIdentifier key, Interface interfaceNew, InstanceIdentifier physicalSwitchNodeId, InstanceIdentifier globalNodeId, IfTunnel ifTunnel) { this.key = key; this.interfaceNew = interfaceNew; this.physicalSwitchNodeId = physicalSwitchNodeId; this.globalNodeId = globalNodeId; this.ifTunnel = ifTunnel; } @Override public List> call() { return HwVTEPInterfaceConfigAddHelper.addConfiguration(dataBroker, physicalSwitchNodeId, globalNodeId, interfaceNew, ifTunnel); } } private class RendererConfigUpdateWorker implements Callable>> { InstanceIdentifier key; Interface interfaceNew; InstanceIdentifier globalNodeId; InstanceIdentifier physicalSwitchNodeId; IfTunnel ifTunnel; RendererConfigUpdateWorker(InstanceIdentifier key, Interface interfaceNew, InstanceIdentifier physicalSwitchNodeId, InstanceIdentifier globalNodeId, IfTunnel ifTunnel) { this.key = key; this.interfaceNew = interfaceNew; this.physicalSwitchNodeId = physicalSwitchNodeId; this.ifTunnel = ifTunnel; this.globalNodeId = globalNodeId; } @Override public List> call() { return HwVTEPInterfaceConfigUpdateHelper.updateConfiguration(dataBroker, physicalSwitchNodeId, globalNodeId, interfaceNew, ifTunnel); } } private class RendererConfigRemoveWorker implements Callable>> { InstanceIdentifier key; Interface interfaceOld; InstanceIdentifier physicalSwitchNodeId; InstanceIdentifier globalNodeId; RendererConfigRemoveWorker(InstanceIdentifier key, Interface interfaceOld, InstanceIdentifier physicalSwitchNodeId, InstanceIdentifier globalNodeId) { this.key = key; this.interfaceOld = interfaceOld; this.physicalSwitchNodeId = physicalSwitchNodeId; this.globalNodeId = globalNodeId; } @Override public List> call() { return HwVTEPConfigRemoveHelper.removeConfiguration(dataBroker, interfaceOld, globalNodeId, physicalSwitchNodeId); } } }