Installation
data:image/s3,"s3://crabby-images/cc892/cc89274610399502511cd38d24800d0ee4d103b5" alt="Vana banner"
# Prepare enviroment
Follow these steps to set up your environment, whether you’re creating a new DLP or joining an existing one as a validator.
Prerequisites
For all users:
- Git
- Python 3.11+
- Poetry
- Metamask or another EVM-compatible wallet
Additional for DLP creators:
1. Install Python 3.11:
sudo apt updatesudo apt install software-properties-common
sudo add-apt-repository ppa:deadsnakes/ppasudo apt updatesudo apt install python3.11 python3.11-venv python3.11-dev python3-pip
python3.11 --version
data:image/s3,"s3://crabby-images/0cd28/0cd28090a01864b067577e76cb8e96bb5a689dad" alt="banner"
data:image/s3,"s3://crabby-images/43893/4389386e62406d88873cbe4ea8e49332e50a031d" alt="banner"
2. Install Poetry
curl -sSL https://install.python-poetry.org | python3 -
data:image/s3,"s3://crabby-images/467df/467df243d5c4182f8c3db2d676bb59ea54dd8196" alt="banner"
echo 'export PATH="$HOME/.local/bin:$PATH"' >> $HOME/.bash_profilesource $HOME/.bash_profilepoetry --version
data:image/s3,"s3://crabby-images/5bdd1/5bdd13c1a7ab16233bb627bd73a49fc2d502b282" alt="banner"
3. Install Nodejs & Npm
# installs nvm (Node Version Manager)curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.0/install.sh | bash
data:image/s3,"s3://crabby-images/77220/77220575dcf4a598bef3098ec4c47164b08848ca" alt="banner"
echo 'export NVM_DIR="$HOME/.nvm"' >> $HOME/.bash_profileecho '[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm' >> $HOME/.bash_profileecho '[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion' >> $HOME/.bash_profile
source $HOME/.bash_profile
nvm install --lts
node -vnpm -v
data:image/s3,"s3://crabby-images/b5d71/b5d7124e9f5d0cdc2cb7a61405d3570eae208b7b" alt="banner"
# Setup steps
1. Clone Vana-dlp-chatgpt git repo
git clone https://github.com/vana-com/vana-dlp-chatgpt.gitcd vana-dlp-chatgpt
data:image/s3,"s3://crabby-images/304c7/304c7af51e494325fd4cb939ba805a76a828172e" alt="banner"
2. Install dependencies
poetry install
data:image/s3,"s3://crabby-images/3719d/3719d613baf51e71dd0319246eb5228e5c3a7fc3" alt="banner"
data:image/s3,"s3://crabby-images/8bf3b/8bf3b7c38c2da89090826499a38ecd2cc4a36d29" alt="banner"
3. Install Vana CLI
pip install vana
data:image/s3,"s3://crabby-images/5a76c/5a76c0527bf53af35bf66d8d04895832a9a5b30f" alt="banner"
4. Create wallet
vanacli wallet create --wallet.name default --wallet.hotkey default
data:image/s3,"s3://crabby-images/53495/53495ac4272ebd16baddfcdf154bb7edc2759c65" alt="banner"
This creates two key pairs:
- Coldkey: for human-managed transactions (like staking)
- Hotkey: for validator-managed transactions (like submitting scores)
Add Satori Testnet to Metamask:
RPC URL | https://rpc.moksha.vana.org |
---|---|
Chain ID | 14800 |
Network name | Vana Moksha Testnet |
Currency | VANA |
Block Explorer | https://moksha.vanascan.io |
5. Export your private keys
#For coldkeyvanacli wallet export_private_key
data:image/s3,"s3://crabby-images/5c3b3/5c3b333593c5ed43616a25f7ddb354cc52f5a23d" alt="banner"
#For hotkeyvanacli wallet export_private_key
data:image/s3,"s3://crabby-images/a8af5/a8af5ea2069d668837f2fa54bb3ca010a976903f" alt="banner"
6. Import your coldkey and hotkey addresses to Metamask:
- Click your account icon in MetaMask and select “Import Account”
- Select “Private Key” as the import method
- Paste the private key for your coldkey
- Repeat the process for your hotkey
data:image/s3,"s3://crabby-images/3a397/3a3972845c11630b9fa4d411dbfe5df8c9807073" alt="banner"
Fund both addresses with testnet VANA:
- Visit https://faucet.vana.org
- Connect your Metamask wallet
- Request VANA for both your coldkey and hotkey addresses
Note: you can only use the faucet once per day. Use the testnet faucet available at https://faucet.vana.org to fund your wallets, or ask a VANA holder to send you some test VANA tokens.
Always keep your private keys and mnemonic phrases secure. Never share them with anyone.
# Creating a DLP
Generate Encryption Keys
Run the key generation script:
./keygen.sh
data:image/s3,"s3://crabby-images/86a1a/86a1ac76916c7aa7832a830fd9332165970ba9ce" alt="banner"
- This script generates RSA key pairs for file encryption/decryption in the DLP.
- Follow the prompts to enter your name, email, and key expiration.
- The script generates four files:
public_key.asc
andpublic_key_base64.asc
(for UI)private_key.asc
andprivate_key_base64.asc
(for validators)
# Deploy DLP Smart Contracts
Clone the DLP Smart Contract repo:
cd $HOMErm -rf vana-dlp-smart-contractsgit clone https://github.com/Josephtran102/vana-dlp-smart-contractscd vana-dlp-smart-contracts
data:image/s3,"s3://crabby-images/8ca49/8ca49aecd9a0e176a9e3a0c03da9a8548e364511" alt="banner"
Install Yarn
npm install -g yarnyarn --version
data:image/s3,"s3://crabby-images/967b2/967b2bb5ac684f0523b0884dd4e3b1be53854759" alt="banner"
Install dependencies:
yarn install
data:image/s3,"s3://crabby-images/fc770/fc770fb631ec6eb340e8b6e33e272398b8f7880e" alt="banner"
Edit the .env
file in the vana-dlp-smart-contracts
directory:
- Copy
env.example
to.env
cp .env.example .env
- Edit
.env
nano .env
data:image/s3,"s3://crabby-images/f4c9e/f4c9e142dfb9ccf5d70e3c5e7a97605f52706c1d" alt="banner"
Deploy contracts:
Deploy contract on Moksha testnet (Recommend)
npx hardhat deploy --network moksha --tags DLPDeploy
data:image/s3,"s3://crabby-images/1c475/1c475a277b4b245b851a96416f169641950944cd" alt="banner"
Update the .env
file in the vana-dlp-chatgpt
directory:
nano ~/vana-dlp-chatgpt/.env
Paste this content and change your info:
# The network to use, currently Vana Moksha testnetOD_CHAIN_NETWORK=mokshaOD_CHAIN_NETWORK_ENDPOINT=https://rpc.moksha.vana.org
# Optional: OpenAI API key for additional data quality checkOPENAI_API_KEY="sk-aIKhy1wmK6Vfx.............._CIJvZx7uZl2HjAA"
# Optional: Your own DLP smart contract address once deployed to the network, useful for local testingDLP_MOKSHA_CONTRACT=0x5cb.......eE04
# Optional: Your own DLP token contract address once deployed to the network, useful for local testingDLP_TOKEN_MOKSHA_CONTRACT=0x69e..........2741
# The private key for the DLP, follow "Generate validator encryption keys" section in the READMEPRIVATE_FILE_ENCRYPTION_PUBLIC_KEY_BASE64="LS0tLS1CRUdJTiB..........g=="
data:image/s3,"s3://crabby-images/9a565/9a565800b16088f0bdf6ba877ab45b8deffa7241" alt="banner"
Get OpenAI API here: https://platform.openai.com/settings/profile?tab=api-keys
Find value of public_key_base64.asc
at: /root/vana-dlp-chatgpt/public_key_base64.asc
# Validator Setup
Ensure you’re in the vana-dlp-chatgpt
directory:
cd ~cd vana-dlp-chatgpt
Fund Validator with DLP Tokens
For DLP creators:
- Import DLP token to Metamask using
<DataLiquidityPoolToken address>
- Send 10 your own DLP tokens (my token is JOSE) to your coldkey address and hotkey address
data:image/s3,"s3://crabby-images/88b80/88b8087982a6e60d6a7f3db5760592d7d871ff38" alt="banner"
For non-DLP creators:
- Request DLP tokens from the DLP creator
- Once received, ensure they are in your coldkey address
Register as a Validator
Note that the following commands use the local chatgpt vanacli tool that supports custom dlp
commands.
Register your validator:
./vanacli dlp register_validator --stake_amount 10
data:image/s3,"s3://crabby-images/1b575/1b575ae63d65175786bfb3d8633216fb0fffef33" alt="banner"
./vanacli dlp approve_validator --validator_address=<your hotkey address from Metamask>
data:image/s3,"s3://crabby-images/5108b/5108b16116416bd4e0386cab9d8cdeb5e5d13789" alt="banner"
Run Validator
poetry run python -m chatgpt.nodes.validator
data:image/s3,"s3://crabby-images/c8195/c819545ebd9725a28a3ea9f1b550ec55132c6d7e" alt="banner"
You can run with systemd in the background with next step.
Find path of Poetry:
echo $(which poetry)
data:image/s3,"s3://crabby-images/270d3/270d3188a4a6ee84b5e7e84a3584f439bd8a18ce" alt="banner"
Create service:
sudo tee /etc/systemd/system/vana.service << EOF[Unit]Description=Vana Validator ServiceAfter=network.target
[Service]Type=simpleUser=rootWorkingDirectory=/root/vana-dlp-chatgptExecStart=/root/.local/bin/poetry run python -m chatgpt.nodes.validatorRestart=on-failureRestartSec=10Environment=PATH=/root/.local/bin:/usr/local/bin:/usr/bin:/bin:/root/vana-dlp-chatgpt/myenv/binEnvironment=PYTHONPATH=/root/vana-dlp-chatgpt
[Install]WantedBy=multi-user.targetEOF
data:image/s3,"s3://crabby-images/fc870/fc8705efb34bc28dee623131d2b3dfc66ba36914" alt="banner"
Start service
sudo systemctl daemon-reload && \sudo systemctl enable vana.service && \sudo systemctl start vana.service && \sudo systemctl status vana.service
data:image/s3,"s3://crabby-images/00db3/00db3c43256f264afc244a36a7904530aaefd0d7" alt="banner"
Check log:
sudo journalctl -u vana.service -f
data:image/s3,"s3://crabby-images/8c56f/8c56fe96afb632409b848ac32e049980864f3c25" alt="banner"