11 unstable releases (3 breaking)

1.0.0-beta.2 Dec 22, 2022
0.8.2 Jan 6, 2025
0.8.1 Dec 5, 2024
0.8.0 Sep 20, 2024
0.5.2 Mar 13, 2023

#1000 in Magic Beans

Download history 7054/week @ 2024-09-26 6891/week @ 2024-10-03 7883/week @ 2024-10-10 14035/week @ 2024-10-17 13903/week @ 2024-10-24 11304/week @ 2024-10-31 10596/week @ 2024-11-07 10985/week @ 2024-11-14 12471/week @ 2024-11-21 14661/week @ 2024-11-28 14839/week @ 2024-12-05 12885/week @ 2024-12-12 11207/week @ 2024-12-19 8018/week @ 2024-12-26 15293/week @ 2025-01-02 14096/week @ 2025-01-09

50,614 downloads per month
Used in 31 crates (13 directly)

Apache-2.0

125KB
3K SLoC

ethereum_ssz

SimpleSerialize (SSZ) implementation optimised for speed and security.

Maintained by Sigma Prime for use in Lighthouse, with an eye to being useful in the Rust Ethereum ecosystem more broadly. We welcome new contributors!

Please see the docs for more information.


lib.rs:

Provides encoding (serialization) and decoding (deserialization) in the SimpleSerialize (SSZ) format designed for use in Ethereum 2.0.

Adheres to the Ethereum 2.0 SSZ specification at v0.12.1.

Example

use ssz_derive::{Encode, Decode};
use ssz::{Decode, Encode};

#[derive(PartialEq, Debug, Encode, Decode)]
struct Foo {
    a: u64,
    b: Vec<u16>,
}

fn ssz_encode_decode_example() {
    let foo = Foo {
        a: 42,
        b: vec![1, 3, 3, 7]
    };

    let ssz_bytes: Vec<u8> = foo.as_ssz_bytes();

    let decoded_foo = Foo::from_ssz_bytes(&ssz_bytes).unwrap();

    assert_eq!(foo, decoded_foo);
}

See examples/ for manual implementations of the Encode and Decode traits.

Dependencies

~8MB
~145K SLoC