2023-10-25 15:01:58 +02:00
# Codex Testnet Starter
Hit the ground running with Codex.
2024-03-29 22:35:34 +02:00
1. [Overview ](#overview )
2. [How to start ](#how-to-start )
3. [How to get ready ](#how-to-get-ready )
4. [How to use ](#how-to-use )
5. [How to stop ](#how-to-stop )
6. [How to stop and delete everything ](#how-to-stop-and-delete-everything )
7. [Troubleshooting ](#troubleshooting )
## [Overview](#codex-testnet-starter)
2024-03-29 14:21:16 +01:00
data:image/s3,"s3://crabby-images/30093/30093f8becc29c4afb2eb994b7032fcf3a597141" alt="Overview "
Using the Testnet Starter, you can run a (mostly preconfigured) Codex node on your machine. You always have the option to build and run Codex from sources [Here ](https://github.com/codex-storage/nim-codex/ ).
2024-03-31 01:45:40 +02:00
### Links
- Codex Website - [codex.storage ](https://codex.storage )
- Codex Whitepaper - [codex.storage ](https://codex.storage )
- Codex API - [api.codex.storage ](https://api.codex.storage )
- Codex Discord - [discord.gg/codex-storage ](https://discord.gg/codex-storage )
- Block explorer - [explorer.testnet.codex.storage ](https://explorer.testnet.codex.storage )
- Web wallet - [wallet.testnet.codex.storage ](https://wallet.testnet.codex.storage )
2024-03-29 09:22:03 +02:00
## [How to start](#codex-testnet-starter)
2024-03-29 22:35:34 +02:00
1. [Have Docker with compose installed ](https://docs.docker.com/engine/install/ )
2. Clone this repo
```shell
git clone https://github.com/codex-storage/codex-testnet-starter & & cd codex-testnet-starter
```
2024-03-31 01:45:40 +02:00
3. Create an Ethereum public/private key pair using [web wallet ](https://wallet.testnet.codex.storage ) or consider other local methods
2024-03-30 15:12:19 +02:00
< details >
< summary > Use Docker< / summary >
```shell
# Generate keypair
docker run --rm gochain/web3 account create
```
< / details >
2024-03-29 22:35:34 +02:00
< details >
2024-03-31 01:45:40 +02:00
< summary > Use MetaMask< / summary >
2024-03-29 22:35:34 +02:00
2024-03-30 15:12:19 +02:00
1. [Accounts and Addresses ](https://support.metamask.io/hc/en-us/sections/4471975962907-Accounts-and-Addresses )
2. [How to export an account's private key ](https://support.metamask.io/hc/en-us/articles/360015289632-How-to-export-an-account-s-private-key )
2024-03-29 22:35:34 +02:00
< / details >
2024-03-30 15:12:19 +02:00
2024-03-29 22:35:34 +02:00
< details >
< summary > Use Python code< / summary >
1. Create a venv
2024-03-30 15:12:19 +02:00
```shell
pip3 install virtualenv
2024-03-29 22:35:34 +02:00
2024-03-30 15:12:19 +02:00
venv=codex-eth-key
mkdir $venv & & cd $venv
2024-03-29 22:35:34 +02:00
2024-03-30 15:12:19 +02:00
python3 -m venv env
source env/bin/activate
```
2024-03-29 22:35:34 +02:00
2. Install required packages
2024-03-30 15:12:19 +02:00
```shell
pip3 install web3
```
2024-03-29 22:35:34 +02:00
3. Create a script
2024-03-30 15:12:19 +02:00
```shell
vi eth-keys.py
```
```python
2024-03-29 22:35:34 +02:00
from eth_account import Account
def generate_ethereum_keypair():
# Generate a new Ethereum account
account = Account.create()
# Get the private key
private_key = account._private_key.hex()
# Get the public key (Ethereum address)
public_key = account.address
return private_key, public_key
# Generate the Ethereum key pair
private_key, public_key = generate_ethereum_keypair()
# Print the keys
print("Private Key:", private_key)
print("Public Key (Ethereum Address):", public_key)
2024-03-30 15:12:19 +02:00
```
4. Generate the keys
```shell
python3 eth-keys.py
```
5. Cleanup
```shell
deactivate
cd .. & & rm -rf $venv
```
2024-03-29 22:35:34 +02:00
< / details >
```
# Example
Private key: 0xacec4df7549199708a9f66b151aea7bf41b4d30bd325b96b26f017246226e1a3
Public address: 0x1C408C8572ce7d5E79a3a6D353e5FC2E8E2c49ce
```
4. Define variables
```shell
export PRIV_KEY=0xacec4df7549199708a9f66b151aea7bf41b4d30bd325b96b26f017246226e1a3
2024-03-30 15:12:19 +02:00
export CODEX_LISTEN_ADDRS=/ip4/0.0.0.0/tcp/8070
export CODEX_DISC_PORT=8090
2024-03-29 22:35:34 +02:00
# export CODEX_ETH_PROVIDER=https://rpc.testnet.codex.storage
# export CODEX_LOG_LEVEL=TRACE
#
# export GETH_DISCOVERY_PORT=8547
# export GETH_PORT=8548
# export GETH_NAT=extip:1.1.1.1
# export GETH_VERBOSITY=3
```
2024-03-29 09:22:03 +02:00
2024-03-29 22:35:34 +02:00
5. Run local nodes
```shell
2024-04-05 15:03:25 +02:00
docker-compose up -d
2024-03-29 22:35:34 +02:00
```
2023-10-25 15:01:58 +02:00
2024-03-30 15:12:19 +02:00
6. Setup port forwarding on your router for Codex, based on defined values
```
TCP - CODEX_LISTEN_ADDRS=/ip4/0.0.0.0/tcp/8070
UDP - CODEX_DISC_PORT=8090
```
2024-03-29 09:22:03 +02:00
2024-03-29 14:21:16 +01:00
## [How to get ready](#codex-testnet-starter)
When starting the Testnet Starter for the first time, (or restarting after a long pause) please keep in mind:
- Your local Geth node will need time to sync.
2024-03-31 01:45:40 +02:00
- Geth checker will wait until Geth is in sync and only then Codex will start.
2024-03-29 14:21:16 +01:00
2024-05-24 10:55:19 +03:00
Before you can use the marketplace functionality of Codex, you will need to obtain some tokens in the Testnet.
2024-05-24 11:24:55 +03:00
1. Use web faucets
2024-05-24 10:55:19 +03:00
- ETH - [faucet-eth.testnet.codex.storage ](https://faucet-eth.testnet.codex.storage )
- TST - [faucet-tst.testnet.codex.storage ](https://faucet-tst.testnet.codex.storage/ )
2024-03-31 01:45:40 +02:00
2024-05-24 10:55:19 +03:00
2. Or join the [Codex Discord server ](https://discord.gg/codex-storage )
2024-03-31 01:45:40 +02:00
< details >
2024-05-24 10:55:19 +03:00
< summary > Get tokens on Discord server faucet< / summary >
1. Find the `#bot` channel.
2. Give your public key to the bot using `set` command.
< details >
< summary > example< / summary >
data:image/s3,"s3://crabby-images/5fd9a/5fd9ab06bd159ac440663c12f35975c1ee9a13cd" alt="Bot-Set "
< / details >
3. Ask it politely to mint some tokens for you using `mint` command.
< details >
< summary > example< / summary >
data:image/s3,"s3://crabby-images/0a84f/0a84f97b09ff95e759f3f6fa6729b211e6aa0fc8" alt="Bot-Mint "
< / details >
(It may or may not happen in the future that testnet participation will be rewarded automatically with Discord server roles.)
2024-03-31 01:45:40 +02:00
< / details >
2024-03-29 14:21:16 +01:00
## [How to use](#codex-testnet-starter)
Once running, Codex exposes a web-api at the API port. (default: 8080)
To read more about how to use the API, go [Here ](/USINGCODEX.md )
2024-03-29 09:22:03 +02:00
## [How to stop](#codex-testnet-starter)
2023-10-25 15:01:58 +02:00
- `docker-compose down`
2024-03-29 14:21:16 +01:00
2024-03-29 09:22:03 +02:00
## [How to stop and delete everything](#codex-testnet-starter)
2023-10-25 15:01:58 +02:00
- `docker-compose down --rmi all -v`
2024-03-29 09:22:03 +02:00
## [Troubleshooting](#codex-testnet-starter)
### Geth
```shell
# List peers
docker exec -it geth geth attach --exec net.peerCount /data/geth.ipc
# Connected peers
docker exec -it geth geth attach --exec admin.peers /data/geth.ipc
# Add a peer
docker exec -it geth geth attach --exec 'admin.addPeer("enode://cff0c44c62ecd6e00d72131f336bb4e4968f2c1c1abeca7d4be2d35f818608b6d8688b6b65a18f1d57796eaca32fd9d08f15908a88afe18c1748997235ea6fe7@159 .223.243.50:40010")' /data/geth.ipc
# Sync status
docker exec -it geth geth attach --exec eth.syncing /data/geth.ipc
# Geth own enode
docker exec -it geth geth attach --exec admin.nodeInfo.enode /data/geth.ipc
```