@gooddollar/goodprotocol 2.1.3 → 2.2.0-beta.1
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.
- package/README.md +0 -2
- package/artifacts/abis/IdentityV4.min.json +1 -0
- package/artifacts/contracts/DAOStackInterfaces.sol/Avatar.dbg.json +1 -1
- package/artifacts/contracts/DAOStackInterfaces.sol/Controller.dbg.json +1 -1
- package/artifacts/contracts/DAOStackInterfaces.sol/GlobalConstraintInterface.dbg.json +1 -1
- package/artifacts/contracts/DAOStackInterfaces.sol/IntVoteInterface.dbg.json +1 -1
- package/artifacts/contracts/DAOStackInterfaces.sol/ReputationInterface.dbg.json +1 -1
- package/artifacts/contracts/DAOStackInterfaces.sol/SchemeRegistrar.dbg.json +1 -1
- package/artifacts/contracts/IUniswapV3.sol/INonfungiblePositionManager.dbg.json +1 -1
- package/artifacts/contracts/IUniswapV3.sol/IUniswapV3Pool.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/AggregatorV3Interface.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/ERC20.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IAaveIncentivesController.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IAdminWallet.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IDonationStaking.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IERC2917.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IFirstClaimPool.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IGoodDollar.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IGoodStaking.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IHasRouter.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IIdentity.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IIdentityV2.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/ILendingPool.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IMultichainRouter.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/INameService.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IQuoterV2.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/ISwapRouter.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/IUBIScheme.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/ProxyAdmin.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/Reserve.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/Uniswap.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/UniswapFactory.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/UniswapPair.dbg.json +1 -1
- package/artifacts/contracts/Interfaces.sol/cERC20.dbg.json +1 -1
- package/artifacts/contracts/MentoInterfaces.sol/IBancorExchangeProvider.dbg.json +1 -1
- package/artifacts/contracts/MentoInterfaces.sol/IBroker.dbg.json +1 -1
- package/artifacts/contracts/MentoInterfaces.sol/IGoodDollarExchangeProvider.dbg.json +1 -1
- package/artifacts/contracts/MentoInterfaces.sol/IGoodDollarExpansionController.dbg.json +1 -1
- package/artifacts/contracts/MentoInterfaces.sol/IMentoReserve.dbg.json +1 -1
- package/artifacts/contracts/MentoInterfaces.sol/ITradingLimits.dbg.json +1 -1
- package/artifacts/contracts/fuseFaucet/Faucet.sol/Faucet.dbg.json +1 -1
- package/artifacts/contracts/fuseFaucet/FuseFaucet.sol/FuseFaucet.dbg.json +1 -1
- package/artifacts/contracts/fuseFaucet/FuseFaucetV2.sol/FuseFaucetV2.dbg.json +1 -1
- package/artifacts/contracts/fuseFaucet/SuperfluidFacuet.sol/SuperfluidFaucet.dbg.json +1 -1
- package/artifacts/contracts/governance/ClaimersDistribution.sol/ClaimersDistribution.dbg.json +1 -1
- package/artifacts/contracts/governance/CompoundVotingMachine.sol/CompoundVotingMachine.dbg.json +1 -1
- package/artifacts/contracts/governance/GReputation.sol/GReputation.dbg.json +1 -1
- package/artifacts/contracts/governance/GoodDollarStaking.sol/GoodDollarStaking.dbg.json +1 -1
- package/artifacts/contracts/governance/GoodDollarStaking.sol/GoodDollarStaking.json +2 -2
- package/artifacts/contracts/governance/GoodDollarStaking.sol/IGovernanceStaking.dbg.json +1 -1
- package/artifacts/contracts/governance/GoodDollarStaking.sol/IStakingUpgrade.dbg.json +1 -1
- package/artifacts/contracts/governance/GoodDollarStaking.sol/RewardsMinter.dbg.json +1 -1
- package/artifacts/contracts/governance/GovernanceStaking.sol/GovernanceStaking.dbg.json +1 -1
- package/artifacts/contracts/governance/MultiBaseGovernanceShareField.sol/MultiBaseGovernanceShareField.dbg.json +1 -1
- package/artifacts/contracts/governance/Reputation.sol/Reputation.dbg.json +1 -1
- package/artifacts/contracts/governance/StakersDistribution.sol/StakersDistribution.dbg.json +1 -1
- package/artifacts/contracts/identity/IdentityV2.sol/IdentityV2.dbg.json +1 -1
- package/artifacts/contracts/identity/IdentityV3.sol/IdentityV3.dbg.json +1 -1
- package/artifacts/contracts/identity/IdentityV3.sol/IdentityV3.json +2 -2
- package/artifacts/contracts/identity/IdentityV4.sol/IdentityV4.dbg.json +4 -0
- package/artifacts/contracts/identity/IdentityV4.sol/IdentityV4.json +1162 -0
- package/artifacts/contracts/invite/InvitesFuseV2.sol/InvitesFuseV2.dbg.json +1 -1
- package/artifacts/contracts/invite/InvitesV1.sol/InvitesV1.dbg.json +1 -1
- package/artifacts/contracts/invite/InvitesV2.sol/InvitesV2.dbg.json +1 -1
- package/artifacts/contracts/invite/OneTimeReward.sol/OneTimeReward.dbg.json +1 -1
- package/artifacts/contracts/mocks/AaveMock.sol/AaveMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/AaveUSDMockOracle.sol/AaveUSDMockOracle.dbg.json +1 -1
- package/artifacts/contracts/mocks/BatUSDMockOracle.sol/BatUSDMockOracle.dbg.json +1 -1
- package/artifacts/contracts/mocks/CeloDistributionHelperTest.sol/CeloDistributionHelperTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/CeloDistributionHelperTest.sol/CeloDistributionHelperTestHelper.dbg.json +1 -1
- package/artifacts/contracts/mocks/CompUsdMockOracle.sol/CompUSDMockOracle.dbg.json +1 -1
- package/artifacts/contracts/mocks/DAIMock.sol/DAIMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/DaiEthPriceMockOracle.sol/DaiEthPriceMockOracle.dbg.json +1 -1
- package/artifacts/contracts/mocks/DecimalsMock.sol/DecimalsMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/DistributionBridgeMock.sol/DistributionBridgeMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/DistributionBridgeMock.sol/DistributionBridgeMock.json +2 -2
- package/artifacts/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTestHelper.dbg.json +1 -1
- package/artifacts/contracts/mocks/EthUSDMockOracle.sol/EthUSDMockOracle.dbg.json +1 -1
- package/artifacts/contracts/mocks/FeesFormularMock.sol/FeesFormulaMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/GasPriceMockOracle.sol/GasPriceMockOracle.dbg.json +1 -1
- package/artifacts/contracts/mocks/GenericDistributionHelperTest.sol/GenericDistributionHelperTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/GenericDistributionHelperTest.sol/GenericDistributionHelperTestHelper.dbg.json +1 -1
- package/artifacts/contracts/mocks/GoodCompoundStakingTest.sol/GoodCompoundStakingTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/GoodDollarStakingMock.sol/GoodDollarStakingMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/GoodDollarStakingMock.sol/GoodDollarStakingMock.json +2 -2
- package/artifacts/contracts/mocks/GoodFundManagerTest.sol/GoodFundManagerTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/IdentityMock.sol/IdentityMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/IncentiveControllerMock.sol/IncentiveControllerMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/LendingPoolMock.sol/LendingPoolMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/MultichainRouterMock.sol/IWrapper.dbg.json +1 -1
- package/artifacts/contracts/mocks/MultichainRouterMock.sol/MultichainRouterMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/MultichainRouterMock.sol/MultichainRouterMock.json +2 -2
- package/artifacts/contracts/mocks/OverMintTester.sol/IGoodDollarStakingTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/OverMintTester.sol/OverMintTester.dbg.json +1 -1
- package/artifacts/contracts/mocks/OverMintTesterRegularStake.sol/OverMintTesterRegularStake.dbg.json +1 -1
- package/artifacts/contracts/mocks/PayableMock.sol/PayableMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/SixteenDecimalsTokenMock.sol/SixteenDecimalsTokenMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/StakingMockFixedAPY.sol/StakingMockFixedAPY.dbg.json +1 -1
- package/artifacts/contracts/mocks/StakingMockFixedAPY.sol/StakingMockFixedAPY.json +2 -2
- package/artifacts/contracts/mocks/SwapHelperTest.sol/SwapHelperTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/TwentyDecimalsTokenMock.sol/TwentyDecimalsTokenMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock2.dbg.json +1 -1
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock3.dbg.json +1 -1
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock4.dbg.json +1 -1
- package/artifacts/contracts/mocks/UsdcMock.sol/USDCMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/cBATMock.sol/cBATMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/cDAILowWorthMock.sol/cDAILowWorthMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/cDAIMock.sol/cDAIMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/cDAINonMintableMock.sol/cDAINonMintableMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/cDecimalsMock.sol/cDecimalsMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/cSDTMock.sol/cSDTMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/cUSDCMock.sol/cUSDCMock.dbg.json +1 -1
- package/artifacts/contracts/reserve/CeloDistributionHelper.sol/CeloDistributionHelper.dbg.json +1 -1
- package/artifacts/contracts/reserve/DistributionHelper.sol/DistributionHelper.dbg.json +1 -1
- package/artifacts/contracts/reserve/ExchangeHelper.sol/ExchangeHelper.dbg.json +1 -1
- package/artifacts/contracts/reserve/GenericDistributionHelper.sol/GenericDistributionHelper.dbg.json +1 -1
- package/artifacts/contracts/reserve/GoodMarketMaker.sol/GoodMarketMaker.dbg.json +1 -1
- package/artifacts/contracts/reserve/GoodReserveCDai.sol/ContributionCalc.dbg.json +1 -1
- package/artifacts/contracts/reserve/GoodReserveCDai.sol/GoodReserveCDai.dbg.json +1 -1
- package/artifacts/contracts/staking/BaseShareField.sol/BaseShareField.dbg.json +1 -1
- package/artifacts/contracts/staking/BaseShareFieldV2.sol/BaseShareFieldV2.dbg.json +1 -1
- package/artifacts/contracts/staking/DonationsStaking.sol/DonationsStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/FuseStakingV3.sol/FuseStakingV3.dbg.json +1 -1
- package/artifacts/contracts/staking/FuseStakingV3.sol/IConsensus.dbg.json +1 -1
- package/artifacts/contracts/staking/FuseStakingV3.sol/PegSwap.dbg.json +1 -1
- package/artifacts/contracts/staking/GoodFundManager.sol/GoodFundManager.dbg.json +1 -1
- package/artifacts/contracts/staking/SimpleStaking.sol/SimpleStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/SimpleStakingV2.sol/SimpleStakingV2.dbg.json +1 -1
- package/artifacts/contracts/staking/UniswapV2SwapHelper.sol/UniswapV2SwapHelper.dbg.json +1 -1
- package/artifacts/contracts/staking/aave/AaveStakingFactory.sol/AaveStakingFactory.dbg.json +1 -1
- package/artifacts/contracts/staking/aave/GoodAaveStaking.sol/GoodAaveStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/aave/GoodAaveStakingV2.sol/GoodAaveStakingV2.dbg.json +1 -1
- package/artifacts/contracts/staking/compound/CompoundStakingFactory.sol/CompoundStakingFactory.dbg.json +1 -1
- package/artifacts/contracts/staking/compound/GoodCompoundStaking.sol/GoodCompoundStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/compound/GoodCompoundStakingV2.sol/GoodCompoundStakingV2.dbg.json +1 -1
- package/artifacts/contracts/staking/utils/Math64X64.sol/Math64x64.dbg.json +1 -1
- package/artifacts/contracts/staking/utils/StakingRewardsFixedAPY.sol/StakingRewardsFixedAPY.dbg.json +1 -1
- package/artifacts/contracts/token/ERC20PresetMinterPauserUpgradeable.sol/ERC20PresetMinterPauserUpgradeable.dbg.json +1 -1
- package/artifacts/contracts/token/ERC677.sol/ERC677.dbg.json +1 -1
- package/artifacts/contracts/token/ERC677.sol/ERC677Receiver.dbg.json +1 -1
- package/artifacts/contracts/token/GoodDollar.sol/GoodDollar.dbg.json +1 -1
- package/artifacts/contracts/token/GoodDollar2.sol/GoodDollar2.dbg.json +1 -1
- package/artifacts/contracts/token/IFeesFormula.sol/IFeesFormula.dbg.json +1 -1
- package/artifacts/contracts/token/MultichainFeeFormula.sol/MultichainFeeFormula.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/ERC20Permit.sol/ERC20Permit.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/ERC20Permit.sol/SelfApprove.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/ISuperGoodDollar.sol/IGoodDollarCustom.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/ISuperGoodDollar.sol/ISuperGoodDollar.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/ISuperToken.sol/ISuperToken.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/SuperGoodDollar.sol/SuperGoodDollar.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/SuperToken.sol/SuperToken.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/SuperfluidToken.sol/SuperfluidToken.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/UUPSProxiable.sol/UUPSProxiable.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/UUPSProxy.sol/Proxy.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/UUPSProxy.sol/UUPSProxy.dbg.json +1 -1
- package/artifacts/contracts/token/superfluid/UUPSProxy.sol/UUPSUtils.dbg.json +1 -1
- package/artifacts/contracts/ubi/UBIScheme.sol/UBIScheme.dbg.json +1 -1
- package/artifacts/contracts/ubi/UBISchemeV2.sol/UBISchemeV2.dbg.json +1 -1
- package/artifacts/contracts/utils/AdminWallet.sol/AdminWallet.dbg.json +1 -1
- package/artifacts/contracts/utils/AdminWalletFuse.sol/AdminWalletFuse.dbg.json +1 -1
- package/artifacts/contracts/utils/BancorFormula.sol/BancorFormula.dbg.json +1 -1
- package/artifacts/contracts/utils/BulkProof.sol/BulkProof.dbg.json +1 -1
- package/artifacts/contracts/utils/BulkWhitelist.sol/BulkWhitelist.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyAndBridgeHelper.sol/BuyAndBridgeHelper.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyFromReserveHelper.sol/BuyFromReserveHelper.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyGDClone.sol/BuyGDClone.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyGDClone.sol/BuyGDCloneFactory.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyGDClone.sol/DonateGDClone.dbg.json +1 -1
- package/artifacts/contracts/utils/DAOContract.sol/DAOContract.dbg.json +1 -1
- package/artifacts/contracts/utils/DAOUpgradeableContract.sol/DAOUpgradeableContract.dbg.json +1 -1
- package/artifacts/contracts/utils/DSMath.sol/DSMath.dbg.json +1 -1
- package/artifacts/contracts/utils/DataTypes.sol/DataTypes.dbg.json +1 -1
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/EternalStorage.dbg.json +1 -1
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/FuseOldBridgeKill.dbg.json +1 -1
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/IUpgradeabilityOwnerStorage.dbg.json +1 -1
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Initializable.dbg.json +1 -1
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Ownable.dbg.json +1 -1
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Upgradeable.dbg.json +1 -1
- package/artifacts/contracts/utils/GDFaucet.sol/GDFaucet.dbg.json +1 -1
- package/artifacts/contracts/utils/GoodDollarMintBurnWrapper.sol/GoodDollarMintBurnWrapper.dbg.json +1 -1
- package/artifacts/contracts/utils/GoodDollarMintBurnWrapper.sol/IRouter.dbg.json +1 -1
- package/artifacts/contracts/utils/GoodDollarMintBurnWrapper.sol/PausableControl.dbg.json +1 -1
- package/artifacts/contracts/utils/GoodDollarMintBurnWrapper.sol/TokenOperation.dbg.json +1 -1
- package/artifacts/contracts/utils/IdentityFix.sol/IdentityFix.dbg.json +1 -1
- package/artifacts/contracts/utils/LastauthReduction.sol/LastauthReduction.dbg.json +1 -1
- package/artifacts/contracts/utils/LastauthReduction.sol/LastauthReduction.json +2 -2
- package/artifacts/contracts/utils/MultiCall.sol/Multicall.dbg.json +1 -1
- package/artifacts/contracts/utils/MultichainBridgeHelper.sol/MultichainBridgeHelper.dbg.json +1 -1
- package/artifacts/contracts/utils/NameService.sol/NameService.dbg.json +1 -1
- package/artifacts/contracts/utils/OneTimePayments.sol/OneTimePayments.dbg.json +1 -1
- package/artifacts/contracts/utils/OneTimePaymentsV2.sol/OneTimePaymentsV2.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtoclUpgradeV4Mento.sol/MentoExchange.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtoclUpgradeV4Mento.sol/ProtocolUpgradeV4Mento.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgrade.sol/OldMarketMaker.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgrade.sol/ProtocolUpgrade.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgradeFuse.sol/ProtocolUpgradeFuse.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgradeFuseRecover.sol/ProtocolUpgradeFuseRecover.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgradeRecover.sol/ProtocolUpgradeRecover.dbg.json +1 -1
- package/artifacts/contracts/utils/ProxyFactory1967.sol/ERC1967Proxy.dbg.json +1 -1
- package/artifacts/contracts/utils/ProxyFactory1967.sol/ProxyFactory1967.dbg.json +1 -1
- package/artifacts/contracts/utils/ReputationTestHelper.sol/ReputationTestHelper.dbg.json +1 -1
- package/artifacts/contracts/utils/ReserveRestore.sol/ReserveRestore.dbg.json +1 -1
- package/artifacts/contracts/utils/ReserveRestore.sol/ReserveRestore.json +2 -2
- package/contracts/identity/IdentityV3.sol +0 -3
- package/contracts/identity/IdentityV4.sol +578 -0
- package/hardhat.config.ts +3 -4
- package/package.json +8 -4
- package/test/governance/ClaimersDistribution.test.ts +1 -1
- package/test/governance/CompoundVotingMachine.castvote.test.ts +30 -30
- package/test/helpers.ts +76 -195
- package/test/identity/IdentityV3.test.ts +53 -129
- package/test/identity/IdentityV4.test.ts +454 -0
- package/test/reserve/GenericDistributionHelper.e2e.test.ts +445 -0
- package/test/utils/AdminWallet.test.ts +14 -15
- package/types/contracts/identity/IdentityV4.ts +2001 -0
- package/types/contracts/identity/index.ts +1 -0
- package/types/contracts/utils/UpdateReserveRatio.sol/MentoExchange.ts +81 -0
- package/types/contracts/utils/UpdateReserveRatio.sol/UpdateReserveRatio.ts +134 -0
- package/types/contracts/utils/UpdateReserveRatio.sol/index.ts +5 -0
- package/types/contracts/utils/UpdateReserveRatioAfterXDC.sol/UpdateReserveRatioAfterXDC.ts +7 -2
- package/types/contracts/utils/index.ts +2 -2
- package/types/factories/contracts/governance/GoodDollarStaking.sol/GoodDollarStaking__factory.ts +1 -1
- package/types/factories/contracts/identity/IdentityV3__factory.ts +1 -1
- package/types/factories/contracts/identity/IdentityV4__factory.ts +1213 -0
- package/types/factories/contracts/identity/index.ts +1 -0
- package/types/factories/contracts/mocks/DistributionBridgeMock__factory.ts +1 -1
- package/types/factories/contracts/mocks/GoodDollarStakingMock__factory.ts +1 -1
- package/types/factories/contracts/mocks/MultichainRouterMock.sol/MultichainRouterMock__factory.ts +1 -1
- package/types/factories/contracts/mocks/StakingMockFixedAPY__factory.ts +1 -1
- package/types/factories/contracts/utils/LastauthReduction__factory.ts +1 -1
- package/types/factories/contracts/utils/ReserveRestore__factory.ts +1 -1
- package/types/factories/contracts/utils/UpdateReserveRatio.sol/MentoExchange__factory.ts +39 -0
- package/types/factories/contracts/utils/UpdateReserveRatio.sol/UpdateReserveRatio__factory.ts +113 -0
- package/types/factories/contracts/utils/UpdateReserveRatio.sol/index.ts +5 -0
- package/types/factories/contracts/utils/UpdateReserveRatioAfterXDC.sol/UpdateReserveRatioAfterXDC__factory.ts +9 -15
- package/types/factories/contracts/utils/index.ts +1 -1
- package/types/hardhat.d.ts +13 -4
- package/types/index.ts +4 -2
- package/scripts/ProxyFactory.json +0 -4425
- package/scripts/analytics/activeGDStakers.ts +0 -188
- package/scripts/analytics/activeStakers.ts +0 -25
- package/scripts/analytics/activeUsersCount.ts +0 -156
- package/scripts/analytics/activeWalletsStats.ts +0 -301
- package/scripts/analytics/checkActiveWallets.ts +0 -60
- package/scripts/analytics/checkBridgeBalances.ts +0 -442
- package/scripts/analytics/claimIncidentStats.ts +0 -98
- package/scripts/analytics/faucetStats.ts +0 -130
- package/scripts/analytics/gdinflow.ts +0 -57
- package/scripts/analytics/goodHolders.ts +0 -46
- package/scripts/analytics/goodgiveback.ts +0 -64
- package/scripts/analytics/p2pTxs.ts +0 -564
- package/scripts/analytics/stuckgd.ts +0 -70
- package/scripts/analytics/tokenInOutStats.ts +0 -48
- package/scripts/analytics/whitelistsyncIssue.ts +0 -87
- package/scripts/bulkProof.ts +0 -202
- package/scripts/bulkWhitelist.ts +0 -31
- package/scripts/deployGnosisSafe.ts +0 -111
- package/scripts/fetchOrDeployProxyFactory.ts +0 -46
- package/scripts/fv.ts +0 -263
- package/scripts/gdx/gdxAirdropCalculation.ts +0 -479
- package/scripts/getFounders.ts +0 -32
- package/scripts/governance/README.md +0 -70
- package/scripts/governance/airdropCalculation.ts +0 -1119
- package/scripts/governance/airdropCalculationRecover.ts +0 -416
- package/scripts/governance/airdropCalculationSorted.ts +0 -438
- package/scripts/governance/goodCheckpointSorted.ts +0 -300
- package/scripts/keeper/fishInactive.ts +0 -47
- package/scripts/minimize.sh +0 -17
- package/scripts/multichain-deploy/0_proxyFactory-deploy.ts +0 -131
- package/scripts/multichain-deploy/1_basicdao-deploy.ts +0 -294
- package/scripts/multichain-deploy/2_helpers-deploy.ts +0 -152
- package/scripts/multichain-deploy/2b_otp-deploy.ts +0 -73
- package/scripts/multichain-deploy/3_gdSavings-deploy.ts +0 -190
- package/scripts/multichain-deploy/4_ubi-deploy.ts +0 -129
- package/scripts/multichain-deploy/5_gov-deploy.ts +0 -179
- package/scripts/multichain-deploy/6_testnetFaucet.ts +0 -85
- package/scripts/multichain-deploy/7_superfluidfaucet-deploy.ts +0 -123
- package/scripts/multichain-deploy/8_disthelper-deploy.ts +0 -152
- package/scripts/multichain-deploy/createUniswapTestPools.ts +0 -163
- package/scripts/multichain-deploy/flattened/Avatar.sol +0 -913
- package/scripts/multichain-deploy/flattened/Controller.sol +0 -1891
- package/scripts/multichain-deploy/flattened/FeeFormula.sol +0 -1290
- package/scripts/multichain-deploy/fulldeploy.sh +0 -26
- package/scripts/multichain-deploy/helpers.ts +0 -647
- package/scripts/multichain-deploy/multichainWrapper-deploy.ts +0 -59
- package/scripts/multichain-deploy/verifyEtherscan.ts +0 -177
- package/scripts/proposals/gip-14_1.ts +0 -251
- package/scripts/proposals/gip-15.ts +0 -427
- package/scripts/proposals/gip-25-xdc-upgrade-ubi.ts +0 -746
- package/scripts/proposals/gips-14_1.md +0 -29
- package/scripts/proposals/hack-ubi-recovery.ts +0 -414
- package/scripts/proposals/identityAuthPeriod.ts +0 -229
- package/scripts/proposals/reserveRestore.ts +0 -474
- package/scripts/proposals/updateDistHelper.ts +0 -180
- package/scripts/proposals/v4Upgrade.ts +0 -845
- package/scripts/releaser.js +0 -24
- package/scripts/staking/stakersGdRewardsCalculation.ts +0 -64
- package/scripts/upgradeScheme.ts +0 -97
- package/scripts/upgradeToV2/upgradeToV2.ts +0 -853
- package/scripts/upgradeToV2/upgradeToV2Recover.ts +0 -939
- package/scripts/upgradeToV3/v3-fix.ts +0 -120
- package/scripts/upgradeToV3/v3-fuse-multichain.ts +0 -117
- package/scripts/upgradeToV3/v3-upgrade.ts +0 -219
- package/scripts/upgrades/celo-defi-ubi-deploy.ts +0 -184
- package/scripts/upgrades/identity-upgrade.ts +0 -126
- package/scripts/upgrades/multichain-formula-upgrade.ts +0 -143
- package/scripts/upgrades/multichain-temp-fix.ts +0 -129
- package/scripts/upgrades/restoreFunds.ts +0 -91
- package/scripts/upgrades/superfluid-nft-celo-gas-token.ts +0 -159
- package/scripts/upgrades/transferDaoToGuardians.ts +0 -80
- package/scripts/upgrades/upgradeAdminWallet.ts +0 -29
- package/scripts/upgrades/upgradeFaucet.ts +0 -46
- package/scripts/utils.ts +0 -50
- package/scripts/verify.ts +0 -67
- package/scripts/voltageswaps.ts +0 -46
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
/***
|
|
2
|
-
* Deploy helper contracts
|
|
3
|
-
* AdminWallet, Faucet, Invites
|
|
4
|
-
*/
|
|
5
|
-
import { network, ethers, upgrades, run } from "hardhat";
|
|
6
|
-
import { Contract } from "ethers";
|
|
7
|
-
import { defaultsDeep } from "lodash";
|
|
8
|
-
import { getImplementationAddress } from "@openzeppelin/upgrades-core";
|
|
9
|
-
import { deployDeterministic, verifyProductionSigner, verifyContract } from "./helpers";
|
|
10
|
-
import releaser from "../releaser";
|
|
11
|
-
import ProtocolSettings from "../../releases/deploy-settings.json";
|
|
12
|
-
import dao from "../../releases/deployment.json";
|
|
13
|
-
import { TransactionResponse } from "@ethersproject/providers";
|
|
14
|
-
import { SuperfluidFaucet } from "../../types";
|
|
15
|
-
|
|
16
|
-
const { name } = network;
|
|
17
|
-
|
|
18
|
-
const printDeploy = async (c: Contract | TransactionResponse): Promise<Contract | TransactionResponse> => {
|
|
19
|
-
if (c instanceof Contract) {
|
|
20
|
-
await c.deployed();
|
|
21
|
-
console.log("deployed to: ", c.address);
|
|
22
|
-
}
|
|
23
|
-
if (c.wait) {
|
|
24
|
-
await c.wait();
|
|
25
|
-
console.log("tx done:", c.hash);
|
|
26
|
-
}
|
|
27
|
-
return c;
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
export const deployHelpers = async () => {
|
|
31
|
-
let release: { [key: string]: any } = dao[network.name] || {};
|
|
32
|
-
|
|
33
|
-
let [root] = await ethers.getSigners();
|
|
34
|
-
const isProduction = network.name.includes("production");
|
|
35
|
-
|
|
36
|
-
if (isProduction) verifyProductionSigner(root);
|
|
37
|
-
|
|
38
|
-
//generic call permissions
|
|
39
|
-
let schemeMock = root;
|
|
40
|
-
|
|
41
|
-
console.log("got signers:", {
|
|
42
|
-
network,
|
|
43
|
-
root: root.address,
|
|
44
|
-
schemeMock: schemeMock.address,
|
|
45
|
-
balance: await ethers.provider.getBalance(root.address).then(_ => _.toString())
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
const walletAdmins = [];
|
|
49
|
-
for (let i = 0; i < 10; i++) {
|
|
50
|
-
const wallet = ethers.Wallet.fromMnemonic(process.env.ADMIN_WALLET_MNEMONIC, `m/44'/60'/0'/0/${i}`);
|
|
51
|
-
walletAdmins.push(wallet.address);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
const gasprice = 1e8;
|
|
55
|
-
console.log("deploying adminwallet", { walletAdmins });
|
|
56
|
-
const AdminWallet = release.AdminWallet
|
|
57
|
-
? await ethers.getContractAt("AdminWallet", release.AdminWallet)
|
|
58
|
-
: ((await deployDeterministic(
|
|
59
|
-
{
|
|
60
|
-
// address payable[] memory _admins,
|
|
61
|
-
// NameService _ns,
|
|
62
|
-
// address _owner,
|
|
63
|
-
// uint256 _gasPrice
|
|
64
|
-
name: "AdminWallet",
|
|
65
|
-
salt: "AdminWallet",
|
|
66
|
-
isUpgradeable: true
|
|
67
|
-
},
|
|
68
|
-
[walletAdmins, ethers.constants.AddressZero, root.address, gasprice]
|
|
69
|
-
).then(printDeploy)) as Contract);
|
|
70
|
-
|
|
71
|
-
const Faucet = release.SuperfluidFaucet
|
|
72
|
-
? await ethers.getContractAt("SuperfluidFaucet", release.SuperfluidFaucet)
|
|
73
|
-
: ((await upgrades
|
|
74
|
-
.deployProxy(
|
|
75
|
-
await ethers.getContractFactory("SuperfluidFaucet"),
|
|
76
|
-
[ethers.utils.parseEther("0.0000035"), 30, AdminWallet.address],
|
|
77
|
-
{ kind: "uups" }
|
|
78
|
-
)
|
|
79
|
-
.then(printDeploy)) as Contract);
|
|
80
|
-
|
|
81
|
-
const torelease = {
|
|
82
|
-
SuperfluidFaucet: Faucet.address,
|
|
83
|
-
AdminWallet: AdminWallet.address
|
|
84
|
-
};
|
|
85
|
-
await releaser(torelease, network.name, "deployment", false);
|
|
86
|
-
|
|
87
|
-
let impl = await getImplementationAddress(ethers.provider, AdminWallet.address);
|
|
88
|
-
await verifyContract(impl, "contracts/utils/AdminWallet.sol:AdminWallet", network.name);
|
|
89
|
-
impl = await getImplementationAddress(ethers.provider, Faucet.address);
|
|
90
|
-
await verifyContract(impl, "contracts/fuseFaucet/SuperfluidFaucet.sol:SuperfluidFaucet", network.name);
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
const upgrade = async () => {
|
|
94
|
-
let [root] = await ethers.getSigners();
|
|
95
|
-
const isProduction = network.name.includes("production");
|
|
96
|
-
|
|
97
|
-
if (isProduction) verifyProductionSigner(root);
|
|
98
|
-
|
|
99
|
-
//generic call permissions
|
|
100
|
-
let schemeMock = root;
|
|
101
|
-
|
|
102
|
-
console.log("got signers:", {
|
|
103
|
-
network,
|
|
104
|
-
root: root.address,
|
|
105
|
-
schemeMock: schemeMock.address,
|
|
106
|
-
balance: await ethers.provider.getBalance(root.address).then(_ => _.toString())
|
|
107
|
-
});
|
|
108
|
-
let release: { [key: string]: any } = dao[network.name] || {};
|
|
109
|
-
const proxy = (await ethers.getContractAt("SuperfluidFaucet", release.SuperfluidFaucet)) as SuperfluidFaucet;
|
|
110
|
-
const impl = await ethers.deployContract("SuperfluidFaucet");
|
|
111
|
-
console.log("impl:", impl.address);
|
|
112
|
-
// const callData = proxy.interface.encodeFunctionData("updateSettings", [ethers.utils.parseEther("0.0000035"), 30]);
|
|
113
|
-
// const tx = await proxy.upgradeToAndCall(impl.address, callData);
|
|
114
|
-
const tx = await proxy.upgradeTo(impl.address);
|
|
115
|
-
console.log(tx.hash);
|
|
116
|
-
const res = await tx.wait();
|
|
117
|
-
console.log(res.transactionHash);
|
|
118
|
-
};
|
|
119
|
-
export const main = async () => {
|
|
120
|
-
await upgrade();
|
|
121
|
-
// await deployHelpers();
|
|
122
|
-
};
|
|
123
|
-
if (process.argv[1].includes("7_superfluidfaucet")) main();
|
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
/***
|
|
2
|
-
* Deploy helper contracts
|
|
3
|
-
* AdminWallet, Faucet, Invites
|
|
4
|
-
*/
|
|
5
|
-
import { network, ethers, upgrades, run } from "hardhat";
|
|
6
|
-
import { Contract } from "ethers";
|
|
7
|
-
import { defaultsDeep } from "lodash";
|
|
8
|
-
import { getImplementationAddress } from "@openzeppelin/upgrades-core";
|
|
9
|
-
import {
|
|
10
|
-
deployDeterministic,
|
|
11
|
-
executeViaGuardian,
|
|
12
|
-
executeViaSafe,
|
|
13
|
-
verifyContract,
|
|
14
|
-
verifyProductionSigner
|
|
15
|
-
} from "./helpers";
|
|
16
|
-
import releaser from "../releaser";
|
|
17
|
-
import ProtocolSettings from "../../releases/deploy-settings.json";
|
|
18
|
-
import dao from "../../releases/deployment.json";
|
|
19
|
-
import { TransactionResponse } from "@ethersproject/providers";
|
|
20
|
-
import { keccak256, toUtf8Bytes } from "ethers/lib/utils";
|
|
21
|
-
|
|
22
|
-
const { name } = network;
|
|
23
|
-
|
|
24
|
-
const printDeploy = async (c: Contract | TransactionResponse): Promise<Contract | TransactionResponse> => {
|
|
25
|
-
if (c instanceof Contract) {
|
|
26
|
-
await c.deployed();
|
|
27
|
-
console.log("deployed to: ", c.address);
|
|
28
|
-
}
|
|
29
|
-
if (c.wait) {
|
|
30
|
-
await c.wait();
|
|
31
|
-
console.log("tx done:", c.hash);
|
|
32
|
-
}
|
|
33
|
-
return c;
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
export const deployHelpers = async () => {
|
|
37
|
-
const viaGuardians = false;
|
|
38
|
-
|
|
39
|
-
let protocolSettings = defaultsDeep({}, ProtocolSettings[network.name], ProtocolSettings["default"]);
|
|
40
|
-
let release: { [key: string]: any } = dao[network.name];
|
|
41
|
-
|
|
42
|
-
let [root, ...signers] = await ethers.getSigners();
|
|
43
|
-
const isProduction = network.name.includes("production");
|
|
44
|
-
let networkEnv = network.name.split("-")[0];
|
|
45
|
-
const celoNetwork = networkEnv + "-celo";
|
|
46
|
-
|
|
47
|
-
if (isProduction) verifyProductionSigner(root);
|
|
48
|
-
//generic call permissions
|
|
49
|
-
let schemeMock = root;
|
|
50
|
-
|
|
51
|
-
console.log("got signers:", {
|
|
52
|
-
network,
|
|
53
|
-
root: root.address,
|
|
54
|
-
schemeMock: schemeMock.address,
|
|
55
|
-
balance: await ethers.provider.getBalance(root.address).then(_ => _.toString())
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
console.log("deploying dist helper");
|
|
59
|
-
const DistHelper = (await deployDeterministic(
|
|
60
|
-
{
|
|
61
|
-
name: "DistributionHelper",
|
|
62
|
-
factory: await ethers.getContractFactory("GenericDistributionHelper"),
|
|
63
|
-
isUpgradeable: true
|
|
64
|
-
},
|
|
65
|
-
[
|
|
66
|
-
release.NameService,
|
|
67
|
-
release.StaticOracle,
|
|
68
|
-
protocolSettings.reserve.gasToken,
|
|
69
|
-
protocolSettings.reserve.reserveToken,
|
|
70
|
-
release.UniswapV3Router,
|
|
71
|
-
[ethers.utils.parseEther("100"), ethers.utils.parseEther("100"), 5, 5]
|
|
72
|
-
]
|
|
73
|
-
).then(printDeploy)) as Contract;
|
|
74
|
-
|
|
75
|
-
const torelease = {
|
|
76
|
-
DistributionHelper: DistHelper.address
|
|
77
|
-
};
|
|
78
|
-
release = {
|
|
79
|
-
...release,
|
|
80
|
-
...torelease
|
|
81
|
-
};
|
|
82
|
-
await releaser(torelease, network.name, "deployment", false);
|
|
83
|
-
|
|
84
|
-
console.log("setting nameservice addresses via guardian");
|
|
85
|
-
const proposalActions = [
|
|
86
|
-
[
|
|
87
|
-
release.NameService, //nameservice
|
|
88
|
-
"setAddresses(bytes32[],address[])", //add ubischeme
|
|
89
|
-
ethers.utils.defaultAbiCoder.encode(
|
|
90
|
-
["bytes32[]", "address[]"],
|
|
91
|
-
[[keccak256(toUtf8Bytes("DISTRIBUTION_HELPER"))], [DistHelper.address]]
|
|
92
|
-
),
|
|
93
|
-
0
|
|
94
|
-
],
|
|
95
|
-
[
|
|
96
|
-
DistHelper.address,
|
|
97
|
-
"addOrUpdateRecipient((uint32,uint32,address,uint8))",
|
|
98
|
-
ethers.utils.defaultAbiCoder.encode(
|
|
99
|
-
["uint32", "uint32", "address", "uint8"],
|
|
100
|
-
[dao[celoNetwork].CommunitySafe ? 9000 : 10000, network.config.chainId, release.UBIScheme, 1] //90% to ubi scheme
|
|
101
|
-
),
|
|
102
|
-
0
|
|
103
|
-
]
|
|
104
|
-
];
|
|
105
|
-
|
|
106
|
-
if (dao[celoNetwork].CommunitySafe) {
|
|
107
|
-
proposalActions.push([
|
|
108
|
-
DistHelper.address,
|
|
109
|
-
"addOrUpdateRecipient((uint32,uint32,address,uint8))",
|
|
110
|
-
ethers.utils.defaultAbiCoder.encode(
|
|
111
|
-
["uint32", "uint32", "address", "uint8"],
|
|
112
|
-
[1000, 42220, dao[celoNetwork].CommunitySafe, network.name === celoNetwork ? 1 : 0] //10% to celo community safe, use LZ bridge if not on celo
|
|
113
|
-
),
|
|
114
|
-
0
|
|
115
|
-
]);
|
|
116
|
-
}
|
|
117
|
-
const [proposalContracts, proposalFunctionSignatures, proposalFunctionInputs, proposalEthValues] = [
|
|
118
|
-
proposalActions.map(_ => _[0]),
|
|
119
|
-
proposalActions.map(_ => _[1]),
|
|
120
|
-
proposalActions.map(_ => _[2]),
|
|
121
|
-
proposalActions.map(_ => _[3])
|
|
122
|
-
];
|
|
123
|
-
try {
|
|
124
|
-
if (viaGuardians) {
|
|
125
|
-
await executeViaSafe(
|
|
126
|
-
proposalContracts,
|
|
127
|
-
proposalEthValues,
|
|
128
|
-
proposalFunctionSignatures,
|
|
129
|
-
proposalFunctionInputs,
|
|
130
|
-
protocolSettings.guardiansSafe
|
|
131
|
-
);
|
|
132
|
-
} else {
|
|
133
|
-
await executeViaGuardian(
|
|
134
|
-
proposalContracts,
|
|
135
|
-
proposalEthValues,
|
|
136
|
-
proposalFunctionSignatures,
|
|
137
|
-
proposalFunctionInputs,
|
|
138
|
-
root
|
|
139
|
-
);
|
|
140
|
-
}
|
|
141
|
-
} catch (e) {
|
|
142
|
-
console.error("proposal execution failed...", e.message);
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
let impl = await getImplementationAddress(ethers.provider, DistHelper.address);
|
|
146
|
-
await verifyContract(impl, "contracts/reserve/GenericDistributionHelper.sol:GenericDistributionHelper", network.name);
|
|
147
|
-
};
|
|
148
|
-
|
|
149
|
-
export const main = async (networkName = name) => {
|
|
150
|
-
await deployHelpers();
|
|
151
|
-
};
|
|
152
|
-
main();
|
|
@@ -1,163 +0,0 @@
|
|
|
1
|
-
import { network, ethers, upgrades, run } from "hardhat";
|
|
2
|
-
import ProtocolSettings from "../../releases/deploy-settings.json";
|
|
3
|
-
import dao from "../../releases/deployment.json";
|
|
4
|
-
import { defaultsDeep } from "lodash";
|
|
5
|
-
|
|
6
|
-
import { IUniswapV3Factory, IUniswapV3Pool, INonfungiblePositionManager, IERC20 } from "../../types";
|
|
7
|
-
const V3Factory = "0x30f317a9ec0f0d06d5de0f8d248ec3506b7e4a8a";
|
|
8
|
-
const NFPM = "0x6d22833398772d7da9a7cbcfdee98342cce154d4";
|
|
9
|
-
const STABLE_DECIMALS = 6; //USDC
|
|
10
|
-
const GASPRICE_STABLE = 0.08;
|
|
11
|
-
const POOL_FEE = 100; // 0.01%
|
|
12
|
-
const main = async () => {
|
|
13
|
-
let protocolSettings = defaultsDeep({}, ProtocolSettings[network.name], ProtocolSettings["default"]);
|
|
14
|
-
let release: { [key: string]: any } = dao[network.name];
|
|
15
|
-
let [root] = await ethers.getSigners();
|
|
16
|
-
console.log("got signers:", {
|
|
17
|
-
root: root.address,
|
|
18
|
-
balance: await ethers.provider.getBalance(root.address).then(_ => _.toString())
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
const v3Factory = (await ethers.getContractAt("IUniswapV3Factory", V3Factory)) as IUniswapV3Factory;
|
|
22
|
-
const nfpm = (await ethers.getContractAt("INonfungiblePositionManager", NFPM)) as INonfungiblePositionManager;
|
|
23
|
-
|
|
24
|
-
// create G$<>Stable pool
|
|
25
|
-
console.log("creating G$<>Stable pool", {
|
|
26
|
-
gd: release.GoodDollar,
|
|
27
|
-
stable: protocolSettings.reserve.reserveToken,
|
|
28
|
-
fee: POOL_FEE
|
|
29
|
-
});
|
|
30
|
-
const poolExists = await v3Factory.getPool(protocolSettings.reserve.reserveToken, release.GoodDollar, POOL_FEE);
|
|
31
|
-
if (poolExists !== ethers.constants.AddressZero) {
|
|
32
|
-
console.log("pool already exists at:", poolExists);
|
|
33
|
-
} else {
|
|
34
|
-
await (
|
|
35
|
-
await v3Factory.createPool(protocolSettings.reserve.reserveToken, release.GoodDollar, POOL_FEE, {
|
|
36
|
-
gasLimit: 5000000
|
|
37
|
-
})
|
|
38
|
-
).wait();
|
|
39
|
-
}
|
|
40
|
-
const gdstablePool = (await ethers.getContractAt(
|
|
41
|
-
"IUniswapV3Pool",
|
|
42
|
-
await v3Factory.getPool(release.GoodDollar, protocolSettings.reserve.reserveToken, POOL_FEE)
|
|
43
|
-
)) as IUniswapV3Pool;
|
|
44
|
-
|
|
45
|
-
//get pool price
|
|
46
|
-
const { sqrtPriceX96 } = await gdstablePool.slot0();
|
|
47
|
-
|
|
48
|
-
const existingPrice = (Number(sqrtPriceX96.toString()) / 2 ** 96) ** 2;
|
|
49
|
-
console.log("created pool at:", gdstablePool.address, { existingPrice });
|
|
50
|
-
let price = BigInt(Math.sqrt(10000 * (10 ** (18 - STABLE_DECIMALS))) * 2 ** 96); //1 G$ = 0.0001 Stable
|
|
51
|
-
let amount1 = ethers.utils.parseUnits("50000", 18);
|
|
52
|
-
let amount0 = ethers.utils.parseUnits("5", STABLE_DECIMALS);
|
|
53
|
-
|
|
54
|
-
if ((await gdstablePool.token0()).toLowerCase() === release.GoodDollar.toLowerCase()) {
|
|
55
|
-
price = BigInt(Math.sqrt(0.0001 * (10 ** (STABLE_DECIMALS - 18))) * 2 ** 96);
|
|
56
|
-
amount0 = ethers.utils.parseUnits("50000", 18);
|
|
57
|
-
amount1 = ethers.utils.parseUnits("5", STABLE_DECIMALS);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
if (existingPrice > 0) {
|
|
61
|
-
console.log("pool already initialized");
|
|
62
|
-
price = BigInt(Math.sqrt(existingPrice) * 2 ** 96); //1 G$ = 0.0001 Stable
|
|
63
|
-
} else {
|
|
64
|
-
await (await gdstablePool.initialize(price)).wait();
|
|
65
|
-
console.log("initialized pool with price:", price.toString(), { amount0, amount1 });
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
// print allowance for nfpm
|
|
69
|
-
const stable = (await ethers.getContractAt("IERC20", protocolSettings.reserve.reserveToken)) as IERC20;
|
|
70
|
-
const gd = (await ethers.getContractAt("IERC20", release.GoodDollar)) as IERC20;
|
|
71
|
-
let stableAllowance = await stable.allowance(root.address, NFPM);
|
|
72
|
-
const gdAllowance = await gd.allowance(root.address, NFPM);
|
|
73
|
-
console.log("stable allowance for NFPM:", ethers.utils.formatUnits(stableAllowance, STABLE_DECIMALS));
|
|
74
|
-
console.log("G$ allowance for NFPM:", ethers.utils.formatUnits(gdAllowance, 18));
|
|
75
|
-
|
|
76
|
-
await (
|
|
77
|
-
await nfpm.mint({
|
|
78
|
-
token0: await gdstablePool.token0(),
|
|
79
|
-
token1: await gdstablePool.token1(),
|
|
80
|
-
fee: POOL_FEE,
|
|
81
|
-
tickLower: -887220,
|
|
82
|
-
tickUpper: 887220,
|
|
83
|
-
amount0Desired: amount0,
|
|
84
|
-
amount1Desired: amount1,
|
|
85
|
-
amount0Min: amount0.mul(8).div(10),
|
|
86
|
-
amount1Min: amount1.mul(8).div(10),
|
|
87
|
-
recipient: root.address,
|
|
88
|
-
deadline: Math.floor(Date.now() / 1000) + 60 * 10
|
|
89
|
-
})
|
|
90
|
-
).wait();
|
|
91
|
-
|
|
92
|
-
console.log("creating gastoken<>Stable pool", {
|
|
93
|
-
gasToken: protocolSettings.reserve.gasToken,
|
|
94
|
-
stable: protocolSettings.reserve.reserveToken,
|
|
95
|
-
fee: POOL_FEE
|
|
96
|
-
});
|
|
97
|
-
const gaspoolExists = await v3Factory.getPool(
|
|
98
|
-
protocolSettings.reserve.gasToken,
|
|
99
|
-
protocolSettings.reserve.reserveToken,
|
|
100
|
-
POOL_FEE
|
|
101
|
-
);
|
|
102
|
-
if (gaspoolExists !== ethers.constants.AddressZero) {
|
|
103
|
-
console.log("pool already exists at:", gaspoolExists);
|
|
104
|
-
} else {
|
|
105
|
-
await (
|
|
106
|
-
await v3Factory.createPool(protocolSettings.reserve.gasToken, protocolSettings.reserve.reserveToken, POOL_FEE, {
|
|
107
|
-
gasLimit: 5000000
|
|
108
|
-
})
|
|
109
|
-
).wait();
|
|
110
|
-
}
|
|
111
|
-
const gasstablePool = (await ethers.getContractAt(
|
|
112
|
-
"IUniswapV3Pool",
|
|
113
|
-
await v3Factory.getPool(protocolSettings.reserve.gasToken, protocolSettings.reserve.reserveToken, POOL_FEE)
|
|
114
|
-
)) as IUniswapV3Pool;
|
|
115
|
-
|
|
116
|
-
//get pool price
|
|
117
|
-
const { sqrtPriceX96: gasSqrtPriceX96 } = await gasstablePool.slot0();
|
|
118
|
-
|
|
119
|
-
const gasexistingPrice = (Number(gasSqrtPriceX96.toString()) / 2 ** 96) ** 2;
|
|
120
|
-
console.log("created pool at:", gasstablePool.address, { gasexistingPrice });
|
|
121
|
-
price = BigInt(Math.sqrt(GASPRICE_STABLE * (10 ** (18 - STABLE_DECIMALS))) * 2 ** 96); //1 G$ = 0.0001 Stable
|
|
122
|
-
amount1 = ethers.utils.parseUnits((5 / GASPRICE_STABLE).toString(), 18);
|
|
123
|
-
amount0 = ethers.utils.parseUnits("5", STABLE_DECIMALS);
|
|
124
|
-
|
|
125
|
-
if ((await gasstablePool.token0()).toLowerCase() === protocolSettings.reserve.gasToken.toLowerCase()) {
|
|
126
|
-
price = BigInt(Math.sqrt(1 / GASPRICE_STABLE / (10 ** (18 - STABLE_DECIMALS))) * 2 ** 96);
|
|
127
|
-
let temp = amount0;
|
|
128
|
-
amount0 = amount1;
|
|
129
|
-
amount1 = temp;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
if (gasexistingPrice > 0) {
|
|
133
|
-
console.log("pool already initialized");
|
|
134
|
-
price = BigInt(Math.sqrt(gasexistingPrice) * 2 ** 96); //1 G$ = 0.0001 Stable
|
|
135
|
-
} else {
|
|
136
|
-
await (await gasstablePool.initialize(price)).wait();
|
|
137
|
-
console.log("initialized pool with price:", price.toString(), { amount0, amount1 });
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
// print allowance for nfpm
|
|
141
|
-
const gasToken = (await ethers.getContractAt("IERC20", protocolSettings.reserve.gasToken)) as IERC20;
|
|
142
|
-
stableAllowance = await stable.allowance(root.address, NFPM);
|
|
143
|
-
const gasAllowance = await gasToken.allowance(root.address, NFPM);
|
|
144
|
-
console.log("stable allowance for NFPM:", ethers.utils.formatUnits(stableAllowance, STABLE_DECIMALS));
|
|
145
|
-
console.log("weth allowance for NFPM:", ethers.utils.formatUnits(gasAllowance, 18));
|
|
146
|
-
|
|
147
|
-
await (
|
|
148
|
-
await nfpm.mint({
|
|
149
|
-
token0: await gasstablePool.token0(),
|
|
150
|
-
token1: await gasstablePool.token1(),
|
|
151
|
-
fee: POOL_FEE,
|
|
152
|
-
tickLower: -887220,
|
|
153
|
-
tickUpper: 887220,
|
|
154
|
-
amount0Desired: amount0,
|
|
155
|
-
amount1Desired: amount1,
|
|
156
|
-
amount0Min: amount0.mul(8).div(10),
|
|
157
|
-
amount1Min: amount1.mul(8).div(10),
|
|
158
|
-
recipient: root.address,
|
|
159
|
-
deadline: Math.floor(Date.now() / 1000) + 60 * 10
|
|
160
|
-
})
|
|
161
|
-
).wait();
|
|
162
|
-
};
|
|
163
|
-
main();
|