Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: ERC1155 #275

Merged
merged 80 commits into from
Nov 7, 2024
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
80 commits
Select commit Hold shift + click to select a range
c24e0bd
build erc1155 skeleton
programskillforverification Sep 4, 2024
b0539cd
migrate erc1155 uri-storage
programskillforverification Sep 5, 2024
ae3a353
add IErc1155 trait
programskillforverification Sep 6, 2024
f049f1d
try the first erc1155 internal func implementation
programskillforverification Sep 7, 2024
0188be0
add balanceof func and some tests
programskillforverification Sep 9, 2024
b136375
Merge branch 'main' into erc1155
programskillforverification Sep 13, 2024
5b871cc
fix all errors
programskillforverification Sep 13, 2024
b65f68b
add approval func and related tests
programskillforverification Sep 16, 2024
9883651
Merge branch 'main' into erc1155
programskillforverification Sep 18, 2024
654b51b
develop supply extension
programskillforverification Sep 20, 2024
1b2d10e
finish burnable and mod
programskillforverification Sep 21, 2024
4cbbeb7
Merge branch 'main' into erc1155
programskillforverification Sep 21, 2024
dd932cd
rest extensions done
programskillforverification Sep 21, 2024
47afca5
Merge branch 'main' into erc1155
programskillforverification Sep 24, 2024
ccaf2cc
init lib
programskillforverification Sep 24, 2024
cb1ce66
run the first test
programskillforverification Sep 24, 2024
49ba267
Merge branch 'main' into erc1155
programskillforverification Sep 24, 2024
6fc6753
Merge branch 'erc1155-test' into erc1155
programskillforverification Sep 24, 2024
6a87bf9
delete keyword
programskillforverification Sep 24, 2024
60acb14
Merge branch 'main' into erc1155
programskillforverification Sep 25, 2024
a12504b
Merge branch 'main' into erc1155
programskillforverification Sep 27, 2024
bb9627d
erc1155 example
programskillforverification Sep 30, 2024
8e9b006
Merge branch 'main' into erc1155
programskillforverification Sep 30, 2024
3ee507b
add IErc165 to Erc1155`
qalisander Sep 30, 2024
3e7618e
optimise imports
qalisander Sep 30, 2024
11247de
build(deps): bump crate-ci/typos from 1.24.6 to 1.25.0 (#303)
dependabot[bot] Oct 1, 2024
efb27da
Merge branch 'main' into erc1155
programskillforverification Oct 2, 2024
d9a4b62
fix all and add e2e tests
programskillforverification Oct 4, 2024
ea2a6b0
Merge branch 'main' into erc1155
bidzyyys Oct 4, 2024
3c52026
fix: remove redundat stylus-proc dependency
bidzyyys Oct 4, 2024
c22de71
fix: cargo doc
bidzyyys Oct 4, 2024
7901af7
split erc1155 and erc1155-supply
qalisander Oct 4, 2024
1977335
split erc1155 and erc1155-burnable
qalisander Oct 4, 2024
b2c7354
review fixes
qalisander Oct 7, 2024
ef23ba9
remove pausable
qalisander Oct 7, 2024
d3230e4
remove pausable from constructs test
qalisander Oct 7, 2024
f2c2a0f
chore: rename in docs
bidzyyys Oct 8, 2024
3e436df
docs: remove redundant links
bidzyyys Oct 8, 2024
541345b
docs: improve docs for IErc1155 trait
bidzyyys Oct 8, 2024
5452245
ref: IErc1155 trait impl
bidzyyys Oct 8, 2024
dded816
ref: re-use common code
bidzyyys Oct 8, 2024
dc1fc03
docs: docs for Erc1155ReceiverData
bidzyyys Oct 9, 2024
1674f63
test: add unit tests for Erc1155ReceiverData
bidzyyys Oct 9, 2024
090244a
docs: update code docs for ERC-1155 token
bidzyyys Oct 9, 2024
c7b358d
Merge branch 'main' into erc1155
bidzyyys Oct 9, 2024
35a66eb
test(e2e): remove impossible scenarios
bidzyyys Oct 9, 2024
c8f321d
feat: add benches for Erc1155 contract
bidzyyys Oct 10, 2024
b1e8cba
Merge branch 'main' into erc1155
bidzyyys Oct 21, 2024
2046916
ref: remove warning around IERC1155Receiver
bidzyyys Oct 24, 2024
ce661f8
fix: bump Rust version
bidzyyys Oct 24, 2024
5e66a8f
test(e2e): improve E2E tests for Erc1155 contract
bidzyyys Oct 25, 2024
4eb9f69
ref: split IERC1155Receiver interface to another file
bidzyyys Oct 25, 2024
f98e5b3
test(e2e): add E2E tests for ERC1155ReceiverMock transfers
bidzyyys Oct 28, 2024
652007e
test(e2e): E2E tests for batch transfers to ERC1155Receiver contract
bidzyyys Oct 29, 2024
eaf440f
Merge branch 'main' into erc1155
bidzyyys Oct 29, 2024
78e3ea7
test: improve unit tests for Erc1155
bidzyyys Oct 29, 2024
c2ffbde
test: add E2E tests for ERC1155Receiver mints
bidzyyys Oct 30, 2024
0d61c97
Merge branch 'main' into erc1155
bidzyyys Oct 30, 2024
ed1720c
fix: clippy
bidzyyys Oct 30, 2024
ffa4cc8
fix: clippy pass by reference
bidzyyys Oct 30, 2024
d576da8
fix: clippy
bidzyyys Oct 30, 2024
4bd4d12
fix: tests
bidzyyys Oct 30, 2024
e3af8f6
fix: disable clippy used_underscore_items
bidzyyys Oct 30, 2024
af9dadb
Merge branch 'main' into erc1155
bidzyyys Oct 30, 2024
4f16cba
ref: apply CR changes
bidzyyys Nov 2, 2024
c6ad909
Merge branch 'main' into erc1155
bidzyyys Nov 4, 2024
4710faf
owner->account in balance_of comment
0xNeshi Nov 7, 2024
412745d
Fix minor comment issues
0xNeshi Nov 7, 2024
ed2e27c
Merge branch 'main' into erc1155
bidzyyys Nov 7, 2024
361a2b1
docs: update CHANGELOG
bidzyyys Nov 7, 2024
537c2aa
more comment fixes
0xNeshi Nov 7, 2024
b48c1fe
remove redundant multiple accounts in mints_batch
0xNeshi Nov 7, 2024
2f53114
remove empty ctor from Erc1155Example
0xNeshi Nov 7, 2024
cb1e8c6
Add missing unit test cases
0xNeshi Nov 7, 2024
d892603
add missing unit tests
0xNeshi Nov 7, 2024
4ac18dc
Add missing burn-related e2e tests
0xNeshi Nov 7, 2024
55500ae
Merge branch 'main' into erc1155
0xNeshi Nov 7, 2024
efcad3d
Merge branch 'main' into erc1155
bidzyyys Nov 7, 2024
37d0ce1
chore: revert burnable E2E tests
bidzyyys Nov 7, 2024
0b37cf5
fix: benches
bidzyyys Nov 7, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 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 @@ -17,7 +17,7 @@ members = [
"examples/basic/token",
"examples/basic/script",
"examples/ecdsa",
"benches",
"benches", "examples/erc1155",
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
]
default-members = [
"contracts",
Expand Down
69 changes: 69 additions & 0 deletions contracts/src/token/erc1155/extensions/burnable.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
//! Extension of {ERC1155} that allows token holders to destroy both their
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
//! own tokens and those that they have been approved to use.

use alloc::vec::Vec;

use alloy_primitives::{Address, U256};

/// Extension of [`Erc1155`] that allows token holders to destroy both their
/// own tokens and those that they have been approved to use.
pub trait IErc1155Burnable {
/// The error type associated to this ERC-1155 burnable trait
/// implementation.
type Error: Into<alloc::vec::Vec<u8>>;

/// Extension of {ERC1155} that allows token holders to destroy both their
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
/// own tokens and those that they have been approved to use.
///
/// The approval is cleared when the token is burned. Relies on the `_burn`
/// mechanism.
///
/// # Arguments
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
///
/// * `value` - Amount to be burnt.
///
/// # Errors
///
/// If the caller is not account address and the account has not been
/// approved, then the error [`Error::MissingApprovalForAll`] is
/// returned.
///
/// # Requirements:
///
/// * `token_id` must exist.
/// * The caller or account must own `token_id` or be an approved operator.
fn burn(
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
&mut self,
account: Address,
token_id: U256,
value: U256,
) -> Result<(), Self::Error>;

/// Extension of {ERC1155} that allows token holders to destroy both their
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
/// own tokens and those that they have been approved to use.
///
/// The approval is cleared when the token is burned. Relies on the `_burn`
/// mechanism.
///
/// # Arguments
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
///
/// * `values` - All amount to be burnt.
/// * `ids` - All amount to be burnt.
///
/// # Errors
///
/// If the caller is not account address and the account has not been
/// approved, then the error [`Error::MissingApprovalForAll`] is
/// returned.
///
/// # Requirements:
///
/// * `token_id` must exist.
/// * The caller or account must own `token_id` or be an approved operator.
fn burn_batch(
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
&mut self,
account: Address,
ids: Vec<U256>,
values: Vec<U256>,
) -> Result<(), Self::Error>;
}
4 changes: 4 additions & 0 deletions contracts/src/token/erc1155/extensions/mod.rs
bidzyyys marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
//! Common extensions to the ERC-1155 standard.
pub mod burnable;
pub mod supply;
pub mod uri_storage;
12 changes: 12 additions & 0 deletions contracts/src/token/erc1155/extensions/supply.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
//! Extension of ERC-1155 that adds tracking of total supply per id.
//!
//! Useful for scenarios where Fungible and Non-fungible tokens have to be
//! clearly identified. Note: While a totalSupply of 1 might mean the
//! corresponding is an NFT, there is no guarantees that no other token
//! with the same id are not going to be minted.
//!
//! NOTE: This contract implies a global limit of 2**256 - 1 to the number
//! of tokens that can be minted.
//!
//! CAUTION: This extension should not be added in an upgrade to an already
//! deployed contract.
63 changes: 63 additions & 0 deletions contracts/src/token/erc1155/extensions/uri_storage.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
//! ERC-1155 token with storage based token URI management.
//!
//! Inspired by the {ERC721URIStorage} extension
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
use alloc::string::String;

use alloy_primitives::U256;
use alloy_sol_types::sol;
use stylus_proc::{external, sol_storage};
use stylus_sdk::evm;

sol! {

/// Emitted when the URI for token type `id` changes to `value`, if it is a non-programmatic URI.
///
/// If an {URI} event was emitted for `id`, the standard
/// https://eips.ethereum.org/EIPS/eip-1155#metadata-extensions[guarantees] that `value` will equal the value
/// returned by {IERC1155MetadataURI-uri}.
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
#[allow(missing_docs)]
event URI(string value, uint256 indexed id);
}

sol_storage! {
/// Uri Storage.
pub struct Erc1155UriStorage {
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
/// Optional mapping for token URIs.
mapping(uint256 => string) _token_uris;
/// Optional base URI
string _base_uri;
}
}

impl Erc1155UriStorage {
/// Sets `tokenURI` as the tokenURI of `tokenId`.
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
pub fn _set_uri(&mut self, token_id: U256, token_uri: String) {
self._token_uris.setter(token_id).set_str(token_uri);
evm::log(URI { value: self.uri(token_id), id: token_id });
}

/// Sets `baseURI` as the `_baseURI` for all tokens
programskillforverification marked this conversation as resolved.
Show resolved Hide resolved
pub fn _set_base_uri(&mut self, base_uri: String) {
self._base_uri.set_str(base_uri);
}
}

#[external]
impl Erc1155UriStorage {
/// Returns the Uniform Resource Identifier (URI) for `token_id` token.
///
/// # Arguments
///
/// * `&self` - Read access to the contract's state.
/// * `token_id` - Id of a token.
#[must_use]
pub fn uri(&self, token_id: U256) -> String {
if !self._token_uris.getter(token_id).is_empty() {
let update_uri = self._base_uri.get_string()
+ &self._token_uris.getter(token_id).get_string();
update_uri
} else {
todo!()
}
}
}
Loading
Loading