From 58bcb02a3bac134afc78a466835a991c67da1640 Mon Sep 17 00:00:00 2001 From: eguajardo Date: Tue, 7 Jan 2025 10:49:10 -0600 Subject: [PATCH] feat(cosmwasm): add previous admin and creator by default to instantiation permissions (#484) --- cosmwasm/cli-utils.js | 4 +++- cosmwasm/submit-proposal.js | 3 +++ cosmwasm/utils.js | 42 +++++++++++++++++++++++++++++++++---- 3 files changed, 44 insertions(+), 5 deletions(-) diff --git a/cosmwasm/cli-utils.js b/cosmwasm/cli-utils.js index 446946d2..14fe9f5a 100644 --- a/cosmwasm/cli-utils.js +++ b/cosmwasm/cli-utils.js @@ -121,7 +121,9 @@ const addStoreProposalOptions = (program) => { new Option('--builder ', 'a valid docker image name with tag, such as "cosmwasm/workspace-optimizer:0.16.0'), ); program.addOption( - new Option('-i, --instantiateAddresses ', 'comma separated list of addresses allowed to instantiate'), + new Option('-i, --instantiateAddresses ', 'comma separated list of addresses allowed to instantiate') + .default([]) + .argParser((addresses) => addresses.split(',').map((address) => address.trim())), ); }; diff --git a/cosmwasm/submit-proposal.js b/cosmwasm/submit-proposal.js index d1ce889f..23db85c7 100644 --- a/cosmwasm/submit-proposal.js +++ b/cosmwasm/submit-proposal.js @@ -17,6 +17,7 @@ const { getAmplifierBaseContractConfig, getAmplifierContractConfig, updateCodeId, + addDefaultInstantiateAddresses, getChainTruncationParams, decodeProposalAttributes, encodeStoreCodeProposal, @@ -80,6 +81,7 @@ const callSubmitProposal = async (client, wallet, config, options, proposal) => const storeCode = async (client, wallet, config, options) => { const { contractName } = options; const contractBaseConfig = getAmplifierBaseContractConfig(config, contractName); + await addDefaultInstantiateAddresses(client, config, options); const proposal = encodeStoreCodeProposal(options); @@ -96,6 +98,7 @@ const storeCode = async (client, wallet, config, options) => { const storeInstantiate = async (client, wallet, config, options) => { const { contractName, instantiate2 } = options; const { contractConfig, contractBaseConfig } = getAmplifierContractConfig(config, options); + await addDefaultInstantiateAddresses(client, config, options); if (instantiate2) { throw new Error('instantiate2 not supported for storeInstantiate'); diff --git a/cosmwasm/utils.js b/cosmwasm/utils.js index db908848..b2e8ca41 100644 --- a/cosmwasm/utils.js +++ b/cosmwasm/utils.js @@ -20,6 +20,7 @@ const { ParameterChangeProposal } = require('cosmjs-types/cosmos/params/v1beta1/ const { AccessType } = require('cosmjs-types/cosmwasm/wasm/v1/types'); const { printInfo, + printWarn, isString, isStringArray, isKeccak256Hash, @@ -133,6 +134,7 @@ const uploadContract = async (client, wallet, config, options) => { const uploadFee = gasLimit === 'auto' ? 'auto' : calculateFee(gasLimit, GasPrice.fromString(gasPrice)); + // uploading through stargate doesn't support defining instantiate permissions return await client.upload(account.address, wasm, uploadFee); }; @@ -544,6 +546,36 @@ const fetchCodeIdFromCodeHash = async (client, contractBaseConfig) => { return codeId; }; +const addDefaultInstantiateAddresses = async (client, config, options) => { + const { contractConfig } = getAmplifierContractConfig(config, options); + + if (!contractConfig.address) { + return; + } + + const contract = await client.getContract(contractConfig.address); + + let { instantiateAddresses } = options; + + if (!instantiateAddresses) { + instantiateAddresses = []; + } + + if (contract.admin && !instantiateAddresses.includes(contract.admin)) { + instantiateAddresses.push(contract.admin); + printWarn( + `Contract ${contractConfig.address} admin address ${contract.admin} was not included in instantiateAddresses list. Adding it by default.`, + ); + } + + if (contract.creator && !instantiateAddresses.includes(contract.creator)) { + instantiateAddresses.push(contract.creator); + printWarn( + `Contract ${contractConfig.address} creator address ${contract.creator} was not included in instantiateAddresses list. Adding it by default.`, + ); + } +}; + const getChainTruncationParams = (config, chainConfig) => { const key = chainConfig.axelarId.toLowerCase(); const chainTruncationParams = config.axelar.contracts.InterchainTokenService[key]; @@ -565,7 +597,7 @@ const getChainTruncationParams = (config, chainConfig) => { const getInstantiatePermission = (accessType, addresses) => { return { permission: accessType, - addresses: addresses.split(',').map((address) => address.trim()), + addresses, }; }; @@ -591,9 +623,10 @@ const getStoreCodeParams = (options) => { codeHash = createHash('sha256').update(wasm).digest(); } - const instantiatePermission = instantiateAddresses - ? getInstantiatePermission(AccessType.ACCESS_TYPE_ANY_OF_ADDRESSES, instantiateAddresses) - : getInstantiatePermission(AccessType.ACCESS_TYPE_NOBODY, ''); + const instantiatePermission = + instantiateAddresses && instantiateAddresses.length > 0 + ? getInstantiatePermission(AccessType.ACCESS_TYPE_ANY_OF_ADDRESSES, instantiateAddresses) + : getInstantiatePermission(AccessType.ACCESS_TYPE_NOBODY, []); return { ...getSubmitProposalParams(options), @@ -841,6 +874,7 @@ module.exports = { uploadContract, instantiateContract, fetchCodeIdFromCodeHash, + addDefaultInstantiateAddresses, getChainTruncationParams, decodeProposalAttributes, encodeStoreCodeProposal,