refactor(cosmwasm/tools): update cosmjs dependencies (#1514)

* refactor(cosmwasm/tools): update cosmjs dependencies

We needed to update cosmjs dependencies to support Xion, which is based
on a new CometBFT-based variation of tendermint. This change also
includes the artifacts for the Xion testnet network.

* fix: pin a dependency to get nextjs to work

* fix: address review comments
This commit is contained in:
Ali Behjati 2024-04-29 19:34:57 +02:00 committed by GitHub
parent 24a08a06c5
commit a203808a44
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
12 changed files with 1693 additions and 1080 deletions

View File

@ -74,3 +74,11 @@
prefix: rol
feeDenom: urax
type: CosmWasmChain
- endpoint: https://testnet-burnt-rpc.lavenderfive.com
id: xion_testnet
wormholeChainName: xion_testnet
mainnet: false
gasPrice: "0.025"
prefix: xion
feeDenom: uxion
type: CosmWasmChain

View File

@ -43,3 +43,6 @@
- chain: rol_testnet
address: rol1pvrwmjuusn9wh34j7y520g8gumuy9xtl3gvprlljfdpwju3x7ucszdyfs8
type: CosmWasmPriceFeedContract
- chain: xion_testnet
address: xion1w39ctwxxhxxc2kxarycjxj9rndn65gf8daek7ggarwh3rq3zl0lqqllnmt
type: CosmWasmPriceFeedContract

View File

@ -19,19 +19,26 @@
"format": "prettier --write \"src/**/*.ts\"",
"test": "jest"
},
"//": [
"The injectivelabs/token-metadata package is pinned to a specific version to ensure that",
"wormhole-sdk can be built with the correct version of the package in nextjs (xc_admin_frontend).",
"Otherwise, the nextjs build will fail due to using a different version of the package."
],
"dependencies": {
"@certusone/wormhole-sdk": "^0.9.22",
"@certusone/wormhole-sdk": "^0.10.15",
"@coral-xyz/anchor": "^0.29.0",
"@injectivelabs/sdk-ts": "^1.10.72",
"@injectivelabs/token-metadata": "~1.10.42",
"@pythnetwork/client": "^2.17.0",
"@pythnetwork/pyth-solana-receiver": "*",
"@pythnetwork/solana-utils": "*",
"@solana/buffer-layout": "^4.0.1",
"@solana/web3.js": "^1.73.0",
"@sqds/mesh": "^1.0.6",
"bigint-buffer": "^1.1.5",
"ethers": "^5.7.2",
"lodash": "^4.17.21",
"typescript": "^4.9.4",
"@pythnetwork/solana-utils": "*",
"@pythnetwork/pyth-solana-receiver": "*"
"typescript": "^4.9.4"
},
"devDependencies": {
"@types/bn.js": "^5.1.1",

View File

@ -144,6 +144,7 @@ export const RECEIVER_CHAINS = {
sei_evm_devnet: 50067,
boba_sepolia: 50068,
astar_zkyoto_testnet: 50069,
xion_testnet: 50070,
};
// If there is any overlapping value the receiver chain will replace the wormhole

2690
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -11,21 +11,21 @@
"author": "",
"license": "Apache-2.0",
"dependencies": {
"@cosmjs/cosmwasm-stargate": "^0.29.5",
"@cosmjs/encoding": "^0.26.2",
"@cosmjs/proto-signing": "^0.30.1",
"@cosmjs/cosmwasm-stargate": "^0.32.3",
"@cosmjs/encoding": "^0.32.3",
"@cosmjs/proto-signing": "^0.32.3",
"@cosmjs/stargate": "^0.32.3",
"@injectivelabs/networks": "^1.14.6",
"@injectivelabs/sdk-ts": "1.0.354",
"@injectivelabs/sdk-ts": "1.14.7",
"@ltd/j-toml": "^1.38.0",
"@pythnetwork/price-service-client": "*",
"@terra-money/terra.js": "^3.1.3",
"@terra-money/terra.js": "^3.1.10",
"adm-zip": "^0.5.10",
"chain-registry": "^1.6.0",
"cosmjs-utils": "^0.1.0",
"chain-registry": "^1.45.1",
"dotenv": "^16.0.0",
"ethers": "^5.4.4",
"node-downloader-helper": "^2.1.7",
"osmojs": "^13.0.0-rc.7-i-alpha",
"osmojs": "^16.12.1",
"xc_admin_common": "*",
"yargs": "^17.0.1"
},
@ -34,7 +34,7 @@
"@types/yargs": "^17.0.18",
"@typescript-eslint/eslint-plugin": "^5.43.0",
"@typescript-eslint/parser": "^5.43.0",
"cosmjs-types": "^0.6.1",
"cosmjs-types": "^0.9.0",
"eslint": "^8.27.0",
"eslint-config-prettier": "^8.5.0",
"ts-node": "^10.9.1",

View File

@ -119,7 +119,7 @@ export class CosmwasmQuerier implements ChainQuerier {
return {
...contractInfo,
codeId: contractInfo.codeId.toNumber(),
codeId: Number(contractInfo.codeId),
adminAddr: contractInfo.admin,
};
}

View File

@ -98,7 +98,7 @@ export class CosmwasmExecutor implements ChainExecutor {
const txResponse = await cosmwasmClient.signAndBroadcast(
address,
[encodedMsgObject],
1.5
2
);
if (txResponse.code !== 0) {
@ -154,7 +154,7 @@ export class CosmwasmExecutor implements ChainExecutor {
value: {
sender: accAddress,
admin: accAddress,
codeId: Long.fromNumber(codeId),
codeId: BigInt(codeId),
label,
msg: Buffer.from(JSON.stringify(instMsg)),
funds: [],
@ -213,7 +213,7 @@ export class CosmwasmExecutor implements ChainExecutor {
value: {
sender: await this.getAddress(),
contract: contractAddr,
codeId: Long.fromNumber(newCodeId),
codeId: BigInt(newCodeId),
msg: Buffer.from(JSON.stringify(migrateMsg)),
},
};

View File

@ -118,7 +118,7 @@ export class InjectiveExecutor implements ChainExecutor {
const sig = await this.wallet.sign(Buffer.from(signBytes));
/** Append Signatures */
txRaw.setSignaturesList([sig]);
txRaw.signatures = txRaw.signatures.concat(sig);
const txResponse = await txService.broadcast(txRaw);

View File

@ -1,5 +1,5 @@
import { readFileSync } from "fs";
import { Bech32, toHex } from "@cosmjs/encoding";
import { toHex, fromBech32 } from "@cosmjs/encoding";
import { ethers } from "ethers";
import assert from "assert";
import { getNetworkInfo, Network } from "@injectivelabs/networks";
@ -59,7 +59,7 @@ export class InjectiveDeployer implements Deployer {
const sig = await this.wallet.sign(Buffer.from(signBytes));
/** Append Signatures */
txRaw.setSignaturesList([sig]);
txRaw.signatures = txRaw.signatures.concat(sig);
const txService = new TxGrpcClient(networkInfo.grpc);
const txResponse = await txService.broadcast(txRaw);
@ -216,7 +216,7 @@ export class InjectiveDeployer implements Deployer {
// Injective addresses are "human-readable", but for cross-chain registrations, we
// want the "canonical" version
function convert_injective_address_to_hex(human_addr: string) {
return "0x" + toHex(ethers.utils.zeroPad(Bech32.decode(human_addr).data, 32));
return "0x" + toHex(ethers.utils.zeroPad(fromBech32(human_addr).data, 32));
}
// enter key of what to extract

View File

@ -1,5 +1,4 @@
import { getSigningOsmosisClient, cosmwasm, estimateOsmoFee } from "osmojs";
import { getOfflineSignerProto as getOfflineSigner } from "cosmjs-utils";
import { chains } from "chain-registry";
import { Chain } from "@chain-registry/types";
import { readFileSync } from "fs";
@ -9,7 +8,7 @@ import assert from "assert";
import { ContractInfo, Deployer } from ".";
import { convert_terra_address_to_hex, extractFromRawLog } from "./terra";
import { EncodeObject } from "@cosmjs/proto-signing";
import { EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
import Long from "long";
export type OsmosisHost = {
@ -26,11 +25,7 @@ export class OsmosisDeployer implements Deployer {
}
private async getAccountAddress(): Promise<string> {
const signer = await getOfflineSigner({
mnemonic: this.mnemonic,
chain: this.chain,
});
const signer = await DirectSecp256k1HdWallet.fromMnemonic(this.mnemonic);
const accountData = await signer.getAccounts();
return accountData[0].address;
}
@ -38,10 +33,7 @@ export class OsmosisDeployer implements Deployer {
private async signAndBroadcast(
msg: EncodeObject
): Promise<DeliverTxResponse> {
const signer = await getOfflineSigner({
mnemonic: this.mnemonic,
chain: this.chain,
});
const signer = await DirectSecp256k1HdWallet.fromMnemonic(this.mnemonic);
const client = await getSigningOsmosisClient({
rpcEndpoint: this.endpoint,
@ -69,7 +61,7 @@ export class OsmosisDeployer implements Deployer {
const rs = await client.signAndBroadcast(address, [msg], fee);
if (rs.code !== 0) {
console.error(`Transaction failed: ${rs.rawLog}`);
console.error(`Transaction failed: ${rs.events}`);
} else {
console.log(
`Broadcasted transaction hash: ${JSON.stringify(rs.transactionHash)}`
@ -210,7 +202,7 @@ export class OsmosisDeployer implements Deployer {
const { codeId, creator, admin } = contractInfo;
return {
codeId: codeId.toNumber(),
codeId: Number(codeId),
address: address,
creator: creator,
admin: admin,

View File

@ -11,7 +11,7 @@ import {
isTxError,
} from "@terra-money/terra.js";
import { readFileSync } from "fs";
import { Bech32, toHex } from "@cosmjs/encoding";
import { fromBech32, toHex } from "@cosmjs/encoding";
import { ethers } from "ethers";
import assert from "assert";
import { ContractInfo, Deployer } from ".";
@ -179,7 +179,7 @@ export class TerraDeployer implements Deployer {
// Terra addresses are "human-readable", but for cross-chain registrations, we
// want the "canonical" version
export function convert_terra_address_to_hex(human_addr: string) {
return "0x" + toHex(ethers.utils.zeroPad(Bech32.decode(human_addr).data, 32));
return "0x" + toHex(ethers.utils.zeroPad(fromBech32(human_addr).data, 32));
}
// enter key of what to extract