A service to learn about Olas agents and Open Autonomy.
- Python
>=3.10
- Tendermint
==0.34.19
- IPFS node
==0.6.0
- Pip
- Poetry
- Docker Engine
- Docker Compose
- Set Docker permissions so you can run containers as non-root user
-
Clone this repo:
git clone git@github.com:valory-xyz/academy-learning-service-template.git
-
Create the virtual environment:
cd academy-learning-service poetry shell poetry install
-
Sync packages:
autonomy packages sync --update-packages
-
Prepare a
keys.json
file containing wallet address and the private key for each of the four agents.autonomy generate-key ethereum -n 4
-
Prepare a
ethereum_private_key.txt
file containing one of the private keys fromkeys.json
. Ensure that there is no newline at the end. -
Deploy a Safe on Gnosis (it's free) and set your agent addresses as signers. Set the signature threshold to 3 out of 4.
-
Create a Tenderly account and from your dashboard create a fork of Gnosis chain (virtual testnet).
-
From Tenderly, fund your agents and Safe with a small amount of xDAI, i.e. $0.02 each.
-
Make a copy of the env file:
cp sample.env .env
-
Fill in the required environment variables in .env. These variables are:
ALL_PARTICIPANTS
,GNOSIS_LEDGER_RPC
,COINGECKO_API_KEY
andSAFE_CONTRACT_ADDRESS
. You will need to get a Coingecko. SetGNOSIS_LEDGER_RPC
to your Tenderly fork Admin RPC.
-
Verify that
ALL_PARTICIPANTS
in.env
contains only 1 address. -
Run the agent:
bash run_agent.sh
-
Check that Docker is running:
docker
-
Verify that
ALL_PARTICIPANTS
in.env
contains 4 addresses. -
Run the service:
bash run_service.sh
-
Look at the service logs for one of the agents (on another terminal):
docker logs -f learningservice_abci_0