Socket
Socket
Sign inDemoInstall

@chainlink/evm-gauntlet

Package Overview
Dependencies
230
Maintainers
5
Versions
123
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 0.0.0-develop-20240409214435 to 0.0.0-develop-20240430133909

3

dist/core/commands/base/executeCommand.js

@@ -161,2 +161,3 @@ "use strict";

blockAgeLimitSeconds: env.blockAgeLimitSeconds,
timeoutSeconds: env.timeoutSeconds,
}, deps.logger)

@@ -206,2 +207,2 @@ : deps.makeProvider(env.providerUrl);

exports.makeExecuteCommand = makeExecuteCommand;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"executeCommand.js","sourceRoot":"","sources":["../../../../src/core/commands/base/executeCommand.ts"],"names":[],"mappings":"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","sourcesContent":["import { Result, WriteCommand } from '@chainlink/gauntlet-core'\nimport { CommandCtor } from '.'\nimport { Dependencies, BasicEnv } from '../../dependencies'\nimport { IProvider } from '../../provider'\nimport { TransactionResponse } from '../../transaction'\nimport { IWallet } from '../../wallet'\nimport { makeCommandId, Validation, Input } from './command'\nimport { printExecutionInputs } from '../../../utils'\nimport { ContractLoader, ExecuteCommandConfig, ExecuteCommandInstance } from './types'\n\nexport interface ExecutionContext<Wallet, Provider, Contract, Message, Transaction> {\n  id: string\n  contractAddress: string\n  wallet: IWallet<Wallet>\n  provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n  flags: any\n  env: any\n  contract: Contract\n}\n\nexport type CommandInfo = {\n  contractName: string\n  action: string\n  inputs: Record<string, any>\n}\n\ntype MakeMessage<CI, Contract, Provider, Message> = (\n  contract: Contract,\n  provider: Provider,\n  input: CI,\n  action: string,\n  contractAddress: string,\n  isDeployment?: boolean,\n  opts?: Record<string, any>,\n) => (opts?: Record<string, any>) => Promise<Message[]>\n\ntype GetFunctionInputSchema<CI, Contract> = (\n  contract: Contract,\n  contractName: string,\n  functionName: string,\n  input: CI,\n) => () => CommandInfo\n\nexport const makeExecuteCommand = <UI, CI, Message, Contract, Provider, Transaction, Wallet>(\n  registerMakeMessage: MakeMessage<CI, Contract, Provider, Message>,\n  getFunctionInputSchema: GetFunctionInputSchema<CI, Contract>,\n  makeDynamicContractLoader: (contractLoaders: ContractLoader<Contract>[]) => (userInput?: UI) => Contract,\n) => (\n  config: ExecuteCommandConfig<\n    UI,\n    CI,\n    Transaction,\n    ExecutionContext<Wallet, Provider, Contract, Message, Transaction>,\n    Contract\n  >,\n) => (deps: Dependencies<Provider, Contract, Message, Transaction, Wallet, BasicEnv>) => {\n  const id = makeCommandId(config.category, config.action, config.suffixes)\n\n  const command: CommandCtor<ExecuteCommandInstance<\n    UI,\n    CI,\n    Provider,\n    Contract,\n    Message,\n    Transaction,\n    Wallet,\n    ExecutionContext<Wallet, Provider, Contract, Message, Transaction>\n  >> = class ExecuteCommand extends WriteCommand<TransactionResponse<Transaction>> {\n    [key: string]: any\n\n    provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n    wallet: IWallet<Wallet>\n    executionContext: ExecutionContext<Wallet, Provider, Contract, Message, Transaction>\n    contractAddress: string\n    contractFunction: string\n    account: string\n    contract: Contract\n    skipSimulate: boolean\n\n    input: Input<UI, CI>\n\n    makeMessage: (opts?: any) => Promise<Message[]>\n    getCommandInfo: () => CommandInfo\n\n    beforeExecute: () => Promise<void>\n    afterExecute: (response: Result<TransactionResponse<Transaction>>) => Promise<any>\n    afterExport: (response: Result<null>) => Promise<any>\n\n    constructor(flags, args) {\n      super(flags, args)\n    }\n\n    static id = id\n    static category = config.category\n    static examples = config.ux.examples\n\n    static create = async (flags, args) => {\n      const c = new ExecuteCommand(flags, args)\n\n      const env = deps.makeEnv(flags)\n\n      if (!!deps.makeMultiNodeProvider && env.multiNodeEnabled) {\n        deps.logger.info(\n          `Using multi-node provider with exponential backoff and retries enabled: urls=${JSON.stringify(\n            [env.providerUrl, ...(env.fallbackUrls || [])],\n            null,\n            '\\t',\n          )}`,\n        )\n      } else {\n        deps.logger.info(\n          `Using single-node provider with exponential backoff and retries disabled: url=${env.providerUrl}`,\n        )\n      }\n      c.provider =\n        !!deps.makeMultiNodeProvider && env.multiNodeEnabled\n          ? await deps.makeMultiNodeProvider(\n              {\n                urls: [env.providerUrl, ...(env.fallbackUrls || [])],\n                providerOpts: {\n                  batchMaxCount: env.maxRpcCallsPerBatch,\n                },\n                initialWaitSeconds: env.initialWaitSeconds,\n                maxRounds: env.maxRounds,\n                blockAgeLimitSeconds: env.blockAgeLimitSeconds,\n              },\n              deps.logger,\n            )\n          : deps.makeProvider(env.providerUrl)\n      c.wallet = await deps.makeWallet(env, flags)\n      c.contractAddress =\n        args[0] || (config.loadDefaultContractAddress ? config.loadDefaultContractAddress(env) : undefined)\n      c.contract = config.loadContract ? config.loadContract() : undefined\n      c.executionContext = {\n        provider: c.provider,\n        wallet: c.wallet,\n        id: makeCommandId(config.category, config.action, config.suffixes),\n        contractAddress: c.contractAddress,\n        flags,\n        env,\n        contract: c.contract,\n      }\n      c.logger = deps.logger\n      c.input = await c.buildCommandInput(flags, args, env)\n      c.skipSimulate = env.skipSimulate || false\n\n      // if there's no contract (`loadContract()`) configured, try to get\n      // a contract loader dynamically, it's used for abstract command.\n      if (!c.contract) {\n        const dynamicContractLoader = makeDynamicContractLoader(deps.contractList)\n        c.contract = dynamicContractLoader(c.input.user)\n        c.executionContext.contract = c.contract\n      }\n\n      // For abstract commands, we want to check for function value on the user input\n      c.contractFunction = (c.input.user as any).function || config.internalFunction || config.action\n      c.makeMessage = registerMakeMessage(\n        c.contract,\n        c.provider.provider,\n        c.input.contract,\n        c.contractFunction,\n        c.contractAddress,\n        c.contractFunction === 'deploy',\n        flags,\n      )\n      c.getCommandInfo = getFunctionInputSchema(c.contract, this.category, c.contractFunction, c.input.contract)\n\n      c.beforeExecute = config.hooks?.beforeExecute\n        ? config.hooks.beforeExecute(c.executionContext, c.input, { logger: deps.logger, prompt: deps.prompt })\n        : c.defaultBeforeExecute()\n\n      c.afterExecute = config.hooks?.afterExecute\n        ? config.hooks.afterExecute(c.executionContext, c.input, { logger: deps.logger, prompt: deps.prompt })\n        : c.defaultAfterExecute()\n\n      c.afterExport = config.hooks?.afterExport\n        ? config.hooks.afterExport(c.executionContext, c.input, { logger: deps.logger, prompt: deps.prompt })\n        : c.defaultAfterExport()\n\n      return c\n    }\n\n    highlightText = (message: string): string => deps.logger.style(message, 'blue')\n\n    defaultBeforeExecute = () => async () => {}\n\n    defaultAfterExecute = () => async () => {}\n\n    defaultAfterExport = () => async () => {}\n\n    runValidations = async (\n      validations: Validation<UI, ExecutionContext<Wallet, Provider, Contract, Message, Transaction>>[],\n      input: UI,\n    ) => {\n      const result = await Promise.all(validations.map((validation) => validation(input, this.executionContext)))\n      return result\n    }\n\n    buildCommandInput = async (flags, args, env): Promise<Input<UI, 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        (await deps.makeCommandInput<UI>(id, flags.network, this.contractAddress, { ...flags, ...env }))\n      if (!userInput) {\n        userInput = await config.makeUserInput(flags, args, env)\n      }\n\n      // Validation\n      if (config.validations.length > 0) {\n        await this.runValidations(config.validations, userInput)\n      }\n\n      const contractInput = await config.makeContractInput(userInput, this.executionContext, deps)\n      return {\n        user: userInput,\n        contract: contractInput,\n      }\n    }\n\n    deployContract = async (): Promise<TransactionResponse<Transaction>> => {\n      await deps.prompt('Continue?')\n      deps.logger.loading(`Sending transaction...`)\n\n      const tx = await this.provider.deployContract(this.wallet, this.contract, this.input.contract, false)\n      deps.logger.loading(`Waiting for tx confirmation at ${tx.hash}...`)\n      const response = await tx.wait()\n      if (!response.success) {\n        deps.logger.error(`Contract was not deployed: ${tx.errorMessage}`)\n        return tx\n      }\n      deps.logger.success(`Contract deployed on ${tx.hash} with address ${tx.address}`)\n      return tx\n    }\n\n    executeWithSigner = async (): Promise<TransactionResponse<Transaction>> => {\n      const messages = await this.makeMessage()\n      await deps.prompt(`Continue?`)\n      deps.logger.loading(`Signing and sending transaction...`)\n      const tx = await this.provider.signAndSend(this.wallet, messages, this.contract)\n      deps.logger.loading(`Waiting for tx confirmation at ${tx.hash}...`)\n      const response = await tx.wait()\n      if (!response.success) {\n        deps.logger.error(`Tx was not successful: ${tx.errorMessage}`)\n        return tx\n      }\n      deps.logger.success(`Tx executed at ${tx.hash}`)\n      return tx\n    }\n\n    simulate = async (signer: string): Promise<string[]> => {\n      const msgs = await this.makeMessage({ omitGasData: true })\n      const result = await Promise.all(msgs.map((msg) => this.provider.simulate(signer, msg, this.contract)))\n      return result\n    }\n\n    execute = async (): Promise<Result<TransactionResponse<Transaction>>> => {\n      const info = this.getCommandInfo()\n      if (config.action !== 'deploy') {\n        deps.logger.info(\n          `About to execute ${info.contractName}(${this.contractAddress}).${info.action}(\\n${printExecutionInputs(\n            info.inputs,\n          )})`,\n        )\n      } else {\n        deps.logger.info(`About to deploy a new ${this.highlightText(config.category)} contract`)\n      }\n\n      await this.beforeExecute()\n\n      const messages = await this.makeMessage()\n\n      // If the user decides to export the transaction data, we can generate and return the\n      // transaction information without signing and sending\n      if (this.flags.export) {\n        deps.logger.info('The export option was enabled. Transaction request information returned in report')\n        const result = { responses: [] }\n        const data = (await this.afterExport(result)) || {}\n        const report = { ...result, data: { messages, ...data } }\n        if (deps.afterExportExternal) await deps.afterExportExternal(id, this.executionContext.flags.network, report)\n        return report\n      }\n      const signer = await this.wallet.getPublicKey()\n      deps.logger.info(`Operator address: ${signer}`)\n\n      deps.logger.info(`Contract address: ${this.contractAddress}`)\n      deps.logger.loading('Simulating transactions...')\n\n      if (!this.skipSimulate) {\n        const simulation = await this.simulate(signer)\n\n        if (!!this.executionContext.flags.simulate) {\n          this.deps.logger.success(`Transaction successfully simulated`)\n          return {\n            responses: [],\n            data: {\n              simulation: simulation,\n            },\n          }\n        }\n      }\n\n      await deps.prompt('Continue?')\n      deps.logger.loading(`Sending transaction...`)\n\n      const tx = await this.provider.signAndSend(this.wallet, messages, this.contract)\n\n      deps.logger.loading(`Waiting for tx confirmation at ${tx.hash}...`)\n\n      const isDeployment = this.contractFunction === 'deploy'\n      const out = await tx.wait()\n      if (isDeployment && out.success) {\n        deps.logger.success(`Contract deployed on ${tx.hash} with address ${tx.address}`)\n      }\n\n      if (isDeployment && !out.success) {\n        // Don't think this case should ever occur\n        // the command should error out before entering this if statement\n        deps.logger.error(`Contract was not deployed: ${tx.errorMessage}`)\n      }\n      let result = {\n        responses: [\n          {\n            tx,\n            contract: tx.address,\n          },\n        ],\n      }\n      const data = await this.afterExecute(result)\n      deps.logger.success(`Execution finished at transaction: ${result.responses[0].tx.hash}`)\n\n      const report = !!data ? { ...result, data: { ...data } } : result\n      if (deps.afterExecuteExternal) await deps.afterExecuteExternal(id, this.executionContext.flags.network, report)\n\n      return report\n    }\n  }\n\n  return command\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"executeCommand.js","sourceRoot":"","sources":["../../../../src/core/commands/base/executeCommand.ts"],"names":[],"mappings":"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","sourcesContent":["import { Result, WriteCommand } from '@chainlink/gauntlet-core'\nimport { CommandCtor } from '.'\nimport { Dependencies, BasicEnv } from '../../dependencies'\nimport { IProvider } from '../../provider'\nimport { TransactionResponse } from '../../transaction'\nimport { IWallet } from '../../wallet'\nimport { makeCommandId, Validation, Input } from './command'\nimport { printExecutionInputs } from '../../../utils'\nimport { ContractLoader, ExecuteCommandConfig, ExecuteCommandInstance } from './types'\n\nexport interface ExecutionContext<Wallet, Provider, Contract, Message, Transaction> {\n  id: string\n  contractAddress: string\n  wallet: IWallet<Wallet>\n  provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n  flags: any\n  env: any\n  contract: Contract\n}\n\nexport type CommandInfo = {\n  contractName: string\n  action: string\n  inputs: Record<string, any>\n}\n\ntype MakeMessage<CI, Contract, Provider, Message> = (\n  contract: Contract,\n  provider: Provider,\n  input: CI,\n  action: string,\n  contractAddress: string,\n  isDeployment?: boolean,\n  opts?: Record<string, any>,\n) => (opts?: Record<string, any>) => Promise<Message[]>\n\ntype GetFunctionInputSchema<CI, Contract> = (\n  contract: Contract,\n  contractName: string,\n  functionName: string,\n  input: CI,\n) => () => CommandInfo\n\nexport const makeExecuteCommand = <UI, CI, Message, Contract, Provider, Transaction, Wallet>(\n  registerMakeMessage: MakeMessage<CI, Contract, Provider, Message>,\n  getFunctionInputSchema: GetFunctionInputSchema<CI, Contract>,\n  makeDynamicContractLoader: (contractLoaders: ContractLoader<Contract>[]) => (userInput?: UI) => Contract,\n) => (\n  config: ExecuteCommandConfig<\n    UI,\n    CI,\n    Transaction,\n    ExecutionContext<Wallet, Provider, Contract, Message, Transaction>,\n    Contract\n  >,\n) => (deps: Dependencies<Provider, Contract, Message, Transaction, Wallet, BasicEnv>) => {\n  const id = makeCommandId(config.category, config.action, config.suffixes)\n\n  const command: CommandCtor<ExecuteCommandInstance<\n    UI,\n    CI,\n    Provider,\n    Contract,\n    Message,\n    Transaction,\n    Wallet,\n    ExecutionContext<Wallet, Provider, Contract, Message, Transaction>\n  >> = class ExecuteCommand extends WriteCommand<TransactionResponse<Transaction>> {\n    [key: string]: any\n\n    provider: IProvider<Provider, Contract, Message, Transaction, Wallet>\n    wallet: IWallet<Wallet>\n    executionContext: ExecutionContext<Wallet, Provider, Contract, Message, Transaction>\n    contractAddress: string\n    contractFunction: string\n    account: string\n    contract: Contract\n    skipSimulate: boolean\n\n    input: Input<UI, CI>\n\n    makeMessage: (opts?: any) => Promise<Message[]>\n    getCommandInfo: () => CommandInfo\n\n    beforeExecute: () => Promise<void>\n    afterExecute: (response: Result<TransactionResponse<Transaction>>) => Promise<any>\n    afterExport: (response: Result<null>) => Promise<any>\n\n    constructor(flags, args) {\n      super(flags, args)\n    }\n\n    static id = id\n    static category = config.category\n    static examples = config.ux.examples\n\n    static create = async (flags, args) => {\n      const c = new ExecuteCommand(flags, args)\n\n      const env = deps.makeEnv(flags)\n\n      if (!!deps.makeMultiNodeProvider && env.multiNodeEnabled) {\n        deps.logger.info(\n          `Using multi-node provider with exponential backoff and retries enabled: urls=${JSON.stringify(\n            [env.providerUrl, ...(env.fallbackUrls || [])],\n            null,\n            '\\t',\n          )}`,\n        )\n      } else {\n        deps.logger.info(\n          `Using single-node provider with exponential backoff and retries disabled: url=${env.providerUrl}`,\n        )\n      }\n      c.provider =\n        !!deps.makeMultiNodeProvider && env.multiNodeEnabled\n          ? await deps.makeMultiNodeProvider(\n              {\n                urls: [env.providerUrl, ...(env.fallbackUrls || [])],\n                providerOpts: {\n                  batchMaxCount: env.maxRpcCallsPerBatch,\n                },\n                initialWaitSeconds: env.initialWaitSeconds,\n                maxRounds: env.maxRounds,\n                blockAgeLimitSeconds: env.blockAgeLimitSeconds,\n                timeoutSeconds: env.timeoutSeconds,\n              },\n              deps.logger,\n            )\n          : deps.makeProvider(env.providerUrl)\n      c.wallet = await deps.makeWallet(env, flags)\n      c.contractAddress =\n        args[0] || (config.loadDefaultContractAddress ? config.loadDefaultContractAddress(env) : undefined)\n      c.contract = config.loadContract ? config.loadContract() : undefined\n      c.executionContext = {\n        provider: c.provider,\n        wallet: c.wallet,\n        id: makeCommandId(config.category, config.action, config.suffixes),\n        contractAddress: c.contractAddress,\n        flags,\n        env,\n        contract: c.contract,\n      }\n      c.logger = deps.logger\n      c.input = await c.buildCommandInput(flags, args, env)\n      c.skipSimulate = env.skipSimulate || false\n\n      // if there's no contract (`loadContract()`) configured, try to get\n      // a contract loader dynamically, it's used for abstract command.\n      if (!c.contract) {\n        const dynamicContractLoader = makeDynamicContractLoader(deps.contractList)\n        c.contract = dynamicContractLoader(c.input.user)\n        c.executionContext.contract = c.contract\n      }\n\n      // For abstract commands, we want to check for function value on the user input\n      c.contractFunction = (c.input.user as any).function || config.internalFunction || config.action\n      c.makeMessage = registerMakeMessage(\n        c.contract,\n        c.provider.provider,\n        c.input.contract,\n        c.contractFunction,\n        c.contractAddress,\n        c.contractFunction === 'deploy',\n        flags,\n      )\n      c.getCommandInfo = getFunctionInputSchema(c.contract, this.category, c.contractFunction, c.input.contract)\n\n      c.beforeExecute = config.hooks?.beforeExecute\n        ? config.hooks.beforeExecute(c.executionContext, c.input, { logger: deps.logger, prompt: deps.prompt })\n        : c.defaultBeforeExecute()\n\n      c.afterExecute = config.hooks?.afterExecute\n        ? config.hooks.afterExecute(c.executionContext, c.input, { logger: deps.logger, prompt: deps.prompt })\n        : c.defaultAfterExecute()\n\n      c.afterExport = config.hooks?.afterExport\n        ? config.hooks.afterExport(c.executionContext, c.input, { logger: deps.logger, prompt: deps.prompt })\n        : c.defaultAfterExport()\n\n      return c\n    }\n\n    highlightText = (message: string): string => deps.logger.style(message, 'blue')\n\n    defaultBeforeExecute = () => async () => {}\n\n    defaultAfterExecute = () => async () => {}\n\n    defaultAfterExport = () => async () => {}\n\n    runValidations = async (\n      validations: Validation<UI, ExecutionContext<Wallet, Provider, Contract, Message, Transaction>>[],\n      input: UI,\n    ) => {\n      const result = await Promise.all(validations.map((validation) => validation(input, this.executionContext)))\n      return result\n    }\n\n    buildCommandInput = async (flags, args, env): Promise<Input<UI, 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        (await deps.makeCommandInput<UI>(id, flags.network, this.contractAddress, { ...flags, ...env }))\n      if (!userInput) {\n        userInput = await config.makeUserInput(flags, args, env)\n      }\n\n      // Validation\n      if (config.validations.length > 0) {\n        await this.runValidations(config.validations, userInput)\n      }\n\n      const contractInput = await config.makeContractInput(userInput, this.executionContext, deps)\n      return {\n        user: userInput,\n        contract: contractInput,\n      }\n    }\n\n    deployContract = async (): Promise<TransactionResponse<Transaction>> => {\n      await deps.prompt('Continue?')\n      deps.logger.loading(`Sending transaction...`)\n\n      const tx = await this.provider.deployContract(this.wallet, this.contract, this.input.contract, false)\n      deps.logger.loading(`Waiting for tx confirmation at ${tx.hash}...`)\n      const response = await tx.wait()\n      if (!response.success) {\n        deps.logger.error(`Contract was not deployed: ${tx.errorMessage}`)\n        return tx\n      }\n      deps.logger.success(`Contract deployed on ${tx.hash} with address ${tx.address}`)\n      return tx\n    }\n\n    executeWithSigner = async (): Promise<TransactionResponse<Transaction>> => {\n      const messages = await this.makeMessage()\n      await deps.prompt(`Continue?`)\n      deps.logger.loading(`Signing and sending transaction...`)\n      const tx = await this.provider.signAndSend(this.wallet, messages, this.contract)\n      deps.logger.loading(`Waiting for tx confirmation at ${tx.hash}...`)\n      const response = await tx.wait()\n      if (!response.success) {\n        deps.logger.error(`Tx was not successful: ${tx.errorMessage}`)\n        return tx\n      }\n      deps.logger.success(`Tx executed at ${tx.hash}`)\n      return tx\n    }\n\n    simulate = async (signer: string): Promise<string[]> => {\n      const msgs = await this.makeMessage({ omitGasData: true })\n      const result = await Promise.all(msgs.map((msg) => this.provider.simulate(signer, msg, this.contract)))\n      return result\n    }\n\n    execute = async (): Promise<Result<TransactionResponse<Transaction>>> => {\n      const info = this.getCommandInfo()\n      if (config.action !== 'deploy') {\n        deps.logger.info(\n          `About to execute ${info.contractName}(${this.contractAddress}).${info.action}(\\n${printExecutionInputs(\n            info.inputs,\n          )})`,\n        )\n      } else {\n        deps.logger.info(`About to deploy a new ${this.highlightText(config.category)} contract`)\n      }\n\n      await this.beforeExecute()\n\n      const messages = await this.makeMessage()\n\n      // If the user decides to export the transaction data, we can generate and return the\n      // transaction information without signing and sending\n      if (this.flags.export) {\n        deps.logger.info('The export option was enabled. Transaction request information returned in report')\n        const result = { responses: [] }\n        const data = (await this.afterExport(result)) || {}\n        const report = { ...result, data: { messages, ...data } }\n        if (deps.afterExportExternal) await deps.afterExportExternal(id, this.executionContext.flags.network, report)\n        return report\n      }\n      const signer = await this.wallet.getPublicKey()\n      deps.logger.info(`Operator address: ${signer}`)\n\n      deps.logger.info(`Contract address: ${this.contractAddress}`)\n      deps.logger.loading('Simulating transactions...')\n\n      if (!this.skipSimulate) {\n        const simulation = await this.simulate(signer)\n\n        if (!!this.executionContext.flags.simulate) {\n          this.deps.logger.success(`Transaction successfully simulated`)\n          return {\n            responses: [],\n            data: {\n              simulation: simulation,\n            },\n          }\n        }\n      }\n\n      await deps.prompt('Continue?')\n      deps.logger.loading(`Sending transaction...`)\n\n      const tx = await this.provider.signAndSend(this.wallet, messages, this.contract)\n\n      deps.logger.loading(`Waiting for tx confirmation at ${tx.hash}...`)\n\n      const isDeployment = this.contractFunction === 'deploy'\n      const out = await tx.wait()\n      if (isDeployment && out.success) {\n        deps.logger.success(`Contract deployed on ${tx.hash} with address ${tx.address}`)\n      }\n\n      if (isDeployment && !out.success) {\n        // Don't think this case should ever occur\n        // the command should error out before entering this if statement\n        deps.logger.error(`Contract was not deployed: ${tx.errorMessage}`)\n      }\n      let result = {\n        responses: [\n          {\n            tx,\n            contract: tx.address,\n          },\n        ],\n      }\n      const data = await this.afterExecute(result)\n      deps.logger.success(`Execution finished at transaction: ${result.responses[0].tx.hash}`)\n\n      const report = !!data ? { ...result, data: { ...data } } : result\n      if (deps.afterExecuteExternal) await deps.afterExecuteExternal(id, this.executionContext.flags.network, report)\n\n      return report\n    }\n  }\n\n  return command\n}\n"]}

@@ -96,2 +96,3 @@ "use strict";

blockAgeLimitSeconds: env.blockAgeLimitSeconds,
timeoutSeconds: env.timeoutSeconds,
}, deps.logger)

@@ -117,2 +118,2 @@ : deps.makeProvider(env.providerUrl);

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'\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  env: 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    context?: InspectionContext<Wallet, Provider, Contract, Message, Transaction>,\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  fns: string[],\n  inputs: 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      if (!!deps.makeMultiNodeProvider && env.multiNodeEnabled) {\n        deps.logger.info(\n          `Using multi-node provider with exponential backoff and retries enabled: urls=${JSON.stringify(\n            [env.providerUrl, ...(env.fallbackUrls || [])],\n            null,\n            '\\t',\n          )}`,\n        )\n      } else {\n        deps.logger.info(\n          `Using single-node provider with exponential backoff and retries disabled: url=${env.providerUrl}`,\n        )\n      }\n      c.provider =\n        !!deps.makeMultiNodeProvider && env.multiNodeEnabled\n          ? await deps.makeMultiNodeProvider(\n              {\n                urls: [env.providerUrl, ...(env.fallbackUrls || [])],\n                providerOpts: {\n                  batchMaxCount: env.maxRpcCallsPerBatch,\n                },\n                initialWaitSeconds: env.initialWaitSeconds,\n                maxRounds: env.maxRounds,\n                blockAgeLimitSeconds: env.blockAgeLimitSeconds,\n              },\n              deps.logger,\n            )\n          : 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,\n        env,\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      const inputsForFns = functions.map((_, i) => inputs[i] || [])\n      functions.map((func) => deps.logger.loading(`Fetching ${func} of contract ${this.contractAddress}...`))\n      // TODO: This should handle same function with different inputs\n      return await fetch(this.contract, this.provider.provider, this.contractAddress, functions, inputsForFns)\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, this.inspectionContext)(\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'\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  env: 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    context?: InspectionContext<Wallet, Provider, Contract, Message, Transaction>,\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  fns: string[],\n  inputs: 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      if (!!deps.makeMultiNodeProvider && env.multiNodeEnabled) {\n        deps.logger.info(\n          `Using multi-node provider with exponential backoff and retries enabled: urls=${JSON.stringify(\n            [env.providerUrl, ...(env.fallbackUrls || [])],\n            null,\n            '\\t',\n          )}`,\n        )\n      } else {\n        deps.logger.info(\n          `Using single-node provider with exponential backoff and retries disabled: url=${env.providerUrl}`,\n        )\n      }\n      c.provider =\n        !!deps.makeMultiNodeProvider && env.multiNodeEnabled\n          ? await deps.makeMultiNodeProvider(\n              {\n                urls: [env.providerUrl, ...(env.fallbackUrls || [])],\n                providerOpts: {\n                  batchMaxCount: env.maxRpcCallsPerBatch,\n                },\n                initialWaitSeconds: env.initialWaitSeconds,\n                maxRounds: env.maxRounds,\n                blockAgeLimitSeconds: env.blockAgeLimitSeconds,\n                timeoutSeconds: env.timeoutSeconds,\n              },\n              deps.logger,\n            )\n          : 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,\n        env,\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      const inputsForFns = functions.map((_, i) => inputs[i] || [])\n      functions.map((func) => deps.logger.loading(`Fetching ${func} of contract ${this.contractAddress}...`))\n      // TODO: This should handle same function with different inputs\n      return await fetch(this.contract, this.provider.provider, this.contractAddress, functions, inputsForFns)\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, this.inspectionContext)(\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"]}

@@ -15,2 +15,3 @@ import { Result } from '@chainlink/gauntlet-core';

multiNodeEnabled?: boolean;
timeoutSeconds?: number;
}

@@ -23,2 +24,4 @@ export type MultiNodeProviderConfig<ProviderOpts> = {

blockAgeLimitSeconds?: number;
timeoutSeconds?: number;
skipHealthCheck?: boolean;
};

@@ -25,0 +28,0 @@ export interface Dependencies<Provider, Contract, Message, Transaction, Wallet, Env extends BasicEnv> {

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29yZS9kZXBlbmRlbmNpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlc3VsdCB9IGZyb20gJ0BjaGFpbmxpbmsvZ2F1bnRsZXQtY29yZSdcbmltcG9ydCB7IGxvZ2dlciBhcyBjb3JlTG9nZ2VyLCBwcm9tcHQgfSBmcm9tICdAY2hhaW5saW5rL2dhdW50bGV0LWNvcmUvZGlzdC91dGlscydcbmltcG9ydCB7IElQcm92aWRlciB9IGZyb20gJy4uL3Byb3ZpZGVyJ1xuaW1wb3J0IHsgSVdhbGxldCB9IGZyb20gJy4uL3dhbGxldCdcbmltcG9ydCB7IENvbnRyYWN0TG9hZGVyIH0gZnJvbSAnLi4vY29tbWFuZHMvYmFzZS90eXBlcydcblxuLy8gT3RoZXJzIHNob3VsZCBleHRlbmRcbmV4cG9ydCBpbnRlcmZhY2UgQmFzaWNFbnYge1xuICBwcm92aWRlclVybDogc3RyaW5nXG4gIGZhbGxiYWNrVXJscz86IHN0cmluZ1tdXG4gIHNraXBTaW11bGF0ZT86IGJvb2xlYW5cbiAgaW5pdGlhbFdhaXRTZWNvbmRzPzogbnVtYmVyXG4gIG1heFJvdW5kcz86IG51bWJlclxuICBtYXhScGNDYWxsc1BlckJhdGNoPzogbnVtYmVyXG4gIGJsb2NrQWdlTGltaXRTZWNvbmRzPzogbnVtYmVyXG4gIG11bHRpTm9kZUVuYWJsZWQ/OiBib29sZWFuXG59XG5cbi8vIENvcmUgY29uZmlndXJhdGlvbiBmb3IgYSBtdWx0aSBub2RlIHByb3ZpZGVyXG5leHBvcnQgdHlwZSBNdWx0aU5vZGVQcm92aWRlckNvbmZpZzxQcm92aWRlck9wdHM+ID0ge1xuICAvKiBUaGUgVVJMIG9mIGVhY2ggbm9kZSB0aGF0IHRoZSBwcm92aWRlciB3aWxsIG1ha2UgUlBDIGNhbGxzIHRvLiAqL1xuICB1cmxzOiBzdHJpbmdbXVxuICAvKiBPcHRpb25zIGRlZmluZWQgYnkgdGhlIHVuZGVybHlpbmcgc2luZ2xlIG5vZGUgcHJvdmlkZXIgdXNlZCBieSB0aGUgbXVsdGkgbm9kZSBwcm92aWRlci4gKi9cbiAgcHJvdmlkZXJPcHRzPzogUHJvdmlkZXJPcHRzXG4gIC8qIFRoZSBpbml0aWFsIHdhaXQgdGltZSB1c2VkIGJ5IGFuIGV4cG9uZW50aWFsIGJhY2tvZmYgZm9ybXVsYTogaW5pdGlhbCAqIDJecm91bmQgKi9cbiAgaW5pdGlhbFdhaXRTZWNvbmRzPzogbnVtYmVyXG4gIC8qIFRoZSBtYXhpbXVtIG51bWJlciBvZiB0aW1lcyB0aGUgbXVsdGkgbm9kZSBwcm92aWRlciB3aWxsIGF0dGVtcHQgZWFjaCBjb25maWd1cmVkIFVSTCAqL1xuICBtYXhSb3VuZHM/OiBudW1iZXJcbiAgLyogSG93IG9sZCBhbnkgZ2l2ZW4gbm9kZSdzIGxhdGVzdC1rbm93biBibG9jayB0aW1lc3RhbXAgY2FuIGJlICovXG4gIGJsb2NrQWdlTGltaXRTZWNvbmRzPzogbnVtYmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVwZW5kZW5jaWVzPFByb3ZpZGVyLCBDb250cmFjdCwgTWVzc2FnZSwgVHJhbnNhY3Rpb24sIFdhbGxldCwgRW52IGV4dGVuZHMgQmFzaWNFbnY+IHtcbiAgbG9nZ2VyOiB0eXBlb2YgY29yZUxvZ2dlclxuICBwcm9tcHQ6IHR5cGVvZiBwcm9tcHRcbiAgbWFrZVByb3ZpZGVyOiAodXJsOiBzdHJpbmcpID0+IElQcm92aWRlcjxQcm92aWRlciwgQ29udHJhY3QsIE1lc3NhZ2UsIFRyYW5zYWN0aW9uLCBXYWxsZXQ+XG4gIG1ha2VNdWx0aU5vZGVQcm92aWRlcj86IDxQcm92aWRlck9wdHM+KFxuICAgIGNvbmZpZzogTXVsdGlOb2RlUHJvdmlkZXJDb25maWc8UHJvdmlkZXJPcHRzPixcbiAgICBsb2dnZXI6IHR5cGVvZiBjb3JlTG9nZ2VyLFxuICApID0+IFByb21pc2U8SVByb3ZpZGVyPFByb3ZpZGVyLCBDb250cmFjdCwgTWVzc2FnZSwgVHJhbnNhY3Rpb24sIFdhbGxldD4+XG4gIG1ha2VXYWxsZXQ6IChlbnY6IEVudiwgZmxhZ3MpID0+IFByb21pc2U8SVdhbGxldDxXYWxsZXQ+IHwgbnVsbD5cbiAgbWFrZUVudjogKGZsYWdzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KSA9PiBFbnZcbiAgbWFrZUNvbW1hbmRJbnB1dD86IE1ha2VDb21tYW5kSW5wdXRcbiAgYWZ0ZXJFeGVjdXRlRXh0ZXJuYWw/OiBBZnRlckV4dGVybmFsXG4gIGFmdGVyRXhwb3J0RXh0ZXJuYWw/OiBBZnRlckV4dGVybmFsXG4gIGNvbnRyYWN0TGlzdD86IENvbnRyYWN0TG9hZGVyPENvbnRyYWN0PltdXG59XG5cbmV4cG9ydCB0eXBlIEluc3BlY3Rpb25EZXBlbmRlbmNpZXM8UHJvdmlkZXIsIENvbnRyYWN0LCBNZXNzYWdlLCBUcmFuc2FjdGlvbiwgV2FsbGV0PiA9IE9taXQ8XG4gIERlcGVuZGVuY2llczxQcm92aWRlciwgQ29udHJhY3QsIE1lc3NhZ2UsIFRyYW5zYWN0aW9uLCBXYWxsZXQsIEJhc2ljRW52PixcbiAgJ21ha2VXYWxsZXQnXG4+XG5cbmV4cG9ydCB0eXBlIEJhc2ljRGVwcyA9IFBpY2s8RGVwZW5kZW5jaWVzPG51bGwsIG51bGwsIG51bGwsIG51bGwsIG51bGwsIG51bGw+LCAnbG9nZ2VyJyB8ICdwcm9tcHQnPlxuXG5leHBvcnQgdHlwZSBNYWtlQ29tbWFuZElucHV0ID0gPFVJPihcbiAgaWQ6IHN0cmluZyxcbiAgbmV0d29ya05hbWU6IHN0cmluZyxcbiAgY29udHJhY3RBZGRyZXNzPzogc3RyaW5nLFxuICBvdmVycmlkZXM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+LFxuKSA9PiBQcm9taXNlPFVJPlxuXG5leHBvcnQgdHlwZSBBZnRlckV4dGVybmFsID0gPFQ+KGlkOiBzdHJpbmcsIG5ldHdvcmtOYW1lOiBzdHJpbmcsIHJlcG9ydDogUmVzdWx0PFQ+KSA9PiBQcm9taXNlPHZvaWQ+XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29yZS9kZXBlbmRlbmNpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlc3VsdCB9IGZyb20gJ0BjaGFpbmxpbmsvZ2F1bnRsZXQtY29yZSdcbmltcG9ydCB7IGxvZ2dlciBhcyBjb3JlTG9nZ2VyLCBwcm9tcHQgfSBmcm9tICdAY2hhaW5saW5rL2dhdW50bGV0LWNvcmUvZGlzdC91dGlscydcbmltcG9ydCB7IElQcm92aWRlciB9IGZyb20gJy4uL3Byb3ZpZGVyJ1xuaW1wb3J0IHsgSVdhbGxldCB9IGZyb20gJy4uL3dhbGxldCdcbmltcG9ydCB7IENvbnRyYWN0TG9hZGVyIH0gZnJvbSAnLi4vY29tbWFuZHMvYmFzZS90eXBlcydcblxuLy8gT3RoZXJzIHNob3VsZCBleHRlbmRcbmV4cG9ydCBpbnRlcmZhY2UgQmFzaWNFbnYge1xuICBwcm92aWRlclVybDogc3RyaW5nXG4gIGZhbGxiYWNrVXJscz86IHN0cmluZ1tdXG4gIHNraXBTaW11bGF0ZT86IGJvb2xlYW5cbiAgaW5pdGlhbFdhaXRTZWNvbmRzPzogbnVtYmVyXG4gIG1heFJvdW5kcz86IG51bWJlclxuICBtYXhScGNDYWxsc1BlckJhdGNoPzogbnVtYmVyXG4gIGJsb2NrQWdlTGltaXRTZWNvbmRzPzogbnVtYmVyXG4gIG11bHRpTm9kZUVuYWJsZWQ/OiBib29sZWFuXG4gIHRpbWVvdXRTZWNvbmRzPzogbnVtYmVyXG59XG5cbi8vIENvcmUgY29uZmlndXJhdGlvbiBmb3IgYSBtdWx0aSBub2RlIHByb3ZpZGVyXG5leHBvcnQgdHlwZSBNdWx0aU5vZGVQcm92aWRlckNvbmZpZzxQcm92aWRlck9wdHM+ID0ge1xuICAvKiBUaGUgVVJMIG9mIGVhY2ggbm9kZSB0aGF0IHRoZSBwcm92aWRlciB3aWxsIG1ha2UgUlBDIGNhbGxzIHRvLiAqL1xuICB1cmxzOiBzdHJpbmdbXVxuICAvKiBPcHRpb25zIGRlZmluZWQgYnkgdGhlIHVuZGVybHlpbmcgc2luZ2xlIG5vZGUgcHJvdmlkZXIgdXNlZCBieSB0aGUgbXVsdGkgbm9kZSBwcm92aWRlci4gKi9cbiAgcHJvdmlkZXJPcHRzPzogUHJvdmlkZXJPcHRzXG4gIC8qIFRoZSBpbml0aWFsIHdhaXQgdGltZSB1c2VkIGJ5IGFuIGV4cG9uZW50aWFsIGJhY2tvZmYgZm9ybXVsYTogaW5pdGlhbCAqIDJecm91bmQgKi9cbiAgaW5pdGlhbFdhaXRTZWNvbmRzPzogbnVtYmVyXG4gIC8qIFRoZSBtYXhpbXVtIG51bWJlciBvZiB0aW1lcyB0aGUgbXVsdGkgbm9kZSBwcm92aWRlciB3aWxsIGF0dGVtcHQgZWFjaCBjb25maWd1cmVkIFVSTCAqL1xuICBtYXhSb3VuZHM/OiBudW1iZXJcbiAgLyogSG93IG9sZCBhbnkgZ2l2ZW4gbm9kZSdzIGxhdGVzdC1rbm93biBibG9jayB0aW1lc3RhbXAgY2FuIGJlICovXG4gIGJsb2NrQWdlTGltaXRTZWNvbmRzPzogbnVtYmVyXG4gIC8qIEhvdyBsb25nIHdlIHdpbGwgd2FpdCBmb3IgYSBzaW5nbGUgcmVxdWVzdCAqL1xuICB0aW1lb3V0U2Vjb25kcz86IG51bWJlclxuICAvKiBQZXJtaXRzIHNraXBwaW5nIHRoZSBoZWFsdGggY2hlY2sgKi9cbiAgc2tpcEhlYWx0aENoZWNrPzogYm9vbGVhblxufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlcGVuZGVuY2llczxQcm92aWRlciwgQ29udHJhY3QsIE1lc3NhZ2UsIFRyYW5zYWN0aW9uLCBXYWxsZXQsIEVudiBleHRlbmRzIEJhc2ljRW52PiB7XG4gIGxvZ2dlcjogdHlwZW9mIGNvcmVMb2dnZXJcbiAgcHJvbXB0OiB0eXBlb2YgcHJvbXB0XG4gIG1ha2VQcm92aWRlcjogKHVybDogc3RyaW5nKSA9PiBJUHJvdmlkZXI8UHJvdmlkZXIsIENvbnRyYWN0LCBNZXNzYWdlLCBUcmFuc2FjdGlvbiwgV2FsbGV0PlxuICBtYWtlTXVsdGlOb2RlUHJvdmlkZXI/OiA8UHJvdmlkZXJPcHRzPihcbiAgICBjb25maWc6IE11bHRpTm9kZVByb3ZpZGVyQ29uZmlnPFByb3ZpZGVyT3B0cz4sXG4gICAgbG9nZ2VyOiB0eXBlb2YgY29yZUxvZ2dlcixcbiAgKSA9PiBQcm9taXNlPElQcm92aWRlcjxQcm92aWRlciwgQ29udHJhY3QsIE1lc3NhZ2UsIFRyYW5zYWN0aW9uLCBXYWxsZXQ+PlxuICBtYWtlV2FsbGV0OiAoZW52OiBFbnYsIGZsYWdzKSA9PiBQcm9taXNlPElXYWxsZXQ8V2FsbGV0PiB8IG51bGw+XG4gIG1ha2VFbnY6IChmbGFnczogUmVjb3JkPHN0cmluZywgc3RyaW5nPikgPT4gRW52XG4gIG1ha2VDb21tYW5kSW5wdXQ/OiBNYWtlQ29tbWFuZElucHV0XG4gIGFmdGVyRXhlY3V0ZUV4dGVybmFsPzogQWZ0ZXJFeHRlcm5hbFxuICBhZnRlckV4cG9ydEV4dGVybmFsPzogQWZ0ZXJFeHRlcm5hbFxuICBjb250cmFjdExpc3Q/OiBDb250cmFjdExvYWRlcjxDb250cmFjdD5bXVxufVxuXG5leHBvcnQgdHlwZSBJbnNwZWN0aW9uRGVwZW5kZW5jaWVzPFByb3ZpZGVyLCBDb250cmFjdCwgTWVzc2FnZSwgVHJhbnNhY3Rpb24sIFdhbGxldD4gPSBPbWl0PFxuICBEZXBlbmRlbmNpZXM8UHJvdmlkZXIsIENvbnRyYWN0LCBNZXNzYWdlLCBUcmFuc2FjdGlvbiwgV2FsbGV0LCBCYXNpY0Vudj4sXG4gICdtYWtlV2FsbGV0J1xuPlxuXG5leHBvcnQgdHlwZSBCYXNpY0RlcHMgPSBQaWNrPERlcGVuZGVuY2llczxudWxsLCBudWxsLCBudWxsLCBudWxsLCBudWxsLCBudWxsPiwgJ2xvZ2dlcicgfCAncHJvbXB0Jz5cblxuZXhwb3J0IHR5cGUgTWFrZUNvbW1hbmRJbnB1dCA9IDxVST4oXG4gIGlkOiBzdHJpbmcsXG4gIG5ldHdvcmtOYW1lOiBzdHJpbmcsXG4gIGNvbnRyYWN0QWRkcmVzcz86IHN0cmluZyxcbiAgb3ZlcnJpZGVzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPixcbikgPT4gUHJvbWlzZTxVST5cblxuZXhwb3J0IHR5cGUgQWZ0ZXJFeHRlcm5hbCA9IDxUPihpZDogc3RyaW5nLCBuZXR3b3JrTmFtZTogc3RyaW5nLCByZXBvcnQ6IFJlc3VsdDxUPikgPT4gUHJvbWlzZTx2b2lkPlxuIl19

@@ -101,2 +101,4 @@ "use strict";

maxRounds: this.maxRounds,
blockAgeLimitSeconds: this.blockAgeLimitSeconds,
timeoutSeconds: this.timeoutSeconds,
}, deps.logger);

