The Bolt CLI is a collection of command-line tools for interacting with Bolt protocol.
Prerequisites:
- Rust toolchain
- Protoc (as well as
libprotobuf-dev
for some Linux distributions)
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 git@github.com: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
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.
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
- Generating a delegation using a local BLS secret key
bolt delegate \
--delegatee-pubkey 0x8d0edf4fe9c80cd640220ca7a68a48efcbc56a13536d6b274bf3719befaffa13688ebee9f37414b3dddc8c7e77233ce8 \
--chain holesky \
secret-keys --secret-keys 642e0d33fde8968a48b5f560c1b20143eb82036c1aa6c7f4adc4beed919a22e3
- 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
- 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
- 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
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
- Listing BLS public keys from a local secret key
bolt pubkeys secret-keys --secret-keys 642e0d33fde8968a48b5f560c1b20143eb82036c1aa6c7f4adc4beed919a22e3
- Listing BLS public keys from an ERC-2335 keystore directory
bolt pubkeys local-keystore \
--path test_data/lighthouse/validators
- 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
- 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
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
- Sending a preconfirmation request to a Bolt sidecar
bolt send --private-key $(openssl rand -hex 32)
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
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
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
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.