blob: 77eb03fb35ba602b1862d42d51c7222cabb8fcb7 [file] [log] [blame]
Daniel Parka73c2362018-09-17 17:43:25 +09001/*
2 * Copyright 2018-present Open Networking Foundation
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.openstacknetworking.cli;
17
Ray Milkey86ad7bb2018-09-27 12:32:28 -070018import org.apache.karaf.shell.api.action.Argument;
19import org.apache.karaf.shell.api.action.Command;
Jian Lidb521c12018-11-19 17:42:35 +090020import org.apache.karaf.shell.api.action.Completion;
Ray Milkey7a2dee52018-09-28 10:58:28 -070021import org.apache.karaf.shell.api.action.lifecycle.Service;
Daniel Parka73c2362018-09-17 17:43:25 +090022import org.onosproject.cli.AbstractShellCommand;
23import org.onosproject.openstacknetworking.api.InstancePort;
24import org.onosproject.openstacknetworking.api.InstancePortAdminService;
25import org.onosproject.openstacknetworking.api.OpenstackNetworkAdminService;
26import org.onosproject.openstacknode.api.OpenstackNode;
27import org.onosproject.openstacknode.api.OpenstackNodeAdminService;
28
29import java.util.Optional;
30
Jian Li5ecfd1a2018-12-10 11:41:03 +090031import static org.onosproject.cli.AbstractShellCommand.get;
Daniel Parka73c2362018-09-17 17:43:25 +090032import static org.onosproject.openstacknetworking.util.OpenstackNetworkingUtil.sendTraceRequestToNode;
33import static org.onosproject.openstacknetworking.util.OpenstackNetworkingUtil.traceRequestString;
34
35/**
36 * Requests flow trace command.
37 */
Ray Milkey7a2dee52018-09-28 10:58:28 -070038@Service
Daniel Parka73c2362018-09-17 17:43:25 +090039@Command(scope = "onos", name = "openstack-flow-trace",
40 description = "Requests flow trace command")
41public class OpenstackFlowTraceCommand extends AbstractShellCommand {
42
43 @Argument(index = 0, name = "src ip address", description = "src ip address",
44 required = true, multiValued = false)
Jian Lidb521c12018-11-19 17:42:35 +090045 @Completion(InstanceIpAddressCompleter.class)
Daniel Parka73c2362018-09-17 17:43:25 +090046 private String srcIp = null;
47
48 @Argument(index = 1, name = "dst ip address", description = "dst ip address",
49 required = true, multiValued = false)
Jian Lidb521c12018-11-19 17:42:35 +090050 @Completion(InstanceIpAddressCompleter.class)
Daniel Parka73c2362018-09-17 17:43:25 +090051 private String dstIp = null;
52
Jian Li5ecfd1a2018-12-10 11:41:03 +090053 private static final String NO_ELEMENT =
54 "There's no instance port information with given ip address";
55 private static final String FLOW_TRACE_REQUEST_STRING_UPLINK =
56 "Flow trace request string for uplink: ";
57 private static final String FLOW_TRACE_REQUEST_STRING_DOWNLINK =
58 "Flow trace request string for downlink: ";
Daniel Parka73c2362018-09-17 17:43:25 +090059
60
61 @Override
Ray Milkey86ad7bb2018-09-27 12:32:28 -070062 protected void doExecute() {
Jian Li5ecfd1a2018-12-10 11:41:03 +090063 OpenstackNodeAdminService osNodeService = get(OpenstackNodeAdminService.class);
64 InstancePortAdminService instancePortService = get(InstancePortAdminService.class);
65 OpenstackNetworkAdminService osNetService = get(OpenstackNetworkAdminService.class);
Daniel Parka73c2362018-09-17 17:43:25 +090066
67 Optional<InstancePort> srcInstance = instancePortService.instancePorts().stream()
68 .filter(port -> port.ipAddress().toString().equals(srcIp)).findAny();
69
70 if (!srcInstance.isPresent()) {
71 print(NO_ELEMENT);
72 return;
73 }
74
75 OpenstackNode srcNode = osNodeService.node(srcInstance.get().deviceId());
76 if (srcNode == null || srcNode.sshAuthInfo() == null) {
77 log.error("Openstack node {} is null or has no SSH authentication information.\n" +
Jian Li5ecfd1a2018-12-10 11:41:03 +090078 " Please refers to the sample network-cfg.json in " +
79 "OpenstackNode app to push SSH authentication information",
80 srcNode == null ? "" : srcNode.hostname());
Daniel Parka73c2362018-09-17 17:43:25 +090081
82 return;
83 }
84
85 if (dstIp.equals(osNetService.gatewayIp(srcInstance.get().portId()))) {
86 dstIp = srcIp;
87 }
88
89 //print uplink flow trace result
90 String requestStringUplink = traceRequestString(srcIp, dstIp, srcInstance.get(),
91 osNetService, true);
92
93 print(FLOW_TRACE_REQUEST_STRING_UPLINK + requestStringUplink);
94
95 String requestStringDownlink = traceRequestString(srcIp, dstIp, srcInstance.get(),
96 osNetService, false);
97 print(FLOW_TRACE_REQUEST_STRING_DOWNLINK + requestStringDownlink);
98
99 String traceResult = sendTraceRequestToNode(requestStringUplink + '\n'
100 + requestStringDownlink, srcNode);
101 print(traceResult);
102 }
103}