This repo provides the code for several example dApps in the Axelar Local Development Environment. Examples contain both JavaScript and Solidity smart contract code.
Note: Some example folders in this repo are not documented below.
Install nodejs. Run node -v
to check your installation.
Version 16 is required. If needed you can switch your node version (or lower, if you are on a higher version) via
sudo npm i -g n
sudo n v16.15.0
Clone this repo:
git clone https://github.com/axelarnetwork/axelar-local-gmp-examples.git
Build contracts and tests:
npm ci
npm run build
In order to run the examples against the local emulator, cd to axelar-local-gmp-examples
and run
node scripts/createLocal
Leave this node running on a separate terminal before deploying and testing the dApps.
Each example has several arguments as described below:
Variable | Valid Values | Default | Example | Notes |
---|---|---|---|---|
network | local, testnet | no default | local | |
source-chain | Moonbeam, Avalanche, Fantom, Ethereum, and Polygon | Avalanche |
"Moonbeam" or 'Moonbeam' | case-sensitive |
destination-chain | Moonbeam, Avalanche, Fantom, Ethereum, and Polygon | Fantom |
"Avalanche" or 'Avalanche' | case-sensitive |
message for call-contract | any string | Hello ${destination.name} from ${source.name}, it is ${new Date().toLocaleTimeString()}. |
'Hello World' | |
message for nonced-execution and send-ack | any string | Hello, the time is ${time}. |
'Hello World' | |
amount | integer or float | 10 |
53 | Any non-integer is rounded down to the nearest integer. |
account | any wallet address | no default | 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb | case-sensitive. |
Run the deploy and test code specific to each example described below.
To use defaults, substitute ${}
for any or all of the variables.
Relay a message from source-chain to destination-chain.
Deploy:
node scripts/deploy examples/call-contract [local|testnet]
Run the test:
node scripts/test examples/call-contract [local|testnet] ${"source-chain"} ${"destination-chain"} ${'message'}
node scripts/deploy examples/call-contract local
node scripts/test examples/call-contract local "Moonbeam" "Avalanche" 'Hello World'
Output:
--- Initially ---
value at Avalanche is
--- After ---
value at Avalanche is Hello World
Send aUSDC from source-chain to destination-chain and distribute it equally among all accounts specified.
Deploy:
node scripts/deploy examples/call-contract-with-token [local|testnet]
Run the test:
node scripts/test examples/call-contract-with-token [local|testnet] ${"source-chain"} ${"destination-chain"} ${amount} ${account} ${account2} ...
node scripts/deploy examples/call-contract-with-token local
node scripts/test examples/call-contract-with-token local "Moonbeam" "Ethereum" 100 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb
Output:
--- Initially ---
0xBa86A5719722B02a5D5e388999C25f3333c7A9fb has 100 aUSDC
--- After ---
0xBa86A5719722B02a5D5e388999C25f3333c7A9fb has 199 aUSDC
Mints some token at source-chain and send it to destination-chain.
Deploy:
node scripts/deploy examples/cross-chain-token [local|testnet]
Run the test:
node scripts/test examples/cross-chain-token [local|testnet] ${"source-chain"} ${"destination-chain"} ${amount}
node scripts/deploy examples/cross-chain-token local
node scripts/test examples/cross-chain-token local "Ethereum" "Fantom" 1
Output:
--- Initially ---
Balance at Ethereum is 0
Balance at Fantom is 0
--- After getting some token on the source chain ---
Balance at Ethereum is 1
Balance at Fantom is 0
--- After ---
Balance at Ethereum is 0
Balance at Fantom is 1
Two different examples. Send aUSDC from source-chain to destination-chain:
deposit-address
: get an Axelar deposit address.send-token
: call an Axelar Gateway contract.
No smart contract to deploy for these examples.
If running on testnet
then ensure that 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb
is funded with aUSDC.
Note: We use 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb
to deploy and test all examples. It's funded by default in the local
environment when you run createLocal
. To make sure that it's funded on all five supported testnets, run node/printBalances
.
Run the deposit-address
test:
node scripts/test examples/deposit-address [local|testnet] ${"source-chain"} ${"destination-chain"} ${amount}
Run the send-token
test:
node scripts/test examples/send-token [local|testnet] ${"source-chain"} ${"destination-chain"} ${amount}
node scripts/test examples/deposit-address local
node scripts/test examples/send-token local
Output:
--- Initially ---
Balance at Avalanche is 100000000
Balance at Fantom is 100000000
0xb54eA64537F3307907E06d3B93ccd4A3E711623f
--- After ---
Balance at Avalanche is 90000000
Balance at Fantom is 109000000
--- Initially ---
Balance of 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb at Avalanche is 90000000
Balance of 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb at Fantom is 109000000
--- After ---
Balance of 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb at Avalanche is 80000000
Balance of 0xBa86A5719722B02a5D5e388999C25f3333c7A9fb at Fantom is 118000000
Informs destination-chain of the last header of source-chain.
Deploy:
node scripts/deploy examples/headers [local|testnet]
Run the test:
node scripts/test examples/headers [local|testnet] ${"source-chain"} ${"destination-chain"}
node scripts/deploy examples/headers local
node scripts/test examples/headers local "Fantom" "Moonbeam"
Output:
Success!
Send the NFT that was originally minted at source-chain to destination-chain.
Deploy:
node scripts/deploy examples/nft-linker [local|testnet]
A single NFT is minted to the deployer (0xBa86A5719722B02a5D5e388999C25f3333c7A9fb
) on each chain.
Run the test:
node scripts/test examples/nft-linker [local|testnet] ${"source-chain"} ${"destination-chain"}
It's not possible to send a duplicate NFT to a chain. The dApp fails when the NFT is already at the destination-chain.
node scripts/deploy examples/nft-linker local
node scripts/test examples/nft-linker local "Avalanche" "Polygon"
Output:
--- Initially ---
Token that was originally minted at Moonbeam is at Moonbeam.
Token that was originally minted at Avalanche is at Avalanche.
Token that was originally minted at Fantom is at Fantom.
Token that was originally minted at Ethereum is at Ethereum.
Token that was originally minted at Polygon is at Polygon.
--- Then ---
Token that was originally minted at Moonbeam is at Moonbeam.
Token that was originally minted at Avalanche is at Polygon.
Token that was originally minted at Fantom is at Fantom.
Token that was originally minted at Ethereum is at Ethereum.
Token that was originally minted at Polygon is at Polygon.
Send a message from source-chain to destination-chain.
Deploy:
node scripts/deploy examples/nonced-execution [local|testnet]
Run the test:
node scripts/test examples/nonced-execution [local|testnet] ${"source-chain"} ${"destination-chain"} ${'message'}
node scripts/deploy examples/nonced-execution local
node scripts/test examples/nonced-execution local ${} ${} ${}
Output:
--- Initially ---
Last message sent from Avalanche@0xBa86A5719722B02a5D5e388999C25f3333c7A9fb to Fantom was "" with a nonce of -1.
--- After ---
Last message sent from Avalanche@0xBa86A5719722B02a5D5e388999C25f3333c7A9fb to Fantom was "Hello, the time is 1654191658288." with a nonce of 0.
Send a message from source-chain to destination-chain.
Deploy:
node scripts/deploy examples/send-ack [local|testnet]
Run the test:
node scripts/test examples/send-ack [local|testnet] ${"source-chain"} ${"destination-chain"} ${'message'}
node scripts/deploy examples/send-ack local
node scripts/test examples/send-ack local "Fantom" "Moonbeam" 'Received'
Output:
--- Initially ---
SendAckReceiverImplementation at Moonbeam has 0 messages and the last one is "".
--- After ---
SendAckReceiverImplementation at Moonbeam has 1 messages and the last one is "Received".