From 62d27f08303036ab2be6ef556495cc9c6adc348b Mon Sep 17 00:00:00 2001 From: Matt Solomon Date: Thu, 30 Jun 2022 07:22:33 -0700 Subject: [PATCH 1/3] perf: use StaticJsonRpcProvider for inura endpoints in frontend --- frontend/src/utils/constants.ts | 4 ++-- frontend/src/utils/ethers.ts | 2 +- frontend/src/utils/payment-links.ts | 4 ++-- frontend/src/utils/umbra-api.ts | 4 ++-- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/frontend/src/utils/constants.ts b/frontend/src/utils/constants.ts index 59c48729f..c10f11f15 100644 --- a/frontend/src/utils/constants.ts +++ b/frontend/src/utils/constants.ts @@ -1,7 +1,7 @@ -import { JsonRpcProvider } from 'src/utils/ethers'; +import { StaticJsonRpcProvider } from 'src/utils/ethers'; export const MAINNET_RPC_URL = `https://mainnet.infura.io/v3/${String(process.env.INFURA_ID)}`; -export const MAINNET_PROVIDER = new JsonRpcProvider(MAINNET_RPC_URL); +export const MAINNET_PROVIDER = new StaticJsonRpcProvider(MAINNET_RPC_URL); export const ETH_NETWORK_LOGO = ''; // prettier-ignore diff --git a/frontend/src/utils/ethers.ts b/frontend/src/utils/ethers.ts index 3831de19e..9e4402ff5 100644 --- a/frontend/src/utils/ethers.ts +++ b/frontend/src/utils/ethers.ts @@ -12,6 +12,6 @@ export { Contract } from '@ethersproject/contracts'; export { namehash } from '@ethersproject/hash'; export { keccak256 } from '@ethersproject/keccak256'; export { Logger, LogLevel } from '@ethersproject/logger'; -export { Block, JsonRpcProvider, JsonRpcSigner, Network, TransactionReceipt, TransactionResponse, Web3Provider, } from '@ethersproject/providers'; // prettier-ignore +export { Block, JsonRpcSigner, Network, StaticJsonRpcProvider, TransactionReceipt, TransactionResponse, Web3Provider } from '@ethersproject/providers'; // prettier-ignore export { toUtf8Bytes } from '@ethersproject/strings'; export { parseUnits, formatUnits } from '@ethersproject/units'; diff --git a/frontend/src/utils/payment-links.ts b/frontend/src/utils/payment-links.ts index 85bfe9ea3..87a5e1140 100644 --- a/frontend/src/utils/payment-links.ts +++ b/frontend/src/utils/payment-links.ts @@ -3,7 +3,7 @@ import { TokenInfoExtended } from 'components/models'; import { utils as umbraUtils } from '@umbra/umbra-js'; import useWalletStore from 'src/store/wallet'; import { notifyUser } from 'src/utils/alerts'; -import { JsonRpcProvider } from 'src/utils/ethers'; +import { StaticJsonRpcProvider } from 'src/utils/ethers'; import { UmbraApi } from 'src/utils/umbra-api'; /** @@ -11,7 +11,7 @@ import { UmbraApi } from 'src/utils/umbra-api'; */ function getProvider() { const { provider } = useWalletStore(); - return provider.value || new JsonRpcProvider(`https://mainnet.infura.io/v3/${String(process.env.INFURA_ID)}`); + return provider.value || new StaticJsonRpcProvider(`https://mainnet.infura.io/v3/${String(process.env.INFURA_ID)}`); } /** diff --git a/frontend/src/utils/umbra-api.ts b/frontend/src/utils/umbra-api.ts index 52541a040..270fe20d1 100644 --- a/frontend/src/utils/umbra-api.ts +++ b/frontend/src/utils/umbra-api.ts @@ -2,7 +2,7 @@ * @notice Class for managing relayed withdrawal transactions */ -import { JsonRpcProvider } from 'src/utils/ethers'; +import { StaticJsonRpcProvider } from './ethers'; import { FeeEstimateResponse, RelayerStatusResponse, @@ -21,7 +21,7 @@ export class UmbraApi { readonly nativeTokenMinSendAmount: string | undefined ) {} - static async create(provider: Provider | JsonRpcProvider) { + static async create(provider: Provider | StaticJsonRpcProvider) { // Get API URL based on chain ID const chainId = (await provider.getNetwork()).chainId; const baseUrl = 'https://mainnet.api.umbra.cash'; // works for all networks From bf8ab5a6077a744da057514cbb0a783049c22f93 Mon Sep 17 00:00:00 2001 From: Matt Solomon Date: Thu, 30 Jun 2022 07:24:26 -0700 Subject: [PATCH 2/3] refactor: remove unused itx method --- frontend/src/utils/umbra-api.ts | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/frontend/src/utils/umbra-api.ts b/frontend/src/utils/umbra-api.ts index 270fe20d1..dfb00f631 100644 --- a/frontend/src/utils/umbra-api.ts +++ b/frontend/src/utils/umbra-api.ts @@ -5,7 +5,6 @@ import { StaticJsonRpcProvider } from './ethers'; import { FeeEstimateResponse, - RelayerStatusResponse, Provider, TokenInfoExtended, RelayResponse, @@ -60,15 +59,4 @@ export class UmbraApi { if ('error' in data) throw new Error(`Could not relay withdraw: ${data.error}`); return data; } - - // Returns the status of the provided relayer transaction ID - async getRelayStatus(itxId: string) { - // If ChainID is 1 or 4, relaying is supported so fetch the status from the relayer. Otherwise, relaying is - // not supported on this chain so we throw an error - if (this.chainId !== 1 && this.chainId !== 4) throw new Error(`Unsupported relayer chain ID ${this.chainId}`); - const response = await fetch(`${this.baseUrl}/status/${itxId}?chainId=${this.chainId}`); - const data = (await response.json()) as RelayerStatusResponse; - if ('error' in data) throw new Error(`Could not get relay status: ${data.error}`); - return data; - } } From 071f2dbae7f074d7fc9b1dfb2cebb7a19b4d74bd Mon Sep 17 00:00:00 2001 From: Matt Solomon Date: Thu, 30 Jun 2022 07:34:42 -0700 Subject: [PATCH 3/3] perf: use StaticJsonRpcProvider for inura endpoints in umbra-js --- umbra-js/src/classes/Umbra.ts | 8 +++++--- umbra-js/src/ethers.ts | 2 +- umbra-js/src/types.ts | 4 ++-- umbra-js/src/utils/utils.ts | 5 +++-- umbra-js/test/Umbra.test.ts | 4 ++-- umbra-js/test/utils.test.ts | 10 +++++++--- 6 files changed, 20 insertions(+), 13 deletions(-) diff --git a/umbra-js/src/classes/Umbra.ts b/umbra-js/src/classes/Umbra.ts index 76bbb9b9b..eea76adec 100644 --- a/umbra-js/src/classes/Umbra.ts +++ b/umbra-js/src/classes/Umbra.ts @@ -13,12 +13,12 @@ import { getAddress, hexlify, isHexString, - JsonRpcProvider, JsonRpcSigner, keccak256, Overrides, sha256, splitSignature, + StaticJsonRpcProvider, toUtf8Bytes, TransactionResponse, Wallet, @@ -118,7 +118,7 @@ export class Umbra { // Fallback provider, used when a user's provider rejects the transaction. This may happen if the provider from // the user's wallet rejects transactions from accounts not associated with that user's wallet (in this case, that // means transactions from stealth addresses would be rejected). More info: https://github.com/coinbase/coinbase-wallet-sdk/issues/580 - readonly fallbackProvider: JsonRpcProvider; + readonly fallbackProvider: StaticJsonRpcProvider; // ========================================= CONSTRUCTOR ========================================= /** @@ -129,7 +129,9 @@ export class Umbra { constructor(readonly provider: EthersProvider, chainConfig: ChainConfig | number) { this.chainConfig = parseChainConfig(chainConfig); this.umbraContract = new Contract(this.chainConfig.umbraAddress, abi, provider) as UmbraContract; - this.fallbackProvider = new JsonRpcProvider(infuraUrl(this.chainConfig.chainId, String(process.env.INFURA_ID))); + this.fallbackProvider = new StaticJsonRpcProvider( + infuraUrl(this.chainConfig.chainId, String(process.env.INFURA_ID)) + ); } // ==================================== CONTRACT INTERACTION ===================================== diff --git a/umbra-js/src/ethers.ts b/umbra-js/src/ethers.ts index b774a1533..196a04467 100644 --- a/umbra-js/src/ethers.ts +++ b/umbra-js/src/ethers.ts @@ -18,8 +18,8 @@ export { EtherscanProvider, ExternalProvider, JsonRpcFetchFunc, - JsonRpcProvider, JsonRpcSigner, + StaticJsonRpcProvider, TransactionReceipt, TransactionResponse, Web3Provider, diff --git a/umbra-js/src/types.ts b/umbra-js/src/types.ts index 766e391e3..af666a3a3 100644 --- a/umbra-js/src/types.ts +++ b/umbra-js/src/types.ts @@ -2,7 +2,7 @@ import { BigNumber, ExternalProvider as EthersExternalProvider, JsonRpcFetchFunc, - JsonRpcProvider, + StaticJsonRpcProvider, Overrides, Web3Provider, } from './ethers'; @@ -11,7 +11,7 @@ import { export { TransactionResponse } from './ethers'; import { TransactionResponse } from './ethers'; export type ExternalProvider = EthersExternalProvider | JsonRpcFetchFunc; -export type EthersProvider = Web3Provider | JsonRpcProvider; +export type EthersProvider = Web3Provider | StaticJsonRpcProvider; // Transaction responses on L2s and other chains may have more fields than on L1. export interface TransactionResponseExtended extends TransactionResponse { diff --git a/umbra-js/src/utils/utils.ts b/umbra-js/src/utils/utils.ts index ce48d88f8..9d13bbe86 100644 --- a/umbra-js/src/utils/utils.ts +++ b/umbra-js/src/utils/utils.ts @@ -10,12 +10,12 @@ import { ContractInterface, getAddress, isHexString, - JsonRpcProvider, keccak256, Overrides, resolveProperties, serialize as serializeTransaction, splitSignature, + StaticJsonRpcProvider, UnsignedTransaction, } from '../ethers'; import { Point, Signature, recoverPublicKey } from 'noble-secp256k1'; @@ -304,7 +304,8 @@ async function resolveEns(name: string, provider: EthersProvider) { // and overriding with a mainnet provider otherwise. This ensures ENS resolution is always done // against L1, as explained here: https://twitter.com/makoto_inoue/status/1453737962110275598 const { chainId } = await provider.getNetwork(); - if (chainId !== 1) provider = new JsonRpcProvider(`https://mainnet.infura.io/v3/${String(process.env.INFURA_ID)}`); + if (chainId !== 1) + provider = new StaticJsonRpcProvider(`https://mainnet.infura.io/v3/${String(process.env.INFURA_ID)}`); const address = await provider.resolveName(name); return address || null; } catch (e) { diff --git a/umbra-js/test/Umbra.test.ts b/umbra-js/test/Umbra.test.ts index 7d977cdbc..9415a897e 100644 --- a/umbra-js/test/Umbra.test.ts +++ b/umbra-js/test/Umbra.test.ts @@ -1,7 +1,7 @@ import { ethers } from 'hardhat'; import hardhatConfig from '../hardhat.config'; import { Umbra } from '../src/classes/Umbra'; -import { BigNumberish, BigNumber, JsonRpcProvider, Wallet } from '../src/ethers'; +import { BigNumberish, BigNumber, StaticJsonRpcProvider, Wallet } from '../src/ethers'; import { SignerWithAddress } from '@nomiclabs/hardhat-ethers/dist/src/signer-with-address'; import { HardhatNetworkHDAccountsUserConfig } from 'hardhat/src/types/config'; import { expect } from 'chai'; @@ -17,7 +17,7 @@ import { const { parseEther } = ethers.utils; const ethersProvider = ethers.provider; -const jsonRpcProvider = new JsonRpcProvider(hardhatConfig.networks?.hardhat?.forking?.url); +const jsonRpcProvider = new StaticJsonRpcProvider(hardhatConfig.networks?.hardhat?.forking?.url); const ETH_ADDRESS = '0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE'; const quantity = parseEther('5'); diff --git a/umbra-js/test/utils.test.ts b/umbra-js/test/utils.test.ts index 3a2280436..56187c275 100644 --- a/umbra-js/test/utils.test.ts +++ b/umbra-js/test/utils.test.ts @@ -166,19 +166,23 @@ describe('Utilities', () => { }); it('looks up transaction history on polygon', async () => { - const ethersProvider = new ethers.providers.JsonRpcProvider('https://polygon-rpc.com') as EthersProvider; + const ethersProvider = new ethers.providers.StaticJsonRpcProvider('https://polygon-rpc.com') as EthersProvider; const txHash = await utils.getSentTransaction(address, ethersProvider); expect(txHash).to.have.lengthOf(66); }); it('looks up transaction history on optimism', async () => { - const ethersProvider = new ethers.providers.JsonRpcProvider('https://mainnet.optimism.io') as EthersProvider; + const ethersProvider = new ethers.providers.StaticJsonRpcProvider( + 'https://mainnet.optimism.io' + ) as EthersProvider; const txHash = await utils.getSentTransaction(address, ethersProvider); expect(txHash).to.have.lengthOf(66); }); it('looks up transaction history on arbitrum one', async () => { - const ethersProvider = new ethers.providers.JsonRpcProvider('https://arb1.arbitrum.io/rpc') as EthersProvider; + const ethersProvider = new ethers.providers.StaticJsonRpcProvider( + 'https://arb1.arbitrum.io/rpc' + ) as EthersProvider; const txHash = await utils.getSentTransaction(address, ethersProvider); expect(txHash).to.have.lengthOf(66); });