Simulated Worlds with AI Narratives.
First, make sure you have the requirements:
- We are using Foundry, so make sure you install it first.
- Upgradable contracts make use of NodeJS, so you should install that as well.
Clone the repository:
git clone [email protected]:firstbatchxyz/dria-oracle-contracts.git
Install dependencies with:
forge install
Compile the contracts with:
forge build
Note
We are using openzeppelin-foundry-upgrades library, which requires clean-up per compilation to ensure upgrades are done safely. We use force = true
option in foundry.toml
for this, which may increase build times.
Note that for some users this may fail (see issue) due to a missing NPM package called @openzeppelin/upgrades-core
. To fix it, you can install the package manually:
npm install @openzeppelin/upgrades-core@latest -g
Tip
If at any point the submodules become "dirty" (e.g. there are local changes that you are unaware of) you can do:
git submodule deinit -f .
git submodule update --init --recursive --checkout
To update contracts to the latest library versions, use:
forge update
To be able to deploy & use our contracts, we need two things:
We use keystores for wallet management, with the help of cast wallet
command.
Use the command below to create your keystore. The command will prompt for your private key, and a password to encrypt the keystore itself.
cast wallet import <WALLET_NAME> --interactive
Warning
Note that you will need to enter the password when you use this keystore.
You can see your keystores under the default directory (~/.foundry/keystores
) with the command:
cast wallet list
To interact with the blockchain, we require an RPC endpoint. You can get one from:
You will use this endpoint for the commands that interact with the blockchain, such as deploying and upgrading; or while doing fork tests.
Deploy the contract with:
forge script ./script/Deploy.s.sol:Deploy<CONTRACT_NAME> \
--rpc-url <RPC_URL> \
--account <WALLET_NAME> \
--broadcast
You can see deployed contract addresses under the deployments/<chainid>.json
folder.
You will need the contract ABIs to interact with them as well, thankfully there is a nice short-hand command to export that:
forge inspect <CONTRACT_NAME> abi > ./deployments/abis/<CONTRACT_NAME>.json
Verification requires the following values, based on which provider you are using:
- Provider: can accept any of
etherscan
,blockscout
,sourcify
,oklink
orcustom
for more fine-grained stuff. - URL: based on the chosen provider, its URL, e.g.
https://base-sepolia.blockscout.com/api/
forblockscout
on Base Sepolia - API Key: an API key from the chosen provider, must be stored as
ETHERSCAN_API_KEY
in environment no matter whicih provider it is!.
You can actually verify the contract during deployment by adding the verification arguments as well:
forge script ./script/Deploy.s.sol:Deploy<CONTRACT_NAME> \
--rpc-url <RPC_URL> \
--account <WALLET_NAME> \
--broadcast \
--verify --verifier blockscout \
--verifier-url <VERIFIER_URL> \
--chain-id 8453
Alternatively, you can verify an existing contract (perhaps deployed from a factory) with the following command:
forge verify-contract <CONTRACT_ADDRESS> ./src/<CONTRACT_NAME>.sol:<CONTRACT_NAME> \
--verifier blockscout --verifier-url <VERIFIER_URL> \
--etherscan-api-key <API_KEY> --chain-id 8453
The chain ID is 8453 for Base Mainnet, and 84532 for Base Sepolia.
Upgrading an existing contract is done as per the instructions in openzeppelin-foundry-upgrades repository.
First, we create a new contract with its name as ContractNameV2
, and then we execute the following command:
forge script ./script/Deploy.s.sol:Upgrade<CONTRACT_NAME> \
--rpc-url <RPC_URL> \
--account <WALLET_NAME> --broadcast \
--sender <WALLET_ADDRESS> \
--verify --verifier blockscout \
--verifier-url <VERIFIER_URL>
Note
The --sender <ADDRESS>
field is mandatory when deploying a contract, it can be obtained with the command below, which will prompt for keystore password:
cast wallet address --account <WALLET_NAME>
Run tests on local network:
FOUNDRY_PROFILE=test forge test
# or -vvv to show reverts in detail
FOUNDRY_PROFILE=test forge test -vvv
or fork an existing chain and run the tests on it:
FOUNDRY_PROFILE=test forge test --rpc-url <RPC_URL>
We have a script that generates the coverage information as an HTML page. This script requires lcov
and genhtml
command line tools. To run, do:
./coverage.sh
Alternatively, you can see a summarized text-only output as well:
forge coverage --no-match-coverage "(test|mock|script)"
You can examine the gas usage metrics using the command:
FOUNDRY_PROFILE=test forge snapshot --snap ./test/.gas-snapshot
You can see the snapshot .gas-snapshot
file in the current directory.
You can format the contracts with:
forge fmt ./src/**/*.sol ./script/**/*.sol
If you have solhint installed, you can lint all contracts with:
solhint 'src/**/*.sol' 'script/**/*.sol'
We have auto-generated MDBook documentations under the docs
folder, generated with the following command:
forge doc
# serves the book as well
forge doc --serve
We are using Apache-2.0 license.