πΈ XCM Token Transfers
Introductionβ
Cross-chain communication can be a challenging task, and developers often rely on wrapper functions and pallets to leverage XCM (Cross-Consensus Messages) features on Polkadot/Kusama. One such pallet is the x-tokens pallet, which provides different methods to transfer fungible assets via XCM.
Until an XCM-SDK is available to abstract this process, third parties who want to integrate XCM transfers from Calamari in their dApps need to use Polkadot.js API to connect to the Calamari backend and do these transfers by xTokens. This guide explains how to use the x-tokens pallet to transfer tokens from one substrate-based blockchain to another.
It is important to note that sending incorrect XCM messages can result in the loss of funds, and it is essential to test XCM features on a TestNet before moving to a production environment.
X-Tokens Pallet Interfaceβ
Extrinsicsβ
The x-tokens pallet provides the following extrinsic functions:
- transfer(MantaCurrency, amount, dest, destWeight)β transfers a currency, defined as either the native token (1) or with an asset-id starting from 8 upwards. The rest of the extrinsics are filtered out for now on our chain.
The following inputs must be provided:
- MantaCurrencyβ the ID of the currency being sent via XCM. Different runtimes have different ways of defining
- `amount β the number of tokens that are going to be sent via XCM
- destβ a multilocation to define the destination address for the tokens being sent via XCM.
- destWeightβ an enum that represents the maximum amount of execution time you want to provide in the destination chain to execute the XCM message being sent. The Unlimited option allows for all of the asset used for gas included to be used to pay for weight. The Limited option limits the amount used for gas to a particular value. If not enough weight is provided, the execution of the XCM will fail, and funds might get locked in either the sovereign account or a special pallet. It is important to correctly set the destination weight to avoid failed XCM executions
Storage Methodsβ
The x-tokens pallet includes the following read-only storage method:
- `palletVersion() - provides the version of the x-tokens pallet being used
Pallet Constantsβ
The x-tokens pallet includes the following read-only functions to obtain pallet constants:
- baseXcmWeight()- returns the base XCM weight required for execution
- selfLocation()- returns the multilocation of the chain
X-Tokens Transfer Functionβ
Head to the extrinsic page of Polkadot.js Apps and set the following options:
- Select the account from which you want to send the XCM
- Choose the xTokens pallet
- Choose the transfer extrinsic
- Set the MantaCurrency ID to any of the available assets, which you can check in the Assets page.
- Enter destination multilocation. In the current example an address on the Karura parachain.
- Enter destination weight
- Set the number of tokens to send. For this example, you are sending 10 KMA, but you have to account for the 12 decimals of KMA
- Submit and sign the transaction
Note that xTokens pallet is supported on many chains like Moonbeam and Acala, with almost identical interface.

Conclusionβ
The x-tokens pallet is a valuable tool for developers who need to transfer fungible assets via XCM on Polkadot/Kusama. It provides a straightforward interface for sending XCM messages and a multilocation system to define specific destinations in the ecosystem.
However, it is important to keep in mind that incorrect XCM messages can result in the loss of funds, so it is crucial to test on a TestNet before moving to production environments.
Overall, the x-tokens pallet provides a great solution for cross-chain transfers and is supported on many chains like Moonbeam and Acala with almost identical interfaces.