https://github.com/angleprotocol/angle-strategies
  
  
    ๐งโ๐พ Yield strategies implemented by the Angle Protocol 
    https://github.com/angleprotocol/angle-strategies
  
        Last synced: 6 months ago 
        JSON representation
    
๐งโ๐พ Yield strategies implemented by the Angle Protocol
- Host: GitHub
- URL: https://github.com/angleprotocol/angle-strategies
- Owner: AngleProtocol
- License: gpl-3.0
- Created: 2022-02-14T10:38:35.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-03-13T09:40:00.000Z (over 2 years ago)
- Last Synced: 2025-03-28T06:23:34.390Z (7 months ago)
- Language: TypeScript
- Homepage: https://angle.money
- Size: 1.72 MB
- Stars: 3
- Watchers: 3
- Forks: 3
- Open Issues: 4
- 
            Metadata Files:
            - Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
 
Awesome Lists containing this project
README
          #  Angle Project Strategies
 Angle Project Strategies
[](https://github.com/AngleProtocol/strategies-dev/actions?query=workflow%3ACI)
This repository proposes a template that mixes hardhat and foundry frameworks. It also provides templates for EVM compatible smart contracts (in `./contracts/examples`), tests and deployment scripts.
## Starting
### Install packages
You can install all dependencies by running
```bash
yarn
forge i
```
### Create `.env` file
In order to interact with non local networks, you must create an `.env` that has:
- `PRIVATE_KEY`
- `MNEMONIC`
- network key (eg. `ALCHEMY_NETWORK_KEY`)
- `ETHERSCAN_API_KEY`
For additional keys, you can check the `.env.example` file.
Warning: always keep your confidential information safe.
## Headers
To automatically create headers, follow: https://github.com/Picodes/headers
## Hardhat Command line completion
Follow these instructions to have hardhat command line arguments completion: https://hardhat.org/hardhat-runner/docs/guides/command-line-completion
## Foundry Installation
```bash
curl -L https://foundry.paradigm.xyz | bash
source /root/.zshrc
# or, if you're under bash: source /root/.bashrc
foundryup
```
To install the standard library:
```bash
forge install foundry-rs/forge-std
```
To update libraries:
```bash
forge update
```
### Foundry on Docker ๐ณ
**If you donโt want to install Rust and Foundry on your computer, you can use Docker**
Image is available here [ghcr.io/foundry-rs/foundry](http://ghcr.io/foundry-rs/foundry).
```bash
docker pull ghcr.io/foundry-rs/foundry
docker tag ghcr.io/foundry-rs/foundry:latest foundry:latest
```
To run the container:
```bash
docker run -it --rm -v $(pwd):/app -w /app foundry sh
```
Then you are inside the container and can run Foundryโs commands.
### Tests
You can run tests as follows:
```bash
forge test -vvvv --watch
forge test -vvvv --match-path contracts/test/forge/testXX1.t.sol
forge test -vvvv --match-test "testAbc*"
forge test -vvvv --fork-url https://eth-mainnet.alchemyapi.io/v2/Lc7oIGYeL_QvInzI0Wiu_pOZZDEKBrdf
```
You can also list tests:
```bash
forge test --list
forge test --list --json --match-test "testXXX*"
```
### Deploying
There is an example script in the `scripts/foundry` folder. Then you can run:
```bash
yarn foundry:deploy  --rpc-url 
```
Example:
```bash
yarn foundry:deploy scripts/foundry/DeployMockAgEUR.s.sol --rpc-url goerli
```
### Coverage
We recommend the use of this [vscode extension](ryanluker.vscode-coverage-gutters).
```bash
yarn hardhat:coverage
yarn foundry:coverage
```
### Gas report
```bash
yarn foundry:gas
```
## Slither
```bash
pip3 install slither-analyzer
pip3 install solc-select
solc-select install 0.8.11
solc-select use 0.8.11
slither .
```
## Media
Don't hesitate to reach out on [Twitter](https://twitter.com/AngleProtocol) ๐ฆ