Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/main' into move-motsu
Browse files Browse the repository at this point in the history
# Conflicts:
#	lib/motsu/README.md
  • Loading branch information
qalisander committed Dec 19, 2024
2 parents 208a521 + 4de08e5 commit de1faf4
Show file tree
Hide file tree
Showing 14 changed files with 87 additions and 44 deletions.
6 changes: 1 addition & 5 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [Unreleased]
## [v0.2.0-alpha.2] - 2024-12-18

### Added

Expand All @@ -27,10 +27,6 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Changed (Breaking)

- Update internal functions of `Erc721` and `Erc721Consecutive` to accept a reference to `Bytes`. #437
- Stop supporting reentrancy, and borrow `self` immutably in `IErc721::_check_on_erc721_received`. #440
- Remove `&mut self` parameter from `IErc1155::_check_on_erc1155_received` and make it an associated function. #440
- Remove `storage: &mut impl TopLevelStorage` parameter from `ecdsa::recover`. #440
- Remove `TopLevelStorage` trait implementation from `VestingWallet`, `Erc1155`, `Erc20Permit`, `SafeErc20`, `Erc721Consecutive`, and `Erc721`. #440

### Fixed

Expand Down
40 changes: 20 additions & 20 deletions Cargo.lock

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

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ authors = ["OpenZeppelin"]
edition = "2021"
license = "MIT"
repository = "https://github.com/OpenZeppelin/rust-contracts-stylus"
version = "0.2.0-alpha.1"
version = "0.2.0-alpha.2"

[workspace.lints.rust]
missing_docs = "warn"
Expand Down
9 changes: 7 additions & 2 deletions contracts/src/finance/vesting_wallet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ use stylus_sdk::{
call::{self, call, Call},
contract, evm, function_selector,
prelude::storage,
storage::{StorageMap, StorageU256, StorageU64},
storage::{StorageMap, StorageU256, StorageU64, TopLevelStorage},
stylus_proc::{public, SolidityError},
};

Expand Down Expand Up @@ -118,6 +118,11 @@ pub struct VestingWallet {
pub safe_erc20: SafeErc20,
}

/// NOTE: Implementation of [`TopLevelStorage`] to be able use `&mut self` when
/// calling other contracts and not `&mut (impl TopLevelStorage +
/// BorrowMut<Self>)`. Should be fixed in the future by the Stylus team.
unsafe impl TopLevelStorage for VestingWallet {}

