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

3.1.0 #1061

Merged
merged 563 commits into from
Feb 7, 2024
Merged

3.1.0 #1061

Changes from 1 commit
Commits
Show all changes
563 commits
Select commit Hold shift + click to select a range
a22f53f
fix typo
tbrent May 19, 2023
0ba27bf
align P0 RToken with P1
tbrent May 19, 2023
17d10be
fix RToken test
tbrent May 19, 2023
de997b0
remove unreachable line
tbrent May 19, 2023
064f02f
add test nit
tbrent May 19, 2023
da63858
Merge pull request #829 from reserve-protocol/gas-optimize-rebalance
tbrent May 19, 2023
1a168b6
Merge branch '3.0.0' into manipulated-prices
pmckelvy1 May 19, 2023
2a7e75a
simplify RToken/BackingManager relationship + remove redundant modifiers
tbrent May 19, 2023
1379fcf
tests
tbrent May 19, 2023
15faffc
gas snapshots
tbrent May 19, 2023
6eda68b
polish off RToken + final snapshots
tbrent May 20, 2023
9bdb1e3
keep notTradingPausedOrFrozen on setBasketsNeeded
tbrent May 20, 2023
6b58e9f
re-order tryTrade and document nonReentrant testatibility
tbrent May 20, 2023
7265e24
fix RTokenP0
tbrent May 20, 2023
cb6c045
fix integration test inconsistency in CI
tbrent May 20, 2023
090be39
Merge branch 'manipulated-prices' into 3.0.0-audit-tbrent
tbrent May 20, 2023
de6f2da
fix P1 tests
tbrent May 20, 2023
ac26373
TraderP1: fix ordering and label nonReentrant requirement
tbrent May 20, 2023
659d3c8
test cacheComponents() doesn't break anything
tbrent May 20, 2023
38b86cd
make auction algorithm far more general; switch to 40%/60% 30m
tbrent May 20, 2023
215bedd
cache components P1 only
tbrent May 20, 2023
9be8709
snipe in last possible second in tests
tbrent May 20, 2023
2bb2e13
updated gas snapshots
tbrent May 20, 2023
352ea80
cacheComponents the right way
tbrent May 20, 2023
318c8c6
Merge pull request #828 from reserve-protocol/manipulated-prices
tbrent May 20, 2023
eed2ebd
Merge branch '3.0.0' into 3.0.0-audit-tbrent
tbrent May 20, 2023
b096416
updated gas snapshots
tbrent May 20, 2023
12812c3
nit over DutchTrade comments
tbrent May 20, 2023
f4beb60
a few more comments
tbrent May 20, 2023
3d6f097
Facades: terser way to try-catch 3.0.0/2.1.0 implementations
tbrent May 21, 2023
4e7697a
FacadeRead: remove basketNonce from redeem function to match RToken.r…
tbrent May 21, 2023
40de8d1
FacadeRead.nextRecollateralizationAuction: make backwards compatible …
tbrent May 21, 2023
205befd
fix compile
tbrent May 21, 2023
2831935
docs/system-design.md: document dutch auctions
tbrent May 21, 2023
58d6795
docs/system-design.md: document all the places we make a blocktime as…
tbrent May 21, 2023
fec188c
CHANGELOG.md: partially complete
tbrent May 21, 2023
40078c0
invert changelog
tbrent May 21, 2023
3a85b21
fix call to settle trade
julianmrodri May 22, 2023
c73aa2a
Merge pull request #832 from reserve-protocol/fix-facaderead
tbrent May 22, 2023
c509a2c
Merge branch '3.0.0' into 3.0.0-audit-tbrent
tbrent May 22, 2023
59156a9
bump Versioned mixin
tbrent May 22, 2023
830d070
FacadeRead/Act: parse version and make version-specific call
tbrent May 22, 2023
d014777
fix typo
tbrent May 22, 2023
f425495
lint clean
tbrent May 22, 2023
1fe413d
add back tests for transfer/transferFrom to RToken
tbrent May 22, 2023
8cc1cea
Merge pull request #831 from reserve-protocol/3.0.0-audit-tbrent
tbrent May 22, 2023
c29455f
bump suggested withdrawalLeak to 1%
tbrent May 22, 2023
6db28bd
bump suggested withdrawalLeak to 5%
tbrent May 22, 2023
e0b66e4
nitpicks
akshatmittal May 22, 2023
80a3a93
use 3.0.0 in tests for Permit approvals, etc
tbrent May 22, 2023
da6d2ce
Remove comment
akshatmittal May 22, 2023
aa6f130
Merge pull request #834 from reserve-protocol/3.0.0-review-akshat
akshatmittal May 22, 2023
57a77ff
Merge pull request #833 from reserve-protocol/parse-version
tbrent May 22, 2023
b72d3f6
document StRSR.cancelUnstake
tbrent May 23, 2023
ab35193
remove all mention of manageTokens
tbrent May 23, 2023
6e9e32f
remove kruft event
tbrent May 23, 2023
e1b2254
update RewardableLibP1 comments
tbrent May 23, 2023
d6459b3
CHANGELOG.md
tbrent May 23, 2023
647b6c0
add summaries
tbrent May 23, 2023
be89c47
CHANGELOG.md: 3.0.0 upgrade instructions
tbrent May 23, 2023
0c11e56
Merge pull request #835 from reserve-protocol/3.0.0-docs
tbrent May 23, 2023
5028f3a
FacadeRead.overview(): do not revert if an asset lotLow is 0
tbrent May 23, 2023
9ade0b3
move trading functions around. FacadeRead was over limit
tbrent May 24, 2023
35d015b
new FacadeRead/FacadeAct addresses
tbrent May 24, 2023
0f4115f
basket handler fix in historical basket
julianmrodri May 24, 2023
cfd1635
add untestable comments
julianmrodri May 24, 2023
c4ec247
Merge pull request #836 from reserve-protocol/3.0.0-rc2
tbrent May 24, 2023
9d0e65f
3.0.0 rc3 (#837)
julianmrodri Jul 3, 2023
498819c
3.0.0 rc4 (#857)
tbrent Jul 3, 2023
1e24984
Merge branch 'master' into 3.0.0
tbrent Jul 3, 2023
a82b672
fix compiling
tbrent Jul 3, 2023
3d847b0
lint clean
tbrent Jul 3, 2023
a99856e
BasketHandlerP1 to under contract limit
tbrent Jul 3, 2023
23ffa89
nit
tbrent Jul 3, 2023
16b4c87
Broker.test.ts
tbrent Jul 4, 2023
33454b5
Revenues.test.ts
tbrent Jul 4, 2023
fe85f8a
curve collateralTests.ts
tbrent Jul 4, 2023
e51b466
Fix 4byte 300 (#862)
pmckelvy1 Jul 5, 2023
aedbd14
prettier fixes 3.0.0 (#859)
julianmrodri Jul 6, 2023
ce892b2
ci tests - non-determinism (#858)
julianmrodri Jul 6, 2023
eea6776
fix storage slots Distributor (#865)
julianmrodri Jul 7, 2023
e351b32
additional furnace timestamp check (#866)
julianmrodri Jul 7, 2023
6da3481
Base Testnet configuration (#867)
julianmrodri Jul 11, 2023
a1092d7
Base Testnet configuration (#867)
julianmrodri Jul 11, 2023
05961a1
Stargate Asset Plugin (#863)
akshatmittal Jul 18, 2023
9ee60f1
Update mattjurenka/morpho to 3.0.0 (#853)
jankjr Jul 18, 2023
e92b43a
Allow `settleTrade` when paused or frozen (#876)
akshatmittal Jul 28, 2023
3c20f04
Morpho - Add missing tokens to deployment and expand unit tests (#874)
jankjr Aug 1, 2023
e85ed27
Zero distribution (#878)
tbrent Aug 2, 2023
12c81a0
Bunch of small changes (#877)
akshatmittal Aug 2, 2023
809a8d2
useAvailable when setting throttles. (#872)
pmckelvy1 Aug 3, 2023
64ed2a9
Disable dutch auctions per-collateral (#873)
tbrent Aug 3, 2023
ef66344
c4 #51 (#871)
pmckelvy1 Aug 3, 2023
117f63e
gas test asset.refresh() for all tests (#880)
tbrent Aug 4, 2023
a6871ac
Fix 4byte Integration (#879)
akshatmittal Aug 7, 2023
949b0be
Dutch trade decimals (#883)
tbrent Aug 8, 2023
9655b34
add new tenderly fork with different chain id
tbrent Aug 8, 2023
9d8b7e2
tenderly fork addresses
tbrent Aug 8, 2023
7aa0628
init readme doc for building on top
tbrent Aug 8, 2023
fe5d38d
README: add responsible disclosure section while we're at it
tbrent Aug 8, 2023
e8f5568
C4 #29 (#885)
tbrent Aug 9, 2023
30d5bfc
[docs] Positive Token Redemption Value (#887)
akshatmittal Aug 10, 2023
4ce086f
C4: handle Chainlink oracle deprecation (#886)
jankjr Aug 10, 2023
20bedef
C4: StRSR reset stakes functionality (#888)
julianmrodri Aug 10, 2023
809b4a8
C4: add test to show effect of someone frontrunning a gnosis trade (#…
jankjr Aug 11, 2023
e5f0a36
remove --parallel from all package.json targets (#893)
tbrent Aug 11, 2023
08212ff
RecollateralizationLib gas optimization (#890)
tbrent Aug 11, 2023
6d4cf57
Gas tests (#895)
tbrent Aug 14, 2023
99d9db7
Bunch of gas optimizations (#894)
akshatmittal Aug 14, 2023
11aa80b
deployment: overwrite addresses when working with tenderly
tbrent Aug 18, 2023
bc8a177
do not stop refreshing prices for DISABLED collateral (#902)
tbrent Aug 21, 2023
54dde6d
update gas snapshots (#904)
tbrent Aug 21, 2023
5d551f4
Single price (#900)
tbrent Aug 21, 2023
45d8c36
c4: #5 Potential Early Exploit in Morho-Aave ERC4626 Implementation (…
jankjr Aug 21, 2023
2cb41d4
avoid revert when checking recoll auctions
julianmrodri Aug 22, 2023
91cc33e
rollback change in facade
julianmrodri Aug 22, 2023
19d84ef
C4: #35 #32, fixes rETH / cbETH / ankrETH ref unit and adds soft defa…
jankjr Aug 22, 2023
f8a7519
document recommended throttle limits. (#905)
pmckelvy1 Aug 22, 2023
006eb16
fix rebalance in facade (#908)
julianmrodri Aug 22, 2023
1b37c77
C4 39 use comet decimals instead of wrapper decimals. (#889)
pmckelvy1 Aug 22, 2023
755cf3c
update Asset price comment. (#910)
pmckelvy1 Aug 23, 2023
4fb96fa
C4 Audit (Plugin) Changes (#896)
akshatmittal Aug 23, 2023
8aa658e
Restrict disabling dutch auctions to those started by the BackingMana…
tbrent Aug 23, 2023
2c98933
Stargate fixes (#881)
pmckelvy1 Aug 24, 2023
a0480a8
3.0.0 rc5 (#882)
pmckelvy1 Aug 24, 2023
c10d1cf
README
tbrent Aug 23, 2023
c4c0a2a
nit: re-order usings to alphabetic ordering
tbrent Aug 24, 2023
1828744
C4 40: Restrict dutch trades to being disabled only by BackingManager…
tbrent Aug 24, 2023
97f6d4b
CHANGELOG.md
tbrent Aug 24, 2023
51bbdf1
collateral.md
tbrent Aug 24, 2023
4ed50dc
mev.md
tbrent Aug 24, 2023
9dc44c6
save gas by only checking aggregator if there is a revert (#914)
tbrent Aug 25, 2023
544213c
Merge branch '3.0.0' into 3.0.0-rc6
tbrent Aug 25, 2023
14600bd
Merge branch '3.0.0-rc6' into docs
tbrent Aug 25, 2023
9657c31
facade support batch auctions (#918)
julianmrodri Aug 27, 2023
1db057b
document RTokenAsset.price() oracleError double-counting (#916)
tbrent Aug 28, 2023
57c88d1
try catch on ctoken exchangeRateCurrent (#921)
julianmrodri Aug 30, 2023
ea1e6c1
Clarify rewards handling on transfer (#920)
julianmrodri Aug 30, 2023
b420059
3.1.0 c4 20 (#922)
tbrent Aug 31, 2023
b0849fd
C4 +inf (#917)
tbrent Aug 31, 2023
1cbbc46
Merge branch '3.0.0-rc6' into 3.1.0-rc1
tbrent Aug 31, 2023
4d989e5
distribute token to buy in setDistribution (#925)
julianmrodri Aug 31, 2023
875bfc3
C4 mit 31 - standoff scenario (#923)
pmckelvy1 Aug 31, 2023
8d9edaa
cherry-pick enable-only auction setters (#924)
tbrent Aug 31, 2023
907299c
loss of pending rewards when claiming in StaticAToken (#926)
julianmrodri Aug 31, 2023
e1d26ca
update CHANGELOG and a few stale comments
tbrent Aug 31, 2023
3897314
Merge branch '3.0.0-rc6' into docs
tbrent Aug 31, 2023
1bcc268
clarify aave V2 erc20s don't need to upgrade
tbrent Aug 31, 2023
8487981
Merge branch 'docs' into 3.1.0-rc1
tbrent Aug 31, 2023
817c36d
CHANGELOG.md
tbrent Aug 31, 2023
9587d28
compile
tbrent Aug 31, 2023
ecc62f3
Update docs for 3.0.0 (#915)
tbrent Sep 1, 2023
b31005b
Upg checker 3.0 (#909)
julianmrodri Sep 1, 2023
5d04fbb
price(): fix possible overflow threat
tbrent Sep 1, 2023
3a198ee
Additional checks and logging (#929)
julianmrodri Sep 1, 2023
18f3b9d
enforce UNPRICED if high price overflows
tbrent Sep 1, 2023
999c7e3
add oracle helpers for testing decay/precise prices
tbrent Sep 1, 2023
53aeffd
decrease testing oracle timeout
tbrent Sep 1, 2023
6611712
Merge branch '3.0.0-rc6' into 3.1.0-rc1
pmckelvy1 Sep 1, 2023
5289955
Asset.test.ts
tbrent Sep 1, 2023
acc6722
Collateral.test.ts
tbrent Sep 1, 2023
e5ffdaf
Asset.test.ts
tbrent Sep 1, 2023
4c80697
test/integration/AssetPlugins.test.ts
tbrent Sep 1, 2023
4b1fcf7
cap maxTradeSell using low price, not high
tbrent Sep 1, 2023
4641d0f
EasyAuction.test.ts
tbrent Sep 1, 2023
1e5e647
test/plugins/individual-collateral/**/*.test.ts
tbrent Sep 2, 2023
9745ed3
Merge branch '3.1.0-rc1' of github.com:reserve-protocol/protocol into…
tbrent Sep 2, 2023
53f24f7
fix AssetPlugins integration tests
tbrent Sep 2, 2023
7a1b16f
Revenues.test.ts
tbrent Sep 2, 2023
f720f27
Recollateralization.test.ts
tbrent Sep 2, 2023
1deef71
CTokenFiatCollateral.test.ts
tbrent Sep 2, 2023
8cd6317
ComplexBasket.test.ts
tbrent Sep 2, 2023
dd69679
Facade.test.ts
tbrent Sep 2, 2023
722fea6
Main.test.ts
tbrent Sep 2, 2023
843a9c6
fix plugin tests.
pmckelvy1 Sep 3, 2023
86aa66b
fix final failing tests
tbrent Sep 5, 2023
b7c9581
advance oracles to prevent timeouts (#933)
tbrent Sep 11, 2023
632fe66
merge 3.0.0 in
tbrent Oct 2, 2023
0f2d605
Merge branch 'master' into 3.1.0
tbrent Oct 2, 2023
04e4e5a
cleanup
tbrent Oct 2, 2023
4106b1a
more cleanup
tbrent Oct 2, 2023
7262b6c
more cleanup
tbrent Oct 3, 2023
7de7885
fix broken tests
tbrent Oct 3, 2023
14a46ae
gas snapshots
tbrent Oct 3, 2023
1adc381
remove some bad merge kruft
tbrent Oct 3, 2023
9a67530
comments and cosmetics
tbrent Oct 3, 2023
a9043a8
Merge branch 'master' into 3.1.0
tbrent Oct 6, 2023
6a8a2bf
Trust M-01 & M-02: RevenueTrader.settleTrade() (#966)
julianmrodri Oct 9, 2023
ae598c6
Trust M-11: Fix storage slots (#968)
julianmrodri Oct 9, 2023
ce38d3b
Revert "Trust M-01 & M-02: RevenueTrader.settleTrade() (#966)"
julianmrodri Oct 9, 2023
ef0a1c3
Trust M-01 & M-02: RevenueTrader.settleTrade() (#969)
julianmrodri Oct 12, 2023
535dbc3
TRUST M-06: Keep buffer when minting rtoken revenue (#972)
julianmrodri Oct 16, 2023
ab79276
TRUST Recommendation 1: reward and underlying checks in RewardERC20 w…
julianmrodri Oct 16, 2023
2de6b0d
fix lint in Revenue traders
julianmrodri Oct 17, 2023
29c0f4c
TRUST QA-2: DefaultThreshold check for Non-Self referential (#980)
julianmrodri Oct 17, 2023
a007c47
Trust M-07: RTokenAsset.refresh() (#964)
tbrent Oct 18, 2023
de352e1
TRUST L-7: Restriction on reportViolation (#981)
julianmrodri Oct 19, 2023
fcade85
Trst-M-11 (#979)
tbrent Oct 19, 2023
35b063c
TRUST M-4: Call reward accounting functions (#984)
julianmrodri Oct 20, 2023
b23cf5c
Merge branch 'master' into 3.1.0
tbrent Oct 20, 2023
124e401
gas snapshots
tbrent Oct 20, 2023
6fccc54
TRUST QA-4: Smoother exposedRefPrice in case of default (#987)
julianmrodri Oct 23, 2023
c1e9f04
Trst m 14 (#982)
tbrent Oct 24, 2023
6bc0b02
TRUST QA-3: Set correct version (#985)
julianmrodri Oct 24, 2023
8d96002
TRUST QA-5/10/11: Optimizations on BasketHandler (#986)
julianmrodri Oct 24, 2023
c20ea91
TRUST QA-6/7: Optimizations in Distributor (#988)
julianmrodri Oct 24, 2023
5aa2d4e
gas snapshots
tbrent Oct 25, 2023
a7f76a7
TRUST QA-21: minimum voting delay (#990)
julianmrodri Oct 25, 2023
6a8fae6
Merge branch 'master' into 3.1.0
akshatmittal Oct 27, 2023
89128e3
Trust M-03: track balances out on trade for RTokenAsset.price() (#973)
tbrent Oct 30, 2023
819446b
TRUST QA-12: default decimals (#991)
julianmrodri Oct 31, 2023
cbbc0b4
TRUST QA-20: Fix morpho DAI oracle timeout mainnet (#995)
julianmrodri Oct 31, 2023
237c0c3
TRUST L-5: add comment for non supported metapools (#997)
julianmrodri Oct 31, 2023
27522af
TRUST QA-13/14: Compoundv3 tweaks (#999)
julianmrodri Oct 31, 2023
75ffbea
TRUST QA-15: Compoundv2 claiming (#1000)
julianmrodri Oct 31, 2023
6c7e449
TRUST QA-8: No revenue hiding in SDAI (#1001)
julianmrodri Oct 31, 2023
6318c68
TRUST H-3: calling incorrect hasPermission() function (#1003)
julianmrodri Oct 31, 2023
b8f4d84
CHANGELOG: add ERC20 upgrades
tbrent Oct 31, 2023
7af3d31
Collateral plugin integration tests (#989)
tbrent Nov 1, 2023
64684ff
TRUST M-8: Reward distribution in `RewardableERC20` (#994)
julianmrodri Nov 1, 2023
d994934
TRUST L-8: Fix reverts due to rounding in CusdcWrapper (#1005)
julianmrodri Nov 2, 2023
92fbdec
TRUST M-9: pegprice in `frxETH` (#1006)
julianmrodri Nov 2, 2023
bc41785
TRUST H-4: Single reward token (#1007)
julianmrodri Nov 2, 2023
87fc386
skip 0-valued transfer (#1015)
tbrent Nov 15, 2023
595eabe
add lotPrice() back everywhere (unused) for backwards compatibility (…
tbrent Nov 17, 2023
f1459e6
TRUST M-13: Use latest Convex contract (#1008)
julianmrodri Nov 27, 2023
abf9f46
TRUST H2 (#1013)
jankjr Nov 30, 2023
1a5f954
Merge branch 'master' into 3.1.0
tbrent Dec 5, 2023
05c1d66
fix deployment
tbrent Dec 5, 2023
2770b2a
fix mainnet integration tests
tbrent Dec 5, 2023
3ae2f07
floor yearn V2 refPerTok() to be consistent with rest of plugins
tbrent Dec 6, 2023
71f6091
TRUST-H4: Add additional comments (#1034)
julianmrodri Jan 12, 2024
b2596de
TRUST-M3: Fix Storage Gap (#1032)
julianmrodri Jan 12, 2024
c2aaa30
TRUST-L8: Remove unnecessary cast (#1033)
julianmrodri Jan 12, 2024
d7315fb
Invariant Monitor contract (#1017)
julianmrodri Jan 15, 2024
8d6933d
fixes to exhaustive tests (#1037)
julianmrodri Jan 16, 2024
ed9daa0
Fix command in extreme test docs (#1038)
julianmrodri Jan 16, 2024
ffa2868
Merge branch 'master' into 3.1.0
tbrent Jan 17, 2024
a2750ee
Yearn plugin scripts (#1014)
tbrent Jan 17, 2024
86fd0ec
fix slither in CI
tbrent Jan 17, 2024
54bf1b5
fix deployment scripts in CI
tbrent Jan 17, 2024
82bca4b
remove unused function on IMorpho interface (#1030)
tbrent Jan 17, 2024
2e3f52f
Trust Mitigation Review: Morpho (#1036)
akshatmittal Jan 19, 2024
20c8f60
UnstakingStarted event fix (#1042)
tbrent Jan 19, 2024
cf30911
fix sfrxETH Collateral, add new oracle (#1026)
pmckelvy1 Jan 20, 2024
e26ba6e
Revert "fix sfrxETH Collateral, add new oracle" (#1043)
tbrent Jan 20, 2024
2fb9a01
comment nit
tbrent Jan 20, 2024
4beaab9
changelog
tbrent Jan 20, 2024
dd28e02
add back low <= high asserts
tbrent Jan 22, 2024
f112c1d
Merge branch 'master' into 3.1.0
akshatmittal Feb 7, 2024
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
Prev Previous commit
Next Next commit
BasketHandlerP1 to under contract limit
tbrent committed Jul 3, 2023
commit a99856e36344cc85e181814a48ab932b8e28d084
14 changes: 7 additions & 7 deletions contracts/p0/BasketHandler.sol
Original file line number Diff line number Diff line change
@@ -238,7 +238,7 @@ contract BasketHandlerP0 is ComponentP0, IBasketHandler {
external
governance
{
require(erc20s.length > 0, "cannot empty basket");
require(erc20s.length > 0, "empty basket");
require(erc20s.length == targetAmts.length, "must be same length");
requireValidCollArray(erc20s);

@@ -747,10 +747,10 @@ contract BasketHandlerP0 is ComponentP0, IBasketHandler {
IERC20 zero = IERC20(address(0));

for (uint256 i = 0; i < erc20s.length; i++) {
require(erc20s[i] != main.rsr(), "RSR is not valid collateral");
require(erc20s[i] != IERC20(address(main.rToken())), "RToken is not valid collateral");
require(erc20s[i] != IERC20(address(main.stRSR())), "stRSR is not valid collateral");
require(erc20s[i] != zero, "address zero is not valid collateral");
require(erc20s[i] != main.rsr(), "invalid collateral");
require(erc20s[i] != IERC20(address(main.rToken())), "invalid collateral");
require(erc20s[i] != IERC20(address(main.stRSR())), "invalid collateral");
require(erc20s[i] != zero, "invalid collateral");
}

require(ArrayLib.allUnique(erc20s), "contains duplicates");
@@ -780,11 +780,11 @@ contract BasketHandlerP0 is ComponentP0, IBasketHandler {
for (uint256 i = 0; i < newERC20s.length; i++) {
bytes32 targetName = main.assetRegistry().toColl(newERC20s[i]).targetName();
(bool contains, uint256 amt) = _targetAmts.tryGet(targetName);
require(contains && amt >= newTargetAmts[i], "new basket adds target weights");
require(contains && amt >= newTargetAmts[i], "new target weights");
if (amt == newTargetAmts[i]) _targetAmts.remove(targetName);
else _targetAmts.set(targetName, amt - newTargetAmts[i]);
}
require(_targetAmts.length() == 0, "new basket missing target weights");
require(_targetAmts.length() == 0, "missing target weights");
}

/// Good collateral is registered, collateral, SOUND, has the expected targetName,
19 changes: 10 additions & 9 deletions contracts/p1/BasketHandler.sol
Original file line number Diff line number Diff line change
@@ -176,7 +176,7 @@ contract BasketHandlerP1 is ComponentP1, IBasketHandler {
external
governance
{
require(erc20s.length > 0, "cannot empty basket");
require(erc20s.length > 0, "empty basket");
require(erc20s.length == targetAmts.length, "must be same length");
requireValidCollArray(erc20s);

@@ -562,22 +562,23 @@ contract BasketHandlerP1 is ComponentP1, IBasketHandler {
for (uint256 i = 0; i < len; ++i) {
bytes32 targetName = assetRegistry.toColl(newERC20s[i]).targetName();
(bool contains, uint256 amt) = _targetAmts.tryGet(targetName);
require(contains && amt >= newTargetAmts[i], "new basket adds target weights");
require(contains && amt >= newTargetAmts[i], "new target weights");
if (amt > newTargetAmts[i]) _targetAmts.set(targetName, amt - newTargetAmts[i]);
else _targetAmts.remove(targetName);
}
require(_targetAmts.length() == 0, "new basket missing target weights");
require(_targetAmts.length() == 0, "missing target weights");
}

/// Require that erc20s is a valid collateral array
function requireValidCollArray(IERC20[] calldata erc20s) private view {
IERC20 zero = IERC20(address(0));

for (uint256 i = 0; i < erc20s.length; i++) {
require(erc20s[i] != rsr, "RSR is not valid collateral");
require(erc20s[i] != IERC20(address(rToken)), "RToken is not valid collateral");
require(erc20s[i] != IERC20(address(stRSR)), "stRSR is not valid collateral");
require(erc20s[i] != zero, "address zero is not valid collateral");
require(
erc20s[i] != rsr &&
erc20s[i] != IERC20(address(rToken)) &&
erc20s[i] != IERC20(address(stRSR)) &&
erc20s[i] != IERC20(address(0)),
"invalid collateral"
);
}

require(ArrayLib.allUnique(erc20s), "contains duplicates");
42 changes: 21 additions & 21 deletions test/Main.test.ts
Original file line number Diff line number Diff line change
@@ -1759,19 +1759,19 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
it('Should not allow to set prime Basket with 0 address tokens', async () => {
await expect(
freshBasketHandler.connect(owner).setPrimeBasket([ZERO_ADDRESS], [fp('1')])
).to.be.revertedWith('address zero is not valid collateral')
).to.be.revertedWith('invalid collateral')
await expect(
basketHandler.connect(owner).setPrimeBasket([ZERO_ADDRESS], [fp('1')])
).to.be.revertedWith('address zero is not valid collateral')
).to.be.revertedWith('invalid collateral')
})

it('Should not allow to set prime Basket with stRSR', async () => {
await expect(
freshBasketHandler.connect(owner).setPrimeBasket([stRSR.address], [fp('1')])
).to.be.revertedWith('stRSR is not valid collateral')
).to.be.revertedWith('invalid collateral')
await expect(
basketHandler.connect(owner).setPrimeBasket([stRSR.address], [fp('1')])
).to.be.revertedWith('stRSR is not valid collateral')
).to.be.revertedWith('invalid collateral')
})

it('Should not allow to bypass MAX_TARGET_AMT', async () => {
@@ -1785,22 +1785,22 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
// not possible on freshBasketHandler
await expect(
basketHandler.connect(owner).setPrimeBasket([token0.address], [fp('1').add(1)])
).to.be.revertedWith('new basket adds target weights')
).to.be.revertedWith('new target weights')
})

it('Should not allow to decrease prime Basket weights', async () => {
// not possible on freshBasketHandler
await expect(
basketHandler.connect(owner).setPrimeBasket([token0.address], [fp('1').sub(1)])
).to.be.revertedWith('new basket missing target weights')
).to.be.revertedWith('missing target weights')
})

it('Should not allow to set prime Basket with an empty basket', async () => {
await expect(freshBasketHandler.connect(owner).setPrimeBasket([], [])).to.be.revertedWith(
'cannot empty basket'
'empty basket'
)
await expect(basketHandler.connect(owner).setPrimeBasket([], [])).to.be.revertedWith(
'cannot empty basket'
'empty basket'
)
})

@@ -1810,7 +1810,7 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
).to.be.revertedWith('invalid target amount; must be nonzero')
await expect(
basketHandler.connect(owner).setPrimeBasket([token0.address], [0])
).to.be.revertedWith('new basket missing target weights')
).to.be.revertedWith('missing target weights')
})

it('Should be able to set exactly same basket', async () => {
@@ -1853,7 +1853,7 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
[token0.address, token1.address, token2.address, token3.address, backupToken1.address],
[fp('0.25'), fp('0.25'), fp('0.25'), fp('0.25'), fp('0.01')]
)
).to.be.revertedWith('new basket adds target weights')
).to.be.revertedWith('new target weights')

await expect(
basketHandler
@@ -1862,7 +1862,7 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
[token0.address, token1.address, token2.address, token3.address, eurToken.address],
[fp('0.25'), fp('0.25'), fp('0.25'), fp('0.25'), fp('0.01')]
)
).to.be.revertedWith('new basket adds target weights')
).to.be.revertedWith('new target weights')
})

it('Should not allow to set prime Basket as subset of old basket', async () => {
@@ -1873,15 +1873,15 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
[token0.address, token1.address, token2.address, token3.address],
[fp('0.25'), fp('0.25'), fp('0.25'), fp('0.24')]
)
).to.be.revertedWith('new basket missing target weights')
).to.be.revertedWith('missing target weights')
await expect(
basketHandler
.connect(owner)
.setPrimeBasket(
[token0.address, token1.address, token2.address],
[fp('0.25'), fp('0.25'), fp('0.25')]
)
).to.be.revertedWith('new basket missing target weights')
).to.be.revertedWith('missing target weights')
})

it('Should not allow to change target unit in old basket', async () => {
@@ -1892,27 +1892,27 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
[token0.address, token1.address, token2.address, eurToken.address],
[fp('0.25'), fp('0.25'), fp('0.25'), fp('0.25')]
)
).to.be.revertedWith('new basket adds target weights')
).to.be.revertedWith('new target weights')
})

it('Should not allow to set prime Basket with RSR/RToken', async () => {
await expect(
freshBasketHandler.connect(owner).setPrimeBasket([rsr.address], [fp('1')])
).to.be.revertedWith('RSR is not valid collateral')
).to.be.revertedWith('invalid collateral')
await expect(
basketHandler.connect(owner).setPrimeBasket([rsr.address], [fp('1')])
).to.be.revertedWith('RSR is not valid collateral')
).to.be.revertedWith('invalid collateral')

await expect(
freshBasketHandler
.connect(owner)
.setPrimeBasket([token0.address, rToken.address], [fp('0.5'), fp('0.5')])
).to.be.revertedWith('RToken is not valid collateral')
).to.be.revertedWith('invalid collateral')
await expect(
basketHandler
.connect(owner)
.setPrimeBasket([token0.address, rToken.address], [fp('0.5'), fp('0.5')])
).to.be.revertedWith('RToken is not valid collateral')
).to.be.revertedWith('invalid collateral')
})

it('Should allow to set prime Basket if OWNER', async () => {
@@ -1946,7 +1946,7 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
[token0.address, token1.address, token2.address, token3.address],
[fp('0.25'), fp('0.25'), fp('0.25'), fp('0.25')]
)
).to.be.revertedWith('new basket adds target weights')
).to.be.revertedWith('new target weights')
})

describe('Custom Redemption', () => {
@@ -2557,7 +2557,7 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
basketHandler
.connect(owner)
.setBackupConfig(ethers.utils.formatBytes32String('USD'), bn(1), [rsr.address])
).to.be.revertedWith('RSR is not valid collateral')
).to.be.revertedWith('invalid collateral')

it('Should not allow to set backup Config with duplicate ERC20s', async () => {
await expect(
@@ -2574,7 +2574,7 @@ describe(`MainP${IMPLEMENTATION} contract`, () => {
basketHandler
.connect(owner)
.setBackupConfig(ethers.utils.formatBytes32String('USD'), bn(1), [rToken.address])
).to.be.revertedWith('RToken is not valid collateral')
).to.be.revertedWith('invalid collateral')
})

it('Should allow to set backup Config if OWNER', async () => {