From 899cb0d20ddc01980ff7098d4e9a0ddc8350b493 Mon Sep 17 00:00:00 2001 From: liangping <18786721@qq.com> Date: Sat, 4 Jun 2022 09:04:00 +0800 Subject: [PATCH] Fixed signning issue --- src/libs/client/PingWalletClient.ts | 8 +++---- src/libs/utils.js | 36 ++++++++++++----------------- 2 files changed, 19 insertions(+), 25 deletions(-) diff --git a/src/libs/client/PingWalletClient.ts b/src/libs/client/PingWalletClient.ts index 182dc8cb..330a6f02 100644 --- a/src/libs/client/PingWalletClient.ts +++ b/src/libs/client/PingWalletClient.ts @@ -11,7 +11,7 @@ import { LedgerSigner } from '@cosmjs/ledger-amino'; import { EthereumLedgerSigner } from './EthereumLedgerSigner'; import TransportWebUSB from '@ledgerhq/hw-transport-webusb'; import TransportWebBLE from '@ledgerhq/hw-transport-web-ble' -import { stringToPath } from '@cosmjs/crypto'; +import { HdPath, stringToPath } from '@cosmjs/crypto'; import { StdFee } from "@cosmjs/amino"; import { TxRaw } from "cosmjs-types/cosmos/tx/v1beta1/tx"; @@ -44,9 +44,9 @@ import { TxRaw } from "cosmjs-types/cosmos/tx/v1beta1/tx"; export declare type SigningClient = SigningStargateClient | SigningEthermintClient; -export async function getSigningClient(device, hdpath) : Promise { +export async function getSigningClient(device, hdpath): Promise { let ledgerAppName = 'Cosmos' - let coinType = Number(stringToPath(hdpath)[1]) + let coinType = Number(hdpath[1]) switch (coinType) { case 60: return new SigningEthermintClient(await EthereumLedgerSigner.create(device, hdpath)) // 'Ethereum' @@ -71,7 +71,7 @@ export class SigningEthermintClient { } sign(signerAddress: string, messages: readonly EncodeObject[], fee: StdFee, memo: string, explicitSignerData?: SignerData): Promise { - return new Promise(()=>{return TxRaw.decode(null)}) + return new Promise(() => { return TxRaw.decode(null) }) } } diff --git a/src/libs/utils.js b/src/libs/utils.js index f08e32d9..9b519859 100644 --- a/src/libs/utils.js +++ b/src/libs/utils.js @@ -18,6 +18,7 @@ import localeData from 'dayjs/plugin/localeData' import { $themeColors } from '@themeConfig' // import { SigningStargateClient } from '@cosmjs/stargate' // import PingWalletClient from './data/signing' +import { SigningStargateClient } from '@cosmjs/stargate' import { getSigningClient } from './client/PingWalletClient.ts' import { EthereumLedgerSigner } from './client/EthereumLedgerSigner.ts' @@ -225,30 +226,23 @@ async function getLedgerAppName(coinType, device, hdpath) { export async function sign(device, chainId, signerAddress, messages, fee, memo, signerData) { const hdpath = getHdPath(signerAddress) - const client = getSigningClient(device, hdpath) + let client + if (device.startsWith('ledger')) { + client = await getSigningClient(device, hdpath) + } else { + if (!window.getOfflineSigner || !window.keplr) { + throw new Error('Please install keplr extension') + } + await window.keplr.enable(chainId) + const signer = window.getOfflineSignerOnlyAmino(chainId) + client = await SigningStargateClient.offline(signer) + } // let transport // let signer // const hdpath = getHdPath(signerAddress) - // const coinType = Number(hdpath[1]) - // switch (device) { - // case 'ledgerBle': - // signer = await getLedgerAppName(coinType, device, hdpath) - // break - // case 'ledgerUSB': - // signer = await getLedgerAppName(coinType, device, hdpath) - // break - // case 'keplr': - // default: - // if (!window.getOfflineSigner || !window.keplr) { - // throw new Error('Please install keplr extension') - // } - // await window.keplr.enable(chainId) - // signer = window.getOfflineSignerOnlyAmino(chainId) - // } - - // // Ensure the address has some tokens to spend - // const client = await PingWalletClient.offline(signer) - return client.signAmino(device.startsWith('ledger') ? toSignAddress(signerAddress) : signerAddress, messages, fee, memo, signerData) + const coinType = Number(hdpath[1]) + const addr = device.startsWith('ledger') && coinType === 118 ? toSignAddress(signerAddress) : signerAddress + return client.sign(addr, messages, fee, memo, signerData) } export async function getLedgerAddress(transport = 'blu', hdPath = "m/44'/118/0'/0/0") {