ERC1155Drop
BASE: ERC1155Base EXTENSION: DropSinglePhase1155 The ERC1155Base
smart contract implements the ERC1155 NFT standard. It includes the following additions to standard ERC1155 logic: - 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. The drop
mechanism in the DropSinglePhase1155
extension is a distribution mechanism for lazy minted tokens. It lets you set restrictions such as a price to charge, an allowlist etc. when an address atttempts to mint lazy minted tokens. The ERC721Drop
contract lets you lazy mint tokens, and distribute those lazy minted tokens via the drop mechanism.
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
Parameters
_receiver
address
undefined
_tokenId
uint256
undefined
_quantity
uint256
undefined
_currency
address
undefined
_pricePerToken
uint256
undefined
_allowlistProof
IDropSinglePhase1155.AllowlistProof
undefined
_data
bytes
undefined
claimCondition
Parameters
_0
uint256
undefined
Returns
startTimestamp
uint256
undefined
maxClaimableSupply
uint256
undefined
supplyClaimed
uint256
undefined
quantityLimitPerWallet
uint256
undefined
merkleRoot
bytes32
undefined
pricePerToken
uint256
undefined
currency
address
undefined
metadata
string
undefined
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
getSupplyClaimedByWallet
Returns the supply claimed by claimer for active conditionId.
Parameters
_tokenId
uint256
undefined
_claimer
address
undefined
Returns
_0
uint256
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
primarySaleRecipient
Returns primary sale recipient address.
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
setClaimConditions
Parameters
_tokenId
uint256
undefined
_condition
IClaimCondition.ClaimCondition
undefined
_resetClaimEligibility
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.
setPrimarySaleRecipient
Updates primary sale recipient.
Caller should be authorized to set primary sales info. See {_canSetPrimarySaleRecipient}. Emits {PrimarySaleRecipientUpdated Event}; See {_setupPrimarySaleRecipient}.
Parameters
_saleRecipient
address
Address to be set as new recipient of primary sales.
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
Mapping from tokenId => total circulating supply of NFTs of that 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
Parameters
_tokenId
uint256
undefined
_claimer
address
undefined
_quantity
uint256
undefined
_currency
address
undefined
_pricePerToken
uint256
undefined
_allowlistProof
IDropSinglePhase1155.AllowlistProof
undefined
Returns
isOverride
bool
undefined
Events
ApprovalForAll
Parameters
_owner indexed
address
undefined
_operator indexed
address
undefined
_approved
bool
undefined
ClaimConditionUpdated
Emitted when the contract's claim conditions are updated.
Parameters
tokenId indexed
uint256
undefined
condition
IClaimCondition.ClaimCondition
undefined
resetEligibility
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
PrimarySaleRecipientUpdated
Parameters
recipient 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
Emitted when tokens are claimed via claim
.
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