d0540b0b63
Co-authored-by: gator-boi <gator-boi@users.noreply.github.com> |
||
---|---|---|
evm | ||
LICENSE | ||
README.md |
README.md
wormhole-circle-integration
Details
This repo demonstrates how to send USDC cross-chain (with additional instructions to be used by a contract) by using Wormhole's generic-messaging layer and by interacting with Circle's Cross-Chain Transfer Protocol.
Compiling contracts
Install Foundry tools, which includes forge
, anvil
and cast
CLI tools.
cd evm
make build
Testnet Deployment
cd evm
# goerli
. env/eth-goerli-testnet.env && PRIVATE_KEY=put_your_private_key_here bash shell-scripts/deploy_circle_integration.sh
# fuji
. env/avax-fuji-testnet.env && PRIVATE_KEY=put_your_private_key_here bash shell-scripts/deploy_circle_integration.sh
Deployed Contract Addresses
goerli: 0xdbedb4ebd098e9f1777af9f8088e794d381309d1
fuji: 0x3e6a4543165aaecbf7ffc81e54a1c7939cb12cb8
Structs
struct RedeemParameters {
bytes encodedWormholeMessage;
bytes circleBridgeMessage;
bytes circleAttestation;
}
struct WormholeDepositWithPayload {
uint8 payloadId; // == 1
bytes32 token;
uint256 amount;
uint32 sourceDomain;
uint32 targetDomain;
uint64 nonce;
bytes32 mintRecipient;
bytes payload;
}
struct CircleDeposit {
// Message Header
uint32 version;
uint32 sourceDomain;
uint32 targetDomain;
uint64 nonce;
bytes32 circleSender;
bytes32 circleReceiver;
// End of Message Header
// There should be an arbitrary length message following the header,
// but we don't need to parse this message for verification purposes.
}
API
function transferTokensWithPayload(
address token,
uint256 amount,
uint16 targetChain,
bytes32 mintRecipient,
bytes memory payload
) public payable returns (uint64 messageSequence)
function redeemTokensWithPayload(
RedeemParameters memory params
) public returns (WormholeDepositWithPayload memory wormholeDepositWithPayload)