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

Fees for substrate #375

Merged
merged 39 commits into from
May 12, 2023
Merged

Fees for substrate #375

merged 39 commits into from
May 12, 2023

Conversation

Nutomic
Copy link
Contributor

@Nutomic Nutomic commented Mar 21, 2023

Summary of changes

  • Add fee and refund logic for substrate
  • Update test instructions to include tangle setup
  • Update fee endpoints
  • Update test case should withdraw using private transaction to use fee and refund

Note

We have updated the fee endpoint to support requests for substrate and evm based chains, following are the new points

  • EVM:
  /api/v1/fee_info/evm/:chain_id/:vanchor/:gas_amount
  • Substrate
 /api/v1/fee_info/substrate/:chain_id/:partialFee

Reference issue to close (if applicable)


Code Checklist

  • Tested
  • Documented

@salman01zp salman01zp changed the base branch from main to develop March 21, 2023 15:53
@Nutomic Nutomic changed the title Felix/substrate fees Fees for substrate Mar 24, 2023
@Nutomic Nutomic force-pushed the felix/substrate-fees branch from 46fc954 to a7fa47e Compare March 24, 2023 11:56
@shekohex shekohex added p1 🟠 Issue should be resolved sooner than later feature ➕ Tasks that are functional additions or enhancements task ✔️ difficulty: medium 🚩 substrate labels Mar 24, 2023
@shekohex shekohex linked an issue Mar 27, 2023 that may be closed by this pull request
4 tasks
@shekohex
Copy link
Collaborator

any status update on this? what it the blocker(s) or issue that is stopping this PR from progressing?

@Nutomic
Copy link
Contributor Author

Nutomic commented Apr 14, 2023

Currently waiting for this PR to make webb.js dependencies work with Node 18.

tangle-network/webb.js#311

@Nutomic Nutomic force-pushed the felix/substrate-fees branch from cc25bfc to 39b4d11 Compare April 17, 2023 13:48
@Nutomic
Copy link
Contributor Author

Nutomic commented May 8, 2023

I pushed the changes made with @shekohex to fix fee calculation. Now its still failing with the error Error: the string "Error while watching Tx: Runtime error: Module(ModuleError { pallet: \"VAnchorBn254\", error: \"InvalidExtData\", description: [], error_data: ModuleErrorData { pallet_index: 41, error: [6, 0, 0, 0] } })" was thrown, throw an Error :). Most likely the problem is somewhere in vanchorWithdraw() inside vanchorPrivateTransaction.test.ts. That file had some hardcoded values before which I had to replace, and most likely there is something wrong.

@drewstone
Copy link
Contributor

What's the status of this @Nutomic ?

@Nutomic
Copy link
Contributor Author

Nutomic commented May 10, 2023

I cleaned up the Rust code now, adding error handling, fixing todos and making clippy pass. So only thing left is fixing the tests.

@salman01zp salman01zp marked this pull request as ready for review May 12, 2023 07:57
@salman01zp salman01zp self-requested a review as a code owner May 12, 2023 07:57
Copy link
Collaborator

@shekohex shekohex left a comment

Choose a reason for hiding this comment

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

Looks good! just few things needs that needs more clean-ups

crates/tx-relay/src/evm/vanchor.rs Show resolved Hide resolved
services/webb-relayer/src/service/evm.rs Show resolved Hide resolved
@salman01zp salman01zp requested a review from shekohex May 12, 2023 09:53
Copy link
Collaborator

@shekohex shekohex left a comment

Choose a reason for hiding this comment

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

Awesome work everyone, LGTM!

