ERC1155DelayedReveal
BASE: ERC1155LazyMint EXTENSION: DelayedReveal The ERC1155DelayedReveal
contract uses the DelayedReveal
extension. 'Lazy minting' means defining the metadata of NFTs without minting it to an address. Regular 'minting' of NFTs means actually assigning an owner to an NFT. As a contract admin, this lets you prepare the metadata for NFTs that will be minted by an external party, without paying the gas cost for actually minting the NFTs. 'Delayed reveal' is a mechanism by which you can distribute NFTs to your audience and reveal the metadata of the distributed NFTs, after the fact. You can read more about how the DelayedReveal
extension works, here: https://blog.thirdweb.com/delayed-reveal-nfts
Methods
OPERATOR_FILTER_REGISTRY
Returns
_0
contract IOperatorFilterRegistry
undefined
balanceOf
Get the balance of an account's Tokens.
Parameters
_0
address
undefined
_1
uint256
undefined
Returns
_0
uint256
undefined
balanceOfBatch
Parameters
accounts
address[]
undefined
ids
uint256[]
undefined
Returns
_0
uint256[]
undefined
burn
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
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.
claim
Lets an address claim multiple lazy minted NFTs at once to a recipient. This function prevents any reentrant calls, and is not allowed to be overridden. Contract creators should override verifyClaim
and transferTokensOnClaim
functions to create custom logic for verification and claiming, for e.g. price collection, allowlist, max quantity, etc.
The logic in verifyClaim
determines whether the caller is authorized to mint NFTs. The logic in transferTokensOnClaim
does actual minting of tokens, can also be used to apply other state changes.
Parameters
_receiver
address
The recipient of the tokens to mint.
_tokenId
uint256
The tokenId of the lazy minted NFT to mint.
_quantity
uint256
The number of tokens to mint.
contractURI
Returns the contract metadata URI.
Returns
_0
string
undefined
encryptDecrypt
Encrypt/decrypt data on chain.
Encrypt/decrypt given data
with key
. Uses inline assembly. See: https://ethereum.stackexchange.com/questions/69825/decrypt-message-on-chain
Parameters
data
bytes
Bytes of data to encrypt/decrypt.
key
bytes
Secure key used by caller for encryption/decryption.
Returns
result
bytes
Output after encryption/decryption of given data.
encryptedData
Parameters
_0
uint256
undefined
Returns
_0
bytes
undefined
getBaseURICount
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
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
Returns the defualt royalty recipient and BPS for this contract's NFTs.
Returns
_0
address
undefined
_1
uint16
undefined
getRevealURI
Returns revealed URI for a batch of NFTs.
Reveal encrypted base URI for _batchId
with caller/admin's _key
used for encryption. Reverts if there's no encrypted URI for _batchId
. See {encryptDecrypt}.
Parameters
_batchId
uint256
ID of the batch for which URI is being revealed.
_key
bytes
Secure key used by caller/admin for encryption of baseURI.
Returns
revealedURI
string
Decrypted base URI.
getRoyaltyInfoForToken
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
Queries the approval status of an operator for a given owner.
Parameters
_0
address
undefined
_1
address
undefined
Returns
_0
bool
undefined
isEncryptedBatch
Returns whether the relvant batch of NFTs is subject to a delayed reveal.
Returns true
if _batchId
's base URI is encrypted.
Parameters
_batchId
uint256
ID of a batch of NFTs.
Returns
_0
bool
undefined
lazyMint
Lets an authorized address lazy mint a given amount of NFTs.
Parameters
_amount
uint256
The number of NFTs to lazy mint.
_baseURIForTokens
string
The placeholder base URI for the 'n' number of NFTs being lazy minted, where the metadata for each of those NFTs is ${baseURIForTokens}/${tokenId}
.
_data
bytes
The encrypted base URI + provenance hash for the batch of NFTs being lazy minted.
Returns
batchId
uint256
A unique integer identifier for the batch of NFTs lazy minted together.
multicall
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
Returns
_0
string
undefined
nextTokenIdToMint
The tokenId assigned to the next new NFT to be lazy minted.
Returns
_0
uint256
undefined
operatorRestriction
Returns
_0
bool
undefined
owner
Returns the owner of the contract.
Returns
_0
address
undefined
reveal
Lets an authorized address reveal a batch of delayed reveal NFTs.
Parameters
_index
uint256
The ID for the batch of delayed-reveal NFTs to reveal.
_key
bytes
The key with which the base URI for the relevant batch of NFTs was encrypted.
Returns
revealedURI
string
undefined
royaltyInfo
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
See {IERC1155-safeBatchTransferFrom}.
Parameters
from
address
undefined
to
address
undefined
ids
uint256[]
undefined
amounts
uint256[]
undefined
data
bytes
undefined
safeTransferFrom
See {IERC1155-safeTransferFrom}.
Parameters
from
address
undefined
to
address
undefined
id
uint256
undefined
amount
uint256
undefined
data
bytes
undefined
setApprovalForAll
See {ERC1155-setApprovalForAll}
Parameters
operator
address
undefined
approved
bool
undefined
setContractURI
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
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
Parameters
_restriction
bool
undefined
setOwner
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
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
Returns whether this contract supports the given interface.
Parameters
interfaceId
bytes4
undefined
Returns
_0
bool
undefined
symbol
Returns
_0
string
undefined
totalSupply
Returns the total supply of NFTs of a given tokenId
Parameters
_0
uint256
undefined
Returns
_0
uint256
undefined
uri
Returns the metadata URI for an NFT.
See BatchMintMetadata
for handling of metadata in this contract.
Parameters
_tokenId
uint256
The tokenId of an NFT.
Returns
_0
string
undefined
verifyClaim
Override this function to add logic for claim verification, based on conditions such as allowlist, price, max quantity etc.
Checks a request to claim NFTs against a custom condition.
Parameters
_claimer
address
Caller of the claim function.
_tokenId
uint256
The tokenId of the lazy minted NFT to mint.
_quantity
uint256
The number of NFTs being claimed.
Events
ApprovalForAll
Parameters
_owner indexed
address
undefined
_operator indexed
address
undefined
_approved
bool
undefined
ContractURIUpdated
Parameters
prevURI
string
undefined
newURI
string
undefined
DefaultRoyalty
Parameters
newRoyaltyRecipient indexed
address
undefined
newRoyaltyBps
uint256
undefined
OperatorRestriction
Parameters
restriction
bool
undefined
OwnerUpdated
Parameters
prevOwner indexed
address
undefined
newOwner indexed
address
undefined
RoyaltyForToken
Parameters
tokenId indexed
uint256
undefined
royaltyRecipient indexed
address
undefined
royaltyBps
uint256
undefined
TokenURIRevealed
Parameters
index indexed
uint256
undefined
revealedURI
string
undefined
TokensClaimed
Parameters
claimer indexed
address
undefined
receiver indexed
address
undefined
tokenId indexed
uint256
undefined
quantityClaimed
uint256
undefined
TokensLazyMinted
Parameters
startTokenId indexed
uint256
undefined
endTokenId
uint256
undefined
baseURI
string
undefined
encryptedBaseURI
bytes
undefined
TransferBatch
Parameters
_operator indexed
address
undefined
_from indexed
address
undefined
_to indexed
address
undefined
_ids
uint256[]
undefined
_values
uint256[]
undefined
TransferSingle
Parameters
_operator indexed
address
undefined
_from indexed
address
undefined
_to indexed
address
undefined
_id
uint256
undefined
_value
uint256
undefined
URI
Parameters
_value
string
undefined
_id indexed
uint256
undefined
Errors
OperatorNotAllowed
Parameters
operator
address
undefined
Last updated