Skip to content

Call

Properties

struct {
  /// The target address.
  target: Address
  /// The calldata from the function that you want to run.
  callData: Hex
}

Call3

Properties

struct {
  /// The target address.
  target: Address
  /// Tells the contract weather to allow the call to fail or not.
  allowFailure: bool
  /// The calldata used to call the function you want to run.
  callData: Hex
}

Call3Value

Properties

struct {
  /// The target address.
  target: Address
  /// Tells the contract weather to allow the call to fail or not.
  allowFailure: bool
  /// The value sent in the call.
  value: u256
  /// The calldata from the function that you want to run.
  callData: Hex
}

Result

The result struct when calling the multicall contract.

Properties

struct {
  /// Weather the call was successfull or not.
  success: bool
  /// The return data from the function call.
  returnData: Hex
}

MulticallTargets

Arguments for the multicall3 function call

Properties

struct {
  function: Function
  target_address: Address
}

MulticallArguments

Type function that gets the expected arguments from the provided abi's.

Signature

pub fn MulticallArguments(comptime targets: []const MulticallTargets) type

aggregate3_abi

Multicall3 aggregate3 abi representation.

.{
    .name = "aggregate3",
    .type = .function,
    .stateMutability = .payable,
    .inputs = &.{
        .{
            .type = .{ .dynamicArray = &.{ .tuple = {} } },
            .name = "calls",
            .components = &.{
                .{ .type = .{ .address = {} }, .name = "target" },
                .{ .type = .{ .bool = {} }, .name = "allowFailure" },
                .{ .type = .{ .bytes = {} }, .name = "callData" },
            },
        },
    },
    .outputs = &.{
        .{
            .type = .{ .dynamicArray = &.{ .tuple = {} } },
            .name = "returnData",
            .components = &.{
                .{ .type = .{ .bool = {} }, .name = "success" },
                .{ .type = .{ .bytes = {} }, .name = "returnData" },
            },
        },
    },
}

Multicall

Wrapper around a rpc_client that exposes the multicall3 functions.

Signature

pub fn Multicall(comptime client: Clients) type

Error

Set of possible errors when running the multicall client.

Client.BasicRequestErrors || encoder.EncodeErrors || decoder.DecoderErrors

Init

Creates the initial state for the contract

Signature

pub fn init(rpc_client: *Client) !Self

Multicall3

Runs the selected multicall3 contracts. This enables to read from multiple contract by a single eth_call. Uses the contracts created here

To learn more about the multicall contract please go here

Signature

pub fn multicall3(
    self: *Self,
    comptime targets: []const MulticallTargets,
    function_arguments: MulticallArguments(targets),
    allow_failure: bool,
) Self.Error!AbiDecoded([]const Result)