Skip to content

Latest commit

 

History

History
 
 

lesson-06-tokens

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Tokens

Use the brownie forked-mainnet feature to interact with live contracts and test basic token transactions.

BROWNIE MAINNET FORK

Run brownie in mainnet fork to interact with contracts deployed to the live blockchain. Requires an Infura API key.

    $ export WEB3_INFURA_PROJECT_ID=<your_infura_key>
    $ brownie console --network mainnet-fork

INSTALL BROWNIE TOKEN TESTER

Brownie Token Tester provides helper objects for generating ERC20s while testing a Brownie project.

    $ pipx inject eth-brownie brownie-token-tester

Mint tokens at will for common ERC20 tokens (ie USDC, DAI...)

    > from brownie_tokens import MintableForkToken
    > amount = <value> * <token_decimals>
    > token = MintableForkToken(<token_address>)
    > token._mint_for_testing(<target_address>, amount)

BROWNIE CONTRACT OBJECT

Interact with a deployed contract that is not part of your project

    > from brownie import Contract
    > contract_object = Contract(<address>)        

BROWNIE ACCOUNTS

Provides ten funded and unlocked accounts to interact with in Brownie.

    > from brownie import accounts

CURVE FINANCE

👑 King of DeFi 👑

The Curve registry is a smart contract used to locate all active Curve contracts and perform high level interactions. The active address may change and can be retrieved from 0x0000000022d53366457f9d5e68ec105046fc4383

Find Pool

Find a pool that allows for transactions between <from> and <to>. You can optionally include the offset <i> to get the i-th pool when multiple pools exist for the given pairing.

    > registry = Contract(<registry_address>)
    > pool_addr = registry.find_pool_for_coins(<from>, <to>, <i>)

Add Liquidity

Deposit coins into a Curve pool as a liquidity provider to earn yield. Accepts an ordered list of <coin_i_amount> values for each coin the pool accepts. Reverts if return amount generated is less than <min_amount>.

    > pool = Contract(<pool_addr>)
    > amounts = [<coin_1_amount>, <coin_2_amount>, ...]
    > pool.add_liquidity(amounts, <min_amount>)

DAI

Dai is a decentralized stablecoin by MakerDao currently pegged to the value of the US dollar.

USDC

A stablecoin pegged to the US dollar launched by Centre, a collaboration of Circle and Coinbase.