Vendor bumps + related fixes + warning fixes (#1985)

- Vendor bump of stew, nim-eth, chronos, nimbus-eth2 and libp2p
- Bump related fixes + fixes of deprecation warnings
- Several other warnings fixed.
This commit is contained in:
Kim De Mey 2024-01-24 16:28:03 +01:00 committed by GitHub
parent 31c288d5e5
commit dbc1ae86e2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
23 changed files with 76 additions and 47 deletions

View File

@ -1,5 +1,5 @@
# Nimbus - Portal Network # Nimbus - Portal Network
# Copyright (c) 2022-2023 Status Research & Development GmbH # Copyright (c) 2022-2024 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
@ -99,7 +99,7 @@ proc new*(
proc lightClientVerifier(obj: SomeForkedLightClientObject): proc lightClientVerifier(obj: SomeForkedLightClientObject):
Future[Result[void, VerifierError]] = Future[Result[void, VerifierError]] =
let resfut = newFuture[Result[void, VerifierError]]("lightClientVerifier") let resfut = Future[Result[void, VerifierError]].Raising([CancelledError]).init("lightClientVerifier")
lightClient.processor[].addObject(MsgSource.gossip, obj, resfut) lightClient.processor[].addObject(MsgSource.gossip, obj, resfut)
resfut resfut

View File

@ -6,10 +6,7 @@
# at your option. This file may not be copied, modified, or distributed except according to those terms. # at your option. This file may not be copied, modified, or distributed except according to those terms.
import import
std/[sequtils, sugar],
stew/results, chronos, chronicles, stew/results, chronos, chronicles,
eth/[rlp, common],
eth/trie/hexary_proof_verification,
eth/p2p/discoveryv5/[protocol, enr], eth/p2p/discoveryv5/[protocol, enr],
../../database/content_db, ../../database/content_db,
../wire/[portal_protocol, portal_stream, portal_protocol_config], ../wire/[portal_protocol, portal_stream, portal_protocol_config],

View File

@ -1,3 +1,10 @@
# fluffy
# Copyright (c) 2022-2024 Status Research & Development GmbH
# Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
-d:"chronicles_runtime_filtering=on" -d:"chronicles_runtime_filtering=on"
-d:"chronicles_disable_thread_id" -d:"chronicles_disable_thread_id"
@ -5,7 +12,6 @@
-d:"chronicles_line_numbers:0" -d:"chronicles_line_numbers:0"
@end @end
-d:chronosStrictException
-d:PREFER_BLST_SHA256=false -d:PREFER_BLST_SHA256=false
--styleCheck:usages --styleCheck:usages

View File

@ -1,5 +1,5 @@
# Fluffy # Fluffy
# Copyright (c) 2021-2023 Status Research & Development GmbH # Copyright (c) 2021-2024 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
@ -9,7 +9,7 @@
import import
std/[times, sequtils, strutils, typetraits], std/[times, sequtils, strutils, typetraits],
json_rpc/[rpcproxy, rpcserver], stew/byteutils, json_rpc/[rpcproxy, rpcserver],
web3/[conversions], # sigh, for FixedBytes marshalling web3/[conversions], # sigh, for FixedBytes marshalling
eth/[common/eth_types, rlp], eth/[common/eth_types, rlp],
beacon_chain/spec/forks, beacon_chain/spec/forks,

View File

@ -12,7 +12,6 @@ import
json_rpc/[rpcproxy, rpcserver], json_rpc/[rpcproxy, rpcserver],
json_serialization/std/tables, json_serialization/std/tables,
stew/byteutils, stew/byteutils,
eth/p2p/discoveryv5/nodes_verification,
../network/wire/portal_protocol, ../network/wire/portal_protocol,
./rpc_types ./rpc_types

View File

@ -6,7 +6,6 @@
# at your option. This file may not be copied, modified, or distributed except according to those terms. # at your option. This file may not be copied, modified, or distributed except according to those terms.
import import
std/[os, json, sequtils],
testutils/unittests, testutils/unittests,
stew/[byteutils, io2], stew/[byteutils, io2],
eth/keys, eth/keys,

View File

@ -8,7 +8,7 @@
{.used.} {.used.}
import import
chronos, testutils/unittests, stew/shims/net, chronos, testutils/unittests,
json_rpc/[rpcproxy, rpcserver], json_rpc/clients/httpclient, json_rpc/[rpcproxy, rpcserver], json_rpc/clients/httpclient,
stint,eth/p2p/discoveryv5/enr, eth/keys, stint,eth/p2p/discoveryv5/enr, eth/keys,
eth/p2p/discoveryv5/protocol as discv5_protocol, eth/p2p/discoveryv5/protocol as discv5_protocol,

View File

@ -1,5 +1,5 @@
# Nimbus - Portal Network # Nimbus - Portal Network
# Copyright (c) 2021-2023 Status Research & Development GmbH # Copyright (c) 2021-2024 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
@ -8,7 +8,7 @@
{.push raises: [].} {.push raises: [].}
import import
stew/shims/net, std/net,
eth/[common, keys, rlp, trie, trie/db], eth/[common, keys, rlp, trie, trie/db],
eth/p2p/discoveryv5/[enr, node, routing_table], eth/p2p/discoveryv5/[enr, node, routing_table],
eth/p2p/discoveryv5/protocol as discv5_protocol, eth/p2p/discoveryv5/protocol as discv5_protocol,

View File

@ -9,7 +9,7 @@
import import
std/[algorithm, sequtils], std/[algorithm, sequtils],
chronos, testutils/unittests, stew/shims/net, chronos, testutils/unittests,
stew/results, stew/results,
eth/keys, eth/p2p/discoveryv5/routing_table, nimcrypto/[hash, sha2], eth/keys, eth/p2p/discoveryv5/routing_table, nimcrypto/[hash, sha2],
eth/p2p/discoveryv5/protocol as discv5_protocol, eth/p2p/discoveryv5/protocol as discv5_protocol,

View File

@ -314,7 +314,7 @@ proc asPortalBlockData*(
proc getBlockReceipts( proc getBlockReceipts(
client: RpcClient, transactions: seq[TypedTransaction], blockHash: Hash256): client: RpcClient, transactions: seq[TypedTransaction], blockHash: Hash256):
Future[Result[seq[Receipt], string]] {.async.} = Future[Result[seq[Receipt], string]] {.async: (raises: [CancelledError]).} =
## Note: This makes use of `eth_getBlockReceipts` JSON-RPC endpoint which is ## Note: This makes use of `eth_getBlockReceipts` JSON-RPC endpoint which is
## only supported by Alchemy. ## only supported by Alchemy.
var receipts: seq[Receipt] var receipts: seq[Receipt]
@ -324,11 +324,8 @@ proc getBlockReceipts(
try: try:
await client.eth_getBlockReceipts(w3Hash blockHash) await client.eth_getBlockReceipts(w3Hash blockHash)
except CatchableError as e: except CatchableError as e:
await client.close()
return err("JSON-RPC eth_getBlockReceipts failed: " & e.msg) return err("JSON-RPC eth_getBlockReceipts failed: " & e.msg)
await client.close()
for receiptObject in receiptObjects: for receiptObject in receiptObjects:
let receipt = asReceipt(receiptObject).valueOr: let receipt = asReceipt(receiptObject).valueOr:
return err(error) return err(error)
@ -426,7 +423,7 @@ proc run(config: BeaconBridgeConf) {.raises: [CatchableError].} =
Opt.some(client) Opt.some(client)
optimisticHandler = proc(signedBlock: ForkedMsgTrustedSignedBeaconBlock): optimisticHandler = proc(signedBlock: ForkedMsgTrustedSignedBeaconBlock):
Future[void] {.async.} = Future[void] {.async: (raises: [CancelledError]).} =
# TODO: Should not be gossiping optimistic blocks, but instead store them # TODO: Should not be gossiping optimistic blocks, but instead store them
# in a cache and only gossip them after they are confirmed due to an LC # in a cache and only gossip them after they are confirmed due to an LC
# finalized header. # finalized header.
@ -459,8 +456,11 @@ proc run(config: BeaconBridgeConf) {.raises: [CatchableError].} =
contentKey = encodedContentKey.toHex() contentKey = encodedContentKey.toHex()
except CatchableError as e: except CatchableError as e:
error "JSON-RPC error", error = $e.msg error "JSON-RPC error", error = $e.msg
# TODO: clean-up when json-rpc gets async raises annotations
await portalRpcClient.close() try:
await portalRpcClient.close()
except CatchableError:
discard
# For bodies to get verified, the header needs to be available on # For bodies to get verified, the header needs to be available on
# the network. Wait a little to get the headers propagated through # the network. Wait a little to get the headers propagated through
@ -480,17 +480,32 @@ proc run(config: BeaconBridgeConf) {.raises: [CatchableError].} =
except CatchableError as e: except CatchableError as e:
error "JSON-RPC error", error = $e.msg error "JSON-RPC error", error = $e.msg
await portalRpcClient.close() # TODO: clean-up when json-rpc gets async raises annotations
try:
await portalRpcClient.close()
except CatchableError:
discard
if web3Client.isSome(): if web3Client.isSome():
let client = web3Client.get()
# get receipts # get receipts
let receipts = let receipts =
(await web3Client.get().getBlockReceipts( (await client.getBlockReceipts(
executionPayload.transactions, hash)).valueOr: executionPayload.transactions, hash)).valueOr:
# (await web3Client.get().getBlockReceipts( # (await web3Client.get().getBlockReceipts(
# executionPayload.transactions)).valueOr: # executionPayload.transactions)).valueOr:
error "Error getting block receipts", error error "Error getting block receipts", error
# TODO: clean-up when json-rpc gets async raises annotations
try:
await client.close()
except CatchableError:
discard
return return
# TODO: clean-up when json-rpc gets async raises annotations
try:
await client.close()
except CatchableError:
discard
let portalReceipts = PortalReceipts.fromReceipts(receipts) let portalReceipts = PortalReceipts.fromReceipts(receipts)
if validateReceipts(portalReceipts, payload.receiptsRoot).isErr(): if validateReceipts(portalReceipts, payload.receiptsRoot).isErr():
@ -511,7 +526,11 @@ proc run(config: BeaconBridgeConf) {.raises: [CatchableError].} =
except CatchableError as e: except CatchableError as e:
error "JSON-RPC error for portal_historyGossip", error = $e.msg error "JSON-RPC error for portal_historyGossip", error = $e.msg
await portalRpcClient.close() # TODO: clean-up when json-rpc gets async raises annotations
try:
await portalRpcClient.close()
except CatchableError:
discard
return return

View File

@ -7,11 +7,10 @@
{.push raises: [].} {.push raises: [].}
import import
std/[hashes, tables], std/[hashes, tables, net],
chronos, chronicles, confutils, chronos, chronicles, confutils,
confutils/std/net as confNet, confutils/std/net as confNet,
stew/[byteutils, endians2], stew/[byteutils, endians2],
stew/shims/net,
json_rpc/servers/httpserver, json_rpc/servers/httpserver,
eth/p2p/discoveryv5/protocol, eth/p2p/discoveryv5/protocol,
eth/p2p/discoveryv5/enr, eth/p2p/discoveryv5/enr,

View File

@ -1,5 +1,5 @@
# Nimbus # Nimbus
# Copyright (c) 2021 Status Research & Development GmbH # Copyright (c) 2021-2024 Status Research & Development GmbH
# Licensed under either of # Licensed under either of
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE)) # * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
# * MIT license ([LICENSE-MIT](LICENSE-MIT)) # * MIT license ([LICENSE-MIT](LICENSE-MIT))
@ -8,9 +8,8 @@
# those terms. # those terms.
import import
std/[os], std/[os, net],
eth/p2p as ethp2p, eth/p2p as ethp2p,
stew/shims/net as stewNet,
stew/results, stew/results,
chronos, json_rpc/[rpcserver, rpcclient], chronos, json_rpc/[rpcserver, rpcclient],
../../../nimbus/sync/protocol, ../../../nimbus/sync/protocol,

View File

@ -1,3 +1,10 @@
# nimbus
# Copyright (c) 2018-2024 Status Research & Development GmbH
# Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
mode = ScriptMode.Verbose mode = ScriptMode.Verbose
packageName = "nimbus" packageName = "nimbus"
@ -83,10 +90,10 @@ task fluffy_test, "Run fluffy tests":
test "fluffy/tests", "all_fluffy_tests", "-d:chronicles_log_level=ERROR -d:nimbus_db_backend=sqlite -d:mergeBlockNumber:38130" test "fluffy/tests", "all_fluffy_tests", "-d:chronicles_log_level=ERROR -d:nimbus_db_backend=sqlite -d:mergeBlockNumber:38130"
task utp_test_app, "Build uTP test app": task utp_test_app, "Build uTP test app":
buildBinary "utp_test_app", "fluffy/tools/utp_testing/", "-d:chronicles_log_level=TRACE -d:chronosStrictException" buildBinary "utp_test_app", "fluffy/tools/utp_testing/", "-d:chronicles_log_level=TRACE"
task utp_test, "Run uTP integration tests": task utp_test, "Run uTP integration tests":
test "fluffy/tools/utp_testing", "utp_test", "-d:chronicles_log_level=ERROR -d:chronosStrictException" test "fluffy/tools/utp_testing", "utp_test", "-d:chronicles_log_level=ERROR"
task test_portal_testnet, "Build test_portal_testnet": task test_portal_testnet, "Build test_portal_testnet":
buildBinary "test_portal_testnet", "fluffy/scripts/", "-d:chronicles_log_level=DEBUG -d:unittest2DisableParamFiltering" buildBinary "test_portal_testnet", "fluffy/scripts/", "-d:chronicles_log_level=DEBUG -d:unittest2DisableParamFiltering"

View File

@ -1,4 +1,4 @@
# Copyright (c) 2018-2023 Status Research & Development GmbH # Copyright (c) 2018-2024 Status Research & Development GmbH
# Licensed under either of # Licensed under either of
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE)) # * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
# * MIT license ([LICENSE-MIT](LICENSE-MIT)) # * MIT license ([LICENSE-MIT](LICENSE-MIT))
@ -14,7 +14,8 @@ import
strutils, strutils,
times, times,
os, os,
uri uri,
net
], ],
pkg/[ pkg/[
chronicles, chronicles,
@ -23,14 +24,13 @@ import
stew/byteutils, stew/byteutils,
confutils/std/net confutils/std/net
], ],
stew/shims/net as stewNet,
eth/[common, net/nat, p2p/bootnodes, p2p/enode, p2p/discoveryv5/enr], eth/[common, net/nat, p2p/bootnodes, p2p/enode, p2p/discoveryv5/enr],
"."/[db/select_backend, "."/[db/select_backend,
constants, vm_compile_info, version constants, vm_compile_info, version
], ],
common/chain_config common/chain_config
export stewNet export net
const const
# TODO: fix this agent-string format to match other # TODO: fix this agent-string format to match other

