Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

eth66 #2365

Merged
merged 84 commits into from
Aug 25, 2021
Merged

eth66 #2365

Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
84 commits
Select commit Hold shift + click to select a range
07f882b
refactor response constructor and sending
RatanRSur Jul 1, 2021
db59e70
nullable fix
RatanRSur Jul 1, 2021
a021144
restore original name
RatanRSur Jul 1, 2021
1725d62
remove early return
RatanRSur Jul 1, 2021
5db16eb
add eth66 version code and cleanup
RatanRSur May 12, 2021
97d46c6
dry
RatanRSur May 12, 2021
3d9ed89
move method
RatanRSur May 12, 2021
3717fbd
add requestId tracking
RatanRSur May 13, 2021
89b0cad
make RequestManager test work
RatanRSur May 14, 2021
8b6cb8d
tests successfully fail
RatanRSur May 17, 2021
dfd8557
write rlp raw instead of as opaque bytes
RatanRSur May 17, 2021
bd09170
use unwrapping from production code
RatanRSur May 17, 2021
a46dc83
wip: json parsing stuff
RatanRSur May 17, 2021
9af245e
todo
RatanRSur May 20, 2021
a815aa3
change json parsers to factory methods
RatanRSur May 20, 2021
edd3c6b
random json stuff
RatanRSur May 24, 2021
3babbc1
get transaction parsing working
RatanRSur May 25, 2021
712540e
fix block header
RatanRSur May 25, 2021
90cae83
some more tests
RatanRSur Jun 2, 2021
fd1813a
Receipts
RatanRSur Jun 2, 2021
f202eae
finish unit tests
RatanRSur Jun 2, 2021
7f4e117
disconnect if they send us a bad requestId
RatanRSur Jun 2, 2021
d5a4b9e
cleanup
RatanRSur Jun 2, 2021
5cb5ad5
remove unused method
RatanRSur Jun 2, 2021
e57300a
add test
RatanRSur Jun 2, 2021
2eb03be
spotless
RatanRSur Jun 2, 2021
c8f018a
remove unused var
RatanRSur Jun 2, 2021
22c9a42
clean up constructor
RatanRSur Jun 9, 2021
b09ec51
update optionals
RatanRSur Jun 23, 2021
ee9439b
spotless
RatanRSur Jun 23, 2021
c3c89a0
refactor response constructor and sending
RatanRSur Jul 1, 2021
bbb3217
wip
RatanRSur Jul 1, 2021
81a9fa7
Merge branch 'refcator-response-constructor' into eth66
RatanRSur Jul 1, 2021
c426304
remove logger
RatanRSur Jul 1, 2021
ee1d36a
Merge branch 'refcator-response-constructor' into eth66
RatanRSur Jul 1, 2021
1a17ed6
fix merge problem
RatanRSur Jul 1, 2021
72733dc
wip: thread all the production code
RatanRSur Jul 2, 2021
864002f
Merge branch 'master' of github.com:hyperledger/besu into eth66
RatanRSur Jul 7, 2021
d617943
add final
RatanRSur Jul 7, 2021
e6d030f
Merge branch 'master' of github.com:hyperledger/besu into eth66
RatanRSur Jul 8, 2021
32a1f8a
wip: mainly test stuff
RatanRSur Jul 8, 2021
3f908da
Merge branch 'master' of github.com:hyperledger/besu into eth66
RatanRSur Jul 9, 2021
6c879e6
request manager cleanup
RatanRSur Jul 11, 2021
5723c2d
wip
RatanRSur Jul 12, 2021
185cc68
Merge branch 'master' of github.com:hyperledger/besu into eth66
RatanRSur Jul 12, 2021
d656bc9
todo
RatanRSur Jul 12, 2021
24b1e76
check if the message needs a requestId
RatanRSur Jul 12, 2021
7f56578
extract vars
RatanRSur Jul 12, 2021
c62626b
remove import
RatanRSur Jul 12, 2021
48d004a
fix comment
RatanRSur Jul 12, 2021
a58e233
impove asserts
RatanRSur Jul 13, 2021
b66b9fa
Merge branch 'master' of github.com:hyperledger/besu into eth66
RatanRSur Jul 20, 2021
d51fe57
master logging
RatanRSur Jul 29, 2021
6472d45
Merge branch 'master' into eth66
RatanRSur Jul 29, 2021
a2fa4c8
tracing
RatanRSur Aug 11, 2021
b0767a3
fix exit
RatanRSur Aug 11, 2021
56d8f2c
add params to handle message log
RatanRSur Aug 11, 2021
a4b992c
add stacktrace for close
RatanRSur Aug 11, 2021
092d54e
add back collection copy
RatanRSur Aug 11, 2021
3baf873
Merge branch 'main' of github.com:hyperledger/besu into eth66
RatanRSur Aug 11, 2021
7431eef
remove logging
RatanRSur Aug 11, 2021
fda160f
fix tests
RatanRSur Aug 11, 2021
220068f
spotless
RatanRSur Aug 11, 2021
f38add2
spdx header
RatanRSur Aug 11, 2021
5c28e93
use big integer
RatanRSur Aug 11, 2021
1eee08b
spotless
RatanRSur Aug 11, 2021
98f9c31
Merge branch 'main' of github.com:hyperledger/besu into eth66
RatanRSur Aug 16, 2021
332778a
robust to future protocols
RatanRSur Aug 16, 2021
0b26535
streamline codespace
RatanRSur Aug 19, 2021
ce32e90
make big integer scalar encoding consistent with long scalar
RatanRSur Aug 19, 2021
abaffc4
Merge branch 'main' of github.com:hyperledger/besu into eth66
RatanRSur Aug 19, 2021
45cad8c
Merge branch 'main' of github.com:hyperledger/besu into eth66
RatanRSur Aug 23, 2021
54e86f8
rename
RatanRSur Aug 23, 2021
261da8f
handle malformed rlp exception
RatanRSur Aug 23, 2021
c3e67db
spotless
RatanRSur Aug 23, 2021
faca857
ethPeer
RatanRSur Aug 23, 2021
36d61b8
minimize try/catch block scope
RatanRSur Aug 23, 2021
9841b70
remove unused logger
RatanRSur Aug 24, 2021
c15c5b7
Merge branch 'main' of github.com:hyperledger/besu into eth66
RatanRSur Aug 24, 2021
f181530
spotless
RatanRSur Aug 24, 2021
3922a9d
Merge branch 'main' into eth66
garyschulte Aug 25, 2021
d0d6c73
changelog
RatanRSur Aug 25, 2021
a013b8c
Merge branch 'main' of github.com:hyperledger/besu into eth66
RatanRSur Aug 25, 2021
731ad55
Merge branch 'eth66' of github.com:RatanRSur/besu into eth66
RatanRSur Aug 25, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
use big integer
Signed-off-by: Ratan Rai Sur <ratan.r.sur@gmail.com>
  • Loading branch information
