Skip to content

Latest commit

 

History

History

bolt-cli

Bolt CLI

The Bolt CLI is a collection of command-line tools for interacting with Bolt protocol.

Installation

Prerequisites:

Once you have the necessary prerequisites, you can build the binary in the following way:

# clone the Bolt repository if you haven't already
git clone [email protected]:chainbound/bolt.git

# navigate to the Bolt CLI package directory
cd bolt-cli

# build and install the binary on your machine
cargo install --path . --force --locked

# test the installation
bolt --version

Usage

Available commands:

  • delegate - Generate BLS delegation messages for the Constraints API.
  • pubkeys - List available BLS public keys from various key sources.
  • send - Send a preconfirmation request to a Bolt sidecar.
  • validators - Subcommand for bolt validators.
  • operators - Subcommand for bolt operators.
  • generate - Subcommand for generating bolt related data.

delegate

The delegate command generates signed delegation messages for the Constraints API. To learn more about the Constraints API, please refer to the Bolt documentation.

The delegate command supports different key sources:

  • Local BLS secret keys (as hex-encoded strings) via secret-keys
  • Local EIP-2335 filesystem keystore directories via local-keystore
  • Remote Dirk keystore via dirk (requires TLS credentials)
  • Remote Web3Signer keystore via web3signer
Usage
❯ bolt delegate --help

Generate BLS delegation or revocation messages

Usage: bolt delegate [OPTIONS] --delegatee-pubkey <DELEGATEE_PUBKEY> <COMMAND>

Commands:
secret-keys     Use local secret keys to generate the signed messages
local-keystore  Use an EIP-2335 filesystem keystore directory to generate the signed messages
dirk            Use a remote DIRK keystore to generate the signed messages
web3signer      Use a remote web3signer keystore to generate the signed messages
help            Print this message or the help of the given subcommand(s)

Options:
    --delegatee-pubkey <DELEGATEE_PUBKEY>
        The BLS public key to which the delegation message should be signed

        [env: DELEGATEE_PUBKEY=]

    --out <OUT>
        The output file for the delegations

        [env: OUTPUT_FILE_PATH=]
        [default: delegations.json]

    --chain <CHAIN>
        The chain for which the delegation message is intended

        [env: CHAIN=]
        [default: mainnet]
        [possible values: mainnet, holesky, helder, kurtosis]

    --action <ACTION>
        The action to perform. The tool can be used to generate delegation or revocation messages (default: delegate)

        [env: ACTION=]
        [default: delegate]

        Possible values:
        - delegate: Create a delegation message
        - revoke:   Create a revocation message

-h, --help
        Print help (see a summary with '-h')
Examples
  1. Generating a delegation using a local BLS secret key
bolt delegate \
  --delegatee-pubkey 0x8d0edf4fe9c80cd640220ca7a68a48efcbc56a13536d6b274bf3719befaffa13688ebee9f37414b3dddc8c7e77233ce8 \
  --chain holesky \
  secret-keys --secret-keys 642e0d33fde8968a48b5f560c1b20143eb82036c1aa6c7f4adc4beed919a22e3
  1. Generating a delegation using an ERC-2335 keystore directory
bolt delegate \
 --delegatee-pubkey 0x8d0edf4fe9c80cd640220ca7a68a48efcbc56a13536d6b274bf3719befaffa13688ebee9f37414b3dddc8c7e77233ce8 \
 --chain holesky \
 local-keystore --path test_data/lighthouse/validators --password-path test_data/lighthouse/secrets
  1. Generating a delegation using a remote DIRK keystore
bolt delegate \
  --delegatee-pubkey 0x83eeddfac5e60f8fe607ee8713efb8877c295ad9f8ca075f4d8f6f2ae241a30dd57f78f6f3863a9fe0d5b5db9d550b93 \
  --chain holesky \
  dirk --url https://localhost:9091 \
  --client-cert-path ./test_data/dirk/client1.crt \
  --client-key-path ./test_data/dirk/client1.key \
  --ca-cert-path ./test_data/dirk/security/ca.crt \
  --wallet-path wallet1 --passphrases secret
  1. Generating a delegation using a remote Web3Signer keystore
bolt delegate \
  --delegatee-pubkey 0x83eeddfac5e60f8fe607ee8713efb8877c295ad9f8ca075f4d8f6f2ae241a30dd57f78f6f3863a9fe0d5b5db9d550b93 \
  --chain holesky \
  web3signer --url https://localhost:9000 \
  --ca-cert-path ./test_data/web3signer/tls/web3signer.crt \
  --combined_pem_path ./test_data/web3signer/tls/combined.pem

pubkeys

The pubkeys command lists available BLS public keys from different key sources:

  • Local BLS secret keys (as hex-encoded strings) via secret-keys
  • Local EIP-2335 filesystem keystore directories via local-keystore
  • Remote Dirk keystore via dirk (requires TLS credentials)
  • Remote Web3Signer via web3signer
Usage
❯ bolt pubkeys --help

Output a list of pubkeys in JSON format

Usage: bolt pubkeys [OPTIONS] <COMMAND>