View File

@ -11,7 +11,6 @@ import
std/[strutils], std/[strutils],
stew/[results, byteutils], stint, stew/[results, byteutils], stint,
eth/common/eth_types_rlp, chronos, eth/common/eth_types_rlp, chronos,
stew/shims/net,
graphql, graphql/graphql as context, graphql, graphql/graphql as context,
graphql/common/types, graphql/httpserver, graphql/common/types, graphql/httpserver,
graphql/instruments/query_complexity, graphql/instruments/query_complexity,

View File

@ -19,7 +19,6 @@ import
json_rpc/rpcserver, json_rpc/rpcserver,
metrics, metrics,
metrics/[chronos_httpserver, chronicles_support], metrics/[chronos_httpserver, chronicles_support],
stew/shims/net as stewNet,
websock/websock as ws, websock/websock as ws,
kzg4844/kzg_ex as kzg, kzg4844/kzg_ex as kzg,
./core/eip4844, ./core/eip4844,

View File

@ -1,3 +1,10 @@
# nimbus_verified_proxy
# Copyright (c) 2022-2024 Status Research & Development GmbH
# Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
-d:"chronicles_runtime_filtering=on" -d:"chronicles_runtime_filtering=on"
-d:"chronicles_disable_thread_id" -d:"chronicles_disable_thread_id"
@ -5,7 +12,6 @@
-d:"chronicles_line_numbers:0" -d:"chronicles_line_numbers:0"
@end @end
-d:chronosStrictException
-d:PREFER_BLST_SHA256=false -d:PREFER_BLST_SHA256=false
# Use only `secp256k1` public key cryptography as an identity in LibP2P. # Use only `secp256k1` public key cryptography as an identity in LibP2P.

