Skip to content

firstbatchxyz/swan-contracts

Repository files navigation

logo

Swan Protocol

Simulated Worlds with AI Narratives.

License: Apache 2.0 Workflow: Tests Discord

Installation

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

Updates

To update contracts to the latest library versions, use:

forge update

Usage

Setup

To be able to deploy & use our contracts, we need two things:

Create Wallet

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

Prepare RPC Endpoint

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 Contract

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

Verify Contract

Verification requires the following values, based on which provider you are using:

  • Provider: can accept any of etherscan, blockscout, sourcify, oklink or custom for more fine-grained stuff.
  • URL: based on the chosen provider, its URL, e.g. https://base-sepolia.blockscout.com/api/ for blockscout 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.

Upgrade Contract

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>

Testing & Diagnostics

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>

Code Coverage

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)"

Gas Snapshot

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.

Styling

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'

Documentation

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

License

We are using Apache-2.0 license.

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •