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=cd331f15ad231c081bf3725fd10e8cfd39f58241;hp=a3d4e7324c880df0d2cd9af45303f30cb6eac75e;hpb=f9cf6c9c65b51d31c13791a87b7eb955f8935ac2;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 a3d4e732..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,23 +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; -public class InterfacemgrProvider implements BindingAwareProvider, AutoCloseable { +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); + 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 List getInterfaceEgressActions(String ifName) { + return interfaceManager.getInterfaceEgressActions(ifName); + } }