7 releases (3 major breaking)

3.0.0 Sep 17, 2024
2.0.0 Sep 16, 2024
1.0.0 Jul 16, 2024
0.1.3 Jul 15, 2024
0.1.2 Jun 26, 2024

#34 in #dfinity

Download history 51/week @ 2024-07-29 28/week @ 2024-08-05 109/week @ 2024-08-12 103/week @ 2024-08-19 228/week @ 2024-08-26 158/week @ 2024-09-02 164/week @ 2024-09-09 552/week @ 2024-09-16 278/week @ 2024-09-23 262/week @ 2024-09-30 61/week @ 2024-10-07 188/week @ 2024-10-14 161/week @ 2024-10-21 203/week @ 2024-10-28 172/week @ 2024-11-04 49/week @ 2024-11-11

590 downloads per month
Used in 2 crates

Apache-2.0

21KB
519 lines

How was this library created?

  • used didc to generate the rust bindings from the evm rpc canister did file
  • added call_with_payment128 to functions that expect cycles
  • derive Debug and Clone trait for types for convenience

How to use this library?

  • make sure you deploy the evm rpc canister to its mainnet id locally (7hfb6-caaaa-aaaar-qadga-cai)
    "evm_rpc": {
      "type": "custom",
      "candid": "https://github.com/internet-computer-protocol/evm-rpc-canister/releases/latest/download/evm_rpc.did",
      "wasm": "https://github.com/internet-computer-protocol/evm-rpc-canister/releases/latest/download/evm_rpc.wasm.gz",
      "remote": {
        "id": {
          "ic": "7hfb6-caaaa-aaaar-qadga-cai"
        }
      },
      "specified_id": "7hfb6-caaaa-aaaar-qadga-cai",
      "init_arg": "(record { nodesInSubnet = 28 })"
    }
    
  • if you deploy your own evm rpc canister, you can use the EvmRpcCanister struct to initiate the canister with your own canister id
    pub const CANISTER_ID: Principal =
      Principal::from_slice(b"\x00\x00\x00\x00\x02\x30\x00\xCC\x01\x01"); // 7hfb6-caaaa-aaaar-qadga-cai
    pub const EVM_RPC: EvmRpcCanister = EvmRpcCanister(CANISTER_ID);
    
  • import the libary in your rust project
    [dependencies]
    evm_rpc_canister_types = 0.1
    
  • import the crate where needed, e.g.
    use evm_rpc_canister_types::{
      BlockTag, GetBlockByNumberResult, GetLogsArgs, GetLogsResult, HttpOutcallError,
      MultiGetBlockByNumberResult, MultiGetLogsResult, RejectionCode, RpcError, EVM_RPC,
    };
    
  • the EVM_RPC struct exposes the EVM RPC canisters interface and is used to make inter canister calls to it
    let (result,) = EVM_RPC
      .eth_get_block_by_number(rpc_providers, None, block_tag, cycles)
      .await
      .expect("Call failed");
    

Dependencies

~11–23MB
~307K SLoC