We believe in an open internet where users own their data and the AI models they contribute to.
AI models should be created more like open source software: iteratively by a community. To make this possible, researchers need access to the world's best datasets that are held captive across walled gardens. Users can break down these walled gardens by exporting their own data.
We are building towards a user-owned foundation model, trained by 100M users who contribute their data and compute.
Minimum hardware requirements:
Local: 1 CPU, 8GB RAM, 10GB free disk space
AWS: t3.large, m5.large or better
GCP: n1-standard-2 or better
To get started with the ChatGPT DLP, follow these steps:
- Clone the repository:
git clone https://github.com/vana-com/vana-dlp-chatgpt.git
- Install the required dependencies using poetry:
poetry install
-
Configure the environment variables by copying and modifying the
.env.example
file: -
Run the application:
poetry run python -m chatgpt.nodes.validator
All DLP validators share a private/public keypair to encrypt the user's encryption keys. To generate a new keypair, follow these steps:
- Install GnuPG:
sudo apt-get install gnupg
- Generate a new key pair and follow the prompts:
gpg --full-generate-key
Select the key type (RSA and RSA).
Specify the key size (3072 bits).
Set the key expiration time (no expiration).
Enter your name and email address.
Choose a passphrase to protect your private key.
- Export the Private Key - this is what validators will use to decrypt the files:
gpg --export-secret-keys --armor [email protected] > private_key.asc
- Export the Public Key - this is what the UI will use to encrypt the user's symmetric file encryption key
gpg --export --armor [email protected] > public_key.asc
- Base64 encode the private key, and paste it into vana-dlp-chatgpt/.env under
PRIVATE_FILE_ENCRYPTION_PUBLIC_KEY_BASE64
base64 -i private_key.asc -o private_key_base64.asc
- Paste the public key into the DLP Demo UI (settings icon on the top right)
The Vana command line interface (vanacli
) is the primary command line tool for interacting with the Vana network.
It can be used to deploy nodes, manage wallets, stake/unstake, nominate, transfer tokens, and more.
pip install vana
To run the tests, you can use the following command. This is especially useful for local development.
pytest
To get the list of all the available commands and their descriptions, you can use:
vanacli <command> <command args>
vana cli v0.0.1
positional arguments:
{root,r,roots,wallet,w,wallets,stake,st,stakes,sudo,su,sudos,info,i}
root (r, roots) Commands for managing and viewing the root network.
wallet (w, wallets)
Commands for managing and viewing wallets.
stake (st, stakes) Commands for staking and removing stake from hotkey accounts.
sudo (su, sudos) Commands for DLP management
info (i) Instructions for enabling autocompletion for the CLI.
options:
-h, --help show this help message and exit
--print-completion {bash,zsh,tcsh}
Print shell tab completion script
Wallets are the core ownership and identity technology around which all functions on Vana are carried out. Vana wallets consists of a coldkey and hotkey where the coldkey may contain many hotkeys, while each hotkey can only belong to a single coldkey. Coldkeys store funds securely, and operate functions such as transfers and staking, while hotkeys are used for all online operations such as signing queries, running miners and validating.
$ vanacli wallet --help
usage: vanacli <command> <command args> wallet [-h] {balance,create,new_hotkey,new_coldkey,regen_coldkey,regen_coldkeypub,regen_hotkey,update,history} ...
positional arguments:
{balance,create,new_hotkey,new_coldkey,regen_coldkey,regen_coldkeypub,regen_hotkey,update,history}
Commands for managing and viewing wallets.
balance Checks the balance of the wallet.
create Creates a new coldkey (for containing balance) under the specified path.
new_hotkey Creates a new hotkey (for running a miner) under the specified path.
new_coldkey Creates a new coldkey (for containing balance) under the specified path.
regen_coldkey Regenerates a coldkey from a passed value
regen_coldkeypub Regenerates a coldkeypub from the public part of the coldkey.
regen_hotkey Regenerates a hotkey from a passed mnemonic
update Updates the wallet security using NaCL instead of ansible vault.
history Fetch transfer history associated with the provided wallet
options:
-h, --help show this help message and exit
You should be able to view your keys by navigating to ~/.vana/wallets or viewed by running vanacli wallet list
$ tree ~/.vana/
.vana/ # Root directory.
wallets/ # The folder containing all vana wallets.
default/ # The name of your wallet, "default"
coldkey # You encrypted coldkey.
coldkeypub.txt # Your coldkey public address
hotkeys/ # The folder containing all of your hotkeys.
default # You unencrypted hotkey information.
Your default wallet Wallet (default, default, ~/.vana/wallets/)
is always used unless you specify otherwise.
Be sure to store your mnemonics safely.
If you lose your password to your wallet, or the access to the machine where the wallet is stored, you can always regenerate the coldkey using the mnemonic you saved from above.
$ vanacli wallet regen_coldkey --mnemonic **** *** **** **** ***** **** *** **** **** **** ***** *****
The MIT License (MIT)
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.