From 510944d3cd1b1765b4becda793f6c9aae2f112a3 Mon Sep 17 00:00:00 2001 From: Eason Date: Mon, 12 Jun 2023 17:18:53 +0800 Subject: [PATCH 1/3] feat: add executor tracing listener --- Cargo.lock | 39 ++- Cargo.toml | 1 + core/api/Cargo.toml | 2 +- core/api/src/adapter.rs | 4 +- core/consensus/Cargo.toml | 1 + core/executor/Cargo.toml | 4 + core/executor/src/debugger/mod.rs | 11 - core/executor/src/lib.rs | 46 ++- core/executor/src/tracing.rs | 561 ++++++++++++++++++++++++++++++ core/run/Cargo.toml | 1 + 10 files changed, 636 insertions(+), 34 deletions(-) create mode 100644 core/executor/src/tracing.rs diff --git a/Cargo.lock b/Cargo.lock index 5a5e3ac3f..51d186199 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1507,7 +1507,7 @@ name = "common-crypto" version = "0.2.1" dependencies = [ "axon-protocol", - "criterion", + "criterion 0.4.0", "ophelia", "ophelia-blst", "ophelia-secp256k1", @@ -1556,7 +1556,7 @@ name = "common-merkle" version = "0.2.1" dependencies = [ "axon-protocol", - "criterion", + "criterion 0.4.0", "hasher", "rand 0.7.3", "rlp", @@ -1669,7 +1669,7 @@ dependencies = [ "core-mempool", "core-network", "core-storage", - "criterion", + "criterion 0.4.0", "futures", "json", "lazy_static", @@ -1703,12 +1703,13 @@ dependencies = [ "core-interoperation", "core-rpc-client", "core-storage", - "criterion", + "criterion 0.5.1", "ethabi 18.0.0", "ethabi-contract", "ethabi-derive", "ethers", "evm", + "evm-runtime", "futures", "hashbrown 0.13.2", "hasher", @@ -1782,7 +1783,7 @@ dependencies = [ "core-executor", "core-interoperation", "core-network", - "criterion", + "criterion 0.4.0", "crossbeam-queue", "dashmap", "futures", @@ -1875,7 +1876,7 @@ dependencies = [ "common-apm-derive", "common-config-parser", "common-crypto", - "criterion", + "criterion 0.4.0", "futures", "lazy_static", "log", @@ -1948,6 +1949,32 @@ dependencies = [ "walkdir", ] +[[package]] +name = "criterion" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f2b12d017a929603d80db1831cd3a24082f8137ce19c69e6447f54f5fc8d692f" +dependencies = [ + "anes", + "cast", + "ciborium", + "clap 4.2.7", + "criterion-plot", + "is-terminal", + "itertools", + "num-traits", + "once_cell", + "oorandom", + "plotters", + "rayon", + "regex", + "serde", + "serde_derive", + "serde_json", + "tinytemplate", + "walkdir", +] + [[package]] name = "criterion-plot" version = "0.5.0" diff --git a/Cargo.toml b/Cargo.toml index 7ae0a32dd..651aa7584 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -50,6 +50,7 @@ jemalloc = ["core-run/jemalloc"] pprof = ["core-api/pprof"] random_leader = ["core-consensus/random_leader"] # tentacle_metrics = ["core-network/tentacle_metrics"] +tracing = ["core-run/tracing"] [profile.release] overflow-checks = true diff --git a/core/api/Cargo.toml b/core/api/Cargo.toml index 17e5b758d..04debeada 100644 --- a/core/api/Cargo.toml +++ b/core/api/Cargo.toml @@ -21,7 +21,7 @@ serde_json = "1.0" common-apm = { path = "../../common/apm" } common-config-parser = { path = "../../common/config-parser" } core-consensus = { path = "../../core/consensus" } -core-executor = { path = "../../core/executor" } +core-executor = { path = "../../core/executor", features = ["tracing"] } core-interoperation ={ path = "../../core/interoperation" } either = { version = "1.8", features = ["serde"] } protocol = { path = "../../protocol", package = "axon-protocol" } diff --git a/core/api/src/adapter.rs b/core/api/src/adapter.rs index f0f012b7f..e5dd06d7a 100644 --- a/core/api/src/adapter.rs +++ b/core/api/src/adapter.rs @@ -3,7 +3,7 @@ use std::sync::Arc; use core_executor::{ system_contract::metadata::MetadataHandle, AxonExecutor, AxonExecutorAdapter, MPTTrie, }; -use protocol::traits::{APIAdapter, Context, Executor, ExecutorAdapter, MemPool, Network, Storage}; +use protocol::traits::{APIAdapter, Context, ExecutorAdapter, MemPool, Network, Storage}; use protocol::types::{ Account, BigEndianHash, Block, BlockNumber, Bytes, CkbRelatedInfo, ExecutorContext, Hash, Header, Metadata, Proposal, Receipt, SignedTransaction, TxResp, H160, MAX_BLOCK_GAS_LIMIT, @@ -197,7 +197,7 @@ where .map(|gas| gas.as_u64()) .unwrap_or(MAX_BLOCK_GAS_LIMIT); - Ok(AxonExecutor::default().call(&backend, gas_limit, from, to, value, data)) + Ok(AxonExecutor::default().tracing_call(&backend, gas_limit, from, to, value, data)) } async fn get_code_by_hash(&self, ctx: Context, hash: &Hash) -> ProtocolResult> { diff --git a/core/consensus/Cargo.toml b/core/consensus/Cargo.toml index 85ec6429e..a00d276eb 100644 --- a/core/consensus/Cargo.toml +++ b/core/consensus/Cargo.toml @@ -37,6 +37,7 @@ num-traits = "0.2" [features] default = [] random_leader = ["overlord/random_leader"] +tracing = ["core-executor/tracing"] [[bench]] harness = false diff --git a/core/executor/Cargo.toml b/core/executor/Cargo.toml index bdc23decb..dba0b4479 100644 --- a/core/executor/Cargo.toml +++ b/core/executor/Cargo.toml @@ -18,6 +18,7 @@ common-merkle = { path = "../../common/merkle" } core-interoperation = { path = "../interoperation" } ethers = "2.0" evm = { version = "0.37", features = ["tracing"] } +evm-runtime = { version = "0.37", features = ["tracing"] } futures = "0.3" hasher = "0.1" lazy_static = "1.4" @@ -51,6 +52,9 @@ rlp = "0.5" serde_json = "1.0" tempfile = "3.3" +[features] +tracing = [] + [[bench]] harness = false name = "bench_convert_u256" diff --git a/core/executor/src/debugger/mod.rs b/core/executor/src/debugger/mod.rs index 6c4debfaf..8d0351aff 100644 --- a/core/executor/src/debugger/mod.rs +++ b/core/executor/src/debugger/mod.rs @@ -6,8 +6,6 @@ mod uniswap2; use std::sync::Arc; use std::time::{SystemTime, UNIX_EPOCH}; -use evm::tracing::{Event, EventListener}; - use common_config_parser::parse_file; use common_crypto::{PrivateKey, Secp256k1RecoverablePrivateKey, Signature}; use protocol::codec::{hex_decode, ProtocolCodec}; @@ -125,15 +123,6 @@ impl EvmDebugger { } } -#[derive(Default)] -pub struct EvmListener; - -impl EventListener for EvmListener { - fn event(&mut self, event: Event) { - println!("EVM event {:?}", event); - } -} - pub fn mock_efficient_signed_tx(tx: Eip1559Transaction, private_key: &str) -> SignedTransaction { let priv_key = Secp256k1RecoverablePrivateKey::try_from(hex_decode(private_key).unwrap().as_ref()) diff --git a/core/executor/src/lib.rs b/core/executor/src/lib.rs index 2acc870c2..84ff2ca68 100644 --- a/core/executor/src/lib.rs +++ b/core/executor/src/lib.rs @@ -7,9 +7,11 @@ mod precompiles; pub mod system_contract; #[cfg(test)] mod tests; +mod tracing; mod utils; pub use crate::adapter::{AxonExecutorAdapter, MPTTrie, RocksTrieDB}; +pub use crate::tracing::TransactionTrace; pub use crate::utils::{ code_address, decode_revert_msg, logs_bloom, DefaultFeeAllocator, FeeInlet, }; @@ -34,6 +36,7 @@ use crate::system_contract::{ after_block_hook, before_block_hook, system_contract_dispatch, CkbLightClientContract, ImageCellContract, MetadataContract, NativeTokenContract, SystemContract, }; +use crate::tracing::{trace_using, AxonListener}; lazy_static::lazy_static! { pub static ref FEE_ALLOCATOR: ArcSwap> = ArcSwap::from_pointee(Box::new(DefaultFeeAllocator::default())); @@ -69,6 +72,7 @@ impl Executor for AxonExecutor { let precompiles = build_precompile_set(); let mut executor = StackExecutor::new_with_precompiles(state, &config, &precompiles); + let from = from.unwrap_or_default(); let base_gas = if to.is_some() { GAS_CALL_TRANSACTION + data_gas_cost(&data) } else { @@ -76,16 +80,9 @@ impl Executor for AxonExecutor { }; let (exit, res) = if let Some(addr) = &to { - executor.transact_call( - from.unwrap_or_default(), - *addr, - value, - data, - gas_limit, - Vec::new(), - ) + executor.transact_call(from, *addr, value, data, gas_limit, Vec::new()) } else { - executor.transact_create(from.unwrap_or_default(), value, data, gas_limit, Vec::new()) + executor.transact_create(from, value, data, gas_limit, Vec::new()) }; let used_gas = executor.used_gas() + base_gas; @@ -103,9 +100,7 @@ impl Executor for AxonExecutor { code_address: if to.is_none() { Some( executor - .create_address(CreateScheme::Legacy { - caller: from.unwrap_or_default(), - }) + .create_address(CreateScheme::Legacy { caller: from }) .into(), ) } else { @@ -139,8 +134,16 @@ impl Executor for AxonExecutor { // Execute a transaction, if system contract dispatch return None, means the // transaction called EVM - let mut r = system_contract_dispatch(adapter, tx) - .unwrap_or_else(|| Self::evm_exec(adapter, &config, &precompiles, tx)); + let mut r = if cfg!(feature = "tracing") { + let mut listener = AxonListener::new(); + trace_using(&mut listener, || { + system_contract_dispatch(adapter, tx) + .unwrap_or_else(|| Self::evm_exec(adapter, &config, &precompiles, tx)) + }) + } else { + system_contract_dispatch(adapter, tx) + .unwrap_or_else(|| Self::evm_exec(adapter, &config, &precompiles, tx)) + }; r.logs = adapter.get_logs(); gas += r.gas_used; @@ -293,6 +296,21 @@ impl AxonExecutor { } } + pub fn tracing_call( + &self, + backend: &B, + gas_limit: u64, + from: Option, + to: Option, + value: U256, + data: Vec, + ) -> TxResp { + let mut listener = AxonListener::new(); + trace_using(&mut listener, || { + self.call(backend, gas_limit, from, to, value, data) + }) + } + #[cfg(test)] fn test_exec( &self, diff --git a/core/executor/src/tracing.rs b/core/executor/src/tracing.rs new file mode 100644 index 000000000..033117e0a --- /dev/null +++ b/core/executor/src/tracing.rs @@ -0,0 +1,561 @@ +use std::{cell::RefCell, ops::Index, ptr::NonNull, rc::Rc}; + +use evm::gasometer::tracing as gas_tracing; +use evm::{tracing as evm_tracing, Capture, Opcode}; +use evm_runtime::tracing as runtime_tracing; + +use protocol::types::H256; + +use crate::tracing::wrapped_event::WrappedEvent; + +macro_rules! trace_type { + ($($name: ident,)*) => { + $( + #[derive(Default, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)] + pub struct $name(pub [u8; 32]); + + impl $name { + pub fn into_raw(self) -> [u8; 32] { + self.0 + } + } + )* + }; + + (Vec $(, $name: ident)*) => { + $( + #[derive(Default, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)] + pub struct $name(pub Vec<[u8; 32]>); + + impl $name { + pub fn len(&self) -> usize { + self.0.len() + } + + #[allow(dead_code)] + pub fn is_empty(&self) -> bool { + self.0.is_empty() + } + + pub fn into_raw(self) -> Vec<[u8; 32]> { + self.0 + } + } + )* + }; + + ($name: ident, $key: ident, $val: ident) => { + #[derive(Default, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)] + pub struct $name(pub std::collections::BTreeMap<$key, $val>); + + impl IntoIterator for $name { + type Item = ($key, $val); + type IntoIter = std::collections::btree_map::IntoIter<$key, $val>; + + fn into_iter(self) -> Self::IntoIter { + self.0.into_iter() + } + } + + impl $name { + pub fn insert(&mut self, key: $key, value: $val) { + self.0.insert(key, value); + } + } + } +} + +pub fn trace_using(listener: &mut T, f: F) -> R +where + T: evm_tracing::EventListener + + runtime_tracing::EventListener + + gas_tracing::EventListener + + 'static, + F: FnOnce() -> R, +{ + let mut evm_listener = SharedMutableReference::new(listener); + let mut runtime_listener = evm_listener.clone(); + let mut gas_listener = evm_listener.clone(); + + gas_tracing::using(&mut gas_listener, || { + runtime_tracing::using(&mut runtime_listener, || { + evm_tracing::using(&mut evm_listener, f) + }) + }) +} + +struct SharedMutableReference { + pointer: Rc>>, +} + +impl SharedMutableReference { + fn new(reference: &mut T) -> Self { + let ptr = NonNull::new(reference as _).unwrap(); + Self { + pointer: Rc::new(RefCell::new(ptr)), + } + } + + fn clone(&self) -> Self { + Self { + pointer: Rc::clone(&self.pointer), + } + } +} + +impl evm_tracing::EventListener for SharedMutableReference { + fn event(&mut self, event: evm_tracing::Event) { + unsafe { + self.pointer.borrow_mut().as_mut().event(event); + } + } +} + +impl runtime_tracing::EventListener + for SharedMutableReference +{ + fn event(&mut self, event: runtime_tracing::Event) { + unsafe { + self.pointer.borrow_mut().as_mut().event(event); + } + } +} + +impl gas_tracing::EventListener for SharedMutableReference { + fn event(&mut self, event: gas_tracing::Event) { + unsafe { + self.pointer.borrow_mut().as_mut().event(event); + } + } +} + +#[derive(Default, Clone, Debug)] +pub struct AxonListener { + logs: Vec, + current: TraceLog, + current_memory_gas: u64, + gas_used: u64, + failed: bool, + output: Vec, +} + +impl evm_tracing::EventListener for AxonListener { + fn event(&mut self, event: evm_tracing::Event) { + use evm::tracing::Event; + + #[cfg(feature = "tracing")] + log::info!("EVM event {:?}", WrappedEvent::from(&event)); + + match event { + Event::Call { .. } | Event::Create { .. } | Event::PrecompileSubcall { .. } => { + self.current.depth += 1; + } + Event::Exit { + reason: _, + return_value, + } => { + // If the depth is not zero then an error must have occurred to exit early. + if !self.current.depth == 0 { + self.failed = true; + self.output = return_value.to_vec(); + } + } + // Others contain no useful information + _ => (), + } + } +} + +impl runtime_tracing::EventListener for AxonListener { + fn event(&mut self, event: runtime_tracing::Event) { + use evm_runtime::tracing::Event; + + #[cfg(feature = "tracing")] + log::info!("EVM runtime event {:?}", WrappedEvent::from(&event)); + + match event { + Event::Step { + context: _, + opcode, + position, + stack, + memory, + } => { + self.current.opcode = opcode; + if let Ok(pc) = position { + self.current.program_counter = *pc as u32; + } + self.current.stack = stack.data().as_slice().into(); + self.current.memory = memory.data().as_slice().into(); + } + + Event::StepResult { + result, + return_value, + } => { + match result { + Ok(_) => { + // Step completed, push current log into the record + self.logs.push(self.current.clone()); + } + Err(Capture::Exit(reason)) => { + // Step completed, push current log into the record + self.logs.push(self.current.clone()); + // Current sub-call completed, reduce depth by 1 + self.current.depth -= 1; + + // if the depth is 0 then the transaction is complete + if self.current.depth == 0 { + if !return_value.is_empty() { + self.output = return_value.to_vec(); + } + if !reason.is_succeed() { + self.failed = true; + } + } + } + Err(Capture::Trap(opcode)) => { + // "Trap" here means that there is some opcode which has special + // handling logic outside the core `step` function. This means the + // `StepResult` does not necessarily indicate the current log + // is finished yet. In particular, `SLoad` and `SStore` events come + // _after_ the `StepResult`, but still correspond to the current step. + if opcode == &Opcode::SLOAD || opcode == &Opcode::SSTORE { + self.logs.push(self.current.clone()); + } + } + } + } + + Event::SLoad { + address: _, + index, + value, + } => { + self.current + .storage + .insert(LogStorageKey(index.0), LogStorageValue(value.0)); + self.logs.push(self.current.clone()); + } + + Event::SStore { + address: _, + index, + value, + } => { + self.current + .storage + .insert(LogStorageKey(index.0), LogStorageValue(value.0)); + self.logs.push(self.current.clone()); + } + } + } +} + +impl gas_tracing::EventListener for AxonListener { + fn event(&mut self, event: gas_tracing::Event) { + use gas_tracing::Event; + + #[cfg(feature = "tracing")] + log::info!("EVM gas event {:?}", WrappedEvent::from(&event)); + + match event { + Event::RecordCost { cost, snapshot: _ } => { + self.current.gas_cost = cost; + } + Event::RecordDynamicCost { + gas_cost, + memory_gas, + gas_refund: _, + snapshot: _, + } => { + // In SputnikVM memory gas is cumulative (ie this event always shows the total) + // gas spent on memory up to this point. But geth traces simply + // show how much gas each step took, regardless of how that gas + // was used. So if this step caused an increase to the + // memory gas then we need to record that. + let memory_cost_diff = if memory_gas > self.current_memory_gas { + memory_gas - self.current_memory_gas + } else { + 0 + }; + self.current_memory_gas = memory_gas; + self.current.gas_cost = gas_cost + memory_cost_diff; + } + Event::RecordRefund { + refund: _, + snapshot, + } => { + // This one seems to show up at the end of a transaction, so it + // can be used to set the total gas used. + if let Some(snapshot) = snapshot { + self.gas_used = snapshot.used_gas; + } + } + Event::RecordTransaction { .. } | Event::RecordStipend { .. } => (), + } + } +} + +impl AxonListener { + pub fn new() -> Self { + Self::default() + } + + pub fn finish(self) -> TransactionTrace { + TransactionTrace::new(self.gas_used, self.failed, self.output, Logs(self.logs)) + } +} + +#[derive(Clone, Debug, PartialEq, Eq)] +pub struct TraceLog { + pub depth: u32, + pub error: Option, + pub gas: u64, + pub gas_cost: u64, + pub memory: LogMemory, + pub opcode: Opcode, + pub program_counter: u32, + pub stack: LogStack, + pub storage: LogStorage, +} + +impl Default for TraceLog { + fn default() -> Self { + Self { + depth: Default::default(), + error: Default::default(), + gas: Default::default(), + gas_cost: Default::default(), + memory: Default::default(), + opcode: Opcode::STOP, + program_counter: Default::default(), + stack: Default::default(), + storage: Default::default(), + } + } +} + +#[derive(Default, Clone, Debug, PartialEq, Eq)] +pub struct TransactionTrace { + gas: u64, + failed: bool, + return_value: Vec, + struct_logs: Logs, +} + +impl TransactionTrace { + pub fn new( + gas: u64, + failed: bool, + return_value: Vec, + struct_logs: Logs, + ) -> TransactionTrace { + Self { + gas, + failed, + return_value, + struct_logs, + } + } + + pub fn gas(&self) -> u64 { + self.gas + } + + pub fn result(&self) -> &[u8] { + self.return_value.as_slice() + } + + pub fn logs(&self) -> &Logs { + &self.struct_logs + } +} + +#[derive(Default, Clone, Debug, PartialEq, Eq)] +pub struct StepTransactionTrace { + inner: TransactionTrace, + step: usize, +} + +#[allow(dead_code)] +impl StepTransactionTrace { + pub fn new(transaction_trace: TransactionTrace) -> Self { + Self { + inner: transaction_trace, + step: 0, + } + } + + pub fn step(&mut self) -> Option<&TraceLog> { + if self.step > self.inner.struct_logs.len() { + None + } else { + self.step += 1; + Some(&self.inner.struct_logs[self.step]) + } + } +} + +#[derive(Default, Clone, Debug, PartialEq, Eq)] +pub struct Logs(pub Vec); + +impl Logs { + pub fn len(&self) -> usize { + self.0.len() + } + + pub fn is_empty(&self) -> bool { + self.0.is_empty() + } +} + +impl Index for Logs { + type Output = TraceLog; + + fn index(&self, index: usize) -> &Self::Output { + &self.0[index] + } +} + +impl IntoIterator for Logs { + type IntoIter = std::vec::IntoIter; + type Item = TraceLog; + + fn into_iter(self) -> Self::IntoIter { + self.0.into_iter() + } +} + +trace_type!(LogStorageKey, LogStorageValue,); +trace_type!(Vec, LogMemory, LogStack); +trace_type!(LogStorage, LogStorageKey, LogStorageValue); + +impl From<&[u8]> for LogMemory { + fn from(bytes: &[u8]) -> Self { + let mut result = Vec::with_capacity(bytes.len() / 32); + let mut buf = [0u8; 32]; + for (i, b) in bytes.iter().enumerate() { + let j = i % 32; + buf[j] = *b; + if j == 31 { + result.push(buf) + } + } + Self(result) + } +} + +impl From<&[H256]> for LogStack { + fn from(stack: &[H256]) -> Self { + let vec = stack.iter().map(|bytes| bytes.0).collect(); + Self(vec) + } +} + +#[cfg(feature = "tracing")] +mod wrapped_event { + use super::*; + use std::fmt::{Debug, Formatter, Result}; + + #[derive(Clone)] + pub enum WrappedEvent<'a> { + Evm(&'a evm_tracing::Event<'a>), + Runtime(&'a runtime_tracing::Event<'a>), + Gas(&'a gas_tracing::Event), + } + + impl<'a> Debug for WrappedEvent<'a> { + fn fmt(&self, f: &mut Formatter<'_>) -> Result { + match self { + WrappedEvent::Evm(event) => { + use evm_tracing::Event; + match event { + Event::Create { + caller, + address, + scheme, + value, + target_gas, + .. + } => f + .debug_struct("Create") + .field("caller", caller) + .field("address", address) + .field("scheme", scheme) + .field("value", value) + .field("gas", target_gas) + .finish(), + Event::TransactCreate { + caller, + value, + gas_limit, + address, + .. + } => f + .debug_struct("Create") + .field("caller", caller) + .field("value", value) + .field("gas", gas_limit) + .field("address", address) + .finish(), + Event::TransactCreate2 { + caller, + value, + salt, + gas_limit, + address, + .. + } => f + .debug_struct("Create2") + .field("caller", caller) + .field("value", value) + .field("salt", salt) + .field("gas", gas_limit) + .field("address", address) + .finish(), + _ => Debug::fmt(event, f), + } + } + WrappedEvent::Runtime(event) => { + use runtime_tracing::Event; + match event { + Event::Step { + context, + opcode, + position, + stack, + .. + } => f + .debug_struct("Step") + .field("context", context) + .field("opcode", opcode) + .field("position", position) + .field("stack", stack) + .finish(), + _ => Debug::fmt(event, f), + } + } + WrappedEvent::Gas(event) => Debug::fmt(event, f), + } + } + } + + impl<'a> From<&'a evm_tracing::Event<'a>> for WrappedEvent<'a> { + fn from(event: &'a evm_tracing::Event) -> Self { + Self::Evm(event) + } + } + + impl<'a> From<&'a runtime_tracing::Event<'a>> for WrappedEvent<'a> { + fn from(event: &'a runtime_tracing::Event) -> Self { + Self::Runtime(event) + } + } + + impl<'a> From<&'a gas_tracing::Event> for WrappedEvent<'a> { + fn from(event: &'a gas_tracing::Event) -> Self { + Self::Gas(event) + } + } +} diff --git a/core/run/Cargo.toml b/core/run/Cargo.toml index 15be1f1d4..5266f0209 100644 --- a/core/run/Cargo.toml +++ b/core/run/Cargo.toml @@ -36,3 +36,4 @@ jemallocator = { version = "0.5", features = ["profiling", "stats", "unprefixed_ [features] jemalloc = ["dep:jemallocator", "dep:jemalloc-ctl", "dep:common-memory-tracker"] +tracing = ["core-executor/tracing", "core-consensus/tracing"] From 234e85b55100793777c0b2bfc1cf5157df652916 Mon Sep 17 00:00:00 2001 From: Eason Date: Mon, 12 Jun 2023 19:03:21 +0800 Subject: [PATCH 2/3] feat: add some special config --- core/api/src/adapter.rs | 11 +++++++++-- core/api/src/jsonrpc/impl/web3.rs | 2 ++ core/executor/src/lib.rs | 16 ++++++++++++++-- core/executor/src/tracing.rs | 15 ++++++++++++--- protocol/src/traits/api.rs | 1 + 5 files changed, 38 insertions(+), 7 deletions(-) diff --git a/core/api/src/adapter.rs b/core/api/src/adapter.rs index e5dd06d7a..81de4f6f0 100644 --- a/core/api/src/adapter.rs +++ b/core/api/src/adapter.rs @@ -3,7 +3,7 @@ use std::sync::Arc; use core_executor::{ system_contract::metadata::MetadataHandle, AxonExecutor, AxonExecutorAdapter, MPTTrie, }; -use protocol::traits::{APIAdapter, Context, ExecutorAdapter, MemPool, Network, Storage}; +use protocol::traits::{APIAdapter, Context, Executor, ExecutorAdapter, MemPool, Network, Storage}; use protocol::types::{ Account, BigEndianHash, Block, BlockNumber, Bytes, CkbRelatedInfo, ExecutorContext, Hash, Header, Metadata, Proposal, Receipt, SignedTransaction, TxResp, H160, MAX_BLOCK_GAS_LIMIT, @@ -182,6 +182,7 @@ where data: Vec, state_root: Hash, mock_header: Proposal, + enable_trace: bool, ) -> ProtocolResult { let mut exec_ctx = ExecutorContext::from(mock_header); exec_ctx.origin = from.unwrap_or_default(); @@ -197,7 +198,13 @@ where .map(|gas| gas.as_u64()) .unwrap_or(MAX_BLOCK_GAS_LIMIT); - Ok(AxonExecutor::default().tracing_call(&backend, gas_limit, from, to, value, data)) + if enable_trace { + return Ok( + AxonExecutor::default().tracing_call(&backend, gas_limit, from, to, value, data) + ); + } + + Ok(AxonExecutor::default().call(&backend, gas_limit, from, to, value, data)) } async fn get_code_by_hash(&self, ctx: Context, hash: &Hash) -> ProtocolResult> { diff --git a/core/api/src/jsonrpc/impl/web3.rs b/core/api/src/jsonrpc/impl/web3.rs index 50df9af0d..49408fd6f 100644 --- a/core/api/src/jsonrpc/impl/web3.rs +++ b/core/api/src/jsonrpc/impl/web3.rs @@ -77,6 +77,7 @@ impl Web3RpcImpl { let mock_header = mock_header_by_call_req(header, &req); + // Todo: change the enable_trace flag to false self.adapter .evm_call( Context::new(), @@ -88,6 +89,7 @@ impl Web3RpcImpl { data.to_vec(), mock_header.state_root, Proposal::new_without_state_root(&mock_header), + true, ) .await } diff --git a/core/executor/src/lib.rs b/core/executor/src/lib.rs index 84ff2ca68..be8792551 100644 --- a/core/executor/src/lib.rs +++ b/core/executor/src/lib.rs @@ -66,7 +66,7 @@ impl Executor for AxonExecutor { value: U256, data: Vec, ) -> TxResp { - let config = Config::london(); + let config = self.config(false); let metadata = StackSubstateMetadata::new(gas_limit, &config); let state = MemoryStackState::new(metadata, backend); let precompiles = build_precompile_set(); @@ -123,7 +123,7 @@ impl Executor for AxonExecutor { let mut hashes = Vec::with_capacity(txs_len); let (mut gas, mut fee) = (0u64, U256::zero()); let precompiles = build_precompile_set(); - let config = Config::london(); + let config = self.config(block_number.is_zero()); // Execute system contracts before block hook. before_block_hook(adapter); @@ -311,6 +311,18 @@ impl AxonExecutor { }) } + // Todo: add the is_genesis judgement + fn config(&self, _is_genesis: bool) -> Config { + let mut config = Config::london(); + + // if is_genesis { + // config.create_contract_limit = Some(0xc000); + // } + + config.create_contract_limit = Some(0xc000); + config + } + #[cfg(test)] fn test_exec( &self, diff --git a/core/executor/src/tracing.rs b/core/executor/src/tracing.rs index 033117e0a..89b5a78d6 100644 --- a/core/executor/src/tracing.rs +++ b/core/executor/src/tracing.rs @@ -485,7 +485,7 @@ mod wrapped_event { .field("scheme", scheme) .field("value", value) .field("gas", target_gas) - .finish(), + .finish_non_exhaustive(), Event::TransactCreate { caller, value, @@ -498,7 +498,7 @@ mod wrapped_event { .field("value", value) .field("gas", gas_limit) .field("address", address) - .finish(), + .finish_non_exhaustive(), Event::TransactCreate2 { caller, value, @@ -513,7 +513,7 @@ mod wrapped_event { .field("salt", salt) .field("gas", gas_limit) .field("address", address) - .finish(), + .finish_non_exhaustive(), _ => Debug::fmt(event, f), } } @@ -532,6 +532,15 @@ mod wrapped_event { .field("opcode", opcode) .field("position", position) .field("stack", stack) + .finish_non_exhaustive(), + Event::StepResult { + result, + return_value, + } => f + .debug_struct("StepResult") + .field("result", result) + .field("return_len", &return_value.len()) + .field("return_value", return_value) .finish(), _ => Debug::fmt(event, f), } diff --git a/protocol/src/traits/api.rs b/protocol/src/traits/api.rs index 8092b36d4..770550314 100644 --- a/protocol/src/traits/api.rs +++ b/protocol/src/traits/api.rs @@ -78,6 +78,7 @@ pub trait APIAdapter: Send + Sync { data: Vec, state_root: Hash, proposal: Proposal, + enable_trace: bool, ) -> ProtocolResult; async fn get_code_by_hash(&self, ctx: Context, hash: &Hash) -> ProtocolResult>; From 7417d4490d8e9c734eaab418aa6732899bac530e Mon Sep 17 00:00:00 2001 From: Eason Date: Wed, 14 Jun 2023 01:58:51 +0800 Subject: [PATCH 3/3] feat: add debug transaction trace --- Cargo.lock | 1208 ++++++++++++++--------------- core/api/src/adapter.rs | 18 +- core/api/src/jsonrpc/impl/web3.rs | 1 + core/executor/Cargo.toml | 1 + core/executor/src/lib.rs | 16 +- core/executor/src/tracing.rs | 533 ++++++++----- protocol/src/traits/api.rs | 4 +- protocol/src/types/transaction.rs | 22 +- 8 files changed, 963 insertions(+), 840 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 51d186199..8d80584dc 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -16,15 +16,15 @@ dependencies = [ name = "abi-generator" version = "0.1.0" dependencies = [ - "clap 4.2.7", + "clap 4.3.19", "ethers", ] [[package]] name = "addr2line" -version = "0.19.0" +version = "0.20.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a76fd60b23679b7d19bd066031410fb7e458ccc5e958eb5c325888ce4baedc97" +checksum = "f4fa78e18c64fce05e902adecd7a5eed15a5e0a3439f7b0e169f0252214865e3" dependencies = [ "gimli", ] @@ -47,24 +47,12 @@ dependencies = [ [[package]] name = "aes" -version = "0.7.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9e8b47f52ea9bae42228d07ec09eb676433d7c4ed1ebdf0f1d1c29ed446f1ab8" -dependencies = [ - "cfg-if 1.0.0", - "cipher 0.3.0", - "cpufeatures", - "opaque-debug", -] - -[[package]] -name = "aes" -version = "0.8.2" +version = "0.8.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "433cfd6710c9986c576a25ca913c39d66a6474107b406f34f91d4a8923395241" +checksum = "ac1f845298e95f983ff1944b728ae08b8cebab80d684f0a832ed0fc74dfa27e2" dependencies = [ "cfg-if 1.0.0", - "cipher 0.4.4", + "cipher", "cpufeatures", ] @@ -74,7 +62,7 @@ version = "0.7.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fcb51a0695d8f838b1ee009b3fbf66bda078cd64590202a864a8f3e8c4315c47" dependencies = [ - "getrandom 0.2.9", + "getrandom 0.2.10", "once_cell", "version_check", ] @@ -92,21 +80,18 @@ dependencies = [ [[package]] name = "aho-corasick" -version = "0.7.20" +version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cc936419f96fa211c1b9166887b38e5e40b19958e5b895be7c1f93adec7071ac" +checksum = "43f6cb1bf222025340178f382c426f13757b2960e89779dfcb319c32542a5a41" dependencies = [ "memchr", ] [[package]] -name = "aho-corasick" -version = "1.0.1" +name = "android-tzdata" +version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "67fc08ce920c31afb70f013dcce1bfc3a3195de6a228474e45e1f145b36f8d04" -dependencies = [ - "memchr", -] +checksum = "e999941b234f3131b00bc13c22d06e8c5ff726d1b6318ac7eb276997bbb4fef0" [[package]] name = "android_system_properties" @@ -149,15 +134,15 @@ dependencies = [ [[package]] name = "anstyle" -version = "1.0.0" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "41ed9a86bf92ae6580e0a31281f65a1b1d867c0cc68d5346e2ae128dddfa6a7d" +checksum = "3a30da5c5f2d5e72842e00bcb57657162cdabef0931f40e2deb9b4140440cecd" [[package]] name = "anstyle-parse" -version = "0.2.0" +version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e765fd216e48e067936442276d1d57399e37bce53c264d6fefbe298080cb57ee" +checksum = "938874ff5980b03a87c5524b3ae5b59cf99b1d6bc836848df7bc5ada9643c333" dependencies = [ "utf8parse", ] @@ -183,9 +168,9 @@ dependencies = [ [[package]] name = "anyhow" -version = "1.0.71" +version = "1.0.72" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c7d0618f0e0b7e8ff11427422b64564d5fb0be1940354bfe2e0529b18a9d9b8" +checksum = "3b13c32d80ecc7ab747b80c3784bce54ee8a7a0cc4fbda9bf4cda2cf6fe90854" [[package]] name = "arbitrary" @@ -207,9 +192,9 @@ checksum = "6b4930d2cb77ce62f89ee5d5289b4ac049559b1c45539271f5ed4fdc7db34545" [[package]] name = "arrayvec" -version = "0.7.2" +version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8da52d66c7071e2e3fa2a1e5c6d088fec47b593032b254f5e980de8ea54454d6" +checksum = "96d30a06541fbafbc7f82ed10c06164cfbd2c401138f6addd8404629c4b16711" [[package]] name = "ascii-canvas" @@ -222,13 +207,13 @@ dependencies = [ [[package]] name = "async-trait" -version = "0.1.68" +version = "0.1.72" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b9ccdd8f2a161be9bd5c023df56f1b2a0bd1d83872ae53b71a84a12c9bf6e842" +checksum = "cc6dde6e4ed435a4c1ee4e73592f5ba9da2151af10076cc04858746af9352d09" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] @@ -276,7 +261,7 @@ name = "axon" version = "0.1.0-beta.5" dependencies = [ "axon-protocol", - "clap 4.2.7", + "clap 4.3.19", "core-api", "core-cli", "core-consensus", @@ -333,18 +318,18 @@ dependencies = [ "serde", "serde_json", "tokio", - "toml 0.7.3", + "toml 0.7.6", ] [[package]] name = "axum" -version = "0.6.18" +version = "0.6.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f8175979259124331c1d7bf6586ee7e0da434155e4b2d48ec2c8386281d8df39" +checksum = "a6a1de45611fdb535bfde7b7de4fd54f4fd2b17b1737c0a59b69bf9b92074b8c" dependencies = [ "async-trait", "axum-core", - "bitflags", + "bitflags 1.3.2", "bytes", "futures-util", "http", @@ -393,15 +378,15 @@ checksum = "7b7e4c2464d97fe331d41de9d5db0def0a96f4d823b8b32a2efd503578988973" [[package]] name = "backtrace" -version = "0.3.67" +version = "0.3.68" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "233d376d6d185f2a3093e58f283f60f880315b6c60075b01f36b3b85154564ca" +checksum = "4319208da049c43661739c5fade2ba182f09d1dc2299b32298d3a31692b17e12" dependencies = [ "addr2line", "cc", "cfg-if 1.0.0", "libc", - "miniz_oxide 0.6.2", + "miniz_oxide", "object", "rustc-demangle", ] @@ -420,9 +405,9 @@ checksum = "9e1b586273c5702936fe7b7d6896644d8be71e6314cfe09d3167c95f712589e8" [[package]] name = "base64" -version = "0.21.0" +version = "0.21.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a4a4ddaa51a5bc52a6948f74c06d20aaaddb71924eab79b8c97a8c556e942d6a" +checksum = "604178f6c5c21f02dc555784810edfb88d34ac2c73b2eae109655649ee73ce3d" [[package]] name = "base64-url" @@ -475,7 +460,7 @@ version = "0.63.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "36d860121800b2a9a94f9b5604b332d5cffb234ce17609ea479d723dbc9d3885" dependencies = [ - "bitflags", + "bitflags 1.3.2", "cexpr", "clang-sys", "lazy_static", @@ -512,6 +497,12 @@ version = "1.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" +[[package]] +name = "bitflags" +version = "2.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "630be753d4e58660abd17930c71b647fe46c27ea6b63cc59e1e3851406972e42" + [[package]] name = "bitvec" version = "0.17.4" @@ -601,9 +592,9 @@ dependencies = [ [[package]] name = "bstr" -version = "1.4.0" +version = "1.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c3d4260bcc2e8fc9df1eac4919a720effeb63a3f0952f5bf4944adfa18897f09" +checksum = "6798148dccfbff0fae41c7574d2fa8f1ef3492fba0face179de5d8d447d67b05" dependencies = [ "memchr", "serde", @@ -611,9 +602,9 @@ dependencies = [ [[package]] name = "bumpalo" -version = "3.12.2" +version = "3.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c6ed94e98ecff0c12dd1b04c15ec0d7d9458ca8fe806cea6f12954efe74c63b" +checksum = "a3e2c3daef883ecc1b5d58c15adae93470a91d425f3532ba1695849656af3fc1" [[package]] name = "byte-slice-cast" @@ -665,9 +656,9 @@ dependencies = [ [[package]] name = "camino" -version = "1.1.4" +version = "1.1.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c530edf18f37068ac2d977409ed5cd50d53d73bc653c7647b48eb78976ac9ae2" +checksum = "c59e92b5a388f549b863a7bea62612c09f24c8393560709a54558a9abdfb3b9c" dependencies = [ "serde", ] @@ -715,9 +706,9 @@ dependencies = [ [[package]] name = "cargo-platform" -version = "0.1.2" +version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cbdb825da8a5df079a43676dbe042702f1707b1109f713a01420fbb4cc71fa27" +checksum = "2cfa25e60aea747ec7e1124f238816749faa93759c6ff5b31f1ccdda137f4479" dependencies = [ "serde", ] @@ -785,7 +776,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c3613f74bd2eac03dad61bd53dbe620703d4371614fe0bc3b9f04dd36fe4e818" dependencies = [ "cfg-if 1.0.0", - "cipher 0.4.4", + "cipher", "cpufeatures", ] @@ -797,20 +788,20 @@ checksum = "10cd79432192d1c0f4e1a0fef9527696cc039165d729fb41b3f4f4f354c2dc35" dependencies = [ "aead", "chacha20", - "cipher 0.4.4", + "cipher", "poly1305", "zeroize", ] [[package]] name = "chrono" -version = "0.4.24" +version = "0.4.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4e3c5919066adf22df73762e50cffcde3a758f2a848b113b586d1f86728b673b" +checksum = "ec837a71355b28f6556dbd569b37b3f363091c0bd4b2e735674521b4c5fd9bc5" dependencies = [ + "android-tzdata", "iana-time-zone", "js-sys", - "num-integer", "num-traits", "time 0.1.45", "wasm-bindgen", @@ -844,15 +835,6 @@ dependencies = [ "half", ] -[[package]] -name = "cipher" -version = "0.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ee52072ec15386f770805afd189a01c8841be8696bed250fa2f13c4c0d6dfb7" -dependencies = [ - "generic-array 0.14.7", -] - [[package]] name = "cipher" version = "0.4.4" @@ -1148,7 +1130,7 @@ checksum = "8b201220ac5762353f9313fbbc3c4cee2a6a924c16c17df51517644991575cc1" dependencies = [ "anyhow", "bech32 0.8.1", - "bitflags", + "bitflags 1.3.2", "bytes", "ckb-crypto", "ckb-dao-utils", @@ -1277,7 +1259,7 @@ checksum = "a0610544180c38b88101fecf2dd634b174a62eef6946f84dfc6a7127512b381c" dependencies = [ "ansi_term", "atty", - "bitflags", + "bitflags 1.3.2", "strsim 0.8.0", "textwrap 0.11.0", "unicode-width", @@ -1292,10 +1274,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4ea181bf566f71cb9a5d17a59e1871af638180a18fb0035c92ae62b705207123" dependencies = [ "atty", - "bitflags", - "clap_derive 3.2.25", + "bitflags 1.3.2", "clap_lex 0.2.4", - "indexmap", + "indexmap 1.9.3", "once_cell", "strsim 0.10.0", "termcolor", @@ -1305,52 +1286,38 @@ dependencies = [ [[package]] name = "clap" -version = "4.2.7" +version = "4.3.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "34d21f9bf1b425d2968943631ec91202fe5e837264063503708b83013f8fc938" +checksum = "5fd304a20bff958a57f04c4e96a2e7594cc4490a0e809cbd48bb6437edaa452d" dependencies = [ "clap_builder", - "clap_derive 4.2.0", + "clap_derive", "once_cell", ] [[package]] name = "clap_builder" -version = "4.2.7" +version = "4.3.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "914c8c79fb560f238ef6429439a30023c862f7a28e688c58f7203f12b29970bd" +checksum = "01c6a3f08f1fe5662a35cfe393aec09c4df95f60ee93b7556505260f75eee9e1" dependencies = [ "anstream", "anstyle", - "bitflags", - "clap_lex 0.4.1", + "clap_lex 0.5.0", "once_cell", "strsim 0.10.0", ] [[package]] name = "clap_derive" -version = "3.2.25" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ae6371b8bdc8b7d3959e9cf7b22d4435ef3e79e138688421ec654acf8c81b008" -dependencies = [ - "heck", - "proc-macro-error", - "proc-macro2", - "quote", - "syn 1.0.109", -] - -[[package]] -name = "clap_derive" -version = "4.2.0" +version = "4.3.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f9644cd56d6b87dbe899ef8b053e331c0637664e9e21a33dfcdc36093f5c5c4" +checksum = "54a9bb5758fc5dfe728d1019941681eccaf0cf8a4189b692a0ee2f2ecf90a050" dependencies = [ "heck", "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] @@ -1364,9 +1331,9 @@ dependencies = [ [[package]] name = "clap_lex" -version = "0.4.1" +version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a2dd5a6fe8c6e3502f568a6353e5273bbb15193ad9a89e457b9970798efbea1" +checksum = "2da6da31387c7e4ef160ffab6d5e7f00c42626fe39aea70a7b0f1773f7dd6c1b" [[package]] name = "clear_on_drop" @@ -1383,7 +1350,7 @@ version = "0.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ddfc5b9aa5d4507acaf872de71051dfd0e309860e88966e1051e462a077aac4f" dependencies = [ - "bitflags", + "bitflags 1.3.2", ] [[package]] @@ -1395,13 +1362,13 @@ dependencies = [ "bincode", "bs58", "coins-core", - "digest 0.10.6", - "getrandom 0.2.9", + "digest 0.10.7", + "getrandom 0.2.10", "hmac", "k256", "lazy_static", "serde", - "sha2 0.10.6", + "sha2 0.10.7", "thiserror", ] @@ -1413,12 +1380,12 @@ checksum = "84f4d04ee18e58356accd644896aeb2094ddeafb6a713e056cef0c0a8e468c15" dependencies = [ "bitvec 0.17.4", "coins-bip32", - "getrandom 0.2.9", + "getrandom 0.2.10", "hmac", "once_cell", - "pbkdf2 0.12.1", + "pbkdf2 0.12.2", "rand 0.8.5", - "sha2 0.10.6", + "sha2 0.10.7", "thiserror", ] @@ -1428,16 +1395,16 @@ version = "0.8.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9b949a1c63fb7eb591eb7ba438746326aedf0ae843e51ec92ba6bec5bb382c4f" dependencies = [ - "base64 0.21.0", + "base64 0.21.2", "bech32 0.7.3", "bs58", - "digest 0.10.6", + "digest 0.10.7", "generic-array 0.14.7", "hex", "ripemd", "serde", "serde_derive", - "sha2 0.10.6", + "sha2 0.10.7", "sha3", "thiserror", ] @@ -1499,7 +1466,7 @@ dependencies = [ "serde_json", "stringreader", "tentacle-multiaddr", - "toml 0.7.3", + "toml 0.7.6", ] [[package]] @@ -1507,7 +1474,7 @@ name = "common-crypto" version = "0.2.1" dependencies = [ "axon-protocol", - "criterion 0.4.0", + "criterion", "ophelia", "ophelia-blst", "ophelia-secp256k1", @@ -1556,7 +1523,7 @@ name = "common-merkle" version = "0.2.1" dependencies = [ "axon-protocol", - "criterion 0.4.0", + "criterion", "hasher", "rand 0.7.3", "rlp", @@ -1567,38 +1534,11 @@ dependencies = [ name = "common-pubsub" version = "0.2.1" -[[package]] -name = "console" -version = "0.14.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3993e6445baa160675931ec041a5e03ca84b9c6e32a056150d3aa2bdda0a1f45" -dependencies = [ - "encode_unicode", - "lazy_static", - "libc", - "regex", - "terminal_size", - "unicode-width", - "winapi", -] - -[[package]] -name = "console" -version = "0.15.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c3d79fbe8970a77e3e34151cc13d3b3e248aa0faaecb9f6091fa07ebefe5ad60" -dependencies = [ - "encode_unicode", - "lazy_static", - "libc", - "windows-sys 0.42.0", -] - [[package]] name = "const-oid" -version = "0.9.2" +version = "0.9.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "520fbf3c07483f94e3e3ca9d0cfd913d7718ef2483d2cfd91c0d9e91474ab913" +checksum = "795bc6e66a8e340f075fcf6227e417a2dc976b92b91f3cdc778bb858778b6747" [[package]] name = "constant_time_eq" @@ -1642,7 +1582,7 @@ name = "core-cli" version = "0.1.0" dependencies = [ "axon-protocol", - "clap 4.2.7", + "clap 4.3.19", "common-config-parser", "common-logger", "core-run", @@ -1669,7 +1609,7 @@ dependencies = [ "core-mempool", "core-network", "core-storage", - "criterion 0.4.0", + "criterion", "futures", "json", "lazy_static", @@ -1703,7 +1643,7 @@ dependencies = [ "core-interoperation", "core-rpc-client", "core-storage", - "criterion 0.5.1", + "criterion", "ethabi 18.0.0", "ethabi-contract", "ethabi-derive", @@ -1715,16 +1655,17 @@ dependencies = [ "hasher", "lazy_static", "log", - "lru 0.10.0", + "lru 0.10.1", "molecule", "parking_lot 0.12.1", "revm", + "revm-interpreter", "ripemd", "rlp", "rlp-derive", "rug", "serde_json", - "sha2 0.10.6", + "sha2 0.10.7", "substrate-bn", "tempfile", "thiserror", @@ -1742,9 +1683,9 @@ dependencies = [ [[package]] name = "core-foundation-sys" -version = "0.8.4" +version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e496a50fda8aacccc86d7529e2c1e0892dbd0f898a6b5645b5561b89c3210efa" +checksum = "a385f5d34e5eff161df2369056a3fd194fcabd8a64ce0eed02de09fcb3203434" [[package]] name = "core-interoperation" @@ -1783,7 +1724,7 @@ dependencies = [ "core-executor", "core-interoperation", "core-network", - "criterion 0.4.0", + "criterion", "crossbeam-queue", "dashmap", "futures", @@ -1862,7 +1803,7 @@ dependencies = [ "serde_json", "tikv-jemalloc-ctl", "tikv-jemallocator", - "toml 0.7.3", + "toml 0.7.6", ] [[package]] @@ -1876,29 +1817,29 @@ dependencies = [ "common-apm-derive", "common-config-parser", "common-crypto", - "criterion 0.4.0", + "criterion", "futures", "lazy_static", "log", - "lru 0.10.0", + "lru 0.10.1", "num-traits", "parking_lot 0.12.1", ] [[package]] name = "cpp_demangle" -version = "0.4.1" +version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2c76f98bdfc7f66172e6c7065f981ebb576ffc903fe4c0561d9f0c2509226dc6" +checksum = "ee34052ee3d93d6d8f3e6f81d85c47921f6653a19a7b70e939e3e602d893a674" dependencies = [ "cfg-if 1.0.0", ] [[package]] name = "cpufeatures" -version = "0.2.7" +version = "0.2.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3e4c1eaa2012c47becbbad2ab175484c2a84d1185b566fb2cc5b8707343dfe58" +checksum = "a17b76ff3a4162b0b27f354a0c87015ddad39d35f9c0c36607a3bdd175dde1f1" dependencies = [ "libc", ] @@ -1930,7 +1871,7 @@ dependencies = [ "anes", "cast", "ciborium", - "clap 4.2.7", + "clap 4.3.19", "criterion-plot", "futures", "is-terminal", @@ -1949,32 +1890,6 @@ dependencies = [ "walkdir", ] -[[package]] -name = "criterion" -version = "0.5.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f2b12d017a929603d80db1831cd3a24082f8137ce19c69e6447f54f5fc8d692f" -dependencies = [ - "anes", - "cast", - "ciborium", - "clap 4.2.7", - "criterion-plot", - "is-terminal", - "itertools", - "num-traits", - "once_cell", - "oorandom", - "plotters", - "rayon", - "regex", - "serde", - "serde_derive", - "serde_json", - "tinytemplate", - "walkdir", -] - [[package]] name = "criterion-plot" version = "0.5.0" @@ -2008,9 +1923,9 @@ dependencies = [ [[package]] name = "crossbeam-epoch" -version = "0.9.14" +version = "0.9.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "46bd5f3f85273295a9d14aedfb86f6aadbff6d8f5295c4a9edb08e819dcf5695" +checksum = "ae211234986c545741a7dc064309f67ee1e5ad243d0e48335adc0484d960bcc7" dependencies = [ "autocfg", "cfg-if 1.0.0", @@ -2031,9 +1946,9 @@ dependencies = [ [[package]] name = "crossbeam-utils" -version = "0.8.15" +version = "0.8.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c063cd8cc95f5c377ed0d4b49a4b21f632396ff690e8470c29b3359b346984b" +checksum = "5a22b2d63d4d1dc0b7f1b6b2747dd0088008a9be28b6ddf0b1e7d335e3037294" dependencies = [ "cfg-if 1.0.0", ] @@ -2089,7 +2004,7 @@ version = "0.9.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0369ee1ad671834580515889b80f2ea915f23b8be8d0daa4bbaf2ac5c7590835" dependencies = [ - "cipher 0.4.4", + "cipher", ] [[package]] @@ -2113,32 +2028,38 @@ dependencies = [ [[package]] name = "dashmap" -version = "5.4.0" +version = "5.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "907076dfda823b0b36d2a1bb5f90c96660a5bbcd7729e10727f07858f22c4edc" +checksum = "6943ae99c34386c84a470c499d3414f66502a41340aa895406e0d2e4a207b91d" dependencies = [ "cfg-if 1.0.0", - "hashbrown 0.12.3", + "hashbrown 0.14.0", "lock_api", "once_cell", - "parking_lot_core 0.9.7", + "parking_lot_core 0.9.8", "rayon", ] +[[package]] +name = "data-encoding" +version = "2.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c2e66c9d817f1720209181c316d28635c050fa304f9c79e47a520882661b7308" + [[package]] name = "debugid" version = "0.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bef552e6f588e446098f6ba40d89ac146c8c7b64aade83c051ee00bb5d2bc18d" dependencies = [ - "uuid 1.3.3", + "uuid 1.4.1", ] [[package]] name = "der" -version = "0.7.5" +version = "0.7.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "05e58dffcdcc8ee7b22f0c1f71a69243d7c2d9ad87b5a14361f2424a1565c219" +checksum = "0c7ed52955ce76b1554f509074bb357d3fb8ac9b51288a65a3fd480d1dfba946" dependencies = [ "const-oid", "zeroize", @@ -2174,18 +2095,6 @@ version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3c877555693c14d2f84191cfd3ad8582790fc52b5e2274b40b59cf5f5cea25c7" -[[package]] -name = "dialoguer" -version = "0.8.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c9dd058f8b65922819fabb4a41e7d1964e56344042c26efbccd465202c23fa0c" -dependencies = [ - "console 0.14.1", - "lazy_static", - "tempfile", - "zeroize", -] - [[package]] name = "diff" version = "0.1.13" @@ -2212,9 +2121,9 @@ dependencies = [ [[package]] name = "digest" -version = "0.10.6" +version = "0.10.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8168378f4e5023e7218c89c891c0fd8ecdb5e5e4f18cb78f38cf245dd021e76f" +checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" dependencies = [ "block-buffer 0.10.4", "const-oid", @@ -2257,9 +2166,9 @@ checksum = "56ce8c6da7551ec6c462cbaf3bfbc75131ebbfa1c944aeaa9dab51ca1c5f0c3b" [[package]] name = "dyn-clone" -version = "1.0.11" +version = "1.0.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68b0cf012f1230e43cd00ebb729c6bb58707ecfa8ad08b52ef3a4ccd2697fc30" +checksum = "304e6508efa593091e97a9abbc10f90aa7ca635b6d2784feff3c89d41dd12272" [[package]] name = "eaglesong" @@ -2269,12 +2178,12 @@ checksum = "8d978bd5d343e8ab9b5c0fc8d93ff9c602fdc96616ffff9c05ac7a155419b824" [[package]] name = "ecdsa" -version = "0.16.7" +version = "0.16.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0997c976637b606099b9985693efa3581e84e41f5c11ba5255f88711058ad428" +checksum = "a4b1e0c257a9e9f25f90ff76d7a68360ed497ee519c8e428d1825ef0000799d4" dependencies = [ "der", - "digest 0.10.6", + "digest 0.10.7", "elliptic-curve", "rfc6979", "signature 2.1.0", @@ -2315,22 +2224,22 @@ dependencies = [ [[package]] name = "either" -version = "1.8.1" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7fcaabb2fef8c910e7f4c7ce9f67a1283a1715879a7c230ca9d6d1ae31f16d91" +checksum = "a26ae43d7bcc3b814de94796a5e736d4029efb0ee900c12e2d54c993ad1a1e07" dependencies = [ "serde", ] [[package]] name = "elliptic-curve" -version = "0.13.4" +version = "0.13.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "75c71eaa367f2e5d556414a8eea812bc62985c879748d6403edabd9cb03f16e7" +checksum = "968405c8fdc9b3bf4df0a6638858cc0b52462836ab6b1c87377785dd09cf1c0b" dependencies = [ "base16ct", "crypto-bigint", - "digest 0.10.6", + "digest 0.10.7", "ff", "generic-array 0.14.7", "group", @@ -2350,12 +2259,6 @@ dependencies = [ "log", ] -[[package]] -name = "encode_unicode" -version = "0.3.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a357d28ed41a50f9c765dbfe56cbc04a64e53e5fc58ba79fbc34c10ef3df831f" - [[package]] name = "encoding_rs" version = "0.8.32" @@ -2395,6 +2298,17 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "enumn" +version = "0.1.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b893c4eb2dc092c811165f84dc7447fae16fb66521717968c34c509b39b1a5c5" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.27", +] + [[package]] name = "env_logger" version = "0.10.0" @@ -2414,6 +2328,12 @@ version = "1.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e48c92028aaa870e83d51c64e5d4e0b6981b360c522198c23959f219a4e1b15b" +[[package]] +name = "equivalent" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" + [[package]] name = "errno" version = "0.3.1" @@ -2441,9 +2361,9 @@ version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1fda3bf123be441da5260717e0661c25a2fd9cb2b2c1d20bf2e05580047158ab" dependencies = [ - "aes 0.8.2", + "aes", "ctr", - "digest 0.10.6", + "digest 0.10.7", "hex", "hmac", "pbkdf2 0.11.0", @@ -2451,7 +2371,7 @@ dependencies = [ "scrypt", "serde", "serde_json", - "sha2 0.10.6", + "sha2 0.10.7", "sha3", "thiserror", "uuid 0.8.2", @@ -2585,9 +2505,9 @@ dependencies = [ [[package]] name = "ethers" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d5486fdc149826f38c388f26a7df72534ee3f20d3a3f72539376fa7b3bbc43d" +checksum = "96b4026b97da8281276744741fac7eb385da905f6093c583331fa2953fdd4253" dependencies = [ "ethers-addressbook", "ethers-contract", @@ -2601,9 +2521,9 @@ dependencies = [ [[package]] name = "ethers-addressbook" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1c66a426b824a0f6d1361ad74b6b01adfd26c44ee1e14c3662dcf28406763ec5" +checksum = "edcb6ffefc230d8c42874c51b28dc11dbb8de50b27a8fdf92648439d6baa68dc" dependencies = [ "ethers-core", "once_cell", @@ -2613,14 +2533,15 @@ dependencies = [ [[package]] name = "ethers-contract" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dfa43e2e69632492d7b38e59465d125a0066cf4c477390ece00d3acbd11b338b" +checksum = "0d4719a44c3d37ab07c6dea99ab174068d8c35e441b60b6c20ce4e48357273e8" dependencies = [ "ethers-contract-abigen", "ethers-contract-derive", "ethers-core", "ethers-providers", + "ethers-signers", "futures-util", "hex", "once_cell", @@ -2632,36 +2553,33 @@ dependencies = [ [[package]] name = "ethers-contract-abigen" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2edb8fdbf77459819a443234b461171a024476bfc12f1853b889a62c6e1185ff" +checksum = "155ea1b84d169d231317ed86e307af6f2bed6b40dd17e5e94bc84da21cadb21c" dependencies = [ "Inflector", "dunce", "ethers-core", "ethers-etherscan", "eyre", - "getrandom 0.2.9", "hex", - "prettyplease 0.2.5", + "prettyplease 0.2.12", "proc-macro2", "quote", "regex", "reqwest", "serde", "serde_json", - "syn 2.0.16", - "tokio", - "toml 0.7.3", - "url", + "syn 2.0.27", + "toml 0.7.6", "walkdir", ] [[package]] name = "ethers-contract-derive" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "939b0c37746929f869285ee37d270b7c998d80cc7404c2e20dda8efe93e3b295" +checksum = "8567ff196c4a37c1a8c90ec73bda0ad2062e191e4f0a6dc4d943e2ec4830fc88" dependencies = [ "Inflector", "ethers-contract-abigen", @@ -2670,14 +2588,14 @@ dependencies = [ "proc-macro2", "quote", "serde_json", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] name = "ethers-core" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "198ea9efa8480fa69f73d31d41b1601dace13d053c6fe4be6f5878d9dfcf0108" +checksum = "60ca2514feb98918a0a31de7e1983c29f2267ebf61b2dc5d4294f91e5b866623" dependencies = [ "arrayvec", "bytes", @@ -2686,7 +2604,6 @@ dependencies = [ "elliptic-curve", "ethabi 18.0.0", "generic-array 0.14.7", - "getrandom 0.2.9", "hex", "k256", "num_enum 0.6.1", @@ -2697,7 +2614,7 @@ dependencies = [ "serde", "serde_json", "strum", - "syn 2.0.16", + "syn 2.0.27", "tempfile", "thiserror", "tiny-keccak", @@ -2706,13 +2623,11 @@ dependencies = [ [[package]] name = "ethers-etherscan" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "196a21d6939ab78b7a1e4c45c2b33b0c2dd821a2e1af7c896f06721e1ba2a0c7" +checksum = "22b3a8269d3df0ed6364bc05b4735b95f4bf830ce3aef87d5e760fb0e93e5b91" dependencies = [ "ethers-core", - "ethers-solc", - "getrandom 0.2.9", "reqwest", "semver", "serde", @@ -2723,9 +2638,9 @@ dependencies = [ [[package]] name = "ethers-middleware" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "75594cc450992fc7de701c9145de612325fd8a18be765b8ae78767ba2b74876f" +checksum = "e0c339aad74ae5c451d27e0e49c7a3c7d22620b119b4f9291d7aa21f72d7f366" dependencies = [ "async-trait", "auto_impl", @@ -2750,20 +2665,19 @@ dependencies = [ [[package]] name = "ethers-providers" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1009041f40476b972b5d79346cc512e97c662b1a0a2f78285eabe9a122909783" +checksum = "b411b119f1cf0efb69e2190883dee731251882bb21270f893ee9513b3a697c48" dependencies = [ "async-trait", "auto_impl", - "base64 0.21.0", + "base64 0.21.2", "bytes", "enr", "ethers-core", "futures-core", "futures-timer", "futures-util", - "getrandom 0.2.9", "hashers", "hex", "http", @@ -2787,9 +2701,9 @@ dependencies = [ [[package]] name = "ethers-signers" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c3bd11ad6929f01f01be74bb00d02bbd6552f22de030865c898b340a3a592db1" +checksum = "4864d387456a9c09a1157fa10e1528b29d90f1d859443acf06a1b23365fb518c" dependencies = [ "async-trait", "coins-bip32", @@ -2799,21 +2713,20 @@ dependencies = [ "ethers-core", "hex", "rand 0.8.5", - "sha2 0.10.6", + "sha2 0.10.7", "thiserror", "tracing", ] [[package]] name = "ethers-solc" -version = "2.0.4" +version = "2.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2284784306de73d8ad1bc792ecc1b87da0268185683698d60fd096d23d168c99" +checksum = "7a6c2b9625a2c639d46625f88acc2092a3cb35786c37f7c2128b3ca20f639b3c" dependencies = [ "cfg-if 1.0.0", "dunce", "ethers-core", - "getrandom 0.2.9", "glob", "hex", "home", @@ -2931,12 +2844,9 @@ dependencies = [ [[package]] name = "fastrand" -version = "1.9.0" +version = "2.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e51093e27b0797c359783294ca4f0a911c270184cb10f85783b118614a1501be" -dependencies = [ - "instant", -] +checksum = "6999dc1837253364c2ebb0704ba97994bd874e8f195d665c50b7548f6ea92764" [[package]] name = "ff" @@ -2998,7 +2908,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3b9429470923de8e8cbd4d2dc513535400b4b3fef0319fb5c4e1f520a7bef743" dependencies = [ "crc32fast", - "miniz_oxide 0.7.1", + "miniz_oxide", ] [[package]] @@ -3024,9 +2934,9 @@ checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" [[package]] name = "form_urlencoded" -version = "1.1.0" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a9c384f161156f5260c24a097c56119f9be8c798586aecc13afbcbe7b7e26bf8" +checksum = "a62bc1cf6f830c2ec14a513a9fb124d0a213a629668a4186f329db21fe045652" dependencies = [ "percent-encoding", ] @@ -3130,7 +3040,7 @@ checksum = "89ca545a94061b6365f2c7355b4b32bd20df3ff95f02da9329b34ccc3bd6ee72" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] @@ -3234,9 +3144,9 @@ dependencies = [ [[package]] name = "getrandom" -version = "0.2.9" +version = "0.2.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c85e1d9ab2eadba7e5040d4e09cbd6d072b76a557ad64e797c2cb9d4da21d7e4" +checksum = "be4136b2a15dd319360be1c07d9933517ccf0be8f16bf62a3bee4f0d618df427" dependencies = [ "cfg-if 1.0.0", "js-sys", @@ -3247,9 +3157,9 @@ dependencies = [ [[package]] name = "gimli" -version = "0.27.2" +version = "0.27.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ad0a93d233ebf96623465aad4046a8d3aa4da22d4f4beba5388838c8a434bbb4" +checksum = "b6c80984affa11d98d1b88b66ac8853f143217b399d3c74116778ff8fdb4ed2e" [[package]] name = "glob" @@ -3259,11 +3169,11 @@ checksum = "d2fabcfbdc87f4758337ca535fb41a6d701b65693ce38287d856d1674551ec9b" [[package]] name = "globset" -version = "0.4.10" +version = "0.4.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "029d74589adefde59de1a0c4f4732695c32805624aec7b68d91503d4dba79afc" +checksum = "1391ab1f92ffcc08911957149833e682aa3fe252b9f45f966d2ef972274c97df" dependencies = [ - "aho-corasick 0.7.20", + "aho-corasick", "bstr", "fnv", "log", @@ -3284,9 +3194,9 @@ dependencies = [ [[package]] name = "gmp-mpfr-sys" -version = "1.5.2" +version = "1.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b560063e2ffa8ce9c2ef9bf487f2944a97deca5b8de0b5bcd0ae6437ef8b75f" +checksum = "13eabc29d16e4a621b495e3919c71ebb7caaed24380955671e7d417370fea95d" dependencies = [ "libc", "windows-sys 0.42.0", @@ -3327,9 +3237,9 @@ dependencies = [ [[package]] name = "h2" -version = "0.3.19" +version = "0.3.20" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d357c7ae988e7d2182f7d7871d0b963962420b0678b0997ce7de72001aeab782" +checksum = "97ec8491ebaf99c8eaa73058b045fe58073cd6be7f596ac993ced0b0a0c01049" dependencies = [ "bytes", "fnv", @@ -3337,7 +3247,7 @@ dependencies = [ "futures-sink", "futures-util", "http", - "indexmap", + "indexmap 1.9.3", "slab", "tokio", "tokio-util", @@ -3383,6 +3293,12 @@ dependencies = [ "ahash 0.8.3", ] +[[package]] +name = "hashbrown" +version = "0.14.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2c6201b9ff9fd90a5a3bac2e56a830d0caa509576f0e503818ee82c181b3437a" + [[package]] name = "hasher" version = "0.1.4" @@ -3427,18 +3343,9 @@ dependencies = [ [[package]] name = "hermit-abi" -version = "0.2.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ee512640fe35acbfb4bb779db6f0d80704c2cacfa2e39b601ef3e3f47d1ae4c7" -dependencies = [ - "libc", -] - -[[package]] -name = "hermit-abi" -version = "0.3.1" +version = "0.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fed44880c466736ef9a5c5b5facefb5ed0785676d0c02d612db14e54f0d84286" +checksum = "443144c8cdadd93ebf52ddb4056d257f5b52c04d3c804e657d19eb73fc33668b" [[package]] name = "hex" @@ -3446,13 +3353,19 @@ version = "0.4.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70" +[[package]] +name = "hex-literal" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6fe2267d4ed49bc07b63801559be28c718ea06c4738b7a03c94df7386d2cde46" + [[package]] name = "hmac" version = "0.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6c49c37c09c17a53d937dfbb742eb3a961d65a994e6bcdcf37e7399d0cc8ab5e" dependencies = [ - "digest 0.10.6", + "digest 0.10.7", ] [[package]] @@ -3526,9 +3439,9 @@ dependencies = [ [[package]] name = "hyper" -version = "0.14.26" +version = "0.14.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ab302d72a6f11a3b910431ff93aae7e773078c769f0a3ef15fb9ec692ed147d4" +checksum = "ffb1cfd654a8219eaef89881fdb3bb3b1cdc5fa75ded05d6933b2b382e395468" dependencies = [ "bytes", "futures-channel", @@ -3550,10 +3463,11 @@ dependencies = [ [[package]] name = "hyper-rustls" -version = "0.23.2" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1788965e61b367cd03a62950836d5cd41560c3577d90e40e0819373194d1661c" +checksum = "8d78e1e73ec14cf7375674f74d7dde185c8206fd9dea6fb6295e8a98098aaa97" dependencies = [ + "futures-util", "http", "hyper", "rustls", @@ -3576,9 +3490,9 @@ dependencies = [ [[package]] name = "iana-time-zone" -version = "0.1.56" +version = "0.1.57" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0722cd7114b7de04316e7ea5456a0bbb20e4adb46fd27a3697adb812cff0f37c" +checksum = "2fad5b825842d2b38bd206f3e81d6957625fd7f0a361e345c30e01a0ae2dd613" dependencies = [ "android_system_properties", "core-foundation-sys", @@ -3599,9 +3513,9 @@ dependencies = [ [[package]] name = "idna" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e14ddfc70884202db2244c223200c204c2bda1bc6e0998d11b5e024d657209e6" +checksum = "7d20d6b07bfbc108882d88ed8e37d39636dcc260e15e30c45e6ba089610b917c" dependencies = [ "unicode-bidi", "unicode-normalization", @@ -3692,15 +3606,13 @@ dependencies = [ ] [[package]] -name = "indicatif" -version = "0.16.2" +name = "indexmap" +version = "2.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2d207dc617c7a380ab07ff572a6e52fa202a2a8f355860ac9c38e23f8196be1b" +checksum = "d5477fe2230a79769d8dc68e0eabf5437907c0457a5614a9e8dddb67f65eb65d" dependencies = [ - "console 0.15.5", - "lazy_static", - "number_prefix", - "regex", + "equivalent", + "hashbrown 0.14.0", ] [[package]] @@ -3721,22 +3633,11 @@ dependencies = [ "cfg-if 1.0.0", ] -[[package]] -name = "io-lifetimes" -version = "1.0.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c66c74d2ae7e79a5a8f7ac924adbe38ee42a859c6539ad869eb51f0b52dc220" -dependencies = [ - "hermit-abi 0.3.1", - "libc", - "windows-sys 0.48.0", -] - [[package]] name = "ipnet" -version = "2.7.2" +version = "2.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "12b6ee2129af8d4fb011108c73d99a1b83a85977f23b82460c0ae2e25bb4b57f" +checksum = "28b29a3cd74f0f4598934efe3aeba42bae0eb4680554128851ebbecb02af14e6" [[package]] name = "ipnetwork" @@ -3749,12 +3650,11 @@ dependencies = [ [[package]] name = "is-terminal" -version = "0.4.7" +version = "0.4.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "adcf93614601c8129ddf72e2d5633df827ba6551541c6d8c59520a371475be1f" +checksum = "cb0889898416213fab133e1d33a0e5858a48177452750691bde3666d0fdbaf8b" dependencies = [ - "hermit-abi 0.3.1", - "io-lifetimes", + "hermit-abi 0.3.2", "rustix", "windows-sys 0.48.0", ] @@ -3770,9 +3670,9 @@ dependencies = [ [[package]] name = "itoa" -version = "1.0.6" +version = "1.0.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "453ad9f582a441959e5f0d088b02ce04cfe8d51a8eaf077f12ac6d3e94164ca6" +checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" [[package]] name = "jobserver" @@ -3911,7 +3811,7 @@ dependencies = [ "ecdsa", "elliptic-curve", "once_cell", - "sha2 0.10.6", + "sha2 0.10.7", "signature 2.1.0", ] @@ -3926,9 +3826,9 @@ dependencies = [ [[package]] name = "lalrpop" -version = "0.19.12" +version = "0.20.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0a1cbf952127589f2851ab2046af368fd20645491bb4b376f04b7f94d7a9837b" +checksum = "da4081d44f4611b66c6dd725e6de3169f9f63905421e8626fcb86b6a898998b8" dependencies = [ "ascii-canvas", "bit-set", @@ -3939,7 +3839,7 @@ dependencies = [ "lalrpop-util", "petgraph", "regex", - "regex-syntax 0.6.29", + "regex-syntax", "string_cache", "term", "tiny-keccak", @@ -3948,12 +3848,9 @@ dependencies = [ [[package]] name = "lalrpop-util" -version = "0.19.12" +version = "0.20.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d3c48237b9604c5a4702de6b824e02006c3214327564636aef27c1028a8fa0ed" -dependencies = [ - "regex", -] +checksum = "3f35c735096c0293d313e8f2a641627472b83d01b937177fe76e5e2708d31e0d" [[package]] name = "lazy_static" @@ -3972,9 +3869,9 @@ checksum = "830d08ce1d1d941e6b30645f1a0eb5643013d835ce3779a5fc208261dbe10f55" [[package]] name = "libc" -version = "0.2.144" +version = "0.2.147" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2b00cc1c228a6782d0f076e7b232802e0c5689d41bb5df366f2a6b6621cfdfe1" +checksum = "b4668fb0ea861c1df094127ac5f1da3409a82116a4ba74fca2e58ef927159bb3" [[package]] name = "libloading" @@ -4006,15 +3903,15 @@ dependencies = [ [[package]] name = "linux-raw-sys" -version = "0.3.7" +version = "0.4.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ece97ea872ece730aed82664c424eb4c8291e1ff2480247ccf7409044bc6479f" +checksum = "09fc20d2ca12cb9f044c93e3bd6d32d523e6e2ec3db4f7b2939cd99026ecd3f0" [[package]] name = "lock_api" -version = "0.4.9" +version = "0.4.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "435011366fe56583b16cf956f9df0095b405b82d76425bc8981c0e22e60ec4df" +checksum = "c1cc9717a20b1bb222f333e6a92fd32f7d8a18ddc5a3191a11af45dcbf4dcd16" dependencies = [ "autocfg", "scopeguard", @@ -4022,11 +3919,10 @@ dependencies = [ [[package]] name = "log" -version = "0.4.17" +version = "0.4.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "abb12e687cfb44aa40f41fc3978ef76448f9b6038cad6aef4259d3c095a2382e" +checksum = "b06a4cde4c0f271a446782e3eff8de789548ce57dbc8eca9292c27f4a42004b4" dependencies = [ - "cfg-if 1.0.0", "serde", ] @@ -4073,9 +3969,9 @@ dependencies = [ [[package]] name = "lru" -version = "0.10.0" +version = "0.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "03f1160296536f10c833a82dca22267d5486734230d47bf00bf435885814ba1e" +checksum = "718e8fae447df0c7e1ba7f5189829e63fd536945c8988d61444c19039f16b670" dependencies = [ "hashbrown 0.13.2", ] @@ -4098,7 +3994,7 @@ version = "0.10.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6365506850d44bff6e2fbcb5176cf63650e48bd45ef2fe2665ae1570e0f4b9ca" dependencies = [ - "digest 0.10.6", + "digest 0.10.7", ] [[package]] @@ -4118,9 +4014,9 @@ dependencies = [ [[package]] name = "memoffset" -version = "0.8.0" +version = "0.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d61c719bcfbcf5d62b3a09efa6088de8c54bc0bfcd3ea7ae39fcc186108b8de1" +checksum = "5a634b1c61a95585bd15607c6ab0c4e5b226e695ff2800ba0cdccddf208c406c" dependencies = [ "autocfg", ] @@ -4146,15 +4042,6 @@ version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" -[[package]] -name = "miniz_oxide" -version = "0.6.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b275950c28b37e794e8c55d88aeb5e139d0ce23fdbbeda68f8d7174abdf9e8fa" -dependencies = [ - "adler", -] - [[package]] name = "miniz_oxide" version = "0.7.1" @@ -4177,14 +4064,13 @@ dependencies = [ [[package]] name = "mio" -version = "0.8.6" +version = "0.8.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b9d9a46eff5b4ff64b45a9e316a6d1e0bc719ef429cbec4dc630684212bfdf9" +checksum = "927a765cd3fc26206e66b296465fa9d3e5ab003e651c1b3c060e7956d96b19d2" dependencies = [ "libc", - "log", "wasi 0.11.0+wasi-snapshot-preview1", - "windows-sys 0.45.0", + "windows-sys 0.48.0", ] [[package]] @@ -4262,7 +4148,7 @@ version = "0.26.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bfdda3d196821d6af13126e40375cdf7da646a96114af134d5f417a9a1dc8e1a" dependencies = [ - "bitflags", + "bitflags 1.3.2", "cfg-if 1.0.0", "libc", "static_assertions", @@ -4298,9 +4184,9 @@ checksum = "0676bb32a98c1a483ce53e500a81ad9c3d5b3f7c920c28c24e9cb0980d0b5bc8" [[package]] name = "num" -version = "0.4.0" +version = "0.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "43db66d1170d347f9a065114077f7dccb00c1b9478c89384490a3425279a4606" +checksum = "b05180d69e3da0e530ba2a1dae5110317e49e3b7f3d41be227dc5f92e49ee7af" dependencies = [ "num-bigint", "num-complex", @@ -4365,20 +4251,20 @@ dependencies = [ [[package]] name = "num-traits" -version = "0.2.15" +version = "0.2.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "578ede34cf02f8924ab9447f50c28075b4d3e5b269972345e7e0372b38c6cdcd" +checksum = "f30b0abd723be7e2ffca1272140fac1a2f084c77ec3e123c192b66af1ee9e6c2" dependencies = [ "autocfg", ] [[package]] name = "num_cpus" -version = "1.15.0" +version = "1.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fac9e2da13b5eb447a6ce3d392f23a29d8694bff781bf03a16cd9ac8697593b" +checksum = "4161fcb6d602d4d2081af7c3a45852d875a03dd337a6bfdd6e06407b61342a43" dependencies = [ - "hermit-abi 0.2.6", + "hermit-abi 0.3.2", "libc", ] @@ -4421,15 +4307,9 @@ dependencies = [ "proc-macro-crate", "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] -[[package]] -name = "number_prefix" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "830b246a0e5f20af87141b25c173cd1b609bd7779a4617d6ec582abaf90870f3" - [[package]] name = "numext-constructor" version = "0.1.6" @@ -4478,18 +4358,18 @@ dependencies = [ [[package]] name = "object" -version = "0.30.3" +version = "0.31.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ea86265d3d3dcb6a27fc51bd29a4bf387fae9d2986b823079d4986af253eb439" +checksum = "8bda667d9f2b5051b8833f59f3bf748b28ef54f850f4fcb389a252aa383866d1" dependencies = [ "memchr", ] [[package]] name = "once_cell" -version = "1.17.1" +version = "1.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b7e5500299e16ebb147ae15a00a942af264cf3688f47923b8fc2cd5858f23ad3" +checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" [[package]] name = "oorandom" @@ -4530,11 +4410,11 @@ dependencies = [ [[package]] name = "openssl" -version = "0.10.52" +version = "0.10.55" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "01b8574602df80f7b85fdfc5392fa884a4e3b3f4f35402c070ab34c3d3f78d56" +checksum = "345df152bc43501c5eb9e4654ff05f794effb78d4efe3d53abc158baddc0703d" dependencies = [ - "bitflags", + "bitflags 1.3.2", "cfg-if 1.0.0", "foreign-types", "libc", @@ -4551,7 +4431,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] @@ -4562,9 +4442,9 @@ checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" [[package]] name = "openssl-sys" -version = "0.9.87" +version = "0.9.90" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e17f59264b2809d77ae94f0e1ebabc434773f370d6ca667bd223ea10e06cc7e" +checksum = "374533b0e45f3a7ced10fcaeccca020e66656bc03dac384f852e4e5a7a8104a6" dependencies = [ "cc", "libc", @@ -4648,9 +4528,9 @@ dependencies = [ [[package]] name = "os_str_bytes" -version = "6.5.0" +version = "6.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ceedf44fb00f2d1984b0bc98102627ce622e083e49a5bacdb3e514fa4238e267" +checksum = "4d5d9eb14b174ee9aa2ef96dc2b94637a2d4b6e7cb873c7e171f0c20c6cf3eac" [[package]] name = "overlord" @@ -4678,9 +4558,9 @@ dependencies = [ [[package]] name = "parity-scale-codec" -version = "3.5.0" +version = "3.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5ddb756ca205bd108aee3c62c6d3c994e1df84a59b9d6d4a5ea42ee1fd5a9a28" +checksum = "dd8e946cc0cc711189c0b0249fb8b599cbeeab9784d83c415719368bb8d4ac64" dependencies = [ "arrayvec", "bitvec 1.0.1", @@ -4692,9 +4572,9 @@ dependencies = [ [[package]] name = "parity-scale-codec-derive" -version = "3.1.4" +version = "3.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "86b26a931f824dd4eca30b3e43bb4f31cd5f0d3a403c5f5ff27106b805bfde7b" +checksum = "2a296c3079b5fefbc499e1de58dc26c09b1b9a5952d26694ee89f04a43ebbb3e" dependencies = [ "proc-macro-crate", "proc-macro2", @@ -4720,7 +4600,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" dependencies = [ "lock_api", - "parking_lot_core 0.9.7", + "parking_lot_core 0.9.8", ] [[package]] @@ -4739,15 +4619,15 @@ dependencies = [ [[package]] name = "parking_lot_core" -version = "0.9.7" +version = "0.9.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9069cbb9f99e3a5083476ccb29ceb1de18b9118cafa53e90c9551235de2b9521" +checksum = "93f00c865fe7cabf650081affecd3871070f26767e7b2070a3ffae14c654b447" dependencies = [ "cfg-if 1.0.0", "libc", - "redox_syscall 0.2.16", + "redox_syscall 0.3.5", "smallvec", - "windows-sys 0.45.0", + "windows-targets", ] [[package]] @@ -4763,9 +4643,9 @@ dependencies = [ [[package]] name = "paste" -version = "1.0.12" +version = "1.0.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9f746c4065a8fa3fe23974dd82f15431cc8d40779821001404d10d2e79ca7d79" +checksum = "de3145af08024dea9fa9914f381a17b8fc6034dfb00f3a84013f7ff43f29ed4c" [[package]] name = "path-slash" @@ -4779,19 +4659,19 @@ version = "0.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "83a0692ec44e4cf1ef28ca317f14f8f07da2d95ec3fa01f86e4467b725e60917" dependencies = [ - "digest 0.10.6", + "digest 0.10.7", "hmac", "password-hash", - "sha2 0.10.6", + "sha2 0.10.7", ] [[package]] name = "pbkdf2" -version = "0.12.1" +version = "0.12.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0ca0b5a68607598bf3bad68f32227a8164f6254833f84eafaac409cd6746c31" +checksum = "f8ed6a7761f76e3b9f92dfb0a60a6a6477c61024b775147ff0973a02653abaf2" dependencies = [ - "digest 0.10.6", + "digest 0.10.7", "hmac", ] @@ -4803,9 +4683,9 @@ checksum = "19b17cddbe7ec3f8bc800887bab5e717348c95ea2ca0b1bf0837fb964dc67099" [[package]] name = "percent-encoding" -version = "2.2.0" +version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "478c572c3d73181ff3c2539045f6eb99e5491218eae919370993b890cdbdd98e" +checksum = "9b2a4787296e9989611394c33f193f676704af1686e70b8f8033ab5ba9a35a94" [[package]] name = "petgraph" @@ -4814,7 +4694,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4dd7d28ee937e54fe3080c91faa1c3a46c06de6252988a7f4592ba2310ef22a4" dependencies = [ "fixedbitset", - "indexmap", + "indexmap 1.9.3", ] [[package]] @@ -4838,12 +4718,12 @@ dependencies = [ [[package]] name = "phf" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "928c6535de93548188ef63bb7c4036bd415cd8f36ad25af44b9789b2ee72a48c" +checksum = "ade2d8b8f33c7333b51bcf0428d37e217e9f32192ae4772156f65063b8ce03dc" dependencies = [ "phf_macros", - "phf_shared 0.11.1", + "phf_shared 0.11.2", ] [[package]] @@ -4868,25 +4748,25 @@ dependencies = [ [[package]] name = "phf_generator" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1181c94580fa345f50f19d738aaa39c0ed30a600d95cb2d3e23f94266f14fbf" +checksum = "48e4cc64c2ad9ebe670cb8fd69dd50ae301650392e81c05f9bfcb2d5bdbc24b0" dependencies = [ - "phf_shared 0.11.1", + "phf_shared 0.11.2", "rand 0.8.5", ] [[package]] name = "phf_macros" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "92aacdc5f16768709a569e913f7451034034178b05bdc8acda226659a3dccc66" +checksum = "3444646e286606587e49f3bcf1679b8cef1dc2c5ecc29ddacaffc305180d464b" dependencies = [ - "phf_generator 0.11.1", - "phf_shared 0.11.1", + "phf_generator 0.11.2", + "phf_shared 0.11.2", "proc-macro2", "quote", - "syn 1.0.109", + "syn 2.0.27", ] [[package]] @@ -4909,38 +4789,38 @@ dependencies = [ [[package]] name = "phf_shared" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1fb5f6f826b772a8d4c0394209441e7d37cbbb967ae9c7e0e8134365c9ee676" +checksum = "90fcb95eef784c2ac79119d1dd819e162b5da872ce6f3c3abe1e8ca1c082f72b" dependencies = [ "siphasher", ] [[package]] name = "pin-project" -version = "1.1.0" +version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c95a7476719eab1e366eaf73d0260af3021184f18177925b07f54b30089ceead" +checksum = "030ad2bc4db10a8944cb0d837f158bdfec4d4a4873ab701a95046770d11f8842" dependencies = [ "pin-project-internal", ] [[package]] name = "pin-project-internal" -version = "1.1.0" +version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39407670928234ebc5e6e580247dd567ad73a3578460c5990f9503df207e8f07" +checksum = "ec2e072ecce94ec471b13398d5402c188e76ac03cf74dd1a975161b23a3f6d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] name = "pin-project-lite" -version = "0.2.9" +version = "0.2.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e0a7ae3ac2f1173085d398531c705756c94a4c56843785df85a60c1a0afac116" +checksum = "4c40d25201921e5ff0c862a505c6557ea88568a4e3ace775ab55e93f2f4f9d57" [[package]] name = "pin-utils" @@ -4972,9 +4852,9 @@ checksum = "b4596b6d070b27117e987119b4dac604f3c58cfb0b191112e24771b2faeac1a6" [[package]] name = "plotters" -version = "0.3.4" +version = "0.3.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2538b639e642295546c50fcd545198c9d64ee2a38620a628724a3b266d5fbf97" +checksum = "d2c224ba00d7cadd4d5c660deaf2098e5e80e07846537c51f9cfa4be50c1fd45" dependencies = [ "num-traits", "plotters-backend", @@ -4985,15 +4865,15 @@ dependencies = [ [[package]] name = "plotters-backend" -version = "0.3.4" +version = "0.3.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "193228616381fecdc1224c62e96946dfbc73ff4384fba576e052ff8c1bea8142" +checksum = "9e76628b4d3a7581389a35d5b6e2139607ad7c75b17aed325f210aa91f4a9609" [[package]] name = "plotters-svg" -version = "0.3.3" +version = "0.3.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f9a81d2759aae1dae668f783c308bc5c8ebd191ff4184aaa1b37f65a6ae5a56f" +checksum = "38f6d39893cca0701371e3c27294f09797214b86f1fb951b89ade8ec04e2abab" dependencies = [ "plotters-backend", ] @@ -5026,7 +4906,7 @@ dependencies = [ "prost", "prost-build", "prost-derive", - "sha2 0.10.6", + "sha2 0.10.7", "smallvec", "symbolic-demangle", "tempfile", @@ -5057,12 +4937,12 @@ dependencies = [ [[package]] name = "prettyplease" -version = "0.2.5" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "617feabb81566b593beb4886fb8c1f38064169dae4dccad0e3220160c3b37203" +checksum = "6c64d9ba0963cdcea2e1b2230fbae2bab30eb25a174be395c41e764bfb65dd62" dependencies = [ "proc-macro2", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] @@ -5138,9 +5018,9 @@ dependencies = [ [[package]] name = "proc-macro2" -version = "1.0.57" +version = "1.0.66" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c4ec6d5fe0b140acb27c9a0444118cf55bfbb4e0b259739429abb4521dd67c16" +checksum = "18fb31db3f9bddb2ea821cde30a9f70117e3f119938b5ee630b7403aa6e2ead9" dependencies = [ "unicode-ident", ] @@ -5244,9 +5124,9 @@ dependencies = [ [[package]] name = "quote" -version = "1.0.27" +version = "1.0.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f4f29d145265ec1c483c7c654450edde0bfe043d3938d6972630663356d9500" +checksum = "50f3b39ccfb720540debaa0164757101c08ecb8d326b15358ce76a62c7e85965" dependencies = [ "proc-macro2", ] @@ -5361,7 +5241,7 @@ version = "0.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c" dependencies = [ - "getrandom 0.2.9", + "getrandom 0.2.10", ] [[package]] @@ -5443,7 +5323,7 @@ version = "0.2.16" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fb5a58c1855b4b6819d59012155603f0b22ad30cad752600aadfcb695265519a" dependencies = [ - "bitflags", + "bitflags 1.3.2", ] [[package]] @@ -5452,7 +5332,7 @@ version = "0.3.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "567664f262709473930a4bf9e51bf2ebf3348f2e748ccc50dea20646858f8f29" dependencies = [ - "bitflags", + "bitflags 1.3.2", ] [[package]] @@ -5461,41 +5341,47 @@ version = "0.4.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b033d837a7cf162d7993aded9304e30a83213c648b6e389db233191f891e5c2b" dependencies = [ - "getrandom 0.2.9", + "getrandom 0.2.10", "redox_syscall 0.2.16", "thiserror", ] [[package]] name = "regex" -version = "1.8.1" +version = "1.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "af83e617f331cc6ae2da5443c602dfa5af81e517212d9d611a5b3ba1777b5370" +checksum = "b2eae68fc220f7cf2532e4494aded17545fce192d59cd996e0fe7887f4ceb575" dependencies = [ - "aho-corasick 1.0.1", + "aho-corasick", "memchr", - "regex-syntax 0.7.1", + "regex-automata", + "regex-syntax", ] [[package]] -name = "regex-syntax" -version = "0.6.29" +name = "regex-automata" +version = "0.3.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f162c6dd7b008981e4d40210aca20b4bd0f9b60ca9271061b07f78537722f2e1" +checksum = "39354c10dd07468c2e73926b23bb9c2caca74c5501e38a35da70406f1d923310" +dependencies = [ + "aho-corasick", + "memchr", + "regex-syntax", +] [[package]] name = "regex-syntax" -version = "0.7.1" +version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a5996294f19bd3aae0453a862ad728f60e6600695733dd5df01da90c54363a3c" +checksum = "e5ea92a5b6195c6ef2a0295ea818b312502c6fc94dde986c5553242e18fd4ce2" [[package]] name = "reqwest" -version = "0.11.17" +version = "0.11.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "13293b639a097af28fc8a90f22add145a9c954e49d77da06263d58cf44d5fb91" +checksum = "cde824a14b7c14f85caff81225f411faacc04a2013f41670f41443742b1c1c55" dependencies = [ - "base64 0.21.0", + "base64 0.21.2", "bytes", "encoding_rs", "futures-core", @@ -5527,7 +5413,7 @@ dependencies = [ "wasm-bindgen", "wasm-bindgen-futures", "web-sys", - "webpki-roots", + "webpki-roots 0.22.6", "winreg", ] @@ -5548,6 +5434,39 @@ dependencies = [ "sha3", ] +[[package]] +name = "revm-interpreter" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a53980a26f9b5a66d13511c35074d4b53631e157850a1d7cf1af4efc2c2b72c9" +dependencies = [ + "derive_more", + "enumn", + "revm-primitives", + "sha3", +] + +[[package]] +name = "revm-primitives" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "304d998f466ffef72d76c7f20b05bf08a96801736a6fb1fdef47d49a292618df" +dependencies = [ + "auto_impl", + "bitvec 1.0.1", + "bytes", + "derive_more", + "enumn", + "fixed-hash 0.8.0", + "hashbrown 0.13.2", + "hex", + "hex-literal", + "primitive-types 0.12.1", + "rlp", + "ruint", + "sha3", +] + [[package]] name = "revm_precompiles" version = "1.1.2" @@ -5561,7 +5480,7 @@ dependencies = [ "primitive-types 0.12.1", "ripemd", "secp256k1 0.24.3", - "sha2 0.10.6", + "sha2 0.10.7", "sha3", "substrate-bn", ] @@ -5597,7 +5516,7 @@ version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bd124222d17ad93a644ed9d011a40f4fb64aa54275c08cc216524a9ea82fb09f" dependencies = [ - "digest 0.10.6", + "digest 0.10.7", ] [[package]] @@ -5633,6 +5552,26 @@ dependencies = [ "libc", ] +[[package]] +name = "ruint" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9d470e29e933dac4101180fd6574971892315c414cf2961a192729089687cc9b" +dependencies = [ + "derive_more", + "primitive-types 0.12.1", + "rlp", + "ruint-macro", + "rustc_version", + "thiserror", +] + +[[package]] +name = "ruint-macro" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62cc5760263ea229d367e7dff3c0cbf09e4797a125bd87059a6c095804f3b2d1" + [[package]] name = "rust-ini" version = "0.18.0" @@ -5672,13 +5611,12 @@ dependencies = [ [[package]] name = "rustix" -version = "0.37.19" +version = "0.38.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "acf8729d8542766f1b2cf77eb034d52f40d375bb8b615d0b147089946e16613d" +checksum = "0a962918ea88d644592894bc6dc55acc6c0956488adcebbfb6e273506b7fd6e5" dependencies = [ - "bitflags", + "bitflags 2.3.3", "errno", - "io-lifetimes", "libc", "linux-raw-sys", "windows-sys 0.48.0", @@ -5686,23 +5624,43 @@ dependencies = [ [[package]] name = "rustls" -version = "0.20.8" +version = "0.21.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fff78fc74d175294f4e83b28343315ffcfb114b156f0185e9741cb5570f50e2f" +checksum = "79ea77c539259495ce8ca47f53e66ae0330a8819f67e23ac96ca02f50e7b7d36" dependencies = [ "log", "ring", + "rustls-webpki 0.101.1", "sct", - "webpki", ] [[package]] name = "rustls-pemfile" -version = "1.0.2" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d194b56d58803a43635bdc398cd17e383d6f71f9182b9a192c127ca42494a59b" +checksum = "2d3987094b1d07b653b7dfdc3f70ce9a1da9c51ac18c1b06b662e4f9a0e9f4b2" dependencies = [ - "base64 0.21.0", + "base64 0.21.2", +] + +[[package]] +name = "rustls-webpki" +version = "0.100.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d6207cd5ed3d8dca7816f8f3725513a34609c0c765bf652b8c3cb4cfd87db46b" +dependencies = [ + "ring", + "untrusted", +] + +[[package]] +name = "rustls-webpki" +version = "0.101.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "15f36a6828982f422756984e47912a7a51dcbc2a197aa791158f8ca61cd8204e" +dependencies = [ + "ring", + "untrusted", ] [[package]] @@ -5765,15 +5723,15 @@ dependencies = [ [[package]] name = "rustversion" -version = "1.0.12" +version = "1.0.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4f3208ce4d8448b3f3e7d168a73f5e0c43a61e32930de3bceeccedb388b6bf06" +checksum = "7ffc183a10b4478d04cbbbfc96d0873219d962dd5accaff2ffbd4ceb7df837f4" [[package]] name = "ryu" -version = "1.0.13" +version = "1.0.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f91339c0467de62360649f8d3e185ca8de4224ff281f66000de5eb2a77a79041" +checksum = "1ad4cc8da4ef723ed60bced201181d83791ad433213d8c24efffda1eec85d741" [[package]] name = "salsa20" @@ -5781,7 +5739,7 @@ version = "0.10.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "97a22f5af31f73a954c10289c93e8a50cc23d971e80ee446f1f6f7137a088213" dependencies = [ - "cipher 0.4.4", + "cipher", ] [[package]] @@ -5795,9 +5753,9 @@ dependencies = [ [[package]] name = "scale-info" -version = "2.7.0" +version = "2.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b569c32c806ec3abdf3b5869fb8bf1e0d275a7c1c9b0b05603d9464632649edf" +checksum = "35c0a159d0c45c12b20c5a844feb1fe4bea86e28f17b92a5f0c42193634d3782" dependencies = [ "bitvec 1.0.1", "cfg-if 1.0.0", @@ -5808,9 +5766,9 @@ dependencies = [ [[package]] name = "scale-info-derive" -version = "2.6.0" +version = "2.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "53012eae69e5aa5c14671942a5dd47de59d4cdcff8532a6dd0e081faf1119482" +checksum = "912e55f6d20e0e80d63733872b40e1227c0bce1e1ab81ba67d696339bfd7fd29" dependencies = [ "proc-macro-crate", "proc-macro2", @@ -5820,18 +5778,18 @@ dependencies = [ [[package]] name = "schannel" -version = "0.1.21" +version = "0.1.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "713cfb06c7059f3588fb8044c0fad1d09e3c01d225e25b9220dbfdcf16dbb1b3" +checksum = "0c3733bf4cf7ea0880754e19cb5a462007c4a8c1914bff372ccc95b464f1df88" dependencies = [ - "windows-sys 0.42.0", + "windows-sys 0.48.0", ] [[package]] name = "scopeguard" -version = "1.1.0" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d29ab0c6d3fc0ee92fe66e2d99f700eab17a8d57d1c1d3b748380fb20baa78cd" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" [[package]] name = "scroll" @@ -5862,7 +5820,7 @@ dependencies = [ "hmac", "pbkdf2 0.11.0", "salsa20", - "sha2 0.10.6", + "sha2 0.10.7", ] [[package]] @@ -5877,9 +5835,9 @@ dependencies = [ [[package]] name = "sec1" -version = "0.7.2" +version = "0.7.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0aec48e813d6b90b15f0b8948af3c63483992dee44c03e9930b3eebdabe046e" +checksum = "d3e97a565f76233a6003f9f5c54be1d9c5bdfa3eccfb189469f11ec4901c47dc" dependencies = [ "base16ct", "der", @@ -5927,11 +5885,11 @@ dependencies = [ [[package]] name = "security-framework" -version = "2.9.0" +version = "2.9.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca2855b3715770894e67cbfa3df957790aa0c9edc3bf06efa1a84d77fa0839d1" +checksum = "05b64fb303737d99b81884b2c63433e9ae28abebe5eb5045dcdd175dc2ecf4de" dependencies = [ - "bitflags", + "bitflags 1.3.2", "core-foundation", "core-foundation-sys", "libc", @@ -5940,9 +5898,9 @@ dependencies = [ [[package]] name = "security-framework-sys" -version = "2.9.0" +version = "2.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f51d0c0d83bec45f16480d0ce0058397a69e48fcdc52d1dc8855fb68acbd31a7" +checksum = "e932934257d3b408ed8f30db49d85ea163bfe74961f017f405b025af298f0c7a" dependencies = [ "core-foundation-sys", "libc", @@ -5950,9 +5908,9 @@ dependencies = [ [[package]] name = "semver" -version = "1.0.17" +version = "1.0.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bebd363326d05ec3e2f532ab7660680f3b02130d780c299bca73469d521bc0ed" +checksum = "b0293b4b29daaf487284529cc2f5675b8e57c61f70167ba415a463651fd6a918" dependencies = [ "serde", ] @@ -5971,9 +5929,9 @@ checksum = "cd0b0ec5f1c1ca621c432a25813d8d60c88abe6d3e08a3eb9cf37d97a0fe3d73" [[package]] name = "serde" -version = "1.0.163" +version = "1.0.175" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2113ab51b87a539ae008b5c6c02dc020ffa39afd2d83cffcb3f4eb2722cebec2" +checksum = "5d25439cd7397d044e2748a6fe2432b5e85db703d6d097bd014b3c0ad1ebff0b" dependencies = [ "serde_derive", ] @@ -5990,20 +5948,20 @@ dependencies = [ [[package]] name = "serde_derive" -version = "1.0.163" +version = "1.0.175" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8c805777e3930c8883389c602315a24224bcc738b63905ef87cd1420353ea93e" +checksum = "b23f7ade6f110613c0d63858ddb8b94c1041f550eab58a16b371bdf2c9c80ab4" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] name = "serde_json" -version = "1.0.96" +version = "1.0.103" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "057d394a50403bcac12672b2b18fb387ab6d289d957dab67dd201875391e52f1" +checksum = "d03b412469450d4404fe8499a268edd7f8b79fecb074b0d812ad64ca21f4031b" dependencies = [ "itoa", "ryu", @@ -6012,18 +5970,19 @@ dependencies = [ [[package]] name = "serde_path_to_error" -version = "0.1.11" +version = "0.1.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f7f05c1d5476066defcdfacce1f52fc3cae3af1d3089727100c02ae92e5abbe0" +checksum = "4beec8bce849d58d06238cb50db2e1c417cfeafa4c63f692b15c82b7c80f8335" dependencies = [ + "itoa", "serde", ] [[package]] name = "serde_spanned" -version = "0.6.1" +version = "0.6.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0efd8caf556a6cebd3b285caf480045fcc1ac04f6bd786b09a6f11af30c4fcf4" +checksum = "96426c9936fd7a0124915f9185ea1d20aa9445cc9821142f0a73bc9207a2e186" dependencies = [ "serde", ] @@ -6046,7 +6005,7 @@ version = "0.8.26" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "578a7433b776b56a35785ed5ce9a7e777ac0598aac5a6dd1b4b18a307c7fc71b" dependencies = [ - "indexmap", + "indexmap 1.9.3", "ryu", "serde", "yaml-rust 0.4.5", @@ -6073,7 +6032,7 @@ checksum = "f04293dc80c3993519f2d7f6f511707ee7094fe0c6d3406feb330cdb3540eba3" dependencies = [ "cfg-if 1.0.0", "cpufeatures", - "digest 0.10.6", + "digest 0.10.7", ] [[package]] @@ -6091,13 +6050,13 @@ dependencies = [ [[package]] name = "sha2" -version = "0.10.6" +version = "0.10.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "82e6b795fe2e3b1e845bafcb27aa35405c4d47cdfc92af5fc8d3002f76cebdc0" +checksum = "479fb9d862239e610720565ca91403019f2f00410f1864c5aa7479b950a76ed8" dependencies = [ "cfg-if 1.0.0", "cpufeatures", - "digest 0.10.6", + "digest 0.10.7", ] [[package]] @@ -6106,7 +6065,7 @@ version = "0.10.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "75872d278a8f37ef87fa0ddbda7802605cb18344497949862c0d4dcb291eba60" dependencies = [ - "digest 0.10.6", + "digest 0.10.7", "keccak", ] @@ -6137,7 +6096,7 @@ version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5e1788eed21689f9cf370582dfc467ef36ed9c707f073528ddafa8d83e3b8500" dependencies = [ - "digest 0.10.6", + "digest 0.10.7", "rand_core 0.6.4", ] @@ -6158,9 +6117,9 @@ dependencies = [ [[package]] name = "smallvec" -version = "1.10.0" +version = "1.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a507befe795404456341dfab10cef66ead4c041f62b8b11bbb92bffe5d0953e0" +checksum = "62bb4feee49fdd9f707ef802e22365a35de4b7b299de4763d44bfea899442ff9" [[package]] name = "snap" @@ -6196,14 +6155,14 @@ dependencies = [ [[package]] name = "solang-parser" -version = "0.2.4" +version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8c5ead679f39243782be98c2689e592fc0fc9489ca2e47c9e027bd30f948df31" +checksum = "9c792fe9fae2a2f716846f214ca10d5a1e21133e0bf36cef34bcc4a852467b21" dependencies = [ "itertools", "lalrpop", "lalrpop-util", - "phf 0.11.1", + "phf 0.11.2", "thiserror", "unicode-xid", ] @@ -6286,24 +6245,24 @@ checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" [[package]] name = "strum" -version = "0.24.1" +version = "0.25.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "063e6045c0e62079840579a7e47a355ae92f60eb74daaf156fb1e84ba164e63f" +checksum = "290d54ea6f91c969195bdbcd7442c8c2a2ba87da8bf60a7ee86a235d4bc1e125" dependencies = [ "strum_macros", ] [[package]] name = "strum_macros" -version = "0.24.3" +version = "0.25.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e385be0d24f186b4ce2f9982191e7101bb737312ad61c1f2f984f34bcf85d59" +checksum = "6069ca09d878a33f883cc06aaa9718ede171841d3832450354410b718b097232" dependencies = [ "heck", "proc-macro2", "quote", "rustversion", - "syn 1.0.109", + "syn 2.0.27", ] [[package]] @@ -6321,37 +6280,26 @@ dependencies = [ [[package]] name = "subtle" -version = "2.4.1" +version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6bdef32e8150c2a081110b42772ffe7d7c9032b606bc226c8260fd97e0976601" +checksum = "81cdd64d312baedb58e21336b31bc043b77e01cc99033ce76ef539f78e965ebc" [[package]] name = "svm-rs" -version = "0.2.22" +version = "0.2.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "01afefe60c02f4a2271fb15d1965c37856712cebb338330b06649d12afec42df" +checksum = "3a04fc4f5cd35c700153b233f5575ccb3237e0f941fa5049d9e98254d10bf2fe" dependencies = [ - "anyhow", - "cfg-if 1.0.0", - "clap 3.2.25", - "console 0.14.1", - "dialoguer", "fs2", "hex", "home", - "indicatif", - "itertools", "once_cell", - "rand 0.8.5", "reqwest", "semver", "serde", "serde_json", - "sha2 0.9.9", - "tempfile", + "sha2 0.10.7", "thiserror", - "tokio", - "tracing", "url", "zip", ] @@ -6365,7 +6313,7 @@ dependencies = [ "debugid", "memmap2", "stable_deref_trait", - "uuid 1.3.3", + "uuid 1.4.1", ] [[package]] @@ -6392,9 +6340,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.16" +version = "2.0.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a6f671d4b5ffdb8eadec19c0ae67fe2639df8684bd7bc4b83d986b8db549cf01" +checksum = "b60f673f44a8255b9c8c657daf66a596d435f2da81a555b06dc644d080ba45e0" dependencies = [ "proc-macro2", "quote", @@ -6415,11 +6363,10 @@ checksum = "55937e1799185b12863d447f42597ed69d9928686b8d88a1df17376a097d8369" [[package]] name = "tempfile" -version = "3.6.0" +version = "3.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "31c0432476357e58790aaa47a8efb0c5138f137343f3b5f23bd36a27e3b0a6d6" +checksum = "5486094ee78b2e5038a6382ed7645bc084dc2ec433426ca4c3cb61e2007b8998" dependencies = [ - "autocfg", "cfg-if 1.0.0", "fastrand", "redox_syscall 0.3.5", @@ -6465,7 +6412,7 @@ dependencies = [ "bs58", "bytes", "serde", - "sha2 0.10.6", + "sha2 0.10.7", "unsigned-varint", ] @@ -6490,7 +6437,7 @@ dependencies = [ "rand_core 0.5.1", "ring", "secp256k1 0.24.3", - "sha2 0.10.6", + "sha2 0.10.7", "tokio", "tokio-util", "unsigned-varint", @@ -6517,16 +6464,6 @@ dependencies = [ "winapi-util", ] -[[package]] -name = "terminal_size" -version = "0.1.17" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "633c1a546cee861a1a6d0dc69ebeca693bf4296661ba7852b9d21d159e0506df" -dependencies = [ - "libc", - "winapi", -] - [[package]] name = "textwrap" version = "0.11.0" @@ -6544,29 +6481,29 @@ checksum = "222a222a5bfe1bba4a77b45ec488a741b3cb8872e5e499451fd7d0129c9c7c3d" [[package]] name = "thiserror" -version = "1.0.40" +version = "1.0.44" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "978c9a314bd8dc99be594bc3c175faaa9794be04a5a5e153caba6915336cebac" +checksum = "611040a08a0439f8248d1990b111c95baa9c704c805fa1f62104b39655fd7f90" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.40" +version = "1.0.44" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f9456a42c5b0d803c8cd86e73dd7cc9edd429499f37a3550d286d5e86720569f" +checksum = "090198534930841fab3a5d1bb637cde49e339654e606195f8d9c76eeb081dc96" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] name = "thread-id" -version = "4.0.0" +version = "4.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5fdfe0627923f7411a43ec9ec9c39c3a9b4151be313e0922042581fb6c9b717f" +checksum = "3ee93aa2b8331c0fec9091548843f2c90019571814057da3b783f9de09349d73" dependencies = [ "libc", "redox_syscall 0.2.16", @@ -6636,9 +6573,9 @@ dependencies = [ [[package]] name = "time" -version = "0.3.21" +version = "0.3.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f3403384eaacbca9923fa06940178ac13e4edb725486d70e8e15881d0c836cc" +checksum = "59e399c068f43a5d116fedaf73b203fa4f9c519f17e2b34f63221d3792f81446" dependencies = [ "serde", "time-core", @@ -6686,11 +6623,12 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "tokio" -version = "1.28.1" +version = "1.29.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0aa32867d44e6f2ce3385e89dceb990188b8bb0fb25b0cf576647a6f98ac5105" +checksum = "532826ff75199d5833b9d2c5fe410f29235e25704ee5f0ef599fb51c21f4a4da" dependencies = [ "autocfg", + "backtrace", "bytes", "libc", "mio", @@ -6711,7 +6649,7 @@ checksum = "630bdcf245f78637c13ec01ffae6187cca34625e8c63150d424b59e55af2675e" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] @@ -6726,13 +6664,12 @@ dependencies = [ [[package]] name = "tokio-rustls" -version = "0.23.4" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c43ee83903113e03984cb9e5cebe6c04a5116269e900e3ddba8f068a62adda59" +checksum = "c28327cf380ac148141087fbfb9de9d7bd4e84ab5d2c28fbc911d753de8a7081" dependencies = [ "rustls", "tokio", - "webpki", ] [[package]] @@ -6748,9 +6685,9 @@ dependencies = [ [[package]] name = "tokio-tungstenite" -version = "0.18.0" +version = "0.19.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "54319c93411147bced34cb5609a80e0a8e44c5999c93903a81cd866630ec0bfd" +checksum = "ec509ac96e9a0c43427c74f003127d953a265737636129424288d27cb5c4b12c" dependencies = [ "futures-util", "log", @@ -6758,8 +6695,7 @@ dependencies = [ "tokio", "tokio-rustls", "tungstenite", - "webpki", - "webpki-roots", + "webpki-roots 0.23.1", ] [[package]] @@ -6802,9 +6738,9 @@ dependencies = [ [[package]] name = "toml" -version = "0.7.3" +version = "0.7.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b403acf6f2bb0859c93c7f0d967cb4a75a7ac552100f9322faf64dc047669b21" +checksum = "c17e963a819c331dcacd7ab957d80bc2b9a9c1e71c804826d2f283dd65306542" dependencies = [ "serde", "serde_spanned", @@ -6814,20 +6750,20 @@ dependencies = [ [[package]] name = "toml_datetime" -version = "0.6.1" +version = "0.6.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3ab8ed2edee10b50132aed5f331333428b011c99402b5a534154ed15746f9622" +checksum = "7cda73e2f1397b1262d6dfdcef8aafae14d1de7748d66822d3bfeeb6d03e5e4b" dependencies = [ "serde", ] [[package]] name = "toml_edit" -version = "0.19.8" +version = "0.19.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "239410c8609e8125456927e6707163a3b1fdb40561e4b803bc041f466ccfdc13" +checksum = "f8123f27e969974a3dfba720fdb560be359f57b44302d280ba72e76a74480e8a" dependencies = [ - "indexmap", + "indexmap 2.0.0", "serde", "serde_spanned", "toml_datetime", @@ -6877,13 +6813,13 @@ dependencies = [ [[package]] name = "tracing-attributes" -version = "0.1.24" +version = "0.1.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0f57e3ca2a01450b1a921183a9c9cbfda207fd822cef4ccb00a65402cbba7a74" +checksum = "5f4f31f56159e98206da9efd823404b79b6ef3143b4a7ab76e67b1751b25a4ab" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] @@ -6952,13 +6888,13 @@ checksum = "3528ecfd12c466c6f163363caf2d02a71161dd5e1cc6ae7b34207ea2d42d81ed" [[package]] name = "tungstenite" -version = "0.18.0" +version = "0.19.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "30ee6ab729cd4cf0fd55218530c4522ed30b7b6081752839b68fcec8d0960788" +checksum = "15fba1a6d6bb030745759a9a2a588bfe8490fc8b4751a277db3a0be1c9ebbf67" dependencies = [ - "base64 0.13.1", "byteorder", "bytes", + "data-encoding", "http", "httparse", "log", @@ -7007,9 +6943,9 @@ checksum = "92888ba5573ff080736b3648696b70cafad7d250551175acbaa4e0385b3e1460" [[package]] name = "unicode-ident" -version = "1.0.8" +version = "1.0.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e5464a87b239f13a63a501f2701565754bae92d243d4bb7eb12f6d57d2269bf4" +checksum = "301abaae475aa91687eb82514b328ab47a211a533026cb25fc3e519b86adfc3c" [[package]] name = "unicode-normalization" @@ -7034,9 +6970,9 @@ checksum = "f962df74c8c05a667b5ee8bcf162993134c104e96440b663c8daa176dc772d8c" [[package]] name = "universal-hash" -version = "0.5.0" +version = "0.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7d3160b73c9a19f7e2939a2fdad446c57c1bbbbf4d919d3213ff1267a580d8b5" +checksum = "fc1de2c688dc15305988b563c3854064043356019f97a4b46276fe734c4f07ea" dependencies = [ "crypto-common", "subtle", @@ -7065,9 +7001,9 @@ checksum = "a156c684c91ea7d62626509bce3cb4e1d9ed5c4d978f7b4352658f96a4c26b4a" [[package]] name = "url" -version = "2.3.1" +version = "2.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0d68c799ae75762b8c3fe375feb6600ef5602c883c5d21eb51c09f22b83c4643" +checksum = "50bff7831e19200a85b17131d085c25d7811bc4e186efdaf54bbd132994a88cb" dependencies = [ "form_urlencoded", "idna", @@ -7092,15 +7028,15 @@ version = "0.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bc5cf98d8186244414c848017f0e2676b3fcb46807f6668a97dfe67359a3c4b7" dependencies = [ - "getrandom 0.2.9", + "getrandom 0.2.10", "serde", ] [[package]] name = "uuid" -version = "1.3.3" +version = "1.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "345444e32442451b267fc254ae85a209c64be56d2890e601a0c37ff0c3c5ecd2" +checksum = "79daa5ed5740825c40b389c5e50312b9c86df53fccd33f281df655642b43869d" [[package]] name = "vcpkg" @@ -7132,11 +7068,10 @@ dependencies = [ [[package]] name = "want" -version = "0.3.0" +version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1ce8a968cb1cd110d136ff8b819a556d6fb6d919363c61534f6860c7eb172ba0" +checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e" dependencies = [ - "log", "try-lock", ] @@ -7261,6 +7196,15 @@ dependencies = [ "webpki", ] +[[package]] +name = "webpki-roots" +version = "0.23.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b03058f88386e5ff5310d9111d53f48b17d732b401aeb83a8d5190f2ac459338" +dependencies = [ + "rustls-webpki 0.100.1", +] + [[package]] name = "which" version = "4.4.0" @@ -7309,7 +7253,7 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e686886bc078bc1b0b600cac0147aadb815089b6e4da64016cbd754b6342700f" dependencies = [ - "windows-targets 0.48.0", + "windows-targets", ] [[package]] @@ -7327,44 +7271,20 @@ dependencies = [ "windows_x86_64_msvc 0.42.2", ] -[[package]] -name = "windows-sys" -version = "0.45.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "75283be5efb2831d37ea142365f009c02ec203cd29a3ebecbc093d52315b66d0" -dependencies = [ - "windows-targets 0.42.2", -] - [[package]] name = "windows-sys" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets 0.48.0", + "windows-targets", ] [[package]] name = "windows-targets" -version = "0.42.2" +version = "0.48.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e5180c00cd44c9b1c88adb3693291f1cd93605ded80c250a75d472756b4d071" -dependencies = [ - "windows_aarch64_gnullvm 0.42.2", - "windows_aarch64_msvc 0.42.2", - "windows_i686_gnu 0.42.2", - "windows_i686_msvc 0.42.2", - "windows_x86_64_gnu 0.42.2", - "windows_x86_64_gnullvm 0.42.2", - "windows_x86_64_msvc 0.42.2", -] - -[[package]] -name = "windows-targets" -version = "0.48.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b1eb6f0cd7c80c79759c929114ef071b87354ce476d9d94271031c0497adfd5" +checksum = "05d4b17490f70499f20b9e791dcf6a299785ce8af4d709018206dc5b4953e95f" dependencies = [ "windows_aarch64_gnullvm 0.48.0", "windows_aarch64_msvc 0.48.0", @@ -7461,9 +7381,9 @@ checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" [[package]] name = "winnow" -version = "0.4.6" +version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61de7bac303dc551fe038e2b3cef0f571087a47571ea6e79a87692ac99b99699" +checksum = "81fac9742fd1ad1bd9643b991319f72dd031016d44b77039a26977eb667141e7" dependencies = [ "memchr", ] @@ -7554,16 +7474,16 @@ checksum = "ce36e65b0d2999d2aafac989fb249189a141aee1f53c612c1f37d72631959f69" dependencies = [ "proc-macro2", "quote", - "syn 2.0.16", + "syn 2.0.27", ] [[package]] name = "zip" -version = "0.6.5" +version = "0.6.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7e92305c174683d78035cbf1b70e18db6329cc0f1b9cae0a52ca90bf5bfe7125" +checksum = "760394e246e4c28189f19d488c058bf16f564016aefac5d32bb1f3b51d5e9261" dependencies = [ - "aes 0.7.5", + "aes", "byteorder", "bzip2", "constant_time_eq", @@ -7573,7 +7493,7 @@ dependencies = [ "hmac", "pbkdf2 0.11.0", "sha1", - "time 0.3.21", + "time 0.3.23", "zstd", ] diff --git a/core/api/src/adapter.rs b/core/api/src/adapter.rs index 81de4f6f0..64838c8f4 100644 --- a/core/api/src/adapter.rs +++ b/core/api/src/adapter.rs @@ -6,8 +6,8 @@ use core_executor::{ use protocol::traits::{APIAdapter, Context, Executor, ExecutorAdapter, MemPool, Network, Storage}; use protocol::types::{ Account, BigEndianHash, Block, BlockNumber, Bytes, CkbRelatedInfo, ExecutorContext, Hash, - Header, Metadata, Proposal, Receipt, SignedTransaction, TxResp, H160, MAX_BLOCK_GAS_LIMIT, - NIL_DATA, RLP_NULL, U256, + Header, Metadata, Proposal, Receipt, SignedTransaction, TransactionTrace, TxResp, H160, + MAX_BLOCK_GAS_LIMIT, NIL_DATA, RLP_NULL, U256, }; use protocol::{async_trait, codec::ProtocolCodec, trie, ProtocolResult}; @@ -183,7 +183,7 @@ where state_root: Hash, mock_header: Proposal, enable_trace: bool, - ) -> ProtocolResult { + ) -> ProtocolResult<(TxResp, Option)> { let mut exec_ctx = ExecutorContext::from(mock_header); exec_ctx.origin = from.unwrap_or_default(); exec_ctx.gas_price = gas_price.unwrap_or_else(U256::one); @@ -199,12 +199,16 @@ where .unwrap_or(MAX_BLOCK_GAS_LIMIT); if enable_trace { - return Ok( - AxonExecutor::default().tracing_call(&backend, gas_limit, from, to, value, data) - ); + let ret = + AxonExecutor::default().tracing_call(&backend, gas_limit, from, to, value, data); + + return Ok((ret.0, Some(ret.1))); } - Ok(AxonExecutor::default().call(&backend, gas_limit, from, to, value, data)) + Ok(( + AxonExecutor::default().call(&backend, gas_limit, from, to, value, data), + None, + )) } async fn get_code_by_hash(&self, ctx: Context, hash: &Hash) -> ProtocolResult> { diff --git a/core/api/src/jsonrpc/impl/web3.rs b/core/api/src/jsonrpc/impl/web3.rs index 49408fd6f..bcfb16050 100644 --- a/core/api/src/jsonrpc/impl/web3.rs +++ b/core/api/src/jsonrpc/impl/web3.rs @@ -92,6 +92,7 @@ impl Web3RpcImpl { true, ) .await + .map(|r| r.0) } async fn calculate_rewards( diff --git a/core/executor/Cargo.toml b/core/executor/Cargo.toml index dba0b4479..8be54a08e 100644 --- a/core/executor/Cargo.toml +++ b/core/executor/Cargo.toml @@ -27,6 +27,7 @@ lru = "0.10" molecule = "0.7" parking_lot = "0.12" protocol = { path = "../../protocol", package = "axon-protocol", default-features = false } +revm-interpreter = "1.1" ripemd = "0.1" rlp = "0.5" rlp-derive = "0.1" diff --git a/core/executor/src/lib.rs b/core/executor/src/lib.rs index be8792551..f5a389e85 100644 --- a/core/executor/src/lib.rs +++ b/core/executor/src/lib.rs @@ -11,7 +11,6 @@ mod tracing; mod utils; pub use crate::adapter::{AxonExecutorAdapter, MPTTrie, RocksTrieDB}; -pub use crate::tracing::TransactionTrace; pub use crate::utils::{ code_address, decode_revert_msg, logs_bloom, DefaultFeeAllocator, FeeInlet, }; @@ -27,8 +26,9 @@ use common_merkle::TrieMerkle; use protocol::codec::ProtocolCodec; use protocol::traits::{Backend, Executor, ExecutorAdapter}; use protocol::types::{ - data_gas_cost, Account, Config, ExecResp, Hasher, SignedTransaction, TransactionAction, TxResp, - ValidatorExtend, GAS_CALL_TRANSACTION, GAS_CREATE_TRANSACTION, H160, NIL_DATA, RLP_NULL, U256, + data_gas_cost, Account, Config, ExecResp, Hasher, SignedTransaction, TransactionAction, + TransactionTrace, TxResp, ValidatorExtend, GAS_CALL_TRANSACTION, GAS_CREATE_TRANSACTION, H160, + NIL_DATA, RLP_NULL, U256, }; use crate::precompiles::build_precompile_set; @@ -136,7 +136,7 @@ impl Executor for AxonExecutor { // transaction called EVM let mut r = if cfg!(feature = "tracing") { let mut listener = AxonListener::new(); - trace_using(&mut listener, || { + trace_using(&mut listener, true, || { system_contract_dispatch(adapter, tx) .unwrap_or_else(|| Self::evm_exec(adapter, &config, &precompiles, tx)) }) @@ -304,11 +304,13 @@ impl AxonExecutor { to: Option, value: U256, data: Vec, - ) -> TxResp { + ) -> (TxResp, TransactionTrace) { let mut listener = AxonListener::new(); - trace_using(&mut listener, || { + let resp = trace_using(&mut listener, false, || { self.call(backend, gas_limit, from, to, value, data) - }) + }); + + (resp, listener.finish().try_into().unwrap()) } // Todo: add the is_genesis judgement diff --git a/core/executor/src/tracing.rs b/core/executor/src/tracing.rs index 89b5a78d6..ffad730f8 100644 --- a/core/executor/src/tracing.rs +++ b/core/executor/src/tracing.rs @@ -1,71 +1,44 @@ -use std::{cell::RefCell, ops::Index, ptr::NonNull, rc::Rc}; +use std::{cell::RefCell, ptr::NonNull, rc::Rc}; use evm::gasometer::tracing as gas_tracing; -use evm::{tracing as evm_tracing, Capture, Opcode}; +use evm::{tracing as evm_tracing, Capture}; use evm_runtime::tracing as runtime_tracing; -use protocol::types::H256; +use protocol::types::{Hex, TransactionTrace as Web3TransactionTrace, H160, H256, U256}; -use crate::tracing::wrapped_event::WrappedEvent; +use crate::tracing::{wrapped_event::WrappedEvent, wrapped_opcode::Opcode}; macro_rules! trace_type { - ($($name: ident,)*) => { - $( - #[derive(Default, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)] - pub struct $name(pub [u8; 32]); - - impl $name { - pub fn into_raw(self) -> [u8; 32] { - self.0 - } - } - )* + ($name: ident, $type_: ty) => { + #[derive(Default, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)] + pub struct $name(pub $type_); }; - (Vec $(, $name: ident)*) => { - $( - #[derive(Default, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)] - pub struct $name(pub Vec<[u8; 32]>); - - impl $name { - pub fn len(&self) -> usize { - self.0.len() - } - - #[allow(dead_code)] - pub fn is_empty(&self) -> bool { - self.0.is_empty() - } + ($name: ident, Vec, $type_: ty) => { + #[derive(Default, Clone, Debug, PartialEq, Eq)] + pub struct $name(pub Vec<$type_>); - pub fn into_raw(self) -> Vec<[u8; 32]> { - self.0 - } + impl $name { + #[allow(dead_code)] + pub fn len(&self) -> usize { + self.0.len() } - )* + } }; - ($name: ident, $key: ident, $val: ident) => { + ($name: ident, BTreeMap, ($key: ident, $val: ident)) => { #[derive(Default, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)] pub struct $name(pub std::collections::BTreeMap<$key, $val>); - impl IntoIterator for $name { - type Item = ($key, $val); - type IntoIter = std::collections::btree_map::IntoIter<$key, $val>; - - fn into_iter(self) -> Self::IntoIter { - self.0.into_iter() - } - } - impl $name { pub fn insert(&mut self, key: $key, value: $val) { self.0.insert(key, value); } } - } + }; } -pub fn trace_using(listener: &mut T, f: F) -> R +pub fn trace_using(listener: &mut T, enable_gasometer: bool, f: F) -> R where T: evm_tracing::EventListener + runtime_tracing::EventListener @@ -75,12 +48,19 @@ where { let mut evm_listener = SharedMutableReference::new(listener); let mut runtime_listener = evm_listener.clone(); - let mut gas_listener = evm_listener.clone(); - gas_tracing::using(&mut gas_listener, || { - runtime_tracing::using(&mut runtime_listener, || { - evm_tracing::using(&mut evm_listener, f) - }) + if enable_gasometer { + let mut gas_listener = evm_listener.clone(); + + return evm_tracing::using(&mut gas_listener, || { + runtime_tracing::using(&mut runtime_listener, || { + gas_tracing::using(&mut evm_listener, f) + }) + }); + } + + evm_tracing::using(&mut runtime_listener, || { + runtime_tracing::using(&mut evm_listener, f) }) } @@ -132,6 +112,7 @@ impl gas_tracing::EventListener for SharedMutable #[derive(Default, Clone, Debug)] pub struct AxonListener { logs: Vec, + type_: Option, current: TraceLog, current_memory_gas: u64, gas_used: u64, @@ -147,15 +128,63 @@ impl evm_tracing::EventListener for AxonListener { log::info!("EVM event {:?}", WrappedEvent::from(&event)); match event { - Event::Call { .. } | Event::Create { .. } | Event::PrecompileSubcall { .. } => { + Event::TransactCall { + caller, + address, + value, + data, + .. + } => { + self.current.from = caller; + self.current.to = address; + self.current.value = value; + self.current.input = data.to_vec(); self.current.depth += 1; + + if self.type_.is_none() { + self.type_ = Some("CALL".to_string()); + } } - Event::Exit { - reason: _, - return_value, + + Event::TransactCreate { + caller, + value, + init_code, + address, + .. + } => { + self.current.from = caller; + self.current.to = address; + self.current.value = value; + self.current.input = init_code.to_vec(); + self.current.depth += 1; + + if self.type_.is_none() { + self.type_ = Some("CREATE".to_string()); + } + } + + Event::TransactCreate2 { + caller, + value, + init_code, + address, + .. } => { + self.current.from = caller; + self.current.to = address; + self.current.value = value; + self.current.input = init_code.to_vec(); + self.current.depth += 1; + + if self.type_.is_none() { + self.type_ = Some("CREATE2".to_string()); + } + } + + Event::Exit { return_value, .. } => { // If the depth is not zero then an error must have occurred to exit early. - if !self.current.depth == 0 { + if self.current.depth != 0 { self.failed = true; self.output = return_value.to_vec(); } @@ -175,16 +204,20 @@ impl runtime_tracing::EventListener for AxonListener { match event { Event::Step { - context: _, + context, opcode, position, stack, memory, } => { - self.current.opcode = opcode; if let Ok(pc) = position { - self.current.program_counter = *pc as u32; + self.current.program_counter = *pc; } + + self.current.type_ = Opcode::from(opcode).to_string(); + self.current.from = context.caller; + self.current.to = context.address; + self.current.opcode = opcode.into(); self.current.stack = stack.data().as_slice().into(); self.current.memory = memory.data().as_slice().into(); } @@ -199,50 +232,44 @@ impl runtime_tracing::EventListener for AxonListener { self.logs.push(self.current.clone()); } Err(Capture::Exit(reason)) => { - // Step completed, push current log into the record + // Step completed, push current log into the record, reduce depth by 1 self.logs.push(self.current.clone()); - // Current sub-call completed, reduce depth by 1 - self.current.depth -= 1; + self.current.output = return_value.to_vec(); + self.current.depth = self.current.depth.saturating_sub(1); // if the depth is 0 then the transaction is complete if self.current.depth == 0 { if !return_value.is_empty() { self.output = return_value.to_vec(); } + if !reason.is_succeed() { self.failed = true; } } } + Err(Capture::Trap(opcode)) => { // "Trap" here means that there is some opcode which has special // handling logic outside the core `step` function. This means the // `StepResult` does not necessarily indicate the current log // is finished yet. In particular, `SLoad` and `SStore` events come // _after_ the `StepResult`, but still correspond to the current step. - if opcode == &Opcode::SLOAD || opcode == &Opcode::SSTORE { + if opcode == &evm::Opcode::SLOAD || opcode == &evm::Opcode::SSTORE { self.logs.push(self.current.clone()); } } } } - Event::SLoad { - address: _, - index, - value, - } => { + Event::SLoad { index, value, .. } => { self.current .storage .insert(LogStorageKey(index.0), LogStorageValue(value.0)); self.logs.push(self.current.clone()); } - Event::SStore { - address: _, - index, - value, - } => { + Event::SStore { index, value, .. } => { self.current .storage .insert(LogStorageKey(index.0), LogStorageValue(value.0)); @@ -260,20 +287,19 @@ impl gas_tracing::EventListener for AxonListener { log::info!("EVM gas event {:?}", WrappedEvent::from(&event)); match event { - Event::RecordCost { cost, snapshot: _ } => { + Event::RecordCost { cost, .. } => { self.current.gas_cost = cost; } + Event::RecordDynamicCost { gas_cost, memory_gas, - gas_refund: _, - snapshot: _, + .. } => { // In SputnikVM memory gas is cumulative (ie this event always shows the total) - // gas spent on memory up to this point. But geth traces simply - // show how much gas each step took, regardless of how that gas - // was used. So if this step caused an increase to the - // memory gas then we need to record that. + // gas spent on memory up to this point. But geth traces simply show how much + // gas each step took, regardless of how that gas was used. So if this step + // caused an increase to the memory gas then we need to record that. let memory_cost_diff = if memory_gas > self.current_memory_gas { memory_gas - self.current_memory_gas } else { @@ -282,16 +308,15 @@ impl gas_tracing::EventListener for AxonListener { self.current_memory_gas = memory_gas; self.current.gas_cost = gas_cost + memory_cost_diff; } - Event::RecordRefund { - refund: _, - snapshot, - } => { - // This one seems to show up at the end of a transaction, so it - // can be used to set the total gas used. + + Event::RecordRefund { snapshot, .. } => { + // This one seems to show up at the end of a transaction, so it can be used to + // set the total gas used. if let Some(snapshot) = snapshot { self.gas_used = snapshot.used_gas; } } + Event::RecordTransaction { .. } | Event::RecordStipend { .. } => (), } } @@ -303,39 +328,34 @@ impl AxonListener { } pub fn finish(self) -> TransactionTrace { - TransactionTrace::new(self.gas_used, self.failed, self.output, Logs(self.logs)) + TransactionTrace { + gas: self.gas_used, + failed: self.failed, + return_value: self.output, + struct_logs: Logs(self.logs), + } } } -#[derive(Clone, Debug, PartialEq, Eq)] +#[derive(Default, Clone, Debug, PartialEq, Eq)] pub struct TraceLog { - pub depth: u32, + pub type_: String, + pub depth: usize, + pub from: H160, + pub to: H160, + pub value: U256, + pub input: Vec, + pub output: Vec, pub error: Option, pub gas: u64, pub gas_cost: u64, - pub memory: LogMemory, pub opcode: Opcode, - pub program_counter: u32, + pub program_counter: usize, + pub memory: LogMemory, pub stack: LogStack, pub storage: LogStorage, } -impl Default for TraceLog { - fn default() -> Self { - Self { - depth: Default::default(), - error: Default::default(), - gas: Default::default(), - gas_cost: Default::default(), - memory: Default::default(), - opcode: Opcode::STOP, - program_counter: Default::default(), - stack: Default::default(), - storage: Default::default(), - } - } -} - #[derive(Default, Clone, Debug, PartialEq, Eq)] pub struct TransactionTrace { gas: u64, @@ -344,92 +364,95 @@ pub struct TransactionTrace { struct_logs: Logs, } -impl TransactionTrace { - pub fn new( - gas: u64, - failed: bool, - return_value: Vec, - struct_logs: Logs, - ) -> TransactionTrace { - Self { - gas, - failed, - return_value, - struct_logs, - } - } - - pub fn gas(&self) -> u64 { - self.gas - } - - pub fn result(&self) -> &[u8] { - self.return_value.as_slice() - } - - pub fn logs(&self) -> &Logs { - &self.struct_logs - } -} - -#[derive(Default, Clone, Debug, PartialEq, Eq)] -pub struct StepTransactionTrace { - inner: TransactionTrace, - step: usize, -} +impl TryFrom for Web3TransactionTrace { + type Error = String; -#[allow(dead_code)] -impl StepTransactionTrace { - pub fn new(transaction_trace: TransactionTrace) -> Self { - Self { - inner: transaction_trace, - step: 0, - } - } + fn try_from(mut value: TransactionTrace) -> Result { + let log_len = value.struct_logs.len(); - pub fn step(&mut self) -> Option<&TraceLog> { - if self.step > self.inner.struct_logs.len() { - None - } else { - self.step += 1; - Some(&self.inner.struct_logs[self.step]) + if log_len == 0 { + return Err("No logs".to_string()); } - } -} -#[derive(Default, Clone, Debug, PartialEq, Eq)] -pub struct Logs(pub Vec); + let root = value.struct_logs.0.swap_remove(0); + let mut ret = Web3TransactionTrace { + type_: root.type_, + from: root.from, + to: root.to, + value: root.value, + input: Hex::encode(root.input), + output: Hex::encode(&value.return_value), + gas: U256::zero(), + gas_used: value.gas.into(), + error: None, + revert_reason: None, + calls: None, + }; + + if log_len > 1 { + let logs = &value.struct_logs.0; + + if !logs.windows(2).all(|pair| { + let (prev, next) = (&pair[0], &pair[1]); + + prev.depth == next.depth + || prev.depth + 1 == next.depth + || prev.depth == next.depth + 1 + }) { + return Err("Log depth variation is not smooth".to_string()); + } -impl Logs { - pub fn len(&self) -> usize { - self.0.len() - } + ret.calls = Some(build_subcalls(logs, &mut 0, logs[0].depth)); + } - pub fn is_empty(&self) -> bool { - self.0.is_empty() + Ok(ret) } } -impl Index for Logs { - type Output = TraceLog; - - fn index(&self, index: usize) -> &Self::Output { - &self.0[index] +fn build_subcalls( + traces: &[TraceLog], + index: &mut usize, + current_depth: usize, +) -> Vec { + let trace_len = traces.len(); + let mut stack = Vec::new(); + + while *index < trace_len { + let t_log = &traces[*index]; + + if t_log.depth == current_depth { + stack.push(Web3TransactionTrace { + type_: t_log.type_.clone(), + from: t_log.from, + to: t_log.to, + value: t_log.value, + gas: t_log.gas.into(), + gas_used: t_log.gas_cost.into(), + input: Hex::encode(&t_log.input), + output: Hex::encode(&t_log.output), + error: None, + revert_reason: None, + calls: None, + }); + + *index += 1; + } else if t_log.depth == (current_depth + 1) { + stack.last_mut().unwrap().calls = + Some(build_subcalls(traces, index, current_depth + 1)); + } else { + return stack; + } } -} -impl IntoIterator for Logs { - type IntoIter = std::vec::IntoIter; - type Item = TraceLog; - - fn into_iter(self) -> Self::IntoIter { - self.0.into_iter() - } + stack } -trace_type!(LogStorageKey, LogStorageValue,); -trace_type!(Vec, LogMemory, LogStack); -trace_type!(LogStorage, LogStorageKey, LogStorageValue); +trace_type!(LogStorageKey, [u8; 32]); +trace_type!(LogStorageValue, [u8; 32]); +trace_type!(LogMemory, Vec, [u8; 32]); +trace_type!(LogStack, Vec, [u8; 32]); +trace_type!(Logs, Vec, TraceLog); +trace_type!(LogStorage, BTreeMap, (LogStorageKey, LogStorageValue)); impl From<&[u8]> for LogMemory { fn from(bytes: &[u8]) -> Self { @@ -453,6 +476,37 @@ impl From<&[H256]> for LogStack { } } +mod wrapped_opcode { + use std::cmp::{Eq, PartialEq}; + use std::fmt::{Display, Formatter, Result}; + + #[derive(Default, Clone, Copy, Debug, PartialEq, Eq)] + pub struct Opcode(u8); + + impl From for Opcode { + fn from(value: evm::Opcode) -> Self { + Opcode::new(value.as_u8()) + } + } + + impl Display for Opcode { + fn fmt(&self, f: &mut Formatter<'_>) -> Result { + Display::fmt( + &revm_interpreter::opcode::OpCode::try_from_u8(self.0) + .unwrap() + .as_str(), + f, + ) + } + } + + impl Opcode { + pub fn new(value: u8) -> Self { + Self(value) + } + } +} + #[cfg(feature = "tracing")] mod wrapped_event { use super::*; @@ -568,3 +622,124 @@ mod wrapped_event { } } } + +#[cfg(test)] +mod tests { + use super::*; + + fn mock_trace(depth: usize) -> TraceLog { + TraceLog { + depth, + value: depth.into(), + ..Default::default() + } + } + + #[test] + fn test_build_subcalls() { + let logs = vec![ + mock_trace(1), + mock_trace(1), + mock_trace(2), + mock_trace(3), + mock_trace(2), + mock_trace(1), + mock_trace(2), + mock_trace(1), + ]; + + let res = build_subcalls(&logs, &mut 0, 1); + let data = r#"[ + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x1", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x" + }, + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x1", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x", + "calls": [ + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x2", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x", + "calls": [ + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x3", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x" + } + ] + }, + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x2", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x" + } + ] + }, + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x1", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x", + "calls": [ + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x2", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x" + } + ] + }, + { + "type_": "", + "from": "0x0000000000000000000000000000000000000000", + "to": "0x0000000000000000000000000000000000000000", + "value": "0x1", + "gas": "0x0", + "gas_used": "0x0", + "input": "0x", + "output": "0x" + }]"#; + + assert_eq!( + res, + serde_json::from_str::>(data).unwrap() + ); + } +} diff --git a/protocol/src/traits/api.rs b/protocol/src/traits/api.rs index 770550314..5d246f5d7 100644 --- a/protocol/src/traits/api.rs +++ b/protocol/src/traits/api.rs @@ -1,6 +1,6 @@ use crate::types::{ Account, Block, BlockNumber, Bytes, CkbRelatedInfo, Hash, Header, Metadata, Proposal, Receipt, - SignedTransaction, TxResp, H160, U256, + SignedTransaction, TransactionTrace, TxResp, H160, U256, }; use crate::{async_trait, traits::Context, ProtocolResult}; @@ -79,7 +79,7 @@ pub trait APIAdapter: Send + Sync { state_root: Hash, proposal: Proposal, enable_trace: bool, - ) -> ProtocolResult; + ) -> ProtocolResult<(TxResp, Option)>; async fn get_code_by_hash(&self, ctx: Context, hash: &Hash) -> ProtocolResult>; diff --git a/protocol/src/types/transaction.rs b/protocol/src/types/transaction.rs index 260e56473..d75d2ea4f 100644 --- a/protocol/src/types/transaction.rs +++ b/protocol/src/types/transaction.rs @@ -7,7 +7,9 @@ use serde::{Deserialize, Serialize}; use common_crypto::secp256k1_recover; -use crate::types::{Bytes, BytesMut, Hash, Hasher, Public, TypesError, H160, H256, H520, U256}; +use crate::types::{ + Bytes, BytesMut, Hash, Hasher, Hex, Public, TypesError, H160, H256, H520, U256, +}; use crate::ProtocolResult; pub const GAS_PER_ZERO_BYTE: u64 = 4; @@ -470,6 +472,24 @@ impl SignedTransaction { } } +#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, Eq)] +pub struct TransactionTrace { + pub type_: String, + pub from: H160, + pub to: H160, + pub value: U256, + pub gas: U256, + pub gas_used: U256, + pub input: Hex, + pub output: Hex, + #[serde(skip_serializing_if = "Option::is_none")] + pub error: Option, + #[serde(skip_serializing_if = "Option::is_none")] + pub revert_reason: Option, + #[serde(skip_serializing_if = "Option::is_none")] + pub calls: Option>, +} + pub fn public_to_address(public: &Public) -> H160 { let hash = Hasher::digest(public); let mut ret = H160::zero();