Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(sui)!: support sui amplifier deployment #342

Merged
merged 12 commits into from
Aug 27, 2024
7 changes: 6 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,9 @@
Install dependencies via
`npm ci`

[EVM deployment instructions](./evm/README.md)
## Deployment Instructions

- [EVM](./evm/README.md)
- [Cosmwasm](./cosmwasm/README.md)
- [Sui](./sui/README.md)
- [Stellar](./stellar/README.md)
2 changes: 1 addition & 1 deletion common/cli-utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ const { Option } = require('commander');
const addBaseOptions = (program, options = {}) => {
program.addOption(
new Option('-e, --env <env>', 'environment')
.choices(['local', 'devnet', 'devnet-amplifier', 'devnet-verifiers', 'stagenet', 'testnet', 'mainnet'])
.choices(['local', 'devnet', 'devnet-amplifier', 'devnet-sui', 'devnet-verifiers', 'stagenet', 'testnet', 'mainnet'])
milapsheth marked this conversation as resolved.
Show resolved Hide resolved
.default('testnet')
.makeOptionMandatory(true)
.env('ENV'),
Expand Down
41 changes: 31 additions & 10 deletions common/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ const readlineSync = require('readline-sync');
const { CosmWasmClient } = require('@cosmjs/cosmwasm-stargate');
const { ethers } = require('hardhat');
const {
utils: { keccak256, hexlify },
utils: { keccak256 },
} = ethers;
const { normalizeBech32 } = require('@cosmjs/encoding');

Expand Down Expand Up @@ -347,6 +347,13 @@ const isValidCosmosAddress = (str) => {
}
};

const getContractConfig = async (config, chain) => {
const key = Buffer.from('config');
const client = await CosmWasmClient.connect(config.axelar.rpc);
const value = await client.queryContractRaw(config.axelar.contracts.MultisigProver[chain].address, key);
return JSON.parse(Buffer.from(value).toString('ascii'));
};

async function getDomainSeparator(config, chain, options) {
// Allow any domain separator for local deployments or `0x` if not provided
if (options.env === 'local') {
Expand Down Expand Up @@ -378,21 +385,32 @@ async function getDomainSeparator(config, chain, options) {
}

printInfo(`Retrieving domain separator for ${chain.name} from Axelar network`);
const domainSeparator = hexlify((await getContractConfig(config, chain.axelarId)).domain_separator);
// const domainSeparator = hexlify((await getContractConfig(config, chain.axelarId)).domain_separator);
const expectedDomainSeparator = calculateDomainSeparator(chain.axelarId, routerAddress, chainId);

if (domainSeparator !== expectedDomainSeparator) {
throw new Error(`unexpected domain separator (want ${expectedDomainSeparator}, got ${domainSeparator})`);
}
// TODO: add domain separator prediction support to display before amplifier contracts are ready
milapsheth marked this conversation as resolved.
Show resolved Hide resolved
// if (domainSeparator !== expectedDomainSeparator) {
// throw new Error(`unexpected domain separator (want ${expectedDomainSeparator}, got ${domainSeparator})`);
// }

return domainSeparator;
return expectedDomainSeparator;
}

const getContractConfig = async (config, chain) => {
const key = Buffer.from('config');
const getChainConfig = (config, chainName) => {
const chainConfig = config.chains[chainName] || config[chainName];

if (!chainConfig) {
throw new Error(`Chain ${chainName} not found in config`);
}

return chainConfig;
};

const getMultisigProof = async (config, chain, multisigSessionId) => {
const query = { proof: { multisig_session_id: `${multisigSessionId}` } };
const client = await CosmWasmClient.connect(config.axelar.rpc);
const value = await client.queryContractRaw(config.axelar.contracts.MultisigProver[chain].address, key);
return JSON.parse(Buffer.from(value).toString('ascii'));
const value = await client.queryContractSmart(config.axelar.contracts.MultisigProver[chain].address, query);
return value;
};

const calculateDomainSeparator = (chain, router, network) => keccak256(Buffer.from(`${chain}${router}${network}`));
Expand Down Expand Up @@ -429,4 +447,7 @@ module.exports = {
timeout,
validateParameters,
getDomainSeparator,
getChainConfig,
getMultisigProof,
getContractConfig,
};
8 changes: 4 additions & 4 deletions cosmwasm/deploy-contract.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
require('dotenv').config();
const { isNil } = require('lodash');

const { isNumber, printInfo, loadConfig, saveConfig, prompt } = require('../evm/utils');
const { isNumber, printInfo, loadConfig, saveConfig, prompt, getChainConfig } = require('../evm/utils');
const {
prepareWallet,
prepareClient,
Expand All @@ -23,8 +23,8 @@ const upload = (client, wallet, chainName, config, options) => {
axelar: {
contracts: { [contractName]: contractConfig },
},
chains: { [chainName]: chainConfig },
} = config;
const chainConfig = chainName === 'none' ? undefined : getChainConfig(config, chainName);

if (!fetchCodeId && (!reuseCodeId || isNil(contractConfig.codeId))) {
printInfo('Uploading contract binary');
Expand Down Expand Up @@ -52,7 +52,7 @@ const upload = (client, wallet, chainName, config, options) => {
.then(() => ({ wallet, client }));
}

printInfo('Skipping upload. Reusing previously uploaded binary');
printInfo('Skipping upload. Reusing previously uploaded bytecode');
return Promise.resolve({ wallet, client });
};

Expand Down Expand Up @@ -114,7 +114,7 @@ const programHandler = () => {

program.addOption(
new Option('-e, --env <env>', 'environment')
.choices(['local', 'devnet', 'stagenet', 'testnet', 'mainnet'])
.choices(['local', 'devnet', 'stagenet', 'testnet', 'devnet-sui', 'mainnet'])
milapsheth marked this conversation as resolved.
Show resolved Hide resolved
.default('testnet')
.makeOptionMandatory(true)
.env('ENV'),
Expand Down
4 changes: 2 additions & 2 deletions cosmwasm/submit-proposal.js
Original file line number Diff line number Diff line change
Expand Up @@ -251,13 +251,13 @@ const programHandler = () => {
// 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'])
.choices(['local', 'devnet', 'devnet-amplifier', 'devnet-sui', 'devnet-verifiers', 'stagenet', 'testnet', 'mainnet'])
.default('devnet-amplifier')
.makeOptionMandatory(true)
.env('ENV'),
);
program.addOption(new Option('-m, --mnemonic <mnemonic>', 'mnemonic').makeOptionMandatory(true).env('MNEMONIC'));
program.addOption(new Option('-a, --artifactPath <artifactPath>', 'artifact path').makeOptionMandatory(true).env('ARTIFACT_PATH'));
program.addOption(new Option('-a, --artifactPath <artifactPath>', 'artifact path').env('ARTIFACT_PATH'));
program.addOption(new Option('-c, --contractName <contractName>', 'contract name').makeOptionMandatory(true));
program.addOption(new Option('-n, --chainNames <chainNames>', 'chain names').default('none'));

Expand Down
20 changes: 8 additions & 12 deletions cosmwasm/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ const {
ExecuteContractProposal,
} = require('cosmjs-types/cosmwasm/wasm/v1/proposal');
const { AccessType } = require('cosmjs-types/cosmwasm/wasm/v1/types');
const { getSaltFromKey, isString, isStringArray, isKeccak256Hash, isNumber, toBigNumberString } = require('../evm/utils');
const { getSaltFromKey, isString, isStringArray, isKeccak256Hash, isNumber, toBigNumberString, getChainConfig } = require('../evm/utils');
const { normalizeBech32 } = require('@cosmjs/encoding');

const governanceAddress = 'axelar10d07y265gmmuvt4z0w9aw880jnsr700j7v9daj';
Expand Down Expand Up @@ -66,11 +66,7 @@ const getChains = (config, { chainNames, instantiate2 }) => {
throw new Error('Cannot pass --instantiate2 with more than one chain');
}

const undefinedChain = chains.find((chain) => !config.chains[chain.toLowerCase()] && chain !== 'none');

if (undefinedChain) {
throw new Error(`Chain ${undefinedChain} is not defined in the info file`);
}
chains.every((chain) => chain === 'none' || getChainConfig(config, chain));
milapsheth marked this conversation as resolved.
Show resolved Hide resolved

return chains;
};
Expand Down Expand Up @@ -216,7 +212,7 @@ const makeNexusGatewayInstantiateMsg = ({ nexus }, { Router: { address: router }
const makeVotingVerifierInstantiateMsg = (
contractConfig,
{ ServiceRegistry: { address: serviceRegistryAddress }, Rewards: { address: rewardsAddress } },
{ id: chainId },
{ axelarId: chainId },
) => {
const {
[chainId]: {
Expand Down Expand Up @@ -286,7 +282,7 @@ const makeVotingVerifierInstantiateMsg = (
};
};

const makeGatewayInstantiateMsg = ({ Router: { address: routerAddress }, VotingVerifier }, { id: chainId }) => {
const makeGatewayInstantiateMsg = ({ Router: { address: routerAddress }, VotingVerifier }, { axelarId: chainId }) => {
const {
[chainId]: { address: verifierAddress },
} = VotingVerifier;
Expand All @@ -305,8 +301,8 @@ const makeGatewayInstantiateMsg = ({ Router: { address: routerAddress }, VotingV
const makeMultisigProverInstantiateMsg = (config, chainName) => {
const {
axelar: { contracts, chainId: axelarChainId },
chains: { [chainName]: chainConfig },
} = config;
const chainConfig = getChainConfig(config, chainName);

const { axelarId: chainId } = chainConfig;

Expand Down Expand Up @@ -424,8 +420,8 @@ const makeMultisigProverInstantiateMsg = (config, chainName) => {
const makeInstantiateMsg = (contractName, chainName, config) => {
const {
axelar: { contracts },
chains: { [chainName]: chainConfig },
} = config;
const chainConfig = getChainConfig(config, chainName);

const { [contractName]: contractConfig } = contracts;

Expand Down Expand Up @@ -618,12 +614,12 @@ const getExecuteContractParams = (config, options, chainName) => {
axelar: {
contracts: { [contractName]: contractConfig },
},
chains: { [chainName]: chainConfig },
} = config;
const chainConfig = getChainConfig(config, chainName);

return {
...getSubmitProposalParams(options),
contract: chainConfig ? contractConfig[chainConfig.axelarId].address : contractConfig.address,
contract: contractConfig[chainConfig.axelarId]?.address || contractConfig.address,
msg: Buffer.from(msg),
};
};
Expand Down
8 changes: 0 additions & 8 deletions evm/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -493,13 +493,6 @@ const getEVMAddresses = async (config, chain, options = {}) => {
return { addresses, weights, threshold, keyID: evmAddresses.key_id };
};

const getContractConfig = async (config, chain) => {
const key = Buffer.from('config');
const client = await CosmWasmClient.connect(config.axelar.rpc);
const value = await client.queryContractRaw(config.axelar.contracts.MultisigProver[chain].address, key);
return JSON.parse(Buffer.from(value).toString('ascii'));
};

const getAmplifierKeyAddresses = async (config, chain) => {
const client = await CosmWasmClient.connect(config.axelar.rpc);
const { id: verifierSetId, verifier_set: verifierSet } = await client.queryContractSmart(
Expand Down Expand Up @@ -1062,7 +1055,6 @@ module.exports = {
getDeployOptions,
isValidChain,
getAmplifierKeyAddresses,
getContractConfig,
relayTransaction,
getDeploymentTx,
getWeightedSigners,
Expand Down
4 changes: 3 additions & 1 deletion sui/deploy-contract.js
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,7 @@ async function postDeployAxelarGateway(published, keypair, client, config, chain

// Update chain configuration
chain.contracts.AxelarGateway = {
address: packageId,
objects: {
Gateway: gateway,
RelayerDiscovery: relayerDiscovery,
Expand Down Expand Up @@ -248,7 +249,8 @@ async function deploy(keypair, client, supportedContract, config, chain, options
// Deploy package
const published = await deployPackage(packageDir, client, keypair, options);

printInfo(`Deployed ${packageName}`, published.publishTxn.digest);
printInfo(`Deployed ${packageName} Package`, published.packageId);
printInfo(`Deployed ${packageName} Tx`, published.publishTxn.digest);

// Update chain configuration with deployed contract address
chain.contracts[packageName] = {
Expand Down
Loading
Loading