Transaction Basics
Working with transactions and its various options
Transactions are used to send assets from one wallet to another and to smart contracts.
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 sending assets and various options to customize the transaction.
Send Lovelace
You can chain the component to send lovelace to multiple recipients. For each recipients, append:
Send lovelace to a recipient
Connect wallet to run this demo
Send Assets
You can chain the component to send assets to multiple recipients. For each recipients, append:
The Asset
object is defined as:
The unit
field is the policy ID and asset name in hex format. The quantity
field is the amount of the asset to send.
Send assets to a recipient
Connect wallet to run this demo
Send Value
Specify an output for the transaction. This funcion allows you to design the output UTXOs, either by splitting the outputs from multiple UTxOs or by creating reference inputs.
sendValue()
is useful when working with smart contracts, when you want to redeem a UTxO from the script.
where UTxO
has the following format (use one of our providers):
Add UTXO as input and send to a recipient. In this demo, the first UTXO from your wallet is selected.
Connect wallet to run this demo
Multi-signature Transaction
The main idea of a multi-signature transaction is to have multiple signatures to authorize a transaction.
Here are a few scenarios where multi-signature transactions are useful:
- you want to create a transaction with a backend and send to the frontend for the user to sign
- when you use a forge script which requires the user to pay for the minting fee
- when redeeming an asset from a script
In the above code snippet, we are signing the transaction with the user wallet and then signing the transaction with the minting wallet. ThesignTx
function is used to sign the transaction. The second argument is a boolean value that indicates whether the transaction is a multi-signature transaction.
Create a multi-signature transaction. In this demo, we will create a transaction with two signatures, where one signature is from the user wallet and the other is from a minting wallet.
Connect wallet to run this demo
Coin selection
There are currently three coin selection algorithms available:
- Keep Relevant
- Largest First
- Largest First Multi-Asset
Keep Relevant
keepRelevant
is a two-step coin selection algorithm. First, given a Map (of requested assets and respective quantities) and a set of UTxOs, it tries to eliminate the irrelevant UTxOs from the set. Next, it checks that this UTxO set includes enough lovelace to cover all/any multi-assets in the set. If the set does not include enough lovelace, then it will try to also pick up another UTxO from the wallet, containing the largest amount of lovelace.
Here is an example how you can use keepRelevant()
:
Largest First
To select UTXOs for transaction that only requires lovelace, use largestFirst
.
For example, selecting the UTXOs for sending 10000000 lovelace:
Largest First Multi-Asset
largestFirstMultiAsset
allows you to define which native assets you require for sending out by defining a Map
. The Map is matches the Unit
with the quantity of each asset.
Note that if lovelace, aside from the "minimum Ada" which in any case needs to accompany the other assets, this must be explicitly specified. This can also be useful in the case that your transaction only requires transfer of lovelace. In this case, the algorithm will exclude all multiasset UTxOs from the selection, which can result in more efficient selection of the required UTxOs.
The third parameter is includeTxFees
. If True
, Mesh will calculate the fees required for the transaction, and include additional UTxOs to necessary to fulfill the fees requirements.
Select the UTXOs with a two-step coin selection algorithm
Connect wallet to run this demo
Select the UTXOs with the most ADA first
Connect wallet to run this demo
Select the UTXOs with the most ADA and asset first
Connect wallet to run this demo
Get Txbuilder
The TxBuilder is a powerful low-level APIs that allows you to build and sign transactions. You can get a new instance of TxBuilder by calling txBuilder
. Doing so allows you to access the low-level APIs of TxBuilder, check the docs for all the available methods.
For example, you can get the meshTxBuilderBody
to retrieve the transaction JSON. This is useful for debugging and understanding how the transaction is built.
Send Assets to Handle
Send assets to a handle. Initialize a provider and fetch the address of a handle.
The handle should be a valid handle on the mainnet.
Send assets to a handle. (Note: this demo only works on mainnet)
Connect wallet to run this demo
Send Assets to Begin ID
Send assets to a Begin ID. Initialize BeginProvider
and fetch the address.
Must be a valid name on the mainnet.
Send assets to a Begin ID. (Note: this demo only works on mainnet)
Connect wallet to run this demo
Set Metadata
Add messages/comments/memos as transaction metadata. This is useful for attaching additional information to a transaction.
Add messages/comments/memos as transaction metadata
Connect wallet to run this demo
Transaction message
Add messages/comments/memos as transaction metadata. This is useful for attaching additional information to a transaction.
The specification for the individual strings follow the general design specification for JSON metadata, which is already implemented and in operation on the cardano blockchain. The used metadatum label is 674
:, this number was chosen because it is the T9 encoding of the stringmsg
. The message content has the key msg
: and consists of an array of individual message-strings. The number of theses message-strings must be at least one for a single message, more for multiple messages/lines. Each of theses individual message-strings array entries must be at most 64 bytes when UTF-8 encoded.
Add messages/comments/memos as transaction metadata
Connect wallet to run this demo
Set Collateral
Specify the UTXOs that you want to use as collateral.
Set the UTXOs that you want to use as collateral. In this demo, the first UTXO from your wallet is selected.
Connect wallet to run this demo
Set Required Signers
Sets the required signers for the transaction. This is useful when you want to include multiple signers, such as in a multi-signature transaction or smart contracts.
Set the signers for this transaction. In this demo, every used addresses in your wallet is selected.
Connect wallet to run this demo
Set Start and Expire Time
We can define the time-to-live (TTL) for the transaction. TTL is the time limit for our transaction to be included in a blockchain, if it is not in a blockchain by then the transaction will be cancelled. This time limit is defined as slot
.
In order to get the slot
of the time you wish the transaction would expire, you can use resolveSlotNo
. For example, if you would like the transaction to expire in 5 minutes, you can get the slot
in the following way:
Next, we set the TTL with setTimeToExpire
and providing the slot
, this means that if the transaction is submitted after after slot
will not be valid.
Likewise, we can set a "validity start interval" for the transaction, where it is the time the transaction will be valid. We can define the start time with setTimeToStart
and providing the slot
:
Note that, if you are using a policy locking script, you must define setTimeToExpire
before the expiry; otherwise, you will catch the ScriptWitnessNotValidatingUTXOW
error.
Set Network
Sets the network to use, this is mainly to know the cost models to be used to calculate script integrity hash. You can set the network for the transaction with setNetwork
.
The network parameter is a string that can be one of the following: