*/
package org.opendaylight.ovsdb.openstack.netvirt.impl;
-import com.google.common.collect.Lists;
-import com.google.common.collect.Maps;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
+
import org.opendaylight.ovsdb.openstack.netvirt.AbstractEvent;
import org.opendaylight.ovsdb.openstack.netvirt.AbstractHandler;
-import org.opendaylight.ovsdb.openstack.netvirt.MdsalUtils;
import org.opendaylight.ovsdb.openstack.netvirt.ConfigInterface;
import org.opendaylight.ovsdb.openstack.netvirt.NodeCacheManagerEvent;
import org.opendaylight.ovsdb.openstack.netvirt.api.Action;
import org.opendaylight.ovsdb.openstack.netvirt.api.EventDispatcher;
import org.opendaylight.ovsdb.openstack.netvirt.api.NodeCacheListener;
import org.opendaylight.ovsdb.openstack.netvirt.api.NodeCacheManager;
+import org.opendaylight.ovsdb.openstack.netvirt.api.Southbound;
import org.opendaylight.ovsdb.utils.servicehelper.ServiceHelper;
import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.NodeId;
import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.Node;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+
/**
* @author Flavio Fernandes (ffernand@redhat.com)
* @author Sam Hague (shague@redhat.com)
private final Object nodeCacheLock = new Object();
private Map<NodeId, Node> nodeCache = new ConcurrentHashMap<>();
private Map<Long, NodeCacheListener> handlers = Maps.newHashMap();
- private EventDispatcher eventDispatcher;
+ private volatile Southbound southbound;
@Override
public void nodeAdded(Node node) {
logger.debug("processNodeUpdate: {} Node type {} {}: {}",
nodeCache.size(),
- MdsalUtils.getBridge(node) != null ? "BridgeNode" : "OvsdbNode",
+ southbound.getBridge(node) != null ? "BridgeNode" : "OvsdbNode",
action == Action.ADD ? "ADD" : "UPDATE",
node);
public Map<NodeId,Node> getOvsdbNodes() {
Map<NodeId,Node> ovsdbNodesMap = new ConcurrentHashMap<NodeId,Node>();
for (Map.Entry<NodeId, Node> ovsdbNodeEntry : nodeCache.entrySet()) {
- if (MdsalUtils.extractOvsdbNode(ovsdbNodeEntry.getValue()) != null) {
+ if (southbound.extractOvsdbNode(ovsdbNodeEntry.getValue()) != null) {
ovsdbNodesMap.put(ovsdbNodeEntry.getKey(), ovsdbNodeEntry.getValue());
}
}
public List<Node> getBridgeNodes() {
List<Node> nodes = Lists.newArrayList();
for (Node node : nodeCache.values()) {
- if (MdsalUtils.getBridge(node) != null) {
+ if (southbound.getBridge(node) != null) {
nodes.add(node);
}
}
@Override
public void setDependencies(BundleContext bundleContext, ServiceReference serviceReference) {
+ southbound =
+ (Southbound) ServiceHelper.getGlobalInstance(Southbound.class, this);
eventDispatcher =
(EventDispatcher) ServiceHelper.getGlobalInstance(EventDispatcher.class, this);
eventDispatcher.eventHandlerAdded(
bundleContext.getServiceReference(NodeCacheManager.class.getName()), this);
- super.setDispatcher(eventDispatcher);
}
@Override