# eth2.0-deposit-cli - [Introduction](#introduction) - [Tutorial for users](#tutorial-for-users) - [Build requirements](#build-requirements) - [For Linux or MacOS users](#for-linux-or-macos-users) - [Option 1. Download binary executable file](#option-1-download-binary-executable-file) - [Step 1. Installation](#step-1-installation) - [Step 2. Create keys and `deposit_data-*.json`](#step-2-create-keys-and-deposit_data-json) - [Arguments](#arguments) - [Successful message](#successful-message) - [Option 2. Build `deposit-cli` with native Python](#option-2-build-deposit-cli-with-native-python) - [Step 0. Python version checking](#step-0-python-version-checking) - [Step 1. Installation](#step-1-installation-1) - [Step 2. Create keys and `deposit_data-*.json`](#step-2-create-keys-and-deposit_data-json-1) - [Arguments](#arguments-1) - [Successful message](#successful-message-1) - [Option 3. Build `deposit-cli` with `virtualenv`](#option-3-build-deposit-cli-with-virtualenv) - [Step 0. Python version checking](#step-0-python-version-checking-1) - [Step 1. Installation](#step-1-installation-2) - [Step 2. Create keys and `deposit_data-*.json`](#step-2-create-keys-and-deposit_data-json-2) - [Arguments](#arguments-2) - [Successful message](#successful-message-2) - [Option 4. Use Docker image](#option-4-use-docker-image) - [Step 1. Build the docker image](#step-1-build-the-docker-image) - [Step 2. Create keys and `deposit_data-*.json`](#step-2-create-keys-and-deposit_data-json-3) - [Arguments](#arguments-3) - [Successful message](#successful-message-3) - [For Windows users](#for-windows-users) - [Option 1. Download binary executable file](#option-1-download-binary-executable-file-1) - [Step 1. Installation](#step-1-installation-3) - [Step 2. Create keys and `deposit_data-*.json`](#step-2-create-keys-and-deposit_data-json-4) - [Arguments](#arguments-4) - [Successful message](#successful-message-4) - [Option 2. Build `deposit-cli` with native Python](#option-2-build-deposit-cli-with-native-python-1) - [Step 0. Python version checking](#step-0-python-version-checking-2) - [Step 1. Installation](#step-1-installation-4) - [Step 2. Create keys and `deposit_data-*.json`](#step-2-create-keys-and-deposit_data-json-5) - [Arguments](#arguments-5) - [Successful message](#successful-message-5) - [Option 3. Build `deposit-cli` with `virtualenv`](#option-3-build-deposit-cli-with-virtualenv-1) - [Step 0. Python version checking](#step-0-python-version-checking-3) - [Step 1. Installation](#step-1-installation-5) - [Step 2. Create keys and `deposit_data-*.json`](#step-2-create-keys-and-deposit_data-json-6) - [Arguments](#arguments-6) - [Successful message](#successful-message-6) - [Development](#development) - [Install basic requirements](#install-basic-requirements) - [Install testing requirements](#install-testing-requirements) - [Run tests](#run-tests) ## Introduction `deposit-cli` is a tool for creating [EIP-2335 format](https://eips.ethereum.org/EIPS/eip-2335) BLS12-381 keystores and a corresponding `deposit_data*.json` file for [Ethereum 2.0 Launchpad](https://github.com/ethereum/eth2.0-deposit). - **Warning: Please generate your keystores on your own safe, completely offline device.** - **Warning: Please backup your mnemonic, keystores, and password securely.** Please read [Launchpad Validator FAQs](https://launchpad.ethereum.org/faq#keys) before generating the keys. You can find the audit report by Trail of Bits [here](https://github.com/trailofbits/publications/blob/master/reviews/ETH2DepositCLI.pdf). ## Tutorial for users ### Build requirements - [Python **3.7+**](https://www.python.org/about/gettingstarted/) - [pip3](https://pip.pypa.io/en/stable/installing/) ### For Linux or MacOS users #### Option 1. Download binary executable file ##### Step 1. Installation See [releases page](https://github.com/ethereum/eth2.0-deposit-cli/releases) to download and decompress the corresponding binary files. ##### Step 2. Create keys and `deposit_data-*.json` Run the following command to enter the interactive CLI: ```sh ./deposit ``` You can also run the tool with optional arguments: ```sh ./deposit --num_validators= --mnemonic_language=english --chain= --folder= ``` ###### Arguments You can use `--help` flag to see all arguments. | Argument | Type | Description | | -------- | -------- | -------- | | `--num_validators` | Non-negative integer | The number of signing keys you want to generate. Note that the child key(s) are generated via the same master key. | | `--mnemonic_language` | String. Options: `czech`, `chinese_traditional`, `chinese_simplified`, `english`, `spanish`, `italian`, `korean`. Default to `english` | The mnemonic language | | `--folder` | String. Pointing to `./validator_keys` by default | The folder path for the keystore(s) and deposit(s) | | `--chain` | String. `mainnet` by default | The chain setting for the signing domain. | ###### Successful message You will see the following messages after successfully generated the keystore(s) and the deposit(s): ``` Creating your keys. Saving your keystore(s). Creating your deposit(s). Verifying your keystore(s). Verifying your deposit(s). Success! Your keys can be found at: ``` #### Option 2. Build `deposit-cli` with native Python ##### Step 0. Python version checking Ensure you are using Python version >= Python3.7: ```sh python3 -V ``` ##### Step 1. Installation Install the dependencies: ```sh pip3 install -r requirements.txt python3 setup.py install ``` Or use the helper script: ```sh ./deposit.sh install ``` ##### Step 2. Create keys and `deposit_data-*.json` Run the following command to enter the interactive CLI: ```sh ./deposit.sh ``` You can also run the tool with optional arguments: ```sh ./deposit.sh --num_validators= --mnemonic_language=english --chain= --folder= ``` ###### Arguments See [here](#arguments) ###### Successful message See [here](#successful-message) #### Option 3. Build `deposit-cli` with `virtualenv` ##### Step 0. Python version checking Ensure you are using Python version >= Python3.7: ```sh python3 -V ``` ##### Step 1. Installation For the [virtualenv](https://virtualenv.pypa.io/en/latest/) users, you can create a new venv: ```sh pip3 install virtualenv virtualenv venv source venv/bin/activate ``` and install the dependencies: ```sh python3 setup.py install pip3 install -r requirements.txt ``` ##### Step 2. Create keys and `deposit_data-*.json` Run the following command to enter the interactive CLI: ```sh python3 ./eth2deposit/deposit.py ``` You can also run the tool with optional arguments: ```sh python3 ./eth2deposit/deposit.py --num_validators= --mnemonic_language=english --chain= --folder= ``` ###### Arguments See [here](#arguments) ###### Successful message See [here](#successful-message) #### Option 4. Use Docker image ##### Step 1. Build the docker image Run the following command to locally build the docker image: ```sh make build_docker ``` ##### Step 2. Create keys and `deposit_data-*.json` Run the following command to enter the interactive CLI: ```sh docker run -it --rm -v $(pwd)/validator_keys:/app/validator_keys ethereum/eth2.0-deposit-cli ``` You can also run the tool with optional arguments: ```sh docker run -it --rm -v $(pwd)/validator_keys:/app/validator_keys ethereum/eth2.0-deposit-cli --num_validators= --mnemonic_language=english --folder= ``` Example for 1 validator on the [Medalla testnet](https://medalla.launchpad.ethereum.org/) using english: ```sh docker run -it --rm -v $(pwd)/validator_keys:/app/validator_keys ethereum/eth2.0-deposit-cli --num_validators=1 --mnemonic_language=english --chain=medalla ``` ###### Arguments See [here](#arguments) ###### Successful message See [here](#successful-message) ---- ### For Windows users #### Option 1. Download binary executable file ##### Step 1. Installation See [releases page](https://github.com/ethereum/eth2.0-deposit-cli/releases) to download and decompress the corresponding binary files. ##### Step 2. Create keys and `deposit_data-*.json` Run the following command to enter the interactive CLI: ```sh deposit.exe ``` You can also run the tool with optional arguments: ```sh deposit.exe --num_validators= --mnemonic_language=english --chain= --folder= ``` ###### Arguments See [here](#arguments) ###### Successful message See [here](#successful-message) #### Option 2. Build `deposit-cli` with native Python ##### Step 0. Python version checking Ensure you are using Python version >= Python3.7 (Assume that you've installed Python 3 as the main Python): ```sh python -V ``` ##### Step 1. Installation Install the dependencies: ```sh pip3 install -r requirements.txt python setup.py install ``` Or use the helper script: ```sh sh deposit.sh install ``` ##### Step 2. Create keys and `deposit_data-*.json` Run the following command to enter the interactive CLI: ```sh sh deposit.sh ``` You can also run the tool with optional arguments: ```sh sh deposit.sh --num_validators= --mnemonic_language=english --chain= --folder= ``` ###### Arguments See [here](#arguments) ###### Successful message See [here](#successful-message) #### Option 3. Build `deposit-cli` with `virtualenv` ##### Step 0. Python version checking Ensure you are using Python version >= Python3.7 (Assume that you've installed Python 3 as the main Python): ```sh python -V ``` ##### Step 1. Installation For the [virtualenv](https://virtualenv.pypa.io/en/latest/) users, you can create a new venv: ```sh pip3 install virtualenv virtualenv venv .\venv\Scripts\activate ``` and install the dependencies: ```sh python setup.py install pip3 install -r requirements.txt ``` ##### Step 2. Create keys and `deposit_data-*.json` Run the following command to enter the interactive CLI: ```sh python .\eth2deposit\deposit.py ``` You can also run the tool with optional arguments: ```sh python .\eth2deposit\deposit.py --num_validators= --mnemonic_language=english --chain= --folder= ``` ###### Arguments See [here](#arguments) ###### Successful message See [here](#successful-message) ## Development ### Install basic requirements ```sh python3 -m pip install -r requirements.txt python3 setup.py install ``` ### Install testing requirements ```sh python3 -m pip install -r requirements_test.txt ``` ### Run tests ```sh python3 -m pytest . ```