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

docs: Update README (SC-535) #9

Merged
merged 3 commits into from
Jul 24, 2024
Merged
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
88 changes: 46 additions & 42 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,62 +1,66 @@
# Spark User Actions

<!-- ![Foundry CI](https://github.com/{org}/{repo}/actions/workflows/ci.yml/badge.svg)
![Foundry CI](https://github.com/marsfoundation/spark-user-actions/actions/workflows/ci.yml/badge.svg)
[![Foundry][foundry-badge]][foundry]
[![License: AGPL v3](https://img.shields.io/badge/License-AGPL%20v3-blue.svg)](https://github.com/{org}/{repo}/blob/master/LICENSE) -->
[![License: AGPL v3](https://img.shields.io/badge/License-AGPL%20v3-blue.svg)](https://github.com/marsfoundation/spark-user-actions/blob/master/LICENSE)

[foundry]: https://getfoundry.sh/
[foundry-badge]: https://img.shields.io/badge/Built%20with-Foundry-FFDB1C.svg

# Overview

Common user actions in the Maker ecosystem related to DAI, sDAI, NST, sNST, and USDC. USDT is unsupported because of a lack of first-class support in Maker at this time. USDT can be supported if Maker infrastructure is added in the future. Users wanting to enter or exit via USDT need to use DEX aggregators such as Cowswap.

These contracts are not meant to exhaustively cover all use cases, but group common actions where there is more than 1 transaction required. For example, swapping from USDC to sDAI is covered, but not DAI to sDAI because there is already a `deposit(...)` function on the sDAI contract.
These contracts are not meant to exhaustively cover all use cases, but group common actions where there is more than 1 transaction required. For example, swapping from USDC to sDAI is covered, but not DAI to sDAI because there is already a `deposit(...)` function on the sDAI contract.

These contracts are designed to revert when edge cases present themselves such as the PSM being empty or at max debt capacity. Users should feel confident that in the worst case their transaction will fail instead of losing part of their principal.

These contracts will be deployed at well-known addresses to be used across the Maker ecosystem.

## Top Level Actions Mapping
# Top Level Actions Mapping

Below is a diagram that outlines the top-level actions that can be taken by a user and the contracts that are used to facilitate these actions.

![Actions Mapping](./.assets/user-actions-overview.png)

### Ethereum (Original PSM - Variant 1)
## Ethereum (Original PSM - Variant 1)

DAI <-> sDAI: sDAI ERC-4626 interface
USDC <-> DAI: Use PSM directly
USDC <-> sDAI: PSMVariant1Actions
- `DAI <-> sDAI`: sDAI ERC-4626 interface
- `USDC <-> DAI`: Use PSM directly
- `USDC <-> sDAI`: PSMVariant1Actions

### Ethereum (PSM Lite - Variant 2)
## Ethereum (PSM Lite - Variant 2)

DAI <-> sDAI: sDAI ERC-4626 interface
USDC <-> DAI: Use PSM directly
USDC <-> sDAI: PSMVariant1Actions
- `DAI <-> sDAI`: sDAI ERC-4626 interface
- `USDC <-> DAI`: Use PSM directly
- `USDC <-> sDAI`: PSMVariant1Actions

*Note: No code changes are needed. Only a redeploy of `PSMVariant1Actions`.*

### Ethereum (PSM Wrapper - Variant 3)
## Ethereum (PSM Wrapper - Variant 3)

NST <-> sNST: sNST ERC-4626 interface
USDC <-> NST: [NstPsmWrapper](https://github.com/makerdao/nst-wrappers/blob/dev/src/NstPsmWrapper.sol)
USDC <-> sNST: PSMVariant1Actions

NST <-> Farms: Directly deposit/withdraw
- `NST <-> sNST`: sNST ERC-4626 interface
- `USDC <-> NST`: [NstPsmWrapper](https://github.com/makerdao/nst-wrappers/blob/dev/src/NstPsmWrapper.sol)
- `USDC <-> sNST`: PSMVariant1Actions
- `NST <-> Farms`: Directly deposit/withdraw

### Ethereum (Migration Actions)
## Ethereum (Migration Actions)

DAI <-> NST: MigrationActions
sDAI -> NST: MigrationActions
DAI -> sNST: MigrationActions
sDAI -> sNST: MigrationActions
- `DAI <-> NST`: MigrationActions
- `sDAI -> NST`: MigrationActions
- `DAI -> sNST`: MigrationActions
- `sDAI -> sNST`: MigrationActions

### Non-Ethereum chains
## Non-Ethereum chains

A three-way PSM will be provided here: https://github.com/marsfoundation/spark-psm. This can be used directly by UIs.

NST <-> sNST: Swap in PSM
USDC <-> NST: Swap in PSM
USDC <-> sNST: Swap in PSM

NST <-> Farms: Directly deposit/withdraw
- `NST <-> sNST`: Swap in PSM
- `USDC <-> NST`: Swap in PSM
- `USDC <-> sNST`: Swap in PSM
- `NST <-> Farms`: Directly deposit/withdraw

# Contracts

## PSMVariant1Actions

Expand All @@ -70,7 +74,7 @@ Deployed at (NST PSM Wrapper): TBD

### swapAndDeposit

```
```solidity
function swapAndDeposit(
address receiver,
uint256 amountIn,
Expand All @@ -82,7 +86,7 @@ Deposit `amountIn` USDC and swap it for at least `minAmountOut` sDAI (measured i

Example:

```
```solidity
// Use exact approvals for safety
usdc.approve(address(actions), 100e6);
actions.swapAndDeposit(address(this), 100e6, 100e18);
Expand All @@ -91,7 +95,7 @@ actions.swapAndDeposit(address(this), 100e6, 100e18);

### withdrawAndSwap

```
```solidity
function withdrawAndSwap(
address receiver,
uint256 amountOut,
Expand All @@ -105,7 +109,7 @@ Sends at most `maxAmountIn` sDAI (measured in DAI units) and swap it for exactly

Example:

```
```solidity
// Use exact approvals for safety
// +1 is to prevent rounding errors
sDAI.approve(address(actions), sDAI.convertToShares(100e18) + 1);
Expand All @@ -115,7 +119,7 @@ actions.withdrawAndSwap(address(this), 100e6, 100e18);

### redeemAndSwap

```
```solidity
function redeemAndSwap(
address receiver,
uint256 shares,
Expand All @@ -129,7 +133,7 @@ Sends `shares` sDAI (measured in sDAI shares) and swap it for at least `minAmoun

Example:

```
```solidity
// Use exact approvals for safety
uint256 bal = sDAI.balanceOf(address(this));
sDAI.approve(address(actions), bal);
Expand All @@ -139,21 +143,21 @@ actions.redeemAndSwap(address(this), bal, sDAI.convertToAssets(bal));

## MigrationActions

TODO.
This contract is used to upgrade from DAI, sDAI to NST, sNST. Also contains a downgrade path for NST -> DAI for backwards compatibility.

Used to upgrade from DAI, sDAI to NST, sNST. Also contains a downgrade path for NST -> DAI for backwards compatibility.
Below is a diagram that outlines the migration path from sDAI to sNST. This migration path is the most complex and all other paths are subsets of this one.

## Usage
![sDai to sNst](https://github.com/user-attachments/assets/a7b74251-f7bb-46e1-ac77-88a1e1c452b5)

```bash
forge build
```
# Test

## Test
To run testing, use the following command:

```bash
forge test
```

Forked integration tests are built off of the MakerDAO staging environment on Tenderly. Prior to running the tests, ensure that the `TENDERLY_STAGING_URL` environment variable is set to the correct RPC URL.

***
*The IP in this repository was assigned to Mars SPC Limited in respect of the MarsOne SP*
Loading