@harvest-finance/harvest-strategy-polygon 0.0.1-security → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of @harvest-finance/harvest-strategy-polygon might be problematic. Click here for more details.
- package/README.md +110 -5
- package/contracts/base/Controller.sol +125 -0
- package/contracts/base/ControllerV2.sol +363 -0
- package/contracts/base/FeeRewardForwarder.sol +163 -0
- package/contracts/base/PotPool.sol +360 -0
- package/contracts/base/ProfitSharingReceiver.sol +39 -0
- package/contracts/base/RewardForwarderV2.sol +109 -0
- package/contracts/base/Vault.sol +344 -0
- package/contracts/base/VaultERC4626.sol +113 -0
- package/contracts/base/VaultProxy.sol +35 -0
- package/contracts/base/VaultStorage.sol +199 -0
- package/contracts/base/VaultStorageV2.sol +196 -0
- package/contracts/base/VaultV2.sol +369 -0
- package/contracts/base/ape-base/MiniApeV2Strategy.sol +322 -0
- package/contracts/base/ape-base/interface/IMiniChefV2.sol +31 -0
- package/contracts/base/ape-base/interface/IRewarder.sol +10 -0
- package/contracts/base/factory/MegaFactory.sol +120 -0
- package/contracts/base/factory/interface/IPoolFactory.sol +6 -0
- package/contracts/base/factory/interface/IStrategyFactory.sol +6 -0
- package/contracts/base/factory/interface/IVaultFactory.sol +7 -0
- package/contracts/base/factory/pool/PotPoolFactory.sol +43 -0
- package/contracts/base/factory/strategy/UpgradableStrategyFactory.sol +19 -0
- package/contracts/base/factory/vault/RegularVaultFactory.sol +34 -0
- package/contracts/base/incentives/GlobalIncentivesHelper.sol +167 -0
- package/contracts/base/incentives/NotifyHelperGeneric.sol +61 -0
- package/contracts/base/incentives/NotifyHelperStateful.sol +290 -0
- package/contracts/base/inheritance/Controllable.sol +26 -0
- package/contracts/base/inheritance/ControllableInit.sol +31 -0
- package/contracts/base/inheritance/Governable.sol +29 -0
- package/contracts/base/inheritance/GovernableInit.sol +51 -0
- package/contracts/base/inheritance/IUpgradeSource.sol +8 -0
- package/contracts/base/inheritance/OwnableWhitelist.sol +17 -0
- package/contracts/base/inheritance/RewardTokenProfitNotifier.sol +48 -0
- package/contracts/base/inheritance/Storage.sol +36 -0
- package/contracts/base/interface/IController.sol +30 -0
- package/contracts/base/interface/IControllerV2.sol +135 -0
- package/contracts/base/interface/IERC4626.sol +263 -0
- package/contracts/base/interface/IFeeRewardForwarder.sol +9 -0
- package/contracts/base/interface/IProfitSharingReceiver.sol +10 -0
- package/contracts/base/interface/IRewardForwarder.sol +58 -0
- package/contracts/base/interface/IRewardPool.sol +34 -0
- package/contracts/base/interface/IStrategy.sol +25 -0
- package/contracts/base/interface/IUniversalLiquidator.sol +21 -0
- package/contracts/base/interface/IUniversalLiquidatorRegistry.sol +20 -0
- package/contracts/base/interface/IUpgradeSource.sol +8 -0
- package/contracts/base/interface/IVault.sol +35 -0
- package/contracts/base/interface/aave/DataTypes.sol +266 -0
- package/contracts/base/interface/aave/IAToken.sol +37 -0
- package/contracts/base/interface/aave/IPool.sol +13 -0
- package/contracts/base/interface/balancer/Gauge.sol +22 -0
- package/contracts/base/interface/balancer/IBVault.sol +557 -0
- package/contracts/base/interface/balancer/IBalancerMinter.sol +114 -0
- package/contracts/base/interface/balancer/linearPool/ILinearPool.sol +185 -0
- package/contracts/base/interface/balancer/linearPool/ILinearPoolFactory.sol +16 -0
- package/contracts/base/interface/balancer/linearPool/ILinearPoolRebalancer.sol +8 -0
- package/contracts/base/interface/balancer/linearPool/IPoolSwapStructs.sol +57 -0
- package/contracts/base/interface/caviar/ICaviarChef.sol +16 -0
- package/contracts/base/interface/compound/IComet.sol +114 -0
- package/contracts/base/interface/compound/ICometRewards.sol +17 -0
- package/contracts/base/interface/curve/Gauge.sol +25 -0
- package/contracts/base/interface/curve/ICurveDeposit_2token.sol +25 -0
- package/contracts/base/interface/curve/ICurveDeposit_2token_underlying.sol +31 -0
- package/contracts/base/interface/curve/ICurveDeposit_3token.sol +25 -0
- package/contracts/base/interface/curve/ICurveDeposit_3token_meta.sol +20 -0
- package/contracts/base/interface/curve/ICurveDeposit_3token_underlying.sol +31 -0
- package/contracts/base/interface/curve/ICurveDeposit_4token.sol +25 -0
- package/contracts/base/interface/curve/ICurveDeposit_4token_meta.sol +20 -0
- package/contracts/base/interface/curve/ICurveDeposit_4token_underlying.sol +31 -0
- package/contracts/base/interface/curve/ICurveDeposit_5token.sol +25 -0
- package/contracts/base/interface/curve/ICurveDeposit_5token_meta.sol +20 -0
- package/contracts/base/interface/curve/ICurveDeposit_5token_underlying.sol +31 -0
- package/contracts/base/interface/curve/ICurveDeposit_6token.sol +25 -0
- package/contracts/base/interface/curve/ICurveDeposit_6token_meta.sol +20 -0
- package/contracts/base/interface/gamma/IClearing.sol +8 -0
- package/contracts/base/interface/gamma/IHypervisor.sol +17 -0
- package/contracts/base/interface/gamma/IStakingRewards.sol +35 -0
- package/contracts/base/interface/gamma/IUniProxy.sol +15 -0
- package/contracts/base/interface/kyber/IDMMExchangeRouter.sol +69 -0
- package/contracts/base/interface/kyber/IDMMFactory.sol +35 -0
- package/contracts/base/interface/kyber/IDMMLiquidityRouter.sol +204 -0
- package/contracts/base/interface/kyber/IDMMPool.sol +42 -0
- package/contracts/base/interface/kyber/IDMMRouter01.sol +12 -0
- package/contracts/base/interface/kyber/IDMMRouter02.sol +55 -0
- package/contracts/base/interface/kyber/IKyberZap.sol +7 -0
- package/contracts/base/interface/merkl/IDistributor.sol +6 -0
- package/contracts/base/interface/morpho/IMetaMorpho.sol +7 -0
- package/contracts/base/interface/pearl/IGauge.sol +13 -0
- package/contracts/base/interface/pearl/IPair.sol +44 -0
- package/contracts/base/interface/pearl/IRouter.sol +305 -0
- package/contracts/base/interface/quickswap/IDragonLair.sol +25 -0
- package/contracts/base/interface/quickswap/IMasterChef.sol +13 -0
- package/contracts/base/interface/uniswap/IUniswapV2Factory.sol +15 -0
- package/contracts/base/interface/uniswap/IUniswapV2Migrator.sol +6 -0
- package/contracts/base/interface/uniswap/IUniswapV2Pair.sol +59 -0
- package/contracts/base/interface/uniswap/IUniswapV2Router01.sol +96 -0
- package/contracts/base/interface/uniswap/IUniswapV2Router02.sol +137 -0
- package/contracts/base/interface/uniswap/IUniswapV3Pool.sol +24 -0
- package/contracts/base/interface/uniswap/IUniswapV3Router.sol +64 -0
- package/contracts/base/interface/uniswap/IWETH.sol +8 -0
- package/contracts/base/interface/uniswap/pool/IUniswapV3PoolActions.sol +103 -0
- package/contracts/base/interface/uniswap/pool/IUniswapV3PoolDerivedState.sol +40 -0
- package/contracts/base/interface/uniswap/pool/IUniswapV3PoolEvents.sol +121 -0
- package/contracts/base/interface/uniswap/pool/IUniswapV3PoolImmutables.sol +35 -0
- package/contracts/base/interface/uniswap/pool/IUniswapV3PoolOwnerActions.sol +23 -0
- package/contracts/base/interface/uniswap/pool/IUniswapV3PoolState.sol +116 -0
- package/contracts/base/masterchef-base/MasterChefHodlStrategy.sol +240 -0
- package/contracts/base/masterchef-base/MasterChefStrategy.sol +364 -0
- package/contracts/base/masterchef-base/interfaces/IMasterChef.sol +12 -0
- package/contracts/base/migration/vaultMigratable_2JPYv2.sol +87 -0
- package/contracts/base/migration/vaultMigratable_bal2EUR_PAR.sol +121 -0
- package/contracts/base/migration/vaultMigratable_bal2EUR_agEUR.sol +121 -0
- package/contracts/base/migration/vaultMigratable_balMaticX.sol +153 -0
- package/contracts/base/migration/vaultMigratable_balStMatic.sol +153 -0
- package/contracts/base/noop/NoopStrategy.sol +89 -0
- package/contracts/base/noop/NoopStrategyUpgradeable.sol +92 -0
- package/contracts/base/sushi-base/MiniChefV2Strategy.sol +380 -0
- package/contracts/base/sushi-base/interface/IMiniChefV2.sol +31 -0
- package/contracts/base/sushi-base/interface/IRewarder.sol +9 -0
- package/contracts/base/sushi-base/lib/BoringERC20.sol +30 -0
- package/contracts/base/upgradability/Address.sol +33 -0
- package/contracts/base/upgradability/BaseUpgradeabilityProxy.sol +61 -0
- package/contracts/base/upgradability/BaseUpgradeableStrategy.sol +111 -0
- package/contracts/base/upgradability/BaseUpgradeableStrategyStorage.sol +176 -0
- package/contracts/base/upgradability/BaseUpgradeableStrategyStorageV2.sol +290 -0
- package/contracts/base/upgradability/BaseUpgradeableStrategyV2.sol +145 -0
- package/contracts/base/upgradability/IUpgradable.sol +7 -0
- package/contracts/base/upgradability/Proxy.sol +71 -0
- package/contracts/base/upgradability/ReentrancyGuard.sol +57 -0
- package/contracts/base/upgradability/ReentrancyGuardUpgradeable.sol +51 -0
- package/contracts/base/upgradability/StrategyProxy.sol +35 -0
- package/contracts/base/wmatic/WMATIC.sol +8 -0
- package/contracts/strategies/aave/AaveSupplyStrategy.sol +213 -0
- package/contracts/strategies/aave/AaveSupplyStrategyMainnet_DAI.sol +23 -0
- package/contracts/strategies/aave/AaveSupplyStrategyMainnet_EURS.sol +23 -0
- package/contracts/strategies/aave/AaveSupplyStrategyMainnet_USDC.sol +23 -0
- package/contracts/strategies/aave/AaveSupplyStrategyMainnet_USDCe.sol +23 -0
- package/contracts/strategies/aave/AaveSupplyStrategyMainnet_USDT.sol +23 -0
- package/contracts/strategies/ape/ApeStrategyMainnet_BANANA_MATIC.sol +36 -0
- package/contracts/strategies/ape/ApeStrategyMainnet_BNB_MATIC.sol +36 -0
- package/contracts/strategies/ape/ApeStrategyMainnet_BTC_MATIC.sol +36 -0
- package/contracts/strategies/ape/ApeStrategyMainnet_DAI_MATIC.sol +36 -0
- package/contracts/strategies/ape/ApeStrategyMainnet_DAI_USDC.sol +37 -0
- package/contracts/strategies/ape/ApeStrategyMainnet_ETH_MATIC.sol +36 -0
- package/contracts/strategies/ape/ApeStrategyMainnet_USDT_MATIC.sol +36 -0
- package/contracts/strategies/aura/AuraStrategy.sol +347 -0
- package/contracts/strategies/aura/AuraStrategyMainnet_jEUR_PAR.sol +30 -0
- package/contracts/strategies/aura/interface/IAuraBaseRewardPool.sol +25 -0
- package/contracts/strategies/aura/interface/IAuraBooster.sol +17 -0
- package/contracts/strategies/aura/interface/IAuraDepositor.sol +7 -0
- package/contracts/strategies/balancer/BalancerStrategyV3.sol +509 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_2BRL.sol +39 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_2BRLUSD.sol +38 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_2EUR_PAR.sol +34 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_2EUR_PARv2.sol +34 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_2EUR_agEUR.sol +34 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_MATIC_USDC_ETH_BAL.sol +32 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_MaticX.sol +37 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_MaticX_amMatic.sol +38 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_SPHERE_MATIC.sol +34 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_TNGBL_USDC.sol +34 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_WBTC_ETH_USDC.sol +32 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_bbamusd.sol +36 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_frxETH.sol +32 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_frxETH_amWETH.sol +35 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_stETH.sol +35 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_stMatic.sol +36 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_stMatic_amMatic.sol +39 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_tetuBal.sol +36 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_wUSDR_USDC.sol +34 -0
- package/contracts/strategies/balancer/BalancerStrategyV3Mainnet_wstETH_amWETH.sol +37 -0
- package/contracts/strategies/balancer/interface/Gauge.sol +26 -0
- package/contracts/strategies/balancer/interface/IBVault.sol +557 -0
- package/contracts/strategies/balancer/interface/IBalanceMinter.sol +114 -0
- package/contracts/strategies/complifi/ComplifiDerivStrategy.sol +381 -0
- package/contracts/strategies/complifi/ComplifiDerivStrategyMainnet_ETH5x.sol +35 -0
- package/contracts/strategies/complifi/ComplifiStrategy.sol +362 -0
- package/contracts/strategies/complifi/ComplifiStrategyMainnet_COMFI_WETH.sol +34 -0
- package/contracts/strategies/complifi/interfaces/ILiquidityMining.sol +13 -0
- package/contracts/strategies/complifi/interfaces/ILiquidityPool.sol +63 -0
- package/contracts/strategies/complifi/interfaces/IProxyActions.sol +10 -0
- package/contracts/strategies/complifi/interfaces/IUSDCVault.sol +55 -0
- package/contracts/strategies/compound/CompoundStrategy.sol +296 -0
- package/contracts/strategies/compound/CompoundStrategyMainnet_USDC.sol +28 -0
- package/contracts/strategies/compound/CompoundStrategyMainnet_USDT.sol +28 -0
- package/contracts/strategies/compound-blue/CompoundBlueStrategy.sol +292 -0
- package/contracts/strategies/compound-blue/CompoundBlueStrategyMainnet_ETH.sol +27 -0
- package/contracts/strategies/compound-blue/CompoundBlueStrategyMainnet_USDC.sol +27 -0
- package/contracts/strategies/compound-blue/CompoundBlueStrategyMainnet_USDT.sol +27 -0
- package/contracts/strategies/convex/ConvexStrategyMainnet_3CRV.sol +40 -0
- package/contracts/strategies/convex/ConvexStrategyMainnet_3CRYPTO.sol +37 -0
- package/contracts/strategies/convex/ConvexStrategyMainnet_CRV_3CRYPTO copy.sol +37 -0
- package/contracts/strategies/convex/ConvexStrategyMainnet_MATIC_3CRYPTO.sol +37 -0
- package/contracts/strategies/convex/ConvexStrategyMainnet_USDR.sol +40 -0
- package/contracts/strategies/convex/ConvexStrategyMainnet_aCRV.sol +38 -0
- package/contracts/strategies/convex/base/ConvexStrategy.sol +480 -0
- package/contracts/strategies/convex/interface/IBaseRewardPool.sol +13 -0
- package/contracts/strategies/convex/interface/IBooster.sol +10 -0
- package/contracts/strategies/gamma-merkl/GammaMerklStrategy.sol +272 -0
- package/contracts/strategies/gamma-merkl/GammaMerklStrategyMainnet_QS_ETH_USDC.sol +25 -0
- package/contracts/strategies/gamma-merkl/GammaMerklStrategyMainnet_QS_ETH_USDT.sol +25 -0
- package/contracts/strategies/gamma-merkl/GammaMerklStrategyMainnet_QS_MATIC_USDT.sol +25 -0
- package/contracts/strategies/gamma-merkl/GammaMerklStrategyMainnet_QS_TBTC_ETH.sol +25 -0
- package/contracts/strategies/gamma-merkl/GammaMerklStrategyMainnet_QS_WBTC_ETH_w.sol +25 -0
- package/contracts/strategies/genomes/NoopStrategy_GENE_ETH.sol +23 -0
- package/contracts/strategies/genomes/NoopStrategy_GNOME_ETH.sol +23 -0
- package/contracts/strategies/idle/IdleFinanceStrategy.sol +240 -0
- package/contracts/strategies/idle/IdleStrategyDAIMainnet.sol +33 -0
- package/contracts/strategies/idle/IdleStrategyUSDCMainnet.sol +33 -0
- package/contracts/strategies/idle/IdleStrategyWETHMainnet.sol +30 -0
- package/contracts/strategies/idle/interface/IdleToken.sol +58 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3.sol +351 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2CAD.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2EUR.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2EUR_EURT.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2EUR_EURe.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2EUR_PAR.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2JPY.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2JPYv2.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2NZD.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_2SGD.sol +34 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_jCHF_USDC.sol +35 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_jCHF_WETH.sol +35 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_jEUR_USDC.sol +35 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_jEUR_WETH.sol +35 -0
- package/contracts/strategies/jarvis/JarvisHodlStrategyV3Mainnet_jGBP_USDC.sol +35 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3.sol +281 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_AUR3_USDC.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_AURJUL22_WETH.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_DEN2_4EUR.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_DEN3_4EUR.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_DEN4_4EUR.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTANGLENOV22_2EURagEUR.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTANGLE_2EURagEUR.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTJUL22_USDC.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTMAY22_USDC.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTMIMONOV22_2EURPAR.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTMIMO_2EURPAR.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTNOV22_USDC.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_JRTSEP22_USDC.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_QUI_2CAD.sol +27 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_SES_2JPY.sol +28 -0
- package/contracts/strategies/jarvis/JarvisStrategyV3Mainnet_agDEN_2EUR.sol +27 -0
- package/contracts/strategies/jarvis/interface/IElysianFields.sol +11 -0
- package/contracts/strategies/jarvis/interface/IKyberFairLaunch.sol +13 -0
- package/contracts/strategies/jarvis/interface/IKyberRewardLocker.sol +9 -0
- package/contracts/strategies/meshswap/MeshswapStrategy.sol +304 -0
- package/contracts/strategies/meshswap/MeshswapStrategyMainnet_MESH_oMOOI.sol +30 -0
- package/contracts/strategies/meshswap/MeshswapStrategyMainnet_MESH_oZEMIT.sol +30 -0
- package/contracts/strategies/meshswap/MeshswapStrategyMainnet_USDC_oUSDC.sol +31 -0
- package/contracts/strategies/meshswap/MeshswapStrategyMainnet_USDT_oUSDT.sol +31 -0
- package/contracts/strategies/meshswap/MeshswapStrategyMainnet_WMATIC_MESH.sol +27 -0
- package/contracts/strategies/meshswap/MeshswapStrategyMainnet_WMATIC_USDC.sol +28 -0
- package/contracts/strategies/meshswap/MeshswapStrategyMainnet_WMATIC_USDT.sol +28 -0
- package/contracts/strategies/meshswap/interface/IExchange.sol +9 -0
- package/contracts/strategies/meshswap/interface/IRouter.sol +68 -0
- package/contracts/strategies/pearl/CaviarStrategy.sol +244 -0
- package/contracts/strategies/pearl/CaviarStrategyMainnet_CVR.sol +26 -0
- package/contracts/strategies/pearl/PearlHodlStrategy.sol +254 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_CVR_PEARL.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_DAI_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_ETH_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_MATIC_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_PEARL_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_STAR_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_TNGBL_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_USDC_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_USDT_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_WBTC_USDR.sol +27 -0
- package/contracts/strategies/pearl/PearlHodlStrategyMainnet_wUSDR_USDR.sol +27 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategy.sol +400 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyMainnet_MATIC_ETH_narrow.sol +31 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyMainnet_MATIC_ETH_wide.sol +31 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyMainnet_MATIC_USDC_narrow.sol +31 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyMainnet_MATIC_USDC_wide.sol +31 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyMainnet_USDC_ETH_narrow.sol +34 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyMainnet_USDC_ETH_wide.sol +34 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyV2.sol +348 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyV2Mainnet_USDC_DAI.sol +28 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyV2Mainnet_USDC_USDT.sol +29 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyV2Mainnet_WBTC_ETH_narrow.sol +28 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyV2Mainnet_WBTC_USDC_narrow.sol +28 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyV2Mainnet_cbETH_ETH.sol +28 -0
- package/contracts/strategies/quick-gamma/QuickGammaStrategyV2Mainnet_wstETH_ETH.sol +28 -0
- package/contracts/strategies/uniswap-gamma/UniswapGammaStrategy.sol +312 -0
- package/contracts/strategies/uniswap-gamma/UniswapGammaStrategyMainnet_USDC_DAI.sol +28 -0
- package/contracts/strategies/uniswap-gamma/UniswapGammaStrategyMainnet_USDC_USDT.sol +28 -0
- package/contracts/strategies/uniswap-gamma/UniswapGammaStrategyMainnet_USDC_WETH.sol +28 -0
- package/contracts/strategies/uniswap-gamma/UniswapGammaStrategyMainnet_WMATIC_USDC.sol +28 -0
- package/contracts/strategies/yel/YelStrategy.sol +350 -0
- package/contracts/strategies/yel/YelStrategyMainnet_YEL_WETH.sol +29 -0
- package/hardhat.config.js +58 -0
- package/index.js +42 -0
- package/package.json +56 -6
- package/scripts/01-deploy-vault-regular-with-upgradable-strategy.js +41 -0
- package/scripts/02-deploy-vault-regular.js +35 -0
- package/scripts/03-deploy-upgradable-strategy.js +34 -0
- package/scripts/04-deploy-new-implementation.js +24 -0
- package/scripts/README.md +55 -0
- package/scripts/utils.js +42 -0
- package/test/aave/dai.js +207 -0
- package/test/aave/eurs.js +207 -0
- package/test/aave/usdc.js +206 -0
- package/test/aave/usdce.js +206 -0
- package/test/aave/usdt.js +206 -0
- package/test/ape/banana-matic.js +157 -0
- package/test/ape/bnb-matic.js +159 -0
- package/test/ape/btc-matic.js +159 -0
- package/test/ape/dai-matic.js +159 -0
- package/test/ape/dai-usdc.js +163 -0
- package/test/ape/eth-matic.js +158 -0
- package/test/ape/usdt-matic.js +159 -0
- package/test/aura/jeur-par.js +135 -0
- package/test/balancer/2brl_v3.js +123 -0
- package/test/balancer/2brlusd_v3.js +123 -0
- package/test/balancer/2eur_ageur.js +141 -0
- package/test/balancer/2eur_par.js +141 -0
- package/test/balancer/2eur_par_v2.js +123 -0
- package/test/balancer/bbamusd_v3.js +124 -0
- package/test/balancer/btc.js +131 -0
- package/test/balancer/frxETH.js +123 -0
- package/test/balancer/frxeth_amweth.js +123 -0
- package/test/balancer/matic_usdc_eth_bal.js +123 -0
- package/test/balancer/maticx_ammatic.js +123 -0
- package/test/balancer/maticx_v2.js +120 -0
- package/test/balancer/maticx_v3.js +141 -0
- package/test/balancer/polybase.js +131 -0
- package/test/balancer/polybase_v2.js +121 -0
- package/test/balancer/polydefi.js +131 -0
- package/test/balancer/polydefi2.js +131 -0
- package/test/balancer/qipool.js +136 -0
- package/test/balancer/sphere_matic.js +123 -0
- package/test/balancer/stETH.js +123 -0
- package/test/balancer/stable.js +131 -0
- package/test/balancer/stable_v2.js +121 -0
- package/test/balancer/stmatic_ammatic.js +123 -0
- package/test/balancer/stmatic_v2.js +120 -0
- package/test/balancer/stmatic_v3.js +141 -0
- package/test/balancer/tetubal_v3.js +123 -0
- package/test/balancer/tngbl_usdc.js +123 -0
- package/test/balancer/tricrypto.js +131 -0
- package/test/balancer/tusd_stable.js +142 -0
- package/test/balancer/usdc_weth.js +136 -0
- package/test/balancer/usdc_weth_v2.js +123 -0
- package/test/balancer/wbtc_eth_usdc.js +123 -0
- package/test/balancer/wbtc_weth.js +136 -0
- package/test/balancer/wsteth_amweth.js +123 -0
- package/test/balancer/wusdr_usdc.js +123 -0
- package/test/compound/usdc.js +127 -0
- package/test/compound/usdt.js +129 -0
- package/test/compound-blue/eth.js +136 -0
- package/test/compound-blue/usdc.js +136 -0
- package/test/compound-blue/usdt.js +136 -0
- package/test/convex/3crv.js +123 -0
- package/test/convex/3crypto.js +123 -0
- package/test/convex/acrv.js +123 -0
- package/test/convex/crv_3crypto.js +123 -0
- package/test/convex/matic_3crypto.js +123 -0
- package/test/convex/usdr.js +123 -0
- package/test/core/emission-fork.js +197 -0
- package/test/core/emission.js +209 -0
- package/test/core/vault_upgrade.js +129 -0
- package/test/curve/aave.js +132 -0
- package/test/curve/atricrypto3.js +135 -0
- package/test/curve/eurtusd.js +135 -0
- package/test/gamma-merkl/qs-eth-usdc.js +212 -0
- package/test/gamma-merkl/qs-eth-usdt.js +213 -0
- package/test/gamma-merkl/qs-matic-usdt.js +213 -0
- package/test/gamma-merkl/qs-tbtc-eth.js +213 -0
- package/test/gamma-merkl/qs-wbtc-eth-w.js +213 -0
- package/test/genomes/gene-eth.js +115 -0
- package/test/genomes/gnome-eth.js +115 -0
- package/test/idle/dai.js +129 -0
- package/test/idle/usdc.js +128 -0
- package/test/idle/weth.js +128 -0
- package/test/jarvis/2cad-hodl.js +183 -0
- package/test/jarvis/2cad-update-nov22.js +182 -0
- package/test/jarvis/2cad-update.js +177 -0
- package/test/jarvis/2cad-update2.js +182 -0
- package/test/jarvis/2cad-update3.js +182 -0
- package/test/jarvis/2eur-ageur-update-nov22.js +182 -0
- package/test/jarvis/2eur-ageur-update.js +182 -0
- package/test/jarvis/2eur-eure-hodl.js +176 -0
- package/test/jarvis/2eur-eurt-hodl.js +176 -0
- package/test/jarvis/2eur-eurt-update-nov22.js +182 -0
- package/test/jarvis/2eur-hodl.js +176 -0
- package/test/jarvis/2eur-par-hodl.js +176 -0
- package/test/jarvis/2eur-par-update-nov22.js +182 -0
- package/test/jarvis/2jpy-hodl.js +244 -0
- package/test/jarvis/2jpy-update-nov22.js +182 -0
- package/test/jarvis/2jpy-update.js +177 -0
- package/test/jarvis/2jpy-update2.js +182 -0
- package/test/jarvis/2jpyv2-upgrade.js +184 -0
- package/test/jarvis/2nzd-hodl.js +176 -0
- package/test/jarvis/2nzd-update.js +182 -0
- package/test/jarvis/2sgd-hodl.js +176 -0
- package/test/jarvis/2sgd-update-nov22.js +182 -0
- package/test/jarvis/2sgd-update.js +182 -0
- package/test/jarvis/2sgd-update2.js +182 -0
- package/test/jarvis/4eur-hodl-upgrade.js +177 -0
- package/test/jarvis/4eur-hodl.js +183 -0
- package/test/jarvis/4eur-update.js +181 -0
- package/test/jarvis/4eur-update2.js +181 -0
- package/test/jarvis/agden-2eur.js +222 -0
- package/test/jarvis/aur-usdc-v2.js +115 -0
- package/test/jarvis/aur-usdc.js +127 -0
- package/test/jarvis/aur3-usdc.js +115 -0
- package/test/jarvis/aurjul22-weth.js +222 -0
- package/test/jarvis/den-4eur.js +115 -0
- package/test/jarvis/den2-4eur.js +220 -0
- package/test/jarvis/den3-4eur.js +220 -0
- package/test/jarvis/den4-4eur.js +220 -0
- package/test/jarvis/jchf-usdc-hodl-v2.js +184 -0
- package/test/jarvis/jchf-usdc-hodl-v3.js +178 -0
- package/test/jarvis/jchf-usdc-hodl.js +193 -0
- package/test/jarvis/jchf-weth-hodl.js +176 -0
- package/test/jarvis/jeur-usdc-hodl-v2.js +184 -0
- package/test/jarvis/jeur-usdc-hodl-v3.js +178 -0
- package/test/jarvis/jeur-usdc-hodl.js +193 -0
- package/test/jarvis/jeur-weth-hodl.js +176 -0
- package/test/jarvis/jgbp-usdc-hodl-v2.js +184 -0
- package/test/jarvis/jgbp-usdc-hodl-v3.js +178 -0
- package/test/jarvis/jgbp-usdc-hodl.js +193 -0
- package/test/jarvis/jrtangle-2eurageur.js +220 -0
- package/test/jarvis/jrtanglenov22-2eurageur.js +220 -0
- package/test/jarvis/jrtjul22-usdc.js +115 -0
- package/test/jarvis/jrtmay22-usdc.js +115 -0
- package/test/jarvis/jrtmimo-2eurpar.js +220 -0
- package/test/jarvis/jrtmimonov22-2eurpar.js +220 -0
- package/test/jarvis/jrtnov22-usdc.js +220 -0
- package/test/jarvis/jrtsep22-usdc.js +220 -0
- package/test/jarvis/qui-2cad.js +218 -0
- package/test/jarvis/ses-2jpy.js +222 -0
- package/test/meshswap/mesh-omooi.js +197 -0
- package/test/meshswap/mesh-ozemit.js +197 -0
- package/test/meshswap/usdc-ousdc.js +197 -0
- package/test/meshswap/usdt-ousdt.js +197 -0
- package/test/meshswap/wmatic-mesh.js +197 -0
- package/test/meshswap/wmatic-usdc.js +197 -0
- package/test/meshswap/wmatic-usdt.js +197 -0
- package/test/mstable/musd.js +123 -0
- package/test/pearl/cvr-pearl.js +198 -0
- package/test/pearl/cvr.js +133 -0
- package/test/pearl/dai-usdr.js +198 -0
- package/test/pearl/eth-usdr.js +198 -0
- package/test/pearl/matic-usdr.js +198 -0
- package/test/pearl/pearl-usdr.js +198 -0
- package/test/pearl/star-usdr.js +186 -0
- package/test/pearl/tngbl-usdr.js +198 -0
- package/test/pearl/usdc-usdr.js +198 -0
- package/test/pearl/usdt-usdr.js +198 -0
- package/test/pearl/wbtc-usdr.js +198 -0
- package/test/pearl/wusdr-usdr.js +198 -0
- package/test/popsicle/ice-weth.js +128 -0
- package/test/quick/eth-matic.js +132 -0
- package/test/quick/eth-usdt.js +140 -0
- package/test/quick/ifarm-quick.js +147 -0
- package/test/quick/matic-usdc.js +145 -0
- package/test/quick/psp-matic.js +124 -0
- package/test/quick/wbtc-eth.js +145 -0
- package/test/quick-gamma/cbeth-eth.js +207 -0
- package/test/quick-gamma/matic-eth-narrow.js +201 -0
- package/test/quick-gamma/matic-eth-wide.js +197 -0
- package/test/quick-gamma/matic-usdc-narrow.js +197 -0
- package/test/quick-gamma/matic-usdc-wide.js +197 -0
- package/test/quick-gamma/upgrade/matic-eth-narrow.js +204 -0
- package/test/quick-gamma/upgrade/matic-usdc-narrow.js +199 -0
- package/test/quick-gamma/usdc-dai.js +209 -0
- package/test/quick-gamma/usdc-eth-narrow.js +197 -0
- package/test/quick-gamma/usdc-eth-wide.js +197 -0
- package/test/quick-gamma/usdc-usdt.js +209 -0
- package/test/quick-gamma/wbtc-eth-narrow.js +207 -0
- package/test/quick-gamma/wbtc-usdc-narrow.js +209 -0
- package/test/quick-gamma/wsteth-eth.js +207 -0
- package/test/sushi/eth-usdt.js +153 -0
- package/test/sushi/matic-eth.js +138 -0
- package/test/sushi/usdc-eth.js +153 -0
- package/test/test-config.js +24 -0
- package/test/uniswap-gamma/usdc-dai.js +212 -0
- package/test/uniswap-gamma/usdc-usdt.js +212 -0
- package/test/uniswap-gamma/usdc-weth.js +212 -0
- package/test/uniswap-gamma/wmatic-usdc.js +210 -0
- package/test/utilities/Utils.js +96 -0
- package/test/utilities/hh-utils.js +242 -0
- package/test/utilities/make-vault.js +10 -0
- package/test/yel/yel-wmatic.js +129 -0
@@ -0,0 +1,36 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "../../base/interface/IVault.sol";
|
5
|
+
import "../../base/ape-base/MiniApeV2Strategy.sol";
|
6
|
+
|
7
|
+
contract ApeStrategyMainnet_ETH_MATIC is MiniApeV2Strategy {
|
8
|
+
|
9
|
+
address constant public weth = address(0x7ceB23fD6bC0adD59E62ac25578270cFf1b9f619);
|
10
|
+
address constant public banana = address(0x5d47bAbA0d66083C52009271faF3F50DCc01023C);
|
11
|
+
address constant public weth_matic = address(0x6Cf8654e85AB489cA7e70189046D507ebA233613);
|
12
|
+
address constant public wmatic = address(0x0d500B1d8E8eF31E21C99d1Db9A6444d3ADf1270);
|
13
|
+
address constant public miniApe = address(0x54aff400858Dcac39797a81894D9920f16972D1D);
|
14
|
+
|
15
|
+
constructor() public {}
|
16
|
+
|
17
|
+
function initializeStrategy(
|
18
|
+
address _storage,
|
19
|
+
address _vault
|
20
|
+
) public initializer {
|
21
|
+
|
22
|
+
MiniApeV2Strategy.initializeBaseStrategy(
|
23
|
+
_storage,
|
24
|
+
weth_matic,
|
25
|
+
_vault,
|
26
|
+
miniApe,
|
27
|
+
banana,
|
28
|
+
1
|
29
|
+
);
|
30
|
+
|
31
|
+
require(IVault(_vault).underlying() == weth_matic, "Underlying mismatch");
|
32
|
+
|
33
|
+
uniswapRoutes[wmatic] = [banana, wmatic];
|
34
|
+
uniswapRoutes[weth] = [banana, wmatic, weth];
|
35
|
+
}
|
36
|
+
}
|
@@ -0,0 +1,36 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "../../base/interface/IVault.sol";
|
5
|
+
import "../../base/ape-base/MiniApeV2Strategy.sol";
|
6
|
+
|
7
|
+
contract ApeStrategyMainnet_USDT_MATIC is MiniApeV2Strategy {
|
8
|
+
|
9
|
+
address constant public usdt = address(0xc2132D05D31c914a87C6611C10748AEb04B58e8F);
|
10
|
+
address constant public banana = address(0x5d47bAbA0d66083C52009271faF3F50DCc01023C);
|
11
|
+
address constant public usdt_matic = address(0x65D43B64E3B31965Cd5EA367D4c2b94c03084797);
|
12
|
+
address constant public wmatic = address(0x0d500B1d8E8eF31E21C99d1Db9A6444d3ADf1270);
|
13
|
+
address constant public miniApe = address(0x54aff400858Dcac39797a81894D9920f16972D1D);
|
14
|
+
|
15
|
+
constructor() public {}
|
16
|
+
|
17
|
+
function initializeStrategy(
|
18
|
+
address _storage,
|
19
|
+
address _vault
|
20
|
+
) public initializer {
|
21
|
+
|
22
|
+
MiniApeV2Strategy.initializeBaseStrategy(
|
23
|
+
_storage,
|
24
|
+
usdt_matic,
|
25
|
+
_vault,
|
26
|
+
miniApe,
|
27
|
+
banana,
|
28
|
+
3
|
29
|
+
);
|
30
|
+
|
31
|
+
require(IVault(_vault).underlying() == usdt_matic, "Underlying mismatch");
|
32
|
+
|
33
|
+
uniswapRoutes[usdt] = [banana, wmatic, usdt];
|
34
|
+
uniswapRoutes[wmatic] = [banana, wmatic];
|
35
|
+
}
|
36
|
+
}
|
@@ -0,0 +1,347 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
pragma experimental ABIEncoderV2;
|
4
|
+
|
5
|
+
import "@openzeppelin/contracts/math/Math.sol";
|
6
|
+
import "@openzeppelin/contracts/math/SafeMath.sol";
|
7
|
+
import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol";
|
8
|
+
import "../../base/interface/IUniversalLiquidator.sol";
|
9
|
+
import "../../base/interface/IVault.sol";
|
10
|
+
import "../../base/upgradability/BaseUpgradeableStrategyV2.sol";
|
11
|
+
import "../../base/interface/balancer/IBVault.sol";
|
12
|
+
import "../../base/interface/balancer/Gauge.sol";
|
13
|
+
import "../../base/interface/balancer/IBalancerMinter.sol";
|
14
|
+
import "./interface/IAuraBooster.sol";
|
15
|
+
import "./interface/IAuraBaseRewardPool.sol";
|
16
|
+
|
17
|
+
contract AuraStrategy is BaseUpgradeableStrategyV2 {
|
18
|
+
|
19
|
+
using SafeMath for uint256;
|
20
|
+
using SafeERC20 for IERC20;
|
21
|
+
|
22
|
+
address public constant weth = address(0x7ceB23fD6bC0adD59E62ac25578270cFf1b9f619);
|
23
|
+
address public constant harvestMSIG = address(0x39cC360806b385C96969ce9ff26c23476017F652);
|
24
|
+
address public constant bVault = address(0xBA12222222228d8Ba445958a75a0704d566BF2C8);
|
25
|
+
address public constant booster = address(0x98Ef32edd24e2c92525E59afc4475C1242a30184);
|
26
|
+
|
27
|
+
// additional storage slots (on top of BaseUpgradeableStrategy ones) are defined here
|
28
|
+
bytes32 internal constant _AURA_POOLID_SLOT = 0xbc10a276e435b4e9a9e92986f93a224a34b50c1898d7551c38ef30a08efadec4;
|
29
|
+
bytes32 internal constant _BALANCER_POOLID_SLOT = 0xbf3f653715dd45c84a3367d2975f271307cb967d6ce603dc4f0def2ad909ca64;
|
30
|
+
bytes32 internal constant _DEPOSIT_TOKEN_SLOT = 0x219270253dbc530471c88a9e7c321b36afda219583431e7b6c386d2d46e70c86;
|
31
|
+
|
32
|
+
// this would be reset on each upgrade
|
33
|
+
address[] public rewardTokens;
|
34
|
+
|
35
|
+
constructor() public BaseUpgradeableStrategyV2() {
|
36
|
+
assert(_AURA_POOLID_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.auraPoolId")) - 1));
|
37
|
+
assert(_BALANCER_POOLID_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.balancerPoolId")) - 1));
|
38
|
+
assert(_DEPOSIT_TOKEN_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.depositToken")) - 1));
|
39
|
+
}
|
40
|
+
|
41
|
+
function initializeBaseStrategy(
|
42
|
+
address _storage,
|
43
|
+
address _underlying,
|
44
|
+
address _vault,
|
45
|
+
address _rewardPool,
|
46
|
+
bytes32 _balancerPoolID,
|
47
|
+
uint256 _auraPoolID,
|
48
|
+
address _depositToken
|
49
|
+
) public initializer {
|
50
|
+
|
51
|
+
BaseUpgradeableStrategyV2.initialize(
|
52
|
+
_storage,
|
53
|
+
_underlying,
|
54
|
+
_vault,
|
55
|
+
_rewardPool,
|
56
|
+
weth,
|
57
|
+
harvestMSIG
|
58
|
+
);
|
59
|
+
|
60
|
+
(address _lpt,) = IBVault(bVault).getPool(_balancerPoolID);
|
61
|
+
require(_lpt == _underlying, "Underlying mismatch");
|
62
|
+
(_lpt,,,,,) = IAuraBooster(booster).poolInfo(_auraPoolID);
|
63
|
+
require(_lpt == underlying(), "Pool Info does not match underlying");
|
64
|
+
|
65
|
+
_setAuraPoolId(_auraPoolID);
|
66
|
+
_setBalancerPoolId(_balancerPoolID);
|
67
|
+
_setDepositToken(_depositToken);
|
68
|
+
}
|
69
|
+
|
70
|
+
function depositArbCheck() public pure returns(bool) {
|
71
|
+
return true;
|
72
|
+
}
|
73
|
+
|
74
|
+
function _rewardPoolBalance() internal view returns (uint256 balance) {
|
75
|
+
balance = IAuraBaseRewardPool(rewardPool()).balanceOf(address(this));
|
76
|
+
}
|
77
|
+
|
78
|
+
function _emergencyExitRewardPool() internal {
|
79
|
+
uint256 stakedBalance = _rewardPoolBalance();
|
80
|
+
if (stakedBalance != 0) {
|
81
|
+
IAuraBaseRewardPool(rewardPool()).withdrawAllAndUnwrap(false); //don't claim rewards
|
82
|
+
}
|
83
|
+
}
|
84
|
+
|
85
|
+
function _partialWithdrawalRewardPool(uint256 amount) internal {
|
86
|
+
IAuraBaseRewardPool(rewardPool()).withdrawAndUnwrap(amount, false); //don't claim rewards at this point
|
87
|
+
}
|
88
|
+
|
89
|
+
function _exitRewardPool() internal {
|
90
|
+
uint256 stakedBalance = _rewardPoolBalance();
|
91
|
+
if (stakedBalance != 0) {
|
92
|
+
IAuraBaseRewardPool(rewardPool()).withdrawAllAndUnwrap(true);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
function _enterRewardPool() internal {
|
97
|
+
address underlying_ = underlying();
|
98
|
+
uint256 entireBalance = IERC20(underlying_).balanceOf(address(this));
|
99
|
+
IERC20(underlying_).safeApprove(booster, 0);
|
100
|
+
IERC20(underlying_).safeApprove(booster, entireBalance);
|
101
|
+
IAuraBooster(booster).depositAll(auraPoolId(), true); //deposit and stake
|
102
|
+
}
|
103
|
+
|
104
|
+
function _investAllUnderlying() internal onlyNotPausedInvesting {
|
105
|
+
if(IERC20(underlying()).balanceOf(address(this)) > 0) {
|
106
|
+
_enterRewardPool();
|
107
|
+
}
|
108
|
+
}
|
109
|
+
|
110
|
+
/*
|
111
|
+
* In case there are some issues discovered about the pool or underlying asset
|
112
|
+
* Governance can exit the pool properly
|
113
|
+
* The function is only used for emergency to exit the pool
|
114
|
+
*/
|
115
|
+
function emergencyExit() public onlyGovernance {
|
116
|
+
_emergencyExitRewardPool();
|
117
|
+
_setPausedInvesting(true);
|
118
|
+
}
|
119
|
+
|
120
|
+
/*
|
121
|
+
* Resumes the ability to invest into the underlying reward pools
|
122
|
+
*/
|
123
|
+
function continueInvesting() public onlyGovernance {
|
124
|
+
_setPausedInvesting(false);
|
125
|
+
}
|
126
|
+
|
127
|
+
function unsalvagableTokens(address token) public view returns (bool) {
|
128
|
+
return (token == rewardToken() || token == underlying());
|
129
|
+
}
|
130
|
+
|
131
|
+
function addRewardToken(address _token) public onlyGovernance {
|
132
|
+
rewardTokens.push(_token);
|
133
|
+
}
|
134
|
+
|
135
|
+
function changeDepositToken(address _depositToken) public onlyGovernance {
|
136
|
+
_setDepositToken(_depositToken);
|
137
|
+
}
|
138
|
+
|
139
|
+
function _approveIfNeed(address token, address spender, uint256 amount) internal {
|
140
|
+
uint256 allowance = IERC20(token).allowance(address(this), spender);
|
141
|
+
if (amount > allowance) {
|
142
|
+
IERC20(token).safeApprove(spender, 0);
|
143
|
+
IERC20(token).safeApprove(spender, amount);
|
144
|
+
}
|
145
|
+
}
|
146
|
+
|
147
|
+
function _balancerDeposit(
|
148
|
+
address tokenIn,
|
149
|
+
bytes32 poolId,
|
150
|
+
uint256 amountIn,
|
151
|
+
uint256 minAmountOut
|
152
|
+
) internal {
|
153
|
+
(address[] memory poolTokens,,) = IBVault(bVault).getPoolTokens(poolId);
|
154
|
+
uint256 _nTokens = poolTokens.length;
|
155
|
+
|
156
|
+
IAsset[] memory assets = new IAsset[](_nTokens);
|
157
|
+
uint256[] memory amountsIn = new uint256[](_nTokens);
|
158
|
+
for (uint256 i = 0; i < _nTokens; i++) {
|
159
|
+
assets[i] = IAsset(poolTokens[i]);
|
160
|
+
amountsIn[i] = poolTokens[i] == tokenIn ? amountIn : 0;
|
161
|
+
}
|
162
|
+
|
163
|
+
IBVault.JoinKind joinKind = IBVault.JoinKind.EXACT_TOKENS_IN_FOR_BPT_OUT;
|
164
|
+
|
165
|
+
bytes memory userData = abi.encode(joinKind, amountsIn, minAmountOut);
|
166
|
+
|
167
|
+
IBVault.JoinPoolRequest memory request;
|
168
|
+
request.assets = assets;
|
169
|
+
request.maxAmountsIn = amountsIn;
|
170
|
+
request.userData = userData;
|
171
|
+
request.fromInternalBalance = false;
|
172
|
+
|
173
|
+
_approveIfNeed(tokenIn, bVault, amountIn);
|
174
|
+
IBVault(bVault).joinPool(
|
175
|
+
poolId,
|
176
|
+
address(this),
|
177
|
+
address(this),
|
178
|
+
request
|
179
|
+
);
|
180
|
+
}
|
181
|
+
|
182
|
+
function _liquidateReward() internal {
|
183
|
+
if (!sell()) {
|
184
|
+
// Profits can be disabled for possible simplified and rapid exit
|
185
|
+
emit ProfitsNotCollected(sell(), false);
|
186
|
+
return;
|
187
|
+
}
|
188
|
+
address _rewardToken = rewardToken();
|
189
|
+
address _universalLiquidator = universalLiquidator();
|
190
|
+
for(uint256 i = 0; i < rewardTokens.length; i++){
|
191
|
+
address token = rewardTokens[i];
|
192
|
+
uint256 rewardBalance = IERC20(token).balanceOf(address(this));
|
193
|
+
if (rewardBalance == 0) {
|
194
|
+
continue;
|
195
|
+
}
|
196
|
+
if (token != _rewardToken){
|
197
|
+
IERC20(token).safeApprove(_universalLiquidator, 0);
|
198
|
+
IERC20(token).safeApprove(_universalLiquidator, rewardBalance);
|
199
|
+
IUniversalLiquidator(_universalLiquidator).swap(token, _rewardToken, rewardBalance, 1, address(this));
|
200
|
+
}
|
201
|
+
}
|
202
|
+
|
203
|
+
uint256 rewardBalance = IERC20(_rewardToken).balanceOf(address(this));
|
204
|
+
_notifyProfitInRewardToken(_rewardToken, rewardBalance);
|
205
|
+
uint256 remainingRewardBalance = IERC20(_rewardToken).balanceOf(address(this));
|
206
|
+
|
207
|
+
if (remainingRewardBalance == 0) {
|
208
|
+
return;
|
209
|
+
}
|
210
|
+
|
211
|
+
address _depositToken = depositToken();
|
212
|
+
if (_depositToken != _rewardToken) {
|
213
|
+
IERC20(_rewardToken).safeApprove(_universalLiquidator, 0);
|
214
|
+
IERC20(_rewardToken).safeApprove(_universalLiquidator, remainingRewardBalance);
|
215
|
+
IUniversalLiquidator(_universalLiquidator).swap(_rewardToken, _depositToken, remainingRewardBalance, 1, address(this));
|
216
|
+
}
|
217
|
+
|
218
|
+
uint256 tokenBalance = IERC20(_depositToken).balanceOf(address(this));
|
219
|
+
if (tokenBalance > 0 && !(_depositToken == underlying())) {
|
220
|
+
depositLP();
|
221
|
+
}
|
222
|
+
}
|
223
|
+
|
224
|
+
function depositLP() internal {
|
225
|
+
address _depositToken = depositToken();
|
226
|
+
uint256 depositTokenBalance = IERC20(_depositToken).balanceOf(address(this));
|
227
|
+
|
228
|
+
_balancerDeposit(
|
229
|
+
_depositToken,
|
230
|
+
balancerPoolId(),
|
231
|
+
depositTokenBalance,
|
232
|
+
1
|
233
|
+
);
|
234
|
+
}
|
235
|
+
|
236
|
+
/** Withdraws all the asset to the vault
|
237
|
+
*/
|
238
|
+
function withdrawAllToVault() public restricted {
|
239
|
+
address _underlying = underlying();
|
240
|
+
_exitRewardPool();
|
241
|
+
_liquidateReward();
|
242
|
+
IERC20(_underlying).safeTransfer(vault(), IERC20(_underlying).balanceOf(address(this)));
|
243
|
+
}
|
244
|
+
|
245
|
+
/** Withdraws specific amount of asset to the vault
|
246
|
+
*/
|
247
|
+
function withdrawToVault(uint256 amount) public restricted {
|
248
|
+
address _underlying = underlying();
|
249
|
+
// Typically there wouldn't be any amount here
|
250
|
+
// however, it is possible because of the emergencyExit
|
251
|
+
uint256 entireBalance = IERC20(_underlying).balanceOf(address(this));
|
252
|
+
|
253
|
+
if(amount > entireBalance){
|
254
|
+
// While we have the check above, we still using SafeMath below
|
255
|
+
// for the peace of mind (in case something gets changed in between)
|
256
|
+
uint256 needToWithdraw = amount.sub(entireBalance);
|
257
|
+
uint256 toWithdraw = Math.min(_rewardPoolBalance(), needToWithdraw);
|
258
|
+
_partialWithdrawalRewardPool(toWithdraw);
|
259
|
+
}
|
260
|
+
IERC20(_underlying).safeTransfer(vault(), amount);
|
261
|
+
}
|
262
|
+
|
263
|
+
/*
|
264
|
+
* Note that we currently do not have a mechanism here to include the
|
265
|
+
* amount of reward that is accrued.
|
266
|
+
*/
|
267
|
+
function investedUnderlyingBalance() external view returns (uint256) {
|
268
|
+
// Adding the amount locked in the reward pool and the amount that is somehow in this contract
|
269
|
+
// both are in the units of "underlying"
|
270
|
+
// The second part is needed because there is the emergency exit mechanism
|
271
|
+
// which would break the assumption that all the funds are always inside of the reward pool
|
272
|
+
return _rewardPoolBalance().add(IERC20(underlying()).balanceOf(address(this)));
|
273
|
+
}
|
274
|
+
|
275
|
+
/*
|
276
|
+
* Governance or Controller can claim coins that are somehow transferred into the contract
|
277
|
+
* Note that they cannot come in take away coins that are used and defined in the strategy itself
|
278
|
+
*/
|
279
|
+
function salvage(address recipient, address token, uint256 amount) external onlyControllerOrGovernance {
|
280
|
+
// To make sure that governance cannot come in and take away the coins
|
281
|
+
require(!unsalvagableTokens(token), "token is defined as not salvagable");
|
282
|
+
IERC20(token).safeTransfer(recipient, amount);
|
283
|
+
}
|
284
|
+
|
285
|
+
/*
|
286
|
+
* Get the reward, sell it in exchange for underlying, invest what you got.
|
287
|
+
* It's not much, but it's honest work.
|
288
|
+
*
|
289
|
+
* Note that although `onlyNotPausedInvesting` is not added here,
|
290
|
+
* calling `investAllUnderlying()` affectively blocks the usage of `doHardWork`
|
291
|
+
* when the investing is being paused by governance.
|
292
|
+
*/
|
293
|
+
function doHardWork() external onlyNotPausedInvesting restricted {
|
294
|
+
IAuraBaseRewardPool(rewardPool()).getReward();
|
295
|
+
_liquidateReward();
|
296
|
+
_investAllUnderlying();
|
297
|
+
}
|
298
|
+
|
299
|
+
/**
|
300
|
+
* Can completely disable claiming UNI rewards and selling. Good for emergency withdraw in the
|
301
|
+
* simplest possible way.
|
302
|
+
*/
|
303
|
+
function setSell(bool s) public onlyGovernance {
|
304
|
+
_setSell(s);
|
305
|
+
}
|
306
|
+
|
307
|
+
/**
|
308
|
+
* Sets the minimum amount of CRV needed to trigger a sale.
|
309
|
+
*/
|
310
|
+
function setSellFloor(uint256 floor) public onlyGovernance {
|
311
|
+
_setSellFloor(floor);
|
312
|
+
}
|
313
|
+
|
314
|
+
/** Aura deposit pool ID
|
315
|
+
*/
|
316
|
+
function _setAuraPoolId(uint256 _value) internal {
|
317
|
+
setUint256(_AURA_POOLID_SLOT, _value);
|
318
|
+
}
|
319
|
+
|
320
|
+
/** Balancer deposit pool ID
|
321
|
+
*/
|
322
|
+
function _setBalancerPoolId(bytes32 _value) internal {
|
323
|
+
setBytes32(_BALANCER_POOLID_SLOT, _value);
|
324
|
+
}
|
325
|
+
|
326
|
+
function auraPoolId() public view returns (uint256) {
|
327
|
+
return getUint256(_AURA_POOLID_SLOT);
|
328
|
+
}
|
329
|
+
|
330
|
+
function balancerPoolId() public view returns (bytes32) {
|
331
|
+
return getBytes32(_BALANCER_POOLID_SLOT);
|
332
|
+
}
|
333
|
+
|
334
|
+
function _setDepositToken(address _address) internal {
|
335
|
+
setAddress(_DEPOSIT_TOKEN_SLOT, _address);
|
336
|
+
}
|
337
|
+
|
338
|
+
function depositToken() public view returns (address) {
|
339
|
+
return getAddress(_DEPOSIT_TOKEN_SLOT);
|
340
|
+
}
|
341
|
+
|
342
|
+
function finalizeUpgrade() external onlyGovernance {
|
343
|
+
_finalizeUpgrade();
|
344
|
+
}
|
345
|
+
|
346
|
+
receive() external payable {} // this is needed for the receiving Matic
|
347
|
+
}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
pragma experimental ABIEncoderV2;
|
4
|
+
|
5
|
+
import "./AuraStrategy.sol";
|
6
|
+
|
7
|
+
contract AuraStrategyMainnet_jEUR_PAR is AuraStrategy {
|
8
|
+
|
9
|
+
constructor() public {}
|
10
|
+
|
11
|
+
function initializeStrategy(
|
12
|
+
address _storage,
|
13
|
+
address _vault
|
14
|
+
) public initializer {
|
15
|
+
address underlying = address(0x513CdEE00251F39DE280d9E5f771A6eaFebCc88E);
|
16
|
+
address aura = address(0x1509706a6c66CA549ff0cB464de88231DDBe213B);
|
17
|
+
address bal = address(0x9a71012B13CA4d3D0Cdc72A177DF3ef03b0E76A3);
|
18
|
+
address rewardPool = address(0x333122d446A950a951942a6C065b6ebBEE72EA98);
|
19
|
+
AuraStrategy.initializeBaseStrategy(
|
20
|
+
_storage,
|
21
|
+
underlying,
|
22
|
+
_vault,
|
23
|
+
rewardPool,
|
24
|
+
0x513cdee00251f39de280d9e5f771a6eafebcc88e000000000000000000000a6b, // Balancer Pool id
|
25
|
+
6, // Aura Pool id
|
26
|
+
underlying //depositToken
|
27
|
+
);
|
28
|
+
rewardTokens = [aura, bal];
|
29
|
+
}
|
30
|
+
}
|
@@ -0,0 +1,25 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
interface IAuraBaseRewardPool {
|
5
|
+
|
6
|
+
function balanceOf(address account) external view returns(uint256 amount);
|
7
|
+
|
8
|
+
function pid() external view returns (uint256 _pid);
|
9
|
+
|
10
|
+
function stakingToken() external view returns (address _stakingToken);
|
11
|
+
|
12
|
+
function getReward() external;
|
13
|
+
|
14
|
+
function stake(uint256 _amount) external;
|
15
|
+
|
16
|
+
function stakeAll() external;
|
17
|
+
|
18
|
+
function withdraw(uint256 amount, bool claim) external;
|
19
|
+
|
20
|
+
function withdrawAll(bool claim) external;
|
21
|
+
|
22
|
+
function withdrawAndUnwrap(uint256 amount, bool claim) external;
|
23
|
+
|
24
|
+
function withdrawAllAndUnwrap(bool claim) external;
|
25
|
+
}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
interface IAuraBooster {
|
5
|
+
|
6
|
+
function deposit(uint256 _pid, uint256 _amount, bool _stake) external;
|
7
|
+
|
8
|
+
function depositAll(uint256 _pid, bool _stake) external;
|
9
|
+
|
10
|
+
function withdraw(uint256 _pid, uint256 _amount) external;
|
11
|
+
|
12
|
+
function withdrawAll(uint256 _pid) external;
|
13
|
+
|
14
|
+
function poolInfo(uint256 _pid) external view returns (address lpToken, address, address, address, address, bool);
|
15
|
+
|
16
|
+
function earmarkRewards(uint256 _pid) external;
|
17
|
+
}
|