Skip to content

lightlink-network/hummingbird-client

Repository files navigation

LightLink Hummingbird

Test, Build Image & Push to ECR

Note

Hummingbird is currently in beta. Please report any issues to the GitHub repository.

LightLink Hummingbird preview screenshot

Hummingbird is a light client for interacting with the LightLink Protocol.

It is designed to work in unison with the hummingbird-contracts repository.

Documentation & deployed contract addresses can be found here.

Usage

hb rollup info  # Get the current rollup state
hb rollup info --num <rblock_number> --bundle # View the bundled L2 block hashes in an L1 rblock
hb rollup next  # [Publisher Only] Generate the next rollup block
hb rollup start # [Publisher Only] Start the rollup loop to generate and submit bundles
hb challenger challenge-da <rblock_number> <bundle_number> # Challenge data availability
hb defender defend-da <rblock_hash> <bundle_number> # Defend data availability
hb defender info-da <rblock_hash> <bundle_number> # Provides info on an existing challenge
hb defender prove-da <rblock_hash> <bundle_number> # Prove data availability
hb defender start # Start the defender loop to watch and defend challenges
hb defender provide --type=header <rblock_hash> <l2_block_hash> # Get header for <l2_block_hash> from Celestia and provide it to L1 ChainOracle
hb defender provide --type=tx <rblock_hash> <l2_tx_hash> # Get tx for <l2_tx_hash> from Celestia and provide it to L1 ChainOracle

Dev Commands

hbdev fetch header <rblock_hash> <l2block_hash> # Fetch and decode an L2 block header from Celesta
hbdev fetch header <rblock_hash> <l2block_hash> --proof # Fetch and return celestia DA proof for an L2 block header
hbdev fetch header <rblock_hash> <l2block_hash> --proof --check-proof # Verify the proof returned by Celestia
hbdev fetch tx <tx_hash> # Fetch and decode an L2 transaction from Celestia
hbdev fetch tx <tx_hash> --proof # Fetch and return celestia DA proof for an L2 transaction
hbdev fetch tx <tx_hash> --proof --check-proof # Verify the proof returned by Celestia
hbdev inspect <rblock_hash> --header --bundle --stats --shares --txns # Inspect will inspect a rollup block
hbdev pointer <rblock_hash> --format=pretty --verify # Pointer finds the Celestia data pointer for a given hash

The following root flags are available for all commands:

--config-path <path> # Path to the config file
--log-level <level> # Log level (debug, info, warn, error)
--log-format <format> # Log format (json, text)
--log-source <bool> # Log source file and line

Installation

Prerequisites

  • Golang (v1.21.5 or higher) installed. Go version can be checked with $ go version

Option 1: Install from source (MacOS/Linux)

Build the binary from source:

cd $HOME
rm -rf hummingbird-client
git clone https://github.com/lightlink-network/hummingbird-client.git
cd hummingbird-client
git checkout tags/v1.1.1-beta -b v1.1.1-beta
make build

Install the binary to your $GOPATH/bin:

make install

Check the installation was successful:

hb --help

Note: If your go path is not set in your system path, the binary can be run directly from the ./build directory:

./build/hb_darwin_amd64 --help

Option 2: Use pre-built binary

Download the latest release from here

Configuration

Hummingbird requires a configuration file to run. A sample configuration file is provided in the repository here. Copy this file and rename it to config.yaml. Then fill in the required fields.

cp config.example.yaml config.yaml

A single environment variable ETH_KEY is required to be set. This is the private key of the Ethereum account that will be used to sign transactions. This account must have sufficient funds to pay for gas fees.

export ETH_KEY=0x...

Note: configuration file config.yaml path can be specified with the --config-path flag. If not specified, the default path is ./config.yaml

see hb --help for more information

HummingBird