@@ -203,2 +205,3 @@ return Promise.all(batch.map((query) => {

c.blockAgeLimitSeconds = env.blockAgeLimitSeconds;
c.timeoutSeconds = env.timeoutSeconds;
c.env = env;

@@ -215,2 +218,3 @@ if (!deps.makeMultiNodeProvider)

blockAgeLimitSeconds: c.blockAgeLimitSeconds,
timeoutSeconds: c.timeoutSeconds,
}, deps.logger);

@@ -267,2 +271,2 @@ /*

exports.makeEVMBatchInspectionCommand = makeEVMBatchInspectionCommand;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"batchInspectionCommand.js","sourceRoot":"","sources":["../../../../src/evm/commands/native/batchInspectionCommand.ts"],"names":[],"mappings":";;;;AAAA,wGAA8E;AAC9E,wCAA0D;AAE1D,mCAA0D;AAG1D,6BAAuB;AACvB,0CAAiE;AAKjE,MAAM,MAAM,GAAG,OAAC;KACb,MAAM,CAAC;IACN,EAAE,EAAE,OAAC,CAAC,MAAM,EAAE;IACd,OAAO,EAAE,gBAAQ;IACjB,KAAK,EAAE,OAAC,CAAC,MAAM,CAAC,EAAE,CAAC;CACpB,CAAC;KACD,KAAK,EAAE,CAAA;AAIV,MAAM,kBAAkB,GAAG,GAAG,CAAA;AAavB,MAAM,6BAA6B,GAAG,CAAC,QAAgB,EAAE,OAAwC,EAAE,EAAE,CAAC,CAC3G,IAAqB,EACrB,EAAE;;IACF,MAAM,EAAE,GAAG,GAAG,QAAQ,gBAAgB,CAAA;IAEtC,MAAM,OAAO,SAAgD,MAAM,sBACjE,SAAQ,cAAW;YADwC;;gBAyC3D,qGAAqG;gBAC7F,wBAAmB,GAAG,KAAK,IAAI,EAAE;oBACvC,MAAM,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAA;oBACpD,MAAM,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAA;oBAEpD,IAAI;wBACF,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;qBAC1B;oBAAC,OAAO,CAAC,EAAE;wBACV,MAAM,IAAI,KAAK,CACb,oFAAoF,IAAI,CAAC,WAAW,EAAE,CACvG,CAAA;qBACF;gBACH,CAAC,CAAA;gBAiGD,YAAO,GAAG,KAAK,IAAI,EAAE;oBACnB,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAA;oBAChC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,wCAAwC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;oBAE7E;;;;sBAIE;oBACF,MAAM,iBAAiB,GAAG,MAAM,OAAO,CAAC,GAAG,CACzC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE;wBACxC,MAAM,SAAS,GAAG,UAAU,CAAC,KAAK,CAAC,KAAK,CAAA;wBACxC,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;wBAC7C,MAAM,cAAc,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;wBAChE,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAA;wBAClE,MAAM,eAAe,GAAG,UAAU,CAAC,eAAe,CAAA;wBAClD,MAAM,aAAa,GAAG;4BACpB,EAAE,EAAE,IAAA,oBAAa,EAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC;4BACzD,eAAe;4BACf,QAAQ,EAAE,IAAI,CAAC,eAAe;4BAC9B,KAAK,EAAE,IAAI,CAAC,KAAK;4BACjB,GAAG,EAAE,IAAI,CAAC,GAAG;4BACb,QAAQ,EAAE,eAAe;yBAC1B,CAAA;wBACD,IAAI,CAAC,CAAC,MAAM,CAAC,WAAW;4BACtB,MAAM,OAAO,CAAC,GAAG,CACf,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE;gCAC1C,IAAI;oCACF,MAAM,UAAU,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;iCAC3C;gCAAC,OAAO,CAAC,EAAE;oCACV,MAAM,IAAI,KAAK,CACb,WAAW,aAAa,CAAC,EAAE,wBAAwB,eAAe,uBAAuB,CAAC,EAAE,CAC7F,CAAA;iCACF;4BACH,CAAC,CAAC,CACH,CAAA;wBACH,OAAO;4BACL,MAAM;4BACN,QAAQ,EAAE,UAAU,CAAC,QAAQ;4BAC7B,eAAe;4BACf,eAAe;4BACf,GAAG,EAAE,OAAO,MAAM,CAAC,OAAO,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO;4BACtF,SAAS;4BACT,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC;4BACjF,aAAa;yBACd,CAAA;oBACH,CAAC,CAAC,CACH,CAAA;oBAED,IAAI,YAAY,GAAG,iBAAiB;yBACjC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CACX,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;wBACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;wBACtB,EAAE;wBACF,KAAK,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;qBAC1D,CAAC,CAAC,CACJ;yBACA,IAAI,EAAE,CAAA;oBAET,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,SAAS,qDAAqD,CAAC,CAAA;oBAChG,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,CAAA;oBAExD;;;;;;sBAME;oBACF,MAAM,OAAO,GAAG,CACd,MAAM,OAAO,CAAC,GAAG,CACf,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;wBAC1B,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAC/C;4BACE,IAAI,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;4BACtD,YAAY,EAAE;gCACZ,aAAa,EAAE,IAAI,CAAC,mBAAmB;6BACxC;4BACD,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;4BAC3C,SAAS,EAAE,IAAI,CAAC,SAAS;yBAC1B,EACD,IAAI,CAAC,MAAM,CACZ,CAAA;wBACD,OAAO,OAAO,CAAC,GAAG,CAChB,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;4BAClB,MAAM,KAAK,GAAG,KAAK,IAAI,EAAE;gCACvB,IAAI;oCACF,OAAO,MAAM,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAA;iCACjF;gCAAC,OAAO,CAAC,EAAE;oCACV,IAAI,eAAM,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,eAAM,CAAC,OAAO,CAAC,CAAC,EAAE,UAAU,CAAC,EAAE;wCAC9D;;;;0CAIE;wCACF,OAAO,WAAW,CAAA;qCACnB;oCAED,MAAM,CAAC,CAAA;iCACR;4BACH,CAAC,CAAA;4BAED,OAAO,KAAK,EAAE,CAAA;wBAChB,CAAC,CAAC,CACH,CAAA;oBACH,CAAC,CAAC,CACH,CACF,CAAC,IAAI,EAAE,CAAA;oBAER;;;sBAGE;oBACF,IAAI,KAAK,GAAG,CAAC,CAAA;oBACb,IAAI,QAAQ,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;wBAC3C,MAAM,OAAO,GAAG,GAAG,CAAC,MAAM,CAAC,mBAAmB,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,aAAa,CAAC,CACrF,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAC5C,GAAG,CAAC,SAAS,EACb,GAAG,CAAC,eAAe,EACnB,GAAG,CAAC,eAAe,CACpB,CAAA;wBACD,KAAK,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,CAAA;wBACvB,OAAO,OAAO,CAAA;oBAChB,CAAC,CAAC,CAAA;oBAEF,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;oBAExC,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;wBACzD,OAAO,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;oBAC7E,CAAC,CAAC,CAAA;oBAEF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;oBACvC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;oBAErB,MAAM,MAAM,GAAG;wBACb,IAAI,EAAE;4BACJ,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;gCAC5B,IAAI,EAAE,KAAK;gCACX,QAAQ,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC,eAAe;gCAC9C,UAAU,EAAE,iBAAiB,CAAC,CAAC,CAAC;6BACjC,CAAC,CAAC;4BACH,QAAQ,EAAE,KAAK;4BACf,UAAU,EAAE,EAAE;yBACf;wBACD,SAAS,EAAE,EAAE;qBACd,CAAA;oBAED,IAAI,IAAI,CAAC,oBAAoB;wBAAE,MAAM,IAAI,CAAC,oBAAoB,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;oBAE9F,OAAO,MAAM,CAAA;gBACf,CAAC,CAAA;YACH,CAAC;SAAA;QAvRC,KAAK;QACE,KAAE,GAAG,EAAE;QACP,WAAQ,GAAG,QAAQ;QACnB,WAAQ,GAAG;YAChB,GAAG,EAAE;;;;;;;;;;;;GAYR;SACE;QAgBM,SAAM,GAAG,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACpC,MAAM,CAAC,GAAG,IAAI,EAAsB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;YAEjD,IAAI,WAAW,CAAA;YACf,IAAI;gBACF,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAU,CAAA;gBAC1C,MAAM,IAAA,kBAAU,EAAC,MAAM,CAAC,CAAC,WAAW,CAAC,CAAA;aACtC;YAAC,OAAO,CAAC,EAAE;gBACV,MAAM,IAAI,KAAK,CAAC;;;;;;;;GAQrB,CAAC,CAAA;aACG;YAED,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAA;YAE3E,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;YAC/B,IAAI,CAAC,GAAG,CAAC,WAAW;gBAAE,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAA;YACvG,CAAC,CAAC,WAAW,GAAG,GAAG,CAAC,WAAW,CAAA;YAC/B,CAAC,CAAC,YAAY,GAAG,GAAG,CAAC,YAAY,CAAA;YACjC,CAAC,CAAC,kBAAkB,GAAG,GAAG,CAAC,kBAAkB,CAAA;YAC7C,CAAC,CAAC,SAAS,GAAG,GAAG,CAAC,SAAS,CAAA;YAC3B,CAAC,CAAC,mBAAmB,GAAG,GAAG,CAAC,mBAAmB,CAAA;YAC/C,CAAC,CAAC,oBAAoB,GAAG,GAAG,CAAC,oBAAoB,CAAA;YACjD,CAAC,CAAC,GAAG,GAAG,GAAG,CAAA;YAEX,IAAI,CAAC,IAAI,CAAC,qBAAqB;gBAAE,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAA;YAChH,CAAC,CAAC,eAAe,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAClD;gBACE,IAAI,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;gBAChD,YAAY,EAAE;oBACZ,aAAa,EAAE,CAAC,CAAC,mBAAmB;iBACrC;gBACD,kBAAkB,EAAE,CAAC,CAAC,kBAAkB;gBACxC,SAAS,EAAE,CAAC,CAAC,SAAS;gBACtB,oBAAoB,EAAE,CAAC,CAAC,oBAAoB;aAC7C,EACD,IAAI,CAAC,MAAM,CACZ,CAAA;YAED;;;;cAIE;YACF,CAAC,CAAC,iBAAiB,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;gBACnD,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC;oBAAE,OAAO,GAAG,CAAA;gBACzC,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,YAAY,EAAE,EAAE,CAAA;YAChE,CAAC,EAAE,EAAE,CAAC,CAAA;YAEN;;;cAGE;YACF,CAAC,CAAC,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;gBAC5C,MAAM,EAAE,GAAG,IAAA,oBAAa,EAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAA;gBAChE,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;oBAAE,OAAO,GAAG,CAAA;gBACzB,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,CAAA;YACjC,CAAC,EAAE,EAAE,CAAC,CAAA;YACN,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAA;YAExC;;;cAGE;YACF,CAAC,CAAC,WAAW,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE;gBAChD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,UAAU,CAAC,EAAE,CAAC,EAAE;oBAC9C,MAAM,YAAY,GAAG,IAAI,GAAG,CAC1B,WAAW;yBACR,KAAK,CAAC,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC;yBAC5B,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC;yBAC9D,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CACxB,CAAA;oBACD,MAAM,IAAI,KAAK,CAAC,8BAA8B,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;iBACpF;gBACD,MAAM,MAAM,GAAG,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;gBAC1C,MAAM,OAAO,GAAG,CAAC,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAA;gBACvD,MAAM,QAAQ,GAAG,IAAI,iBAAQ,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,CAAA;gBACpE,OAAO;oBACL,EAAE,EAAE,UAAU,CAAC,EAAE;oBACjB,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAQ;oBAC5B,eAAe,EAAE,UAAU,CAAC,OAAO;oBACnC,QAAQ;oBACR,KAAK,EAAE,EAAE,KAAK,EAAE,UAAU,CAAC,KAAK,IAAI,EAAE,EAAE;iBACzC,CAAA;YACH,CAAC,CAAC,CAAA;YAEF,OAAO,CAAC,CAAA;QACV,CAAC;WAyJF,CAAA;IAED,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA;AArTY,QAAA,6BAA6B,iCAqTzC","sourcesContent":["import BaseCommand from '@chainlink/gauntlet-core/dist/commands/internal/base'\nimport { CommandCtor, makeCommandId } from '../../../core'\nimport { InspectUserInput, InspectionReport } from '../../../core/commands/base/inspectionCommand'\nimport { Contract, ContractFactory, ethers } from 'ethers'\nimport { EVMInspectionCommandConfig } from '..'\nimport { EVMDependencies } from '../../dependencies'\nimport { z } from 'zod'\nimport { chunkArray, parseAsync, zAddress } from '../../../utils'\nimport { EVMProvider } from '../../provider'\n\ntype EVMInspectionCommandConfigAny = EVMInspectionCommandConfig<any, any, any, any>\n\nconst schema = z\n  .object({\n    id: z.string(),\n    address: zAddress,\n    input: z.object({}),\n  })\n  .array()\n\ntype Input = z.infer<typeof schema>\n\nconst DEFAULT_BATCH_SIZE = 500\n\n/*\nThe data field of the EVMBatchInspectionReport is just an array of regular inspection reports.\nThe top level \"contract\" and \"inspection\" fields are not used. They are just present to meet\nthe interface.\n*/\nexport interface EVMBatchInspectionReport extends InspectionReport<InspectionReport<any>[]> {}\n\nexport interface EVMBatchInspectCommandInstance {\n  execute: () => Promise<{ data: EVMBatchInspectionReport; responses: any[] }>\n}\n\nexport const makeEVMBatchInspectionCommand = (category: string, configs: EVMInspectionCommandConfigAny[]) => (\n  deps: EVMDependencies,\n) => {\n  const id = `${category}:inspect:batch`\n\n  const command: CommandCtor<EVMBatchInspectCommandInstance> = class BatchInspectionCommand\n    extends BaseCommand\n    implements EVMBatchInspectCommandInstance {\n    // Props\n    batchSize: number\n    providerUrl: string\n    fallbackUrls: string[]\n    initialWaitSeconds?: number\n    maxRounds?: number\n    maxRpcCallsPerBatch?: number\n    blockAgeLimitSeconds?: number\n    defaultProvider: EVMProvider\n    categoryToFactory: { [id: string]: ContractFactory }\n    idToConfig: { [id: string]: EVMInspectionCommandConfigAny }\n    inspections: {\n      id: string\n      contractAddress: string\n      contract: Contract\n      input: InspectUserInput<any, any>\n    }[]\n    env: any\n\n    // UX\n    static id = id\n    static category = category\n    static examples = [\n      `${id} --network=<NETWORK> (--batchSize=<BATCH_SIZE>) '[\n  {\n    \"id\": \"<COMMAND_ID_1\",\n    \"address\": \"0x...\",\n    \"input\": { ... }\n  },\n  {\n    \"id\": \"<COMMAND_ID_2>\"},\n    \"address\": \"0x...\",\n    \"input\": { ... }\n  } \n  ...\n]'`,\n    ]\n\n    // This is a simple check to determine whether or not the configured node supports batching RPC calls\n    private mustSupportBatching = async () => {\n      const a = this.defaultProvider.provider.getNetwork()\n      const b = this.defaultProvider.provider.getNetwork()\n\n      try {\n        await Promise.all([a, b])\n      } catch (e) {\n        throw new Error(\n          `The given RPC URL is unreachable or does not support batching, please change it: ${this.providerUrl}`,\n        )\n      }\n    }\n\n    static create = async (flags, args) => {\n      const c = new BatchInspectionCommand(flags, args)\n\n      let inspectDefs\n      try {\n        inspectDefs = JSON.parse(args[0]) as Input\n        await parseAsync(schema)(inspectDefs)\n      } catch (e) {\n        throw new Error(`Invalid input argument, please adhere to the following format for batched inspections: \n'[\n  {\n    \"id\": \"<COMMAND_ID>\",\n    \"input\": { ... },\n    \"address\": \"<CONTRACT_ADDRESS>\"\n  }, \n  ...\n]'`)\n      }\n\n      c.batchSize = isNaN(flags.batchSize) ? DEFAULT_BATCH_SIZE : flags.batchSize\n\n      const env = deps.makeEnv(flags)\n      if (!env.providerUrl) throw new Error(`providerUrl has not been configured for BatchInspectionCommand`)\n      c.providerUrl = env.providerUrl\n      c.fallbackUrls = env.fallbackUrls\n      c.initialWaitSeconds = env.initialWaitSeconds\n      c.maxRounds = env.maxRounds\n      c.maxRpcCallsPerBatch = env.maxRpcCallsPerBatch\n      c.blockAgeLimitSeconds = env.blockAgeLimitSeconds\n      c.env = env\n\n      if (!deps.makeMultiNodeProvider) throw new Error(`makeMultiNodeProvider is required for BatchInspectionCommand`)\n      c.defaultProvider = await deps.makeMultiNodeProvider(\n        {\n          urls: [c.providerUrl, ...(c.fallbackUrls || [])],\n          providerOpts: {\n            batchMaxCount: c.maxRpcCallsPerBatch,\n          },\n          initialWaitSeconds: c.initialWaitSeconds,\n          maxRounds: c.maxRounds,\n          blockAgeLimitSeconds: c.blockAgeLimitSeconds,\n        },\n        deps.logger,\n      )\n\n      /*\n      categoryToFactory enables us to load a contract once and have all\n      commands in the same category share the same reference. We assume\n      that same category = same contract.\n      */\n      c.categoryToFactory = configs.reduce((acc, config) => {\n        if (!!acc[config.ux.category]) return acc\n        return { ...acc, [config.ux.category]: config.loadContract() }\n      }, {})\n\n      /*\n      idToConfig maps a command ID to its config, which contains all the\n      hooks and variables (e.g. query list) required to run it\n      */\n      c.idToConfig = configs.reduce((acc, config) => {\n        const id = makeCommandId(config.ux.category, config.ux.function)\n        if (!!acc[id]) return acc\n        return { ...acc, [id]: config }\n      }, {})\n      const allIds = Object.keys(c.idToConfig)\n\n      /*\n      With the help of our maps, we can now build the list of inspections.\n      We bundle all the information needed to run each inspection into a single object.\n      */\n      c.inspections = inspectDefs.map((inspectDef, i) => {\n        if (!allIds.find((id) => id === inspectDef.id)) {\n          const unrecognized = new Set(\n            inspectDefs\n              .slice(i, inspectDefs.length)\n              .filter((def) => !allIds.find((knownId) => knownId === def.id))\n              .map((def) => def.id),\n          )\n          throw new Error(`Found unknown command IDs: ${Array.from(unrecognized).join(',')}`)\n        }\n        const config = c.idToConfig[inspectDef.id]\n        const factory = c.categoryToFactory[config.ux.category]\n        const contract = new Contract(inspectDef.address, factory.interface)\n        return {\n          id: inspectDef.id,\n          category: config.ux.category,\n          contractAddress: inspectDef.address,\n          contract,\n          input: { input: inspectDef.input || {} },\n        }\n      })\n\n      return c\n    }\n\n    execute = async () => {\n      await this.mustSupportBatching()\n      deps.logger.debug(`The given RPC URL supports batching: ${this.providerUrl}`)\n\n      /*\n      Here, we pull the actual contract functions and inputs from each inspection.\n      Any information we need to run command hooks is assembled here. We run validations\n      per inspection here as well.\n      */\n      const allInspectionCmds = await Promise.all(\n        this.inspections.map(async (inspection) => {\n          const userInput = inspection.input.input\n          const config = this.idToConfig[inspection.id]\n          const contractInputs = await config.makeContractInput(userInput)\n          const contractFactory = this.categoryToFactory[config.ux.category]\n          const contractAddress = inspection.contractAddress\n          const inspectionCtx = {\n            id: makeCommandId(config.ux.category, config.ux.function),\n            contractAddress,\n            provider: this.defaultProvider,\n            flags: this.flags,\n            env: this.env,\n            contract: contractFactory,\n          }\n          if (!!config.validations)\n            await Promise.all(\n              config.validations.map(async (validation) => {\n                try {\n                  await validation(userInput, inspectionCtx)\n                } catch (e) {\n                  throw new Error(\n                    `Command ${inspectionCtx.id} with target address ${contractAddress} failed with error: ${e}`,\n                  )\n                }\n              }),\n            )\n          return {\n            config,\n            contract: inspection.contract,\n            contractFactory,\n            contractAddress,\n            fns: typeof config.queries === 'function' ? config.queries(userInput) : config.queries,\n            userInput,\n            contractInputs: Array.isArray(contractInputs) ? contractInputs : [contractInputs],\n            inspectionCtx,\n          }\n        }),\n      )\n\n      let fnsWithInput = allInspectionCmds\n        .map((cmd) =>\n          cmd.fns.map((fn, i) => ({\n            contract: cmd.contract,\n            fn,\n            input: cmd.contractInputs[i] ? cmd.contractInputs[i] : [],\n          })),\n        )\n        .flat()\n\n      deps.logger.info(`Sending ${this.batchSize} RPC calls per batch (use --batchSize to configure)`)\n      const batches = chunkArray(fnsWithInput, this.batchSize)\n\n      /*\n      We make a new provider for each batch. Under the hood, the ethers batch provider builds\n      a batch request until the promises are resolved via \"await\". If we use a single provider\n      for all batches, running \"await\" would cause the provider to treat all batches as a single\n      batch, even if it seems like we are separating them. This would overload the RPCs and they \n      would throw an error.\n      */\n      const results = (\n        await Promise.all(\n          batches.map(async (batch) => {\n            const provider = await deps.makeMultiNodeProvider(\n              {\n                urls: [this.providerUrl, ...(this.fallbackUrls || [])],\n                providerOpts: {\n                  batchMaxCount: this.maxRpcCallsPerBatch,\n                },\n                initialWaitSeconds: this.initialWaitSeconds,\n                maxRounds: this.maxRounds,\n              },\n              deps.logger,\n            )\n            return Promise.all(\n              batch.map((query) => {\n                const fetch = async () => {\n                  try {\n                    return await query.contract.connect(provider.provider)[query.fn](...query.input)\n                  } catch (e) {\n                    if (ethers.isCallException(e) || ethers.isError(e, 'BAD_DATA')) {\n                      /*\n                      If there is a CALL_EXCEPTION, we don't want to abort the entire inspection.\n                      Sometimes, certain inspections are used for multiple contract versions, and one\n                      or two calls may not exist for a particular version.\n                      */\n                      return '!!ERROR!!'\n                    }\n\n                    throw e\n                  }\n                }\n\n                return fetch()\n              }),\n            )\n          }),\n        )\n      ).flat()\n\n      /*\n      Currently, we run makeComparisonData for each inspection command. Some\n      commands may define event queries or additional RPC calls here.\n      */\n      let start = 0\n      let promises = allInspectionCmds.map((cmd) => {\n        const promise = cmd.config.makeComparisionData(this.defaultProvider, cmd.inspectionCtx)(\n          results.slice(start, start + cmd.fns.length),\n          cmd.userInput,\n          cmd.contractAddress,\n          cmd.contractFactory,\n        )\n        start += cmd.fns.length\n        return promise\n      })\n\n      const data = await Promise.all(promises)\n\n      const inspectionResults = allInspectionCmds.map((cmd, i) => {\n        return cmd.config.inspect ? cmd.config.inspect(cmd.userInput, data[i]) : []\n      })\n\n      deps.logger.info('Inspection Results:')\n      deps.logger.log(data)\n\n      const report = {\n        data: {\n          data: data.map((datum, i) => ({\n            data: datum,\n            contract: allInspectionCmds[i].contractAddress,\n            inspection: inspectionResults[i],\n          })),\n          contract: 'n/a',\n          inspection: [],\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":"batchInspectionCommand.js","sourceRoot":"","sources":["../../../../src/evm/commands/native/batchInspectionCommand.ts"],"names":[],"mappings":"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","sourcesContent":["import BaseCommand from '@chainlink/gauntlet-core/dist/commands/internal/base'\nimport { CommandCtor, makeCommandId } from '../../../core'\nimport { InspectUserInput, InspectionReport } from '../../../core/commands/base/inspectionCommand'\nimport { Contract, ContractFactory, ethers } from 'ethers'\nimport { EVMInspectionCommandConfig } from '..'\nimport { EVMDependencies } from '../../dependencies'\nimport { z } from 'zod'\nimport { chunkArray, parseAsync, zAddress } from '../../../utils'\nimport { EVMProvider } from '../../provider'\n\ntype EVMInspectionCommandConfigAny = EVMInspectionCommandConfig<any, any, any, any>\n\nconst schema = z\n  .object({\n    id: z.string(),\n    address: zAddress,\n    input: z.object({}),\n  })\n  .array()\n\ntype Input = z.infer<typeof schema>\n\nconst DEFAULT_BATCH_SIZE = 500\n\n/*\nThe data field of the EVMBatchInspectionReport is just an array of regular inspection reports.\nThe top level \"contract\" and \"inspection\" fields are not used. They are just present to meet\nthe interface.\n*/\nexport interface EVMBatchInspectionReport extends InspectionReport<InspectionReport<any>[]> {}\n\nexport interface EVMBatchInspectCommandInstance {\n  execute: () => Promise<{ data: EVMBatchInspectionReport; responses: any[] }>\n}\n\nexport const makeEVMBatchInspectionCommand = (category: string, configs: EVMInspectionCommandConfigAny[]) => (\n  deps: EVMDependencies,\n) => {\n  const id = `${category}:inspect:batch`\n\n  const command: CommandCtor<EVMBatchInspectCommandInstance> = class BatchInspectionCommand\n    extends BaseCommand\n    implements EVMBatchInspectCommandInstance {\n    // Props\n    batchSize: number\n    providerUrl: string\n    fallbackUrls: string[]\n    initialWaitSeconds?: number\n    maxRounds?: number\n    maxRpcCallsPerBatch?: number\n    blockAgeLimitSeconds?: number\n    timeoutSeconds?: number\n    defaultProvider: EVMProvider\n    categoryToFactory: { [id: string]: ContractFactory }\n    idToConfig: { [id: string]: EVMInspectionCommandConfigAny }\n    inspections: {\n      id: string\n      contractAddress: string\n      contract: Contract\n      input: InspectUserInput<any, any>\n    }[]\n    env: any\n\n    // UX\n    static id = id\n    static category = category\n    static examples = [\n      `${id} --network=<NETWORK> (--batchSize=<BATCH_SIZE>) '[\n  {\n    \"id\": \"<COMMAND_ID_1\",\n    \"address\": \"0x...\",\n    \"input\": { ... }\n  },\n  {\n    \"id\": \"<COMMAND_ID_2>\"},\n    \"address\": \"0x...\",\n    \"input\": { ... }\n  } \n  ...\n]'`,\n    ]\n\n    // This is a simple check to determine whether or not the configured node supports batching RPC calls\n    private mustSupportBatching = async () => {\n      const a = this.defaultProvider.provider.getNetwork()\n      const b = this.defaultProvider.provider.getNetwork()\n\n      try {\n        await Promise.all([a, b])\n      } catch (e) {\n        throw new Error(\n          `The given RPC URL is unreachable or does not support batching, please change it: ${this.providerUrl}`,\n        )\n      }\n    }\n\n    static create = async (flags, args) => {\n      const c = new BatchInspectionCommand(flags, args)\n\n      let inspectDefs\n      try {\n        inspectDefs = JSON.parse(args[0]) as Input\n        await parseAsync(schema)(inspectDefs)\n      } catch (e) {\n        throw new Error(`Invalid input argument, please adhere to the following format for batched inspections: \n'[\n  {\n    \"id\": \"<COMMAND_ID>\",\n    \"input\": { ... },\n    \"address\": \"<CONTRACT_ADDRESS>\"\n  }, \n  ...\n]'`)\n      }\n\n      c.batchSize = isNaN(flags.batchSize) ? DEFAULT_BATCH_SIZE : flags.batchSize\n\n      const env = deps.makeEnv(flags)\n      if (!env.providerUrl) throw new Error(`providerUrl has not been configured for BatchInspectionCommand`)\n      c.providerUrl = env.providerUrl\n      c.fallbackUrls = env.fallbackUrls\n      c.initialWaitSeconds = env.initialWaitSeconds\n      c.maxRounds = env.maxRounds\n      c.maxRpcCallsPerBatch = env.maxRpcCallsPerBatch\n      c.blockAgeLimitSeconds = env.blockAgeLimitSeconds\n      c.timeoutSeconds = env.timeoutSeconds\n      c.env = env\n\n      if (!deps.makeMultiNodeProvider) throw new Error(`makeMultiNodeProvider is required for BatchInspectionCommand`)\n      c.defaultProvider = await deps.makeMultiNodeProvider(\n        {\n          urls: [c.providerUrl, ...(c.fallbackUrls || [])],\n          providerOpts: {\n            batchMaxCount: c.maxRpcCallsPerBatch,\n          },\n          initialWaitSeconds: c.initialWaitSeconds,\n          maxRounds: c.maxRounds,\n          blockAgeLimitSeconds: c.blockAgeLimitSeconds,\n          timeoutSeconds: c.timeoutSeconds,\n        },\n        deps.logger,\n      )\n\n      /*\n      categoryToFactory enables us to load a contract once and have all\n      commands in the same category share the same reference. We assume\n      that same category = same contract.\n      */\n      c.categoryToFactory = configs.reduce((acc, config) => {\n        if (!!acc[config.ux.category]) return acc\n        return { ...acc, [config.ux.category]: config.loadContract() }\n      }, {})\n\n      /*\n      idToConfig maps a command ID to its config, which contains all the\n      hooks and variables (e.g. query list) required to run it\n      */\n      c.idToConfig = configs.reduce((acc, config) => {\n        const id = makeCommandId(config.ux.category, config.ux.function)\n        if (!!acc[id]) return acc\n        return { ...acc, [id]: config }\n      }, {})\n      const allIds = Object.keys(c.idToConfig)\n\n      /*\n      With the help of our maps, we can now build the list of inspections.\n      We bundle all the information needed to run each inspection into a single object.\n      */\n      c.inspections = inspectDefs.map((inspectDef, i) => {\n        if (!allIds.find((id) => id === inspectDef.id)) {\n          const unrecognized = new Set(\n            inspectDefs\n              .slice(i, inspectDefs.length)\n              .filter((def) => !allIds.find((knownId) => knownId === def.id))\n              .map((def) => def.id),\n          )\n          throw new Error(`Found unknown command IDs: ${Array.from(unrecognized).join(',')}`)\n        }\n        const config = c.idToConfig[inspectDef.id]\n        const factory = c.categoryToFactory[config.ux.category]\n        const contract = new Contract(inspectDef.address, factory.interface)\n        return {\n          id: inspectDef.id,\n          category: config.ux.category,\n          contractAddress: inspectDef.address,\n          contract,\n          input: { input: inspectDef.input || {} },\n        }\n      })\n\n      return c\n    }\n\n    execute = async () => {\n      await this.mustSupportBatching()\n      deps.logger.debug(`The given RPC URL supports batching: ${this.providerUrl}`)\n\n      /*\n      Here, we pull the actual contract functions and inputs from each inspection.\n      Any information we need to run command hooks is assembled here. We run validations\n      per inspection here as well.\n      */\n      const allInspectionCmds = await Promise.all(\n        this.inspections.map(async (inspection) => {\n          const userInput = inspection.input.input\n          const config = this.idToConfig[inspection.id]\n          const contractInputs = await config.makeContractInput(userInput)\n          const contractFactory = this.categoryToFactory[config.ux.category]\n          const contractAddress = inspection.contractAddress\n          const inspectionCtx = {\n            id: makeCommandId(config.ux.category, config.ux.function),\n            contractAddress,\n            provider: this.defaultProvider,\n            flags: this.flags,\n            env: this.env,\n            contract: contractFactory,\n          }\n          if (!!config.validations)\n            await Promise.all(\n              config.validations.map(async (validation) => {\n                try {\n                  await validation(userInput, inspectionCtx)\n                } catch (e) {\n                  throw new Error(\n                    `Command ${inspectionCtx.id} with target address ${contractAddress} failed with error: ${e}`,\n                  )\n                }\n              }),\n            )\n          return {\n            config,\n            contract: inspection.contract,\n            contractFactory,\n            contractAddress,\n            fns: typeof config.queries === 'function' ? config.queries(userInput) : config.queries,\n            userInput,\n            contractInputs: Array.isArray(contractInputs) ? contractInputs : [contractInputs],\n            inspectionCtx,\n          }\n        }),\n      )\n\n      let fnsWithInput = allInspectionCmds\n        .map((cmd) =>\n          cmd.fns.map((fn, i) => ({\n            contract: cmd.contract,\n            fn,\n            input: cmd.contractInputs[i] ? cmd.contractInputs[i] : [],\n          })),\n        )\n        .flat()\n\n      deps.logger.info(`Sending ${this.batchSize} RPC calls per batch (use --batchSize to configure)`)\n      const batches = chunkArray(fnsWithInput, this.batchSize)\n\n      /*\n      We make a new provider for each batch. Under the hood, the ethers batch provider builds\n      a batch request until the promises are resolved via \"await\". If we use a single provider\n      for all batches, running \"await\" would cause the provider to treat all batches as a single\n      batch, even if it seems like we are separating them. This would overload the RPCs and they \n      would throw an error.\n      */\n      const results = (\n        await Promise.all(\n          batches.map(async (batch) => {\n            const provider = await deps.makeMultiNodeProvider(\n              {\n                urls: [this.providerUrl, ...(this.fallbackUrls || [])],\n                providerOpts: {\n                  batchMaxCount: this.maxRpcCallsPerBatch,\n                },\n                initialWaitSeconds: this.initialWaitSeconds,\n                maxRounds: this.maxRounds,\n                blockAgeLimitSeconds: this.blockAgeLimitSeconds,\n                timeoutSeconds: this.timeoutSeconds,\n              },\n              deps.logger,\n            )\n            return Promise.all(\n              batch.map((query) => {\n                const fetch = async () => {\n                  try {\n                    return await query.contract.connect(provider.provider)[query.fn](...query.input)\n                  } catch (e) {\n                    if (ethers.isCallException(e) || ethers.isError(e, 'BAD_DATA')) {\n                      /*\n                      If there is a CALL_EXCEPTION, we don't want to abort the entire inspection.\n                      Sometimes, certain inspections are used for multiple contract versions, and one\n                      or two calls may not exist for a particular version.\n                      */\n                      return '!!ERROR!!'\n                    }\n\n                    throw e\n                  }\n                }\n\n                return fetch()\n              }),\n            )\n          }),\n        )\n      ).flat()\n\n      /*\n      Currently, we run makeComparisonData for each inspection command. Some\n      commands may define event queries or additional RPC calls here.\n      */\n      let start = 0\n      let promises = allInspectionCmds.map((cmd) => {\n        const promise = cmd.config.makeComparisionData(this.defaultProvider, cmd.inspectionCtx)(\n          results.slice(start, start + cmd.fns.length),\n          cmd.userInput,\n          cmd.contractAddress,\n          cmd.contractFactory,\n        )\n        start += cmd.fns.length\n        return promise\n      })\n\n      const data = await Promise.all(promises)\n\n      const inspectionResults = allInspectionCmds.map((cmd, i) => {\n        return cmd.config.inspect ? cmd.config.inspect(cmd.userInput, data[i]) : []\n      })\n\n      deps.logger.info('Inspection Results:')\n      deps.logger.log(data)\n\n      const report = {\n        data: {\n          data: data.map((datum, i) => ({\n            data: datum,\n            contract: allInspectionCmds[i].contractAddress,\n            inspection: inspectionResults[i],\n          })),\n          contract: 'n/a',\n          inspection: [],\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"]}

@@ -18,2 +18,3 @@ import { ContractFactory, AbstractSigner as EthersWallet, Provider as EthersProvider, TransactionResponse, TransactionRequest } from 'ethers';

multiNodeEnabled?: boolean;
timeoutSeconds?: number;
safeMasterCopy?: string;

@@ -20,0 +21,0 @@ safeProxyFactory?: string;

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZXZtL2RlcGVuZGVuY2llcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29udHJhY3RGYWN0b3J5LFxuICBBYnN0cmFjdFNpZ25lciBhcyBFdGhlcnNXYWxsZXQsXG4gIFByb3ZpZGVyIGFzIEV0aGVyc1Byb3ZpZGVyLFxuICBUcmFuc2FjdGlvblJlc3BvbnNlLFxuICBUcmFuc2FjdGlvblJlcXVlc3QsXG59IGZyb20gJ2V0aGVycydcbmltcG9ydCB7IERlcGVuZGVuY2llcyB9IGZyb20gJy4uLy4uL2NvcmUvZGVwZW5kZW5jaWVzJ1xuXG5leHBvcnQgaW50ZXJmYWNlIEVudiBleHRlbmRzIE5ldHdvcmtFbnYge1xuICBwaz86IHN0cmluZ1xuICB3aXRoTGVkZ2VyPzogc3RyaW5nXG4gIC8vIFNvbWUgY29tbWFuZHMgbWF5IG5lZWQgYWNjZXNzIHRvIG11bHRpcGxlIG5ldHdvcmsgZW52aXJvbm1lbnRzXG4gIG5ldHdvcmtzPzoge1xuICAgIFtuZXR3b3JrOiBzdHJpbmddOiBOZXR3b3JrRW52XG4gIH1cbn1cblxudHlwZSBOZXR3b3JrRW52ID0ge1xuICBwcm92aWRlclVybDogc3RyaW5nXG4gIGZhbGxiYWNrVXJscz86IHN0cmluZ1tdXG4gIGluaXRpYWxXYWl0U2Vjb25kcz86IG51bWJlclxuICBtYXhSb3VuZHM/OiBudW1iZXJcbiAgbWF4UnBjQ2FsbHNQZXJCYXRjaD86IG51bWJlclxuICBibG9ja0FnZUxpbWl0U2Vjb25kcz86IG51bWJlclxuICBtdWx0aU5vZGVFbmFibGVkPzogYm9vbGVhblxuXG4gIC8vIE5PVEU6IGV2bS1nYXVudGxldCBzaG91bGQgbm90IG5lZWQgYmUgYXdhcmUgb2YgdGhlIHNhZmUgZW52IHZhcnNcbiAgLy8gQmUgY2FyZWZ1bCB3aGVuIGFkZGluZyBuZXcgZW52IHZhcnMgaGVyZVxuICBzYWZlTWFzdGVyQ29weT86IHN0cmluZ1xuICBzYWZlUHJveHlGYWN0b3J5Pzogc3RyaW5nXG4gIHNhZmVNdWx0aXNlbmQ/OiBzdHJpbmdcbiAgc2FmZUV4ZWN1dG9yPzogc3RyaW5nXG4gIHNhZmVBZGRyZXNzPzogc3RyaW5nXG4gIGdhc1ByaWNlPzogc3RyaW5nIC8vIGluIFdlaVxuICBnYXNMaW1pdD86IHN0cmluZyAvLyBpbiBnYXMgdW5pdHNcblxuICAvKlxuICBQYXJhbWV0ZXJzIHRoYXQgY29uZmlndXJlIGV2ZW50IHF1ZXJpZXMuXG4gIGJsb2NrUmFuZ2VQZXJFdmVudFF1ZXJ5IGlzIHRoZSBudW1iZXIgb2YgYmxvY2tzIHRvIHNlYXJjaCBpbiBhIHNpbmdsZSByZXF1ZXN0LlxuICBldmVudFF1ZXJpZXNQZXJCYXRjaCBpcyB0aGUgbnVtYmVyIG9mIHF1ZXJpZXMgdGhhdCBjYW4gYmUgcnVuIGNvbmN1cnJlbnRseS5cbiAgKi9cbiAgYmxvY2tSYW5nZVBlckV2ZW50UXVlcnk/OiBzdHJpbmdcbiAgZXZlbnRRdWVyaWVzUGVyQmF0Y2g/OiBzdHJpbmdcbn1cblxuZXhwb3J0IHR5cGUgRVZNRGVwZW5kZW5jaWVzID0gRGVwZW5kZW5jaWVzPFxuICBFdGhlcnNQcm92aWRlcixcbiAgQ29udHJhY3RGYWN0b3J5LFxuICBUcmFuc2FjdGlvblJlcXVlc3QsXG4gIFRyYW5zYWN0aW9uUmVzcG9uc2UsXG4gIEV0aGVyc1dhbGxldCxcbiAgRW52XG4+XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZXZtL2RlcGVuZGVuY2llcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29udHJhY3RGYWN0b3J5LFxuICBBYnN0cmFjdFNpZ25lciBhcyBFdGhlcnNXYWxsZXQsXG4gIFByb3ZpZGVyIGFzIEV0aGVyc1Byb3ZpZGVyLFxuICBUcmFuc2FjdGlvblJlc3BvbnNlLFxuICBUcmFuc2FjdGlvblJlcXVlc3QsXG59IGZyb20gJ2V0aGVycydcbmltcG9ydCB7IERlcGVuZGVuY2llcyB9IGZyb20gJy4uLy4uL2NvcmUvZGVwZW5kZW5jaWVzJ1xuXG5leHBvcnQgaW50ZXJmYWNlIEVudiBleHRlbmRzIE5ldHdvcmtFbnYge1xuICBwaz86IHN0cmluZ1xuICB3aXRoTGVkZ2VyPzogc3RyaW5nXG4gIC8vIFNvbWUgY29tbWFuZHMgbWF5IG5lZWQgYWNjZXNzIHRvIG11bHRpcGxlIG5ldHdvcmsgZW52aXJvbm1lbnRzXG4gIG5ldHdvcmtzPzoge1xuICAgIFtuZXR3b3JrOiBzdHJpbmddOiBOZXR3b3JrRW52XG4gIH1cbn1cblxudHlwZSBOZXR3b3JrRW52ID0ge1xuICBwcm92aWRlclVybDogc3RyaW5nXG4gIGZhbGxiYWNrVXJscz86IHN0cmluZ1tdXG4gIGluaXRpYWxXYWl0U2Vjb25kcz86IG51bWJlclxuICBtYXhSb3VuZHM/OiBudW1iZXJcbiAgbWF4UnBjQ2FsbHNQZXJCYXRjaD86IG51bWJlclxuICBibG9ja0FnZUxpbWl0U2Vjb25kcz86IG51bWJlclxuICBtdWx0aU5vZGVFbmFibGVkPzogYm9vbGVhblxuICB0aW1lb3V0U2Vjb25kcz86IG51bWJlclxuXG4gIC8vIE5PVEU6IGV2bS1nYXVudGxldCBzaG91bGQgbm90IG5lZWQgYmUgYXdhcmUgb2YgdGhlIHNhZmUgZW52IHZhcnNcbiAgLy8gQmUgY2FyZWZ1bCB3aGVuIGFkZGluZyBuZXcgZW52IHZhcnMgaGVyZVxuICBzYWZlTWFzdGVyQ29weT86IHN0cmluZ1xuICBzYWZlUHJveHlGYWN0b3J5Pzogc3RyaW5nXG4gIHNhZmVNdWx0aXNlbmQ/OiBzdHJpbmdcbiAgc2FmZUV4ZWN1dG9yPzogc3RyaW5nXG4gIHNhZmVBZGRyZXNzPzogc3RyaW5nXG4gIGdhc1ByaWNlPzogc3RyaW5nIC8vIGluIFdlaVxuICBnYXNMaW1pdD86IHN0cmluZyAvLyBpbiBnYXMgdW5pdHNcblxuICAvKlxuICBQYXJhbWV0ZXJzIHRoYXQgY29uZmlndXJlIGV2ZW50IHF1ZXJpZXMuXG4gIGJsb2NrUmFuZ2VQZXJFdmVudFF1ZXJ5IGlzIHRoZSBudW1iZXIgb2YgYmxvY2tzIHRvIHNlYXJjaCBpbiBhIHNpbmdsZSByZXF1ZXN0LlxuICBldmVudFF1ZXJpZXNQZXJCYXRjaCBpcyB0aGUgbnVtYmVyIG9mIHF1ZXJpZXMgdGhhdCBjYW4gYmUgcnVuIGNvbmN1cnJlbnRseS5cbiAgKi9cbiAgYmxvY2tSYW5nZVBlckV2ZW50UXVlcnk/OiBzdHJpbmdcbiAgZXZlbnRRdWVyaWVzUGVyQmF0Y2g/OiBzdHJpbmdcbn1cblxuZXhwb3J0IHR5cGUgRVZNRGVwZW5kZW5jaWVzID0gRGVwZW5kZW5jaWVzPFxuICBFdGhlcnNQcm92aWRlcixcbiAgQ29udHJhY3RGYWN0b3J5LFxuICBUcmFuc2FjdGlvblJlcXVlc3QsXG4gIFRyYW5zYWN0aW9uUmVzcG9uc2UsXG4gIEV0aGVyc1dhbGxldCxcbiAgRW52XG4+XG4iXX0=

@@ -31,4 +31,4 @@ import { IProvider, MultiNodeProviderConfig } from '../../core';

private constructor();
static create: (config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>, logger: typeof coreLogger, testingMode?: boolean) => Promise<MultiNodeProvider>;
static create: (config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>, logger: typeof coreLogger) => Promise<MultiNodeProvider>;
}
//# sourceMappingURL=index.d.ts.map

@@ -139,6 +139,6 @@ "use strict";

_a = MultiNodeProvider;
MultiNodeProvider.create = async (config, logger, testingMode = false) => {
const provider = await multiNodeProvider_1.MultiNodeJsonRpcProvider.create(config, logger, testingMode);
MultiNodeProvider.create = async (config, logger) => {
const provider = await multiNodeProvider_1.MultiNodeJsonRpcProvider.create(config, logger);
return new MultiNodeProvider(provider);
};
//# 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, MultiNodeProviderConfig } from '../../core'\nimport {\n  Provider as EthersProvider,\n  TransactionResponse as Transaction,\n  TransactionRequest,\n  AbstractSigner as EthersWallet,\n  JsonRpcProvider,\n  ContractFactory,\n  ErrorDescription,\n  JsonRpcApiProviderOptions,\n} from 'ethers'\nimport { EVMTransaction } from '../transaction'\nimport { IWallet } from '../../core/wallet'\nimport { MultiNodeJsonRpcProvider } from './multiNodeProvider'\nimport { logger as coreLogger } from '@chainlink/gauntlet-core/dist/utils'\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\nexport class Provider implements EVMProvider {\n  provider: EthersProvider\n\n  constructor(provider: EthersProvider) {\n    this.provider = provider\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>, contractFactory: ContractFactory, input: any) => {\n    const txReq = await contractFactory.getDeployTransaction(...input)\n    return await this.signAndSend(wallet, [txReq], contractFactory)\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?.info?.error)\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?.toString())\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.info?.error)\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: BigInt(call.value),\n      })\n      return gasUsed.toString()\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.info?.error)\n      if (decodedError) {\n        throw new Error(\n          `Transaction simulation failed with error: ${decodedError.name} with signature ${JSON.stringify(\n            decodedError.sighash,\n          )} and message \\\"${decodedError.message}\\\" and reason=\\\"${decodedError.reason}\\\"`,\n        )\n      }\n      throw err\n    }\n  }\n\n  parseContractError = (\n    contract: ContractFactory,\n    error: any,\n  ): { name: string; sighash: string; message: string; reason: string } => {\n    if (!error) return\n\n    let parsedErrResult: ErrorDescription\n    try {\n      if (!!error?.data?.result) {\n        // Mainly for tests, as Ganache still returns data in this field\n        parsedErrResult = contract.interface.parseError(error.data.result)\n      } else if (!!error?.data) {\n        parsedErrResult = contract.interface.parseError(error.data)\n      }\n    } catch (e) {\n      throw new Error(`Failed to parse revert data: ${e.message}`)\n    }\n    return {\n      name: error.name ?? 'Error not identified',\n      sighash: parsedErrResult?.fragment?.selector ?? 'Selector not identified',\n      message: error.message ?? 'Message not identified',\n      reason: error.data?.reason ?? 'Reason not identified',\n    }\n  }\n}\n\nexport const makeProvider = (baseUrl: string) => {\n  return new Provider(new JsonRpcProvider(baseUrl))\n}\n\nexport const makeMultiNodeProvider = async (\n  config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>,\n  logger: typeof coreLogger,\n) => {\n  return await MultiNodeProvider.create(config, logger)\n}\n\nexport class MultiNodeProvider extends Provider {\n  provider: MultiNodeJsonRpcProvider\n\n  private constructor(provider: MultiNodeJsonRpcProvider) {\n    super(provider)\n  }\n\n  static create = async (\n    config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>,\n    logger: typeof coreLogger,\n    testingMode = false,\n  ) => {\n    const provider = await MultiNodeJsonRpcProvider.create(config, logger, testingMode)\n\n    return new MultiNodeProvider(provider)\n  }\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, MultiNodeProviderConfig } from '../../core'\nimport {\n  Provider as EthersProvider,\n  TransactionResponse as Transaction,\n  TransactionRequest,\n  AbstractSigner as EthersWallet,\n  JsonRpcProvider,\n  ContractFactory,\n  ErrorDescription,\n  JsonRpcApiProviderOptions,\n} from 'ethers'\nimport { EVMTransaction } from '../transaction'\nimport { IWallet } from '../../core/wallet'\nimport { MultiNodeJsonRpcProvider } from './multiNodeProvider'\nimport { logger as coreLogger } from '@chainlink/gauntlet-core/dist/utils'\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\nexport class Provider implements EVMProvider {\n  provider: EthersProvider\n\n  constructor(provider: EthersProvider) {\n    this.provider = provider\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>, contractFactory: ContractFactory, input: any) => {\n    const txReq = await contractFactory.getDeployTransaction(...input)\n    return await this.signAndSend(wallet, [txReq], contractFactory)\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?.info?.error)\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?.toString())\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.info?.error)\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: BigInt(call.value),\n      })\n      return gasUsed.toString()\n    } catch (err) {\n      const decodedError = this.parseContractError(contract, err?.info?.error)\n      if (decodedError) {\n        throw new Error(\n          `Transaction simulation failed with error: ${decodedError.name} with signature ${JSON.stringify(\n            decodedError.sighash,\n          )} and message \\\"${decodedError.message}\\\" and reason=\\\"${decodedError.reason}\\\"`,\n        )\n      }\n      throw err\n    }\n  }\n\n  parseContractError = (\n    contract: ContractFactory,\n    error: any,\n  ): { name: string; sighash: string; message: string; reason: string } => {\n    if (!error) return\n\n    let parsedErrResult: ErrorDescription\n    try {\n      if (!!error?.data?.result) {\n        // Mainly for tests, as Ganache still returns data in this field\n        parsedErrResult = contract.interface.parseError(error.data.result)\n      } else if (!!error?.data) {\n        parsedErrResult = contract.interface.parseError(error.data)\n      }\n    } catch (e) {\n      throw new Error(`Failed to parse revert data: ${e.message}`)\n    }\n    return {\n      name: error.name ?? 'Error not identified',\n      sighash: parsedErrResult?.fragment?.selector ?? 'Selector not identified',\n      message: error.message ?? 'Message not identified',\n      reason: error.data?.reason ?? 'Reason not identified',\n    }\n  }\n}\n\nexport const makeProvider = (baseUrl: string) => {\n  return new Provider(new JsonRpcProvider(baseUrl))\n}\n\nexport const makeMultiNodeProvider = async (\n  config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>,\n  logger: typeof coreLogger,\n) => {\n  return await MultiNodeProvider.create(config, logger)\n}\n\nexport class MultiNodeProvider extends Provider {\n  provider: MultiNodeJsonRpcProvider\n\n  private constructor(provider: MultiNodeJsonRpcProvider) {\n    super(provider)\n  }\n\n  static create = async (config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>, logger: typeof coreLogger) => {\n    const provider = await MultiNodeJsonRpcProvider.create(config, logger)\n\n    return new MultiNodeProvider(provider)\n  }\n}\n"]}

@@ -1,22 +0,19 @@

import { JsonRpcApiProviderOptions, JsonRpcProvider, Network, FeeData, AddressLike, BlockTag, BigNumberish, TransactionRequest, TransactionResponse, Block, TransactionReceipt, Filter, FilterByBlockHash, Log, AbstractProvider } from 'ethers';
import { JsonRpcApiProviderOptions, Network, FeeData, AddressLike, BlockTag, BigNumberish, TransactionRequest, TransactionResponse, Block, TransactionReceipt, Filter, FilterByBlockHash, Log, AbstractProvider } from 'ethers';
import { logger as coreLogger } from '@chainlink/gauntlet-core/dist/utils';
import { MultiNodeProviderConfig } from '../../core';
type ProviderAndUrl = {
provider: JsonRpcProvider;
url: string;
};
type JsonRpcBatchCall = {
method: string;
params: any[];
}[];
type StrictJsonRpcApiProviderOptions = {
batchStallTime: number;
batchMaxCount: number;
} & JsonRpcApiProviderOptions;
export declare class MultiNodeJsonRpcProvider extends AbstractProvider {
readonly providers: ProviderAndUrl[];
readonly urls: string[];
readonly providerOpts: StrictJsonRpcApiProviderOptions;
readonly initialWaitSeconds: number;
readonly maxRounds: number;
readonly blockAgeLimitSeconds: number;
readonly timeoutSeconds: number;
readonly skipHealthCheck: boolean;
private readonly logger;
private readonly startingRound;
private readonly startingProvider;
private readonly batchStallTimeMs;
private readonly batchMaxCount;
private readonly initialWaitSeconds;
private readonly maxRounds;
private readonly testingMode;
private readonly labelColor;

@@ -27,16 +24,15 @@ private readonly valueColor;

private pendingCalls;
private requestCounts;
private payloads;
constructor(network: Network, providers: ProviderAndUrl[], logger: typeof coreLogger, batchStallTimeMs: number, batchMaxCount: number, initialWaitSeconds: number, maxRounds: number, testingMode: boolean);
getRequestCounts(): number[];
getNewPayloads(): JsonRpcBatchCall[][];
private logRpc;
private readonly healthStatuses;
private constructor();
static create(config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>, logger: typeof coreLogger): Promise<MultiNodeJsonRpcProvider>;
destroy(): void;
private endOfRoundReached;
private completedMaxRounds;
static create(config: MultiNodeProviderConfig<JsonRpcApiProviderOptions>, logger: typeof coreLogger, testingMode?: boolean): Promise<MultiNodeJsonRpcProvider>;
private isUnretryableEthersError;
private validateNetwork;
private logRpc;
private runCall;
private startNewAttempt;
private runWithBackoffAndFailover;
private executeBatchWithDelay;
private executeBatch;
private addCallToBatch;

@@ -43,0 +39,0 @@ private startBatchCountdown;

{
"name": "@chainlink/evm-gauntlet",
"version": "0.0.0-develop-20240409214435",
"version": "0.0.0-develop-20240430133909",
"description": "Gauntlet EVM",

@@ -33,4 +33,4 @@ "keywords": [

"devDependencies": {
"@chainlink/evm-gauntlet-token": "0.0.0-develop-20240409214435"
"@chainlink/evm-gauntlet-token": "*"
}
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

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

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc