Submitting an Order Creation Transaction
The transaction call retrieved from the DLN API must be signed by a user how is willing to sell the asset, and then broadcasted to the source chain.
EVM-based blockchains
The tx
object has the following structure and is ready to be signed and broadcasted:
Field names from the tx
object speak for themselves:
the
to
is the field the transaction should be sent to, and typically you should expect the address of one of the smart contracts responsible for forwarding;the
data
is the contents of the transaction, containing instructions related to swaps planned on the source or (and) on the destination chains, bridging settings, etc;the
value
is the amount of native blockchain currency that must be sent along with the transaction.
However, there are a few things you must consider:
First, the value
is always positive, even if the input token is an ERC-20 token. This is because the underlying DLN protocol takes a fixed amount in the native currency, so the API always includes it as the transaction value. In the above example, the value
equals the current fixed fee, which is 0.005 BNB on the BNB Chain.
Second, in case the input token is an ERC-20 token, a user need to give approval to the smart contract address specified in the tx.to
field prior to submitting this transaction so it can transfer them on the behalf of the sender. This can be typically done by calling either approve()
or increaseAllowance()
method of the smart contract which implements the token you are willing to swap. Approve at least the amount that has been specified as the estimation.srcChainTokenIn.amount
response property.
Other than that, the transaction is ready to be signed by a user and broadcasted to the blockchain. It is also worth mentioning that the given transaction data can be used as a part of another transaction: a dApp can bypass the given to
, data
and value
to your smart contract, and make a low-level call. There is even possible to create multiple transactions for different orders, and perform several low-level calls.
The affiliate fee is paid only after the order gets fulfilled, and the taker requests order unlock during the unlock procedure.
Solana
For DLN trades coming from Solana the tx
object returned by DLN API has only one field data
which is hex-encoded VersionedTransaction
To convert the hex-encoded string into VersionedTransaction
decode hex to buffer using any library and call VersionedTransaction.deserialize(decoded)
.
Example:
More info about sending versioned transactions here.
Last updated