/* * Copyright (c) 2016 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.netvirt.vpnmanager; import com.google.common.base.Optional; import com.google.common.util.concurrent.ListenableFuture; import org.opendaylight.controller.md.sal.binding.api.DataBroker; import org.opendaylight.controller.md.sal.binding.api.WriteTransaction; import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; import org.opendaylight.genius.datastoreutils.DataStoreJobCoordinator; import org.opendaylight.genius.mdsalutil.*; import org.opendaylight.genius.mdsalutil.interfaces.IMdsalApiManager; import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.AddDpnEvent; import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.OdlL3vpnListener; import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.RemoveDpnEvent; import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.remove.dpn.event.RemoveEventData; import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.vpn.instance.op.data.VpnInstanceOpDataEntry; import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.l3vpn.rev130911.vpn.instance.op.data.vpn.instance.op.data.entry .VpnToDpnList; import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.idmanager.rev160406.IdManagerService; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.math.BigInteger; import java.util.ArrayList; import java.util.Collection; import java.util.List; import java.util.concurrent.Callable; public class DpnInVpnChangeListener implements OdlL3vpnListener { private static final Logger LOG = LoggerFactory.getLogger(DpnInVpnChangeListener.class); private DataBroker dataBroker; private IMdsalApiManager mdsalManager; private IdManagerService idManager; public DpnInVpnChangeListener(DataBroker dataBroker) { this.dataBroker = dataBroker; } public void onAddDpnEvent(AddDpnEvent notification) { } public void onRemoveDpnEvent(RemoveDpnEvent notification) { RemoveEventData eventData = notification.getRemoveEventData(); final String rd = eventData.getRd(); String vpnName = eventData.getVpnName(); BigInteger dpnId = eventData.getDpnId(); LOG.trace("Remove Dpn Event notification received for rd {} VpnName {} DpnId {}", rd , vpnName, dpnId); synchronized (vpnName.intern()) { InstanceIdentifier id = VpnUtil.getVpnInstanceOpDataIdentifier(rd); Optional vpnOpValue = VpnUtil.read(dataBroker, LogicalDatastoreType.OPERATIONAL, id); if (vpnOpValue.isPresent()) { LOG.trace(" Active Dpn count {} in VpnInstOpData", vpnOpValue.get().getActiveDpnCount()); if (vpnOpValue.get().getActiveDpnCount() == 0) { final Collection vpnToDpnList = vpnOpValue.get().getVpnToDpnList(); DataStoreJobCoordinator dataStoreCoordinator = DataStoreJobCoordinator.getInstance(); dataStoreCoordinator.enqueueJob("VPN-" + vpnName, new Callable>>() { @Override public List> call() throws Exception { WriteTransaction writeTxn = dataBroker.newWriteOnlyTransaction(); deleteDpn(vpnToDpnList , rd , writeTxn); List> futures = new ArrayList<>(); futures.add(writeTxn.submit()); return futures; } }); } } } } protected void deleteDpn(Collection vpnToDpnList, String rd, WriteTransaction writeTxn) { for (final VpnToDpnList curDpn : vpnToDpnList) { InstanceIdentifier VpnToDpnId = VpnUtil.getVpnToDpnListIdentifier(rd, curDpn.getDpnId()); writeTxn.delete(LogicalDatastoreType.OPERATIONAL, VpnToDpnId); } } }