Commands:
  secret-keys     Use local secret keys to generate the signed messages
  local-keystore  Use an EIP-2335 filesystem keystore directory to generate the signed messages
  dirk            Use a remote DIRK keystore to generate the signed messages
  web3signer      Use a remote web3signer keystore to generate the signed messages
  help            Print this message or the help of the given subcommand(s)

Options:
      --out <OUT>  The output file for the pubkeys [env: OUTPUT_FILE_PATH=] [default: pubkeys.json]
  -h, --help       Print help
Examples
  1. Listing BLS public keys from a local secret key
bolt pubkeys secret-keys --secret-keys 642e0d33fde8968a48b5f560c1b20143eb82036c1aa6c7f4adc4beed919a22e3
  1. Listing BLS public keys from an ERC-2335 keystore directory
bolt pubkeys local-keystore \
  --path test_data/lighthouse/validators
  1. Listing BLS public keys from a remote DIRK keystore
bolt pubkeys dirk --url https://localhost:9091 \
  --client-cert-path ./test_data/dirk/client1.crt \
  --client-key-path ./test_data/dirk/client1.key \
  --ca-cert-path ./test_data/dirk/security/ca.crt \
  --wallet-path wallet1 --passphrases secret
  1. Listing BLS public keys from a remote Web3Signer keystore
bolt pubkeys web3signer --url https://localhost:9000 \
  --ca-cert-path ./test_data/web3signer/tls/web3signer.crt \
  --combined_pem_path ./test_data/web3signer/tls/combined.pem

send

The send command sends a preconfirmation request to a Bolt sidecar.

Usage
❯ bolt send --help

Send a preconfirmation request to a Bolt proposer

Usage: bolt send [OPTIONS] --private-key <PRIVATE_KEY>

Options:
      --bolt-rpc-url <BOLT_RPC_URL>
          Bolt RPC URL to send requests to and fetch lookahead info from

          [env: BOLT_RPC_URL=]
          [default: http://135.181.191.125:58017/rpc]

      --private-key <PRIVATE_KEY>
          The private key to sign the transaction with

          [env: PRIVATE_KEY]

      --override-bolt-sidecar-url <OVERRIDE_BOLT_SIDECAR_URL>
          The Bolt Sidecar URL to send requests to. If provided, this will override the canonical bolt RPC URL and disregard any registration information.

          This is useful for testing and development purposes.

          [env: OVERRIDE_BOLT_SIDECAR_URL=]

      --count <COUNT>
          How many transactions to send

          [env: TRANSACTION_COUNT=]
          [default: 1]

      --blob
          If set, the transaction will be blob-carrying (type 3)

          [env: BLOB=]

  -h, --help
          Print help (see a summary with '-h')
Examples
  1. Sending a preconfirmation request to a Bolt sidecar
bolt send --private-key $(openssl rand -hex 32)

validators

The validators subcommand contains functionality for bolt validators.

Usage
❯ bolt validators --help
Handle validators in the bolt network

Usage: bolt validators <COMMAND>

Commands:
  register  Register a batch of validators
  help      Print this message or the help of the given subcommand(s)

Options:
  -h, --help  Print help

operators

The operators subcommand contains functionality for bolt operators and interacting with restaking protocols like Symbiotic and EigenLayer.

Usage
❯ bolt operators --help
Handle operators in the bolt network

Usage: bolt operators <COMMAND>

Commands:
  eigenlayer  Commands to interact with EigenLayer and bolt
  symbiotic   Commands to interact with Symbiotic and bolt
  help        Print this message or the help of the given subcommand(s)

Options:
  -h, --help  Print help

❯ bolt operators eigenlayer --help
Commands to interact with EigenLayer and bolt

Usage: bolt operators eigenlayer <COMMAND>

Commands:
  deposit     Deposit into a strategy
  register    Register an operator into the bolt AVS
  deregister  Deregister an EigenLayer operator from the bolt AVS
  update-rpc  Update the operator RPC
  status      Check the status of an operator in the bolt AVS
  help        Print this message or the help of the given subcommand(s)

Options:
  -h, --help  Print help

❯ bolt operators symbiotic --help
Commands to interact with Symbiotic and bolt

Usage: bolt operators symbiotic <COMMAND>

Commands:
  register    Register into the bolt manager contract as a Symbiotic operator
  deregister  Deregister a Symbiotic operator from bolt
  update-rpc  Update the operator RPC
  status      Check the status of a Symbiotic operator
  help        Print this message or the help of the given subcommand(s)

Options:
  -h, --help  Print help

generate

The generate subcommand contains functionality for generating bolt related data like BLS keypairs.

Usage
❯ bolt generate --help
Useful data generation commands

Usage: bolt generate <COMMAND>

Commands:
  bls   Generate a BLS keypair
  help  Print this message or the help of the given subcommand(s)

Options:
  -h, --help  Print help

Security

The Bolt CLI is designed to be used offline. It does not require any network connections unless you are using the remote dirk key source. In that case, the tool will connect to the Dirk server with the provided TLS credentials.

The tool does not store any sensitive information beyond the duration of the execution. It is recommended to use the tool in a secure environment and to avoid storing any sensitive information in the shell history.

If you have any security concerns or have found a security issue/bug, please contact Chainbound on our official Discord or Twitter channels.