Socket
Socket
Sign inDemoInstall

@chainlink/evm-gauntlet

Package Overview
Dependencies
Maintainers
5
Versions
126
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@chainlink/evm-gauntlet - npm Package Compare versions

Comparing version 0.0.0-develop-20231212160120 to 0.0.0-develop-20240124203548

2

dist/core/commands/base/inspectionCommand.d.ts

@@ -28,3 +28,3 @@ import { CommandCtor } from '.';

ux: CommandUX;
queries: string[];
queries: string[] | ((input: UI) => string[]);
makeUserInput?: (flags: any, args: string[]) => Promise<InspectUserInput<UI, CompareInput>>;

@@ -31,0 +31,0 @@ /**

@@ -60,3 +60,4 @@ "use strict";

this.execute = async () => {
const results = await this.runQueries(config.queries, this.input.contract);
const queries = typeof config.queries === 'function' ? config.queries(this.input.user.input) : config.queries;
const results = await this.runQueries(queries, this.input.contract);
const data = await config.makeComparisionData(this.provider)(results, this.input.user.input, this.contractAddress, this.contract);

@@ -106,2 +107,2 @@ const inspectionResults = config.inspect ? config.inspect(this.input.user, data) : [];

exports.makeInspectionCommand = makeInspectionCommand;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inspectionCommand.js","sourceRoot":"","sources":["../../../../src/core/commands/base/inspectionCommand.ts"],"names":[],"mappings":"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","sourcesContent":["import BaseCommand from '@chainlink/gauntlet-core/dist/commands/internal/base'\nimport { CommandCtor, Input } from '.'\nimport { InspectionDependencies } from '../../dependencies'\nimport { IProvider } from '../../provider'\nimport { CommandUX, makeCommandId, Validation } from './command'\nimport { ContractFactory } from 'ethers'\nimport { callWithExpBackoff } from '../../../utils'\n\nexport interface InspectionContext<Wallet, Provider, Contract, Message, Transaction> {\n  id: string\n  contractAddress: string\n  provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n  flags: any\n  contract: Contract\n}\n\nexport interface InspectUserInput<UI, CompareInput> {\n  input: UI\n  toCompare?: CompareInput\n}\n\n// TODO: Temporary inspection report.\nexport interface InspectionReport<QueryResult> {\n  data: QueryResult\n  contract: string\n  inspection: {\n    id: string\n    message: string\n    resultType: 'success' | 'failed'\n  }[]\n}\n\nexport interface InspectCommandConfig<\n  UI,\n  CI,\n  CompareInput,\n  QueryResult,\n  Provider,\n  Contract,\n  Message,\n  Transaction,\n  Wallet\n> {\n  ux: CommandUX\n  // List of query functions to call\n  queries: string[]\n  makeUserInput?: (flags: any, args: string[]) => Promise<InspectUserInput<UI, CompareInput>>\n  /**\n   * Given the user input, translate to every contract input required for each query\n   */\n  makeContractInput?: (userInput: UI) => Promise<CI>\n  /**\n   * After doing every query, convert the results into the type we want (QueryResult) and if toCompare is given, match result into it\n   */\n  makeComparisionData: (\n    provider: IProvider<Provider, Contract, Message, Transaction, Wallet>,\n  ) => (\n    results: any[],\n    input: UI,\n    contractAddress: string,\n    contract?: ContractFactory,\n  ) => Promise<{\n    toCompare: CompareInput\n    result: QueryResult\n  }>\n  inspect?: (\n    expected: InspectUserInput<UI, CompareInput>,\n    data: {\n      toCompare: CompareInput\n      result: QueryResult\n    },\n  ) => {\n    id: string\n    message: string\n    resultType: 'success' | 'failed'\n  }[]\n  loadContract: () => Contract\n  loadDefaultContractAddress?: (env: any) => string\n  validations?: Validation<UI, InspectionContext<Wallet, Provider, Contract, Message, Transaction>>[]\n}\n\nexport interface InspectCommandInstance<QueryResult> {\n  execute: () => Promise<{ data: InspectionReport<QueryResult>; responses: any[] }>\n}\n\ntype Fetch<Contract, Provider> = (\n  contract: Contract,\n  provider: Provider,\n  contractAddress: string,\n  fn: string,\n  input: any,\n) => any\n\nexport const makeInspectionCommand = <UI, CI, CompareInput, QueryResult, Contract, Provider>(\n  fetch: Fetch<Contract, Provider>,\n) => <Message, Transaction, Wallet>(\n  config: InspectCommandConfig<UI, CI, CompareInput, QueryResult, Provider, Contract, Message, Transaction, Wallet>,\n) => (deps: InspectionDependencies<Provider, Contract, Message, Transaction, Wallet>) => {\n  const id = makeCommandId(config.ux.category, config.ux.function, config.ux.suffixes)\n\n  const command: CommandCtor<InspectCommandInstance<QueryResult>> = class InspectionCommand\n    extends BaseCommand\n    implements InspectCommandInstance<QueryResult> {\n    // Props\n    provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n    contractAddress: string\n\n    input: Input<InspectUserInput<UI, CompareInput>, CI>\n\n    contract: Contract\n\n    inspectionContext: InspectionContext<Wallet, Provider, Contract, Message, Transaction>\n\n    // UX\n    static id = id\n    static category = config.ux.category\n    static examples = config.ux.examples\n\n    static create = async (flags, args) => {\n      const c = new InspectionCommand(flags, args)\n\n      const env = deps.makeEnv(flags)\n\n      c.provider = deps.makeProvider(env.providerUrl)\n      c.contractAddress =\n        args[0] || (config.loadDefaultContractAddress ? config.loadDefaultContractAddress(env) : undefined)\n\n      c.input = await c.buildCommandInput(flags, args, env)\n      c.contract = config.loadContract()\n      c.inspectionContext = {\n        provider: c.provider,\n        id: makeCommandId(config.ux.category, config.ux.function, config.ux.suffixes),\n        contractAddress: c.contractAddress,\n        flags: flags,\n        contract: c.contract,\n      }\n\n      return c\n    }\n\n    runValidations = async (\n      validations: Validation<UI, InspectionContext<Wallet, Provider, Contract, Message, Transaction>>[],\n      input: UI,\n    ) => {\n      const result = await Promise.all(validations.map((validation) => validation(input, this.inspectionContext)))\n      return result\n    }\n\n    buildCommandInput = async (flags, args, env): Promise<Input<InspectUserInput<UI, CompareInput>, CI>> => {\n      // If an external input generator is defined has preference. If it fails to generate the input, falls back to default method\n      // We input all flags and env into overrides so that the makeCommandInput fn can use them as needed\n      let userInput =\n        deps.makeCommandInput &&\n        ({\n          input: await deps.makeCommandInput<UI>(id, flags.network, this.contractAddress, {\n            ...flags,\n            ...env,\n          }),\n          toCompare: null,\n        } as InspectUserInput<UI, CompareInput>)\n\n      if (!userInput) {\n        userInput = await config.makeUserInput(flags, args)\n      }\n\n      // Validation\n      if (config.validations?.length > 0) {\n        await this.runValidations(config.validations, userInput.input)\n      }\n\n      const contractInput = config.makeContractInput && (await config.makeContractInput(userInput.input))\n\n      return {\n        user: userInput || {\n          input: null,\n          toCompare: null,\n        },\n        contract: contractInput || ([] as any),\n      }\n    }\n\n    runQueries = async (functions: string[], contractInputs: CI | CI[]): Promise<any[]> => {\n      const inputs = Array.isArray(contractInputs) ? contractInputs : [contractInputs]\n      // TODO: This should handle same function with different inputs\n      return await Promise.all(\n        functions.map(async (func, i) => {\n          deps.logger.loading(`Fetching ${func} of contract ${this.contractAddress}...`)\n          try {\n            return await callWithExpBackoff(\n              () => fetch(this.contract, this.provider.provider, this.contractAddress, func, inputs[i] || []),\n              1,\n              5,\n            )\n          } catch (e) {\n            // Don't fail out if one query fails\n            return '!!ERROR!!'\n          }\n        }),\n      )\n    }\n\n    execute = async () => {\n      const results = await this.runQueries(config.queries, this.input.contract)\n      const data = await config.makeComparisionData(this.provider)(\n        results,\n        this.input.user.input,\n        this.contractAddress,\n        (this.contract as unknown) as ContractFactory,\n      )\n      const inspectionResults = config.inspect ? config.inspect(this.input.user, data) : []\n\n      deps.logger.info('Inspection Results:')\n      deps.logger.log(data.result)\n      // TODO: Gauntlet core forces us to use Result type for every command. Update to choose the result if using Base Command\n      const report = {\n        data: {\n          data: data.result,\n          contract: this.contractAddress,\n          inspection: inspectionResults,\n        },\n        responses: [],\n      }\n\n      if (deps.afterExecuteExternal) await deps.afterExecuteExternal(id, this.flags.network, report)\n\n      return report\n    }\n  }\n\n  return command\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inspectionCommand.js","sourceRoot":"","sources":["../../../../src/core/commands/base/inspectionCommand.ts"],"names":[],"mappings":"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","sourcesContent":["import BaseCommand from '@chainlink/gauntlet-core/dist/commands/internal/base'\nimport { CommandCtor, Input } from '.'\nimport { InspectionDependencies } from '../../dependencies'\nimport { IProvider } from '../../provider'\nimport { CommandUX, makeCommandId, Validation } from './command'\nimport { ContractFactory } from 'ethers'\nimport { callWithExpBackoff } from '../../../utils'\n\nexport interface InspectionContext<Wallet, Provider, Contract, Message, Transaction> {\n  id: string\n  contractAddress: string\n  provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n  flags: any\n  contract: Contract\n}\n\nexport interface InspectUserInput<UI, CompareInput> {\n  input: UI\n  toCompare?: CompareInput\n}\n\n// TODO: Temporary inspection report.\nexport interface InspectionReport<QueryResult> {\n  data: QueryResult\n  contract: string\n  inspection: {\n    id: string\n    message: string\n    resultType: 'success' | 'failed'\n  }[]\n}\n\nexport interface InspectCommandConfig<\n  UI,\n  CI,\n  CompareInput,\n  QueryResult,\n  Provider,\n  Contract,\n  Message,\n  Transaction,\n  Wallet\n> {\n  ux: CommandUX\n  // List of query functions to call\n  queries: string[] | ((input: UI) => string[])\n  makeUserInput?: (flags: any, args: string[]) => Promise<InspectUserInput<UI, CompareInput>>\n  /**\n   * Given the user input, translate to every contract input required for each query\n   */\n  makeContractInput?: (userInput: UI) => Promise<CI>\n  /**\n   * After doing every query, convert the results into the type we want (QueryResult) and if toCompare is given, match result into it\n   */\n  makeComparisionData: (\n    provider: IProvider<Provider, Contract, Message, Transaction, Wallet>,\n  ) => (\n    results: any[],\n    input: UI,\n    contractAddress: string,\n    contract?: ContractFactory,\n  ) => Promise<{\n    toCompare: CompareInput\n    result: QueryResult\n  }>\n  inspect?: (\n    expected: InspectUserInput<UI, CompareInput>,\n    data: {\n      toCompare: CompareInput\n      result: QueryResult\n    },\n  ) => {\n    id: string\n    message: string\n    resultType: 'success' | 'failed'\n  }[]\n  loadContract: () => Contract\n  loadDefaultContractAddress?: (env: any) => string\n  validations?: Validation<UI, InspectionContext<Wallet, Provider, Contract, Message, Transaction>>[]\n}\n\nexport interface InspectCommandInstance<QueryResult> {\n  execute: () => Promise<{ data: InspectionReport<QueryResult>; responses: any[] }>\n}\n\ntype Fetch<Contract, Provider> = (\n  contract: Contract,\n  provider: Provider,\n  contractAddress: string,\n  fn: string,\n  input: any,\n) => any\n\nexport const makeInspectionCommand = <UI, CI, CompareInput, QueryResult, Contract, Provider>(\n  fetch: Fetch<Contract, Provider>,\n) => <Message, Transaction, Wallet>(\n  config: InspectCommandConfig<UI, CI, CompareInput, QueryResult, Provider, Contract, Message, Transaction, Wallet>,\n) => (deps: InspectionDependencies<Provider, Contract, Message, Transaction, Wallet>) => {\n  const id = makeCommandId(config.ux.category, config.ux.function, config.ux.suffixes)\n\n  const command: CommandCtor<InspectCommandInstance<QueryResult>> = class InspectionCommand\n    extends BaseCommand\n    implements InspectCommandInstance<QueryResult> {\n    // Props\n    provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n    contractAddress: string\n\n    input: Input<InspectUserInput<UI, CompareInput>, CI>\n\n    contract: Contract\n\n    inspectionContext: InspectionContext<Wallet, Provider, Contract, Message, Transaction>\n\n    // UX\n    static id = id\n    static category = config.ux.category\n    static examples = config.ux.examples\n\n    static create = async (flags, args) => {\n      const c = new InspectionCommand(flags, args)\n\n      const env = deps.makeEnv(flags)\n\n      c.provider = deps.makeProvider(env.providerUrl)\n      c.contractAddress =\n        args[0] || (config.loadDefaultContractAddress ? config.loadDefaultContractAddress(env) : undefined)\n\n      c.input = await c.buildCommandInput(flags, args, env)\n      c.contract = config.loadContract()\n      c.inspectionContext = {\n        provider: c.provider,\n        id: makeCommandId(config.ux.category, config.ux.function, config.ux.suffixes),\n        contractAddress: c.contractAddress,\n        flags: flags,\n        contract: c.contract,\n      }\n\n      return c\n    }\n\n    runValidations = async (\n      validations: Validation<UI, InspectionContext<Wallet, Provider, Contract, Message, Transaction>>[],\n      input: UI,\n    ) => {\n      const result = await Promise.all(validations.map((validation) => validation(input, this.inspectionContext)))\n      return result\n    }\n\n    buildCommandInput = async (flags, args, env): Promise<Input<InspectUserInput<UI, CompareInput>, CI>> => {\n      // If an external input generator is defined has preference. If it fails to generate the input, falls back to default method\n      // We input all flags and env into overrides so that the makeCommandInput fn can use them as needed\n      let userInput =\n        deps.makeCommandInput &&\n        ({\n          input: await deps.makeCommandInput<UI>(id, flags.network, this.contractAddress, {\n            ...flags,\n            ...env,\n          }),\n          toCompare: null,\n        } as InspectUserInput<UI, CompareInput>)\n\n      if (!userInput) {\n        userInput = await config.makeUserInput(flags, args)\n      }\n\n      // Validation\n      if (config.validations?.length > 0) {\n        await this.runValidations(config.validations, userInput.input)\n      }\n\n      const contractInput = config.makeContractInput && (await config.makeContractInput(userInput.input))\n\n      return {\n        user: userInput || {\n          input: null,\n          toCompare: null,\n        },\n        contract: contractInput || ([] as any),\n      }\n    }\n\n    runQueries = async (functions: string[], contractInputs: CI | CI[]): Promise<any[]> => {\n      const inputs = Array.isArray(contractInputs) ? contractInputs : [contractInputs]\n      // TODO: This should handle same function with different inputs\n      return await Promise.all(\n        functions.map(async (func, i) => {\n          deps.logger.loading(`Fetching ${func} of contract ${this.contractAddress}...`)\n          try {\n            return await callWithExpBackoff(\n              () => fetch(this.contract, this.provider.provider, this.contractAddress, func, inputs[i] || []),\n              1,\n              5,\n            )\n          } catch (e) {\n            // Don't fail out if one query fails\n            return '!!ERROR!!'\n          }\n        }),\n      )\n    }\n\n    execute = async () => {\n      const queries = typeof config.queries === 'function' ? config.queries(this.input.user.input) : config.queries\n      const results = await this.runQueries(queries, this.input.contract)\n      const data = await config.makeComparisionData(this.provider)(\n        results,\n        this.input.user.input,\n        this.contractAddress,\n        (this.contract as unknown) as ContractFactory,\n      )\n      const inspectionResults = config.inspect ? config.inspect(this.input.user, data) : []\n\n      deps.logger.info('Inspection Results:')\n      deps.logger.log(data.result)\n      // TODO: Gauntlet core forces us to use Result type for every command. Update to choose the result if using Base Command\n      const report = {\n        data: {\n          data: data.result,\n          contract: this.contractAddress,\n          inspection: inspectionResults,\n        },\n        responses: [],\n      }\n\n      if (deps.afterExecuteExternal) await deps.afterExecuteExternal(id, this.flags.network, report)\n\n      return report\n    }\n  }\n\n  return command\n}\n"]}

@@ -23,2 +23,3 @@ import { IProvider } from '../../core';

message: string;
result: string;
};

@@ -25,0 +26,0 @@ }

