blob: 50e8d534095d38065e9cf1fcaf2360aca6e5c0d9 [file] [log] [blame]
Thomas Vachuska7d693f52014-10-21 19:17:57 -07001/*
Ray Milkey34c95902015-04-15 09:47:53 -07002 * Copyright 2014-2015 Open Networking Laboratory
Thomas Vachuska7d693f52014-10-21 19:17:57 -07003 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07004 * 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
Thomas Vachuska7d693f52014-10-21 19:17:57 -07007 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07008 * 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.
Thomas Vachuska7d693f52014-10-21 19:17:57 -070015 */
Brian O'Connorabafb502014-12-02 22:26:20 -080016package org.onosproject.cli;
tome4729872014-09-23 00:37:37 -070017
Jon Halle97083c2015-04-20 15:18:56 -070018import com.fasterxml.jackson.databind.JsonNode;
19import com.fasterxml.jackson.databind.ObjectMapper;
20import com.fasterxml.jackson.databind.node.ArrayNode;
21import com.fasterxml.jackson.databind.node.ObjectNode;
Madan Jampani7d2fab22015-03-18 17:21:57 -070022import org.apache.karaf.shell.commands.Command;
Jon Halle97083c2015-04-20 15:18:56 -070023import org.joda.time.DateTime;
Madan Jampani7d2fab22015-03-18 17:21:57 -070024import org.onlab.util.Tools;
25import org.onosproject.cluster.ClusterService;
26import org.onosproject.cluster.ControllerNode;
27
Jon Halle97083c2015-04-20 15:18:56 -070028import java.util.Collections;
29import java.util.List;
30
31import static com.google.common.collect.Lists.newArrayList;
32
tome4729872014-09-23 00:37:37 -070033
34/**
35 * Lists all controller cluster nodes.
36 */
37@Command(scope = "onos", name = "nodes",
38 description = "Lists all controller cluster nodes")
39public class NodesListCommand extends AbstractShellCommand {
40
41 private static final String FMT =
Madan Jampani7d2fab22015-03-18 17:21:57 -070042 "id=%s, address=%s:%s, state=%s, updated=%s %s";
tome4729872014-09-23 00:37:37 -070043
tome4729872014-09-23 00:37:37 -070044 @Override
tom0872a172014-09-23 11:24:26 -070045 protected void execute() {
46 ClusterService service = get(ClusterService.class);
tome4729872014-09-23 00:37:37 -070047 List<ControllerNode> nodes = newArrayList(service.getNodes());
tom1380eee2014-09-24 09:22:02 -070048 Collections.sort(nodes, Comparators.NODE_COMPARATOR);
tom32085cf2014-10-16 00:04:33 -070049 if (outputJson()) {
50 print("%s", json(service, nodes));
51 } else {
52 ControllerNode self = service.getLocalNode();
53 for (ControllerNode node : nodes) {
Jon Halle97083c2015-04-20 15:18:56 -070054 DateTime lastUpdated = service.getLastUpdated(node.id());
55 String timeAgo = "Never";
56 if (lastUpdated != null) {
57 timeAgo = Tools.timeAgo(lastUpdated.getMillis());
58 }
tom32085cf2014-10-16 00:04:33 -070059 print(FMT, node.id(), node.ip(), node.tcpPort(),
60 service.getState(node.id()),
Jon Halle97083c2015-04-20 15:18:56 -070061 timeAgo,
tom32085cf2014-10-16 00:04:33 -070062 node.equals(self) ? "*" : "");
63 }
64 }
65 }
66
67 // Produces JSON structure.
68 private JsonNode json(ClusterService service, List<ControllerNode> nodes) {
69 ObjectMapper mapper = new ObjectMapper();
70 ArrayNode result = mapper.createArrayNode();
tome4729872014-09-23 00:37:37 -070071 ControllerNode self = service.getLocalNode();
72 for (ControllerNode node : nodes) {
Jon Halle97083c2015-04-20 15:18:56 -070073 ControllerNode.State nodeState = service.getState(node.id());
74 ObjectNode newNode = mapper.createObjectNode()
tom32085cf2014-10-16 00:04:33 -070075 .put("id", node.id().toString())
76 .put("ip", node.ip().toString())
77 .put("tcpPort", node.tcpPort())
Jon Halle97083c2015-04-20 15:18:56 -070078 .put("self", node.equals(self));
79
80 if (nodeState != null) {
81 newNode.put("state", nodeState.toString());
82 }
83 result.add(newNode);
tome4729872014-09-23 00:37:37 -070084 }
tom32085cf2014-10-16 00:04:33 -070085 return result;
tome4729872014-09-23 00:37:37 -070086 }
87
88}