Skip to content

Commit

Permalink
Merge branch 'main' into chore/fix-sui-gmp-example
Browse files Browse the repository at this point in the history
  • Loading branch information
npty committed Aug 20, 2024
2 parents 47e4458 + ca64dd9 commit 76329f6
Show file tree
Hide file tree
Showing 25 changed files with 755 additions and 139 deletions.
21 changes: 18 additions & 3 deletions axelar-chains-config/info/stagenet.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,12 @@
"deployer": "0xBeF25f4733b9d451072416360609e5A4c115293E"
},
"AxelarDepositService": {
"wrappedSymbol": "WAVAX"
"wrappedSymbol": "WAVAX",
"refundIssuer": "0x2517bA7a3E2cef54c1CD8618e7B0B661A7623817",
"salt": "AxelarDepositService",
"address": "0x405407133E2783aEb56F2cA9d8e6025465De0B9f",
"implementation": "0x523ee715a997bd471BfbE1B66acCF0d47D1fD812",
"deployer": "0xBeF25f4733b9d451072416360609e5A4c115293E"
},
"ConstAddressDeployer": {
"address": "0x98B2920D53612483F91F12Ed7754E51b4A77919e"
Expand Down Expand Up @@ -132,7 +137,12 @@
"deployer": "0xBeF25f4733b9d451072416360609e5A4c115293E"
},
"AxelarDepositService": {
"wrappedSymbol": "WFTM"
"wrappedSymbol": "WFTM",
"refundIssuer": "0x2517bA7a3E2cef54c1CD8618e7B0B661A7623817",
"salt": "AxelarDepositService",
"address": "0x405407133E2783aEb56F2cA9d8e6025465De0B9f",
"implementation": "0x523ee715a997bd471BfbE1B66acCF0d47D1fD812",
"deployer": "0xBeF25f4733b9d451072416360609e5A4c115293E"
},
"ConstAddressDeployer": {
"address": "0x98B2920D53612483F91F12Ed7754E51b4A77919e"
Expand Down Expand Up @@ -235,7 +245,12 @@
"deployer": "0xBeF25f4733b9d451072416360609e5A4c115293E"
},
"AxelarDepositService": {
"wrappedSymbol": "WDEV"
"wrappedSymbol": "WDEV",
"refundIssuer": "0x2517bA7a3E2cef54c1CD8618e7B0B661A7623817",
"salt": "AxelarDepositService",
"address": "0x405407133E2783aEb56F2cA9d8e6025465De0B9f",
"implementation": "0x20fee12E3d138b783aa9238467BDFDDECA407EF9",
"deployer": "0xBeF25f4733b9d451072416360609e5A4c115293E"
},
"ConstAddressDeployer": {
"address": "0x98B2920D53612483F91F12Ed7754E51b4A77919e"
Expand Down
307 changes: 303 additions & 4 deletions axelar-chains-config/info/testnet.json

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions cosmwasm/deploy-contract.js
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,7 @@ const programHandler = () => {
),
);
program.addOption(new Option('--instantiate2', 'use instantiate2 for constant address deployment'));
program.addOption(new Option('-l, --label <label>', 'contract instance label'));
program.addOption(new Option('--aarch64', 'aarch64').env('AARCH64').default(false));
program.addOption(new Option('-y, --yes', 'skip deployment prompt confirmation').env('YES'));

