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

feat(gear-programs): Erc20 relay program #116

Merged
merged 34 commits into from
Sep 29, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
67a13ce
initial
gshep Aug 29, 2024
f2ac6c0
implement proofs verification
gshep Aug 29, 2024
3653fd3
fmt & clippy
gshep Sep 2, 2024
a4851c9
implement event
gshep Sep 3, 2024
73c97df
move service to the standalone module
gshep Sep 3, 2024
475ace2
add FungibleTokenManage service
gshep Sep 4, 2024
f15f3f6
tokens mapping test
gshep Sep 9, 2024
f966f1d
sort headers of the proof
gshep Sep 9, 2024
d550ee1
Merge remote-tracking branch 'origin/main'
gshep Sep 12, 2024
57bc017
add support of calculating gas for reply
gshep Sep 16, 2024
66395d1
make address of the VFT gateway optional & related functions
gshep Sep 17, 2024
7baca2b
refactor FTManage
gshep Sep 18, 2024
2982b25
cargo clippy
gshep Sep 19, 2024
9548bc1
refactor test: use program binary from the crate
gshep Sep 19, 2024
049359e
Merge remote-tracking branch 'origin/main'
gshep Sep 25, 2024
b60f658
Merge remote-tracking branch 'origin/main'
gshep Sep 27, 2024
bc92da5
adjust to the new VftGateway interface
gshep Sep 27, 2024
08718c7
fix review remark: use workspace's version & edition
gshep Sep 27, 2024
a84fa94
fix review remark: sails deps
gshep Sep 27, 2024
b0e9216
fix review remark: getrandom/lazy_static deps
gshep Sep 27, 2024
9cd2294
fix review remark: rename the method and introduce a return struct
gshep Sep 27, 2024
b706c90
ignore tests requiring running gear node
gshep Sep 27, 2024
5248187
cargo build/clippy in release mode
gshep Sep 27, 2024
bdbb715
cargo fmt
gshep Sep 27, 2024
7a925ed
remove FTManage service
gshep Sep 29, 2024
62468f1
Merge remote-tracking branch 'origin/main'
gshep Sep 29, 2024
f893840
fix review remark: remove `use super::*;`
gshep Sep 29, 2024
895319a
fix review remark: init vft_gateway address with default value
gshep Sep 29, 2024
5e2b828
fix review remark: don't use PathBuf::join
gshep Sep 29, 2024
17cb94d
fix review remark: remove ERC20Treasury.json
gshep Sep 29, 2024
3cdc121
adjust tests
gshep Sep 29, 2024
f638729
Revert "fix review remark: remove ERC20Treasury.json"
gshep Sep 29, 2024
85b95ee
fix remarks
gshep Sep 29, 2024
4413d12
Merge remote-tracking branch 'origin/main'
gshep Sep 29, 2024
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
170 changes: 165 additions & 5 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ members = [
"gear-programs/vft-gateway/src/wasm",
"gear-programs/*",
"gear-programs/checkpoint-light-client/io",
"gear-programs/erc20-relay/app",
"gear-programs/erc20-relay/client",
"utils-prometheus",
]

Expand Down Expand Up @@ -41,6 +43,9 @@ gear_proof_storage = { path = "gear-programs/proof-storage" }
checkpoint_light_client-io = { path = "gear-programs/checkpoint-light-client/io", default-features = false }
utils-prometheus = { path = "utils-prometheus" }
checkpoint_light_client = { path = "gear-programs/checkpoint-light-client", default-features = false }
erc20-relay = { path = "gear-programs/erc20-relay" }
erc20-relay-app = { path = "gear-programs/erc20-relay/app" }
erc20-relay-client = { path = "gear-programs/erc20-relay/client" }

