Naoki Shiota
Committed by Gerrit Code Review

Modified onos:resources CLI command to be able to filter resource types (ONOS-3617).

Change-Id: I3465cca0ba44fce14d3607be5f4fccf29cfabbed
...@@ -17,9 +17,15 @@ package org.onosproject.cli.net; ...@@ -17,9 +17,15 @@ package org.onosproject.cli.net;
17 17
18 import static org.onosproject.net.DeviceId.deviceId; 18 import static org.onosproject.net.DeviceId.deviceId;
19 19
20 +import java.util.Set;
21 +import java.util.HashSet;
22 +import java.util.Arrays;
20 import java.util.Collection; 23 import java.util.Collection;
24 +import java.util.Collections;
25 +
21 import org.apache.karaf.shell.commands.Argument; 26 import org.apache.karaf.shell.commands.Argument;
22 import org.apache.karaf.shell.commands.Command; 27 import org.apache.karaf.shell.commands.Command;
28 +import org.apache.karaf.shell.commands.Option;
23 import org.onosproject.cli.AbstractShellCommand; 29 import org.onosproject.cli.AbstractShellCommand;
24 import org.onosproject.net.DeviceId; 30 import org.onosproject.net.DeviceId;
25 import org.onosproject.net.PortNumber; 31 import org.onosproject.net.PortNumber;
...@@ -35,6 +41,16 @@ import com.google.common.base.Strings; ...@@ -35,6 +41,16 @@ import com.google.common.base.Strings;
35 description = "Lists available resources") 41 description = "Lists available resources")
36 public class ResourcesCommand extends AbstractShellCommand { 42 public class ResourcesCommand extends AbstractShellCommand {
37 43
44 + @Option(name = "-s", aliases = "--sort", description = "Sort output",
45 + required = false, multiValued = false)
46 + boolean sort = false;
47 +
48 + @Option(name = "-t", aliases = "--typeStrings", description = "List of resource types to be printed",
49 + required = false, multiValued = true)
50 + String[] typeStrings = null;
51 +
52 + Set<String> typesToPrint;
53 +
38 @Argument(index = 0, name = "deviceIdString", description = "Device ID", 54 @Argument(index = 0, name = "deviceIdString", description = "Device ID",
39 required = false, multiValued = false) 55 required = false, multiValued = false)
40 String deviceIdStr = null; 56 String deviceIdStr = null;
...@@ -50,6 +66,12 @@ public class ResourcesCommand extends AbstractShellCommand { ...@@ -50,6 +66,12 @@ public class ResourcesCommand extends AbstractShellCommand {
50 protected void execute() { 66 protected void execute() {
51 resourceService = get(ResourceService.class); 67 resourceService = get(ResourceService.class);
52 68
69 + if (typeStrings != null) {
70 + typesToPrint = new HashSet<>(Arrays.asList(typeStrings));
71 + } else {
72 + typesToPrint = Collections.emptySet();
73 + }
74 +
53 if (deviceIdStr != null && portNumberStr != null) { 75 if (deviceIdStr != null && portNumberStr != null) {
54 DeviceId deviceId = deviceId(deviceIdStr); 76 DeviceId deviceId = deviceId(deviceIdStr);
55 PortNumber portNumber = PortNumber.fromString(portNumberStr); 77 PortNumber portNumber = PortNumber.fromString(portNumberStr);
...@@ -65,24 +87,36 @@ public class ResourcesCommand extends AbstractShellCommand { ...@@ -65,24 +87,36 @@ public class ResourcesCommand extends AbstractShellCommand {
65 } 87 }
66 88
67 private void printResource(ResourcePath resource, int level) { 89 private void printResource(ResourcePath resource, int level) {
90 + Collection<ResourcePath> children = resourceService.getAvailableResources(resource);
91 +
68 if (resource.equals(ResourcePath.ROOT)) { 92 if (resource.equals(ResourcePath.ROOT)) {
69 print("ROOT"); 93 print("ROOT");
70 } else { 94 } else {
71 - String name = resource.last().getClass().getSimpleName(); 95 + String resourceName = resource.last().getClass().getSimpleName();
96 +
97 + if (children.isEmpty() && !typesToPrint.isEmpty() && !typesToPrint.contains(resourceName)) {
98 + // This resource is target of filtering
99 + return;
100 + }
101 +
72 String toString = String.valueOf(resource.last()); 102 String toString = String.valueOf(resource.last());
73 - if (toString.startsWith(name)) { 103 + if (toString.startsWith(resourceName)) {
74 print("%s%s", Strings.repeat(" ", level), 104 print("%s%s", Strings.repeat(" ", level),
75 toString); 105 toString);
76 -
77 } else { 106 } else {
78 - print("%s%s:%s", Strings.repeat(" ", level), 107 + print("%s%s: %s", Strings.repeat(" ", level),
79 - name, 108 + resourceName,
80 toString); 109 toString);
81 } 110 }
82 } 111 }
83 112
84 - Collection<ResourcePath> resources = resourceService.getAvailableResources(resource); 113 + if (sort) {
114 + children.stream()
115 + .sorted((o1, o2) -> String.valueOf(o1.id()).compareTo(String.valueOf(o2.id())))
116 + .forEach(r -> printResource(r, level + 1));
117 + } else {
85 // TODO: Should consider better output for leaf nodes 118 // TODO: Should consider better output for leaf nodes
86 - resources.forEach(r -> printResource(r, level + 1)); 119 + children.forEach(r -> printResource(r, level + 1));
120 + }
87 } 121 }
88 } 122 }
......