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.renderer.openflow;
\r
11 import com.google.common.base.Optional;
\r
12 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
\r
13 import org.opendaylight.controller.md.sal.binding.api.DataChangeListener;
\r
14 import org.opendaylight.controller.md.sal.binding.api.ReadOnlyTransaction;
\r
15 import org.opendaylight.controller.md.sal.common.api.data.AsyncDataBroker.DataChangeScope;
\r
16 import org.opendaylight.controller.md.sal.common.api.data.AsyncDataChangeEvent;
\r
17 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
\r
18 import org.opendaylight.nemo.renderer.openflow.physicalnetwork.PhyConfigLoader;
\r
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.packet.service.rev130709.PacketProcessingService;
\r
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.PhysicalNetwork;
\r
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.PhysicalNodes;
\r
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.physical.network.rev151010.physical.network.physical.nodes.PhysicalNode;
\r
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.VirtualNetworks;
\r
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.networks.VirtualNetwork;
\r
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.generic.virtual.network.rev151010.virtual.networks.VirtualNetworkKey;
\r
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.IntentVnMappingResults;
\r
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.VnPnMappingResults;
\r
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.intent.vn.mapping.results.UserIntentVnMapping;
\r
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.intent.vn.mapping.results.UserIntentVnMappingKey;
\r
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.intent.mapping.result.rev151010.vn.pn.mapping.results.UserVnPnMapping;
\r
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.common.rev151010.UserId;
\r
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.engine.common.rev151010.VirtualNetworkId;
\r
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.Users;
\r
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.User;
\r
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.UserKey;
\r
36 import org.opendaylight.yangtools.concepts.ListenerRegistration;
\r
37 import org.opendaylight.yangtools.yang.binding.DataObject;
\r
38 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
\r
39 import org.slf4j.Logger;
\r
40 import org.slf4j.LoggerFactory;
\r
42 import java.util.List;
\r
43 import java.util.Map;
\r
44 import java.util.Set;
\r
46 public class FlowTableManager implements AutoCloseable {
\r
47 private static final Logger LOG = LoggerFactory.getLogger(FlowTableManager.class);
\r
49 private final DataBroker dataProvider;
\r
50 private final PacketProcessingService packetProcessingService;
\r
52 private ListenerRegistration<DataChangeListener> userVnPnMappingChangeListenerReg;
\r
54 private FlowUtils flowUtils = null;
\r
56 public FlowTableManager(DataBroker dataProvider,
\r
57 PacketProcessingService packetProcessingService,
\r
58 PhyConfigLoader phyConfigLoader) {
\r
61 this.dataProvider = dataProvider;
\r
62 this.packetProcessingService = packetProcessingService;
\r
64 LOG.debug("Initialized FlowTableManager.");
\r
66 flowUtils = new FlowUtils(dataProvider, packetProcessingService, phyConfigLoader);
\r
68 // Register listener;
\r
69 registerUserVnPnMappingListener();
\r
72 protected FlowUtils getFlowUtils() {
\r
76 private void registerUserVnPnMappingListener() {
\r
78 //build userVnPnMappingIid
\r
79 InstanceIdentifier<UserVnPnMapping> userVnPnMappingIid = InstanceIdentifier
\r
80 .builder(VnPnMappingResults.class)
\r
81 .child(UserVnPnMapping.class)
\r
84 userVnPnMappingChangeListenerReg = dataProvider.registerDataChangeListener(
\r
85 LogicalDatastoreType.CONFIGURATION, userVnPnMappingIid,
\r
86 new UserVnPnMappingChangeListener(), DataChangeScope.BASE);
\r
90 private User getUser(UserId userId) {
\r
92 ReadOnlyTransaction readOnlyTransaction = dataProvider.newReadOnlyTransaction();
\r
93 InstanceIdentifier<User> userIid = InstanceIdentifier.builder(Users.class)
\r
94 .child(User.class, new UserKey(userId))
\r
96 Optional<User> result = null;
\r
99 result = readOnlyTransaction.read(LogicalDatastoreType.CONFIGURATION, userIid).get();
\r
100 } catch (Exception e) {
\r
101 e.printStackTrace();
\r
103 if (result.isPresent()){
\r
104 LOG.debug("getUser OK");
\r
105 return (result.get());
\r
108 LOG.debug("getUser ERROR");
\r
114 private VirtualNetwork getVirtualNetwork(UserId userId) {
\r
116 VirtualNetworkId virtualNetworkId = new VirtualNetworkId(userId.getValue());
\r
117 VirtualNetworkKey virtualNetworkKey = new VirtualNetworkKey(virtualNetworkId);
\r
119 ReadOnlyTransaction readOnlyTransaction = dataProvider.newReadOnlyTransaction();
\r
120 InstanceIdentifier<VirtualNetwork> virtualNetworkIid = InstanceIdentifier
\r
121 .builder(VirtualNetworks.class)
\r
122 .child(VirtualNetwork.class, virtualNetworkKey)
\r
124 Optional<VirtualNetwork> result = null;
\r
127 result = readOnlyTransaction.read(LogicalDatastoreType.CONFIGURATION, virtualNetworkIid).get();
\r
129 } catch (Exception e) {
\r
130 e.printStackTrace();
\r
132 if (result.isPresent()) {
\r
133 LOG.debug("getVirtualNetwork OK");
\r
134 return (result.get());
\r
137 LOG.debug("getVirtualNetwork ERROR");
\r
142 private UserIntentVnMapping getUserIntentVnMapping(UserId userId) {
\r
144 ReadOnlyTransaction readOnlyTransaction = dataProvider.newReadOnlyTransaction();
\r
145 InstanceIdentifier<UserIntentVnMapping> userIntentVnMappingIid = InstanceIdentifier
\r
146 .builder(IntentVnMappingResults.class)
\r
147 .child(UserIntentVnMapping.class, new UserIntentVnMappingKey(userId))
\r
149 Optional<UserIntentVnMapping> result = null;
\r
151 result = readOnlyTransaction.read(LogicalDatastoreType.CONFIGURATION, userIntentVnMappingIid).get();
\r
152 } catch (Exception e) {
\r
153 e.printStackTrace();
\r
155 if (result.isPresent()) {
\r
156 LOG.debug("getUserIntentVnMapping OK");
\r
157 return (result.get());
\r
160 LOG.debug("getUserIntentVnMapping ERROR");
\r
165 private PhysicalNetwork getPhysicalNetwork() {
\r
167 ReadOnlyTransaction readOnlyTransaction = dataProvider.newReadOnlyTransaction();
\r
168 InstanceIdentifier<PhysicalNetwork> physicalNetworkIid = InstanceIdentifier
\r
169 .builder(PhysicalNetwork.class)
\r
171 Optional<PhysicalNetwork> result = null;
\r
173 result = readOnlyTransaction.read(LogicalDatastoreType.OPERATIONAL, physicalNetworkIid).get();
\r
174 } catch (Exception e) {
\r
175 e.printStackTrace();
\r
177 if (result.isPresent()) {
\r
178 LOG.debug("getPhysicalNetwork OK");
\r
179 return (result.get());
\r
182 LOG.debug("getPhysicalNetwork ERROR");
\r
188 //A listener implementation
\r
189 private class UserVnPnMappingChangeListener implements DataChangeListener {
\r
192 public void onDataChanged(AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
\r
193 if ( null == change ) {
\r
197 Map<InstanceIdentifier<?>, DataObject> createdData = change.getCreatedData();
\r
198 if ( null != createdData && !createdData.isEmpty() ) {
\r
199 for ( DataObject dataObject : createdData.values() ) {
\r
200 if ( dataObject instanceof UserVnPnMapping ) {
\r
201 LOG.debug("Ready to update flow table.");
\r
202 UserVnPnMapping userVnPnMapping = (UserVnPnMapping)dataObject;
\r
203 UserId userId = userVnPnMapping.getUserId();
\r
205 User user = getUser(userId);
\r
206 VirtualNetwork virtualNetwork = getVirtualNetwork(userId);
\r
207 UserIntentVnMapping userIntentVnMapping = getUserIntentVnMapping(userId);
\r
208 PhysicalNetwork physicalNetwork = getPhysicalNetwork();
\r
209 if(physicalNetwork == null)
\r
211 LOG.debug("Physical Network data are not present.");
\r
214 PhysicalNodes physicalNodes= physicalNetwork.getPhysicalNodes();
\r
215 List<PhysicalNode> physicalNodeList = physicalNodes.getPhysicalNode();
\r
216 flowUtils.init(physicalNodeList);
\r
218 flowUtils.updateFlowTable(user, virtualNetwork, userIntentVnMapping, userVnPnMapping, physicalNetwork);
\r
219 LOG.debug("Already call flowUtils.updateFlowTable().");
\r
224 Map<InstanceIdentifier<?>, DataObject> updatedData = change.getUpdatedData();
\r
225 if ( null != updatedData && !updatedData.isEmpty() ) {
\r
226 for ( DataObject dataObject : updatedData.values() ) {
\r
227 if ( dataObject instanceof UserVnPnMapping ) {
\r
228 UserVnPnMapping userVnPnMapping = (UserVnPnMapping)dataObject;
\r
229 UserId userId = userVnPnMapping.getUserId();
\r
231 flowUtils.deleteFlowEntries(userId);
\r
233 User user = getUser(userId);
\r
234 VirtualNetwork virtualNetwork = getVirtualNetwork(userId);
\r
235 UserIntentVnMapping userIntentVnMapping = getUserIntentVnMapping(userId);
\r
236 PhysicalNetwork physicalNetwork = getPhysicalNetwork();
\r
237 if(physicalNetwork == null)
\r
239 LOG.debug("Physical Network data are not present.");
\r
243 flowUtils.updateFlowTable(user, virtualNetwork, userIntentVnMapping, userVnPnMapping, physicalNetwork);
\r
248 Map<InstanceIdentifier<?>, DataObject> originalData = change.getOriginalData();
\r
249 Set<InstanceIdentifier<?>> removedPaths = change.getRemovedPaths();
\r
250 if ( null != removedPaths && !removedPaths.isEmpty() ) {
\r
251 DataObject dataObject;
\r
253 for ( InstanceIdentifier<?> instanceId : removedPaths ) {
\r
254 dataObject = originalData.get(instanceId);
\r
255 if ( null != dataObject && dataObject instanceof UserVnPnMapping ) {
\r
256 UserVnPnMapping userVnPnMapping = (UserVnPnMapping)dataObject;
\r
257 flowUtils.deleteFlowEntries(userVnPnMapping.getUserId());
\r
266 public void close() throws Exception {
\r
268 if ( null != userVnPnMappingChangeListenerReg ) {
\r
269 userVnPnMappingChangeListenerReg.close();
\r
271 if ( null != flowUtils ) {
\r