@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,381 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "@openzeppelin/contracts/math/Math.sol";
|
5
|
+
import "@openzeppelin/contracts/math/SafeMath.sol";
|
6
|
+
import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol";
|
7
|
+
import "@uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router02.sol";
|
8
|
+
import "@uniswap/v2-core/contracts/interfaces/IUniswapV2Pair.sol";
|
9
|
+
import "../../base/interface/IVault.sol";
|
10
|
+
import "../../base/upgradability/BaseUpgradeableStrategy.sol";
|
11
|
+
import "./interfaces/ILiquidityMining.sol";
|
12
|
+
import "./interfaces/IProxyActions.sol";
|
13
|
+
import "./interfaces/ILiquidityPool.sol";
|
14
|
+
import "./interfaces/IUSDCVault.sol";
|
15
|
+
|
16
|
+
import "hardhat/console.sol";
|
17
|
+
|
18
|
+
contract ComplifiDerivStrategy is BaseUpgradeableStrategy {
|
19
|
+
|
20
|
+
using SafeMath for uint256;
|
21
|
+
using SafeERC20 for IERC20;
|
22
|
+
|
23
|
+
address public constant quickswapRouterV2 = address(0xa5E0829CaCEd8fFDD4De3c43696c57F7D7A678ff);
|
24
|
+
address public constant usdc = address(0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174);
|
25
|
+
|
26
|
+
// additional storage slots (on top of BaseUpgradeableStrategy ones) are defined here
|
27
|
+
bytes32 internal constant _POOLID_UNDERLYING_SLOT = 0x2668b27e0735c5f6e35079d508e3204198f7707448f1ebb98fca59c4c52b8f07;
|
28
|
+
bytes32 internal constant _POOLID_UP_SLOT = 0x6be613a6d2004c4d2e1084c374896d7fbed4970f361e0e7674fa219f91ad3b15;
|
29
|
+
bytes32 internal constant _POOLID_DOWN_SLOT = 0xccb93df1ed8ce69edd49f5292dc925acceb5faa9245e0e03d458acdf91ae0501;
|
30
|
+
bytes32 internal constant _USDC_VAULT_SLOT = 0xaab6b4bd3b91f202325685e422df24f288f829eb6e79991474d39f569c7e1da1;
|
31
|
+
bytes32 internal constant _PROXY_SLOT = 0xe0898eac8b9a936189ab0c51fb8795de984bdabad6d1a277d006fecbf46049ee;
|
32
|
+
bytes32 internal constant _UP_TOKEN_SLOT = 0xe78c0ac41746e02ab5fe2f13a047af360821ac5121402db1b87842b4ca7da4e8;
|
33
|
+
bytes32 internal constant _DOWN_TOKEN_SLOT = 0x6601600d2d4d050af79e2b98cf2cb31878b3a629ac3903e218a71e7adc68cf8d;
|
34
|
+
|
35
|
+
|
36
|
+
// this would be reset on each upgrade
|
37
|
+
address[] public liquidationPath;
|
38
|
+
|
39
|
+
constructor() public BaseUpgradeableStrategy() {
|
40
|
+
assert(_POOLID_UNDERLYING_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.poolIdUnderlying")) - 1));
|
41
|
+
assert(_POOLID_UP_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.poolIdUp")) - 1));
|
42
|
+
assert(_POOLID_DOWN_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.poolIdDown")) - 1));
|
43
|
+
assert(_USDC_VAULT_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.usdcVault")) - 1));
|
44
|
+
assert(_PROXY_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.proxy")) - 1));
|
45
|
+
assert(_UP_TOKEN_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.upToken")) - 1));
|
46
|
+
assert(_DOWN_TOKEN_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.downToken")) - 1));
|
47
|
+
}
|
48
|
+
|
49
|
+
function initializeStrategy(
|
50
|
+
address _storage,
|
51
|
+
address _underlying,
|
52
|
+
address _vault,
|
53
|
+
address _rewardPool,
|
54
|
+
address _rewardToken,
|
55
|
+
address _usdcVault,
|
56
|
+
address _proxy
|
57
|
+
) public initializer {
|
58
|
+
|
59
|
+
BaseUpgradeableStrategy.initialize(
|
60
|
+
_storage,
|
61
|
+
_underlying,
|
62
|
+
_vault,
|
63
|
+
_rewardPool,
|
64
|
+
_rewardToken,
|
65
|
+
80, // profit sharing numerator
|
66
|
+
1000, // profit sharing denominator
|
67
|
+
true, // sell
|
68
|
+
1e18, // sell floor
|
69
|
+
12 hours // implementation change delay
|
70
|
+
);
|
71
|
+
|
72
|
+
address _lpt;
|
73
|
+
uint256 pidUnderlying = ILiquidityMining(rewardPool()).poolPidByAddress(_underlying);
|
74
|
+
(_lpt,,,) = ILiquidityMining(rewardPool()).poolInfo(pidUnderlying);
|
75
|
+
require(_lpt == underlying(), "Pool Info does not match underlying");
|
76
|
+
address upToken = IUSDCVault(_usdcVault).primaryToken();
|
77
|
+
address downToken = IUSDCVault(_usdcVault).complementToken();
|
78
|
+
uint256 pidUp = ILiquidityMining(rewardPool()).poolPidByAddress(upToken);
|
79
|
+
uint256 pidDown = ILiquidityMining(rewardPool()).poolPidByAddress(downToken);
|
80
|
+
_setPoolIdUnderlying(pidUnderlying);
|
81
|
+
_setPoolIdUp(pidUp);
|
82
|
+
_setPoolIdDown(pidDown);
|
83
|
+
_setUSDCVault(_usdcVault);
|
84
|
+
_setProxy(_proxy);
|
85
|
+
_setUpToken(upToken);
|
86
|
+
_setDownToken(downToken);
|
87
|
+
}
|
88
|
+
|
89
|
+
function depositArbCheck() public pure returns(bool) {
|
90
|
+
return true;
|
91
|
+
}
|
92
|
+
|
93
|
+
function rewardPoolBalances() internal view returns (uint256 balUnderlying, uint256 balUp, uint256 balDown) {
|
94
|
+
(balUnderlying,) = ILiquidityMining(rewardPool()).userPoolInfo(poolIdUnderlying(), address(this));
|
95
|
+
(balUp,) = ILiquidityMining(rewardPool()).userPoolInfo(poolIdUp(), address(this));
|
96
|
+
(balDown,) = ILiquidityMining(rewardPool()).userPoolInfo(poolIdDown(), address(this));
|
97
|
+
}
|
98
|
+
|
99
|
+
function exitRewardPool() internal {
|
100
|
+
(uint256 balUnderlying, uint256 balUp, uint256 balDown) = rewardPoolBalances();
|
101
|
+
if (balUnderlying != 0) {
|
102
|
+
ILiquidityMining(rewardPool()).withdraw(poolIdUnderlying(), balUnderlying);
|
103
|
+
}
|
104
|
+
if (balUp != 0) {
|
105
|
+
ILiquidityMining(rewardPool()).withdraw(poolIdUp(), balUp);
|
106
|
+
}
|
107
|
+
if (balDown != 0) {
|
108
|
+
ILiquidityMining(rewardPool()).withdraw(poolIdDown(), balDown);
|
109
|
+
}
|
110
|
+
}
|
111
|
+
|
112
|
+
function emergencyExitRewardPool() internal {
|
113
|
+
(uint256 balUnderlying, uint256 balUp, uint256 balDown) = rewardPoolBalances();
|
114
|
+
if (balUnderlying != 0) {
|
115
|
+
ILiquidityMining(rewardPool()).withdrawEmergency(poolIdUnderlying());
|
116
|
+
}
|
117
|
+
if (balUp != 0) {
|
118
|
+
ILiquidityMining(rewardPool()).withdrawEmergency(poolIdUp());
|
119
|
+
}
|
120
|
+
if (balDown != 0) {
|
121
|
+
ILiquidityMining(rewardPool()).withdrawEmergency(poolIdDown());
|
122
|
+
}
|
123
|
+
}
|
124
|
+
|
125
|
+
function unsalvagableTokens(address token) public view returns (bool) {
|
126
|
+
return (token == rewardToken() || token == underlying());
|
127
|
+
}
|
128
|
+
|
129
|
+
function enterRewardPool(address _token) internal {
|
130
|
+
uint256 entireBalance = IERC20(_token).balanceOf(address(this));
|
131
|
+
IERC20(_token).safeApprove(rewardPool(), 0);
|
132
|
+
IERC20(_token).safeApprove(rewardPool(), entireBalance);
|
133
|
+
ILiquidityMining(rewardPool()).deposit(ILiquidityMining(rewardPool()).poolPidByAddress(_token), entireBalance);
|
134
|
+
}
|
135
|
+
|
136
|
+
/*
|
137
|
+
* In case there are some issues discovered about the pool or underlying asset
|
138
|
+
* Governance can exit the pool properly
|
139
|
+
* The function is only used for emergency to exit the pool
|
140
|
+
*/
|
141
|
+
function emergencyExit() public onlyGovernance {
|
142
|
+
emergencyExitRewardPool();
|
143
|
+
_setPausedInvesting(true);
|
144
|
+
}
|
145
|
+
|
146
|
+
/*
|
147
|
+
* Resumes the ability to invest into the underlying reward pools
|
148
|
+
*/
|
149
|
+
|
150
|
+
function continueInvesting() public onlyGovernance {
|
151
|
+
_setPausedInvesting(false);
|
152
|
+
}
|
153
|
+
|
154
|
+
function setLiquidationPath(address [] memory _route) public onlyGovernance {
|
155
|
+
require(_route[0] == rewardToken(), "Path should start with reward");
|
156
|
+
require(_route[_route.length-1] == usdc, "Path should end with USDC");
|
157
|
+
liquidationPath = _route;
|
158
|
+
}
|
159
|
+
|
160
|
+
// We assume that all the tradings can be done on Uniswap
|
161
|
+
function _liquidateReward() internal {
|
162
|
+
uint256 rewardBalance = IERC20(rewardToken()).balanceOf(address(this));
|
163
|
+
if (!sell() || rewardBalance < sellFloor()) {
|
164
|
+
// Profits can be disabled for possible simplified and rapid exit
|
165
|
+
emit ProfitsNotCollected(sell(), rewardBalance < sellFloor());
|
166
|
+
return;
|
167
|
+
}
|
168
|
+
|
169
|
+
notifyProfitInRewardToken(rewardBalance);
|
170
|
+
uint256 remainingRewardBalance = IERC20(rewardToken()).balanceOf(address(this));
|
171
|
+
|
172
|
+
if (remainingRewardBalance == 0) {
|
173
|
+
return;
|
174
|
+
}
|
175
|
+
|
176
|
+
// allow Uniswap to sell our reward
|
177
|
+
IERC20(rewardToken()).safeApprove(quickswapRouterV2, 0);
|
178
|
+
IERC20(rewardToken()).safeApprove(quickswapRouterV2, remainingRewardBalance);
|
179
|
+
|
180
|
+
// we can accept 1 as minimum because this is called only by a trusted role
|
181
|
+
uint256 amountOutMin = 1;
|
182
|
+
|
183
|
+
IUniswapV2Router02(quickswapRouterV2).swapExactTokensForTokens(
|
184
|
+
remainingRewardBalance,
|
185
|
+
amountOutMin,
|
186
|
+
liquidationPath,
|
187
|
+
address(this),
|
188
|
+
block.timestamp
|
189
|
+
);
|
190
|
+
}
|
191
|
+
|
192
|
+
function _usdcToUnderlying() internal {
|
193
|
+
uint256 usdcBalance = IERC20(usdc).balanceOf(address(this));
|
194
|
+
if(usdcBalance == 0) {
|
195
|
+
return;
|
196
|
+
}
|
197
|
+
IERC20(usdc).safeApprove(proxy(), 0);
|
198
|
+
IERC20(usdc).safeApprove(proxy(), usdcBalance);
|
199
|
+
|
200
|
+
IProxyActions(proxy()).mintAndJoinPool(underlying(), usdcBalance, address(0), 0, address(0), 0, 0);
|
201
|
+
IProxyActions(proxy()).extractChange(underlying());
|
202
|
+
}
|
203
|
+
|
204
|
+
/*
|
205
|
+
* Stakes everything the strategy holds into the reward pool
|
206
|
+
*/
|
207
|
+
function investAllUnderlying() internal onlyNotPausedInvesting {
|
208
|
+
// this check is needed, because most of the SNX reward pools will revert if
|
209
|
+
// you try to stake(0).
|
210
|
+
if(IERC20(underlying()).balanceOf(address(this)) > 0) {
|
211
|
+
enterRewardPool(underlying());
|
212
|
+
}
|
213
|
+
if(IERC20(upToken()).balanceOf(address(this)) > 0) {
|
214
|
+
enterRewardPool(upToken());
|
215
|
+
}
|
216
|
+
if(IERC20(downToken()).balanceOf(address(this)) > 0) {
|
217
|
+
enterRewardPool(downToken());
|
218
|
+
}
|
219
|
+
}
|
220
|
+
|
221
|
+
/*
|
222
|
+
* Withdraws all the asset to the vault
|
223
|
+
*/
|
224
|
+
function withdrawAllToVault() public restricted {
|
225
|
+
if (address(rewardPool()) != address(0)) {
|
226
|
+
exitRewardPool();
|
227
|
+
}
|
228
|
+
ILiquidityMining(rewardPool()).claim();
|
229
|
+
_liquidateReward();
|
230
|
+
_usdcToUnderlying();
|
231
|
+
IERC20(underlying()).safeTransfer(vault(), IERC20(underlying()).balanceOf(address(this)));
|
232
|
+
}
|
233
|
+
|
234
|
+
/*
|
235
|
+
* Withdraws all the asset to the vault
|
236
|
+
*/
|
237
|
+
function withdrawToVault(uint256 amount) public restricted {
|
238
|
+
// Typically there wouldn't be any amount here
|
239
|
+
// however, it is possible because of the emergencyExit
|
240
|
+
uint256 entireBalance = IERC20(underlying()).balanceOf(address(this));
|
241
|
+
|
242
|
+
if(amount > entireBalance){
|
243
|
+
// While we have the check above, we still using SafeMath below
|
244
|
+
// for the peace of mind (in case something gets changed in between)
|
245
|
+
uint256 needToWithdraw = amount.sub(entireBalance);
|
246
|
+
(uint256 rewardPoolBalance,,) = rewardPoolBalances();
|
247
|
+
uint256 toWithdraw = Math.min(rewardPoolBalance, needToWithdraw);
|
248
|
+
ILiquidityMining(rewardPool()).withdraw(poolIdUnderlying(), toWithdraw);
|
249
|
+
}
|
250
|
+
|
251
|
+
IERC20(underlying()).safeTransfer(vault(), amount);
|
252
|
+
}
|
253
|
+
|
254
|
+
/*
|
255
|
+
* Note that we currently do not have a mechanism here to include the
|
256
|
+
* amount of reward that is accrued.
|
257
|
+
*/
|
258
|
+
function investedUnderlyingBalance() external view returns (uint256) {
|
259
|
+
if (rewardPool() == address(0)) {
|
260
|
+
return IERC20(underlying()).balanceOf(address(this));
|
261
|
+
}
|
262
|
+
// Adding the amount locked in the reward pool and the amount that is somehow in this contract
|
263
|
+
// both are in the units of "underlying"
|
264
|
+
// The second part is needed because there is the emergency exit mechanism
|
265
|
+
// which would break the assumption that all the funds are always inside of the reward pool
|
266
|
+
(uint256 rewardPoolBalance,,) = rewardPoolBalances();
|
267
|
+
return rewardPoolBalance.add(IERC20(underlying()).balanceOf(address(this)));
|
268
|
+
}
|
269
|
+
|
270
|
+
/*
|
271
|
+
* Governance or Controller can claim coins that are somehow transferred into the contract
|
272
|
+
* Note that they cannot come in take away coins that are used and defined in the strategy itself
|
273
|
+
*/
|
274
|
+
function salvage(address recipient, address token, uint256 amount) external onlyControllerOrGovernance {
|
275
|
+
// To make sure that governance cannot come in and take away the coins
|
276
|
+
require(!unsalvagableTokens(token), "token is defined as not salvagable");
|
277
|
+
IERC20(token).safeTransfer(recipient, amount);
|
278
|
+
}
|
279
|
+
|
280
|
+
function redeemDerivatives() external onlyGovernance {
|
281
|
+
exitRewardPool();
|
282
|
+
uint256 balanceUp = IERC20(upToken()).balanceOf(address(this));
|
283
|
+
uint256 balanceDown = IERC20(downToken()).balanceOf(address(this));
|
284
|
+
uint256[] memory empty;
|
285
|
+
|
286
|
+
IProxyActions(proxy()).redeem(usdcVault(), balanceUp, balanceDown, empty);
|
287
|
+
}
|
288
|
+
|
289
|
+
/*
|
290
|
+
* Get the reward, sell it in exchange for underlying, invest what you got.
|
291
|
+
* It's not much, but it's honest work.
|
292
|
+
*
|
293
|
+
* Note that although `onlyNotPausedInvesting` is not added here,
|
294
|
+
* calling `investAllUnderlying()` affectively blocks the usage of `doHardWork`
|
295
|
+
* when the investing is being paused by governance.
|
296
|
+
*/
|
297
|
+
function doHardWork() external onlyNotPausedInvesting restricted {
|
298
|
+
ILiquidityMining(rewardPool()).claim();
|
299
|
+
_liquidateReward();
|
300
|
+
_usdcToUnderlying();
|
301
|
+
investAllUnderlying();
|
302
|
+
}
|
303
|
+
|
304
|
+
/**
|
305
|
+
* Can completely disable claiming UNI rewards and selling. Good for emergency withdraw in the
|
306
|
+
* simplest possible way.
|
307
|
+
*/
|
308
|
+
function setSell(bool s) public onlyGovernance {
|
309
|
+
_setSell(s);
|
310
|
+
}
|
311
|
+
|
312
|
+
/**
|
313
|
+
* Sets the minimum amount of CRV needed to trigger a sale.
|
314
|
+
*/
|
315
|
+
function setSellFloor(uint256 floor) public onlyGovernance {
|
316
|
+
_setSellFloor(floor);
|
317
|
+
}
|
318
|
+
|
319
|
+
// masterchef rewards pool ID
|
320
|
+
function _setPoolIdUnderlying(uint256 _value) internal {
|
321
|
+
setUint256(_POOLID_UNDERLYING_SLOT, _value);
|
322
|
+
}
|
323
|
+
|
324
|
+
function poolIdUnderlying() public view returns (uint256) {
|
325
|
+
return getUint256(_POOLID_UNDERLYING_SLOT);
|
326
|
+
}
|
327
|
+
|
328
|
+
function _setPoolIdUp(uint256 _value) internal {
|
329
|
+
setUint256(_POOLID_UP_SLOT, _value);
|
330
|
+
}
|
331
|
+
|
332
|
+
function poolIdUp() public view returns (uint256) {
|
333
|
+
return getUint256(_POOLID_UP_SLOT);
|
334
|
+
}
|
335
|
+
|
336
|
+
function _setPoolIdDown(uint256 _value) internal {
|
337
|
+
setUint256(_POOLID_DOWN_SLOT, _value);
|
338
|
+
}
|
339
|
+
|
340
|
+
function poolIdDown() public view returns (uint256) {
|
341
|
+
return getUint256(_POOLID_DOWN_SLOT);
|
342
|
+
}
|
343
|
+
|
344
|
+
function _setUSDCVault(address _address) internal {
|
345
|
+
setAddress(_USDC_VAULT_SLOT, _address);
|
346
|
+
}
|
347
|
+
|
348
|
+
function usdcVault() public view returns (address) {
|
349
|
+
return getAddress(_USDC_VAULT_SLOT);
|
350
|
+
}
|
351
|
+
|
352
|
+
function _setProxy(address _address) internal {
|
353
|
+
setAddress(_PROXY_SLOT, _address);
|
354
|
+
}
|
355
|
+
|
356
|
+
function proxy() public view returns (address) {
|
357
|
+
return getAddress(_PROXY_SLOT);
|
358
|
+
}
|
359
|
+
|
360
|
+
function _setUpToken(address _address) internal {
|
361
|
+
setAddress(_UP_TOKEN_SLOT, _address);
|
362
|
+
}
|
363
|
+
|
364
|
+
function upToken() public view returns (address) {
|
365
|
+
return getAddress(_UP_TOKEN_SLOT);
|
366
|
+
}
|
367
|
+
|
368
|
+
function _setDownToken(address _address) internal {
|
369
|
+
setAddress(_DOWN_TOKEN_SLOT, _address);
|
370
|
+
}
|
371
|
+
|
372
|
+
function downToken() public view returns (address) {
|
373
|
+
return getAddress(_DOWN_TOKEN_SLOT);
|
374
|
+
}
|
375
|
+
|
376
|
+
function finalizeUpgrade() external onlyGovernance {
|
377
|
+
_finalizeUpgrade();
|
378
|
+
// reset the liquidation paths
|
379
|
+
// they need to be re-set manually
|
380
|
+
}
|
381
|
+
}
|
@@ -0,0 +1,35 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "./ComplifiDerivStrategy.sol";
|
5
|
+
|
6
|
+
//TO BE UPDATED WITH ADDRESSES WHEN THEY ARE KNOWN
|
7
|
+
|
8
|
+
contract ComplifiDerivStrategyMainnet_ETH5x is ComplifiDerivStrategy {
|
9
|
+
|
10
|
+
address public eth5x_unused; // just a differentiator for the bytecode
|
11
|
+
|
12
|
+
constructor() public {}
|
13
|
+
|
14
|
+
function initializeStrategy(
|
15
|
+
address _storage,
|
16
|
+
address _vault
|
17
|
+
) public initializer {
|
18
|
+
address underlying = address(0);
|
19
|
+
address usdcVault = address(0);
|
20
|
+
address proxy = address(0);
|
21
|
+
address comfi = address(0x72bba3Aa59a1cCB1591D7CDDB714d8e4D5597E96);
|
22
|
+
address weth = address(0x7ceB23fD6bC0adD59E62ac25578270cFf1b9f619);
|
23
|
+
ComplifiDerivStrategy.initializeStrategy(
|
24
|
+
_storage,
|
25
|
+
underlying,
|
26
|
+
_vault,
|
27
|
+
address(0), // master chef contract
|
28
|
+
comfi,
|
29
|
+
usdcVault,
|
30
|
+
proxy
|
31
|
+
);
|
32
|
+
// comfi is token0, weth is token1
|
33
|
+
liquidationPath = [comfi, weth, usdc];
|
34
|
+
}
|
35
|
+
}
|