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

Add ERC1155 #896

Merged
merged 33 commits into from
Feb 29, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
e1ffb47
Add ERC1155 module, dual and interface
Dec 11, 2023
1378e54
Implement ERC1155 and update token_id variable names
Dec 12, 2023
5e27ef8
Add ERC1155 receiver mocks and test dual1155 receiver
Dec 12, 2023
8ec925e
apply linter
Dec 12, 2023
1e815d4
Update token_uri variable and remove IERC1155MetadataCamelOnly support
Dec 12, 2023
3fcd640
Add ERC1155 mocks and tests and add ERC1155 preset
Dec 15, 2023
5bf2d86
update CHANGELOG
Dec 15, 2023
7862594
adding PR number (#852)
Dec 15, 2023
1be1f2c
reset changlog
Dec 15, 2023
8836cdd
Merge branch 'main' into migrate-erc1155-contracts
Jan 17, 2024
24d695f
Update ERC1155Component Event and add batch_burn
Jan 18, 2024
fd41fdb
Add batch minting functions for ERC1155 tokens
Jan 18, 2024
5514177
Refactor code for better readability
Jan 24, 2024
a8e27e0
Merge branch 'migrate-erc1155-contracts' of github.com:cloudvenger/ca…
ericnordelo Feb 5, 2024
6ff198e
feat: finish first version with 2.5.3
ericnordelo Feb 5, 2024
d321db6
Merge branch 'main' of github.com:OpenZeppelin/cairo-contracts into f…
ericnordelo Feb 12, 2024
6172605
feat: apply review updates
ericnordelo Feb 12, 2024
c729003
feat: add tests
ericnordelo Feb 13, 2024
3b69f0e
feat: bump version and add entry to CHANGELOG
ericnordelo Feb 13, 2024
7877a83
Merge branch 'main' of github.com:OpenZeppelin/cairo-contracts into f…
ericnordelo Feb 13, 2024
57e3474
feat: add more tests
ericnordelo Feb 15, 2024
c4dc742
fix: remove print
ericnordelo Feb 15, 2024
76922ef
feat: add preset tests
ericnordelo Feb 16, 2024
6da745a
fix: format
ericnordelo Feb 16, 2024
027851a
feat: uncomment test
ericnordelo Feb 16, 2024
00a37e6
refactor: shortening test names
ericnordelo Feb 16, 2024
98dc3aa
Merge branch 'main' of github.com:OpenZeppelin/cairo-contracts into f…
ericnordelo Feb 20, 2024
814ccab
feat: move assertion
ericnordelo Feb 21, 2024
3e13f2c
Update src/token/erc1155/erc1155.cairo
ericnordelo Feb 22, 2024
43b8c67
fix: comments
ericnordelo Feb 22, 2024
991cc8d
Merge branch 'feat/erc1155-#572' of github.com:ericnordelo/cairo-cont…
ericnordelo Feb 22, 2024
71d6235
featL apply review updates
ericnordelo Feb 28, 2024
c77b3c1
feat: remove IAccount
ericnordelo Feb 29, 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
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

## Unreleased

### Added

- ERC1155 component and preset (#896)

### Changed

- Change unwrap to unwrap_syscall (#901)
Expand Down
2 changes: 2 additions & 0 deletions src/presets.cairo
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
mod account;
mod erc1155;
mod erc20;
mod erc721;
mod eth_account;

use account::Account;
use erc1155::ERC1155;
use erc20::ERC20;
use erc721::ERC721;
use eth_account::EthAccountUpgradeable;
72 changes: 72 additions & 0 deletions src/presets/erc1155.cairo
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts for Cairo v0.9.0 (presets/erc1155.cairo)

/// # ERC1155 Preset
///
/// The ERC1155 contract offers a batch-mint mechanism that
/// can only be executed once upon contract construction.
ericnordelo marked this conversation as resolved.
Show resolved Hide resolved
///
/// For more complex or custom contracts, use Wizard for Cairo
/// https://wizard.openzeppelin.com/cairo
#[starknet::contract]
mod ERC1155 {
use openzeppelin::introspection::src5::SRC5Component;
use openzeppelin::token::erc1155::ERC1155Component;
use starknet::ContractAddress;

component!(path: ERC1155Component, storage: erc1155, event: ERC1155Event);
component!(path: SRC5Component, storage: src5, event: SRC5Event);

// ERC1155
#[abi(embed_v0)]
impl ERC1155Impl = ERC1155Component::ERC1155Impl<ContractState>;
#[abi(embed_v0)]
impl ERC1155MetadataURIImpl =
ERC1155Component::ERC1155MetadataURIImpl<ContractState>;
#[abi(embed_v0)]
impl ERC1155Camel = ERC1155Component::ERC1155CamelImpl<ContractState>;
impl ERC1155InternalImpl = ERC1155Component::InternalImpl<ContractState>;

// SRC5
#[abi(embed_v0)]
impl SRC5Impl = SRC5Component::SRC5Impl<ContractState>;

#[storage]
struct Storage {
#[substorage(v0)]
erc1155: ERC1155Component::Storage,
#[substorage(v0)]
src5: SRC5Component::Storage
}

#[event]
#[derive(Drop, starknet::Event)]
enum Event {
#[flat]
ERC1155Event: ERC1155Component::Event,
#[flat]
SRC5Event: SRC5Component::Event
}

/// Sets the `token_uri`.
/// Mints the `values` for `token_ids` tokens to `recipient`.
ericnordelo marked this conversation as resolved.
Show resolved Hide resolved
///
/// Requirements:
///
/// - `to` is either an account contract (supporting ISRC6) or
/// supports the `IERC1155Receiver` interface.
/// - `token_ids` and `values` must have the same length.
#[constructor]
fn constructor(
ref self: ContractState,
token_uri: ByteArray,
recipient: ContractAddress,
token_ids: Span<u256>,
values: Span<u256>
) {
self.erc1155.initializer(token_uri);
self
.erc1155
.batch_mint_with_acceptance_check(recipient, token_ids, values, array![].span());
}
}
1 change: 1 addition & 0 deletions src/tests/account/test_secp256k1.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@ fn test_unpack_big_secp256k1_points() {
let (x, _) = StorePacking::unpack((xlow, xhigh_and_parity)).get_coordinates().unwrap_syscall();

assert_eq!(x, expected_x);
assert_eq!(y, expected_y);
}

#[test]
Expand Down
2 changes: 2 additions & 0 deletions src/tests/mocks.cairo
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
mod accesscontrol_mocks;
mod account_mocks;
mod erc1155_mocks;
mod erc1155_receiver_mocks;
martriay marked this conversation as resolved.
Show resolved Hide resolved
mod erc20_mocks;
mod erc721_mocks;
mod erc721_receiver_mocks;
Expand Down
Loading
Loading