X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=nexthopmgr%2Fnexthopmgr-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fvpnservice%2Fnexthopmgr%2FOdlInterfaceChangeListener.java;h=e8a5bc2e1561fd58698a297990b7e99d40047a02;hb=cd331f15ad231c081bf3725fd10e8cfd39f58241;hp=d97fc88efb5996640fb4bd2a9e082bfa7071f68c;hpb=5c869fd83384560ccef9d1c87e44abab9732d4a0;p=vpnservice.git diff --git a/nexthopmgr/nexthopmgr-impl/src/main/java/org/opendaylight/vpnservice/nexthopmgr/OdlInterfaceChangeListener.java b/nexthopmgr/nexthopmgr-impl/src/main/java/org/opendaylight/vpnservice/nexthopmgr/OdlInterfaceChangeListener.java index d97fc88e..e8a5bc2e 100644 --- a/nexthopmgr/nexthopmgr-impl/src/main/java/org/opendaylight/vpnservice/nexthopmgr/OdlInterfaceChangeListener.java +++ b/nexthopmgr/nexthopmgr-impl/src/main/java/org/opendaylight/vpnservice/nexthopmgr/OdlInterfaceChangeListener.java @@ -16,11 +16,12 @@ import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; import org.opendaylight.controller.md.sal.common.api.data.AsyncDataBroker.DataChangeScope; 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.inventory.rev130819.NodeConnectorId; +import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.interfacemgr.rev150331.BaseIds; import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.interfacemgr.rev150331.L3tunnel; import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.interfacemgr.rev150331.IfL3tunnel; - +import org.opendaylight.vpnservice.interfacemgr.interfaces.IInterfaceManager; import org.opendaylight.vpnservice.nexthopmgr.AbstractDataChangeListener; - import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -31,11 +32,14 @@ public class OdlInterfaceChangeListener extends AbstractDataChangeListener listenerRegistration; private final DataBroker broker; private NexthopManager nexthopManager; + private IInterfaceManager interfaceManager; + - public OdlInterfaceChangeListener(final DataBroker db, NexthopManager nhm) { + public OdlInterfaceChangeListener(final DataBroker db, NexthopManager nhm, IInterfaceManager ifManager) { super(Interface.class); broker = db; nexthopManager = nhm; + interfaceManager = ifManager; registerListener(db); } @@ -62,24 +66,24 @@ public class OdlInterfaceChangeListener extends AbstractDataChangeListener identifier, Interface intrf) { + protected void add(InstanceIdentifier identifier, Interface intrf) { LOG.info("key: " + identifier + ", value=" + intrf ); if (intrf.getType().equals(L3tunnel.class)) { - IfL3tunnel intfData = intrf.getAugmentation(IfL3tunnel.class); + IfL3tunnel intfData = intrf.getAugmentation(IfL3tunnel.class); String gwIp = intfData.getGatewayIp().toString(); String remoteIp = intfData.getRemoteIp().toString(); if (gwIp != null) { remoteIp = gwIp; } - nexthopManager.createRemoteNextHop(intrf.getName(), remoteIp); + NodeConnectorId ofPort = intrf.getAugmentation(BaseIds.class).getOfPortId(); + nexthopManager.createRemoteNextHop(intrf.getName(), ofPort.toString(), remoteIp); } } - + private InstanceIdentifier getWildCardPath() { return InstanceIdentifier.create(Interfaces.class).child(Interface.class); } @@ -88,13 +92,14 @@ public class OdlInterfaceChangeListener extends AbstractDataChangeListener identifier, Interface intrf) { if (intrf.getType().equals(L3tunnel.class)) { + long dpnId = interfaceManager.getDpnForInterface(intrf.getName()); IfL3tunnel intfData = intrf.getAugmentation(IfL3tunnel.class); String gwIp = intfData.getGatewayIp().toString(); String remoteIp = intfData.getRemoteIp().toString(); if (gwIp != null) { remoteIp = gwIp; } - nexthopManager.removeRemoteNextHop(intrf.getName(), remoteIp); + nexthopManager.removeRemoteNextHop(dpnId, remoteIp); } }