From 5c18aa02617ccc8362e0d1cc959272b9eaf72b0e Mon Sep 17 00:00:00 2001 From: clemlak Date: Wed, 21 Feb 2024 14:30:44 +0400 Subject: [PATCH 1/4] chore: add .env to .gitignore --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index 882fc0c5..22641f75 100644 --- a/.gitignore +++ b/.gitignore @@ -2,3 +2,4 @@ cache out optimized-out +.env \ No newline at end of file From 7f96314c9887df6e827ee898f6cea4275eeacbb6 Mon Sep 17 00:00:00 2001 From: clemlak Date: Wed, 21 Feb 2024 14:30:54 +0400 Subject: [PATCH 2/4] chore: add env.example --- .env.example | 4 ++++ 1 file changed, 4 insertions(+) create mode 100644 .env.example diff --git a/.env.example b/.env.example new file mode 100644 index 00000000..5963c52f --- /dev/null +++ b/.env.example @@ -0,0 +1,4 @@ +MAINNET_RPC_URL= +ETHERSCAN_API_KEY= +DEPLOYMENT_PRIVATE_KEY= +OPTIMISM_SEPOLIA_RPC_URL= \ No newline at end of file From 018031944241316f9b7402ad16f4da7da58a8a50 Mon Sep 17 00:00:00 2001 From: clemlak Date: Wed, 21 Feb 2024 14:31:13 +0400 Subject: [PATCH 3/4] build: enable via-ir in Foundry settings --- foundry.toml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/foundry.toml b/foundry.toml index 66a064bb..aef31eed 100644 --- a/foundry.toml +++ b/foundry.toml @@ -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 @@ -26,4 +27,3 @@ optimism_sepolia = "${OPTIMISM_SEPOLIA_RPC_URL}" [etherscan] optimism_sepolia = { key = "${ETHERSCAN_API_KEY}" } - From 6f1ab9e92c3b5e40e20a0807fb26301c0e5685bf Mon Sep 17 00:00:00 2001 From: clemlak Date: Wed, 21 Feb 2024 14:52:15 +0400 Subject: [PATCH 4/4] chore: update README --- README.md | 105 +++++++++++++++++++++++++++++++++++------------------- 1 file changed, 68 insertions(+), 37 deletions(-) diff --git a/README.md b/README.md index 29c82a0f..42df5e2b 100644 --- a/README.md +++ b/README.md @@ -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 @@ -72,13 +65,39 @@ 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: @@ -86,6 +105,18 @@ You can deploy the contracts with the following command: $ 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