/celo-light-client

Celo Light Client (IBC compatible)

Primary LanguageRust

Build Status

Celo Light Client

The library provides a lightest-sync mode, that enables a quick, secure, and cheap way to synchronize IBFT consensus state with a Celo Blockchain node.

The codebase is split into two parts:

  • library - a subset of Celo Blockchain building blocks, such as data structures (ie. Header, IBFT) or functionalities (ie. serialization, consensus state management)
  • contract - an (optional) IBC compatible light client contract, intended to be run on Cosmos Blockchain as WASM binary

ultralight-sync explained

In the nutshell, the validator set for the current epoch is computed by downloading the last header of each previous epoch and applying the validator set diff. The latest block header is then verified by checking that at least two-thirds of the validator set for the current epoch signed the block header. Ultralight mode download approximately 30,000 times fewer headers than light nodes in order to sync the latest block (assuming 3-second block periods and 1-day epochs).

Example

An example program that utilizes lightest-sync library is placed in the examples/lightest-sync. It uses celo-blockchain node to fetch epoch headers, built up the validator set, and verify the latest available header.

You may spawn up example program via:

$ docker-compose up --abort-on-container-exit

Light Client

The CosmWasm contract is gated by wasm-contract feature:

$ rustup target add wasm32-unknown-unknown
$ cargo build --release --features wasm-contract --target wasm32-unknown-unknown

To compile optimized binary run:

$ make wasm-optimized
$ stat target/wasm32-unknown-unknown/release/celo.wasm

Demo

asciicast