RatanRSur committed Aug 11, 2021
commit 5c28e93aab8ee78238936f328903a7a09fb7b6ed
Original file line number Diff line number Diff line change
Expand Up @@ -276,7 +276,7 @@ public void processMessage(final Capability cap, final Message message) {
// This will handle requests
final Optional<MessageData> maybeResponseData;
if (cap.getVersion() >= 66 && EthProtocol.requestIdCompatible(code)) {
final Map.Entry<Long, MessageData> requestIdAndEthMessage =
final Map.Entry<BigInteger, MessageData> requestIdAndEthMessage =
RequestId.unwrapRequestId(ethMessage.getData());
maybeResponseData =
ethMessages
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,29 +20,31 @@
import org.hyperledger.besu.ethereum.rlp.RLP;
import org.hyperledger.besu.ethereum.rlp.RLPInput;

import java.math.BigInteger;
import java.util.AbstractMap;
import java.util.Map;

import org.apache.tuweni.bytes.Bytes;

public class RequestId {
public static MessageData wrapRequestId(final long requestId, final MessageData messageData) {
public static MessageData wrapRequestId(
garyschulte marked this conversation as resolved.
Show resolved Hide resolved
final BigInteger requestId, final MessageData messageData) {
final BytesValueRLPOutput rlpOutput = new BytesValueRLPOutput();
rlpOutput.startList();
rlpOutput.writeLongScalar(requestId);
rlpOutput.writeBigIntegerScalar(requestId);
rlpOutput.writeRaw(messageData.getData());
rlpOutput.endList();
return new RawMessage(messageData.getCode(), rlpOutput.encoded());
}

static Map.Entry<Long, MessageData> unwrapRequestId(final MessageData messageData) {
static Map.Entry<BigInteger, MessageData> unwrapRequestId(final MessageData messageData) {
final RLPInput messageDataRLP = RLP.input(messageData.getData());
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

do we need to handle MalformedRLPInputException here or would it get appropriately handled further up the call stack?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

good catch, will fix

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

did you determine we do not need to handle this here?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

messageDataRLP.enterList();
final long requestId = messageDataRLP.readLongScalar();
final Bytes unwrappedMessageData = messageDataRLP.readBytes();
final BigInteger requestId = messageDataRLP.readBigIntegerScalar();
final RLPInput unwrappedMessageRLP = messageDataRLP.readAsRlp();
messageDataRLP.leaveList();

return new AbstractMap.SimpleImmutableEntry<>(
requestId, new RawMessage(messageData.getCode(), unwrappedMessageData));
requestId, new RawMessage(messageData.getCode(), unwrappedMessageRLP.raw()));
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
import org.hyperledger.besu.ethereum.p2p.rlpx.wire.MessageData;
import org.hyperledger.besu.ethereum.p2p.rlpx.wire.messages.DisconnectMessage;

import java.math.BigInteger;
import java.util.Collection;
import java.util.List;
import java.util.Map;
Expand All @@ -30,7 +31,7 @@

public class RequestManager {
private final AtomicLong requestIdCounter = new AtomicLong(0);
private final Map<Long, ResponseStream> responseStreams = new ConcurrentHashMap<>();
private final Map<BigInteger, ResponseStream> responseStreams = new ConcurrentHashMap<>();
private final EthPeer peer;
private final boolean supportsRequestId;

Expand All @@ -48,7 +49,7 @@ public int outstandingRequests() {
public ResponseStream dispatchRequest(final RequestSender sender, final MessageData messageData)
throws PeerNotConnected {
outstandingRequests.incrementAndGet();
final long requestId = requestIdCounter.getAndIncrement();
final BigInteger requestId = BigInteger.valueOf(requestIdCounter.getAndIncrement());
final ResponseStream stream = createStream(requestId);
sender.send(supportsRequestId ? RequestId.wrapRequestId(requestId, messageData) : messageData);
return stream;
Expand All @@ -59,7 +60,7 @@ public void dispatchResponse(final EthMessage ethMessage) {
final int count = outstandingRequests.decrementAndGet();
if (supportsRequestId) {
// If there's a requestId, find the specific stream it belongs to
final Map.Entry<Long, MessageData> requestIdAndEthMessage =
final Map.Entry<BigInteger, MessageData> requestIdAndEthMessage =
RequestId.unwrapRequestId(ethMessage.getData());
Optional.ofNullable(responseStreams.get(requestIdAndEthMessage.getKey()))
.ifPresentOrElse(
Expand All @@ -80,7 +81,7 @@ public void close() {
closeOutstandingStreams(responseStreams.values());
}

private ResponseStream createStream(final long requestId) {
private ResponseStream createStream(final BigInteger requestId) {
final ResponseStream stream = new ResponseStream(peer, () -> deregisterStream(requestId));
responseStreams.put(requestId, stream);
return stream;
Expand All @@ -91,7 +92,7 @@ private void closeOutstandingStreams(final Collection<ResponseStream> outstandin
outstandingStreams.forEach(ResponseStream::close);
}

private void deregisterStream(final long id) {
private void deregisterStream(final BigInteger id) {
responseStreams.remove(id);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ public void GetBlockHeaders() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
GetBlockHeadersMessage.create(
Hash.fromHexString(
"0x00000000000000000000000000000000000000000000000000000000deadc0de"),
Expand All @@ -80,7 +80,8 @@ public void GetBlockHeaders1() throws IOException {
final var testJson = parseTestFile("GetBlockHeadersPacket66-1.json");
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(1111, GetBlockHeadersMessage.create(9999, 5, 5, false)).getData();
wrapRequestId(BigInteger.valueOf(1111), GetBlockHeadersMessage.create(9999, 5, 5, false))
.getData();
assertThat(actual).isEqualTo(expected);
}

Expand All @@ -90,7 +91,7 @@ public void BlockHeaders() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
BlockHeadersMessage.create(
Arrays.asList(
objectMapper.treeToValue(
Expand All @@ -106,7 +107,7 @@ public void GetBlockBodies() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
GetBlockBodiesMessage.create(
Stream.of(
"0x00000000000000000000000000000000000000000000000000000000deadc0de",
Expand All @@ -123,7 +124,7 @@ public void BlockBodies() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
BlockBodiesMessage.create(
Arrays.asList(
objectMapper.treeToValue(
Expand All @@ -138,7 +139,7 @@ public void GetNodeData() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
GetNodeDataMessage.create(
Stream.of(
"0x00000000000000000000000000000000000000000000000000000000deadc0de",
Expand All @@ -155,7 +156,7 @@ public void NodeData() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
NodeDataMessage.create(
Stream.of("0xdeadc0de", "0xfeedbeef")
.map(Bytes::fromHexString)
Expand All @@ -170,7 +171,7 @@ public void GetReceipts() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
GetReceiptsMessage.create(
Stream.of(
"0x00000000000000000000000000000000000000000000000000000000deadc0de",
Expand All @@ -187,7 +188,7 @@ public void Receipts() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
ReceiptsMessage.create(
singletonList(
singletonList(
Expand Down Expand Up @@ -223,7 +224,7 @@ public void GetPooledTransactions() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
GetPooledTransactionsMessage.create(
Stream.of(
"0x00000000000000000000000000000000000000000000000000000000deadc0de",
Expand All @@ -240,7 +241,7 @@ public void PooledTransactions() throws IOException {
final Bytes expected = Bytes.fromHexString(testJson.get("rlp").asText());
final Bytes actual =
wrapRequestId(
1111,
BigInteger.valueOf(1111),
PooledTransactionsMessage.create(
Arrays.asList(
objectMapper.treeToValue(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ public interface RLPInput {
void leaveListLenient();

/**
* Reads a scalar from the input and return is as a long value.
* Reads a non-negative scalar from the input and return is as a long value.
*
* @return The next scalar item of this input as a long value.
* @throws RLPException if the next item to read is a list, the input is at the end of its current
Expand Down