@@ -90,3 +90,3 @@ "use strict";

if (decodedError) {
throw new Error(`Transaction simulation failed with error: ${decodedError.name} with signature ${decodedError.sighash} and message \"${decodedError.message}\"`);
throw new Error(`Transaction simulation failed with error: ${decodedError.name} with signature ${decodedError.sighash} and message \"${decodedError.message}\" and result=\"${decodedError.result}\"`);
}

@@ -105,2 +105,3 @@ throw err;

message: parsedError.args.message,
result: JSON.parse(parsedError.sighash).result,
};

@@ -112,3 +113,4 @@ }

sighash: e.value,
message: undefined,
message: error.data && error.data.message ? error.data.message : 'Message not identified',
result: error.data && error.data.result ? error.data.result : 'Reason not identified',
};

@@ -125,2 +127,2 @@ }

exports.makeProvider = makeProvider;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/evm/provider/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { IProvider } from '../../core'\nimport {\n  Provider as EthersProvider,\n  TransactionResponse as Transaction,\n  TransactionRequest,\n} from '@ethersproject/abstract-provider'\nimport { ethers, BigNumber } from 'ethers'\nimport { ContractFactory } from '@ethersproject/contracts'\nimport { EVMTransaction } from '../transaction'\nimport { IWallet } from '../../core/wallet'\nimport { Wallet as EthersWallet } from '@ethersproject/wallet'\n\nexport type EVMProvider = IProvider<EthersProvider, ContractFactory, TransactionRequest, Transaction, EthersWallet>\n\nconst wrapResponse = (response: Transaction, address?: string): EVMTransaction => {\n  const evmResponse: EVMTransaction = {\n    hash: response.hash,\n    address: address || response.to,\n    wait: async () => {\n      try {\n        const receipt = await response.wait()\n        const success = receipt == null || receipt.status === 1\n        evmResponse.status = success ? 'ACCEPTED' : 'REJECTED'\n        if (!evmResponse.address) {\n          evmResponse.address = receipt.contractAddress\n        }\n        return { success: receipt == null || receipt.status === 1 }\n      } catch (e) {\n        evmResponse.status = 'REJECTED'\n        throw e\n      }\n    },\n    tx: response,\n    status: 'PENDING',\n  }\n  return evmResponse\n}\n\nclass Provider implements EVMProvider {\n  provider: EthersProvider\n\n  constructor(baseUrl: string) {\n    ethers.utils.Logger.setLogLevel(ethers.utils.Logger.levels.ERROR)\n    this.provider = new ethers.providers.JsonRpcProvider(baseUrl)\n  }\n\n  send = async (signedTx) => {\n    const tx = await this.provider.sendTransaction(signedTx)\n    return wrapResponse(tx)\n  }\n\n  deployContract = async (wallet: IWallet<EthersWallet>, contract: ContractFactory, input: any) => {\n    const txReq = await contract.getDeployTransaction(...input)\n    return await this.signAndSend(wallet, [txReq], contract)\n  }\n\n  sign = async (wallet: IWallet<EthersWallet>, calls: TransactionRequest[], contract: ContractFactory) => {\n    if (calls.length > 1) throw new Error('EVM does not support native batching')\n    const connectedWallet = await wallet.wallet.connect(this.provider)\n    try {\n      // delete gas price fields because they aren't needed for signing\n      delete calls[0].maxPriorityFeePerGas\n      delete calls[0].maxFeePerGas\n\n      const tx = await connectedWallet.signTransaction(calls[0])\n      return {\n        tx: tx,\n        message: calls[0],\n      }\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.error?.error?.error?.data)\n      if (decodedError) {\n        throw new Error(`Failed to sign and send, transaction reverted with data: ${JSON.stringify(decodedError)}`)\n      }\n      throw err\n    }\n  }\n\n  signAndSend = async (wallet: IWallet<EthersWallet>, calls: TransactionRequest[], contract: ContractFactory) => {\n    if (calls.length > 1) throw new Error('EVM does not support native batching')\n    const connectedWallet = await wallet.wallet.connect(this.provider)\n    try {\n      const tx = await connectedWallet.sendTransaction(calls[0])\n      return wrapResponse(tx, calls[0].to)\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.error?.error?.error?.data)\n      if (decodedError) {\n        throw new Error(`Failed to sign and send, transaction reverted with data: ${JSON.stringify(decodedError)}`)\n      }\n      throw err\n    }\n  }\n\n  simulate = async (\n    signer: string,\n    call: TransactionRequest,\n    contract: ContractFactory,\n    opts?: Record<string, any>,\n  ): Promise<string> => {\n    try {\n      const gasUsed = await this.provider.estimateGas({\n        to: call.to,\n        from: signer,\n        data: call.data,\n        value: BigNumber.from(call.value),\n      })\n      return gasUsed.toString()\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.error?.error)\n      if (decodedError) {\n        throw new Error(\n          `Transaction simulation failed with error: ${decodedError.name} with signature ${decodedError.sighash} and message \\\"${decodedError.message}\\\"`,\n        )\n      }\n      throw err\n    }\n  }\n\n  parseContractError = (contract: ContractFactory, error: any): { name: string; sighash: string; message: string } => {\n    if (!error) return\n    try {\n      const parsedError = contract.interface.parseError(error.data)\n      return {\n        name: parsedError.name,\n        sighash: parsedError.sighash,\n        message: parsedError.args.message,\n      }\n    } catch (e) {\n      return {\n        name: error.message ? error.message : 'Error not identified',\n        sighash: e.value,\n        message: undefined,\n      }\n    }\n  }\n}\n\nexport const makeProvider = (baseUrl: string) => {\n  return new Provider(baseUrl)\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/evm/provider/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { IProvider } from '../../core'\nimport {\n  Provider as EthersProvider,\n  TransactionResponse as Transaction,\n  TransactionRequest,\n} from '@ethersproject/abstract-provider'\nimport { ethers, BigNumber } from 'ethers'\nimport { ContractFactory } from '@ethersproject/contracts'\nimport { EVMTransaction } from '../transaction'\nimport { IWallet } from '../../core/wallet'\nimport { Wallet as EthersWallet } from '@ethersproject/wallet'\n\nexport type EVMProvider = IProvider<EthersProvider, ContractFactory, TransactionRequest, Transaction, EthersWallet>\n\nconst wrapResponse = (response: Transaction, address?: string): EVMTransaction => {\n  const evmResponse: EVMTransaction = {\n    hash: response.hash,\n    address: address || response.to,\n    wait: async () => {\n      try {\n        const receipt = await response.wait()\n        const success = receipt == null || receipt.status === 1\n        evmResponse.status = success ? 'ACCEPTED' : 'REJECTED'\n        if (!evmResponse.address) {\n          evmResponse.address = receipt.contractAddress\n        }\n        return { success: receipt == null || receipt.status === 1 }\n      } catch (e) {\n        evmResponse.status = 'REJECTED'\n        throw e\n      }\n    },\n    tx: response,\n    status: 'PENDING',\n  }\n  return evmResponse\n}\n\nclass Provider implements EVMProvider {\n  provider: EthersProvider\n\n  constructor(baseUrl: string) {\n    ethers.utils.Logger.setLogLevel(ethers.utils.Logger.levels.ERROR)\n    this.provider = new ethers.providers.JsonRpcProvider(baseUrl)\n  }\n\n  send = async (signedTx) => {\n    const tx = await this.provider.sendTransaction(signedTx)\n    return wrapResponse(tx)\n  }\n\n  deployContract = async (wallet: IWallet<EthersWallet>, contract: ContractFactory, input: any) => {\n    const txReq = await contract.getDeployTransaction(...input)\n    return await this.signAndSend(wallet, [txReq], contract)\n  }\n\n  sign = async (wallet: IWallet<EthersWallet>, calls: TransactionRequest[], contract: ContractFactory) => {\n    if (calls.length > 1) throw new Error('EVM does not support native batching')\n    const connectedWallet = await wallet.wallet.connect(this.provider)\n    try {\n      // delete gas price fields because they aren't needed for signing\n      delete calls[0].maxPriorityFeePerGas\n      delete calls[0].maxFeePerGas\n\n      const tx = await connectedWallet.signTransaction(calls[0])\n      return {\n        tx: tx,\n        message: calls[0],\n      }\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.error?.error?.error?.data)\n      if (decodedError) {\n        throw new Error(`Failed to sign and send, transaction reverted with data: ${JSON.stringify(decodedError)}`)\n      }\n      throw err\n    }\n  }\n\n  signAndSend = async (wallet: IWallet<EthersWallet>, calls: TransactionRequest[], contract: ContractFactory) => {\n    if (calls.length > 1) throw new Error('EVM does not support native batching')\n    const connectedWallet = await wallet.wallet.connect(this.provider)\n    try {\n      const tx = await connectedWallet.sendTransaction(calls[0])\n      return wrapResponse(tx, calls[0].to)\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.error?.error?.error?.data)\n      if (decodedError) {\n        throw new Error(`Failed to sign and send, transaction reverted with data: ${JSON.stringify(decodedError)}`)\n      }\n      throw err\n    }\n  }\n\n  simulate = async (\n    signer: string,\n    call: TransactionRequest,\n    contract: ContractFactory,\n    opts?: Record<string, any>,\n  ): Promise<string> => {\n    try {\n      const gasUsed = await this.provider.estimateGas({\n        to: call.to,\n        from: signer,\n        data: call.data,\n        value: BigNumber.from(call.value),\n      })\n      return gasUsed.toString()\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.error?.error)\n      if (decodedError) {\n        throw new Error(\n          `Transaction simulation failed with error: ${decodedError.name} with signature ${decodedError.sighash} and message \\\"${decodedError.message}\\\" and result=\\\"${decodedError.result}\\\"`,\n        )\n      }\n      throw err\n    }\n  }\n\n  parseContractError = (\n    contract: ContractFactory,\n    error: any,\n  ): { name: string; sighash: string; message: string; result: string } => {\n    if (!error) return\n    try {\n      const parsedError = contract.interface.parseError(error.data)\n      return {\n        name: parsedError.name,\n        sighash: parsedError.sighash,\n        message: parsedError.args.message,\n        result: JSON.parse(parsedError.sighash).result,\n      }\n    } catch (e) {\n      return {\n        name: error.message ? error.message : 'Error not identified',\n        sighash: e.value,\n        message: error.data && error.data.message ? error.data.message : 'Message not identified',\n        result: error.data && error.data.result ? error.data.result : 'Reason not identified',\n      }\n    }\n  }\n}\n\nexport const makeProvider = (baseUrl: string) => {\n  return new Provider(baseUrl)\n}\n"]}
{
"name": "@chainlink/evm-gauntlet",
"version": "0.0.0-develop-20231212160120",
"version": "0.0.0-develop-20240124203548",
"description": "Gauntlet EVM",

@@ -5,0 +5,0 @@ "keywords": [

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc