@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,322 @@
|
|
1
|
+
//SPDX-License-Identifier: Unlicense
|
2
|
+
|
3
|
+
pragma solidity 0.6.12;
|
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 "@uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router02.sol";
|
9
|
+
import "@uniswap/v2-core/contracts/interfaces/IUniswapV2Pair.sol";
|
10
|
+
import "../interface/IVault.sol";
|
11
|
+
import "../upgradability/BaseUpgradeableStrategy.sol";
|
12
|
+
import "./interface/IMiniChefV2.sol";
|
13
|
+
import "@uniswap/v2-periphery/contracts/interfaces/IWETH.sol";
|
14
|
+
|
15
|
+
|
16
|
+
contract MiniApeV2Strategy is BaseUpgradeableStrategy {
|
17
|
+
|
18
|
+
using SafeMath for uint256;
|
19
|
+
using SafeERC20 for IERC20;
|
20
|
+
|
21
|
+
address public constant apeswapRouterV2 = address(0xC0788A3aD43d79aa53B09c2EaCc313A787d1d607);
|
22
|
+
|
23
|
+
// additional storage slots (on top of BaseUpgradeableStrategy ones) are defined here
|
24
|
+
bytes32 internal constant _POOLID_SLOT = 0x3fd729bfa2e28b7806b03a6e014729f59477b530f995be4d51defc9dad94810b;
|
25
|
+
|
26
|
+
// this would be reset on each upgrade
|
27
|
+
mapping (address => address[]) public uniswapRoutes;
|
28
|
+
|
29
|
+
constructor() public BaseUpgradeableStrategy() {
|
30
|
+
assert(_POOLID_SLOT == bytes32(uint256(keccak256("eip1967.strategyStorage.poolId")) - 1));
|
31
|
+
}
|
32
|
+
|
33
|
+
function initializeBaseStrategy(
|
34
|
+
address _storage,
|
35
|
+
address _underlying,
|
36
|
+
address _vault,
|
37
|
+
address _rewardPool,
|
38
|
+
address _rewardToken,
|
39
|
+
uint256 _poolID
|
40
|
+
) public initializer {
|
41
|
+
|
42
|
+
BaseUpgradeableStrategy.initialize(
|
43
|
+
_storage,
|
44
|
+
_underlying,
|
45
|
+
_vault,
|
46
|
+
_rewardPool,
|
47
|
+
_rewardToken,
|
48
|
+
80, // profit sharing numerator
|
49
|
+
1000, // profit sharing denominator
|
50
|
+
true, // sell
|
51
|
+
1e18, // sell floor
|
52
|
+
12 hours // implementation change delay
|
53
|
+
);
|
54
|
+
|
55
|
+
require(address(IMiniChefV2(rewardPool()).lpToken(_poolID)) == underlying(), "Pool Info does not match underlying");
|
56
|
+
_setPoolId(_poolID);
|
57
|
+
|
58
|
+
address uniLPComponentToken0 = IUniswapV2Pair(underlying()).token0();
|
59
|
+
address uniLPComponentToken1 = IUniswapV2Pair(underlying()).token1();
|
60
|
+
|
61
|
+
// these would be required to be initialized separately by governance
|
62
|
+
uniswapRoutes[uniLPComponentToken0] = new address[](0);
|
63
|
+
uniswapRoutes[uniLPComponentToken1] = new address[](0);
|
64
|
+
|
65
|
+
}
|
66
|
+
|
67
|
+
function depositArbCheck() public pure returns(bool) {
|
68
|
+
return true;
|
69
|
+
}
|
70
|
+
|
71
|
+
function rewardPoolBalance() internal view returns (uint256 bal) {
|
72
|
+
(bal,) = IMiniChefV2(rewardPool()).userInfo(poolId(), address(this));
|
73
|
+
}
|
74
|
+
|
75
|
+
function exitRewardPool() internal {
|
76
|
+
uint256 bal = rewardPoolBalance();
|
77
|
+
if (bal != 0) {
|
78
|
+
IMiniChefV2(rewardPool()).withdrawAndHarvest(poolId(), bal, address(this));
|
79
|
+
}
|
80
|
+
}
|
81
|
+
|
82
|
+
function emergencyExitRewardPool() internal {
|
83
|
+
uint256 bal = rewardPoolBalance();
|
84
|
+
if (bal != 0) {
|
85
|
+
IMiniChefV2(rewardPool()).emergencyWithdraw(poolId(), address(this));
|
86
|
+
}
|
87
|
+
}
|
88
|
+
|
89
|
+
function harvestReward() internal {
|
90
|
+
IMiniChefV2(rewardPool()).harvest(poolId(), address(this));
|
91
|
+
}
|
92
|
+
|
93
|
+
function unsalvagableTokens(address token) public view returns (bool) {
|
94
|
+
return (token == rewardToken() || token == underlying());
|
95
|
+
}
|
96
|
+
|
97
|
+
function enterRewardPool() internal {
|
98
|
+
uint256 entireBalance = IERC20(underlying()).balanceOf(address(this));
|
99
|
+
IERC20(underlying()).safeApprove(rewardPool(), 0);
|
100
|
+
IERC20(underlying()).safeApprove(rewardPool(), entireBalance);
|
101
|
+
IMiniChefV2(rewardPool()).deposit(poolId(), entireBalance, address(this));
|
102
|
+
}
|
103
|
+
|
104
|
+
/*
|
105
|
+
* In case there are some issues discovered about the pool or underlying asset
|
106
|
+
* Governance can exit the pool properly
|
107
|
+
* The function is only used for emergency to exit the pool
|
108
|
+
*/
|
109
|
+
function emergencyExit() public onlyGovernance {
|
110
|
+
emergencyExitRewardPool();
|
111
|
+
_setPausedInvesting(true);
|
112
|
+
}
|
113
|
+
|
114
|
+
/*
|
115
|
+
* Resumes the ability to invest into the underlying reward pools
|
116
|
+
*/
|
117
|
+
|
118
|
+
function continueInvesting() public onlyGovernance {
|
119
|
+
_setPausedInvesting(false);
|
120
|
+
}
|
121
|
+
|
122
|
+
function setLiquidationPath(address _token, address [] memory _route) public onlyGovernance {
|
123
|
+
uniswapRoutes[_token] = _route;
|
124
|
+
}
|
125
|
+
|
126
|
+
// We assume that all the tradings can be done on Uniswap
|
127
|
+
function _liquidateReward() internal {
|
128
|
+
// we can accept 1 as minimum because this is called only by a trusted role
|
129
|
+
uint256 amountOutMin = 1;
|
130
|
+
|
131
|
+
uint256 rewardBalance = IERC20(rewardToken()).balanceOf(address(this));
|
132
|
+
if (!sell() || rewardBalance < sellFloor()) {
|
133
|
+
// Profits can be disabled for possible simplified and rapid exit
|
134
|
+
emit ProfitsNotCollected(sell(), rewardBalance < sellFloor());
|
135
|
+
return;
|
136
|
+
}
|
137
|
+
|
138
|
+
notifyProfitInRewardToken(rewardBalance);
|
139
|
+
uint256 remainingRewardBalance = IERC20(rewardToken()).balanceOf(address(this));
|
140
|
+
|
141
|
+
if (remainingRewardBalance == 0) {
|
142
|
+
return;
|
143
|
+
}
|
144
|
+
|
145
|
+
// allow Uniswap to sell our reward
|
146
|
+
IERC20(rewardToken()).safeApprove(apeswapRouterV2, 0);
|
147
|
+
IERC20(rewardToken()).safeApprove(apeswapRouterV2, remainingRewardBalance);
|
148
|
+
|
149
|
+
|
150
|
+
address uniLPComponentToken0 = IUniswapV2Pair(underlying()).token0();
|
151
|
+
address uniLPComponentToken1 = IUniswapV2Pair(underlying()).token1();
|
152
|
+
|
153
|
+
uint256 toToken0 = remainingRewardBalance.div(2);
|
154
|
+
uint256 toToken1 = remainingRewardBalance.sub(toToken0);
|
155
|
+
|
156
|
+
uint256 token0Amount;
|
157
|
+
|
158
|
+
if (uniswapRoutes[uniLPComponentToken0].length > 1) {
|
159
|
+
// if we need to liquidate the token0
|
160
|
+
IUniswapV2Router02(apeswapRouterV2).swapExactTokensForTokens(
|
161
|
+
toToken0,
|
162
|
+
amountOutMin,
|
163
|
+
uniswapRoutes[uniLPComponentToken0],
|
164
|
+
address(this),
|
165
|
+
block.timestamp
|
166
|
+
);
|
167
|
+
token0Amount = IERC20(uniLPComponentToken0).balanceOf(address(this));
|
168
|
+
} else {
|
169
|
+
// otherwise we assme token0 is the reward token itself
|
170
|
+
token0Amount = toToken0;
|
171
|
+
}
|
172
|
+
|
173
|
+
uint256 token1Amount;
|
174
|
+
|
175
|
+
if (uniswapRoutes[uniLPComponentToken1].length > 1) {
|
176
|
+
// sell reward token to token1
|
177
|
+
IUniswapV2Router02(apeswapRouterV2).swapExactTokensForTokens(
|
178
|
+
toToken1,
|
179
|
+
amountOutMin,
|
180
|
+
uniswapRoutes[uniLPComponentToken1],
|
181
|
+
address(this),
|
182
|
+
block.timestamp
|
183
|
+
);
|
184
|
+
token1Amount = IERC20(uniLPComponentToken1).balanceOf(address(this));
|
185
|
+
} else {
|
186
|
+
token1Amount = toToken1;
|
187
|
+
}
|
188
|
+
|
189
|
+
// provide token1 and token2 to ape
|
190
|
+
IERC20(uniLPComponentToken0).safeApprove(apeswapRouterV2, 0);
|
191
|
+
IERC20(uniLPComponentToken0).safeApprove(apeswapRouterV2, token0Amount);
|
192
|
+
|
193
|
+
IERC20(uniLPComponentToken1).safeApprove(apeswapRouterV2, 0);
|
194
|
+
IERC20(uniLPComponentToken1).safeApprove(apeswapRouterV2, token1Amount);
|
195
|
+
|
196
|
+
// we provide liquidity to ape
|
197
|
+
uint256 liquidity;
|
198
|
+
(,,liquidity) = IUniswapV2Router02(apeswapRouterV2).addLiquidity(
|
199
|
+
uniLPComponentToken0,
|
200
|
+
uniLPComponentToken1,
|
201
|
+
token0Amount,
|
202
|
+
token1Amount,
|
203
|
+
1, // we are willing to take whatever the pair gives us
|
204
|
+
1, // we are willing to take whatever the pair gives us
|
205
|
+
address(this),
|
206
|
+
block.timestamp
|
207
|
+
);
|
208
|
+
|
209
|
+
}
|
210
|
+
|
211
|
+
/*
|
212
|
+
* Stakes everything the strategy holds into the reward pool
|
213
|
+
*/
|
214
|
+
function investAllUnderlying() internal onlyNotPausedInvesting {
|
215
|
+
// this check is needed, because most of the SNX reward pools will revert if
|
216
|
+
// you try to stake(0).
|
217
|
+
if(IERC20(underlying()).balanceOf(address(this)) > 0) {
|
218
|
+
enterRewardPool();
|
219
|
+
}
|
220
|
+
}
|
221
|
+
|
222
|
+
/*
|
223
|
+
* Withdraws all the asset to the vault
|
224
|
+
*/
|
225
|
+
function withdrawAllToVault() public restricted {
|
226
|
+
if (address(rewardPool()) != address(0)) {
|
227
|
+
exitRewardPool();
|
228
|
+
}
|
229
|
+
_liquidateReward();
|
230
|
+
IERC20(underlying()).safeTransfer(vault(), IERC20(underlying()).balanceOf(address(this)));
|
231
|
+
}
|
232
|
+
|
233
|
+
/*
|
234
|
+
* Withdraws all the asset to the vault
|
235
|
+
*/
|
236
|
+
function withdrawToVault(uint256 amount) public restricted {
|
237
|
+
// Typically there wouldn't be any amount here
|
238
|
+
// however, it is possible because of the emergencyExit
|
239
|
+
uint256 entireBalance = IERC20(underlying()).balanceOf(address(this));
|
240
|
+
|
241
|
+
if(amount > entireBalance){
|
242
|
+
// While we have the check above, we still using SafeMath below
|
243
|
+
// for the peace of mind (in case something gets changed in between)
|
244
|
+
uint256 needToWithdraw = amount.sub(entireBalance);
|
245
|
+
uint256 toWithdraw = Math.min(rewardPoolBalance(), needToWithdraw);
|
246
|
+
IMiniChefV2(rewardPool()).withdraw(poolId(), toWithdraw, address(this));
|
247
|
+
}
|
248
|
+
|
249
|
+
IERC20(underlying()).safeTransfer(vault(), amount);
|
250
|
+
}
|
251
|
+
|
252
|
+
/*
|
253
|
+
* Note that we currently do not have a mechanism here to include the
|
254
|
+
* amount of reward that is accrued.
|
255
|
+
*/
|
256
|
+
function investedUnderlyingBalance() external view returns (uint256) {
|
257
|
+
if (rewardPool() == address(0)) {
|
258
|
+
return IERC20(underlying()).balanceOf(address(this));
|
259
|
+
}
|
260
|
+
// Adding the amount locked in the reward pool and the amount that is somehow in this contract
|
261
|
+
// both are in the units of "underlying"
|
262
|
+
// The second part is needed because there is the emergency exit mechanism
|
263
|
+
// which would break the assumption that all the funds are always inside of the reward pool
|
264
|
+
return rewardPoolBalance().add(IERC20(underlying()).balanceOf(address(this)));
|
265
|
+
}
|
266
|
+
|
267
|
+
/*
|
268
|
+
* Governance or Controller can claim coins that are somehow transferred into the contract
|
269
|
+
* Note that they cannot come in take away coins that are used and defined in the strategy itself
|
270
|
+
*/
|
271
|
+
function salvage(address recipient, address token, uint256 amount) external onlyControllerOrGovernance {
|
272
|
+
// To make sure that governance cannot come in and take away the coins
|
273
|
+
require(!unsalvagableTokens(token), "token is defined as not salvagable");
|
274
|
+
IERC20(token).safeTransfer(recipient, amount);
|
275
|
+
}
|
276
|
+
|
277
|
+
/*
|
278
|
+
* Get the reward, sell it in exchange for underlying, invest what you got.
|
279
|
+
* It's not much, but it's honest work.
|
280
|
+
*
|
281
|
+
* Note that although `onlyNotPausedInvesting` is not added here,
|
282
|
+
* calling `investAllUnderlying()` affectively blocks the usage of `doHardWork`
|
283
|
+
* when the investing is being paused by governance.
|
284
|
+
*/
|
285
|
+
function doHardWork() external onlyNotPausedInvesting restricted {
|
286
|
+
harvestReward();
|
287
|
+
_liquidateReward();
|
288
|
+
investAllUnderlying();
|
289
|
+
}
|
290
|
+
|
291
|
+
/**
|
292
|
+
* Can completely disable claiming BANANA rewards and selling. Good for emergency withdraw in the
|
293
|
+
* simplest possible way.
|
294
|
+
*/
|
295
|
+
function setSell(bool s) public onlyGovernance {
|
296
|
+
_setSell(s);
|
297
|
+
}
|
298
|
+
|
299
|
+
/**
|
300
|
+
* Sets the minimum amount of reward needed to trigger a sale.
|
301
|
+
*/
|
302
|
+
function setSellFloor(uint256 floor) public onlyGovernance {
|
303
|
+
_setSellFloor(floor);
|
304
|
+
}
|
305
|
+
|
306
|
+
// masterchef rewards pool ID
|
307
|
+
function _setPoolId(uint256 _value) internal {
|
308
|
+
setUint256(_POOLID_SLOT, _value);
|
309
|
+
}
|
310
|
+
|
311
|
+
function poolId() public view returns (uint256) {
|
312
|
+
return getUint256(_POOLID_SLOT);
|
313
|
+
}
|
314
|
+
|
315
|
+
function finalizeUpgrade() external onlyGovernance {
|
316
|
+
_finalizeUpgrade();
|
317
|
+
// reset the liquidation paths
|
318
|
+
// they need to be re-set manually
|
319
|
+
uniswapRoutes[IUniswapV2Pair(underlying()).token0()] = new address[](0);
|
320
|
+
uniswapRoutes[IUniswapV2Pair(underlying()).token1()] = new address[](0);
|
321
|
+
}
|
322
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
pragma experimental ABIEncoderV2;
|
4
|
+
|
5
|
+
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
|
6
|
+
import "./IRewarder.sol";
|
7
|
+
|
8
|
+
interface IMiniChefV2 {
|
9
|
+
struct UserInfo {
|
10
|
+
uint256 amount;
|
11
|
+
uint256 rewardDebt;
|
12
|
+
}
|
13
|
+
|
14
|
+
struct PoolInfo {
|
15
|
+
uint128 accSushiPerShare;
|
16
|
+
uint64 lastRewardTime;
|
17
|
+
uint64 allocPoint;
|
18
|
+
}
|
19
|
+
|
20
|
+
function rewarder(uint256 _pid) external view returns (IRewarder);
|
21
|
+
function poolLength() external view returns (uint256);
|
22
|
+
function updatePool(uint256 pid) external returns (IMiniChefV2.PoolInfo memory);
|
23
|
+
function userInfo(uint256 _pid, address _user) external view returns (uint256, uint256);
|
24
|
+
function lpToken(uint256 _pid) external view returns (IERC20);
|
25
|
+
function deposit(uint256 pid, uint256 amount, address to) external;
|
26
|
+
function withdraw(uint256 pid, uint256 amount, address to) external;
|
27
|
+
function harvest(uint256 pid, address to) external;
|
28
|
+
function withdrawAndHarvest(uint256 pid, uint256 amount, address to) external;
|
29
|
+
function emergencyWithdraw(uint256 pid, address to) external;
|
30
|
+
function pendingBanana(uint256 _pid, address _user) external view returns (uint256 pending);
|
31
|
+
}
|
@@ -0,0 +1,10 @@
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
2
|
+
|
3
|
+
pragma solidity 0.6.12;
|
4
|
+
|
5
|
+
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
|
6
|
+
|
7
|
+
interface IRewarder {
|
8
|
+
function onBananaReward(uint256 pid, address user, address recipient, uint256 bananaAmount, uint256 newLpAmount) external;
|
9
|
+
function pendingTokens(uint256 pid, address user, uint256 bananaAmount) external view returns (IERC20[] memory, uint256[] memory);
|
10
|
+
}
|
@@ -0,0 +1,120 @@
|
|
1
|
+
// SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "@openzeppelin/contracts/access/Ownable.sol";
|
5
|
+
import "./interface/IStrategyFactory.sol";
|
6
|
+
import "./interface/IVaultFactory.sol";
|
7
|
+
import "./interface/IPoolFactory.sol";
|
8
|
+
|
9
|
+
import "../interface/IVault.sol";
|
10
|
+
import "../inheritance/Governable.sol";
|
11
|
+
|
12
|
+
contract MegaFactory is Ownable {
|
13
|
+
|
14
|
+
enum VaultType {
|
15
|
+
None,
|
16
|
+
Regular
|
17
|
+
}
|
18
|
+
|
19
|
+
enum StrategyType {
|
20
|
+
None,
|
21
|
+
Upgradable
|
22
|
+
}
|
23
|
+
|
24
|
+
address public potPoolFactory;
|
25
|
+
mapping(uint256 => address) public vaultFactories;
|
26
|
+
mapping(uint256 => address) public strategyFactories;
|
27
|
+
|
28
|
+
struct CompletedDeployment {
|
29
|
+
VaultType vaultType;
|
30
|
+
address Underlying;
|
31
|
+
address NewVault;
|
32
|
+
address NewStrategy;
|
33
|
+
address NewPool;
|
34
|
+
}
|
35
|
+
|
36
|
+
event DeploymentCompleted(string id);
|
37
|
+
|
38
|
+
mapping (string => CompletedDeployment) public completedDeployments;
|
39
|
+
mapping (address => bool) public authorizedDeployers;
|
40
|
+
|
41
|
+
address public multisig;
|
42
|
+
address public actualStorage;
|
43
|
+
|
44
|
+
/* methods to make compatible with Storage */
|
45
|
+
function governance() external view returns (address) {
|
46
|
+
return address(this); // fake governance
|
47
|
+
}
|
48
|
+
|
49
|
+
function isGovernance(address addr) external view returns (bool) {
|
50
|
+
return addr == address(this); // fake governance
|
51
|
+
}
|
52
|
+
|
53
|
+
function isController(address addr) external view returns (bool) {
|
54
|
+
return addr == address(this); // fake controller
|
55
|
+
}
|
56
|
+
|
57
|
+
modifier onlyAuthorizedDeployer(string memory id) {
|
58
|
+
require(completedDeployments[id].vaultType == VaultType.None, "cannot reuse id");
|
59
|
+
require(authorizedDeployers[msg.sender], "unauthorized deployer");
|
60
|
+
_;
|
61
|
+
emit DeploymentCompleted(id);
|
62
|
+
}
|
63
|
+
|
64
|
+
constructor(address _storage, address _multisig) public {
|
65
|
+
multisig = _multisig;
|
66
|
+
actualStorage = _storage;
|
67
|
+
setAuthorization(owner(), true);
|
68
|
+
setAuthorization(multisig, true);
|
69
|
+
}
|
70
|
+
|
71
|
+
function setAuthorization(address userAddress, bool isDeployer) public onlyOwner {
|
72
|
+
authorizedDeployers[userAddress] = isDeployer;
|
73
|
+
}
|
74
|
+
|
75
|
+
function setVaultFactory(uint256 vaultType, address factoryAddress) external onlyOwner {
|
76
|
+
vaultFactories[vaultType] = factoryAddress;
|
77
|
+
}
|
78
|
+
|
79
|
+
function setStrategyFactory(uint256 strategyType, address factoryAddress) external onlyOwner {
|
80
|
+
strategyFactories[strategyType] = factoryAddress;
|
81
|
+
}
|
82
|
+
|
83
|
+
function setPotPoolFactory(address factoryAddress) external onlyOwner {
|
84
|
+
potPoolFactory = factoryAddress;
|
85
|
+
}
|
86
|
+
|
87
|
+
function createRegularVault(string calldata id, address underlying) external onlyAuthorizedDeployer(id) {
|
88
|
+
address vault = IVaultFactory(vaultFactories[uint256(VaultType.Regular)]).deploy(
|
89
|
+
actualStorage,
|
90
|
+
underlying
|
91
|
+
);
|
92
|
+
|
93
|
+
completedDeployments[id] = CompletedDeployment(
|
94
|
+
VaultType.Regular,
|
95
|
+
underlying,
|
96
|
+
vault,
|
97
|
+
address(0),
|
98
|
+
IPoolFactory(potPoolFactory).deploy(actualStorage, vault)
|
99
|
+
);
|
100
|
+
}
|
101
|
+
|
102
|
+
function createRegularVaultUsingUpgradableStrategy(string calldata id, address underlying, address strategyImplementation) external onlyAuthorizedDeployer(id) {
|
103
|
+
address vault = IVaultFactory(vaultFactories[uint256(VaultType.Regular)]).deploy(
|
104
|
+
address(this), // using this as initial storage, then switching to actualStorage
|
105
|
+
underlying
|
106
|
+
);
|
107
|
+
|
108
|
+
address strategy = IStrategyFactory(strategyFactories[uint256(StrategyType.Upgradable)]).deploy(actualStorage, vault, strategyImplementation);
|
109
|
+
IVault(vault).setStrategy(strategy);
|
110
|
+
Governable(vault).setStorage(actualStorage);
|
111
|
+
|
112
|
+
completedDeployments[id] = CompletedDeployment(
|
113
|
+
VaultType.Regular,
|
114
|
+
underlying,
|
115
|
+
vault,
|
116
|
+
strategy,
|
117
|
+
IPoolFactory(potPoolFactory).deploy(actualStorage, vault)
|
118
|
+
);
|
119
|
+
}
|
120
|
+
}
|
@@ -0,0 +1,7 @@
|
|
1
|
+
// SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
interface IVaultFactory {
|
5
|
+
function deploy(address _storage, address _underlying) external returns (address);
|
6
|
+
function info(address vault) external view returns(address Underlying, address NewVault);
|
7
|
+
}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
// SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
|
5
|
+
import "../../inheritance/Governable.sol";
|
6
|
+
import "../../inheritance/OwnableWhitelist.sol";
|
7
|
+
import "../interface/IPoolFactory.sol";
|
8
|
+
import "../../PotPool.sol";
|
9
|
+
|
10
|
+
contract PotPoolFactory is OwnableWhitelist, IPoolFactory {
|
11
|
+
address public iFARM = 0xab0b2ddB9C7e440fAc8E140A89c0dbCBf2d7Bbff;
|
12
|
+
address public wMATIC = 0x0d500B1d8E8eF31E21C99d1Db9A6444d3ADf1270;
|
13
|
+
uint256 public poolDefaultDuration = 604800; // 7 days
|
14
|
+
|
15
|
+
function setPoolDefaultDuration(uint256 _value) external onlyOwner {
|
16
|
+
poolDefaultDuration = _value;
|
17
|
+
}
|
18
|
+
|
19
|
+
function deploy(address actualStorage, address vault) override external onlyWhitelisted returns (address) {
|
20
|
+
address actualGovernance = Governable(vault).governance();
|
21
|
+
|
22
|
+
string memory tokenSymbol = ERC20(vault).symbol();
|
23
|
+
address[] memory rewardDistribution = new address[](1);
|
24
|
+
rewardDistribution[0] = actualGovernance;
|
25
|
+
address[] memory rewardTokens = new address[](2);
|
26
|
+
rewardTokens[0] = iFARM;
|
27
|
+
rewardTokens[1] = wMATIC;
|
28
|
+
PotPool pool = new PotPool(
|
29
|
+
rewardTokens,
|
30
|
+
vault,
|
31
|
+
poolDefaultDuration,
|
32
|
+
rewardDistribution,
|
33
|
+
actualStorage,
|
34
|
+
string(abi.encodePacked("p", tokenSymbol)),
|
35
|
+
string(abi.encodePacked("p", tokenSymbol)),
|
36
|
+
ERC20(vault).decimals()
|
37
|
+
);
|
38
|
+
|
39
|
+
Ownable(pool).transferOwnership(actualGovernance);
|
40
|
+
|
41
|
+
return address(pool);
|
42
|
+
}
|
43
|
+
}
|
@@ -0,0 +1,19 @@
|
|
1
|
+
// SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "../interface/IStrategyFactory.sol";
|
5
|
+
import "../../upgradability/StrategyProxy.sol";
|
6
|
+
import "../../inheritance/OwnableWhitelist.sol";
|
7
|
+
|
8
|
+
interface IInitializableStrategy {
|
9
|
+
function initializeStrategy(address _storage, address _vault) external;
|
10
|
+
}
|
11
|
+
|
12
|
+
contract UpgradableStrategyFactory is OwnableWhitelist, IStrategyFactory {
|
13
|
+
function deploy(address actualStorage, address vault, address upgradableStrategyImplementation) override external onlyWhitelisted returns (address) {
|
14
|
+
StrategyProxy proxy = new StrategyProxy(upgradableStrategyImplementation);
|
15
|
+
IInitializableStrategy strategy = IInitializableStrategy(address(proxy));
|
16
|
+
strategy.initializeStrategy(actualStorage, vault);
|
17
|
+
return address(proxy);
|
18
|
+
}
|
19
|
+
}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
// SPDX-License-Identifier: Unlicense
|
2
|
+
pragma solidity 0.6.12;
|
3
|
+
|
4
|
+
import "../../VaultProxy.sol";
|
5
|
+
import "../../interface/IVault.sol";
|
6
|
+
import "../interface/IVaultFactory.sol";
|
7
|
+
import "../../inheritance/OwnableWhitelist.sol";
|
8
|
+
|
9
|
+
contract RegularVaultFactory is OwnableWhitelist, IVaultFactory {
|
10
|
+
address public vaultImplementation = 0xCf5F83F8FE0AB0f9E9C1db07E6606dD598b2bbf5;
|
11
|
+
address public lastDeployedAddress = address(0);
|
12
|
+
|
13
|
+
function deploy(address _storage, address underlying) override external onlyWhitelisted returns (address) {
|
14
|
+
lastDeployedAddress = address(new VaultProxy(vaultImplementation));
|
15
|
+
IVault(lastDeployedAddress).initializeVault(
|
16
|
+
_storage,
|
17
|
+
underlying,
|
18
|
+
10000,
|
19
|
+
10000
|
20
|
+
);
|
21
|
+
|
22
|
+
return lastDeployedAddress;
|
23
|
+
}
|
24
|
+
|
25
|
+
function changeDefaultImplementation(address newImplementation) external onlyOwner {
|
26
|
+
require(newImplementation != address(0), "Must be set");
|
27
|
+
vaultImplementation = newImplementation;
|
28
|
+
}
|
29
|
+
|
30
|
+
function info(address vault) override external view returns(address Underlying, address NewVault) {
|
31
|
+
Underlying = IVault(vault).underlying();
|
32
|
+
NewVault = vault;
|
33
|
+
}
|
34
|
+
}
|