diff --git a/CHANGES.md b/CHANGES.md index 154f2b668..5e666f37f 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -7,6 +7,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +## [2.5.2] 2022-03-22 + +### Removed + +- New Aurora-only precompiles removed since they do not work in NEAR view calls. This will need to be fixed and they will be re-added to a future release. + ## [2.5.1] - 2022-03-16 ### Fixes @@ -232,7 +238,8 @@ struct SubmitResult { ## [1.0.0] - 2021-05-12 -[Unreleased]: https://github.com/aurora-is-near/aurora-engine/compare/2.5.1...develop +[Unreleased]: https://github.com/aurora-is-near/aurora-engine/compare/2.5.2...develop +[2.5.2]: https://github.com/aurora-is-near/aurora-engine/compare/2.5.1...2.5.2 [2.5.1]: https://github.com/aurora-is-near/aurora-engine/compare/2.5.0...2.5.1 [2.5.0]: https://github.com/aurora-is-near/aurora-engine/compare/2.4.0...2.5.0 [2.4.0]: https://github.com/aurora-is-near/aurora-engine/compare/2.3.0...2.4.0 diff --git a/VERSION b/VERSION index 73462a5a1..f225a78ad 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -2.5.1 +2.5.2 diff --git a/engine-precompiles/src/account_ids.rs b/engine-precompiles/src/account_ids.rs deleted file mode 100644 index df349a460..000000000 --- a/engine-precompiles/src/account_ids.rs +++ /dev/null @@ -1,124 +0,0 @@ -use super::{EvmPrecompileResult, Precompile}; -use crate::prelude::types::{Address, EthGas}; -use crate::PrecompileOutput; -use aurora_engine_types::account_id::AccountId; -use evm::{Context, ExitError}; - -mod costs { - use crate::prelude::types::EthGas; - - // TODO(#51): Determine the correct amount of gas - pub(super) const PREDECESSOR_ACCOUNT_GAS: EthGas = EthGas::new(0); - // TODO(#51): Determine the correct amount of gas - pub(super) const CURRENT_ACCOUNT_GAS: EthGas = EthGas::new(0); -} - -pub struct PredecessorAccount { - predecessor_account_id: AccountId, -} - -impl PredecessorAccount { - /// predecessor_account_id precompile address - /// - /// Address: `0x723ffbaba940e75e7bf5f6d61dcbf8d9a4de0fd7` - /// This address is computed as: `&keccak("predecessorAccountId")[12..]` - pub const ADDRESS: Address = - super::make_address(0x723ffbab, 0xa940e75e7bf5f6d61dcbf8d9a4de0fd7); - - pub fn new(predecessor_account_id: AccountId) -> Self { - Self { - predecessor_account_id, - } - } -} - -impl Precompile for PredecessorAccount { - fn required_gas(_input: &[u8]) -> Result { - Ok(costs::PREDECESSOR_ACCOUNT_GAS) - } - - fn run( - &self, - input: &[u8], - target_gas: Option, - _context: &Context, - _is_static: bool, - ) -> EvmPrecompileResult { - let cost = Self::required_gas(input)?; - if let Some(target_gas) = target_gas { - if cost > target_gas { - return Err(ExitError::OutOfGas); - } - } - - Ok( - PrecompileOutput::without_logs(cost, self.predecessor_account_id.as_bytes().to_vec()) - .into(), - ) - } -} - -pub struct CurrentAccount { - current_account_id: AccountId, -} - -impl CurrentAccount { - /// current_account_id precompile address - /// - /// Address: `0xfefae79e4180eb0284f261205e3f8cea737aff56` - /// This address is computed as: `&keccak("currentAccountId")[12..]` - pub const ADDRESS: Address = - super::make_address(0xfefae79e, 0x4180eb0284f261205e3f8cea737aff56); - - pub fn new(current_account_id: AccountId) -> Self { - Self { current_account_id } - } -} - -impl Precompile for CurrentAccount { - fn required_gas(_input: &[u8]) -> Result { - Ok(costs::PREDECESSOR_ACCOUNT_GAS) - } - - fn run( - &self, - input: &[u8], - target_gas: Option, - _context: &Context, - _is_static: bool, - ) -> EvmPrecompileResult { - let cost = Self::required_gas(input)?; - if let Some(target_gas) = target_gas { - if cost > target_gas { - return Err(ExitError::OutOfGas); - } - } - - Ok( - PrecompileOutput::without_logs(cost, self.current_account_id.as_bytes().to_vec()) - .into(), - ) - } -} - -#[cfg(test)] -mod tests { - use crate::account_ids::{CurrentAccount, PredecessorAccount}; - use crate::prelude::sdk::types::near_account_to_evm_address; - - #[test] - fn test_predecessor_account_precompile_id() { - assert_eq!( - PredecessorAccount::ADDRESS, - near_account_to_evm_address("predecessorAccountId".as_bytes()) - ); - } - - #[test] - fn test_curent_account_precompile_id() { - assert_eq!( - CurrentAccount::ADDRESS, - near_account_to_evm_address("currentAccountId".as_bytes()) - ); - } -} diff --git a/engine-precompiles/src/lib.rs b/engine-precompiles/src/lib.rs index a7bfc88e9..7e4089dc5 100644 --- a/engine-precompiles/src/lib.rs +++ b/engine-precompiles/src/lib.rs @@ -2,7 +2,6 @@ #![cfg_attr(not(feature = "std"), no_std)] #![cfg_attr(not(feature = "std"), feature(alloc_error_handler))] -pub mod account_ids; pub mod blake2; pub mod bn128; pub mod hash; @@ -15,7 +14,6 @@ pub mod secp256k1; #[cfg(test)] mod utils; -use crate::account_ids::{CurrentAccount, PredecessorAccount}; use crate::blake2::Blake2F; use crate::bn128::{Bn128Add, Bn128Mul, Bn128Pair}; use crate::hash::{RIPEMD160, SHA256}; @@ -126,7 +124,6 @@ impl executor::stack::PrecompileSet for Precompiles { pub struct PrecompileConstructorContext { pub current_account_id: AccountId, pub random_seed: H256, - pub predecessor_account_id: AccountId, } impl Precompiles { @@ -139,18 +136,14 @@ impl Precompiles { ExitToNear::ADDRESS, ExitToEthereum::ADDRESS, RandomSeed::ADDRESS, - CurrentAccount::ADDRESS, - PredecessorAccount::ADDRESS, ]; let fun: prelude::Vec> = vec![ Box::new(ECRecover), Box::new(SHA256), Box::new(RIPEMD160), Box::new(ExitToNear::new(ctx.current_account_id.clone())), - Box::new(ExitToEthereum::new(ctx.current_account_id.clone())), + Box::new(ExitToEthereum::new(ctx.current_account_id)), Box::new(RandomSeed::new(ctx.random_seed)), - Box::new(CurrentAccount::new(ctx.current_account_id)), - Box::new(PredecessorAccount::new(ctx.predecessor_account_id)), ]; let map: BTreeMap> = addresses.into_iter().zip(fun).collect(); @@ -171,8 +164,6 @@ impl Precompiles { ExitToNear::ADDRESS, ExitToEthereum::ADDRESS, RandomSeed::ADDRESS, - CurrentAccount::ADDRESS, - PredecessorAccount::ADDRESS, ]; let fun: prelude::Vec> = vec![ Box::new(ECRecover), @@ -184,10 +175,8 @@ impl Precompiles { Box::new(Bn128Mul::::new()), Box::new(Bn128Pair::::new()), Box::new(ExitToNear::new(ctx.current_account_id.clone())), - Box::new(ExitToEthereum::new(ctx.current_account_id.clone())), + Box::new(ExitToEthereum::new(ctx.current_account_id)), Box::new(RandomSeed::new(ctx.random_seed)), - Box::new(CurrentAccount::new(ctx.current_account_id)), - Box::new(PredecessorAccount::new(ctx.predecessor_account_id)), ]; let map: BTreeMap> = addresses.into_iter().zip(fun).collect(); @@ -208,8 +197,6 @@ impl Precompiles { ExitToNear::ADDRESS, ExitToEthereum::ADDRESS, RandomSeed::ADDRESS, - CurrentAccount::ADDRESS, - PredecessorAccount::ADDRESS, ]; let fun: prelude::Vec> = vec![ Box::new(ECRecover), @@ -222,10 +209,8 @@ impl Precompiles { Box::new(Bn128Pair::::new()), Box::new(Blake2F), Box::new(ExitToNear::new(ctx.current_account_id.clone())), - Box::new(ExitToEthereum::new(ctx.current_account_id.clone())), + Box::new(ExitToEthereum::new(ctx.current_account_id)), Box::new(RandomSeed::new(ctx.random_seed)), - Box::new(CurrentAccount::new(ctx.current_account_id)), - Box::new(PredecessorAccount::new(ctx.predecessor_account_id)), ]; let map: BTreeMap> = addresses.into_iter().zip(fun).collect(); @@ -246,8 +231,6 @@ impl Precompiles { ExitToNear::ADDRESS, ExitToEthereum::ADDRESS, RandomSeed::ADDRESS, - CurrentAccount::ADDRESS, - PredecessorAccount::ADDRESS, ]; let fun: prelude::Vec> = vec![ Box::new(ECRecover), @@ -260,10 +243,8 @@ impl Precompiles { Box::new(Bn128Pair::::new()), Box::new(Blake2F), Box::new(ExitToNear::new(ctx.current_account_id.clone())), - Box::new(ExitToEthereum::new(ctx.current_account_id.clone())), + Box::new(ExitToEthereum::new(ctx.current_account_id)), Box::new(RandomSeed::new(ctx.random_seed)), - Box::new(CurrentAccount::new(ctx.current_account_id)), - Box::new(PredecessorAccount::new(ctx.predecessor_account_id)), ]; let map: BTreeMap> = addresses.into_iter().zip(fun).collect(); diff --git a/engine-tests/src/tests/account_id_precompiles.rs b/engine-tests/src/tests/account_id_precompiles.rs deleted file mode 100644 index bd60ad758..000000000 --- a/engine-tests/src/tests/account_id_precompiles.rs +++ /dev/null @@ -1,69 +0,0 @@ -use crate::test_utils::{self, standalone}; -use aurora_engine::parameters::SubmitResult; - -#[test] -fn test_account_id_precompiles() { - let mut signer = test_utils::Signer::random(); - let mut runner = test_utils::deploy_evm(); - let mut standalone = standalone::StandaloneRunner::default(); - - standalone.init_evm(); - runner.standalone_runner = Some(standalone); - - let constructor = test_utils::solidity::ContractConstructor::compile_from_source( - "src/tests/res", - "target/solidity_build", - "AccountIds.sol", - "AccountIds", - ); - - // deploy contract - let nonce = signer.use_nonce(); - let contract = runner.deploy_contract( - &signer.secret_key, - |c| c.deploy_without_constructor(nonce.into()), - constructor, - ); - - // check current_account_id is correct - let result = runner - .submit_with_signer(&mut signer, |nonce| { - contract.call_method_without_args("currentAccountId", nonce) - }) - .unwrap(); - assert_eq!(unwrap_ethabi_string(&result), "aurora"); - - // check predecessor_account_id is correct - let result = runner - .submit_with_signer(&mut signer, |nonce| { - contract.call_method_without_args("predecessorAccountId", nonce) - }) - .unwrap(); - assert_eq!(unwrap_ethabi_string(&result), "some-account.near"); - - // double check the case where account_id is the full 64 bytes - let account_id = "abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789"; - assert_eq!(account_id.len(), 64); - runner.standalone_runner.as_mut().unwrap().env.block_height += 1000; - runner - .standalone_runner - .as_mut() - .unwrap() - .env - .current_account_id = account_id.parse().unwrap(); - let nonce = signer.use_nonce(); - let tx = contract.call_method_without_args("currentAccountId", nonce.into()); - let result = runner - .standalone_runner - .as_mut() - .unwrap() - .submit_transaction(&signer.secret_key, tx) - .unwrap(); - assert_eq!(unwrap_ethabi_string(&result), account_id); -} - -fn unwrap_ethabi_string(result: &SubmitResult) -> String { - let bytes = test_utils::unwrap_success_slice(result); - let mut tokens = ethabi::decode(&[ethabi::ParamType::String], &bytes).unwrap(); - tokens.pop().unwrap().into_string().unwrap() -} diff --git a/engine-tests/src/tests/mod.rs b/engine-tests/src/tests/mod.rs index 84b3a1b7d..6f6d09ad3 100644 --- a/engine-tests/src/tests/mod.rs +++ b/engine-tests/src/tests/mod.rs @@ -1,5 +1,4 @@ mod access_lists; -mod account_id_precompiles; mod contract_call; mod eip1559; mod erc20; diff --git a/engine-tests/src/tests/res/AccountIds.sol b/engine-tests/src/tests/res/AccountIds.sol deleted file mode 100644 index 92d0a10bd..000000000 --- a/engine-tests/src/tests/res/AccountIds.sol +++ /dev/null @@ -1,45 +0,0 @@ -// SPDX-License-Identifier: CC0-1.0 -pragma solidity ^0.8.0; - -contract AccountIds { - function currentAccountId() public returns (string memory) { - // Near accounts are at most 64 1-byte characters (see https://docs.near.org/docs/concepts/account#account-id-rules) - bytes32[2] memory value; - - assembly { - let ret := call(gas(), 0xfefae79e4180eb0284f261205e3f8cea737aff56, 0, 0, 0, value, 64) - } - - return bytes64ToString(value); - } - - function predecessorAccountId() public returns (string memory) { - // Near accounts are at most 64 1-byte characters (see https://docs.near.org/docs/concepts/account#account-id-rules) - bytes32[2] memory value; - - assembly { - let ret := call(gas(), 0x723ffbaba940e75e7bf5f6d61dcbf8d9a4de0fd7, 0, 0, 0, value, 64) - } - - return bytes64ToString(value); - } - - function bytes64ToString(bytes32[2] memory value) private pure returns (string memory) { - uint8 result_len = 0; - while((result_len < 32 && value[0][result_len] != 0) || (result_len >= 32 && result_len < 64 && value[1][result_len - 32] != 0)) { - result_len++; - } - bytes memory result = new bytes(result_len); - uint8 i = 0; - for (i = 0; i < 32 && value[0][i] != 0; i++) { - result[i] = value[0][i]; - } - if (result_len > 32) { - for (i = 0; i < 32 && value[1][i] != 0; i++) { - result[i + 32] = value[1][i]; - } - } - - return string(result); - } -} diff --git a/engine/src/engine.rs b/engine/src/engine.rs index 115284685..be92dd18e 100644 --- a/engine/src/engine.rs +++ b/engine/src/engine.rs @@ -346,17 +346,11 @@ struct StackExecutorParams { } impl StackExecutorParams { - fn new( - gas_limit: u64, - current_account_id: AccountId, - predecessor_account_id: AccountId, - random_seed: H256, - ) -> Self { + fn new(gas_limit: u64, current_account_id: AccountId, random_seed: H256) -> Self { Self { precompiles: Precompiles::new_london(PrecompileConstructorContext { current_account_id, random_seed, - predecessor_account_id, }), gas_limit, } @@ -516,7 +510,6 @@ impl<'env, I: IO + Copy, E: Env> Engine<'env, I, E> { let executor_params = StackExecutorParams::new( gas_limit, self.current_account_id.clone(), - self.env.predecessor_account_id(), self.env.random_seed(), ); let mut executor = executor_params.make_executor(self); @@ -601,7 +594,6 @@ impl<'env, I: IO + Copy, E: Env> Engine<'env, I, E> { let executor_params = StackExecutorParams::new( gas_limit, self.current_account_id.clone(), - self.env.predecessor_account_id(), self.env.random_seed(), ); let mut executor = executor_params.make_executor(self); @@ -651,7 +643,6 @@ impl<'env, I: IO + Copy, E: Env> Engine<'env, I, E> { let executor_params = StackExecutorParams::new( gas_limit, self.current_account_id.clone(), - self.env.predecessor_account_id(), self.env.random_seed(), ); let mut executor = executor_params.make_executor(self);