/// Required interface of a [`VestingWallet`] compliant contract.
#[interface_id]
pub trait IVestingWallet {
Expand Down Expand Up @@ -421,7 +426,7 @@ impl IVestingWallet for VestingWallet {

let owner = self.ownable.owner();

call(Call::new().value(amount), owner, &[])?;
call(Call::new_in(self).value(amount), owner, &[])?;

evm::log(EtherReleased { amount });

Expand Down
2 changes: 1 addition & 1 deletion contracts/src/token/erc1155/extensions/supply.rs
Original file line number Diff line number Diff line change
Expand Up @@ -279,7 +279,7 @@ impl Erc1155Supply {
self._update(from, to, ids.clone(), values.clone())?;

if !to.is_zero() {
Erc1155::_check_on_erc1155_received(
self.erc1155._check_on_erc1155_received(
msg::sender(),
from,
to,
Expand Down
2 changes: 1 addition & 1 deletion contracts/src/token/erc1155/extensions/uri_storage.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ mod tests {
use stylus_sdk::prelude::storage;

use super::Erc1155UriStorage;
use crate::token::erc1155::extensions::Erc1155MetadataUri;
use crate::token::erc1155::{extensions::Erc1155MetadataUri, Erc1155};

fn random_token_id() -> U256 {
let num: u32 = rand::random();
Expand Down
13 changes: 10 additions & 3 deletions contracts/src/token/erc1155/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use stylus_sdk::{
call::{self, Call, MethodError},
evm, function_selector, msg,
prelude::{public, storage, AddressVM, SolidityError},
storage::{StorageBool, StorageMap, StorageU256},
storage::{StorageBool, StorageMap, StorageU256, TopLevelStorage},
};

use crate::utils::{
Expand Down Expand Up @@ -194,6 +194,11 @@ pub struct Erc1155 {
StorageMap<Address, StorageMap<Address, StorageBool>>,
}

/// NOTE: Implementation of [`TopLevelStorage`] to be able use `&mut self` when
/// calling other contracts and not `&mut (impl TopLevelStorage +
/// BorrowMut<Self>)`. Should be fixed in the future by the Stylus team.
unsafe impl TopLevelStorage for Erc1155 {}

/// Required interface of an [`Erc1155`] compliant contract.
#[interface_id]
pub trait IErc1155 {
Expand Down Expand Up @@ -557,7 +562,7 @@ impl Erc1155 {
self._update(from, to, ids.clone(), values.clone())?;

if !to.is_zero() {
Erc1155::_check_on_erc1155_received(
self._check_on_erc1155_received(
msg::sender(),
from,
to,
Expand Down Expand Up @@ -767,6 +772,7 @@ impl Erc1155 {
///
/// # Arguments
///
/// * `&mut self` - Write access to the contract's state.
/// * `operator` - Generally the address that initiated the token transfer
/// (e.g. `msg::sender()`).
/// * `from` - Account of the sender.
Expand All @@ -785,6 +791,7 @@ impl Erc1155 {
/// interface id or returned with error, then the error
/// [`Error::InvalidReceiver`] is returned.
fn _check_on_erc1155_received(
&mut self,
operator: Address,
from: Address,
to: Address,
Expand All @@ -796,7 +803,7 @@ impl Erc1155 {
}

let receiver = IERC1155Receiver::new(to);
let call = Call::new();
let call = Call::new_in(self);
let result = match details.transfer {
Transfer::Single { id, value } => receiver
.on_erc_1155_received(call, operator, from, id, value, data),
Expand Down
8 changes: 7 additions & 1 deletion contracts/src/token/erc20/extensions/permit.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ use alloy_sol_types::SolType;
use stylus_sdk::{
block,
prelude::{storage, StorageType},
storage::TopLevelStorage,
stylus_proc::{public, SolidityError},
};

Expand Down Expand Up @@ -81,6 +82,11 @@ pub struct Erc20Permit<T: IEip712 + StorageType> {
pub eip712: T,
}

/// NOTE: Implementation of [`TopLevelStorage`] to be able use `&mut self` when
/// calling other contracts and not `&mut (impl TopLevelStorage +
/// BorrowMut<Self>)`. Should be fixed in the future by the Stylus team.
unsafe impl<T: IEip712 + StorageType> TopLevelStorage for Erc20Permit<T> {}

#[public]
impl<T: IEip712 + StorageType> Erc20Permit<T> {
/// Returns the current nonce for `owner`.
Expand Down Expand Up @@ -171,7 +177,7 @@ impl<T: IEip712 + StorageType> Erc20Permit<T> {

let hash: B256 = self.eip712.hash_typed_data_v4(struct_hash);

let signer: Address = ecdsa::recover(hash, v, r, s)?;
let signer: Address = ecdsa::recover(self, hash, v, r, s)?;

if signer != owner {
return Err(ERC2612InvalidSigner { signer, owner }.into());
Expand Down
6 changes: 6 additions & 0 deletions contracts/src/token/erc20/utils/safe_erc20.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ use stylus_sdk::{
evm::gas_left,
function_selector,
prelude::storage,
storage::TopLevelStorage,
stylus_proc::{public, SolidityError},
types::AddressVM,
};
Expand Down Expand Up @@ -87,6 +88,11 @@ mod token {
#[storage]
pub struct SafeErc20 {}

/// NOTE: Implementation of [`TopLevelStorage`] to be able use `&mut self` when
/// calling other contracts and not `&mut (impl TopLevelStorage +
/// BorrowMut<Self>)`. Should be fixed in the future by the Stylus team.
unsafe impl TopLevelStorage for SafeErc20 {}

/// Required interface of a [`SafeErc20`] utility contract.
pub trait ISafeErc20 {
/// The error type associated to this trait implementation.
Expand Down
4 changes: 3 additions & 1 deletion contracts/src/token/erc721/extensions/consecutive.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ use alloy_primitives::{uint, Address, U256};
use stylus_sdk::{
abi::Bytes,
evm, msg,
prelude::storage,
prelude::{storage, TopLevelStorage},
stylus_proc::{public, SolidityError},
};

Expand Down Expand Up @@ -140,6 +140,8 @@ pub enum Error {
ForbiddenBatchBurn(ERC721ForbiddenBatchBurn),
}

unsafe impl TopLevelStorage for Erc721Consecutive {}

// ************** ERC-721 External **************

#[public]
Expand Down
Loading

0 comments on commit de1faf4

Please sign in to comment.