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

P2: [LILA-5515]: create example frontend implementations repository #24

Merged
Show file tree
Hide file tree
Changes from 7 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
80 changes: 41 additions & 39 deletions contracts/OffsetHelper.sol
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import "./interfaces/IToucanContractRegistry.sol";
*
* Retiring carbon tokens requires multiple steps and interactions with
* Toucan Protocol's main contracts:
* 1. Obtain a Toucan pool token e.g., NCT (by performing a token
* 1. Obtain a pool token e.g., NCT (by performing a token
* swap on a DEX).
* 2. Redeem the pool token for a TCO2 token.
* 3. Retire the TCO2 token.
Expand Down Expand Up @@ -66,7 +66,7 @@ contract OffsetHelper is OffsetHelperStorage {
* pool token e.g., NCT.
*
* @param sender The sender of the transaction
* @param poolToken The address of the Toucan pool token used in the
* @param poolToken The address of the pool token used in the
* redemption, e.g., NCT
* @param tco2s An array of the TCO2 addresses that were redeemed
* @param amounts An array of the amounts of each TCO2 that were redeemed
Expand Down Expand Up @@ -140,26 +140,26 @@ contract OffsetHelper is OffsetHelperStorage {
// ----------------------------------------

/**
* @notice Retire carbon credits using the lowest quality (oldest) TCO2
* @notice Retire carbon credits using the oldest TCO2
* tokens available from the specified Toucan token pool by sending ERC20
* tokens (cUSD, USDC, WETH, WMATIC). Use `calculateNeededTokenAmount` first in
* order to find out how much of the ERC20 token is required to retire the
* specified quantity of TCO2.
*
* This function:
* 1. Swaps the ERC20 token sent to the contract for the specified pool token.
* 2. Redeems the pool token for the poorest quality TCO2 tokens available.
* 2. Redeems the pool token for the oldest TCO2 tokens available.
* 3. Retires the TCO2 tokens.
*
* Note: The client must approve the ERC20 token that is sent to the contract.
*
* @dev When automatically redeeming pool tokens for the lowest quality
* @dev When automatically redeeming pool tokens for the oldest ones
* TCO2s there are no fees and you receive exactly 1 TCO2 token for 1 pool
* token.
*
* @param _fromToken The address of the ERC20 token that the user sends
* (e.g., cUSD, cUSD, USDC, WETH, WMATIC)
* @param _poolToken The address of the Toucan pool token that the
* @param _poolToken The address of the pool token that the
* user wants to use, e.g., NCT
* @param _amountToOffset The amount of TCO2 to offset
*
Expand All @@ -182,25 +182,26 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Retire carbon credits using the lowest quality (oldest) TCO2
* @notice Retire carbon credits using the oldest TCO2
* tokens available from the specified Toucan token pool by sending ERC20
* tokens (cUSD, USDC, WETH, WMATIC). All provided token is consumed for
* offsetting.
* offsetting. Use `calculateExpectedPoolTokenForToken()` to calculate the expected amount
* of Pool token that can be acquired by swapping the provided amount of ERC20 token.
*
* This function:
* 1. Swaps the ERC20 token sent to the contract for the specified pool token.
* 2. Redeems the pool token for the poorest quality TCO2 tokens available.
* 2. Redeems the pool token for the oldest TCO2 tokens available.
* 3. Retires the TCO2 tokens.
*
* Note: The client must approve the ERC20 token that is sent to the contract.
*
* @dev When automatically redeeming pool tokens for the lowest quality
* @dev When automatically redeeming pool tokens for the oldest ones
* TCO2s there are no fees and you receive exactly 1 TCO2 token for 1 pool
* token.
*
* @param _fromToken The address of the ERC20 token that the user sends
* (e.g., cUSD, cUSD, USDC, WETH, WMATIC)
* @param _poolToken The address of the Toucan pool token that the
* @param _poolToken The address of the pool token that the
* user wants to use, e.g., NCT
* @param _amountToSwap The amount of ERC20 token to swap into Toucan pool
* token. Full amount will be used for offsetting.
Expand Down Expand Up @@ -228,14 +229,14 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Retire carbon credits using the lowest quality (oldest) TCO2
* @notice Retire carbon credits using the oldest TCO2
* tokens available from the specified Toucan token pool by sending native tokens e.g., MATIC.
* Use `calculateNeededETHAmount()` first in order to find out how much
* native tokens are required to retire the specified quantity of TCO2.
*
* This function:
* 1. Swaps the Matic sent to the contract for the specified pool token.
* 2. Redeems the pool token for the poorest quality TCO2 tokens available.
* 2. Redeems the pool token for the oldest TCO2 tokens available.
* 3. Retires the TCO2 tokens.
*
* @dev If the user sends too much native tokens , the leftover amount will be sent back
Expand Down Expand Up @@ -268,13 +269,15 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Retire carbon credits using the lowest quality (oldest) TCO2
* @notice Retire carbon credits using the oldest TCO2
* tokens available from the specified Toucan token pool by sending native tokens e.g., MATIC.
* All provided native tokens is consumed for offsetting.
* Use `calculateExpectedPoolTokenForETH()` to calculate the expected amount of
* Pool token that can be acquired by swapping the provided amount of native tokens e.g., MATIC.
*
* This function:
* 1. Swaps the Matic sent to the contract for the specified pool token.
* 2. Redeems the pool token for the poorest quality TCO2 tokens available.
* 2. Redeems the pool token for the oldest TCO2 tokens available.
* 3. Retires the TCO2 tokens.
*
* @dev This function is only available on Polygon, not on Celo.
Expand Down Expand Up @@ -304,11 +307,11 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Retire carbon credits using the lowest quality (oldest) TCO2
* tokens available by sending Toucan pool tokens, e.g., NCT.
* @notice Retire carbon credits using the oldest TCO2
* tokens available by sending pool tokens, e.g., NCT.
*
* This function:
* 1. Redeems the pool token for the poorest quality TCO2 tokens available.
* 1. Redeems the pool token for the oldest TCO2 tokens available.
* 2. Retires the TCO2 tokens.
*
* Note: The client must approve the pool token that is sent.
Expand Down Expand Up @@ -404,6 +407,14 @@ contract OffsetHelper is OffsetHelperStorage {
}
}

/**
* @notice Swap eligible ERC20 tokens for pool tokens (BCT/NCT) on SushiSwap
* @dev Needs to be approved on the client side
* @param _fromToken The address of the ERC20 token used for the swap
* @param _poolToken The address of the pool token to swap for,
* e.g., NCT
* @param _toAmount The required amount of the pool token (NCT/BCT)
*/
function swapExactOutToken(
address _fromToken,
address _poolToken,
Expand Down Expand Up @@ -445,14 +456,14 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Swap eligible ERC20 tokens for Toucan pool tokens (BCT/NCT) on
* @notice Swap eligible ERC20 tokens for pool tokens (BCT/NCT) on
* SushiSwap. All provided ERC20 tokens will be swapped.
* @dev Needs to be approved on the client side.
* @param _fromToken The address of the ERC20 token used for the swap
* @param _poolToken The address of the pool token to swap for,
* @param _fromAmount The amount of ERC20 token to swap
* e.g., NCT
* @return amountOut Resulting amount of Toucan pool token that got acquired for the
* @return amountOut Resulting amount of pool token that got acquired for the
* swapped ERC20 tokens.
*/
function swapExactInToken(
Expand Down Expand Up @@ -495,11 +506,11 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Swap native tokens e.g., MATIC for Toucan pool tokens (BCT/NCT) on SushiSwap.
* @notice Swap native tokens e.g., MATIC for pool tokens (BCT/NCT) on SushiSwap.
* Remaining native tokens that was not consumed by the swap is returned.
* @param _poolToken The address of the pool token to swap for,
* e.g., NCT
* @param _toAmount The required amount of the Toucan pool token (NCT/BCT)
* @param _toAmount The required amount of the pool token (NCT/BCT)
*/
function swapExactOutETH(
address _poolToken,
Expand Down Expand Up @@ -530,11 +541,11 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Swap native tokens e.g., MATIC for Toucan pool tokens (BCT/NCT) on SushiSwap. All
* @notice Swap native tokens e.g., MATIC for pool tokens (BCT/NCT) on SushiSwap. All
* provided native tokens will be swapped.
* @param _poolToken The address of the pool token to swap for,
* e.g., NCT
* @return amountOut Resulting amount of Toucan pool token that got acquired for the
* @return amountOut Resulting amount of pool token that got acquired for the
* swapped native tokens .
*/
function swapExactInETH(
Expand Down Expand Up @@ -595,7 +606,7 @@ contract OffsetHelper is OffsetHelperStorage {

/**
* @notice Return how much of the specified ERC20 token is required in
* order to swap for the desired amount of a Toucan pool token, for
* order to swap for the desired amount of a pool token, for
* example, e.g., NCT.
*
* @param _fromToken The address of the ERC20 token used for the swap
Expand Down Expand Up @@ -626,7 +637,7 @@ contract OffsetHelper is OffsetHelperStorage {

/**
* @notice Return how much native tokens e.g, MATIC is required in order to swap for the
* desired amount of a Toucan pool token, e.g., NCT.
* desired amount of a pool token, e.g., NCT.
* @param _poolToken The address of the pool token to swap for, for
* example, NCT
* @param _toAmount The desired amount of pool token to receive
Expand All @@ -647,7 +658,7 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Calculates the expected amount of Toucan Pool token that can be
* @notice Calculates the expected amount of pool token that can be
* acquired by swapping the provided amount of ERC20 token.
*
* @param _fromToken The address of the ERC20 token used for the swap
Expand Down Expand Up @@ -676,16 +687,7 @@ contract OffsetHelper is OffsetHelperStorage {
}

/**
* @notice Swap eligible ERC20 tokens for Toucan pool tokens (BCT/NCT) on SushiSwap
* @dev Needs to be approved on the client side
* @param _fromToken The address of the ERC20 token used for the swap
* @param _poolToken The address of the pool token to swap for,
* e.g., NCT
* @param _toAmount The required amount of the Toucan pool token (NCT/BCT)
*/

/**
* @notice Calculates the expected amount of Toucan Pool token that can be
* @notice Calculates the expected amount of pool token that can be
* acquired by swapping the provided amount of native tokens e.g., MATIC.
*
* @param _fromTokenAmount The amount of native tokens to swap
Expand Down Expand Up @@ -798,9 +800,9 @@ contract OffsetHelper is OffsetHelperStorage {
// ----------------------------------------

/**
* @notice Checks whether an address is a Toucan pool token address
* @notice Checks whether an address is a pool token address
* @param _erc20Address address of token to be checked
* @return True if the address is a Toucan pool token address
* @return True if the address is a pool token address
*/
function isRedeemable(address _erc20Address) private view returns (bool) {
for (uint i = 0; i < poolAddresses.length; i++) {
Expand Down
20 changes: 10 additions & 10 deletions docs/OffsetHelper.md
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ function initialize() external virtual
function autoOffsetExactOutToken(address _depositedToken, address _poolToken, uint256 _amountToOffset) public returns (address[] tco2s, uint256[] amounts)
```

Retire carbon credits using the lowest quality (oldest) TCO2
Retire carbon credits using the oldest TCO2
tokens available from the specified Toucan token pool by sending ERC20
tokens (USDC, WETH, WMATIC). Use `calculateNeededTokenAmount` first in
order to find out how much of the ERC20 token is required to retire the
Expand All @@ -157,7 +157,7 @@ specified quantity of TCO2.
This function:

1. Swaps the ERC20 token sent to the contract for the specified pool token.
2. Redeems the pool token for the poorest quality TCO2 tokens available.
2. Redeems the pool token for the oldest TCO2 tokens available.
3. Retires the TCO2 tokens.

Note: The client must approve the ERC20 token that is sent to the contract.
Expand Down Expand Up @@ -187,15 +187,15 @@ token._
function autoOffsetExactInToken(address _fromToken, uint256 _amountToSwap, address _poolToken) public returns (address[] tco2s, uint256[] amounts)
```

Retire carbon credits using the lowest quality (oldest) TCO2
Retire carbon credits using the oldest TCO2
tokens available from the specified Toucan token pool by sending ERC20
tokens (USDC, WETH, WMATIC). All provided token is consumed for
offsetting.

This function:

1. Swaps the ERC20 token sent to the contract for the specified pool token.
2. Redeems the pool token for the poorest quality TCO2 tokens available.
2. Redeems the pool token for the oldest TCO2 tokens available.
3. Retires the TCO2 tokens.

Note: The client must approve the ERC20 token that is sent to the contract.
Expand Down Expand Up @@ -225,15 +225,15 @@ token._
function autoOffsetExactOutETH(address _poolToken, uint256 _amountToOffset) public payable returns (address[] tco2s, uint256[] amounts)
```

Retire carbon credits using the lowest quality (oldest) TCO2
Retire carbon credits using the oldest TCO2
tokens available from the specified Toucan token pool by sending MATIC.
Use `calculateNeededETHAmount()` first in order to find out how much
MATIC is required to retire the specified quantity of TCO2.

This function:

1. Swaps the Matic sent to the contract for the specified pool token.
2. Redeems the pool token for the poorest quality TCO2 tokens available.
2. Redeems the pool token for the oldest TCO2 tokens available.
3. Retires the TCO2 tokens.

_If the user sends much MATIC, the leftover amount will be sent back
Expand All @@ -259,14 +259,14 @@ to the user._
function autoOffsetExactInETH(address _poolToken) public payable returns (address[] tco2s, uint256[] amounts)
```

Retire carbon credits using the lowest quality (oldest) TCO2
Retire carbon credits using the oldest TCO2
tokens available from the specified Toucan token pool by sending MATIC.
All provided MATIC is consumed for offsetting.

This function:

1. Swaps the Matic sent to the contract for the specified pool token.
2. Redeems the pool token for the poorest quality TCO2 tokens available.
2. Redeems the pool token for the oldest TCO2 tokens available.
3. Retires the TCO2 tokens.

#### Parameters
Expand All @@ -288,12 +288,12 @@ This function:
function autoOffsetPoolToken(address _poolToken, uint256 _amountToOffset) public returns (address[] tco2s, uint256[] amounts)
```

Retire carbon credits using the lowest quality (oldest) TCO2
Retire carbon credits using the oldest TCO2
tokens available by sending Toucan pool tokens, for example, BCT or NCT.

This function:

1. Redeems the pool token for the poorest quality TCO2 tokens available.
1. Redeems the pool token for the oldest TCO2 tokens available.
2. Retires the TCO2 tokens.

Note: The client must approve the pool token that is sent.
Expand Down
1 change: 1 addition & 0 deletions example-frontend/.env.example
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
NEXT_PUBLIC_WC_PROJECT_ID=289a40b4eef16151e69c7db06322f4
3 changes: 3 additions & 0 deletions example-frontend/.eslintrc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"extends": "next/core-web-vitals"
}
36 changes: 36 additions & 0 deletions example-frontend/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.

# dependencies
/node_modules
/.pnp
.pnp.js

# testing
/coverage

# next.js
/.next/
/out/

# production
/build

# misc
.DS_Store
*.pem

# debug
npm-debug.log*
yarn-debug.log*
yarn-error.log*
.pnpm-debug.log*

# local env files
.env*.local

# vercel
.vercel

# typescript
*.tsbuildinfo
next-env.d.ts
Loading