plonky2 = { git = "https://github.com/gear-tech/plonky2.git", rev = "4a620f4d79efe9233d0e7682df5a2fc625b5420e" }
plonky2_field = { git = "https://github.com/gear-tech/plonky2.git", rev = "4a620f4d79efe9233d0e7682df5a2fc625b5420e" }
Expand Down Expand Up @@ -156,6 +161,7 @@ alloy-consensus = { version = "0.2.1", default-features = false }
alloy-eips = { version = "0.2.1", default-features = false }
alloy-rlp = { version = "0.3.8", default-features = false }
alloy-primitives = { version = "0.7.7", default-features = false }
alloy-sol-types = { version = "0.7.7", default-features = false }
alloy = { version = "0.2.0", package = "alloy", features = [
"sol-types",
"contract",
Expand Down
3 changes: 2 additions & 1 deletion ethereum-common/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ use core::{
slice::{self, SliceIndex},
};

pub use ethereum_types::{H256, U256};
pub use ethereum_types::{H160, H256, U256};
pub use hash_db;
use parity_scale_codec::{Decode, Encode};
use scale_info::TypeInfo;
use serde::{de, Deserialize};
Expand Down
9 changes: 3 additions & 6 deletions ethereum-common/src/utils.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
use super::*;
use alloy_consensus::ReceiptEnvelope;
use alloy_eips::eip2718::Encodable2718;
use alloy_primitives::Log;
use alloy_rlp::Encodable;
use core::str::FromStr;

const CAPACITY_RLP_RECEIPT: usize = 10_000;

pub type ReceiptEnvelope = alloy_consensus::ReceiptEnvelope<Log>;
/// Tuple with a transaction index and the related receipt.
pub type Receipt = (u64, ReceiptEnvelope<Log>);
pub type Receipt = (u64, ReceiptEnvelope);

pub fn calculate_epoch(slot: u64) -> u64 {
slot / SLOTS_PER_EPOCH
Expand Down Expand Up @@ -120,10 +120,7 @@ pub fn rlp_encode_transaction_index(index: &u64) -> Vec<u8> {
buf
}

pub fn rlp_encode_index_and_receipt(
index: &u64,
receipt: &ReceiptEnvelope<Log>,
) -> (Vec<u8>, Vec<u8>) {
pub fn rlp_encode_index_and_receipt(index: &u64, receipt: &ReceiptEnvelope) -> (Vec<u8>, Vec<u8>) {
let mut buf = Vec::with_capacity(CAPACITY_RLP_RECEIPT);
receipt.encode_2718(&mut buf);

Expand Down
16 changes: 16 additions & 0 deletions gear-programs/erc20-relay/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
[package]
name = "erc20-relay"
version = "0.1.0"
edition = "2021"
gshep marked this conversation as resolved.
Show resolved Hide resolved

[dependencies]
erc20-relay-app.workspace = true

[build-dependencies]
erc20-relay-app.workspace = true
sails-rs = { git = "https://github.com/gear-tech/sails.git", rev = "aab08733ee9ccdb809dc9b29c57dd411b2b917b1", features = ["wasm-builder"] }
sails-idl-gen = { git = "https://github.com/gear-tech/sails.git", rev = "aab08733ee9ccdb809dc9b29c57dd411b2b917b1" }
gshep marked this conversation as resolved.
Show resolved Hide resolved

[features]
wasm-binary = []
gas_calculation = ["erc20-relay-app/gas_calculation"]
8 changes: 8 additions & 0 deletions gear-programs/erc20-relay/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
## The **erc20-relay** program

The program workspace includes the following packages:
- `erc20-relay` is the package allowing to build WASM binary for the program and IDL file for it.
- `erc20-relay-app` is the package containing business logic for the program represented by the `Erc20RelayService` structure.
- `erc20-relay-client` is the package containing the client for the program allowing to interact with it from another program, tests, or
off-chain client.

33 changes: 33 additions & 0 deletions gear-programs/erc20-relay/app/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
[package]
name = "erc20-relay-app"
version = "0.1.0"
edition = "2021"
gshep marked this conversation as resolved.
Show resolved Hide resolved

[dependencies]
sails-rs = { git = "https://github.com/gear-tech/sails.git", rev = "aab08733ee9ccdb809dc9b29c57dd411b2b917b1" }
ethereum-common.workspace = true
alloy-rlp.workspace = true
alloy-sol-types = { workspace = true, features = ["json"] }
checkpoint_light_client-io.workspace = true

[target.'cfg(all(target_arch = "wasm32", target_os = "unknown"))'.dependencies]
getrandom = { version = "0.2", default-features = false, features = ["custom"] }
lazy_static = { version = "1.1", features = ["spin_no_std"] }
gshep marked this conversation as resolved.
Show resolved Hide resolved

[dev-dependencies]
erc20-relay-client.workspace = true
erc20-relay = { workspace = true, features = ["wasm-binary", "gas_calculation"] }
futures.workspace = true
gclient.workspace = true
gstd.workspace = true
sails-rs = { git = "https://github.com/gear-tech/sails.git", rev = "aab08733ee9ccdb809dc9b29c57dd411b2b917b1", features = ["gclient"] }
tokio = { workspace = true, features = ["rt", "macros"] }
hex-literal.workspace = true
hex.workspace = true

[build-dependencies]
sails-client-gen = { git = "https://github.com/gear-tech/sails.git", rev = "aab08733ee9ccdb809dc9b29c57dd411b2b917b1" }

[features]
gas_calculation = []
mocks = []
Loading
Loading