The Axecute SDK is a library that allows developers to interact with Axecute smart contracts more easily. It provides the necessary tools to construct cross-chain multicall transactions. The SDK's core functionality is encapsulated within the Call
class.
Include the SDK in your project by adding it to your dependencies:
npm install --save @axecute-official/axecute-sdk
- Simple Transaction Construction: Easily create transactions for interaction with Axecute smart contracts.
- Sub-Calls Management: Add, remove, and manage sub-calls within a call.
- Fee Calculation: Automatically calculate the total fee for the call and its sub-calls.
- Call Encoding: Encode the call for transaction submission.
async function createCall(source, destination) {
const chainName = destination.name;
const target = destination.loggerContract.address;
const callData = getLogCallData(`Call from ${source.name} to ${destination.name}.`);
const axecutor = destination.contract.address;
const fee = await calculateCallFee(source, destination);
return new Call(chainName, target, callData, axecutor, fee);
}
const call1 = await createCall(source, moonbeam);
call1.addSubCall(await createCall(moonbeam, fantom));
call1.addSubCall(await createCall(moonbeam, ethereum));
// ...
const fee = calls.reduce((a, b) => (Number(a) + Number(b.calculateTotalFee())), 0).toString();
const encodedCalls = calls.map(call => call.encode());
const tx = await source.contract.aggregate(encodedCalls, { value: fee });
console.log("Submit transaction successfully: ", tx.hash);
chain
: String representing the blockchain chain.target
: String representing the target contract address.callData
: String representing the call data.subCalls
: Array of sub-call instances (Call[]
).axecutor
: String representing the axecutor's address.fee
: String representing the fee.
getSubCall(index)
: Retrieve a sub-call by index.addSubCall(subCall)
: Add a sub-call.removeSubCall(index)
: Remove a sub-call by index.calculateTotalFee()
: Calculate the total fee for this call and its sub-calls.encode()
: Encode the call for transaction submission.
For issues and feature requests, please open an issue on GitHub.
This project is licensed under the MIT License - see the LICENSE.md file for details.