*/
package org.opendaylight.vpnservice.interfacemgr;
+import java.math.BigInteger;
+import java.util.List;
+import java.util.concurrent.ExecutionException;
+import java.util.concurrent.Future;
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.ActionInfo;
+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(IfmConstants.IFM_IDPOOL_NAME)
+ .setIdStart(IfmConstants.IFM_IDPOOL_START)
+ .setPoolSize(new BigInteger(IfmConstants.IFM_IDPOOL_SIZE))
+ .build();
+ //TODO: Error handling
+ Future<RpcResult<Void>> 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<MatchInfo> getInterfaceIngressRule(String ifName) {
+ return interfaceManager.getInterfaceIngressRule(ifName);
}
@Override
- public void testApi() {
- LOG.debug("Testing interface mgr api");
+ public List<ActionInfo> getInterfaceEgressActions(String ifName) {
+ return interfaceManager.getInterfaceEgressActions(ifName);
}
-}
\ No newline at end of file
+}