crates/tx-relay/src/evm/fees.rs Show resolved Hide resolved
@shekohex shekohex merged commit e939c7b into develop May 12, 2023
@shekohex shekohex deleted the felix/substrate-fees branch May 12, 2023 11:03
shekohex added a commit that referenced this pull request Jun 8, 2023
* Fast sync and merkle root validation (#354)

Co-authored-by: shekohex <[email protected]>

* Update the CI to run on develop too (#362)

* Get the Eth2 Substrate hooked in to the relayer (#335)

Co-authored-by: Drew Stone <[email protected]>

* relayer transfer test (#365)

* relayer transfer test

* fix test

* use relayer for transfering assets

* add comments

* Update Relayer configration docs and Examples (#369)

Co-authored-by: Dustin Brickwood <[email protected]>
Co-authored-by: salman01zp <[email protected]>

* Substrate governor update  (#371)

* send nonce+dkg_key

* governor update test

* update packages and tests

* downgrade nightly

* fix tests

* use typed chainId as Bridge key

* skip transfer test for now

* yarn format

---------

Co-authored-by: shekohex <[email protected]>

* Bridge Registry pallet integration (#355)

Co-authored-by: shekohex <[email protected]>
Co-authored-by: drewstone <[email protected]>
Co-authored-by: Salman Pathan <[email protected]>

* fix dkd node connection (#378)

* Add etherscan api configuration (#372)

* Change how DKG client for bridge registry is initialized (#379)

* Update webb-rs (#400)

* Refactor service.rs into smaller modules (#405)

* Refactor service.rs into smaller modules

* make substrate related crates feature flagged

* Update the imports

* Split the services by the system

* Update Cargo.lock

* Add `assets` to the Relayer config (#407)

* delete unused file

* Add assets section to the config

* Update configration in tests

* Update example config with docs

* Make use of assets in the config when the token is not found on price oracle

* Update the return of the status code for errors

* Update docs

* Hardcode the secrit phrase

* Rename Fields with serde while serialization to be `camelCase` (#409)

* Rename Fields with serde while serialization to be `camelCase`

* more fields to change

* Update `chain-id` to `chainId`

* Update `chain-id` and `tree-id`

* rename `resource-id`

* create defaults module

* better using of serde `rename_all`feature

* be more consistent with the signing backend.

* Update docs and simple config files to reflect the new changes

* fix the code with the new changes

* [feat] Introduce Price Oracle Backends (#411)

Co-authored-by: drewstone <[email protected]>

* Add more clippy checks to avoid potential runtime crashes (#408)

* Get rid of unwrap usage

* Add more clippy checks

* add ReadSubstrateStorageError

* fixes

* review changes

* feat: Improve the `GasOracle` usage (#414)

* Handle webb tokens (#415)

* support webbAlpha

* use VAnchor contract

* handle webbtTNT-standalone

* trigger actions

* Add webbStandalone

* [feat] Add Webb Chains Info crate (#416)

* delete unused mod.rs file

* Add Webb Chains Info crate

* make use of the new package

* fix the chain id for mumbai

* abstract away coingecko specific ids

this hides the complexity of coingecko's coins ids away from
the original trait, now we can map them directly internally in the
backend implementation.

* make clippy happy

* support more chains

* update wrapped token names

* [chore] Create CODEOWNERS (#446)

Adds [Codeowners](https://docs.github.com/en/repositories/managing-your-repositorys-settings-and-features/customizing-your-repository/about-code-owners) file

* Fix asset transfer test (#445)

* fix asset transfer test

* trigger actions

* Use bridge registry for substrate chains (#447)

* use bridge registry for substrate

* cargo.lock file

* Attempt to speedup CI steps (ref #449) (#454)

* Bridge registry integration tests (#457)

* birdge registry test

* revert test timeout

* update test

* update doc

* Prometheus/Grafana setup (#413)

* Basic Prometheus/Grafana setup

* fix metrics endpoint

* Add full setup instructions

* docker volume, improved instructions

* Create basic Grafana dashboard with all available metrics (#463)

* Use provisioning to setup Grafana dashboard and alerts (#466)

* Add Webb Orbit Chains to the Supported Chains (#469)

* fix: `u64` overflow when updating relayer metrics (#471)

* Use transaction queue for DKG/Substrate (fixes #450) (#461)

* Use transaction queue for DKG/Substrate (fixes #450)

* dont need chain id param

* address review comments

* add proof-generation crate for masp integration (#467)

* add proof-generation crate for the masp

* add negative test case for batch-tree updating. It is (incorrectly) able to generate a proof with invalid inputs, but proof doesnt verify

* removing prints

* clippy

* clippy

* add cargo.lock

* updade proof-delegation to receive new transaction parameters

* ignore test during CI (since it doesnt download fixtures)

* update dvc file for solidity-fixtures

* up protocol-solidity version

* update lockfile

* revert vanchor fixture

* Update crates/circom-proving package name

Co-authored-by: shekohex <[email protected]>

* change circom-proving to webb-circom-proving

* fmt

* clippy

* re fmt

* add cargo.lock

* downgrade protocol-solidity verifier contracts

* add lockfile...

---------

Co-authored-by: drewstone <[email protected]>
Co-authored-by: shekohex <[email protected]>

* Rework resource metrics (#472

* Rework resource metrics (ref #387)

* Use Display trait for ResourceId

* split resource metric labels into separate values

* rework chain balance metrics

* fix clippy

* update dashboard

* fix overflow

* consistently use gwei for certain metrics fields

* Remove dynamic tx from relayer (#477)

* fix: DKG Signing Backend

* remove dynamic txs

* remove dynamic payload type

---------

Co-authored-by: Shady Khalifa <[email protected]>

* Grafana alerts provisioning (#479)

Co-authored-by: Salman Pathan <[email protected]>

* Run CI integration tests in parallel (#458)

* Run CI integration tests in parallel

* remove cargo build step

* fix test filter

* skip mixer tests

* disable `fail-fast`

---------

Co-authored-by: Salman Pathan <[email protected]>
Co-authored-by: drewstone <[email protected]>
Co-authored-by: shekohex <[email protected]>

* Try using shared key for rust cache to speedup CI (#483)

* Try using shared key for rust cache to speedup CI

* try cache linux check

* cache dvc, linux unit tests

* fix dvc cache path

* dont cache cargo cross builds

* Changes to CI conditions, push new commits on develop to `edge` tag (#480)

* Dont run checks on main/dev branch

* Push edge image from develop branch

* Fix name of docker edge tag (#487)

* fix and detect Leaf Cache flaky tests on EVM (#485)

* use hex values while printing the leaves in the logs

* update the types for the leaf cache response

* compare strings instead of bytes to reproduce the bug

* optmize the CI even more

* make the test retries 3 times just in case

* make the test predectable

* improve the lints and use the cache

* optmize the ci

* optmize the ci and update names

* fixing group names

* make group unique

* run integration tests on gnu linux instead of musl

* add cache to linux unit testings

* Update relayer to node v18 (#465)Co-authored-by: shekohex <[email protected]>

* update to node v18

* update nvmrc

* update dkg-types

* update webb.js

* fix yarn.lock and update solidity packages

* update solidity packages

* update governor type change

---------

Co-authored-by: shekohex <[email protected]>

* Merge relayer and grafana docker, add setup documentation (#486)

* Merge relayer and grafana docker, add setup documentation

* mention cronjob, remove old readme

---------

Co-authored-by: shekohex <[email protected]>
Co-authored-by: drewstone <[email protected]>

* Use tangle runtime metadata (#462)

* use tangle runtime

* update configs

* localTangle

* update tests

* use local chainspec for tangle

* update tangle node and pallet idx

* tangle docker image for integration tests

* Merge remote-tracking branch 'origin/develop' into salman/tangle-runtime-metadata

* use tangle-substrate-types

* update docker image

* update images

* update tests

* update test

* remove .only

* fix evm-substrate cross chain test

---------

Co-authored-by: shekohex <[email protected]>
Co-authored-by: drewstone <[email protected]>

* Setup Development env using Nix and Flakes (#492)

* fix: Add RetryClient to the EVM Providers

* bugfix: Custom Retry Policy for EVM providers (#497)

* bugfix: building MerkleTree history (#500)

* Update The logic for Merkle Tree building

* add dvc

* Update Example to use WebbAlpha contract address

* Use of the `chain_id` when possible instead of refetching it

* Make the default `max_blocks_per_step` is 500 blocks/step

* Correctly build the merkle tree in the leaves handler

* Remove the unused imports

* Cache the EVM Providers instead of creating ones every single time

* Change the way we return the cached leaves

* Update the error handling

* Update the leaves endpoint

* Make use of the correct ChainId type, instead of strings (for EVM)

* Do not fetch the chainId nor the latest block number when not needed

* Update the service file with the new changes

* Optmize the way we fetch events. (see details)

The way the old way was implemented is that at each iteration we used to
fetch the last block number, calculate the destination block number and
then fetch the events. And as long as we did not reach the latest block
(which is the case most of the time) we would repeat the process without
a cooldown. This was a waste of resources.

The new implementation is that we fetch the last block number and never
update it, untill we fully catch up with the latest block. This way we
can fetch the events in a fewer calls, without even cooling down, until
we reach the latest block. That's when we know we are fully synced and
until then we only update the latest block.

From now on, fetching the latest block should not be in a hot loop.
as we only fetch it after `polling interval` milliseconds.

* Use gmp if we are running tangle/dkg locally

* Formmating

* Update the tests with the new changes

* Make use of RustCache in CI

* Run `cargo fmt`

* Add a way to save the target block number

* Make use of the `target_block_number` feature

* Runs `cargo fmt`

* Ignore the .env file in the root of the repo

* clear the logs when not needed

* Fees for substrate (#375)

Co-authored-by: shekohex <[email protected]>
Co-authored-by: Salman Pathan <[email protected]>
Co-authored-by: drewstone <[email protected]>

* add avalanche fuji testnet to supported chains (#505)

* Fix and make DKG tests pass CI (#511)

* dkg test on CI

* Update CI: build relayer before executing test

* update and fix dkg tests

* use docker host

* add signature bridge test

* use docker host

* update signature bridge test

* update metadata and fix test

* remove test timeout

* Fix partial writes (#517)

* Update relayer endpoints (#519)

* update relayer leaf caching and info endpoints

* update relayer leaf caching and info endpoint

* update doc

* Trigger actions

* update info response and doc

* update dev branch version

* update build info

* feat: Proposals Queue (#515)

* flake.lock: Update

Flake lock file updates:

• Updated input 'nixpkgs':
    'github:NixOS/nixpkgs/44f30edf5661d86fb3a95841c35127f3d0ea8b0f' (2023-05-02)
  → 'github:NixOS/nixpkgs/d4825e5e4ac1de7d5bb99381534fd0af3875a26d' (2023-05-16)
• Updated input 'rust-overlay':
    'github:oxalica/rust-overlay/d59c3fa0cba8336e115b376c2d9e91053aa59e56' (2023-05-03)
  → 'github:oxalica/rust-overlay/65c3f2655f52a81e1b3e629d4c07df4873d0f2bb' (2023-05-16)

* Base case testing

* Remove `ProposalsStore`

* Add more logging

* Add ProposalsQueue

* Move crate the workspace

* Added ProposalQueue with Polices

* Move `parking_lot` to the workspace

* Remove the Queue type from the PSB

* Simplify the Proposal Queue

* Working Nonce and Time delay Polices

* Working on fixing the current impl

* Working on fixing the current Nonce Policy Impl

* Ups

* updates that makes it working

* cargo fmt

* fix clippy

* Update CODEOWNERS

* remove unused test files

* feat(tests): add `SmartAnchorUpdatesConfig` to `LocalChain` configuration options

SUMMARY:
* Added a new configuration option smartAnchorUpdates to the ExportedConfigOptions type in localTestnet.ts file.
* Added the SmartAnchorUpdatesConfig interface in webbRelayer.ts file.

* add simulation

* fix failing test

* Trigger CI

* fix tests

---------

Co-authored-by: Salman Pathan <[email protected]>

* Handle substrate node disconnection (#522)

* create new client if connection drops

* remove logs

* remove unused dependency

* clippy fix

* remove unused deps

* Fix error handling (#523)

* fix: Move tx signing logic to the substrate transaction queue (#525)

* Add logging to the create proposal handler

* Make substrate chain id generic

* Move the signing logic to the tx queue

* Update the logging format

* Add Typed Erased Static Transaction Payload for Substrate

* cargo fmt

* Use `TypeErasedStaticTxPayload` for Signature Bridge Watcher

* fix substrate failing tests

* Add Timelag middleware and code cleanup (#527)

* Update Orbit Network chainIds (#532)

* Bundle Multiple EVM Providers (#531)

* bundle multiple providers in retry client

* update doc

* undo quorum changes

* multi provider client

* use multi provider client

* error handling and update readme doc

* update docs in config files and incorporate review feedback

* Prepare to Release stable version 0.5.0 (#533)

* Release 0.5.0

---------

Co-authored-by: Salman Pathan <[email protected]>
Co-authored-by: Thomas Braun <[email protected]>
Co-authored-by: Drew Stone <[email protected]>
Co-authored-by: Dustin Brickwood <[email protected]>
Co-authored-by: Nutomic <[email protected]>
Co-authored-by: Semar Augusto <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
difficulty: medium 🚩 feature ➕ Tasks that are functional additions or enhancements p1 🟠 Issue should be resolved sooner than later substrate task ✔️
Projects
None yet
4 participants