EVM: Broadcast Transaction
EVM chains like Ethereum, Polygon, BSC, Arbitrum, etc support the use of templates to broadcast transactions. Select the following based on the template kind
:
Evm
: Use this template if you don't want to worry about gas parameters.Eip1559
: Use this template to interact with chains that support the new EIP-1559 gas standard (most chains do now).Transaction
: Use this template to just pass in the fully serialized EVM transaction (formatted and encoded using eg Ethersjs library)
EVM Template
kind
*
Required - String
Evm
to
*
Required - String
Blockchain address of target contract or payee.
value
(Optional. Required only if making a payment) - String (representing a integer eg "1000000")
Amount of the native currency to transfer denominated in WEI.
data
(Optional) String
Encoded hex string indicating which function in the smart contract to call with which parameters. Can also be an entire encoded contract in the case of contract deployment.
nonce
(Optional) Integer
The transaction number to guarantee idempotency. If omitted, it will be provided automatically. Note the same nonce can be submitted multiple times with a higher maxFeePerGas
to "overwrite" existing transactions in the mempool.
externalId
(Optional) String
A unique ID from your system. It can be leveraged to be used as an idempotency key (read more here)
Sample request body
200 response example
EIP-1559 Template
Use this template to adjust the maxFeePerGas
and maxPriorityFeePerGas
of an EIP-1559 type-2 transaction. Keep in mind that not all EVM compatible chains support this standard.
kind
*
String
Eip1559
to
*
String
Blockchain address of target contract or payee.
value
(Optional - Required if making a payment) - String (representing an integer eg "1000000"
)
Amount of the native currency to transfer denominated in WEI.
data
(Optional) String
Encoded hex string indicating which function in the smart contract to call with which parameters. Can also be an entire encoded contract in the case of contract deployment.
nonce
(Optional) Integer
The transaction number to guarantee idempotency. If omitted, it will be provided automatically. Note the same nonce can be submitted multiple times with a higher maxFeePerGas
to "overwrite" existing transactions in the mempool.
gasLimit
(Optional) String (representing an Integer)
The maximum amount of gas that can be spent for executing the transaction. If omitted, it will be calculated automatically.
maxPriorityFeePerGas
(Optional) String (representing an Integer)
The maximum amount of gas to be included as a tip to the validator. If omitted, it will be calculated automatically.
maxFeePerGas
(Optional) String (representing an Integer)
The maximum amount for gas willing to be paid for the transaction. If omitted, it will be calculated automatically.
externalId
(Optional) String
A unique ID from your system. It can be leveraged to be used as an idempotency key (read more here)
Sample request body
200 response example
Raw Transaction
You can also format the transaction using Ethers JS and the Dfns SDK:
kind
*
String
Transaction
transaction
*
Hex String
The unsigned hex encoded transaction as shown below
externalId
(Optional) String
A unique ID from your system. It can be leveraged to be used as an idempotency key (read more here)
Sample request body
200 Response Example
Typescript Example with Ethers
First install the Ethers JS. You can find the full documentation here: https://docs.ethers.org/v6/
Here a code sample to broadcast a transaction via the Dfns TypeScript SDK:
Last updated