blob: 8319137ccc20ec10baf3bc9b38c00608dd6fb0d4 [file] [log] [blame]
rama-huaweic78f3092016-05-19 18:09:29 +05301/*
2 * Copyright 2016-present Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package org.onosproject.sfcweb;
17
Phaneendra Mandab212bc92016-07-08 16:50:11 +053018import static org.onosproject.net.DefaultEdgeLink.createEdgeLink;
19
20import java.util.Collection;
21import java.util.List;
22import java.util.ListIterator;
23import java.util.Set;
24import java.util.TimerTask;
25
26import jersey.repackaged.com.google.common.collect.Lists;
27
rama-huaweic78f3092016-05-19 18:09:29 +053028import org.onlab.osgi.DefaultServiceDirectory;
29import org.onlab.osgi.ServiceDirectory;
rama-huaweic78f3092016-05-19 18:09:29 +053030import org.onlab.packet.MacAddress;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053031import org.onosproject.net.DeviceId;
rama-huaweic78f3092016-05-19 18:09:29 +053032import org.onosproject.net.Element;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053033import org.onosproject.net.Host;
34import org.onosproject.net.HostId;
rama-huaweic78f3092016-05-19 18:09:29 +053035import org.onosproject.net.Link;
rama-huaweic78f3092016-05-19 18:09:29 +053036import org.onosproject.net.host.HostService;
37import org.onosproject.net.link.LinkService;
rama-huaweic78f3092016-05-19 18:09:29 +053038import org.onosproject.ui.RequestHandler;
39import org.onosproject.ui.UiConnection;
40import org.onosproject.ui.UiMessageHandler;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053041import org.onosproject.ui.topo.DeviceHighlight;
rama-huaweic78f3092016-05-19 18:09:29 +053042import org.onosproject.ui.topo.Highlights;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053043import org.onosproject.ui.topo.HostHighlight;
rama-huaweic78f3092016-05-19 18:09:29 +053044import org.onosproject.ui.topo.NodeBadge;
45import org.onosproject.ui.topo.TopoJson;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053046import org.onosproject.vtnrsc.FiveTuple;
47import org.onosproject.vtnrsc.LoadBalanceId;
rama-huaweic78f3092016-05-19 18:09:29 +053048import org.onosproject.vtnrsc.PortChain;
rama-huaweic78f3092016-05-19 18:09:29 +053049import org.onosproject.vtnrsc.PortChainId;
rama-huaweic78f3092016-05-19 18:09:29 +053050import org.onosproject.vtnrsc.PortPair;
51import org.onosproject.vtnrsc.PortPairId;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053052import org.onosproject.vtnrsc.VirtualPort;
rama-huaweic78f3092016-05-19 18:09:29 +053053import org.onosproject.vtnrsc.VirtualPortId;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053054import org.onosproject.vtnrsc.portchain.PortChainService;
55import org.onosproject.vtnrsc.portpair.PortPairService;
56import org.onosproject.vtnrsc.portpairgroup.PortPairGroupService;
rama-huaweic78f3092016-05-19 18:09:29 +053057import org.onosproject.vtnrsc.service.VtnRscService;
58import org.onosproject.vtnrsc.virtualport.VirtualPortService;
Phaneendra Mandab212bc92016-07-08 16:50:11 +053059import org.slf4j.Logger;
60import org.slf4j.LoggerFactory;
rama-huaweic78f3092016-05-19 18:09:29 +053061
Phaneendra Mandab212bc92016-07-08 16:50:11 +053062import com.fasterxml.jackson.databind.node.ArrayNode;
63import com.fasterxml.jackson.databind.node.ObjectNode;
64import com.google.common.collect.ImmutableSet;
rama-huaweic78f3092016-05-19 18:09:29 +053065
66/**
67 * SFC web gui topology-overlay message handler.
68 */
69public class SfcwebUiTopovMessageHandler extends UiMessageHandler {
70
71 private static final String SAMPLE_TOPOV_DISPLAY_START = "sfcwebTopovDisplayStart";
72 private static final String SAMPLE_TOPOV_DISPLAY_SFC = "showSfcInfo";
73 private static final String SAMPLE_TOPOV_DISPLAY_STOP = "sfcTopovClear";
74 private static final String CONFIG_SFP_MSG = "configSfpMessage";
Phaneendra Mandab212bc92016-07-08 16:50:11 +053075 private static final String SAMPLE_TOPOV_SHOW_SFC_PATH = "showSfcPath";
rama-huaweic78f3092016-05-19 18:09:29 +053076 private static final String ID = "id";
77 private static final String MODE = "mode";
Phaneendra Mandab212bc92016-07-08 16:50:11 +053078 private static final String CLASSIFIER = "CLS";
79 private static final String FORWARDER = "SFF";
rama-huaweic78f3092016-05-19 18:09:29 +053080
81 private static final Link[] EMPTY_LINK_SET = new Link[0];
82
Phaneendra Mandab212bc92016-07-08 16:50:11 +053083 private enum Mode {
84 IDLE, MOUSE, LINK
85 }
rama-huaweic78f3092016-05-19 18:09:29 +053086
87 private final Logger log = LoggerFactory.getLogger(getClass());
88
rama-huaweic78f3092016-05-19 18:09:29 +053089 private HostService hostService;
90 private LinkService linkService;
rama-huaweic78f3092016-05-19 18:09:29 +053091 private TimerTask demoTask = null;
92 private Mode currentMode = Mode.IDLE;
93 private Element elementOfNote;
94 private Link[] linkSet = EMPTY_LINK_SET;
rama-huaweic78f3092016-05-19 18:09:29 +053095
rama-huaweic78f3092016-05-19 18:09:29 +053096 protected PortPairService portPairService;
97 protected VtnRscService vtnRscService;
98 protected VirtualPortService virtualPortService;
99 protected PortChainService portChainService;
100 protected PortPairGroupService portPairGroupService;
101
102 @Override
103 public void init(UiConnection connection, ServiceDirectory directory) {
104 super.init(connection, directory);
rama-huaweic78f3092016-05-19 18:09:29 +0530105 hostService = directory.get(HostService.class);
106 linkService = directory.get(LinkService.class);
107 portChainService = directory.get(PortChainService.class);
108 portPairService = directory.get(PortPairService.class);
109 portPairGroupService = directory.get(PortPairGroupService.class);
110 }
111
112 @Override
113 protected Collection<RequestHandler> createRequestHandlers() {
114 return ImmutableSet.of(
115 new DisplayStartHandler(),
116 new DisplayStopHandler(),
117 new ConfigSfpMsg()
118 );
119 }
120
121 /**
122 * Handler classes.
123 */
124 private final class DisplayStartHandler extends RequestHandler {
125 public DisplayStartHandler() {
126 super(SAMPLE_TOPOV_DISPLAY_START);
127 }
128 @Override
129 public void process(long sid, ObjectNode payload) {
130 String mode = string(payload, MODE);
131 PortChainService pcs = get(PortChainService.class);
132 Iterable<PortChain> portChains = pcs.getPortChains();
133 ObjectNode result = objectNode();
134
135 ArrayNode arrayNode = arrayNode();
136
137 for (final PortChain portChain : portChains) {
138 arrayNode.add(portChain.portChainId().value().toString());
139 }
140 result.putArray("a").addAll(arrayNode);
141
142 sendMessage(SAMPLE_TOPOV_DISPLAY_SFC, sid, result);
143 }
144 }
145
146 private final class DisplayStopHandler extends RequestHandler {
147 public DisplayStopHandler() {
148 super(SAMPLE_TOPOV_DISPLAY_STOP);
149 }
150
151 @Override
152 public void process(long sid, ObjectNode payload) {
153 log.debug("Stop Display");
154 clearState();
155 clearForMode();
156 cancelTask();
157 }
158 }
159
160 private final class ConfigSfpMsg extends RequestHandler {
161 public ConfigSfpMsg() {
162 super(CONFIG_SFP_MSG);
163 }
164
165 @Override
166 public void process(long sid, ObjectNode payload) {
167 String id = string(payload, ID);
168 ServiceDirectory serviceDirectory = new DefaultServiceDirectory();
169 vtnRscService = serviceDirectory.get(VtnRscService.class);
170 virtualPortService = serviceDirectory.get(VirtualPortService.class);
171
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530172 List<String> sfcPathList = Lists.newArrayList();
173
rama-huaweic78f3092016-05-19 18:09:29 +0530174 Highlights highlights = new Highlights();
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530175 SfcLinkMap linkMap = new SfcLinkMap();
rama-huaweic78f3092016-05-19 18:09:29 +0530176
177 PortChainId portChainId = PortChainId.of(id);
178 boolean portChainIdExist = portChainService.exists(portChainId);
179 if (!portChainIdExist) {
180 log.info("portchain id doesn't exist");
181 return;
182 }
183
184 PortChain portChain = portChainService.getPortChain(portChainId);
185
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530186 Set<FiveTuple> fiveTupleSet = portChain.getLoadBalanceIdMapKeys();
187 for (FiveTuple fiveTuple : fiveTupleSet) {
188 List<PortPairId> path = portChain.getLoadBalancePath(fiveTuple);
189 LoadBalanceId lbId = portChain.getLoadBalanceId(fiveTuple);
190 ListIterator<PortPairId> pathIterator = path.listIterator();
rama-huaweic78f3092016-05-19 18:09:29 +0530191
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530192 // Add source
193 Host srcHost = hostService.getHost(HostId.hostId(fiveTuple.macSrc()));
194
195 HostHighlight hSrc = new HostHighlight(srcHost.id().toString());
196 hSrc.setBadge(NodeBadge.text("SRC"));
197 String sfcPath = "SRC -> ";
198 highlights.add(hSrc);
199
200 DeviceId previousDeviceId = null;
201 while (pathIterator.hasNext()) {
202
203 PortPairId portPairId = pathIterator.next();
rama-huaweic78f3092016-05-19 18:09:29 +0530204 PortPair portPair = portPairService.getPortPair(portPairId);
205 DeviceId deviceId = vtnRscService.getSfToSffMaping(VirtualPortId.portId(portPair.egress()));
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530206 VirtualPort vPort = virtualPortService.getPort(VirtualPortId.portId(portPair.egress()));
207 MacAddress dstMacAddress = vPort.macAddress();
rama-huaweic78f3092016-05-19 18:09:29 +0530208 Host host = hostService.getHost(HostId.hostId(dstMacAddress));
rama-huaweic78f3092016-05-19 18:09:29 +0530209
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530210 addEdgeLinks(linkMap, host);
211 log.info("before check");
212 if (previousDeviceId != null) {
213 log.info("pdid not null");
214 if (!deviceId.equals(previousDeviceId)) {
215 // Highlight the link between devices.
216
217 Link link = getLinkBetweenDevices(deviceId, previousDeviceId);
218 if (link != null) {
219 linkMap.add(link);
220 }
221 }
222 }
223
224 DeviceHighlight dh = new DeviceHighlight(deviceId.toString());
225 if (portChain.getSfcClassifiers(lbId).contains(deviceId)) {
226 dh.setBadge(NodeBadge.text(CLASSIFIER));
227 } else {
228 dh.setBadge(NodeBadge.text(FORWARDER));
229 }
rama-huaweic78f3092016-05-19 18:09:29 +0530230
231 highlights.add(dh);
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530232
233 HostHighlight hhDst = new HostHighlight(host.id().toString());
234 hhDst.setBadge(NodeBadge.text(portPair.name()));
235 sfcPath = sfcPath + portPair.name() + "(" + vPort.fixedIps().iterator().next().ip() + ") -> ";
236
237 if (!portPair.ingress().equals(portPair.egress())) {
238 MacAddress srcMacAddress = virtualPortService.getPort(VirtualPortId
239 .portId(portPair.ingress()))
240 .macAddress();
241 Host hostSrc = hostService.getHost(HostId.hostId(srcMacAddress));
242 HostHighlight hhSrc = new HostHighlight(hostSrc.id().toString());
243 hhSrc.setBadge(NodeBadge.text(portPair.name()));
244 highlights.add(hhSrc);
245 }
rama-huaweic78f3092016-05-19 18:09:29 +0530246 highlights.add(hhDst);
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530247 previousDeviceId = deviceId;
rama-huaweic78f3092016-05-19 18:09:29 +0530248 }
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530249
250 // Add destination
251 Host dstHost = hostService.getHost(HostId.hostId(fiveTuple.macDst()));
252
253 HostHighlight hDst = new HostHighlight(dstHost.id().toString());
254 hDst.setBadge(NodeBadge.text("DST"));
255 sfcPath = sfcPath + "DST";
256 highlights.add(hDst);
257 sfcPathList.add(sfcPath);
rama-huaweic78f3092016-05-19 18:09:29 +0530258 }
259
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530260 for (SfcLink sfcLink : linkMap.biLinks()) {
261 highlights.add(sfcLink.highlight(null));
262 }
rama-huaweic78f3092016-05-19 18:09:29 +0530263 sendHighlights(highlights);
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530264
265 ObjectNode result = objectNode();
266 ArrayNode arrayNode = arrayNode();
267 for (String path : sfcPathList) {
268 arrayNode.add(path);
269 }
270 result.putArray("sfcPathList").addAll(arrayNode);
271
272 sendMessage(SAMPLE_TOPOV_SHOW_SFC_PATH, sid, result);
rama-huaweic78f3092016-05-19 18:09:29 +0530273 }
274 }
275
Phaneendra Mandab212bc92016-07-08 16:50:11 +0530276 private Link getLinkBetweenDevices(DeviceId deviceId, DeviceId previousDeviceId) {
277 Set<Link> deviceLinks = linkService.getDeviceEgressLinks(deviceId);
278 Set<Link> previousDeviceLinks = linkService.getDeviceIngressLinks(previousDeviceId);
279 for (Link link : deviceLinks) {
280 previousDeviceLinks.contains(link);
281 return link;
282 }
283 return null;
284 }
285
286 private void addEdgeLinks(SfcLinkMap linkMap, Host host1) {
287 linkMap.add(createEdgeLink(host1, true));
288 linkMap.add(createEdgeLink(host1, false));
289 }
290
rama-huaweic78f3092016-05-19 18:09:29 +0530291 private synchronized void cancelTask() {
292 if (demoTask != null) {
293 demoTask.cancel();
294 demoTask = null;
295 }
296 }
297
298 private void clearState() {
299 currentMode = Mode.IDLE;
300 elementOfNote = null;
301 linkSet = EMPTY_LINK_SET;
302 }
303
304 private void clearForMode() {
305 sendHighlights(new Highlights());
306 }
307
308 private void sendHighlights(Highlights highlights) {
309 sendMessage(TopoJson.highlightsMessage(highlights));
310 }
311
312}