2 unstable releases

0.2.0 Aug 9, 2023
0.1.0 Aug 4, 2023

#51 in #signer

Download history 7/week @ 2024-02-14 21/week @ 2024-02-21 10/week @ 2024-02-28 1/week @ 2024-03-06 15/week @ 2024-03-13 1/week @ 2024-03-20 17/week @ 2024-03-27 36/week @ 2024-04-03

54 downloads per month
Used in 2 crates (via ethers-signers-browser-fr…)

MPL-2.0 license

28KB
618 lines

ethereum-provider

This project implements a Provider type which wraps the browser's window.ethereum for use in Rust, which is useful for wasm-based projects (e.g. front-ends).

Installation

cargo add ethereum-provider
ethereum-provider = "0.2.0"

Features

  • yew (optional): provides a hook, use_provider, which simplifies the interaction with the provider when using yew

Examples

use ethereum_provider::{Provider, ProviderError};
use web_sys::window;

# async fn foo() -> Result<(), Box<dyn std::error::Error>> {
// create a provider
let provider = Provider::new(&window().unwrap())?;

// request accounts
let v = provider.request::<()>("eth_requestAccounts".to_string(), None).await?;
println!("eth_requestAccounts: {:?}", v);
// or use the convenience method
let v = provider.request_accounts().await?;
println!("accounts: {:?}", v);
# Ok(())
# }

Yew examples

use ethereum_provider::yew::use_provider;
use yew::prelude::*;

#[function_component]
fn Wallet() -> Html {
    let status = use_provider();

    html! {
        <div>
            {
              match status {
                  Some(status) => match status {
                      Ok(status) => html! {
                        <div>
                          <pre>{ format!("Wallet: {:?}", status) }</pre>
                        </div>
                      },
                      Err(e) => html! { <pre>{ format!("Error: {:?}", e) }</pre> },
                  },
                  None => html! { <pre>{ "Loading wallet provider..." }</pre> },
              }
            }
        </div>
    }
}

Dependencies

~7–11MB
~218K SLoC