From a2518a2c4967dbbefba3b48dec9eb7b57c716a3d Mon Sep 17 00:00:00 2001 From: mbaxter Date: Mon, 15 Apr 2019 12:27:18 -0400 Subject: [PATCH] [PAN-2560] Cleanup PeerConnection interface (#1282) --- .../ibft/support/StubbedPeerConnection.java | 2 +- .../pantheon/consensus/ibft/IbftGossip.java | 2 +- .../ibft/network/ValidatorPeers.java | 6 ++-- .../ibft/network/MockPeerFactory.java | 2 +- .../ibft/network/ValidatorPeersTest.java | 2 +- .../ethereum/eth/manager/EthPeer.java | 2 +- .../eth/manager/MockPeerConnection.java | 8 ++--- .../eth/transactions/TestNodeList.java | 9 ++--- .../jsonrpc/internal/results/PeerResult.java | 10 +++--- .../jsonrpc/AdminJsonRpcHttpServiceTest.java | 2 +- .../ethereum/jsonrpc/MockPeerConnection.java | 2 +- .../ethereum/p2p/testing/MockNetwork.java | 8 ++--- .../ethereum/p2p/testing/MockNetworkTest.java | 10 +++--- ...nsufficientPeersPermissioningProvider.java | 3 +- .../ethereum/p2p/api/PeerConnection.java | 19 +++++----- .../p2p/discovery/PeerDiscoveryAgent.java | 2 +- .../ethereum/p2p/netty/ApiHandler.java | 6 ++-- .../ethereum/p2p/netty/NettyP2PNetwork.java | 15 ++++---- .../p2p/netty/NettyPeerConnection.java | 12 +++---- .../p2p/netty/PeerConnectionRegistry.java | 4 +-- .../ethereum/p2p/peers/PeerBlacklist.java | 4 +-- ...ficientPeersPermissioningProviderTest.java | 10 ++---- .../p2p/discovery/PeerDiscoveryAgentTest.java | 2 +- .../ethereum/p2p/netty/DeFramerTest.java | 2 +- .../p2p/netty/NettyP2PNetworkTest.java | 35 +++++++++++++------ .../p2p/netty/PeerConnectionRegistryTest.java | 6 ++-- .../ethereum/p2p/peers/PeerBlacklistTest.java | 2 +- 27 files changed, 99 insertions(+), 88 deletions(-) diff --git a/consensus/ibft/src/integration-test/java/tech/pegasys/pantheon/consensus/ibft/support/StubbedPeerConnection.java b/consensus/ibft/src/integration-test/java/tech/pegasys/pantheon/consensus/ibft/support/StubbedPeerConnection.java index e5dfe381c4..70b11f33ae 100644 --- a/consensus/ibft/src/integration-test/java/tech/pegasys/pantheon/consensus/ibft/support/StubbedPeerConnection.java +++ b/consensus/ibft/src/integration-test/java/tech/pegasys/pantheon/consensus/ibft/support/StubbedPeerConnection.java @@ -25,7 +25,7 @@ public class StubbedPeerConnection { public static PeerConnection create(final BytesValue nodeId) { PeerConnection peerConnection = mock(PeerConnection.class); PeerInfo peerInfo = new PeerInfo(0, "IbftIntTestPeer", emptyList(), 0, nodeId); - when(peerConnection.getPeer()).thenReturn(peerInfo); + when(peerConnection.getPeerInfo()).thenReturn(peerInfo); return peerConnection; } } diff --git a/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/IbftGossip.java b/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/IbftGossip.java index 8ce4de51e0..6e63387ace 100644 --- a/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/IbftGossip.java +++ b/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/IbftGossip.java @@ -69,7 +69,7 @@ public void send(final Message message) { } final List
excludeAddressesList = Lists.newArrayList( - message.getConnection().getPeer().getAddress(), decodedMessage.getAuthor()); + message.getConnection().getPeerInfo().getAddress(), decodedMessage.getAuthor()); multicaster.send(messageData, excludeAddressesList); } diff --git a/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeers.java b/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeers.java index 112ab62919..d630d14422 100644 --- a/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeers.java +++ b/consensus/ibft/src/main/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeers.java @@ -46,13 +46,13 @@ public ValidatorPeers(final VoteTallyCache voteTallyCache) { @Override public void add(final PeerConnection newConnection) { - final Address peerAddress = newConnection.getPeer().getAddress(); + final Address peerAddress = newConnection.getPeerInfo().getAddress(); peerConnections.put(peerAddress, newConnection); } @Override public void remove(final PeerConnection removedConnection) { - final Address peerAddress = removedConnection.getPeer().getAddress(); + final Address peerAddress = removedConnection.getPeerInfo().getAddress(); peerConnections.remove(peerAddress); } @@ -85,7 +85,7 @@ private void sendMessageToSpecificAddresses( LOG.trace( "Lost connection to a validator. remoteAddress={} peerInfo={}", connection.getRemoteAddress(), - connection.getPeer()); + connection.getPeerInfo()); } }); } diff --git a/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/MockPeerFactory.java b/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/MockPeerFactory.java index a27312587a..2d8db691de 100644 --- a/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/MockPeerFactory.java +++ b/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/MockPeerFactory.java @@ -24,7 +24,7 @@ public class MockPeerFactory { public static PeerConnection create(final Address address) { final PeerConnection peerConnection = mock(PeerConnection.class); final PeerInfo peerInfo = createPeerInfo(address); - when(peerConnection.getPeer()).thenReturn(peerInfo); + when(peerConnection.getPeerInfo()).thenReturn(peerInfo); return peerConnection; } diff --git a/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeersTest.java b/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeersTest.java index 6b89a7a1d7..aa3f5527a7 100644 --- a/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeersTest.java +++ b/consensus/ibft/src/test/java/tech/pegasys/pantheon/consensus/ibft/network/ValidatorPeersTest.java @@ -57,7 +57,7 @@ public void setup() { final PeerInfo peerInfo = mock(PeerInfo.class); final PeerConnection peerConnection = mock(PeerConnection.class); - when(peerConnection.getPeer()).thenReturn(peerInfo); + when(peerConnection.getPeerInfo()).thenReturn(peerInfo); when(peerInfo.getAddress()).thenReturn(address); peerConnections.add(peerConnection); diff --git a/ethereum/eth/src/main/java/tech/pegasys/pantheon/ethereum/eth/manager/EthPeer.java b/ethereum/eth/src/main/java/tech/pegasys/pantheon/ethereum/eth/manager/EthPeer.java index 756972b00d..7691f94ef7 100644 --- a/ethereum/eth/src/main/java/tech/pegasys/pantheon/ethereum/eth/manager/EthPeer.java +++ b/ethereum/eth/src/main/java/tech/pegasys/pantheon/ethereum/eth/manager/EthPeer.java @@ -329,7 +329,7 @@ public int outstandingRequests() { } public BytesValue nodeId() { - return connection.getPeer().getNodeId(); + return connection.getPeerInfo().getNodeId(); } @Override diff --git a/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/manager/MockPeerConnection.java b/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/manager/MockPeerConnection.java index 99d442a41d..21549c3e3d 100644 --- a/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/manager/MockPeerConnection.java +++ b/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/manager/MockPeerConnection.java @@ -19,7 +19,7 @@ import tech.pegasys.pantheon.ethereum.p2p.wire.messages.DisconnectMessage.DisconnectReason; import tech.pegasys.pantheon.util.bytes.Bytes32; -import java.net.SocketAddress; +import java.net.InetSocketAddress; import java.util.ArrayList; import java.util.Set; import java.util.concurrent.atomic.AtomicLong; @@ -65,7 +65,7 @@ public Set getAgreedCapabilities() { } @Override - public PeerInfo getPeer() { + public PeerInfo getPeerInfo() { return new PeerInfo(5, "Mock", new ArrayList<>(caps), 0, nodeId); } @@ -80,12 +80,12 @@ public void disconnect(final DisconnectReason reason) { } @Override - public SocketAddress getLocalAddress() { + public InetSocketAddress getLocalAddress() { throw new UnsupportedOperationException(); } @Override - public SocketAddress getRemoteAddress() { + public InetSocketAddress getRemoteAddress() { throw new UnsupportedOperationException(); } diff --git a/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/transactions/TestNodeList.java b/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/transactions/TestNodeList.java index 071c9ecc26..60ebbb090c 100644 --- a/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/transactions/TestNodeList.java +++ b/ethereum/eth/src/test/java/tech/pegasys/pantheon/ethereum/eth/transactions/TestNodeList.java @@ -73,7 +73,8 @@ public void connectAndAssertAll() final TestNode destination = nodes.get(j); try { LOG.info("Attempting to connect source " + source.shortId() + " to dest " + destination); - assertThat(source.connect(destination).get(30L, TimeUnit.SECONDS).getPeer().getNodeId()) + assertThat( + source.connect(destination).get(30L, TimeUnit.SECONDS).getPeerInfo().getNodeId()) .isEqualTo(destination.id()); // Wait for the destination node to finish bonding. Awaitility.await() @@ -118,7 +119,7 @@ public void assertPeerCounts() { private boolean hasConnection(final TestNode node1, final TestNode node2) { for (final PeerConnection peer : node1.network.getPeers()) { - if (node2.id().equals(peer.getPeer().getNodeId())) { + if (node2.id().equals(peer.getPeerInfo().getNodeId())) { return true; } } @@ -221,7 +222,7 @@ public void assertNoNetworkDisconnections() { for (final Map.Entry entry : node.disconnections.entrySet()) { final PeerConnection peer = entry.getKey(); - final String peerString = peer.getPeer().getNodeId() + "@" + peer.getRemoteAddress(); + final String peerString = peer.getPeerInfo().getNodeId() + "@" + peer.getRemoteAddress(); final String unsentTxMsg = "Node " + node.shortId() @@ -245,7 +246,7 @@ public void logPeerConnections() { for (final PeerConnection peer : node.network.getPeers()) { final String localString = node.shortId() + "@" + peer.getLocalAddress(); final String peerString = - shortId(peer.getPeer().getNodeId()) + "@" + peer.getRemoteAddress(); + shortId(peer.getPeerInfo().getNodeId()) + "@" + peer.getRemoteAddress(); connStr.add("Connection: " + localString + " to " + peerString); } } diff --git a/ethereum/jsonrpc/src/main/java/tech/pegasys/pantheon/ethereum/jsonrpc/internal/results/PeerResult.java b/ethereum/jsonrpc/src/main/java/tech/pegasys/pantheon/ethereum/jsonrpc/internal/results/PeerResult.java index cb8238cd4e..7105bc283a 100644 --- a/ethereum/jsonrpc/src/main/java/tech/pegasys/pantheon/ethereum/jsonrpc/internal/results/PeerResult.java +++ b/ethereum/jsonrpc/src/main/java/tech/pegasys/pantheon/ethereum/jsonrpc/internal/results/PeerResult.java @@ -34,16 +34,16 @@ public class PeerResult { private final String id; public PeerResult(final PeerConnection peer) { - this.version = Quantity.create(peer.getPeer().getVersion()); - this.name = peer.getPeer().getClientId(); + this.version = Quantity.create(peer.getPeerInfo().getVersion()); + this.name = peer.getPeerInfo().getClientId(); this.caps = - peer.getPeer().getCapabilities().stream() + peer.getPeerInfo().getCapabilities().stream() .map(Capability::toString) .map(TextNode::new) .collect(Collectors.toList()); this.network = new NetworkResult(peer.getLocalAddress(), peer.getRemoteAddress()); - this.port = Quantity.create(peer.getPeer().getPort()); - this.id = peer.getPeer().getNodeId().toString(); + this.port = Quantity.create(peer.getPeerInfo().getPort()); + this.id = peer.getPeerInfo().getNodeId().toString(); } @JsonGetter(value = "version") diff --git a/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/AdminJsonRpcHttpServiceTest.java b/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/AdminJsonRpcHttpServiceTest.java index 93d95de148..4fe404c536 100644 --- a/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/AdminJsonRpcHttpServiceTest.java +++ b/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/AdminJsonRpcHttpServiceTest.java @@ -97,7 +97,7 @@ protected void assertPeerResultMatchesPeer( final BytesValue jsonNodeId = BytesValue.fromHexString(peerJson.getString("id")); final PeerInfo jsonPeer = new PeerInfo(jsonVersion, jsonClient, caps, jsonPort, jsonNodeId); - assertThat(peerConn.getPeer()).isEqualTo(jsonPeer); + assertThat(peerConn.getPeerInfo()).isEqualTo(jsonPeer); } } diff --git a/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/MockPeerConnection.java b/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/MockPeerConnection.java index dfc85a92c6..f436fc7f3d 100644 --- a/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/MockPeerConnection.java +++ b/ethereum/jsonrpc/src/test/java/tech/pegasys/pantheon/ethereum/jsonrpc/MockPeerConnection.java @@ -30,7 +30,7 @@ public static PeerConnection create( final InetSocketAddress localAddress, final InetSocketAddress remoteAddress) { PeerConnection peerConnection = mock(PeerConnection.class); - when(peerConnection.getPeer()).thenReturn(peerInfo); + when(peerConnection.getPeerInfo()).thenReturn(peerInfo); when(peerConnection.getLocalAddress()).thenReturn(localAddress); when(peerConnection.getRemoteAddress()).thenReturn(remoteAddress); diff --git a/ethereum/mock-p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetwork.java b/ethereum/mock-p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetwork.java index b10004888b..c4b9766f55 100644 --- a/ethereum/mock-p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetwork.java +++ b/ethereum/mock-p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetwork.java @@ -26,7 +26,7 @@ import tech.pegasys.pantheon.util.Subscribers; import tech.pegasys.pantheon.util.enode.EnodeURL; -import java.net.SocketAddress; +import java.net.InetSocketAddress; import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; @@ -260,7 +260,7 @@ public Set getAgreedCapabilities() { } @Override - public PeerInfo getPeer() { + public PeerInfo getPeerInfo() { return new PeerInfo( 5, "mock-network-client", @@ -287,12 +287,12 @@ public boolean isDisconnected() { } @Override - public SocketAddress getLocalAddress() { + public InetSocketAddress getLocalAddress() { throw new UnsupportedOperationException(); } @Override - public SocketAddress getRemoteAddress() { + public InetSocketAddress getRemoteAddress() { throw new UnsupportedOperationException(); } } diff --git a/ethereum/mock-p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetworkTest.java b/ethereum/mock-p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetworkTest.java index 152472d7d3..5a9eae29ed 100644 --- a/ethereum/mock-p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetworkTest.java +++ b/ethereum/mock-p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/testing/MockNetworkTest.java @@ -46,9 +46,9 @@ public void exchangeMessages() throws Exception { final CompletableFuture messageFuture = new CompletableFuture<>(); network1.subscribe(cap, messageFuture::complete); final Predicate isPeerOne = - peerConnection -> peerConnection.getPeer().getNodeId().equals(one.getId()); + peerConnection -> peerConnection.getPeerInfo().getNodeId().equals(one.getId()); final Predicate isPeerTwo = - peerConnection -> peerConnection.getPeer().getNodeId().equals(two.getId()); + peerConnection -> peerConnection.getPeerInfo().getNodeId().equals(two.getId()); Assertions.assertThat(network1.getPeers().stream().filter(isPeerTwo).findFirst()) .isNotPresent(); Assertions.assertThat(network2.getPeers().stream().filter(isPeerOne).findFirst()) @@ -60,8 +60,8 @@ public void exchangeMessages() throws Exception { final CompletableFuture peer1Future = new CompletableFuture<>(); network2.subscribeConnect(peer1Future::complete); network1.connect(two).get(); - Assertions.assertThat(peer1Future.get().getPeer().getNodeId()).isEqualTo(one.getId()); - Assertions.assertThat(peer2Future.get().getPeer().getNodeId()).isEqualTo(two.getId()); + Assertions.assertThat(peer1Future.get().getPeerInfo().getNodeId()).isEqualTo(one.getId()); + Assertions.assertThat(peer2Future.get().getPeerInfo().getNodeId()).isEqualTo(two.getId()); Assertions.assertThat(network1.getPeers().stream().filter(isPeerTwo).findFirst()).isPresent(); final Optional optionalConnection = network2.getPeers().stream().filter(isPeerOne).findFirst(); @@ -78,7 +78,7 @@ public void exchangeMessages() throws Exception { final MessageData receivedMessageData = receivedMessage.getData(); Assertions.assertThat(receivedMessageData.getData().compareTo(BytesValue.wrap(data))) .isEqualTo(0); - Assertions.assertThat(receivedMessage.getConnection().getPeer().getNodeId()) + Assertions.assertThat(receivedMessage.getConnection().getPeerInfo().getNodeId()) .isEqualTo(two.getId()); Assertions.assertThat(receivedMessageData.getSize()).isEqualTo(size); Assertions.assertThat(receivedMessageData.getCode()).isEqualTo(code); diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProvider.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProvider.java index 7dd60588cf..4ef2897f33 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProvider.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProvider.java @@ -53,7 +53,8 @@ public InsufficientPeersPermissioningProvider( } private boolean isNotABootnode(final PeerConnection peerConnection) { - return bootnodeEnodes.stream().noneMatch(peerConnection::isRemoteEnode); + return bootnodeEnodes.stream() + .noneMatch((bootNode) -> peerConnection.getRemoteEnode().sameEndpoint(bootNode)); } private long countP2PNetworkNonBootnodeConnections() { diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/api/PeerConnection.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/api/PeerConnection.java index 9fefcda055..947546c855 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/api/PeerConnection.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/api/PeerConnection.java @@ -19,7 +19,6 @@ import java.io.IOException; import java.net.InetSocketAddress; -import java.net.SocketAddress; import java.util.Set; /** A P2P connection to another node. */ @@ -70,7 +69,7 @@ default void sendForProtocol(final String protocol, final MessageData message) * * @return Peer Description */ - PeerInfo getPeer(); + PeerInfo getPeerInfo(); /** * Immediately terminate the connection without sending a disconnect message. @@ -90,9 +89,9 @@ default void sendForProtocol(final String protocol, final MessageData message) /** @return True if the peer is disconnected */ boolean isDisconnected(); - SocketAddress getLocalAddress(); + InetSocketAddress getLocalAddress(); - SocketAddress getRemoteAddress(); + InetSocketAddress getRemoteAddress(); class PeerNotConnected extends IOException { @@ -101,11 +100,11 @@ public PeerNotConnected(final String message) { } } - default boolean isRemoteEnode(final EnodeURL remoteEnodeUrl) { - return ((remoteEnodeUrl.getNodeId().equals(this.getPeer().getAddress())) - && (remoteEnodeUrl.getListeningPort() == this.getPeer().getPort()) - && (remoteEnodeUrl - .getInetAddress() - .equals(((InetSocketAddress) this.getRemoteAddress()).getAddress()))); + default EnodeURL getRemoteEnode() { + return EnodeURL.builder() + .nodeId(getPeerInfo().getNodeId()) + .listeningPort(getPeerInfo().getPort()) + .ipAddress(getRemoteAddress().getAddress()) + .build(); } } diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgent.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgent.java index f1e9633332..db2ad4d56e 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgent.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgent.java @@ -314,7 +314,7 @@ public void onDisconnect( final PeerConnection connection, final DisconnectMessage.DisconnectReason reason, final boolean initiatedByPeer) { - final BytesValue nodeId = connection.getPeer().getNodeId(); + final BytesValue nodeId = connection.getPeerInfo().getNodeId(); peerTable.tryEvict(new DefaultPeerId(nodeId)); } diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/ApiHandler.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/ApiHandler.java index 2a395bc6b1..7e4d0d9376 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/ApiHandler.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/ApiHandler.java @@ -80,15 +80,15 @@ protected void channelRead0(final ChannelHandlerContext ctx, final MessageData o LOG.debug( "Received Wire DISCONNECT ({}) from peer: {}", reason.name(), - connection.getPeer().getClientId()); + connection.getPeerInfo().getClientId()); } catch (final RLPException e) { LOG.debug( "Received Wire DISCONNECT with invalid RLP. Peer: {}", - connection.getPeer().getClientId()); + connection.getPeerInfo().getClientId()); } catch (final Exception e) { LOG.error( "Received Wire DISCONNECT, but unable to parse reason. Peer: {}", - connection.getPeer().getClientId(), + connection.getPeerInfo().getClientId(), e); } connection.terminateConnection(reason, true); diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetwork.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetwork.java index 1d5a409af7..d39a971cc8 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetwork.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetwork.java @@ -365,7 +365,7 @@ protected void initChannel(final SocketChannel ch) { LOG.debug( "Disconnecting incoming connection because connection limit of {} has been reached: {}", maxPeers, - connection.getPeer().getNodeId()); + connection.getPeerInfo().getNodeId()); connection.disconnect(DisconnectReason.TOO_MANY_PEERS); return; } @@ -377,7 +377,7 @@ protected void initChannel(final SocketChannel ch) { onConnectionEstablished(connection); LOG.debug( - "Successfully accepted connection from {}", connection.getPeer().getNodeId()); + "Successfully accepted connection from {}", connection.getPeerInfo().getNodeId()); logConnections(); }); } @@ -591,7 +591,7 @@ private Consumer handlePeerDroppedEvents() { return event -> { final Peer peer = event.getPeer(); getPeers().stream() - .filter(p -> p.getPeer().getNodeId().equals(peer.getId())) + .filter(p -> p.getPeerInfo().getNodeId().equals(peer.getId())) .findFirst() .ifPresent(p -> p.disconnect(DisconnectReason.REQUESTED)); }; @@ -626,18 +626,17 @@ private boolean isPeerConnectionAllowed(final PeerConnection peerConnection) { } LOG.trace( - "Checking if connection with peer {} is permitted", peerConnection.getPeer().getNodeId()); + "Checking if connection with peer {} is permitted", + peerConnection.getPeerInfo().getNodeId()); return nodePermissioningController .map( c -> { final EnodeURL localPeerEnodeURL = - peerInfoToEnodeURL( - ourPeerInfo, (InetSocketAddress) peerConnection.getLocalAddress()); + peerInfoToEnodeURL(ourPeerInfo, peerConnection.getLocalAddress()); final EnodeURL remotePeerEnodeURL = peerInfoToEnodeURL( - peerConnection.getPeer(), - (InetSocketAddress) peerConnection.getRemoteAddress()); + peerConnection.getPeerInfo(), peerConnection.getRemoteAddress()); return c.isPermitted(localPeerEnodeURL, remotePeerEnodeURL); }) .orElse(true); diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyPeerConnection.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyPeerConnection.java index 28780ebbf9..f54f31dc41 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyPeerConnection.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyPeerConnection.java @@ -26,7 +26,7 @@ import tech.pegasys.pantheon.metrics.Counter; import tech.pegasys.pantheon.metrics.LabelledMetric; -import java.net.SocketAddress; +import java.net.InetSocketAddress; import java.util.HashMap; import java.util.Map; import java.util.Set; @@ -108,7 +108,7 @@ public void send(final Capability capability, final MessageData message) throws } @Override - public PeerInfo getPeer() { + public PeerInfo getPeerInfo() { return peerInfo; } @@ -156,13 +156,13 @@ public boolean isDisconnected() { } @Override - public SocketAddress getLocalAddress() { - return ctx.channel().localAddress(); + public InetSocketAddress getLocalAddress() { + return (InetSocketAddress) ctx.channel().localAddress(); } @Override - public SocketAddress getRemoteAddress() { - return ctx.channel().remoteAddress(); + public InetSocketAddress getRemoteAddress() { + return (InetSocketAddress) ctx.channel().remoteAddress(); } @Override diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistry.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistry.java index 142c5fe2ed..78cae30cf7 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistry.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistry.java @@ -54,7 +54,7 @@ public PeerConnectionRegistry(final MetricsSystem metricsSystem) { } public void registerConnection(final PeerConnection connection) { - connections.put(connection.getPeer().getNodeId(), connection); + connections.put(connection.getPeerInfo().getNodeId(), connection); connectedPeersCounter.inc(); } @@ -79,7 +79,7 @@ public void onDisconnect( final PeerConnection connection, final DisconnectReason reason, final boolean initiatedByPeer) { - connections.remove(connection.getPeer().getNodeId()); + connections.remove(connection.getPeerInfo().getNodeId()); disconnectCounter.labels(initiatedByPeer ? "remote" : "local", reason.name()).inc(); } } diff --git a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklist.java b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklist.java index a0535cdde3..d997f1dae3 100644 --- a/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklist.java +++ b/ethereum/p2p/src/main/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklist.java @@ -84,7 +84,7 @@ private boolean contains(final BytesValue nodeId) { } public boolean contains(final PeerConnection peer) { - return contains(peer.getPeer().getNodeId()); + return contains(peer.getPeerInfo().getNodeId()); } public boolean contains(final Peer peer) { @@ -105,7 +105,7 @@ public void onDisconnect( final DisconnectReason reason, final boolean initiatedByPeer) { if (shouldBlacklistForDisconnect(reason, initiatedByPeer)) { - add(connection.getPeer().getNodeId()); + add(connection.getPeerInfo().getNodeId()); } } diff --git a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProviderTest.java b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProviderTest.java index fcb006b6e6..183e4f85c6 100644 --- a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProviderTest.java +++ b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/InsufficientPeersPermissioningProviderTest.java @@ -13,9 +13,6 @@ package tech.pegasys.pantheon.ethereum.p2p; import static org.assertj.core.api.Assertions.assertThat; -import static org.mockito.AdditionalMatchers.not; -import static org.mockito.ArgumentMatchers.any; -import static org.mockito.ArgumentMatchers.eq; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.times; import static org.mockito.Mockito.verify; @@ -71,7 +68,7 @@ public void noResultWhenNoBootnodes() { @Test public void noResultWhenOtherConnections() { final PeerConnection neverMatchPeerConnection = mock(PeerConnection.class); - when(neverMatchPeerConnection.isRemoteEnode(any())).thenReturn(false); + when(neverMatchPeerConnection.getRemoteEnode()).thenReturn(ENODE_5); when(p2pNetwork.getPeers()).thenReturn(Collections.singletonList(neverMatchPeerConnection)); final Collection bootnodes = Collections.singletonList(ENODE_2); @@ -101,7 +98,7 @@ public void allowsConnectionIfBootnodeAndOnlyBootnodesConnected() { final Collection bootnodes = Collections.singletonList(ENODE_2); final PeerConnection bootnodeMatchPeerConnection = mock(PeerConnection.class); - when(bootnodeMatchPeerConnection.isRemoteEnode(ENODE_2)).thenReturn(true); + when(bootnodeMatchPeerConnection.getRemoteEnode()).thenReturn(ENODE_2); when(p2pNetwork.getPeers()).thenReturn(Collections.singletonList(bootnodeMatchPeerConnection)); final InsufficientPeersPermissioningProvider provider = @@ -113,8 +110,7 @@ public void allowsConnectionIfBootnodeAndOnlyBootnodesConnected() { private PeerConnection peerConnectionMatching(final EnodeURL enode) { final PeerConnection pc = mock(PeerConnection.class); - when(pc.isRemoteEnode(enode)).thenReturn(true); - when(pc.isRemoteEnode(not(eq(enode)))).thenReturn(false); + when(pc.getRemoteEnode()).thenReturn(enode); return pc; } diff --git a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgentTest.java b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgentTest.java index 8f02c6cfcc..2a6c118d9b 100644 --- a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgentTest.java +++ b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/discovery/PeerDiscoveryAgentTest.java @@ -296,7 +296,7 @@ public void shouldNotBeActiveWhenConfigIsFalse() { private PeerConnection createAnonymousPeerConnection(final BytesValue id) { PeerConnection conn = mock(PeerConnection.class); PeerInfo peerInfo = new PeerInfo(0, null, null, 0, id); - when(conn.getPeer()).thenReturn(peerInfo); + when(conn.getPeerInfo()).thenReturn(peerInfo); return conn; } } diff --git a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/DeFramerTest.java b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/DeFramerTest.java index 37a40f249a..e2f23390b7 100644 --- a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/DeFramerTest.java +++ b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/DeFramerTest.java @@ -156,7 +156,7 @@ public void decode_handlesHello() throws ExecutionException, InterruptedExceptio assertThat(connectFuture).isDone(); assertThat(connectFuture).isNotCompletedExceptionally(); PeerConnection peerConnection = connectFuture.get(); - assertThat(peerConnection.getPeer()).isEqualTo(remotePeerInfo); + assertThat(peerConnection.getPeerInfo()).isEqualTo(remotePeerInfo); assertThat(out).isEmpty(); // Next phase of pipeline should be setup diff --git a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetworkTest.java b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetworkTest.java index 37347a2011..b5bc63aac7 100644 --- a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetworkTest.java +++ b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/NettyP2PNetworkTest.java @@ -156,7 +156,7 @@ public void handshaking() throws Exception { listenPort, OptionalInt.of(listenPort)))) .get(30L, TimeUnit.SECONDS) - .getPeer() + .getPeerInfo() .getNodeId()) .isEqualTo(listenId); } @@ -209,7 +209,7 @@ public void preventMultipleConnections() throws Exception { listenPort, OptionalInt.of(listenPort)))) .get(30L, TimeUnit.SECONDS) - .getPeer() + .getPeerInfo() .getNodeId()) .isEqualTo(listenId); final CompletableFuture secondConnectionFuture = @@ -290,7 +290,12 @@ public void limitMaxPeers() throws Exception { InetAddress.getLoopbackAddress().getHostAddress(), listenPort, OptionalInt.of(listenPort))); - assertThat(connector1.connect(listeningPeer).get(30L, TimeUnit.SECONDS).getPeer().getNodeId()) + assertThat( + connector1 + .connect(listeningPeer) + .get(30L, TimeUnit.SECONDS) + .getPeerInfo() + .getNodeId()) .isEqualTo(listenId); // Setup second connection and check that connection is not accepted @@ -302,9 +307,15 @@ public void limitMaxPeers() throws Exception { reasonFuture.complete(reason); }); connector2.start(); - assertThat(connector2.connect(listeningPeer).get(30L, TimeUnit.SECONDS).getPeer().getNodeId()) + assertThat( + connector2 + .connect(listeningPeer) + .get(30L, TimeUnit.SECONDS) + .getPeerInfo() + .getNodeId()) + .isEqualTo(listenId); + assertThat(peerFuture.get(30L, TimeUnit.SECONDS).getPeerInfo().getNodeId()) .isEqualTo(listenId); - assertThat(peerFuture.get(30L, TimeUnit.SECONDS).getPeer().getNodeId()).isEqualTo(listenId); assertThat(reasonFuture.get(30L, TimeUnit.SECONDS)) .isEqualByComparingTo(DisconnectReason.TOO_MANY_PEERS); } @@ -437,8 +448,9 @@ public void rejectIncomingConnectionFromBlacklistedPeer() throws Exception { final CompletableFuture connectFuture = remoteNetwork.connect(localPeer); // Check connection is made, and then a disconnect is registered at remote - assertThat(connectFuture.get(5L, TimeUnit.SECONDS).getPeer().getNodeId()).isEqualTo(localId); - assertThat(peerFuture.get(5L, TimeUnit.SECONDS).getPeer().getNodeId()).isEqualTo(localId); + assertThat(connectFuture.get(5L, TimeUnit.SECONDS).getPeerInfo().getNodeId()) + .isEqualTo(localId); + assertThat(peerFuture.get(5L, TimeUnit.SECONDS).getPeerInfo().getNodeId()).isEqualTo(localId); assertThat(reasonFuture.get(5L, TimeUnit.SECONDS)) .isEqualByComparingTo(DisconnectReason.UNKNOWN); } @@ -519,8 +531,9 @@ public void rejectIncomingConnectionFromNonWhitelistedPeer() throws Exception { final CompletableFuture connectFuture = remoteNetwork.connect(localPeer); // Check connection is made, and then a disconnect is registered at remote - assertThat(connectFuture.get(5L, TimeUnit.SECONDS).getPeer().getNodeId()).isEqualTo(localId); - assertThat(peerFuture.get(5L, TimeUnit.SECONDS).getPeer().getNodeId()).isEqualTo(localId); + assertThat(connectFuture.get(5L, TimeUnit.SECONDS).getPeerInfo().getNodeId()) + .isEqualTo(localId); + assertThat(peerFuture.get(5L, TimeUnit.SECONDS).getPeerInfo().getNodeId()).isEqualTo(localId); assertThat(reasonFuture.get(5L, TimeUnit.SECONDS)) .isEqualByComparingTo(DisconnectReason.UNKNOWN); } @@ -958,7 +971,7 @@ private PeerConnection mockPeerConnection(final BytesValue id) { final PeerInfo peerInfo = mock(PeerInfo.class); when(peerInfo.getNodeId()).thenReturn(id); final PeerConnection peerConnection = mock(PeerConnection.class); - when(peerConnection.getPeer()).thenReturn(peerInfo); + when(peerConnection.getPeerInfo()).thenReturn(peerInfo); return peerConnection; } @@ -972,7 +985,7 @@ private PeerConnection mockPeerConnection(final Peer localPeer, final Peer remot doReturn(remotePeer.getEndpoint().getTcpPort().getAsInt()).when(peerInfo).getPort(); final PeerConnection peerConnection = mock(PeerConnection.class); - when(peerConnection.getPeer()).thenReturn(peerInfo); + when(peerConnection.getPeerInfo()).thenReturn(peerInfo); Endpoint localEndpoint = localPeer.getEndpoint(); InetSocketAddress localSocketAddress = diff --git a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistryTest.java b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistryTest.java index 13076d7b92..c742e88251 100644 --- a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistryTest.java +++ b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/netty/PeerConnectionRegistryTest.java @@ -38,8 +38,10 @@ public class PeerConnectionRegistryTest { @Before public void setUp() { - when(connection1.getPeer()).thenReturn(new PeerInfo(5, "client1", emptyList(), 10, PEER1_ID)); - when(connection2.getPeer()).thenReturn(new PeerInfo(5, "client2", emptyList(), 10, PEER2_ID)); + when(connection1.getPeerInfo()) + .thenReturn(new PeerInfo(5, "client1", emptyList(), 10, PEER1_ID)); + when(connection2.getPeerInfo()) + .thenReturn(new PeerInfo(5, "client2", emptyList(), 10, PEER2_ID)); } @Test diff --git a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklistTest.java b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklistTest.java index 40af78fd87..49f4d12b12 100644 --- a/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklistTest.java +++ b/ethereum/p2p/src/test/java/tech/pegasys/pantheon/ethereum/p2p/peers/PeerBlacklistTest.java @@ -199,7 +199,7 @@ private PeerConnection generatePeerConnection() { final PeerInfo peerInfo = mock(PeerInfo.class); when(peerInfo.getNodeId()).thenReturn(nodeId); - when(peer.getPeer()).thenReturn(peerInfo); + when(peer.getPeerInfo()).thenReturn(peerInfo); return peer; }