How to create and interact with a mintable XC20 asset via Solidity smart contract
TL;DR
XC20 is an asset standard that enables users and developers to interact with them through a familiar ERC20 interface via a precompile contract (Ethereum API) while having XCM cross-chain compatibility as native Substrate assets. Since ERC20 assets can not be transferred via XCM in the Polkadot/Kusama ecosystem, you will need XC20 if you want to build cross-chain compatible assets usable in EVM.
There are two types of XC20 assets, mintable XC20, and external XC20 assets. Mintable XC20 assets can be issued on Astar Network based on the owner’s implementation logic. External XC20 assets are XC20 assets originally from other parachain/relaychain and transferred to Astar Network via XCM and issued by the sovereign account.
In this guide, we will support you on:
- How to create mintable XC20 assets.
- How to send them to EVM
- How to interact with XC20 assets via Solidity smart contract.
Overview
What is an XC20
XC20 is an asset standard introduced by PureStake Technologies, which combines the power of Substrate assets (native cross-chain interoperability) but allows users and developers to interact with them through a familiar ERC20 interface via a precompile contract (Ethereum API). With XC20, developers will be able to create assets that are both EVM-usable and cross-chain compatible via XCM.
What are mintable XC20 and external XC20
There are two types of XC20 assets, mintable XC20, and external XC20 assets. Mintable XC20 assets can be issued on Astar Network based on the owner’s issuance logic. And external XC20 assets are XC20 assets originally from other parachain/relaychain and transferred to Astar Network via XCM and issued by the sovereign account.
What is XCM
Cross-Consensus Message Format (XCM) aims to be a language to communicate ideas between consensus systems. One of Polkadot's promises is interoperability, and XCM is the vehicle through which it will deliver this promise. Simply, it is a standard that allows protocol developers to define the data and origins that their chains can send and receive from, including cross-chain asset transfer between parachains.
Instructions
Register an XC20 asset
Currently, the best way to create XC20 asset is via Polkadot.js. In this guide, we will create an XC20 asset using Shibuya (Astar's Testnet) as a demo.
- Please visit Polkadot.js
- Go to
Network
→Asset
→Create
- Note: please make sure to have at least 100 ASTR in the wallet when creating XC20 asset on Astar Network.
- Please set the following parameters for your asset
creater account
: the account that will create this asset and set up the initial metadata.asset name
: the descriptive name for this asset, e.g. Cookbook Token.asset symbol
: the ticker for this asset, e.g. CKT.asset decimals
: the number of decimals for this token. Max allowed via the UI is set to 20.minimum balance
: the minimum balance for the asset. This is specified in the units and decimals as requested.- Note:
minimum malance
is the same as theExistential Deposit (ED)
of your asset. The ED exists so that accounts with very small balances, or completely empty, do not "bloat" the state of the blockchain in order to maintain high performance. - Note: We suggest setting the
minimum balance
to1 Pico
, which will only require 0.000000000001 unit of the asset.
- Note:
asset id
: the selected id for the asset. This should not match an already-existing asset id.
Please make sure the account creating the asset has sufficient balance to pay the rent fee.
- Set the managing addresses for the XC20 asset:
creator
: the account responsible for creating the asset.issuer
: the designated account capable of issuing or minting tokens.admin
: the designated account capable of burning tokens and unfreezing accounts and assets.freezer
: the designated account capable of freezing accounts and assets.
Mint the registered XC20 asset
To mint the initial supply of the registered XC20 asset, we need to open Polkadot.js with the issuer address.
- Go to
Network
→Assets
→ Find the asset that you just created - Set the minting amount and recipient address:
mint to address
: the recipient account for this minting operation.amount to issue
: the amount of assets to issue to the account.
Transfer the asset parameters to a multi-sig account (suggested)
The owner of the XC20 asset has many high-level accesses. Thus, to ensure the security of the mintable XC20 assets, we suggest transferring the owner, issuer, freezer, and admin to a multi-sig account after the creation and initial mint. Click here for the guide to create a multi-sig wallet.
- Go to
Developer
→Extrinsics
- Choose
assets
extrinsics andtransferOwnership
method - Enter the
asset ID
of the new asset (you may find it underNetwork
→Assets
) - Choose
Id
fortarget
and enter the address
- Go to
Developer
→Extrinsics
- Choose
assets
extrinsics andsetTeam
method - Enter the
asset ID
of the new asset (you may find it underNetwork
→Assets
) - Choose
Id
fortarget
and enter the address
Send the asset to EVM
Since Astar Network is building a multi-VM smart contract hub, we support both EVM and WASM with two different account systems, H160 and SS58 respectively.
In order to send the asset to an H160 address (address B) from the Substrate-native SS58 address (address A), we need to convert the H160 address to its mapped Substrate-native SS58 address (address B) and send the asset directly from address A to address B via Polkadot.js.
Here are the full steps:
-
Convert the destination H160 address to its mapped Substrate-native SS58 address by using our address converter.
-
Visit Polkadot.js.
-
Go to
Developer
→Extrinsics
-
Choose
assets
extrinsics andtransfer
method -
Enter the
asset ID
of the new asset (you may find it underNetwork
→Assets
) -
Choose
id
fortarget
-
Enter the mapped Substrate-native SS58 address for
AccountId
-
Enter the amount that you hope to transfer for
Balance
- Please notice if the decimal is 18,
1000000000000000000
refers to 1 unit of the asset. - Call data for reference:
0x2405950300d6e68e3d545d18f2298dda31e70b63283a3ecc664f7bead5f174f6cc2f5df65d1b000000a1edccce1bc2d3
- Please notice if the decimal is 18,