Skip to content

Latest commit

 

History

History
173 lines (127 loc) · 4.55 KB

README.md

File metadata and controls

173 lines (127 loc) · 4.55 KB

Vessel Contract

Vessel smart contracts.

Script Usage

Dependencies

  1. Install Node.js (>= v20)
    $ brew install nvm
    $ nvm install --lts
    $ nvm use --lts
    
  2. Install Foundry compiler
    $ curl -L https://foundry.paradigm.xyz | bash
    $ foundryup
    
  3. Install TypeScript and pnpm
    $ npm install -g typescript tsx pnpm
  4. Compile the Solidity cod
    $ pnpm run build
  5. Install script dependencies
    $ cd script
    $ pnpm install
  6. Create a .env file
    $ cp .env.example .env
  7. Create a config file with the name .config.{NODE_ENV}.json. For the default NODE_ENV=local, it should be:
    $ cp .config.exmaple.json .config.local.json

Config

Ensure all essential configuration variables are correctly filled. These variables are used in both production and test environments.

  • DEPLOYER_SK: Private key of deployer EOA.
  • ADMIN_ADDRESS: Address of the vault admin, eligible to upgrade the vault and SNARK verifier.
  • OPERATOR_ADDRESSES: List of addresses of vault operators, eligible to manage tokens and users, and commit SNARK proofs.
  • GITHUB_TOKEN: GitHub token used to download the circuit release containing SNARK verifier bytecode.
  • RELEASE_TAG: GitHub release tag identifying the circuit release.
  • NODE_RPC_URL: string URL. RPC endpoint of the EVM chain node.
  • CHAIN_ID: Integer representing the chain ID.
  • MAX_FEE_PER_GAS: Maximum fee per gas (human-readable number) if ENABLE_1559 is true, or gas price if ENABLE_1559 is false.
  • MAX_PRIORITY_FEE_PER_GAS: Maximum priority fee per gas (human-readable number) if ENABLE_1559 is true.
  • ENABLE_1559: Boolean indicating if EIP-1559 is enabled.
  • ENABLE_MULTISIG_ADMIN: Boolean indicating if contract upgrades should propose a multi-sig transaction to the SAFE API URL instead of directly sending a transaction to the node RPC using ADMIN_SK.
  • SAFE_TX_SERVICE_URL: SAFE API endpoint, normally requiring the /api suffix.
  • VAULT_PROXY_CONTRACT_ADDRESS: Will be overwritten after running the deploy script.
  • PROXY_ADMIN_CONTRACT_ADDRESS: Will be overwritten after running the deploy script.
  • OWNER_CONTRACT_ADDRESS: Will be overwritten after running the deploy script.
  • ADMIN_SK: Private key of admin EOA, needed only if the admin is an EOA rather than a multi-sig contract, for running the script to upgrade the contract.

To test listing token and registering users in the vault, additional test configuration variables may be used.

Ensure all essential configuration variables are correctly filled. Initially, set dummy values for VAULT_ADDRESS, TOKEN_ADDRESS, and TOKEN_ASSET_ID, they will be automatically set after deploying new contracts.

Forge Usage

Build

Build the contracts:

$ forge build

Clean

Delete the build artifacts and cache directories:

$ forge clean

Compile

Compile the contracts:

$ forge build

Coverage

Get a test coverage report:

$ forge coverage

Deploy

Deploy to Anvil:

$ forge script script/Deploy.s.sol --broadcast --fork-url http://localhost:8545

For this script to work, you need to have a MNEMONIC environment variable set to a valid BIP39 mnemonic.

For instructions on how to deploy to a testnet or mainnet, check out the Solidity Scripting tutorial.

Format

Format the contracts:

$ forge fmt

Gas Usage

Get a gas report:

$ forge test --gas-report

Lint

Lint the contracts:

$ pnpm lint

Test

Run the tests:

$ forge test

Notes

  1. Foundry uses git submodules to manage dependencies. For detailed instructions on working with dependencies, please refer to the guide in the book
  2. You don't have to create a .env file, but filling in the environment variables may be useful when debugging and testing against a fork.

Related Efforts

License

SPDX-License-Identifier: Apache-2.0

Copyright 2024 Vessel Team.