Add inbound/outbound info to peers list

This commit is contained in:
Manfred Karrer 2016-02-14 12:15:59 +01:00
parent 43d811d9fe
commit 59e4fc6842

View file

@ -29,6 +29,7 @@ import io.bitsquare.p2p.NodeAddress;
import io.bitsquare.p2p.P2PService; import io.bitsquare.p2p.P2PService;
import io.bitsquare.p2p.P2PServiceListener; import io.bitsquare.p2p.P2PServiceListener;
import io.bitsquare.p2p.network.LocalhostNetworkNode; import io.bitsquare.p2p.network.LocalhostNetworkNode;
import io.bitsquare.p2p.network.OutboundConnection;
import io.bitsquare.p2p.seed.SeedNodesRepository; import io.bitsquare.p2p.seed.SeedNodesRepository;
import io.bitsquare.user.Preferences; import io.bitsquare.user.Preferences;
import javafx.beans.value.ChangeListener; import javafx.beans.value.ChangeListener;
@ -46,6 +47,7 @@ import javax.inject.Inject;
import java.time.Duration; import java.time.Duration;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
import java.util.stream.Collectors;
@FxmlView @FxmlView
public class NetworkSettingsView extends ActivatableViewAndModel<GridPane, Activatable> { public class NetworkSettingsView extends ActivatableViewAndModel<GridPane, Activatable> {
@ -190,13 +192,20 @@ public class NetworkSettingsView extends ActivatableViewAndModel<GridPane, Activ
private void updateP2PPeersTextArea() { private void updateP2PPeersTextArea() {
p2PPeersTextArea.clear(); p2PPeersTextArea.clear();
p2PService.getNodeAddressesOfConnectedPeers().stream().forEach(e -> { p2PPeersTextArea.setText(p2PService.getNetworkNode().getConfirmedConnections()
if (p2PPeersTextArea.getText().length() > 0) .stream()
p2PPeersTextArea.appendText("\n"); .map(connection -> {
p2PPeersTextArea.appendText(e.getFullAddress()); if (connection.getPeersNodeAddressOptional().isPresent()) {
if (seedNodeAddresses.contains(e)) NodeAddress nodeAddress = connection.getPeersNodeAddressOptional().get();
p2PPeersTextArea.appendText(" (Seed node)"); return nodeAddress.getFullAddress() + " (" +
}); (connection instanceof OutboundConnection ? "outbound" : "inbound") +
(seedNodeAddresses.contains(nodeAddress) ? " / seed node)" : ")");
} else {
// Should never be the case
return "";
}
})
.collect(Collectors.joining("\n")));
} }
private void updateBitcoinPeersTextArea() { private void updateBitcoinPeersTextArea() {