From 4bfe2b645ea5bccccc64ea29c589d2849d8cf1e4 Mon Sep 17 00:00:00 2001 From: Nitin Mittal Date: Thu, 7 Mar 2024 14:43:49 +0400 Subject: [PATCH 1/2] fix: eth signer --- src/ethers/web3_client.ts | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/src/ethers/web3_client.ts b/src/ethers/web3_client.ts index d75a05b..60ecb82 100644 --- a/src/ethers/web3_client.ts +++ b/src/ethers/web3_client.ts @@ -17,6 +17,9 @@ export class EtherWeb3Client extends BaseWeb3Client { if ((provider as ETHER_PROVIDER)._isProvider) { this.provider = provider as ETHER_PROVIDER; this.signer = this.provider.getSigner(); + if (!this.signer || !this.signer._address) { + this.signer = (provider as any); + } } else { this.signer = (provider as any); @@ -93,7 +96,7 @@ export class EtherWeb3Client extends BaseWeb3Client { getTransactionReceipt(transactionHash: string) { return this.provider.getTransactionReceipt(transactionHash).then(result => { this.ensureTransactionNotNull_(result); - + return ethReceiptToMaticReceipt(result); }); } @@ -151,14 +154,14 @@ export class EtherWeb3Client extends BaseWeb3Client { hexToNumber(value) { return BigNumber.from(value).toNumber(); } - + hexToNumberString(value) { return BigNumber.from(value).toString(); } signTypedData(signer, typedData) { - const {domain, types, message: value} = typedData; - if(types.EIP712Domain) { + const { domain, types, message: value } = typedData; + if (types.EIP712Domain) { delete types.EIP712Domain; } return this.signer._signTypedData(domain, types, value); From 03f7e1992f5678f3b464651e88b7b27417d57ebb Mon Sep 17 00:00:00 2001 From: Nitin Mittal Date: Fri, 8 Mar 2024 13:04:44 +0400 Subject: [PATCH 2/2] fix: signer --- package.json | 2 +- src/ethers/web3_client.ts | 29 +++++++++++++++-------------- 2 files changed, 16 insertions(+), 15 deletions(-) diff --git a/package.json b/package.json index 3ef9165..8c8e1a3 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@maticnetwork/maticjs-ethers", - "version": "1.0.3", + "version": "1.1.0", "description": "ethers plugin for matic.js", "main": "dist/npm.export.js", "types": "dist/ts/index.d.ts", diff --git a/src/ethers/web3_client.ts b/src/ethers/web3_client.ts index 60ecb82..93679d0 100644 --- a/src/ethers/web3_client.ts +++ b/src/ethers/web3_client.ts @@ -6,29 +6,28 @@ import { ethBlockToMaticBlock, ethReceiptToMaticReceipt, ethTxToMaticTx } from " type ETHER_PROVIDER = providers.JsonRpcProvider; type ETHER_SIGNER = providers.JsonRpcSigner; +type WEB3_PROVIDER = providers.Web3Provider; export class EtherWeb3Client extends BaseWeb3Client { name = 'ETHER'; provider: ETHER_PROVIDER; signer: ETHER_SIGNER; - constructor(provider: ETHER_PROVIDER | Wallet, logger) { + constructor(provider: ETHER_PROVIDER | Wallet | WEB3_PROVIDER, logger) { super(logger); - if ((provider as ETHER_PROVIDER)._isProvider) { - this.provider = provider as ETHER_PROVIDER; - this.signer = this.provider.getSigner(); - if (!this.signer || !this.signer._address) { - this.signer = (provider as any); - } - } - else { - this.signer = (provider as any); - this.provider = ((provider as Wallet).provider) as any; + + if (provider instanceof ethers.providers.Web3Provider) { + this.provider = provider; + this.signer = provider.getSigner(); + } else if (provider instanceof ethers.providers.JsonRpcProvider) { + this.provider = provider; + this.signer = provider as any; + } else { + this.signer = provider as any; + this.provider = provider.provider || provider as any; } } - - getBlock(blockHashOrBlockNumber) { return this.provider.getBlock(blockHashOrBlockNumber).then(block => { return block as any; @@ -57,7 +56,9 @@ export class EtherWeb3Client extends BaseWeb3Client { getChainId() { - return this.signer.getChainId(); + return this.provider.getNetwork().then(function (res) { + return res.chainId; + }); } getBalance(address) {