ERC-1155 Supply
The OpenZeppelin ERC-1155 Supply extension that adds tracking of total supply per token id. Useful for scenarios where Fungible and Non-fungible tokens have to be clearly identified.
Usage
In order to make an ERC-1155 token with Supply flavour,
you need to reexport all the supply-related functions.
Make sure to apply the #[selector(name = "totalSupply")]
attribute to the total_supply_all
function!
You need to create the specified contract as follows:
use openzeppelin_stylus::{
token::erc1155::{
self,
extensions::{Erc1155Supply, IErc1155Supply},
IErc1155,
},
utils::introspection::erc165::IErc165,
};
#[entrypoint]
#[storage]
struct Erc1155Example {
erc1155_supply: Erc1155Supply,
}
#[public]
#[implements(IErc1155<Error = erc1155::Error>, IErc1155Supply, IErc165)]
impl Erc1155Example {
// Add token minting feature.
fn mint(
&mut self,
to: Address,
id: U256,
value: U256,
data: Bytes,
) -> Result<(), erc1155::Error> {
self.erc1155_supply._mint(to, id, value, &data)
}
fn mint_batch(
&mut self,
to: Address,
ids: Vec<U256>,
values: Vec<U256>,
data: Bytes,
) -> Result<(), erc1155::Error> {
self.erc1155_supply._mint_batch(to, ids, values, &data)
}
}
#[public]
impl IErc1155Supply for Erc1155Example {
fn total_supply(&self, id: U256) -> U256 {
self.erc1155_supply.total_supply(id)
}
#[selector(name = "totalSupply")]
fn total_supply_all(&self) -> U256 {
self.erc1155_supply.total_supply_all()
}
fn exists(&self, id: U256) -> bool {
self.erc1155_supply.exists(id)
}
}
#[public]
impl IErc1155 for Erc1155Example {
type Error = erc1155::Error;
fn balance_of(&self, account: Address, id: U256) -> U256 {
self.erc1155_supply.balance_of(account, id)
}
fn balance_of_batch(
&self,
accounts: Vec<Address>,
ids: Vec<U256>,
) -> Result<Vec<U256>, Self::Error> {
self.erc1155_supply.balance_of_batch(accounts, ids)
}
fn set_approval_for_all(
&mut self,
operator: Address,
approved: bool,
) -> Result<(), Self::Error> {
self.erc1155_supply.set_approval_for_all(operator, approved)
}
fn is_approved_for_all(&self, account: Address, operator: Address) -> bool {
self.erc1155_supply.is_approved_for_all(account, operator)
}
fn safe_transfer_from(
&mut self,
from: Address,
to: Address,
id: U256,
value: U256,
data: Bytes,
) -> Result<(), Self::Error> {
self.erc1155_supply.safe_transfer_from(from, to, id, value, data)
}
fn safe_batch_transfer_from(
&mut self,
from: Address,
to: Address,
ids: Vec<U256>,
values: Vec<U256>,
data: Bytes,
) -> Result<(), Self::Error> {
self.erc1155_supply
.safe_batch_transfer_from(from, to, ids, values, data)
}
}
#[public]
impl IErc165 for Erc1155Example {
fn supports_interface(&self, interface_id: FixedBytes<4>) -> bool {
self.erc1155_supply.supports_interface(interface_id)
}
}