Preparing Transactions
All transactions sent with the SDK need to be prepared first. Preparing a transaction is synchronous, lightweight and does not require any network requests. It also gives you type-safe definitions for your contract calls.
The recommended way to prepare a contract call is to pass the Solidity method signature and the params. This is type-safe based on the Solidity method signature you define. You can get your desired contract method signature from the solidity code directly.
This will return a prepared transaction object that is ready to be sent to the blockchain and can be acted on in various ways.
You can also create a raw transaction directly. This is useful when you want to send ether to an address for example, or when you already have encoded data.
There are few other ways to prepare a contract call, all of these return the same transaction object.
Using the CLI, you can generate optimized functions for all the possible calls to a contract. This saves you time and precomputes all the necessary encoding.
Read more on how to generate extension functions using the CLI.
Another way to get type safety is to pass the full contract ABI to getContract
. This will give you autocompletion for all methods declared in the ABI. There is a slight extract cost of having the full ABI in your code which can be pretty large.
As an alternative to passing the full ABI, you can pass a snippet of the ABI for the method you want to call. This is useful when you only want to call a single method and don't want to have the full ABI in your code.
Finally, you can dynamically resolve contract methods at runtime using the resolveMethod
function. This is the best way to handle contracts you don't know the ABI of in advance but it is also less performant and not type-safe.
Please note
This method is convenient, however, it is also:
- less performant at runtime (it has to resolve the ABI of the contract and then match the method name you provide)
- not type-safe (you lose type safety for your params)
There are cases where you specifically need to be able to resolve methods dynamically at runtime, in which case this method is useful.