Expand Down
2 changes: 2 additions & 0 deletions cosmwasm/submit-proposal.js
Original file line number Diff line number Diff line change
Expand Up @@ -248,6 +248,7 @@ const programHandler = () => {

program.name('submit-proposal').description('Submit governance proposals');

// TODO: combine deploy-contract and submit-proposal options to remove duplicates
program.addOption(
new Option('-e, --env <env>', 'environment')
.choices(['local', 'devnet', 'devnet-amplifier', 'devnet-verifiers', 'stagenet', 'testnet', 'mainnet'])
Expand All @@ -267,6 +268,7 @@ const programHandler = () => {
),
);
program.addOption(new Option('--instantiate2', 'use instantiate2 for constant address deployment'));
program.addOption(new Option('-l, --label <label>', 'contract instance label'));
program.addOption(new Option('--aarch64', 'aarch64').env('AARCH64').default(false));
program.addOption(new Option('-y, --yes', 'skip prompt confirmation').env('YES'));

Expand Down
18 changes: 12 additions & 6 deletions cosmwasm/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,8 @@ const calculateDomainSeparator = (chain, router, network) => keccak256(Buffer.fr

const getSalt = (salt, contractName, chainNames) => fromHex(getSaltFromKey(salt || contractName.concat(chainNames)));

const getLabel = ({ contractName, label }) => label || contractName;

const readWasmFile = ({ artifactPath, contractName, aarch64 }) =>
readFileSync(`${artifactPath}/${pascalToSnake(contractName)}${aarch64 ? '-aarch64' : ''}.wasm`);

Expand Down Expand Up @@ -94,7 +96,9 @@ const uploadContract = async (client, wallet, config, options) => {
});
};

