blob: 8516ed2c9f54c95b44e24790a49b0f7fce9ba2e2 [file] [log] [blame]
/*
* Copyright 2017-present Open Networking Laboratory
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.onosproject.routing.fpm.cli;
import org.apache.karaf.shell.commands.Command;
import org.onlab.packet.IpAddress;
import org.onlab.util.Tools;
import org.onosproject.cli.AbstractShellCommand;
import org.onosproject.cluster.ClusterService;
import org.onosproject.routing.fpm.FpmConnectionInfo;
import org.onosproject.routing.fpm.FpmInfoService;
import java.util.Comparator;
/**
* Displays the current FPM connections.
*/
@Command(scope = "onos", name = "fpm-connections",
description = "Displays the current FPM connections")
public class FpmConnectionsList extends AbstractShellCommand {
private static final String FORMAT = "peer %s:%s connected to %s since %s %s";
@Override
protected void execute() {
FpmInfoService fpmInfo = get(FpmInfoService.class);
ClusterService clusterService = get(ClusterService.class);
fpmInfo.peers().values().stream()
.flatMap(v -> v.stream())
.sorted(Comparator.<FpmConnectionInfo, IpAddress>comparing(i -> i.peer().address())
.thenComparing(i -> i.peer().port()))
.forEach(info -> print(FORMAT, info.peer().address(), info.peer().port(),
info.connectedTo(), Tools.timeAgo(info.connectTime()),
info.connectedTo().equals(clusterService.getLocalNode().id()) ? "*" : ""));
}
}