Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Chore/repo org #7

Merged
merged 4 commits into from
Feb 21, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions .env.example
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
MAINNET_RPC_URL=
ETHERSCAN_API_KEY=
DEPLOYMENT_PRIVATE_KEY=
OPTIMISM_SEPOLIA_RPC_URL=
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,4 @@
cache
out
optimized-out
.env
105 changes: 68 additions & 37 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,40 +1,33 @@
# DFMM

## Overview
This repository contains the smart contracts source code for the DFMM protocol.

## Repository Structure
## What is DFMM?

```
src/
├─DFMM.sol
├─...
├─interfaces/
│ ├─IDFMM.sol
│ └─...
├─lib/
│ ├─ScalingLib.sol
│ └─...
├─script/
│ ├─Deployment.s.sol
│ └─...
├─solvers/
│ └─G3M/
│ ├─G3MSolver.sol
│ └─...
├─strategies/
│ └─G3M/
│ ├─G3MStrategy.sol
│ └─...
└─test/
├─attack/
├─fork/
├─invariant/
├─unit/
└─...
```
The DFMM protocol is a novel portfolio management system designed to leverage external strategy contracts. This system separates the operational logic and the mathematical model: the `DFMM` core contract completely relies on the strategies to validate the state of each interaction. On the other hand, this core contract acts as a single entry point and performs all the operations, such as:
- Passing the input data to the strategies for validation
- Safely transferring the assets between the users and the core contract
- Tracking the reserves in a singleton pattern
- Tokenizing the liquidity and distributing the LP tokens to the users

## Contracts Architecture

The DFMM protocol relies on two main components: the `DFMM` core contract and the strategies.

### DFMM

This contract is the core of the protocol and is the single entry point for all the user interactions. It also handles all the following operations on the behalf of the strategies:
- Deploying an ERC20 token for each new pool (using the minimal proxy pattern)
- Wrapping / unwrapping native ETH when necessary
- Transferring the assets from or to the user's wallet
- Preventing reentrancy by locking the contract during the operations
- Emitting according events for each interaction
- Keeping track of the reserves for each pool

### Strategies

The strategies are the mathematical models that define the logic of the pools. They all implement a specific trading curve (for example `xy=k`) and are responsible for validating the state of the pool at each interaction.

### Initializing and updating a pool

#### Creating a new pool
Expand Down Expand Up @@ -72,20 +65,58 @@ flowchart LR

### Arbitrage

## Deployments
## Development

| Designation | Network | Address |
|---|---|---|
| `DFMM` | Optimism Sepolia | `0x89a023e3cbccf1c96F00749F87D24C9B1124BaE1` |
| `G3M` | Optimism Sepolia | `0xB5C2c5a4000FB230b289bB54f8b48F4dd8075F3D` |
| `LogNormal` | Optimism Sepolia | `0x6A74a571c638dDDF13ae52F48A37D1019B916520` |
### Installation

This repository uses Foundry, be sure to have it installed or run the following command to install it:

```bash
curl -L https://foundry.paradigm.xyz | bash
```

Then clone the repository along with its dependencies:

```bash
git clone git@github.com:primitivefinance/DFMM.git --recurse-submodules
```

One last step is to set up the environment variables, run this to copy the template:

```bash
cp .env.example .env
```

Then populate the `.env` file with the required environment variables.

### Testing

To run all the tests, simply run the following command:

```bash
forge t
```

### Deployment

You can deploy the contracts with the following command:

```bash
$ forge script ./src/script/Deployment.s.sol --rpc-url $OPTIMISM_SEPOLIA_RPC_URL --broadcast --verify -vvv
```

*Note: Be sure to populate your `.env` file with the required environment variables beforehand.*
## Current Deployments

The DFMM protocol is currently deployed on the following networks:

| Designation | Network | Address |
|---|---|---|
| `DFMM` | Optimism Sepolia | `0x89a023e3cbccf1c96F00749F87D24C9B1124BaE1` |
| `G3M` | Optimism Sepolia | `0xB5C2c5a4000FB230b289bB54f8b48F4dd8075F3D` |
| `LogNormal` | Optimism Sepolia | `0x6A74a571c638dDDF13ae52F48A37D1019B916520` |

## Contributing

Contributions are welcome! Check out our [guidelines](./CONTRIBUTING.md).

## Licences
8 changes: 4 additions & 4 deletions foundry.toml
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
[profile.default]
remappings = [
"solstat/=lib/solstat/src/",
"forge-std/=lib/solstat/lib/forge-std/src/",
"solmate/=lib/solstat/lib/solmate/src/",
"solstat/=lib/solstat/src/",
"forge-std/=lib/solstat/lib/forge-std/src/",
"solmate/=lib/solstat/lib/solmate/src/",
]
solc_version = "0.8.22"

# these are defaults. explicitly setting them here for clarity.
libs = ["lib"]
out = "out/"
via-ir = true

[fmt]
bracket_spacing = true
Expand All @@ -26,4 +27,3 @@ optimism_sepolia = "${OPTIMISM_SEPOLIA_RPC_URL}"

[etherscan]
optimism_sepolia = { key = "${ETHERSCAN_API_KEY}" }

Loading