2 * Copyright (c) 2015 Huawei, Inc. and others. All rights reserved.
\r
4 * This program and the accompanying materials are made available under the
\r
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
\r
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
\r
9 package org.opendaylight.nemo.intent.computation;
\r
11 import java.util.ArrayList;
\r
12 import java.util.HashMap;
\r
13 import java.util.LinkedList;
\r
14 import java.util.List;
\r
15 import java.util.Map;
\r
16 import java.util.Set;
\r
17 import java.util.UUID;
\r
18 import java.util.concurrent.ExecutionException;
\r
20 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
\r
21 import org.opendaylight.controller.md.sal.binding.api.DataChangeListener;
\r
22 import org.opendaylight.controller.md.sal.binding.api.ReadOnlyTransaction;
\r
23 import org.opendaylight.controller.md.sal.common.api.data.AsyncDataBroker.DataChangeScope;
\r
24 import org.opendaylight.controller.md.sal.common.api.data.AsyncDataChangeEvent;
\r
25 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
\r
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.PhysicalNetwork;
\r
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.PhysicalNodeAttributeDefinitions;
\r
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.PhysicalPortAttributeDefinitions;
\r
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.attribute.definition.AttributeMatchPatterns;
\r
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.attribute.instance.attribute.value.RangeValue;
\r
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.PhysicalLinks;
\r
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.PhysicalNodes;
\r
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.physical.links.PhysicalLink;
\r
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.physical.nodes.PhysicalNode;
\r
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.physical.paths.PhysicalPath;
\r
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.physical.paths.PhysicalPathBuilder;
\r
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.attribute.definitions.PhysicalNodeAttributeDefinition;
\r
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.attribute.definitions.PhysicalNodeAttributeDefinitionKey;
\r
39 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.instance.PhysicalPort;
\r
40 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.port.attribute.definitions.PhysicalPortAttributeDefinition;
\r
41 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.port.attribute.definitions.PhysicalPortAttributeDefinitionKey;
\r
42 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.port.instance.Attribute;
\r
43 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.networks.VirtualNetwork;
\r
44 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.networks.virtual.network.virtual.links.VirtualLink;
\r
45 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.networks.virtual.network.virtual.links.VirtualLinkBuilder;
\r
46 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.networks.virtual.network.virtual.nodes.VirtualNode;
\r
47 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.VirtualPort;
\r
48 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.port.instance.PhysicalResourceRequirement;
\r
49 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.PhysicalResourceInstance;
\r
50 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.VirtualResourceInstance;
\r
51 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.vn.pn.mapping.results.UserVnPnMapping;
\r
52 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.vn.pn.mapping.results.user.vn.pn.mapping.VnPnMappingResult;
\r
53 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.vn.pn.mapping.results.user.vn.pn.mapping.VnPnMappingResultBuilder;
\r
54 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.AttributeName;
\r
55 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.PhysicalNodeId;
\r
56 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.PhysicalPathId;
\r
57 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.PhysicalPortId;
\r
58 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.PhysicalResourceEntityId;
\r
59 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.PhysicalResourceId;
\r
60 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.VirtualNetworkId;
\r
61 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.VirtualNodeId;
\r
62 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.VirtualResourceEntityId;
\r
63 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.VirtualResourceId;
\r
64 import org.opendaylight.yangtools.concepts.ListenerRegistration;
\r
65 import org.opendaylight.yangtools.yang.binding.DataObject;
\r
66 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
\r
67 import org.slf4j.Logger;
\r
68 import org.slf4j.LoggerFactory;
\r
70 import com.google.common.base.Optional;
\r
73 * The virtual network mapping unit implements the following functions:
\r
74 * (1) Automatically perform the virtual network mapping when the user's
\r
75 * virtual network changed, which is subscribed from the data store.
\r
76 * (2) Automatically perform the remapping for the virtual networks that
\r
77 * are influenced by the changes of the underlying physical network
\r
78 * which are also subscribed from the data store.
\r
80 * @author Zhigang Ji
\r
82 public class VNMappingUnit implements AutoCloseable {
\r
83 private static final Logger LOG = LoggerFactory.getLogger(VNMappingUnit.class);
\r
85 private final DataBroker dataBroker;
\r
88 * The physical network computation unit.
\r
90 private PNComputationUnit pnComputationUnit;
\r
93 * The registrations for the physical port change listeners.
\r
95 private Map<PhysicalNodeId, Map<PhysicalPortId, ListenerRegistration<DataChangeListener>>> physicalPortChangeListenerRegs;
\r
98 * The registration for the physical node change listener.
\r
100 private ListenerRegistration<DataChangeListener> physicalNodeChangeListenerReg;
\r
103 * The registration for the physical link change listener.
\r
105 private ListenerRegistration<DataChangeListener> physicalLinkChangeListenerReg;
\r
107 public VNMappingUnit(DataBroker dataBroker, PNComputationUnit pnComputationUnit) {
\r
110 this.dataBroker = dataBroker;
\r
111 this.pnComputationUnit = pnComputationUnit;
\r
113 physicalPortChangeListenerRegs =
\r
114 new HashMap<PhysicalNodeId, Map<PhysicalPortId, ListenerRegistration<DataChangeListener>>>();
\r
116 InstanceIdentifier<PhysicalNode> physicalNodeIid = InstanceIdentifier
\r
117 .builder(PhysicalNetwork.class)
\r
118 .child(PhysicalNodes.class)
\r
119 .child(PhysicalNode.class)
\r
121 InstanceIdentifier<PhysicalLink> physicalLinkIid = InstanceIdentifier
\r
122 .builder(PhysicalNetwork.class)
\r
123 .child(PhysicalLinks.class)
\r
124 .child(PhysicalLink.class)
\r
127 physicalNodeChangeListenerReg = dataBroker.registerDataChangeListener(LogicalDatastoreType.OPERATIONAL,
\r
128 physicalNodeIid, new PhysicalNodeChangeListener(), DataChangeScope.BASE);
\r
129 physicalLinkChangeListenerReg = dataBroker.registerDataChangeListener(LogicalDatastoreType.OPERATIONAL,
\r
130 physicalLinkIid, new PhysicalLinkChangeListener(), DataChangeScope.BASE);
\r
132 LOG.debug("Initialized the virtual network mapping unit.");
\r
140 * @param virtualNetwork TODO
\r
141 * @param userVnPnMapping TODO
\r
142 * @param physicalPaths TODO
\r
144 public void virtualNetworkMapping(VirtualNetwork virtualNetwork, UserVnPnMapping userVnPnMapping,
\r
145 List<PhysicalPath> physicalPaths)
\r
146 throws VNMappingException {
\r
147 ReadOnlyTransaction readOnlyTransaction = dataBroker.newReadOnlyTransaction();
\r
149 InstanceIdentifier<PhysicalNodes> physicalNodesIid = InstanceIdentifier
\r
150 .builder(PhysicalNetwork.class)
\r
151 .child(PhysicalNodes.class)
\r
153 Optional<PhysicalNodes> result;
\r
156 result = readOnlyTransaction.read(LogicalDatastoreType.OPERATIONAL, physicalNodesIid).get();
\r
157 } catch ( InterruptedException | ExecutionException exception ) {
\r
158 throw new VNMappingException("Can not read the physical nodes.");
\r
161 PhysicalNodes physicalNodes = result.get();
\r
162 List<PhysicalNode> physicalNodeList = physicalNodes.getPhysicalNode();
\r
164 List<VnPnMappingResult> vnPnMappingResults = userVnPnMapping.getVnPnMappingResult();
\r
165 List<VirtualNode> virtualNodes = virtualNetwork.getVirtualNodes().getVirtualNode();
\r
166 List<VirtualPort> virtualPorts;
\r
167 PhysicalNode physicalNode;
\r
168 PhysicalPort physicalPort;
\r
169 VnPnMappingResult vnPnMappingResult;
\r
171 for ( VirtualNode virtualNode : virtualNodes ) {
\r
172 physicalNode = virtualNodeMapping(virtualNetwork.getNetworkId(), virtualNode, physicalNodeList);
\r
174 if ( null == physicalNode ) {
\r
175 throw new VNMappingException("Failed mapping for the virtual node " +
\r
176 virtualNode.getNodeId().getValue() + " in the virtual network " +
\r
177 virtualNetwork.getNetworkId().getValue());
\r
180 virtualPorts = virtualNode.getVirtualPort();
\r
182 for ( VirtualPort virtualPort : virtualPorts ) {
\r
183 if ( VirtualPort.PortType.External == virtualPort.getPortType() ) {
\r
184 physicalPort = virtualPortMapping(virtualNetwork.getNetworkId(),
\r
185 virtualNode.getNodeId(), virtualPort, physicalNode);
\r
187 if ( null == physicalPort ) {
\r
188 throw new VNMappingException("Failed mapping for the virtual port " +
\r
189 virtualPort.getPortId().getValue() + " of the virtual node " +
\r
190 virtualNode.getNodeId().getValue() + " in the virtual network " +
\r
191 virtualNetwork.getNetworkId().getValue());
\r
194 vnPnMappingResult = new VnPnMappingResultBuilder()
\r
195 .setVirtualResourceId(new VirtualResourceId(UUID.randomUUID().toString()))
\r
196 .setVirtualResourceType(VirtualResourceInstance.VirtualResourceType.Vport)
\r
197 .setVirtualResourceEntityId(new VirtualResourceEntityId(virtualPort.getPortId().getValue()))
\r
198 .setParentVirtualResourceEntityId(new VirtualResourceEntityId(virtualNode.getNodeId().getValue()))
\r
199 .setPhysicalResourceId(new PhysicalResourceId(UUID.randomUUID().toString()))
\r
200 .setPhysicalResourceType(PhysicalResourceInstance.PhysicalResourceType.Port)
\r
201 .setPhysicalResourceEntityId(new PhysicalResourceEntityId(physicalPort.getPortId().getValue()))
\r
202 .setParentPhysicalResourceEntityId(new PhysicalResourceEntityId(physicalNode.getNodeId().getValue()))
\r
205 vnPnMappingResults.add(vnPnMappingResult);
\r
209 vnPnMappingResult = new VnPnMappingResultBuilder()
\r
210 .setVirtualResourceId(new VirtualResourceId(UUID.randomUUID().toString()))
\r
211 .setVirtualResourceType(VirtualResourceInstance.VirtualResourceType.Vnode)
\r
212 .setVirtualResourceEntityId(new VirtualResourceEntityId(virtualNode.getNodeId().getValue()))
\r
213 .setPhysicalResourceId(new PhysicalResourceId(UUID.randomUUID().toString()))
\r
214 .setPhysicalResourceType(PhysicalResourceInstance.PhysicalResourceType.Node)
\r
215 .setPhysicalResourceEntityId(new PhysicalResourceEntityId(physicalNode.getNodeId().getValue()))
\r
218 vnPnMappingResults.add(vnPnMappingResult);
\r
221 List<VirtualLink> virtualLinks = virtualNetwork.getVirtualLinks().getVirtualLink();
\r
222 List<VirtualLink> newVirtualLinks = new ArrayList<VirtualLink>(virtualLinks.size());
\r
223 PhysicalPath physicalPath;
\r
224 VirtualLink newVirtualLink;
\r
226 for ( VirtualLink virtualLink : virtualLinks ) {
\r
227 physicalPath = virtualLinkMapping(virtualNetwork.getNetworkId(), virtualLink, userVnPnMapping);
\r
229 if ( null == physicalPath ) {
\r
230 throw new VNMappingException("Failed mapping for the virtual link " +
\r
231 virtualLink.getLinkId().getValue() + " in the virtual network " +
\r
232 virtualNetwork.getNetworkId().getValue());
\r
235 physicalPaths.add(physicalPath);
\r
237 newVirtualLink = new VirtualLinkBuilder(virtualLink)
\r
238 .setMetric(physicalPath.getMetric())
\r
239 .setDelay(physicalPath.getDelay())
\r
242 newVirtualLinks.add(newVirtualLink);
\r
244 vnPnMappingResult = new VnPnMappingResultBuilder()
\r
245 .setVirtualResourceId(new VirtualResourceId(UUID.randomUUID().toString()))
\r
246 .setVirtualResourceType(VirtualResourceInstance.VirtualResourceType.Vlink)
\r
247 .setVirtualResourceEntityId(new VirtualResourceEntityId(virtualLink.getLinkId().getValue()))
\r
248 .setPhysicalResourceId(new PhysicalResourceId(UUID.randomUUID().toString()))
\r
249 .setPhysicalResourceType(PhysicalResourceInstance.PhysicalResourceType.Path)
\r
250 .setPhysicalResourceEntityId(new PhysicalResourceEntityId(physicalPath.getPathId().getValue()))
\r
253 vnPnMappingResults.add(vnPnMappingResult);
\r
256 virtualLinks.clear();
\r
257 virtualLinks.addAll(newVirtualLinks);
\r
263 public void close() throws Exception {
\r
264 for ( Map<PhysicalPortId, ListenerRegistration<DataChangeListener>>
\r
265 physicalPortChangeListenerRegs1 : physicalPortChangeListenerRegs.values() ) {
\r
266 for ( ListenerRegistration<DataChangeListener>
\r
267 physicalPortChangeListenerReg : physicalPortChangeListenerRegs1.values() ) {
\r
268 if ( null != physicalPortChangeListenerReg ) {
\r
269 physicalPortChangeListenerReg.close();
\r
274 if ( null != physicalNodeChangeListenerReg ) {
\r
275 physicalNodeChangeListenerReg.close();
\r
278 if ( null != physicalLinkChangeListenerReg ) {
\r
279 physicalLinkChangeListenerReg.close();
\r
288 * @param virtualNetworkId TODO
\r
289 * @param virtualNodeId TODO
\r
290 * @param virtualPort TODO
\r
291 * @param physicalNode TODO
\r
294 private PhysicalPort virtualPortMapping(VirtualNetworkId virtualNetworkId, VirtualNodeId virtualNodeId,
\r
295 VirtualPort virtualPort, PhysicalNode physicalNode)
\r
296 throws VNMappingException {
\r
297 if ( VirtualPort.PortType.Internal == virtualPort.getPortType() ) {
\r
301 List<PhysicalPort> physicalPorts = physicalNode.getPhysicalPort();
\r
302 List<PhysicalResourceRequirement> physicalResourceRequirements = virtualPort.getPhysicalResourceRequirement();
\r
304 for ( PhysicalPort physicalPort : physicalPorts ) {
\r
305 if ( PhysicalPort.PortType.External == physicalPort.getPortType()
\r
306 && checkPhysicalPortSatisfied(physicalPort, physicalResourceRequirements) ) {
\r
307 return physicalPort;
\r
317 * @param virtualNetworkId TODO
\r
318 * @param virtualNode TODO
\r
319 * @param physicalNodes TODO
\r
322 private PhysicalNode virtualNodeMapping(VirtualNetworkId virtualNetworkId, VirtualNode virtualNode,
\r
323 List<PhysicalNode> physicalNodes)
\r
324 throws VNMappingException {
\r
325 List<org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement>
\r
326 physicalResourceRequirements = virtualNode.getPhysicalResourceRequirement();
\r
327 List<PhysicalNode> candidates = new LinkedList<PhysicalNode>();
\r
329 switch ( virtualNode.getNodeType() ) {
\r
331 for ( PhysicalNode physicalNode : physicalNodes ) {
\r
332 if ( PhysicalNode.NodeType.Switch == physicalNode.getNodeType() ) {
\r
333 if ( checkPhysicalNodeSatisfied(physicalNode, physicalResourceRequirements) ) {
\r
334 candidates.add(physicalNode);
\r
341 for ( PhysicalNode physicalNode : physicalNodes ) {
\r
342 if ( PhysicalNode.NodeType.Router == physicalNode.getNodeType() ) {
\r
343 if ( checkPhysicalNodeSatisfied(physicalNode, physicalResourceRequirements) ) {
\r
344 candidates.add(physicalNode);
\r
351 for ( PhysicalNode physicalNode : physicalNodes ) {
\r
352 if ( PhysicalNode.NodeType.Firewall == physicalNode.getNodeType() ) {
\r
353 if ( checkPhysicalNodeSatisfied(physicalNode, physicalResourceRequirements) ) {
\r
354 candidates.add(physicalNode);
\r
360 case Vloadbalancer:
\r
361 for ( PhysicalNode physicalNode : physicalNodes ) {
\r
362 if ( PhysicalNode.NodeType.Loadbalancer == physicalNode.getNodeType() ) {
\r
363 if ( checkPhysicalNodeSatisfied(physicalNode, physicalResourceRequirements) ) {
\r
364 candidates.add(physicalNode);
\r
371 throw new VNMappingException("Unsupported virtual node type " +
\r
372 virtualNode.getNodeType() + ".");
\r
376 if ( candidates.isEmpty() ) {
\r
380 return candidates.get(0);
\r
386 * @param virtualNetworkId TODO
\r
387 * @param virtualLink TODO
\r
388 * @param userVnPnMapping TODO
\r
391 private PhysicalPath virtualLinkMapping(VirtualNetworkId virtualNetworkId, VirtualLink virtualLink,
\r
392 UserVnPnMapping userVnPnMapping)
\r
393 throws VNMappingException {
\r
394 List<VnPnMappingResult> vnPnMappingResults = userVnPnMapping.getVnPnMappingResult();
\r
395 VnPnMappingResult vnPnMappingResult = VNMappingUnitUtils.getVnPnMappingResult(vnPnMappingResults,
\r
396 new VirtualResourceEntityId(virtualLink.getSrcNodeId().getValue()));
\r
398 if ( null == vnPnMappingResult ) {
\r
399 throw new VNMappingException("Can not get the vn-pn mapping result for " +
\r
400 "the virtual node " + virtualLink.getSrcNodeId().getValue());
\r
403 PhysicalNodeId source = new PhysicalNodeId(vnPnMappingResult.getPhysicalResourceEntityId().getValue());
\r
405 vnPnMappingResult = VNMappingUnitUtils.getVnPnMappingResult(vnPnMappingResults,
\r
406 new VirtualResourceEntityId(virtualLink.getDestNodeId().getValue()));
\r
408 if ( null == vnPnMappingResult ) {
\r
409 throw new VNMappingException("Can not get the vn-pn mapping result for " +
\r
410 "the virtual node " + virtualLink.getDestNodeId().getValue());
\r
413 PhysicalNodeId target = new PhysicalNodeId(vnPnMappingResult.getPhysicalResourceEntityId().getValue());
\r
415 if ( source.equals(target) ) {
\r
416 PhysicalPath physicalPath = new PhysicalPathBuilder()
\r
417 .setPathId(new PhysicalPathId(UUID.randomUUID().toString()))
\r
418 .setPhysicalLink(new ArrayList<org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.path.instance.PhysicalLink>(0))
\r
420 .setBandwidth(virtualLink.getBandwidth())
\r
424 return physicalPath;
\r
427 PhysicalPath physicalPath;
\r
429 if ( 0 == virtualLink.getBandwidth() ) {
\r
430 physicalPath = pnComputationUnit.computePath(source, target);
\r
432 physicalPath = pnComputationUnit.computePath(source, target, virtualLink.getBandwidth());
\r
435 return physicalPath;
\r
441 * @param physicalPort TODO
\r
442 * @param physicalResourceRequirements TODO
\r
445 private boolean checkPhysicalPortSatisfied(PhysicalPort physicalPort,
\r
446 List<PhysicalResourceRequirement> physicalResourceRequirements)
\r
447 throws VNMappingException {
\r
448 List<Attribute> attributes = physicalPort.getAttribute();
\r
449 Attribute attribute;
\r
451 for ( PhysicalResourceRequirement physicalResourceRequirement : physicalResourceRequirements ) {
\r
452 attribute = getPhysicalPortAttribute(attributes, physicalResourceRequirement.getAttributeName());
\r
454 if ( null == attribute ) {
\r
458 if ( !checkPhysicalPortAttributeSatisfied(attribute, physicalResourceRequirement) ) {
\r
469 * @param physicalNode TODO
\r
470 * @param physicalResourceRequirements TODO
\r
473 private boolean checkPhysicalNodeSatisfied(PhysicalNode physicalNode,
\r
474 List<org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement>
\r
475 physicalResourceRequirements)
\r
476 throws VNMappingException {
\r
477 List<org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.instance.Attribute>
\r
478 attributes = physicalNode.getAttribute();
\r
479 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.instance.Attribute attribute;
\r
481 for ( org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement
\r
482 physicalResourceRequirement : physicalResourceRequirements ) {
\r
483 attribute = getPhysicalNodeAttribute(attributes, physicalResourceRequirement.getAttributeName());
\r
485 if ( null == attribute ) {
\r
489 if ( !checkPhysicalNodeAttributeSatisfied(attribute, physicalResourceRequirement) ) {
\r
500 * @param attributes TODO
\r
501 * @param attributeName TODO
\r
504 private Attribute getPhysicalPortAttribute(List<Attribute> attributes, AttributeName attributeName) {
\r
505 for ( Attribute attribute : attributes ) {
\r
506 if ( attribute.getAttributeName().equals(attributeName) ) {
\r
517 * @param attributes TODO
\r
518 * @param attributeName TODO
\r
521 private org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.instance.Attribute getPhysicalNodeAttribute(
\r
522 List<org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.instance.Attribute> attributes,
\r
523 AttributeName attributeName) {
\r
524 for ( org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.instance.Attribute
\r
525 attribute : attributes ) {
\r
526 if ( attribute.getAttributeName().equals(attributeName) ) {
\r
537 * @param attribute TODO
\r
538 * @param physicalResourceRequirement TODO
\r
541 private boolean checkPhysicalPortAttributeSatisfied(Attribute attribute,
\r
542 PhysicalResourceRequirement physicalResourceRequirement)
\r
543 throws VNMappingException {
\r
544 ReadOnlyTransaction readOnlyTransaction = dataBroker.newReadOnlyTransaction();
\r
546 InstanceIdentifier<PhysicalPortAttributeDefinition> physicalPortAttributeDefinitionIid = InstanceIdentifier
\r
547 .builder(PhysicalPortAttributeDefinitions.class)
\r
548 .child(PhysicalPortAttributeDefinition.class,
\r
549 new PhysicalPortAttributeDefinitionKey(attribute.getAttributeName()))
\r
551 Optional<PhysicalPortAttributeDefinition> result;
\r
554 result = readOnlyTransaction.read(LogicalDatastoreType.CONFIGURATION,
\r
555 physicalPortAttributeDefinitionIid).get();
\r
556 } catch ( InterruptedException | ExecutionException exception ) {
\r
557 throw new VNMappingException("Can not read the physical port attribute definition " +
\r
558 "with attribute name " + attribute.getAttributeName().getValue() + ".");
\r
561 if ( !result.isPresent() ) {
\r
562 throw new VNMappingException("The physical port attribute definition with attribute name " +
\r
563 attribute.getAttributeName().getValue() + " does not exist.");
\r
566 PhysicalPortAttributeDefinition physicalPortAttributeDefinition = result.get();
\r
567 List<AttributeMatchPatterns.AttributeMatchPattern> attributeMatchPatterns
\r
568 = physicalPortAttributeDefinition.getAttributeMatchPatterns().getAttributeMatchPattern();
\r
569 PhysicalResourceRequirement.AttributeMatchPattern attributeMatchPattern
\r
570 = physicalResourceRequirement.getAttributeMatchPattern();
\r
572 if ( !checkAttributeMatchPatternSpecified(attributeMatchPatterns, attributeMatchPattern) ) {
\r
573 throw new VNMappingException("The attribute match pattern " + attributeMatchPattern +
\r
574 " is not specified in the physical port attribute definition " +
\r
575 "with attribute name " + attribute.getAttributeName().getValue() + ".");
\r
578 switch ( physicalPortAttributeDefinition.getAttributeValueType() ) {
\r
580 return checkAttributeStringValueSatisfied(attribute.getAttributeValue().getStringValue(),
\r
581 physicalResourceRequirement.getAttributeValue().getStringValue(), attributeMatchPattern);
\r
584 return checkAttributeIntegerValueSatisfied(attribute.getAttributeValue().getIntValue(),
\r
585 physicalResourceRequirement.getAttributeValue().getIntValue(), attributeMatchPattern);
\r
588 return checkAttributeRangeValueSatisfied(attribute.getAttributeValue().getIntValue(),
\r
589 physicalResourceRequirement.getAttributeValue().getRangeValue(), attributeMatchPattern);
\r
592 throw new VNMappingException("Unsupported physical port attribute value type " +
\r
593 physicalPortAttributeDefinition.getAttributeValueType() + ".");
\r
603 * @param attribute TODO
\r
604 * @param physicalResourceRequirement TODO
\r
607 private boolean checkPhysicalNodeAttributeSatisfied(
\r
608 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.node.instance.Attribute attribute,
\r
609 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement physicalResourceRequirement)
\r
610 throws VNMappingException {
\r
611 ReadOnlyTransaction readOnlyTransaction = dataBroker.newReadOnlyTransaction();
\r
613 InstanceIdentifier<PhysicalNodeAttributeDefinition> physicalNodeAttributeDefinitionIid = InstanceIdentifier
\r
614 .builder(PhysicalNodeAttributeDefinitions.class)
\r
615 .child(PhysicalNodeAttributeDefinition.class,
\r
616 new PhysicalNodeAttributeDefinitionKey(attribute.getAttributeName()))
\r
618 Optional<PhysicalNodeAttributeDefinition> result;
\r
621 result = readOnlyTransaction.read(LogicalDatastoreType.CONFIGURATION,
\r
622 physicalNodeAttributeDefinitionIid).get();
\r
623 } catch ( InterruptedException | ExecutionException exception ) {
\r
624 throw new VNMappingException("Can not read the physical node attribute definition " +
\r
625 "with attribute name " + attribute.getAttributeName().getValue() + ".");
\r
628 if ( !result.isPresent() ) {
\r
629 throw new VNMappingException("The physical node attribute definition with attribute name " +
\r
630 attribute.getAttributeName().getValue() + " does not exist.");
\r
633 PhysicalNodeAttributeDefinition physicalNodeAttributeDefinition = result.get();
\r
634 List<AttributeMatchPatterns.AttributeMatchPattern> attributeMatchPatterns
\r
635 = physicalNodeAttributeDefinition.getAttributeMatchPatterns().getAttributeMatchPattern();
\r
636 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement.AttributeMatchPattern
\r
637 attributeMatchPattern = physicalResourceRequirement.getAttributeMatchPattern();
\r
639 if ( !checkAttributeMatchPatternSpecified(attributeMatchPatterns, attributeMatchPattern) ) {
\r
640 throw new VNMappingException("The attribute match pattern " + attributeMatchPattern +
\r
641 " is not specified in the physical node attribute definition " +
\r
642 "with attribute name " + attribute.getAttributeName().getValue() + ".");
\r
645 switch ( physicalNodeAttributeDefinition.getAttributeValueType() ) {
\r
647 return checkAttributeStringValueSatisfied(attribute.getAttributeValue().getStringValue(),
\r
648 physicalResourceRequirement.getAttributeValue().getStringValue(), attributeMatchPattern);
\r
651 return checkAttributeIntegerValueSatisfied(attribute.getAttributeValue().getIntValue(),
\r
652 physicalResourceRequirement.getAttributeValue().getIntValue(), attributeMatchPattern);
\r
655 return checkAttributeRangeValueSatisfied(attribute.getAttributeValue().getIntValue(),
\r
656 physicalResourceRequirement.getAttributeValue().getRangeValue(), attributeMatchPattern);
\r
659 throw new VNMappingException("Unsupported physical node attribute value type " +
\r
660 physicalNodeAttributeDefinition.getAttributeValueType() + ".");
\r
670 * @param attributeMatchPatterns TODO
\r
671 * @param attributeMatchPattern TODO
\r
674 private boolean checkAttributeMatchPatternSpecified(List<AttributeMatchPatterns.AttributeMatchPattern> attributeMatchPatterns,
\r
675 PhysicalResourceRequirement.AttributeMatchPattern attributeMatchPattern) {
\r
676 for ( AttributeMatchPatterns.AttributeMatchPattern attributeMatchPattern1 : attributeMatchPatterns ) {
\r
677 if ( attributeMatchPattern1.name().equals(attributeMatchPattern.name()) ) {
\r
688 * @param attributeMatchPatterns TODO
\r
689 * @param attributeMatchPattern TODO
\r
692 private boolean checkAttributeMatchPatternSpecified(List<AttributeMatchPatterns.AttributeMatchPattern> attributeMatchPatterns,
\r
693 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement.AttributeMatchPattern
\r
694 attributeMatchPattern) {
\r
695 for ( AttributeMatchPatterns.AttributeMatchPattern attributeMatchPattern1 : attributeMatchPatterns ) {
\r
696 if ( attributeMatchPattern1.name().equals(attributeMatchPattern.name()) ) {
\r
707 * @param attributeValue TODO
\r
708 * @param requiredAttributeValue TODO
\r
709 * @param attributeMatchPattern TODO
\r
712 private boolean checkAttributeStringValueSatisfied(String attributeValue, String requiredAttributeValue,
\r
713 PhysicalResourceRequirement.AttributeMatchPattern attributeMatchPattern)
\r
714 throws VNMappingException {
\r
715 int result = attributeValue.compareTo(requiredAttributeValue);
\r
717 switch ( attributeMatchPattern ) {
\r
722 return 0 <= result;
\r
725 return 0 == result;
\r
728 return 0 != result;
\r
733 case NotGreaterThan:
\r
734 return 0 >= result;
\r
737 throw new VNMappingException("Unsupported attribute match pattern " +
\r
738 attributeMatchPattern + " for the attribute string value.");
\r
748 * @param attributeValue TODO
\r
749 * @param requiredAttributeValue TODO
\r
750 * @param attributeMatchPattern TODO
\r
753 private boolean checkAttributeStringValueSatisfied(String attributeValue, String requiredAttributeValue,
\r
754 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement.AttributeMatchPattern
\r
755 attributeMatchPattern)
\r
756 throws VNMappingException {
\r
757 int result = attributeValue.compareTo(requiredAttributeValue);
\r
759 switch ( attributeMatchPattern ) {
\r
764 return 0 <= result;
\r
767 return 0 == result;
\r
770 return 0 != result;
\r
775 case NotGreaterThan:
\r
776 return 0 >= result;
\r
779 throw new VNMappingException("Unsupported attribute match pattern " +
\r
780 attributeMatchPattern + " for the attribute string value.");
\r
790 * @param attributeValue TODO
\r
791 * @param requiredAttributeValue TODO
\r
792 * @param attributeMatchPattern TODO
\r
795 private boolean checkAttributeIntegerValueSatisfied(Long attributeValue, Long requiredAttributeValue,
\r
796 PhysicalResourceRequirement.AttributeMatchPattern attributeMatchPattern)
\r
797 throws VNMappingException {
\r
798 int result = attributeValue.compareTo(requiredAttributeValue);
\r
800 switch ( attributeMatchPattern ) {
\r
805 return 0 <= result;
\r
808 return 0 == result;
\r
811 return 0 != result;
\r
816 case NotGreaterThan:
\r
817 return 0 >= result;
\r
820 throw new VNMappingException("Unsupported attribute match pattern " +
\r
821 attributeMatchPattern + " for the attribute integer value.");
\r
831 * @param attributeValue TODO
\r
832 * @param requiredAttributeValue TODO
\r
833 * @param attributeMatchPattern TODO
\r
836 private boolean checkAttributeIntegerValueSatisfied(Long attributeValue, Long requiredAttributeValue,
\r
837 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement.AttributeMatchPattern
\r
838 attributeMatchPattern)
\r
839 throws VNMappingException {
\r
840 int result = attributeValue.compareTo(requiredAttributeValue);
\r
842 switch ( attributeMatchPattern ) {
\r
847 return 0 <= result;
\r
850 return 0 == result;
\r
853 return 0 != result;
\r
858 case NotGreaterThan:
\r
859 return 0 >= result;
\r
862 throw new VNMappingException("Unsupported attribute match pattern " +
\r
863 attributeMatchPattern + " for the attribute integer value.");
\r
873 * @param attributeValue TODO
\r
874 * @param requiredAttributeValue TODO
\r
875 * @param attributeMatchPattern TODO
\r
878 private boolean checkAttributeRangeValueSatisfied(Long attributeValue, RangeValue requiredAttributeValue,
\r
879 PhysicalResourceRequirement.AttributeMatchPattern attributeMatchPattern)
\r
880 throws VNMappingException {
\r
881 switch ( attributeMatchPattern ) {
\r
883 return attributeValue > requiredAttributeValue.getMin()
\r
884 && attributeValue < requiredAttributeValue.getMax();
\r
887 throw new VNMappingException("Unsupported attribute match pattern " +
\r
888 attributeMatchPattern + " for the attribute range value.");
\r
898 * @param attributeValue TODO
\r
899 * @param requiredAttributeValue TODO
\r
900 * @param attributeMatchPattern TODO
\r
903 private boolean checkAttributeRangeValueSatisfied(Long attributeValue, RangeValue requiredAttributeValue,
\r
904 org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.node.instance.PhysicalResourceRequirement.AttributeMatchPattern
\r
905 attributeMatchPattern)
\r
906 throws VNMappingException {
\r
907 switch ( attributeMatchPattern ) {
\r
909 return attributeValue > requiredAttributeValue.getMin()
\r
910 && attributeValue < requiredAttributeValue.getMax();
\r
913 throw new VNMappingException("Unsupported attribute match pattern " +
\r
914 attributeMatchPattern + " for the attribute range value.");
\r
922 // * A listener to change events related to virtual ports being
\r
923 // * added, removed or updated.
\r
925 // * @author Zhigang Ji
\r
927 // private class VirtualPortChangeListener implements DataChangeListener {
\r
929 // * The virtual network that the virtual port belongs to.
\r
931 // private VirtualNetworkId virtualNetworkId;
\r
934 // * The virtual node that the virtual port belongs to.
\r
936 // private VirtualNodeId virtualNodeId;
\r
938 // public VirtualPortChangeListener(VirtualNetworkId virtualNetworkId, VirtualNodeId virtualNodeId) {
\r
941 // this.virtualNetworkId = virtualNetworkId;
\r
942 // this.virtualNodeId = virtualNodeId;
\r
948 // public void onDataChanged(AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
\r
949 // if ( null == change ) {
\r
953 // Map<InstanceIdentifier<?>, DataObject> createdData = change.getCreatedData();
\r
955 // if ( null != createdData && !createdData.isEmpty() ) {
\r
956 // for ( DataObject dataObject : createdData.values() ) {
\r
957 // if ( dataObject instanceof VirtualPort ) {
\r
958 // // TODO: 1、执行端口映射。
\r
966 // * A listener to change events related to virtual nodes being
\r
967 // * added, removed or updated.
\r
969 // * @author Zhigang Ji
\r
971 // private class VirtualNodeChangeListener implements DataChangeListener {
\r
973 // * The virtual network that the virtual node belongs to.
\r
975 // private VirtualNetworkId virtualNetworkId;
\r
977 // public VirtualNodeChangeListener(VirtualNetworkId virtualNetworkId) {
\r
980 // this.virtualNetworkId = virtualNetworkId;
\r
986 // public void onDataChanged(AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
\r
987 // if ( null == change ) {
\r
991 // Map<InstanceIdentifier<?>, DataObject> createdData = change.getCreatedData();
\r
993 // if ( null != createdData && !createdData.isEmpty() ) {
\r
994 // for ( DataObject dataObject : createdData.values() ) {
\r
995 // if ( dataObject instanceof VirtualNode ) {
\r
996 // // TODO: 1、执行节点映射。
\r
997 // // TODO: 2、启动vports监听(external端口),还需监听vnode中vport的增加。
\r
998 // // TODO: 3、读取已有vports,并执行端口映射(external端口)。
\r
1006 // * A listener to change events related to virtual links being
\r
1007 // * added, removed or updated.
\r
1009 // * @author Zhigang Ji
\r
1011 // private class VirtualLinkChangeListener implements DataChangeListener {
\r
1013 // * The virtual network that the virtual link belongs to.
\r
1015 // private VirtualNetworkId virtualNetworkId;
\r
1017 // public VirtualLinkChangeListener(VirtualNetworkId virtualNetworkId) {
\r
1020 // this.virtualNetworkId = virtualNetworkId;
\r
1026 // public void onDataChanged(AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
\r
1027 // if ( null == change ) {
\r
1031 // Map<InstanceIdentifier<?>, DataObject> createdData = change.getCreatedData();
\r
1033 // if ( null != createdData && !createdData.isEmpty() ) {
\r
1034 // for ( DataObject dataObject : createdData.values() ) {
\r
1035 // if ( dataObject instanceof VirtualLink ) {
\r
1036 // // TODO: 1、执行链路映射(两端vport映射结果可不写)。
\r
1044 * A listener to change events related to physical ports being
\r
1045 * added, removed or updated.
\r
1047 * @author Zhigang Ji
\r
1049 private class PhysicalPortChangeListener implements DataChangeListener {
\r
1051 * The physical node that the physical port belongs to.
\r
1053 private PhysicalNodeId physicalNodeId;
\r
1055 public PhysicalPortChangeListener(PhysicalNodeId physicalNodeId) {
\r
1058 this.physicalNodeId = physicalNodeId;
\r
1064 public void onDataChanged(AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
\r
1065 if ( null == change ) {
\r
1069 Map<InstanceIdentifier<?>, DataObject> originalData = change.getOriginalData();
\r
1070 Map<InstanceIdentifier<?>, DataObject> updatedData = change.getUpdatedData();
\r
1072 if ( null != updatedData && !updatedData.isEmpty() ) {
\r
1073 for ( DataObject dataObject : updatedData.values() ) {
\r
1078 Set<InstanceIdentifier<?>> removedPaths = change.getRemovedPaths();
\r
1080 if ( null != removedPaths && !removedPaths.isEmpty() ) {
\r
1081 DataObject dataObject;
\r
1083 for ( InstanceIdentifier<?> instanceId : removedPaths ) {
\r
1084 dataObject = originalData.get(instanceId);
\r
1093 * A listener to change events related to physical nodes being
\r
1094 * added, removed or updated.
\r
1096 * @author Zhigang Ji
\r
1098 private class PhysicalNodeChangeListener implements DataChangeListener {
\r
1100 public void onDataChanged(AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
\r
1101 if ( null == change ) {
\r
1105 Map<InstanceIdentifier<?>, DataObject> originalData = change.getOriginalData();
\r
1106 Map<InstanceIdentifier<?>, DataObject> updatedData = change.getUpdatedData();
\r
1108 if ( null != updatedData && !updatedData.isEmpty() ) {
\r
1109 for ( DataObject dataObject : updatedData.values() ) {
\r
1114 Set<InstanceIdentifier<?>> removedPaths = change.getRemovedPaths();
\r
1116 if ( null != removedPaths && !removedPaths.isEmpty() ) {
\r
1117 DataObject dataObject;
\r
1119 for ( InstanceIdentifier<?> instanceId : removedPaths ) {
\r
1120 dataObject = originalData.get(instanceId);
\r
1129 * A listener to change events related to physical links being
\r
1130 * added, removed or updated.
\r
1132 * @author Zhigang Ji
\r
1134 private class PhysicalLinkChangeListener implements DataChangeListener {
\r
1136 public void onDataChanged(AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
\r
1137 if ( null == change ) {
\r
1141 Map<InstanceIdentifier<?>, DataObject> originalData = change.getOriginalData();
\r
1142 Map<InstanceIdentifier<?>, DataObject> updatedData = change.getUpdatedData();
\r
1144 if ( null != updatedData && !updatedData.isEmpty() ) {
\r
1145 for ( DataObject dataObject : updatedData.values() ) {
\r
1150 Set<InstanceIdentifier<?>> removedPaths = change.getRemovedPaths();
\r
1152 if ( null != removedPaths && !removedPaths.isEmpty() ) {
\r
1153 DataObject dataObject;
\r
1155 for ( InstanceIdentifier<?> instanceId : removedPaths ) {
\r
1156 dataObject = originalData.get(instanceId);
\r