View File

@ -104,7 +104,7 @@ proc run(config: VerifiedProxyConf) {.raises: [CatchableError].} =
verifiedProxy = VerifiedRpcProxy.new(rpcProxy, blockCache, chainId) verifiedProxy = VerifiedRpcProxy.new(rpcProxy, blockCache, chainId)
optimisticHandler = proc(signedBlock: ForkedMsgTrustedSignedBeaconBlock): optimisticHandler = proc(signedBlock: ForkedMsgTrustedSignedBeaconBlock):
Future[void] {.async.} = Future[void] {.async: (raises: [CancelledError]).} =
notice "New LC optimistic block", notice "New LC optimistic block",
opt = signedBlock.toBlockId(), opt = signedBlock.toBlockId(),
wallSlot = getBeaconTime().slotOrZero wallSlot = getBeaconTime().slotOrZero

2
vendor/nim-chronos vendored

@ -1 +1 @@
Subproject commit 3ca2c5e6b510c15ce88c94ed25731b30f7ad46b5 Subproject commit 09a0b117194ed41ee6cebf628404698006d238b4

2
vendor/nim-eth vendored

@ -1 +1 @@
Subproject commit 2c6049b1266a7739f4dca86da4e8c65b75797195 Subproject commit 21f3014f548618919007910c4aacd47ce2373a46

2
vendor/nim-libp2p vendored

@ -1 +1 @@
Subproject commit e3c967ad1939fb33b8e13759037d193734acd202 Subproject commit 2725be64bacb46997c0959560d833ff946c8cb3b

2
vendor/nim-stew vendored

@ -1 +1 @@
Subproject commit 2c2544aec13536304438be045bfdd22452741466 Subproject commit 3aa92ab843ee2dbf2198e2d517ceeeb29dcda3d9

2
vendor/nimbus-eth2 vendored

@ -1 +1 @@
Subproject commit 5404178a4004c4bc13c75853a02b1a74f2ca302c Subproject commit d3e10cc7c6ea002b6918e1cd7cdb8db6ac25489f