const instantiateContract = (client, wallet, initMsg, config, { contractName, salt, instantiate2, chainNames, admin }) => {
const instantiateContract = (client, wallet, initMsg, config, options) => {
const { contractName, salt, instantiate2, chainNames, admin } = options;

return wallet
.getAccounts()
.then(([account]) => {
Expand All @@ -105,17 +109,19 @@ const instantiateContract = (client, wallet, initMsg, config, { contractName, sa
} = config;
const initFee = gasLimit === 'auto' ? 'auto' : calculateFee(gasLimit, GasPrice.fromString(gasPrice));

const contractLabel = getLabel(options);

return instantiate2
? client.instantiate2(
account.address,
contractConfig.codeId,
getSalt(salt, contractName, chainNames),
initMsg,
contractName,
contractLabel,
initFee,
{ admin },
)
: client.instantiate(account.address, contractConfig.codeId, initMsg, contractName, initFee, {
: client.instantiate(account.address, contractConfig.codeId, initMsg, contractLabel, initFee, {
admin,
});
})
Expand Down Expand Up @@ -573,12 +579,12 @@ const getStoreCodeParams = (options) => {
};

const getStoreInstantiateParams = (config, options, msg) => {
const { contractName, admin } = options;
const { admin } = options;

return {
...getStoreCodeParams(options),
admin,
label: contractName,
label: getLabel(options),
msg: Buffer.from(JSON.stringify(msg)),
};
};
Expand All @@ -592,7 +598,7 @@ const getInstantiateContractParams = (config, options, msg) => {
...getSubmitProposalParams(options),
admin,
codeId: contractConfig.codeId,
label: contractName,
label: getLabel(options),
msg: Buffer.from(JSON.stringify(msg)),
};
};
Expand Down
40 changes: 39 additions & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
"homepage": "https://github.com/axelarnetwork/axelar-contract-deployments#readme",
"dependencies": {
"@axelar-network/axelar-cgp-solidity": "6.3.1",
"@axelar-network/axelar-cgp-sui": "^0.0.0-snapshot.08213e4",
"@axelar-network/axelar-cgp-sui": "^0.0.0-snapshot.218635e",
"@axelar-network/axelar-gmp-sdk-solidity": "5.10.0",
"@axelar-network/interchain-token-service": "1.2.4",
"@cosmjs/cosmwasm-stargate": "^0.32.1",
Expand Down
18 changes: 18 additions & 0 deletions sui/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,24 @@ The syntax is `node sui/gas-service.js payGas --amount <amount> <destinationChai
node sui/gas-service.js payGas --amount 0.1 ethereum 0x6f24A47Fc8AE5441Eb47EFfC3665e70e69Ac3F05 0xba76c6980428A0b10CFC5d8ccb61949677A61233 0x1234
```

Collect gas:

Conditions:
- The `GasCollectorCap` object id is read from the chain config, under gas service objects.
```bash
# store GasCollectorCap to the Operators contract
node sui/operators.js storeCap
```
- The sender must be a whitelisted operator and hold the `OperatorCap` capability.
```bash
# execute the following command from the owner account
node sui/operators add <operator address>
```

```bash
node sui/gas-service.js collectGas --amount 0.1 --receiver <receiver address>
```

Approve messages:

If the gateway was deployed using the wallet, you can submit a message approval with it
Expand Down
13 changes: 9 additions & 4 deletions sui/deploy-contract.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,16 @@ const {
utils: { arrayify },
} = ethers;
const { saveConfig, printInfo, validateParameters, writeJSON, getDomainSeparator, loadConfig } = require('../common');
const { addBaseOptions, addOptionsToCommands } = require('./cli-utils');
const { getWallet, printWalletInfo, broadcast } = require('./sign-utils');
const { bytes32Struct, signersStruct } = require('./types-utils');
const { upgradePackage, UPGRADE_POLICIES } = require('./deploy-utils');
const {
addBaseOptions,
addOptionsToCommands,
getWallet,
printWalletInfo,
broadcast,
bytes32Struct,
signersStruct,
upgradePackage,
UPGRADE_POLICIES,
getSigners,
deployPackage,
getObjectIdsByObjectTypes,
Expand Down
75 changes: 0 additions & 75 deletions sui/deploy-test.js

This file was deleted.

5 changes: 2 additions & 3 deletions sui/faucet.js
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
'use strict';

const { addBaseOptions } = require('./cli-utils');
const { requestSuiFromFaucetV0, getFaucetHost } = require('@mysten/sui/faucet');
const { getWallet, printWalletInfo } = require('./sign-utils');
const { Command } = require('commander');
const { saveConfig, loadConfig, printInfo } = require('../common/utils');
const { getWallet, printWalletInfo, addBaseOptions } = require('./utils');
const { Command } = require('commander');

async function processCommand(config, chain, options) {
const [keypair, client] = getWallet(chain, options);
Expand Down
22 changes: 13 additions & 9 deletions sui/gas-service.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,22 @@
const { saveConfig, printInfo, printError } = require('../common/utils');
const { Command } = require('commander');
const { Transaction } = require('@mysten/sui/transactions');
const { bcs } = require('@mysten/sui/bcs');
const { loadConfig } = require('../common/utils');
const { gasServiceStruct } = require('./types-utils');
const { getBcsBytesByObjectId } = require('./utils');
const { ethers } = require('hardhat');
const { getFormattedAmount } = require('./amount-utils');
const {
utils: { arrayify },
} = ethers;

const { addOptionsToCommands, addBaseOptions, parseSuiUnitAmount } = require('./cli-utils');
const { getWallet, printWalletInfo, broadcast } = require('./sign-utils');
const { saveConfig, loadConfig, printInfo, printError } = require('../common/utils');
const {
getWallet,
printWalletInfo,
broadcast,
gasServiceStruct,
getBcsBytesByObjectId,
getFormattedAmount,
addOptionsToCommands,
addBaseOptions,
parseSuiUnitAmount,
} = require('./utils');

async function payGas(keypair, client, gasServiceConfig, args, options) {
const walletAddress = keypair.toSuiAddress();
Expand Down Expand Up @@ -176,7 +180,7 @@ if (require.main === module) {
.description('Pay gas for the new contract call.')
.option('--refundAddress <refundAddress>', 'Refund address. Default is the sender address.')
.requiredOption('--amount <amount>', 'Amount to pay gas', parseSuiUnitAmount)
.option('--params <params>', 'Params. Default is empty.')
.option('--params <params>', 'Params. Default is empty.', '0x')
.action((destinationChain, destinationAddress, channelId, payload, options) => {
mainProcessor(options, [destinationChain, destinationAddress, channelId, payload], processCommand, payGas);
});
Expand Down
Loading

0 comments on commit 76329f6

Please sign in to comment.