ERC1155Base
The ERC1155Base
smart contract implements the ERC1155 NFT standard. It includes the following additions to standard ERC1155 logic: - Ability to mint NFTs via the provided mintTo
and batchMintTo
functions. - Contract metadata for royalty support on platforms such as OpenSea that use off-chain information to distribute roaylties. - Ownership of the contract, with the ability to restrict certain functions to only be called by the contract's owner. - Multicall capability to perform multiple actions atomically - EIP 2981 compliance for royalty support on NFT marketplaces.
Methods
OPERATOR_FILTER_REGISTRY
function OPERATOR_FILTER_REGISTRY() external view returns (contract IOperatorFilterRegistry)
Returns
_0
contract IOperatorFilterRegistry
undefined
balanceOf
function balanceOf(address, uint256) external view returns (uint256)
Get the balance of an account's Tokens.
Parameters
_0
address
undefined
_1
uint256
undefined
Returns
_0
uint256
undefined
balanceOfBatch
function balanceOfBatch(address[] accounts, uint256[] ids) external view returns (uint256[])
Parameters
accounts
address[]
undefined
ids
uint256[]
undefined
Returns
_0
uint256[]
undefined
batchMintTo
function batchMintTo(address _to, uint256[] _tokenIds, uint256[] _amounts, string _baseURI) external nonpayable
Lets an authorized address mint multiple NEW NFTs at once to a recipient.
The logic in the _canMint
function determines whether the caller is authorized to mint NFTs. If _tokenIds[i] == type(uint256).max
a new NFT at tokenId nextTokenIdToMint
is minted. If the given tokenIds[i] < nextTokenIdToMint
, then additional supply of an existing NFT is minted. The metadata for each new NFT is stored at baseURI/{tokenID of NFT}
Parameters
_to
address
The recipient of the NFT to mint.
_tokenIds
uint256[]
The tokenIds of the NFTs to mint.
_amounts
uint256[]
The amounts of each NFT to mint.
_baseURI
string
The baseURI for the n
number of NFTs minted. The metadata for each NFT is baseURI/tokenId
burn
function burn(address _owner, uint256 _tokenId, uint256 _amount) external nonpayable
Lets an owner or approved operator burn NFTs of the given tokenId.
Parameters
_owner
address
The owner of the NFT to burn.
_tokenId
uint256
The tokenId of the NFT to burn.
_amount
uint256
The amount of the NFT to burn.
burnBatch
function burnBatch(address _owner, uint256[] _tokenIds, uint256[] _amounts) external nonpayable
Lets an owner or approved operator burn NFTs of the given tokenIds.
Parameters
_owner
address
The owner of the NFTs to burn.
_tokenIds
uint256[]
The tokenIds of the NFTs to burn.
_amounts
uint256[]
The amounts of the NFTs to burn.
contractURI
function contractURI() external view returns (string)
Returns the contract metadata URI.
Returns
_0
string
undefined
getBaseURICount
function getBaseURICount() external view returns (uint256)
Returns the count of batches of NFTs.
Each batch of tokens has an in ID and an associated baseURI
. See {batchIds}.
Returns
_0
uint256
undefined
getBatchIdAtIndex
function getBatchIdAtIndex(uint256 _index) external view returns (uint256)
Returns the ID for the batch of tokens the given tokenId belongs to.
See {getBaseURICount}.
Parameters
_index
uint256
ID of a token.
Returns
_0
uint256
undefined
getDefaultRoyaltyInfo
function getDefaultRoyaltyInfo() external view returns (address, uint16)
Returns the defualt royalty recipient and BPS for this contract's NFTs.
Returns
_0
address
undefined
_1
uint16
undefined
getRoyaltyInfoForToken
function getRoyaltyInfoForToken(uint256 _tokenId) external view returns (address, uint16)
View royalty info for a given token.
Returns royalty recipient and bps for _tokenId
.
Parameters
_tokenId
uint256
The tokenID of the NFT for which to query royalty info.
Returns
_0
address
undefined
_1
uint16
undefined
isApprovedForAll
function isApprovedForAll(address, address) external view returns (bool)
Queries the approval status of an operator for a given owner.
Parameters
_0
address
undefined
_1
address
undefined
Returns
_0
bool
undefined
mintTo
function mintTo(address _to, uint256 _tokenId, string _tokenURI, uint256 _amount) external nonpayable
Lets an authorized address mint NFTs to a recipient.
- The logic in the _canMint
function determines whether the caller is authorized to mint NFTs. - If _tokenId == type(uint256).max
a new NFT at tokenId nextTokenIdToMint
is minted. If the given tokenId < nextTokenIdToMint
, then additional supply of an existing NFT is being minted.
Parameters
_to
address
The recipient of the NFTs to mint.
_tokenId
uint256
The tokenId of the NFT to mint.
_tokenURI
string
The full metadata URI for the NFTs minted (if a new NFT is being minted).
_amount
uint256
The amount of the same NFT to mint.
multicall
function multicall(bytes[] data) external nonpayable returns (bytes[] results)
Receives and executes a batch of function calls on this contract.
Receives and executes a batch of function calls on this contract.
Parameters
data
bytes[]
The bytes data that makes up the batch of function calls to execute.
Returns
results
bytes[]
The bytes data that makes up the result of the batch of function calls executed.
name
function name() external view returns (string)
Returns
_0
string
undefined
nextTokenIdToMint
function nextTokenIdToMint() external view returns (uint256)
The tokenId assigned to the next new NFT to be minted.
Returns
_0
uint256
undefined
operatorRestriction
function operatorRestriction() external view returns (bool)
Returns
_0
bool
undefined
owner
function owner() external view returns (address)
Returns the owner of the contract.
Returns
_0
address
undefined
royaltyInfo
function royaltyInfo(uint256 tokenId, uint256 salePrice) external view returns (address receiver, uint256 royaltyAmount)
View royalty info for a given token and sale price.
Returns royalty amount and recipient for tokenId
and salePrice
.
Parameters
tokenId
uint256
The tokenID of the NFT for which to query royalty info.
salePrice
uint256
Sale price of the token.
Returns
receiver
address
Address of royalty recipient account.
royaltyAmount
uint256
Royalty amount calculated at current royaltyBps value.
safeBatchTransferFrom
function safeBatchTransferFrom(address from, address to, uint256[] ids, uint256[] amounts, bytes data) external nonpayable
See {IERC1155-safeBatchTransferFrom}.
Parameters
from
address
undefined
to
address
undefined
ids
uint256[]
undefined
amounts
uint256[]
undefined
data
bytes
undefined
safeTransferFrom
function safeTransferFrom(address from, address to, uint256 id, uint256 amount, bytes data) external nonpayable
See {IERC1155-safeTransferFrom}.
Parameters
from
address
undefined
to
address
undefined
id
uint256
undefined
amount
uint256
undefined
data
bytes
undefined
setApprovalForAll
function setApprovalForAll(address operator, bool approved) external nonpayable
See {ERC1155-setApprovalForAll}
Parameters
operator
address
undefined
approved
bool
undefined
setContractURI
function setContractURI(string _uri) external nonpayable
Lets a contract admin set the URI for contract-level metadata.
Caller should be authorized to setup contractURI, e.g. contract admin. See {_canSetContractURI}. Emits {ContractURIUpdated Event}.
Parameters
_uri
string
keccak256 hash of the role. e.g. keccak256("TRANSFER_ROLE")
setDefaultRoyaltyInfo
function setDefaultRoyaltyInfo(address _royaltyRecipient, uint256 _royaltyBps) external nonpayable
Updates default royalty recipient and bps.
Caller should be authorized to set royalty info. See {_canSetRoyaltyInfo}. Emits {DefaultRoyalty Event}; See {_setupDefaultRoyaltyInfo}.
Parameters
_royaltyRecipient
address
Address to be set as default royalty recipient.
_royaltyBps
uint256
Updated royalty bps.
setOperatorRestriction
function setOperatorRestriction(bool _restriction) external nonpayable
Parameters
_restriction
bool
undefined
setOwner
function setOwner(address _newOwner) external nonpayable
Lets an authorized wallet set a new owner for the contract.
Parameters
_newOwner
address
The address to set as the new owner of the contract.
setRoyaltyInfoForToken
function setRoyaltyInfoForToken(uint256 _tokenId, address _recipient, uint256 _bps) external nonpayable
Updates default royalty recipient and bps for a particular token.
Sets royalty info for _tokenId
. Caller should be authorized to set royalty info. See {_canSetRoyaltyInfo}. Emits {RoyaltyForToken Event}; See {_setupRoyaltyInfoForToken}.
Parameters
_tokenId
uint256
undefined
_recipient
address
Address to be set as royalty recipient for given token Id.
_bps
uint256
Updated royalty bps for the token Id.
supportsInterface
function supportsInterface(bytes4 interfaceId) external view returns (bool)
Returns whether this contract supports the given interface.
Parameters
interfaceId
bytes4
undefined
Returns
_0
bool
undefined
symbol
function symbol() external view returns (string)
Returns
_0
string
undefined
totalSupply
function totalSupply(uint256) external view returns (uint256)
Returns the total supply of NFTs of a given tokenId
Mapping from tokenId => total circulating supply of NFTs of that tokenId.
Parameters
_0
uint256
undefined
Returns
_0
uint256
undefined
uri
function uri(uint256 _tokenId) external view returns (string)
Returns the metadata URI for the given tokenId.
Parameters
_tokenId
uint256
undefined
Returns
_0
string
undefined
Events
ApprovalForAll
event ApprovalForAll(address indexed _owner, address indexed _operator, bool _approved)
Parameters
_owner indexed
address
undefined
_operator indexed
address
undefined
_approved
bool
undefined
ContractURIUpdated
event ContractURIUpdated(string prevURI, string newURI)
Parameters
prevURI
string
undefined
newURI
string
undefined
DefaultRoyalty
event DefaultRoyalty(address indexed newRoyaltyRecipient, uint256 newRoyaltyBps)
Parameters
newRoyaltyRecipient indexed
address
undefined
newRoyaltyBps
uint256
undefined
OperatorRestriction
event OperatorRestriction(bool restriction)
Parameters
restriction
bool
undefined
OwnerUpdated
event OwnerUpdated(address indexed prevOwner, address indexed newOwner)
Parameters
prevOwner indexed
address
undefined
newOwner indexed
address
undefined
RoyaltyForToken
event RoyaltyForToken(uint256 indexed tokenId, address indexed royaltyRecipient, uint256 royaltyBps)
Parameters
tokenId indexed
uint256
undefined
royaltyRecipient indexed
address
undefined
royaltyBps
uint256
undefined
TransferBatch
event TransferBatch(address indexed _operator, address indexed _from, address indexed _to, uint256[] _ids, uint256[] _values)
Parameters
_operator indexed
address
undefined
_from indexed
address
undefined
_to indexed
address
undefined
_ids
uint256[]
undefined
_values
uint256[]
undefined
TransferSingle
event TransferSingle(address indexed _operator, address indexed _from, address indexed _to, uint256 _id, uint256 _value)
Parameters
_operator indexed
address
undefined
_from indexed
address
undefined
_to indexed
address
undefined
_id
uint256
undefined
_value
uint256
undefined
URI
event URI(string _value, uint256 indexed _id)
Parameters
_value
string
undefined
_id indexed
uint256
undefined
Errors
OperatorNotAllowed
error OperatorNotAllowed(address operator)
Parameters
operator
address
undefined
Last updated