diff --git a/relay_rpc/Cargo.toml b/relay_rpc/Cargo.toml index c9ff0d7..d75d8e5 100644 --- a/relay_rpc/Cargo.toml +++ b/relay_rpc/Cargo.toml @@ -5,19 +5,11 @@ edition = "2021" license = "Apache-2.0" [features] +default = ["cacao"] cacao = [ "dep:k256", "dep:sha3", - "dep:alloy-provider", - "dep:alloy-transport", - "dep:alloy-transport-http", - "dep:alloy-rpc-types", - "dep:alloy-json-rpc", - "dep:alloy-json-abi", - "dep:alloy-sol-types", - "dep:alloy-primitives", - "dep:alloy-node-bindings", - "dep:alloy-contract" + "dep:alloy" ] [dependencies] @@ -46,16 +38,7 @@ k256 = { version = "0.13", optional = true } sha3 = { version = "0.10", optional = true } sha2 = { version = "0.10.6" } url = "2" -alloy-provider = { git = "https://github.com/alloy-rs/alloy.git", rev = "d68a6b7", optional = true } -alloy-transport = { git = "https://github.com/alloy-rs/alloy.git", rev = "d68a6b7", optional = true } -alloy-transport-http = { git = "https://github.com/alloy-rs/alloy.git", rev = "d68a6b7", optional = true } -alloy-rpc-types = { git = "https://github.com/alloy-rs/alloy.git", rev = "d68a6b7", optional = true } -alloy-json-rpc = { git = "https://github.com/alloy-rs/alloy.git", rev = "d68a6b7", optional = true } -alloy-node-bindings = { git = "https://github.com/alloy-rs/alloy.git", rev = "d68a6b7", optional = true } -alloy-contract = { git = "https://github.com/alloy-rs/alloy.git", rev = "d68a6b7", optional = true } -alloy-json-abi = { version = "0.7.0", optional = true } -alloy-sol-types = { version = "0.7.0", optional = true } -alloy-primitives = { version = "0.7.0", optional = true } +alloy = { version = "0.3.6", optional = true, features = ["json-rpc", "provider-http", "contract", "rpc-types-eth"] } strum = { version = "0.26", features = ["strum_macros", "derive"] } [dev-dependencies] diff --git a/relay_rpc/src/auth/cacao.rs b/relay_rpc/src/auth/cacao.rs index 179077f..18b9b32 100644 --- a/relay_rpc/src/auth/cacao.rs +++ b/relay_rpc/src/auth/cacao.rs @@ -4,7 +4,7 @@ use { payload::Payload, signature::{get_rpc_url::GetRpcUrl, Signature}, }, - alloy_primitives::hex::FromHexError, + alloy::primitives::hex::FromHexError, core::fmt::Debug, serde::{Deserialize, Serialize}, serde_json::value::RawValue, @@ -52,10 +52,10 @@ pub enum CacaoError { Verification, #[error("Internal EIP-1271 resolution error: {0}")] - Eip1271Internal(alloy_json_rpc::RpcError>), + Eip1271Internal(alloy::rpc::json_rpc::RpcError>), #[error("Internal EIP-6492 resolution error: {0}")] - Eip6492Internal(alloy_json_rpc::RpcError>), + Eip6492Internal(alloy::rpc::json_rpc::RpcError>), } impl From for CacaoError { diff --git a/relay_rpc/src/auth/cacao/signature/eip1271.rs b/relay_rpc/src/auth/cacao/signature/eip1271.rs index 6deddf7..eb82ab1 100644 --- a/relay_rpc/src/auth/cacao/signature/eip1271.rs +++ b/relay_rpc/src/auth/cacao/signature/eip1271.rs @@ -1,9 +1,9 @@ use { super::CacaoError, - alloy_primitives::Address, - alloy_provider::{network::Ethereum, Provider, ReqwestProvider}, - alloy_rpc_types::{TransactionInput, TransactionRequest}, - alloy_sol_types::{sol, SolCall}, + alloy::primitives::Address, + alloy::providers::{network::Ethereum, Provider, ReqwestProvider}, + alloy::rpc::types::{TransactionInput, TransactionRequest}, + alloy::{sol, sol_types::SolCall}, url::Url, }; @@ -40,7 +40,7 @@ pub async fn verify_eip1271( )); let result = provider - .call(&call_request, Default::default()) + .call(&call_request) .await .map_err(|e| { if let Some(error_response) = e.as_error_resp() { @@ -81,7 +81,7 @@ mod test { EIP1271_MOCK_CONTRACT, }, }, - alloy_primitives::address, + alloy::primitives::address, k256::ecdsa::SigningKey, sha3::{Digest, Keccak256}, }; diff --git a/relay_rpc/src/auth/cacao/signature/eip191.rs b/relay_rpc/src/auth/cacao/signature/eip191.rs index 2287ef5..093da60 100644 --- a/relay_rpc/src/auth/cacao/signature/eip191.rs +++ b/relay_rpc/src/auth/cacao/signature/eip191.rs @@ -1,7 +1,7 @@ use { super::CacaoError, crate::auth::cacao::signature::strip_hex_prefix, - alloy_primitives::Address, + alloy::primitives::Address, sha3::{Digest, Keccak256}, }; diff --git a/relay_rpc/src/auth/cacao/signature/eip6492.rs b/relay_rpc/src/auth/cacao/signature/eip6492.rs index 0fc5117..39d6587 100644 --- a/relay_rpc/src/auth/cacao/signature/eip6492.rs +++ b/relay_rpc/src/auth/cacao/signature/eip6492.rs @@ -1,9 +1,9 @@ use { crate::auth::cacao::CacaoError, - alloy_primitives::Address, - alloy_provider::{network::Ethereum, Provider, ReqwestProvider}, - alloy_rpc_types::{TransactionInput, TransactionRequest}, - alloy_sol_types::{sol, SolConstructor}, + alloy::primitives::Address, + alloy::providers::{network::Ethereum, Provider, ReqwestProvider}, + alloy::rpc::types::{TransactionInput, TransactionRequest}, + alloy::{sol, sol_types::SolConstructor}, url::Url, }; @@ -42,20 +42,17 @@ pub async fn verify_eip6492( let transaction_request = TransactionRequest::default().input(TransactionInput::new(bytes.into())); - let result = provider - .call(&transaction_request, Default::default()) - .await - .map_err(|e| { - if let Some(error_response) = e.as_error_resp() { - if error_response.message == "execution reverted" { - CacaoError::Verification - } else { - CacaoError::Eip6492Internal(e) - } + let result = provider.call(&transaction_request).await.map_err(|e| { + if let Some(error_response) = e.as_error_resp() { + if error_response.message == "execution reverted" { + CacaoError::Verification } else { CacaoError::Eip6492Internal(e) } - })?; + } else { + CacaoError::Eip6492Internal(e) + } + })?; let magic = result.first(); if let Some(magic) = magic { @@ -76,16 +73,12 @@ mod test { crate::auth::cacao::signature::{ strip_hex_prefix, test_helpers::{ - deploy_contract, - message_hash, - sign_message, - spawn_anvil, - CREATE2_CONTRACT, + deploy_contract, message_hash, sign_message, spawn_anvil, CREATE2_CONTRACT, EIP1271_MOCK_CONTRACT, }, }, - alloy_primitives::{address, b256, Uint}, - alloy_sol_types::{SolCall, SolValue}, + alloy::primitives::{address, b256, Uint}, + alloy::sol_types::{SolCall, SolValue}, k256::ecdsa::SigningKey, }; diff --git a/relay_rpc/src/auth/cacao/signature/mod.rs b/relay_rpc/src/auth/cacao/signature/mod.rs index 4eb0ae1..2732460 100644 --- a/relay_rpc/src/auth/cacao/signature/mod.rs +++ b/relay_rpc/src/auth/cacao/signature/mod.rs @@ -6,7 +6,7 @@ use { get_rpc_url::GetRpcUrl, }, super::{Cacao, CacaoError}, - alloy_primitives::Address, + alloy::primitives::Address, serde::{Deserialize, Serialize}, sha3::{Digest, Keccak256}, std::str::FromStr,