Skip to main content
Minting fungible token allows you to increase the total supply of the token. Minting a non-fungible token creates an NFT with its unique metadata for the class of NFTs defined by the token ID. The Supply Key must sign the transaction.
  • If no Supply Key is defined, the transaction will resolve to TOKEN\_HAS\_NO\_SUPPLY\_KEY. The maximum total supply a token can have is 2^63-1.
  • The amount provided must be in the lowest denomination possible.
    • Example: Token A has 2 decimals. In order to mint 100 tokens, one must provide an amount of 10000. In order to mint 100.55 tokens, one must provide an amount of 10055.
  • The metadata field is specific to NFTs. Once an NFT is minted, the metadata cannot be changed and is immutable.
    • You can use the metadata field to add a URI that contains additional information about the token. You can view the metadata schema here. The metadata field has a 100-character limit.
  • The serial number for the NFT is returned in the receipt of the transaction.
  • When minting NFTs, do not set the amount. The amount is used for minting fungible tokens only.
  • This transaction accepts zero unit minting operations for fungible tokens (HIP-564)
Transaction Signing Requirements
  • Supply key
  • Transaction fee payer account key
Transaction Fees
  • Please see the transaction and query fees table for the base transaction fee.
  • Please use the Hedera fee estimator to estimate your transaction fee cost.

Constructor

ConstructorDescription
new TokenMintTransaction()Initializes the TokenMintTransaction object

Transaction Properties

MethodTypeRequirement
setTokenId(<tokenId>)TokenIdRequired
setAmount(<amount>)longOptional (fungible)
addMetadata(<metadata>)byte[]Optional (NFT)
setMetadata(<metadataList>)List<byte[]>Optional (NFT)
setHighVolume(<highVolume>)booleanOptional

Get Transaction Values

MethodTypeDescription
getTokenId()TokenIdReturns the token ID
getAmount()longReturns the amount to mint (fungible)
getMetadata()List<byte[]>Returns the metadata list (NFT)
getHighVolume()booleanReturns whether this transaction uses high-volume throttles
This transaction supports high-volume entity creation (HIP-1313). Setting setHighVolume(true) routes the transaction through dedicated high-volume throttle capacity with variable-rate pricing for both fungible and NFT mints. Always pair this with setMaxTransactionFee() to cap your costs.
//Mint another 1,000 tokens
TokenMintTransaction transaction = new TokenMintTransaction()
     .setTokenId(tokenId)
     .setMaxTransactionFee(new Hbar(20)) //Use when HBAR is under 10 cents
     .setAmount(1000);

//Freeze the unsigned transaction, sign with the supply private key of the token, submit the transaction to a Hedera network
TransactionResponse txResponse = transaction
     .freezeWith(client)
     .sign(supplyKey)
     .execute(client);

//Request the receipt of the transaction
TransactionReceipt receipt = txResponse.getReceipt(client);

//Obtain the transaction consensus status
Status transactionStatus = receipt.status;

System.out.println("The transaction consensus status is " +transactionStatus;

//v2.0.1