Mint and Burn Assets
Minting and burning assets with Native Script and Plutus Script
Minting and burning assets is a common operation in blockchain applications. In the Cardano ecosystem, minting and burning are achieved through Native Scripts and Plutus Scripts. The Mesh SDK provides a set of APIs to interact with the blockchain and build transactions that can mint or burn assets.
To initiate a transaction, we import the Transaction class from the @meshsdk/core package and assign the wallet to the initiator property. We build the transaction with .build() constructs the transaction and returns a transaction CBOR. Behind the scenes, it selects all of the necessary inputs belonging to the wallet, calculates the fee for this transaction and returns the remaining assets to the change address. Use wallet.signTx() to sign transaction CBOR.
The verbose is optional and set to false by default, setting it to true will enable verbose logging for the txBodyJson prior going into build.
In this page, you will find the APIs to create transactions for minting and burning assets.
Minting with One Signature
In this section, we will see how to mint native assets with a ForgeScript. For minting assets with smart contract, visit Transaction - Smart Contract - Minting Assets with Smart Contract.
Firstly, we need to define the forgingScript with ForgeScript. We use the first wallet address as the "minting address" (you can use other addresses).
Then, we define the metadata.
Finally, we create a transaction and mint the asset with the mintAsset method.
Mint native assets with ForgeScript
Connect wallet to run this demo
Define Asset Metadata
There are many ways to define asset metadata, the best way to find all is looking at the source code asset-metadata.ts file.
The most common is to define it as a JSON object with description:
For string values that are longer than 64 length, you can break it into a list of strings:
Burning assets
Like minting assets, we need to define the forgingScript with ForgeScript. We use the first wallet address as the "minting address". Note that, assets can only be burned by its minting address.
Then, we define Asset and set tx.burnAsset()
Here is the full code:
Burn native assets
Connect wallet to run this demo
Minting Assets with Native Script
Additionally, you can define the forging script with NativeScript. For example if you want to have a policy locking script, you can create a new ForgeScript from NativeScript:
To get the keyHash, use the deserializeAddress(). To get the slot, use the resolveSlotNo(). Check out Resolvers on how to use these functions.
Important: if you are using a policy locking script, you must define setTimeToExpire before the expiry; otherwise, you will catch the ScriptWitnessNotValidatingUTXOW error. See Transaction - set time.
Next, we define the metadata for the asset and create the asset object:
Finally, we create a transaction and mint the asset with the mintAsset method:
You can get the policy ID for this Native Script with resolveNativeScriptHash:
Mint native assets with Native Script
Connect wallet to run this demo
Minting Assets with Plutus Script
In this section, we will see how to mint native assets with a PlutusScript.
The PlutusScript object is used to define the Plutus script that will be used to mint the asset. The redeemer object is used to provide the data that the validator script will use to validate the transaction. For this example, the validator script is expecting a redeemer with a data field of "mesh".
Similar to previous examples, we define the asset metadata and mint object. The asset metadata is a JSON object that contains the metadata for the asset. The mint object contains the asset name, quantity, metadata, label, and recipient address.
Finally, we create a transaction and mint the asset with the mintAsset method. We set the required signers to include the address that is minting the asset.
Mint native assets with Plutus Script. For this example, the Plutus script expects a data field of 'mesh'.
Connect wallet to run this demo
Minting Assets with CIP-68 Metadata standard
CIP-68 proposes a metadata standard for assets on the Cardano blockchain, not limited to just NFTs but any asset class. It aims to address the limitations of a previous standard (CIP-25).
The basic idea is to have two assets issued, where one references the other. We call these two a reference NFT and an user token, where theuser token can be an NFT, FT or any other asset class that is transferable and represents any value. So, the user token is the actual asset that lives in a user's wallet.
To find the metadata for the user token you need to look for the output, where the reference NFT is locked in. How this is done concretely will become clear below. Moreover, this output contains a datum, which holds the metadata. The advantage of this approach is that the issuer of the assets can decide how the transaction output with the reference NFT is locked and further handled. If the issuer wants complete immutable metadata, the reference NFT can be locked at the address of an unspendable script. Similarly, if the issuer wants the NFTs/FTs to evolve or wants a mechanism to update the metadata, the reference NFTcan be locked at the address of a script with arbitrary logic that the issuer decides.
Lastly and most importantly, with this construction, the metadata can be used by a Plutus V2 script with the use of reference inputs (CIP-31) . This will drive further innovation in the token space.
Mint assets with CIP68 metadata standard where two assets are issued, one referencing the other user token.
Connect wallet to run this demo
Minting Royalty Token
Royalty tokens is a special type of token that allows the creator to collect a royalty fee, this proposed standard will allow for uniform royalties' distributions across the secondary market space. Read CIP-27 for more information.
The implementation of royalty tokens is very simple, minting a token with 777 label, with "rate" and "addr" in the metadata.
Here is the full code:
Mint native assets with ForgeScript
Connect wallet to run this demo
Mask asset metadata
Masking metadata is a way to hide the metadata from the transaction before signing it. This is useful when you want to keep the metadata private until the transaction is signed. Check the Multisig Multing guide for a end-to-end example.
In the following code snippet, we will see how to mask metadata before signing the transaction. First we build the minting transaction, check the other sections for more details.
After building the transaction, we can save the original metadata to use it later.
Mask the metadata before sending it to the user for signing the transaction.
The user signs the transaction with the masked metadata.
After the user signs the transaction, we can write the original metadata back to the transaction. Then we submit the transaction to the network.
Mint native assets with ForgeScript and mask metadata
Connect wallet to run this demo