X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=interfacemgr%2Finterfacemgr-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fvpnservice%2Finterfacemgr%2FInterfacemgrProvider.java;h=01bf1f7ca662c11d96160ccb72a0037e577bdfd9;hb=7cecb2563e0ae0f68015a3b8b0495e7ea9881080;hp=ab30a083bf94dd5aa17d389603eb0dbdbbad47cc;hpb=078ef3863f49c93ab889390f4b0121d35066ac66;p=vpnservice.git diff --git a/interfacemgr/interfacemgr-impl/src/main/java/org/opendaylight/vpnservice/interfacemgr/InterfacemgrProvider.java b/interfacemgr/interfacemgr-impl/src/main/java/org/opendaylight/vpnservice/interfacemgr/InterfacemgrProvider.java index ab30a083..01bf1f7c 100644 --- a/interfacemgr/interfacemgr-impl/src/main/java/org/opendaylight/vpnservice/interfacemgr/InterfacemgrProvider.java +++ b/interfacemgr/interfacemgr-impl/src/main/java/org/opendaylight/vpnservice/interfacemgr/InterfacemgrProvider.java @@ -7,38 +7,93 @@ */ package org.opendaylight.vpnservice.interfacemgr; +import java.util.concurrent.ExecutionException; +import java.math.BigInteger; +import java.util.List; +import java.util.concurrent.Future; +import org.opendaylight.vpnservice.mdsalutil.ActionInfo; +import org.opendaylight.vpnservice.interfacemgr.interfaces.IInterfaceManager; import org.opendaylight.controller.md.sal.binding.api.DataBroker; import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext; import org.opendaylight.controller.sal.binding.api.BindingAwareProvider; +import org.opendaylight.idmanager.IdManager; +import org.opendaylight.vpnservice.interfacemgr.interfaces.IInterfaceManager; +import org.opendaylight.vpnservice.mdsalutil.InstructionInfo; +import org.opendaylight.vpnservice.mdsalutil.MatchInfo; +import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.idmanager.rev150403.CreateIdPoolInput; +import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.idmanager.rev150403.CreateIdPoolInputBuilder; +import org.opendaylight.yangtools.yang.common.RpcResult; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import org.opendaylight.vpnservice.interfacemgr.interfaces.IInterfaceManager; public class InterfacemgrProvider implements BindingAwareProvider, AutoCloseable, IInterfaceManager { private static final Logger LOG = LoggerFactory.getLogger(InterfacemgrProvider.class); private InterfaceManager interfaceManager; + private IfmNodeConnectorListener ifmNcListener; + private IdManager idManager; @Override public void onSessionInitiated(ProviderContext session) { LOG.info("InterfacemgrProvider Session Initiated"); try { final DataBroker dataBroker = session.getSALService(DataBroker.class); - interfaceManager = new InterfaceManager(dataBroker); + idManager = new IdManager(dataBroker); + interfaceManager = new InterfaceManager(dataBroker, idManager); + ifmNcListener = new IfmNodeConnectorListener(dataBroker, interfaceManager); + createIdPool(); } catch (Exception e) { LOG.error("Error initializing services", e); } } + private void createIdPool() { + CreateIdPoolInput createPool = new CreateIdPoolInputBuilder() + .setPoolName("interfaces") + .setIdStart(1L) + .setPoolSize(new BigInteger("65535")) + .build(); + //TODO: Error handling + Future> result = idManager.createIdPool(createPool); + try { + if((result != null) && (result.get().isSuccessful())) { + LOG.debug("Created IdPool for InterfaceMgr"); + } + } catch (InterruptedException | ExecutionException e) { + LOG.error("Failed to create idPool for InterfaceMgr",e); + } + } + @Override public void close() throws Exception { LOG.info("InterfacemgrProvider Closed"); interfaceManager.close(); + ifmNcListener.close(); + } + + @Override + public Long getPortForInterface(String ifName) { + return interfaceManager.getPortForInterface(ifName); + } + + @Override + public long getDpnForInterface(String ifName) { + return interfaceManager.getDpnForInterface(ifName); + } + + @Override + public String getEndpointIpForDpn(long dpnId) { + return interfaceManager.getEndpointIpForDpn(dpnId); + } + + @Override + public List getInterfaceIngressRule(String ifName) { + return interfaceManager.getInterfaceIngressRule(ifName); } @Override - public void testApi() { - LOG.debug("Testing interface mgr api"); + public List getInterfaceEgressActions(String ifName) { + return interfaceManager.getInterfaceEgressActions(ifName); } -} \ No newline at end of file +}