A high-performance command-line interface for contributing proofs to the Nexus network.
data:image/s3,"s3://crabby-images/525d3/525d38a7fea594bdffe21632177ddbe11a240d71" alt="Nexus Network visualization showing a distributed network of interconnected nodes with a 'Launch Network' button in the center"
We're building a global distributed prover network to unite the world's computers and power a new and better Internet: the Verifiable Internet. Connect to the beta and give it a try today.
The Nexus Network is a global distributed prover network that unites the world's computers to power a new and better Internet: the Verifiable Internet.
There have been two testnets so far:
- First testnet: October 08 – 28, 2024
- Second testnet: December 9 – 13, 2024
For the simplest one-command install (especially for local testing or personal use). This is what most users will want to do:
curl https://cli.nexus.xyz/ | sh
Note: This script automatically installs Rust if you don’t have it and prompts for Terms of Use in an interactive shell.
Alternatively, if you’ve already downloaded install.sh
:
./install.sh
The install.sh
script is designed to do few things:
- Install Rust if it's not already installed... and do it non-interactively if possible, so it does not bother the user.
- Prompt the user to accept the Terms of Use (via bash) and enter their node id (via the Rust program)
# this is the part in the install.sh script has the brittle `< /dev/tty` part within CI environments
(
cd "$REPO_PATH/clients/cli" || exit
cargo run --release -- --start --beta
) < /dev/tty
This combination of bash and Rust is a bit brittle in CI environments. Consider these approaches instead:
- Build from source:
git clone https://github.com/nexus-xyz/network-api cd network-api/clients/cli cargo build --release ./target/release/nexus-network --start --beta
- Download the script locally (and optionally set
NONINTERACTIVE=1
if you need it to run without prompts):curl -sSf https://cli.nexus.xyz/ -o install.sh chmod +x install.sh NONINTERACTIVE=1 ./install.sh
Building from source or running a downloaded script gives you more control over dependencies and versions, and avoids any unexpected prompts during automated runs.
If you want to simulate curl https://cli.nexus.xyz/ | sh
locally:
- In the project’s root directory, start a local server:
python3 -m http.server 8080
- In a separate terminal, run:
curl -sSf http://localhost:8080/public/install.sh | sh -x
- Observe the script output and verify installation logic.
If you don’t have Rust installed, you will be prompted to install it (unless NONINTERACTIVE=1
is set).
sudo apt update && sudo apt upgrade
sudo apt install build-essential pkg-config libssl-dev git-all protobuf-compiler
brew install git
- Install WSL.
- Follow the Linux instructions above within WSL.
Use of the CLI is subject to the Terms of Use. First-time users running interactively will be prompted to accept these terms. For non-interactive acceptance (e.g., in CI), run:
NONINTERACTIVE=1 sh install.sh
or set NONINTERACTIVE=1
before invoking the script.
During the CLI’s startup, you’ll be asked for your node ID (used on Testnet or Devnet).
- To skip prompts in a non-interactive environment (
NONINTERACTIVE=1
), manually place your node ID in~/.nexus/node-id
.
- Only the latest CLI version is supported.
- No prebuilt binaries yet.
- Proof cycle counting is coming soon.
- Program submission requires an API key (contact [email protected]).
- Network FAQ
- Discord Community
- Technical issues? Open an issue
network-api/
├── assets/ # Media for documentation
├── clients/
│ └── cli/ # Main CLI implementation
├── proto/ # Shared network interface definition
└── public/ # Files hosted at cli.nexus.xyz
See CONTRIBUTING.md for development setup and guidelines.