Svyatoslav Nikolsky
1b96e51679
Subscribe to justifications in Millau->Rialto headers sync ( #394 )
...
* maintain MillauHeadersToRialto sync by subscribing to Millau justifications
* more tracing in maintain
* Update relays/substrate/src/headers_maintain.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* Update relays/substrate/src/headers_maintain.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* -Please
* -TODO
* revert raise recursion limit
* updated comment
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
3738bc4277
Bump futures from 0.3.6 to 0.3.7 ( #456 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
c42023269a
Bump env_logger from 0.7.1 to 0.8.1 ( #424 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
31c90f1cae
Bump serde_json from 1.0.58 to 1.0.59 ( #426 )
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
7a03b709be
Millau -> Rialto headers relay ( #398 )
...
* working-millau-to-rialto-relay
* fix Millau state root
* properly fix synced+incomplete headers for sub2sub
* removed wrong TODO
* fmt + clippy
* Update relays/headers-relay/src/headers.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* moved SubstrateTransactionMaker definition
* removed M from phantomdata
* removed prune_synced_children
* methods names as consts
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
55d22a0d1e
connect to substrate using ws ( #417 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
488162209b
Bump futures from 0.3.5 to 0.3.6 ( #413 )
2024-04-10 10:28:37 +02:00
Hernando Castano
f52c839d6e
Add GenesisConfig for Millau and Rialto Runtimes ( #401 )
...
* Add Rialto as a target for the Millau node
* Rename Rialto module to Rialto-PoA
This will reduce confusion as the Millau runtime has a
Rialto module as well which refers to the Substrate chain.
* Add Millau as a target for the Rialto node
* Be more explicit about Rialto PoA related code
* Missed some name changes in the Ethereum PoA relay
* Re-export Substrate pallet structs used by node
* Remove `first_scheduled_change` of Millau in Rialto node
* Make Millau's genesis config for Rialto bridge more accurate
* Set initial header for Millau config
* Update initial Millau authorities
Co-authored-by: Svyatoslav Nikolsky <svyatonik@gmail.com >
* RustFmt Millau authorities
Co-authored-by: Svyatoslav Nikolsky <svyatonik@gmail.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
9e9ac8df3c
Move Chain trait to runtime primitives ( #403 )
...
* extract ChainBase to bp-runtime
* post-merge fixes
* cargo fmt --all
* compilation fixes
* reexport BlockNumberOf, HashOf, HeaderOf
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
ddeb59d336
Prometheus options in Substrate relay ( #402 )
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
cfe1e43473
Message lane loop metrics ( #400 )
...
* message lane metrics
* fmt and clippy
2024-04-10 10:28:37 +02:00
Hernando Castano
8b8248f83f
Split Rialto and Millau Nodes ( #372 )
...
* Split the Rialto Node into a standalone crate
* Split the Millau Node into a standalone crate
* Remove `bridge-node` crate
* Add benchmarking feature to nodes
* Check that benchmarks compile in CI
* Remove nodes from CI matrix
* Update Rialto node to Substrate 2.0
* Get Millau node compiling with Substrate 2.0
* Remove extra license text
* Remove comments in TOML files
* Move nodes and runtimes into Rialto and Millau folders
* Fix dependency paths
* Remove unused script
* Add issue to benchmarking TODO
* Fix benchmark manifest paths
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
52b11a58c9
extract common relay initialization func ( #392 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
fe2d786f13
Bump serde_json from 1.0.57 to 1.0.58 ( #396 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
87ea31a439
Bump async-trait from 0.1.40 to 0.1.41 ( #395 )
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
1a35afc3dc
Support non-positional params ( #393 )
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
07a514e9f7
Get substrate dependencies from crates io ( #387 )
...
* get Substrate dependencies from crates.io
* removing unused dependencies
* cargo fmt --all
* remove commented dependencies
* remove commented dependencies again
* try to fix compilation
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
f43e405b5e
update async-std ( #388 )
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
dbb72faa86
Substrate relay stub ( #376 )
...
* substrate-relay: initial commit
* MillauHeaderApi and RialtoHeaderApi
* post-merge fixes + TODOs + compilation
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
52c1913fff
Extract minimal Rialto-Sub and Millau-Sub clients ( #365 )
...
* extracting sub clients
* fmt + lost docs
* revert enum BridgeInstance
* apply suggestions from review
* explicite debug impl
* remove unused imports from Millau
* fix typo
* fix instance + API name
* Update relays/ethereum/src/ethereum_sync_loop.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* separate crates for millau and rialto client
* cargo fmt
* fix
* fmt
* remove no_std support
* fix compilation again
* Update relays/substrate-client/Cargo.toml
* Update relay clients to Substrate 2.0
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
Co-authored-by: Hernando Castano <castano.ha@gmail.com >
2024-04-10 10:28:37 +02:00
Tomasz Drwięga
be050bda84
Bump Substrate to v2.0.0 ( #382 )
...
* Change script to update versions.
* Bump versions.
* Address remainders.
* cargo fmt --all
* Fix tests.
* Whitelist BlueOak license
* Fix benchmarks?
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
3cd8937b38
Fees, weights, message delivery and dispatch ( #339 )
...
* introduce BridgedHeaderChain trait
* LaneMessageVerifier + tests
* fixed tests
* do not expose intenal functions
* cargo fmt --all + fix no_std compilation
* ByWeightDispatcher
* process queued messages from message-lane::on_initialize
* scheduled_messages_are_processed_from_on_initialize
* flush
* deal with fees + weights
* drop heavy messages on dispatch
* cargo fmt
* clippy
* fix comment
* Update primitives/message-lane/src/source_chain.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
* removed messages_processed
* Update primitives/message-lane/src/source_chain.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* Update modules/message-lane/src/lib.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* remove queueing from message-lane
* also remove queueing from RPCs
* remove by-weight traces
* dispatch fee
* receiving -> delivery
* receival -> delivery
* remove extra line
* Update primitives/message-lane/src/source_chain.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* cargo fmt --all
* clippy
* let dispatch_weight to be larger than actual_dispatch_weight
* post-merge fix
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
ec34870eab
Extract minimal ethereum client ( #359 )
...
* relay-ethereum-client
* use relay-ethereum-client from ethereum-poa-relay
* cargo fmt --all
* #![warn(missing_docs)]
* EthereumRpcClient -> EthereumClient
* make EthereumHeadersSyncPipeline private
* return concrete type from crate::new
* cleanup dependencies
* *self -> self
* remove trait Client
* sort deps
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
d614cdaba8
Extract (headers, exchange, messages) relay loops into separate crates ( #357 )
...
* extracted relay crates
* moved metrics to utils
* exchange-relay compilation
* fix compilation of headers-relay
* fixed messages-relay compilation
* fixed ethereum-poa-relay compilation
* cargo lock
* cargo fmt --all
* clippy
* cargo fmt --all
* fix tests compilation
* clippy
* eof
* module level docs
* removed obsolete comment
* #![warn(missing_docs)]
* .0 -> Deref
* post-merge fix
* cargo fmt
* Update relays/headers-relay/src/headers.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* Update relays/headers-relay/src/headers.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* Update relays/headers-relay/src/lib.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
2ae886506d
Relay receiving + processing confirmations ( #351 )
...
* relay receiving + processing confirmations
* fmt && clippy
* removed message processing race
* remove more traces
* generic args names
2024-04-10 10:28:37 +02:00
Hernando Castano
5163f62df4
Rename Ethereum Headers to AuraHeader ( #354 )
...
* Rename Header to AuraHeader
This prevents some type conflicts with the PolkadotJS Apps types.
* Fix test and benchmark builds
* Update AuraHeader in types.json
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
d8ae786792
Prepare separate runtime for testing sub2sub bridge ( #341 )
...
* renamed bin/node/runtime to bin/node/rialto-runtime
* replaced bridge-node-runtime references with rialto-runtime references
* separate folders for millau/rialto nodes+runtimes
* extracted pallet-shift-session-manager
* bridge-node -> bridge-node-runtime
* uninstall previous rust (temp solution???)
* fix dockerfile
* cargo fmt
* fix benchmarks check
* fix benchmarks again
* update LAST_RUST_UPDATE to clear the cache
* changed runtime comments
* move bin/node/* to bin/
* REVERT ME
* Revert "REVERT ME"
This reverts commit 7c335f946308ed11d9ed6ffec7c1c13dbe2743ed.
* specify container name
* REVERT ME
* container_name -> hostname
* fix typo
* aliases
* Revert "REVERT ME"
This reverts commit 0e74af5f8430f1975a3fc924d8b52079f266bda1.
* removed prefixes
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
bed44dec13
Relay DummyOrdered messages ( #318 )
...
* DummyOrdered relay: initial commit
* 1 ML file -> 3 files
* extracted generic message race loop
* uncommented race error procesing
* lane loop tests
* cargo fmt
* moved HeaderId to utils.rs
* restart lane loop on stall
* message delivery strategy tests
* removed obsolete code
* clippy
* Update relays/ethereum/src/message_lane_loop.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
* Update relays/ethereum/src/message_lane_loop.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
* added more races docs
* Update relays/ethereum/src/message_race_delivery.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
* update docs
* Update relays/ethereum/src/message_race_loop.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
* deal with TODOs
* removed docs
* docs
* cargo fmt --all
* Update relays/ethereum/src/message_race_loop.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
112e60439a
Bump async-trait from 0.1.38 to 0.1.40 ( #329 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
933a8e9252
Bump async-trait from 0.1.37 to 0.1.38 ( #306 )
...
Bumps [async-trait](https://github.com/dtolnay/async-trait ) from 0.1.37 to 0.1.38.
- [Release notes](https://github.com/dtolnay/async-trait/releases )
- [Commits](https://github.com/dtolnay/async-trait/compare/0.1.37...0.1.38 )
Signed-off-by: dependabot-preview[bot] <support@dependabot.com >
Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com>
Co-authored-by: Svyatoslav Nikolsky <svyatonik@gmail.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
b7cb0623d4
Update substrate reference to rc6 ( #321 )
...
* update substrate to rc6
* clippy
* fixed benchmarks compilation
* Update bin/node/node/src/service.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
aa90d16832
Fix (workaround) for "cannot read property 'toFixed' of null" ( #297 )
...
* fix (workaround) for NaN CPU usage
* cargo fmt --all
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
1823923a79
Remove errors from log ( #294 )
...
* changed log level from error to trace
* incomplete during submit != synced
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
b2c3238501
MAX_SUBMITTED_HEADERS = 4 ( #293 )
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
a0555d8118
Parse all deploy contract arguments ( #289 )
...
* parse all deploy contract arguments
* cargo fmt --all
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
4ddb8b1e7a
Bump clap from 2.33.2 to 2.33.3 ( #284 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
0900573706
Bump async-trait from 0.1.36 to 0.1.37 ( #283 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
761882e06b
Bump clap from 2.33.1 to 2.33.2 ( #279 )
2024-04-10 10:28:37 +02:00
dependabot-preview[bot]
4545931e02
Bump async-stream from 0.2.1 to 0.3.0 ( #278 )
2024-04-10 10:28:37 +02:00
Hernando Castano
acb78b0595
Fix panic when no instance is passed to certain CLI options ( #275 )
2024-04-10 10:28:37 +02:00
Hernando Castano
9f6bd28384
Rename Primitive Crates ( #271 )
...
* Rename Ethereum PoA primitives crate
The "sp" prefix comes from Substrate primitives, since this crate originated
in that repo. However, it is not part of Substrate anymore and its name should
be updated to reflect that.
* Rename currency exchange primitives
* Rust Fmt
* Update import in benchmarking module
* Rust Fmt
* Split pub and no-pub
* Sort toml files.
Co-authored-by: Tomasz Drwięga <tomasz@parity.io >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
868814e4b6
Prepare for sub to eth relay - part2 ( #253 )
...
* fixed PoA contract deploy (granda_authorities call)
* pause if all submitted headers were rejected
* give funds to Bertha and Carlos
* max 1 active PoA transaction in headers sync :(
* display initial header id when deploying PoA contract
* cargo fmt + clipy
* update PoA contract to accept <= 4 Substrate headers at once
* pause submitting headers when contract rejects all new headers + we have active transactions
* fix compilation
* cargo fmt --all
* does_not_select_new_headers_to_submit_when_submit_is_paused
* updated bridge contract
* Update relays/ethereum/src/sync.rs
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
* WiP.
* Submit first incomplete header.
* Finish up test.
* cargo fmt --all
* Remove redundant clone.
* Address review comments.
* cargo fmt --all
* Fix clippy.
Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com >
Co-authored-by: Tomasz Drwięga <tomasz@parity.io >
2024-04-10 10:28:37 +02:00
Hernando Castano
7f8360d8ab
Support Pallet Instances in Relay ( #238 )
...
* Sketch out how to support different bridge pallet instances
* Create a common interface for using pallet instances
* Start introducing generic instance parameter
Attemps to make the compiler happy, but I'm having second thoughts about
this approach. Commiting now as a way to have a checkpoint, but I think
I'm going to need to re-consider my approach here.
Ideally I want a change which introduces minimal changes, but this seems
to be propagating around the codebase in ways I don't want.
* Use trait objects instead of generics
* Implement traits for Boxed trait objects
This is done in order to statisfy trait bounds by types
which use these new trait objects
* Remove Clone usage for sync parameters
* Remove implementation of Default for sync params
* Require that BridgeInstance implements Debug
* Ensure that BridgeInstance trait implements Send/Sync
* Add documentation related to instances
* Rust Fmt
* Remove needless format
* Make instance CLI option case insensitive
* Replace `with_*` constructors with `new`
* Clean up usage of instance structs
* Enforce a default instance in the CLI params
* Build sync params as we process input from CLI
* Remove case insensitivity from sub-tx-mode
I think this should happen, but maybe as part of a different PR
* Process default Eth contract deployment config in CLI
* Build EthereumExchangeParams in CLI
* Process EthereumExchangeSubmitParams params in CLI
2024-04-10 10:28:37 +02:00
Hernando Castano
6fd1651b21
Bump Substrate to RC5 ( #243 )
...
* Bump Substrate to rc5
* Bump async-std to v1.6.2
There was a bug in v.1.6.0 which kept us locked to v1.5 releases.
I think that's fixed now so I'm bumping this.
* Update bridge node runtime
* Update node service
* Update CLI
* Add SystemWeightInfo type to test runtimes
* Add RPC extension builder to service
* Directly return rpc_extensions_builder
* Allow complex types in service
This comes from Substrate, so I'd rather just keep the code as is
* Update benchmarking code for new CLI
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
80cc9e793e
Fix gas_used fields in receipts ( #261 )
...
* gas_used should be cumulative_gas_used!!!
* more runtime traces
* improve logs
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
b98b7d2e43
Prepare for sub to eth relay ( #248 )
...
* fixed PoA contract deploy (granda_authorities call)
* pause if all submitted headers were rejected
* give funds to Bertha and Carlos
* max 1 active PoA transaction in headers sync :(
* display initial header id when deploying PoA contract
* cargo fmt + clipy
* fix compilation
* Update relays/ethereum/src/sync_types.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
* Update relays/ethereum/src/utils.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
fddfbb5b1c
Submit exchange transactions to PoA node ( #229 )
...
* submit Eth exchange transactions
* submit ethereum in docker-compose
* submit Eth exchange transactions
* fix duplicate message
* fix relay script
* lost file
* cargo fmt --all
* cargo +nightly clippy
* Show sccache
* remove test-helpers remains
* what's going on with jsonrpsee + Cargo.lock?
* relay-eth-submit-exchange-tx -> poa-exchange-tx-generator
* Update relays/ethereum/src/main.rs
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
* configuring exchange-gen loop using env variables
* fixed signer account from dev chain to Arthur
* improve debug prints
* parse nonce from relay output
* --eth-nonce=
* fix compilation
* cargo fmt --all
* fix typo
* duplicate relay output to tty
* allow using from bash scripts tests
* fix: U256::parse() expects hex string :/
* cargo fmt --all
* BRIDGE_HASH: ${BRIDGE_HASH:-master}
* script comment
* generate exchange PoA transactions by Bertha
* Bertha address
Co-authored-by: Denis S. Soldatov aka General-Beck <general.beck@gmail.com >
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
Tomasz Drwięga
d3f6948050
Remove substrate relay. ( #244 )
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
8456d0d969
Exchange transactions relay dashboard ( #241 )
...
* update dashboards
* cargo fmt --all
* Update deployments/rialto/dashboard/prometheus/prometheus.yml
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com >
2024-04-10 10:28:37 +02:00
Svyatoslav Nikolsky
ae88e86d6d
fixed method name ( #239 )
2024-04-10 10:28:37 +02:00