Alloy connects applications to blockchains.
Alloy is a rewrite of ethers-rs
from the ground up, with exciting new
features, high performance, and excellent docs.
ethers-rs
will continue to be maintained until we have achieved
feature-parity in Alloy. No action is currently needed from devs.
This repository contains the following crates:
alloy-consensus
- Ethereum consensus interfacealloy-eips
- Ethereum Improvement Proprosal (EIP) implementationsalloy-genesis
- Ethereum genesis file definitionsalloy-json-rpc
- Core data types for JSON-RPC 2.0 clientsalloy-network
- Network abstraction for RPC typesalloy-node-bindings
- Ethereum execution-layer client bindingsalloy-providers
- Client trait for interacting with Ethereum-like RPC endpointsalloy-pubsub
- Ethereum JSON-RPC publish-subscribe provideralloy-rpc-client
- High-level Ethereum JSON-RPC client implementationalloy-rpc-types
- Ethereum JSON-RPC typesalloy-rpc-engine-types
- Ethereum execution-consensus layer (engine) API RPC typesalloy-rpc-trace-types
- Ethereum RPC trace types
alloy-signer
- Ethereum signer abstractionalloy-signer-aws
- AWS KMS signer implementationalloy-signer-gcp
- GCP KMS signer implementationalloy-signer-ledger
- Ledger signer implementationalloy-signer-trezor
- Trezor signer implementation
alloy-transport
- Low-level Ethereum JSON-RPC transport abstractionalloy-transport-http
- HTTP transport implementationalloy-transport-ipc
- IPC transport implementationalloy-transport-ws
- WS transport implementation
Alloy will keep a rolling MSRV (minimum supported rust version) policy of at least 6 months. When increasing the MSRV, the new Rust version must have been released at least six months ago. The current MSRV is 1.68.
Note that the MSRV is not increased automatically, and only as part of a minor release.
Thanks for your help improving the project! We are so happy to have you! We have a contributing guide to help you get involved in the Alloy project.
Pull requests will not be merged unless CI passes, so please ensure that your contribution follows the linting rules and passes clippy.
Because these crates are primarily json-rpc focused, we do not intend to support
no_std
for them at this time.
None of these crates would have been possible without the great work done in:
Licensed under either of Apache License, Version 2.0 or MIT license at your option.Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in these crates by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.