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

feat!: version 3.1 #282

Open
wants to merge 42 commits into
base: main
Choose a base branch
from
Open

feat!: version 3.1 #282

wants to merge 42 commits into from

Conversation

lekhovitsky
Copy link
Collaborator

No description provided.

lekhovitsky and others added 23 commits April 23, 2024 17:44
In this PR:
* new `IBotV3` interface that defines bot's required permissions which are checked in the bot list
* special permission bots are deprecated
* `BotListV3` interface changes:
  * redundant `creditManager` parameter removed from most functions that operate on `creditAccount`
  * `EraseBot` event removed in favor of `SetBotPermissions(..., 0)`
* minor implementation improvements that make code more consistent
* increase `BotListV3` version to `3_10`
In this PR:
* Reserve price feed's role is revised: now it's only used in safe pricing and can't be activated. Thus, `setReservePriceFeedStatus` is removed while `setPriceFeed` is now open to controller.
* `trusted` flag is removed from price feed params since it was a mess to configure and only provided small gas savings, its effect can be replicated by setting reserve feed equal to the main one.
* Add new and cleanup existing getters (`getTokens`, `reservePriceFeedParams`, etc).
* Price oracle can now be used to store whitelisted updatable price feeds and consistently update them.
* `PriceOracleV3`'s version is increased to `3_10`.
All collateral tokens are now considered quoted (credit configurator forbids adding non-quoted tokens as collateral), while underlying token is always considered enabled. The former allows to make the system stricter and remove a huge pile of dead code related to enabling/disabling tokens, while the latter allows to prevent liquidations during pause by sending underlying directly to credit account.

While it's encouraged to use new credit managers going forward, new facade and configurator are compatible with existing ones, with two important remarks:
* all non-quoted collateral tokens must be made such **before** upgrading credit facades and configurators;
* open credit accounts with disabled underlying will only have it enabled after the first multicall. Before that, sending underlying directly won't prevent liquidation and might result in the loss of funds.

Additionally, this PR removes all functionality related to `revokeAdapterAllowances`.
In this PR:
* move `setBotPermissions` inside multicall
* overall code simplification and improvements
* add params in facade exceptions to make them slightly more useful
* confusing `IncreaseDebt` and `DecreaseDebt` events are removed in favour of pool's `Borrow` and `Repay`
To make configuration more flexible, it was decided to remove the `AddressProviderV3` from contract constructors and pass all used contract addresses as constructor arguments. On top of that, configurator/controller division was slightly revised (this one is still WIP though). Finally, we're letting go of some v1/v2 mentions in our codebase.

For a more broader view on the new configuration system, track upcoming changes in the [governance repo](https://github.com/Gearbox-protocol/governance) by @0xmikko.
This commit focuses on improving project structure.

First of all, `core-v2` references are finally removed.

Next, `governance/` directory is dissected:
* gauge and rate keeper are moved into `pool/`
* staking is moved into `core/`
* controller timelock is moved into governance repo
In this PR:
* simplify `CreditConfiguratorV3` deployment and migration
* rename `RateKeeperV3` into `TumblerV3` and separate configurator and controller's functions
* allow stateful IRMs in `PoolV3`
* a lot of minor changes (cleaner interfaces separation, version bumps, comment fixes, etc.)
That's the very commit one would expect to see the night before the audit kicks in.

Here we add the logic from `PartialLiquidationBotV3` to the credit facade. This approach has a few important benefits:
* it doesn't trigger safe pricing in the collateral check
* it allows partial liquidations during pause
* it properly handles fee-on-transfer underlying

The PR also contains some general code improvements:
* `CreditConfiguratorV3`'s constructor is more consistent
* `feeInterest` is made immutable in `CreditManagerV3`, which prevents debt manipulation by controller and improves storage packing
* some dead code is removed from libraries
The motivation is to have three singleton contracts with the same ownership model.
…283)

Previously, `ACLNonReentrantTrait` was a Swiss knife that combined all traits we commonly use, which had its benefits, but resulted in contracts having functions that they never use (like `setController` in `CreditFacadeV3` or `pause` in `PoolQuotaKeeperV3`), which is not really good considering that contract size limit, well, exists. This PR solves the original issue and makes separation of all functionality much cleaner.
Lossy liquidations no longer pause credit facade.
Instead, they must go through a contract that can enforce various policies on them.
For more context, an early implementation can be found in the governance repo.

`liquidateCreditAccount` now returns reported loss.

Access modifiers of some functions are revised.
Notion of phantom tokens is added to the core.
When adding a phantom token as collateral, credit configurator checks that its deposited token is already added as collateral.
When withdrawing a phantom token in the credit facade, a call to a withdrawer adapter is made first to unwrap phantom token into its deposited token.

Number of optimizer runs is decreased to `1000` (which was actually always used in practice) for all contracts to fit into a size limit.

---------

Co-authored-by: Van0k <ivkamakin@gmail.com>
Having `contractType` return the full contract name makes more sense and doesn't cost anything since it shouldn't really be queried on-chain.

The general rule for naming is to use snake-cased capitalized name of the contract without the `V3` prefix.
The exceptions are contracts that implement interfaces `IAdapter`, `IPriceFeed`, `IBot`, `IRateKeeper`, `IInterestRateModel` (also `IZapper`, which is not included in this repo), which start with respective abbreviation.
lekhovitsky and others added 6 commits September 13, 2024 14:41
Previously, `TumblerV3`'s constructor was accepting `pool` as argument and reading `poolQuotaKeeper` from there. This caused complications in deployments since it required a configurator-only function `setPoolQuotaKeeper` to be called between contract creations. This PR changes the constructor to accept `poolQuotaKeeper` instead of the pool, which allows to deploy contracts first and configure them later.
Note that this is the only occurrence of such issue in core contracts.
* feat: integration test helper updated for v3.1

* fix: add new adapter configs

* fix: remove troublesome vm invocations in tests

* fix: remove time warp in test helper
doomsower and others added 13 commits November 28, 2024 08:26
- set of emergency liquidators is now stored in ACL instead of credit facades
- credit facade's constructor accepts ACL as argument since deployed pools have legacy acl
- other contracts don't use roles at all so they can just inherit ACL even from deployed pools
- `IRateKeeper` now declares the signature of `addToken`
- `TumblerV3` accepts pool as constructor argument instead of the quota keeper for consistency
- `CreditManagerV3`'s constructor now accepts liquidation fees as parameters
- `ltUnderlying` is now `immutable`
- `setFees` performs more checks on passed values
- `rampDuration` should be at least 2 days
- `newExpirationDate` is updated to be at least 2 weeks from the current timestamp
This commit also contains minor changes to allow migration from v3.0.x to v3.1.x:
- `CreditConfiguratorV3`'s constructor accepts `acl` as argument
- `CreditFacadeV3`'s constructor accepts `lossPolicy` as argument
- `lossPolicy` is no longer migrated during credit facade replacement
- add base account factory interface
- rename existing account factory into default
- `addCreditManager` is no longer `onlyOwner`

The last change is required for the new governance framework which deploys separate AF per each CM.
`addCreditManager` is called atomically with AF deployment so front-running is not an issue.
Adding other credit managers, even malicious ones, can't mess with main one CA's.
Required for the new governance framework.
Malicious triplets of CM-CF-CA can't mess with permissions of normal CAs.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants