@gooddollar/goodprotocol 2.0.25-beta.8 → 2.0.25
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/artifacts/abis/AdminWallet.min.json +1 -1
- package/artifacts/abis/CompoundVotingMachine.min.json +1 -1
- package/artifacts/abis/DistributionHelper.min.json +1 -1
- package/artifacts/abis/DistributionHelperTest.min.json +1 -1
- package/artifacts/abis/DistributionHelperTestHelper.min.json +1 -1
- package/artifacts/abis/EternalStorage.min.json +1 -0
- package/artifacts/abis/FuseOldBridgeKill.min.json +1 -0
- package/artifacts/abis/GoodFundManager.min.json +1 -1
- package/artifacts/abis/GoodFundManagerTest.min.json +1 -1
- package/artifacts/abis/GoodMarketMaker.min.json +1 -1
- package/artifacts/abis/GoodReserveCDai.min.json +1 -1
- package/artifacts/abis/IQuoterV2.min.json +1 -1
- package/artifacts/abis/ISwapRouter.min.json +1 -1
- package/artifacts/abis/IUpgradeabilityOwnerStorage.min.json +1 -0
- package/artifacts/abis/Initializable.min.json +1 -0
- package/artifacts/abis/LastauthReduction.min.json +1 -0
- package/artifacts/abis/Ownable.min.json +1 -0
- package/artifacts/abis/ReserveRestore.min.json +1 -0
- package/artifacts/abis/SuperfluidFaucet.min.json +1 -0
- package/artifacts/abis/Upgradeable.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/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 +4 -0
- package/artifacts/contracts/{utils/BuyGDClone.sol → Interfaces.sol}/IQuoterV2.json +1 -1
- package/artifacts/contracts/Interfaces.sol/ISwapRouter.dbg.json +4 -0
- package/artifacts/contracts/{utils/BuyGDClone.sol → Interfaces.sol}/ISwapRouter.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/fuseFaucet/Faucet.sol/Faucet.dbg.json +1 -1
- package/artifacts/contracts/fuseFaucet/Faucet.sol/Faucet.json +2 -2
- package/artifacts/contracts/fuseFaucet/FuseFaucet.sol/FuseFaucet.dbg.json +1 -1
- package/artifacts/contracts/fuseFaucet/FuseFaucet.sol/FuseFaucet.json +2 -2
- package/artifacts/contracts/fuseFaucet/FuseFaucetV2.sol/FuseFaucetV2.dbg.json +1 -1
- package/artifacts/contracts/fuseFaucet/FuseFaucetV2.sol/FuseFaucetV2.json +2 -2
- package/artifacts/contracts/fuseFaucet/SuperfluidFacuet.sol/SuperfluidFaucet.dbg.json +4 -0
- package/artifacts/contracts/fuseFaucet/SuperfluidFacuet.sol/SuperfluidFaucet.json +531 -0
- package/artifacts/contracts/governance/ClaimersDistribution.sol/ClaimersDistribution.dbg.json +1 -1
- package/artifacts/contracts/governance/ClaimersDistribution.sol/ClaimersDistribution.json +2 -2
- package/artifacts/contracts/governance/CompoundVotingMachine.sol/CompoundVotingMachine.dbg.json +1 -1
- package/artifacts/contracts/governance/CompoundVotingMachine.sol/CompoundVotingMachine.json +20 -2
- package/artifacts/contracts/governance/GReputation.sol/GReputation.dbg.json +1 -1
- package/artifacts/contracts/governance/GReputation.sol/GReputation.json +2 -2
- 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/GovernanceStaking.sol/GovernanceStaking.json +2 -2
- 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/Reputation.sol/Reputation.json +2 -2
- package/artifacts/contracts/governance/StakersDistribution.sol/StakersDistribution.dbg.json +1 -1
- package/artifacts/contracts/governance/StakersDistribution.sol/StakersDistribution.json +2 -2
- package/artifacts/contracts/identity/IdentityV2.sol/IdentityV2.dbg.json +1 -1
- package/artifacts/contracts/identity/IdentityV2.sol/IdentityV2.json +2 -2
- package/artifacts/contracts/invite/InvitesFuseV2.sol/InvitesFuseV2.dbg.json +1 -1
- package/artifacts/contracts/invite/InvitesFuseV2.sol/InvitesFuseV2.json +2 -2
- package/artifacts/contracts/invite/InvitesV1.sol/InvitesV1.dbg.json +1 -1
- package/artifacts/contracts/invite/InvitesV1.sol/InvitesV1.json +2 -2
- package/artifacts/contracts/invite/InvitesV2.sol/InvitesV2.dbg.json +1 -1
- package/artifacts/contracts/invite/InvitesV2.sol/InvitesV2.json +2 -2
- package/artifacts/contracts/invite/OneTimeReward.sol/OneTimeReward.dbg.json +1 -1
- package/artifacts/contracts/invite/OneTimeReward.sol/OneTimeReward.json +2 -2
- 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/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/DistributionHelperTest.json +21 -2
- package/artifacts/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTestHelper.dbg.json +1 -1
- package/artifacts/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTestHelper.json +21 -2
- 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/GoodCompoundStakingTest.sol/GoodCompoundStakingTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/GoodCompoundStakingTest.sol/GoodCompoundStakingTest.json +2 -2
- 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/GoodFundManagerTest.sol/GoodFundManagerTest.json +21 -2
- package/artifacts/contracts/mocks/IdentityMock.sol/IdentityMock.dbg.json +1 -1
- package/artifacts/contracts/mocks/IdentityMock.sol/IdentityMock.json +2 -2
- 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/OverMintTester.sol/OverMintTester.json +2 -2
- package/artifacts/contracts/mocks/OverMintTesterRegularStake.sol/OverMintTesterRegularStake.dbg.json +1 -1
- package/artifacts/contracts/mocks/OverMintTesterRegularStake.sol/OverMintTesterRegularStake.json +2 -2
- 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/SwapHelperTest.sol/SwapHelperTest.dbg.json +1 -1
- package/artifacts/contracts/mocks/SwapHelperTest.sol/SwapHelperTest.json +2 -2
- 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/UpgradableMock.json +2 -2
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock2.dbg.json +1 -1
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock2.json +2 -2
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock3.dbg.json +1 -1
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock3.json +2 -2
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock4.dbg.json +1 -1
- package/artifacts/contracts/mocks/UpgradableMocks.sol/UpgradableMock4.json +2 -2
- 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/DistributionHelper.sol/DistributionHelper.dbg.json +1 -1
- package/artifacts/contracts/reserve/DistributionHelper.sol/DistributionHelper.json +21 -2
- package/artifacts/contracts/reserve/ExchangeHelper.sol/ExchangeHelper.dbg.json +1 -1
- package/artifacts/contracts/reserve/ExchangeHelper.sol/ExchangeHelper.json +2 -2
- package/artifacts/contracts/reserve/GoodMarketMaker.sol/GoodMarketMaker.dbg.json +1 -1
- package/artifacts/contracts/reserve/GoodMarketMaker.sol/GoodMarketMaker.json +6 -6
- 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/reserve/GoodReserveCDai.sol/GoodReserveCDai.json +3 -3
- package/artifacts/contracts/staking/BaseShareField.sol/BaseShareField.dbg.json +1 -1
- package/artifacts/contracts/staking/BaseShareField.sol/BaseShareField.json +2 -2
- package/artifacts/contracts/staking/BaseShareFieldV2.sol/BaseShareFieldV2.dbg.json +1 -1
- package/artifacts/contracts/staking/BaseShareFieldV2.sol/BaseShareFieldV2.json +2 -2
- package/artifacts/contracts/staking/DonationsStaking.sol/DonationsStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/DonationsStaking.sol/DonationsStaking.json +2 -2
- package/artifacts/contracts/staking/FuseStakingV3.sol/FuseStakingV3.dbg.json +1 -1
- package/artifacts/contracts/staking/FuseStakingV3.sol/FuseStakingV3.json +2 -2
- 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/GoodFundManager.sol/GoodFundManager.json +21 -2
- 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/UniswapV2SwapHelper.sol/UniswapV2SwapHelper.json +2 -2
- package/artifacts/contracts/staking/aave/AaveStakingFactory.sol/AaveStakingFactory.dbg.json +1 -1
- package/artifacts/contracts/staking/aave/AaveStakingFactory.sol/AaveStakingFactory.json +2 -2
- package/artifacts/contracts/staking/aave/GoodAaveStaking.sol/GoodAaveStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/aave/GoodAaveStaking.sol/GoodAaveStaking.json +2 -2
- package/artifacts/contracts/staking/aave/GoodAaveStakingV2.sol/GoodAaveStakingV2.dbg.json +1 -1
- package/artifacts/contracts/staking/aave/GoodAaveStakingV2.sol/GoodAaveStakingV2.json +2 -2
- package/artifacts/contracts/staking/compound/CompoundStakingFactory.sol/CompoundStakingFactory.dbg.json +1 -1
- package/artifacts/contracts/staking/compound/CompoundStakingFactory.sol/CompoundStakingFactory.json +2 -2
- package/artifacts/contracts/staking/compound/GoodCompoundStaking.sol/GoodCompoundStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/compound/GoodCompoundStaking.sol/GoodCompoundStaking.json +2 -2
- package/artifacts/contracts/staking/compound/GoodCompoundStakingV2.sol/GoodCompoundStakingV2.dbg.json +1 -1
- package/artifacts/contracts/staking/compound/GoodCompoundStakingV2.sol/GoodCompoundStakingV2.json +2 -2
- 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/GoodDollar.sol/GoodDollar.json +2 -2
- 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/SuperGoodDollar.sol/SuperGoodDollar.json +2 -2
- 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/UBIScheme.sol/UBIScheme.json +2 -2
- package/artifacts/contracts/ubi/UBISchemeV2.sol/UBISchemeV2.dbg.json +1 -1
- package/artifacts/contracts/ubi/UBISchemeV2.sol/UBISchemeV2.json +2 -2
- package/artifacts/contracts/utils/AdminWallet.sol/AdminWallet.dbg.json +1 -1
- package/artifacts/contracts/utils/AdminWallet.sol/AdminWallet.json +2 -22
- package/artifacts/contracts/utils/AdminWalletFuse.sol/AdminWalletFuse.dbg.json +1 -1
- package/artifacts/contracts/utils/AdminWalletFuse.sol/AdminWalletFuse.json +2 -2
- 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/BulkProof.sol/BulkProof.json +2 -2
- package/artifacts/contracts/utils/BulkWhitelist.sol/BulkWhitelist.dbg.json +1 -1
- package/artifacts/contracts/utils/BulkWhitelist.sol/BulkWhitelist.json +2 -2
- package/artifacts/contracts/utils/BuyAndBridgeHelper.sol/BuyAndBridgeHelper.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyAndBridgeHelper.sol/BuyAndBridgeHelper.json +2 -2
- package/artifacts/contracts/utils/BuyGDClone.sol/BuyGDClone.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyGDClone.sol/BuyGDClone.json +2 -2
- package/artifacts/contracts/utils/BuyGDClone.sol/BuyGDCloneFactory.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyGDClone.sol/BuyGDCloneFactory.json +2 -2
- package/artifacts/contracts/utils/BuyGDClone.sol/DonateGDClone.dbg.json +1 -1
- package/artifacts/contracts/utils/BuyGDClone.sol/DonateGDClone.json +2 -2
- package/artifacts/contracts/utils/DAOContract.sol/DAOContract.dbg.json +1 -1
- package/artifacts/contracts/utils/DAOContract.sol/DAOContract.json +2 -2
- package/artifacts/contracts/utils/DAOUpgradeableContract.sol/DAOUpgradeableContract.dbg.json +1 -1
- package/artifacts/contracts/utils/DAOUpgradeableContract.sol/DAOUpgradeableContract.json +2 -2
- 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 +4 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/EternalStorage.json +10 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/FuseOldBridgeKill.dbg.json +4 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/FuseOldBridgeKill.json +31 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/IUpgradeabilityOwnerStorage.dbg.json +4 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/IUpgradeabilityOwnerStorage.json +24 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Initializable.dbg.json +4 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Initializable.json +24 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Ownable.dbg.json +4 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Ownable.json +56 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Upgradeable.dbg.json +4 -0
- package/artifacts/contracts/utils/FuseOldBridgeKill.sol/Upgradeable.json +10 -0
- package/artifacts/contracts/utils/GDFaucet.sol/GDFaucet.dbg.json +1 -1
- package/artifacts/contracts/utils/GDFaucet.sol/GDFaucet.json +2 -2
- package/artifacts/contracts/utils/GoodDollarMintBurnWrapper.sol/GoodDollarMintBurnWrapper.dbg.json +1 -1
- package/artifacts/contracts/utils/GoodDollarMintBurnWrapper.sol/GoodDollarMintBurnWrapper.json +2 -2
- 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/GoodDollarMintBurnWrapper.sol/TokenOperation.json +2 -2
- package/artifacts/contracts/utils/IdentityFix.sol/IdentityFix.dbg.json +1 -1
- package/artifacts/contracts/utils/IdentityFix.sol/IdentityFix.json +2 -2
- package/artifacts/contracts/utils/LastauthReduction.sol/LastauthReduction.dbg.json +4 -0
- package/artifacts/contracts/utils/LastauthReduction.sol/LastauthReduction.json +81 -0
- 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/MultichainBridgeHelper.sol/MultichainBridgeHelper.json +2 -2
- 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/OneTimePayments.sol/OneTimePayments.json +2 -2
- package/artifacts/contracts/utils/OneTimePaymentsV2.sol/OneTimePaymentsV2.dbg.json +1 -1
- package/artifacts/contracts/utils/OneTimePaymentsV2.sol/OneTimePaymentsV2.json +2 -2
- 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/ProtocolUpgrade.sol/ProtocolUpgrade.json +2 -2
- package/artifacts/contracts/utils/ProtocolUpgradeFuse.sol/ProtocolUpgradeFuse.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgradeFuse.sol/ProtocolUpgradeFuse.json +2 -2
- package/artifacts/contracts/utils/ProtocolUpgradeFuseRecover.sol/ProtocolUpgradeFuseRecover.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgradeFuseRecover.sol/ProtocolUpgradeFuseRecover.json +2 -2
- package/artifacts/contracts/utils/ProtocolUpgradeRecover.sol/ProtocolUpgradeRecover.dbg.json +1 -1
- package/artifacts/contracts/utils/ProtocolUpgradeRecover.sol/ProtocolUpgradeRecover.json +2 -2
- 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/ReputationTestHelper.sol/ReputationTestHelper.json +2 -2
- package/artifacts/contracts/utils/ReserveRestore.sol/ReserveRestore.dbg.json +4 -0
- package/artifacts/contracts/utils/ReserveRestore.sol/ReserveRestore.json +91 -0
- package/contracts/Interfaces.sol +122 -0
- package/contracts/fuseFaucet/SuperfluidFacuet.sol +127 -0
- package/contracts/governance/CompoundVotingMachine.sol +26 -11
- package/contracts/governance/StakersDistribution.sol +13 -13
- package/contracts/reserve/DistributionHelper.sol +29 -10
- package/contracts/reserve/ExchangeHelper.sol +16 -7
- package/contracts/reserve/GoodMarketMaker.sol +43 -53
- package/contracts/reserve/GoodReserveCDai.sol +44 -16
- package/contracts/staking/GoodFundManager.sol +44 -4
- package/contracts/utils/AdminWallet.sol +4 -6
- package/contracts/utils/BuyGDClone.sol +0 -122
- package/contracts/utils/FuseOldBridgeKill.sol +123 -0
- package/contracts/utils/LastauthReduction.sol +92 -0
- package/contracts/utils/ReserveRestore.sol +157 -0
- package/dist/artifacts/contracts/identity/IdentityV2.sol/IdentityV2.json +2 -2
- package/dist/artifacts/contracts/token/superfluid/SuperGoodDollar.sol/SuperGoodDollar.json +2 -2
- package/hardhat.config.ts +21 -39
- package/package.json +17 -19
- package/releases/deployment.json +78 -7
- package/scripts/analytics/activeStakers.ts +25 -0
- package/scripts/analytics/activeUsersCount.ts +80 -26
- package/scripts/analytics/activeWalletsStats.ts +138 -18
- package/scripts/fv.ts +7 -5
- package/scripts/multichain-deploy/0_proxyFactory-deploy.ts +20 -15
- package/scripts/multichain-deploy/7_superfluidfaucet-deploy.ts +96 -0
- package/scripts/multichain-deploy/helpers.ts +8 -8
- package/scripts/proposals/identityAuthPeriod.ts +229 -0
- package/scripts/proposals/reserveRestore.ts +429 -0
- package/scripts/test/localOldDaoDeploy.ts +2 -1
- package/scripts/utils.ts +14 -1
- package/test/governance/CompoundVotingMachine.daoscheme.ts +3 -0
- package/test/governance/CompoundVotingMachine.guardian.test.ts +76 -21
- package/test/governance/CompoundVotingMachine.state.test.ts +31 -28
- package/test/governance/StakersDistribution.test.ts +79 -5
- package/test/helpers.ts +7 -0
- package/test/reserve/DistributionHelper.test.ts +10 -10
- package/test/reserve/GoodMarketMaker.test.ts +75 -26
- package/test/staking/StakingRewards.test.ts +106 -29
- package/test/utils/ProtocolUpgrade.test.ts +1 -0
- package/types/contracts/{utils/BuyGDClone.sol → Interfaces.sol}/IQuoterV2.ts +1 -1
- package/types/contracts/{utils/BuyGDClone.sol → Interfaces.sol}/ISwapRouter.ts +1 -1
- package/types/contracts/Interfaces.sol/index.ts +2 -0
- package/types/contracts/fuseFaucet/SuperfluidFacuet.sol/SuperfluidFaucet.ts +862 -0
- package/types/contracts/fuseFaucet/SuperfluidFacuet.sol/index.ts +4 -0
- package/types/contracts/fuseFaucet/index.ts +2 -0
- package/types/contracts/governance/CompoundVotingMachine.ts +44 -3
- package/types/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTest.ts +35 -0
- package/types/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTestHelper.ts +35 -0
- package/types/contracts/mocks/GoodFundManagerTest.ts +35 -0
- package/types/contracts/reserve/DistributionHelper.ts +35 -0
- package/types/contracts/reserve/GoodMarketMaker.ts +3 -3
- package/types/contracts/reserve/GoodReserveCDai.sol/GoodReserveCDai.ts +5 -5
- package/types/contracts/staking/GoodFundManager.ts +35 -0
- package/types/contracts/utils/AdminWallet.ts +0 -34
- package/types/contracts/utils/BuyGDClone.sol/index.ts +0 -2
- package/types/contracts/utils/FuseOldBridgeKill.sol/FuseOldBridgeKill.ts +108 -0
- package/types/contracts/utils/FuseOldBridgeKill.sol/IUpgradeabilityOwnerStorage.ts +89 -0
- package/types/contracts/utils/FuseOldBridgeKill.sol/Initializable.ts +87 -0
- package/types/contracts/utils/FuseOldBridgeKill.sol/Ownable.ts +148 -0
- package/types/contracts/utils/FuseOldBridgeKill.sol/index.ts +7 -0
- package/types/contracts/utils/LastauthReduction.ts +168 -0
- package/types/contracts/utils/ReserveRestore.ts +201 -0
- package/types/contracts/utils/index.ts +4 -0
- package/types/factories/contracts/{utils/BuyGDClone.sol → Interfaces.sol}/IQuoterV2__factory.ts +1 -1
- package/types/factories/contracts/{utils/BuyGDClone.sol → Interfaces.sol}/ISwapRouter__factory.ts +1 -1
- package/types/factories/contracts/Interfaces.sol/index.ts +2 -0
- package/types/factories/contracts/fuseFaucet/Faucet__factory.ts +1 -1
- package/types/factories/contracts/fuseFaucet/FuseFaucetV2__factory.ts +1 -1
- package/types/factories/contracts/fuseFaucet/FuseFaucet__factory.ts +1 -1
- package/types/factories/contracts/fuseFaucet/SuperfluidFacuet.sol/SuperfluidFaucet__factory.ts +582 -0
- package/types/factories/contracts/fuseFaucet/SuperfluidFacuet.sol/index.ts +4 -0
- package/types/factories/contracts/fuseFaucet/index.ts +1 -0
- package/types/factories/contracts/governance/ClaimersDistribution__factory.ts +1 -1
- package/types/factories/contracts/governance/CompoundVotingMachine__factory.ts +19 -1
- package/types/factories/contracts/governance/GReputation__factory.ts +1 -1
- package/types/factories/contracts/governance/GoodDollarStaking.sol/GoodDollarStaking__factory.ts +1 -1
- package/types/factories/contracts/governance/GovernanceStaking__factory.ts +1 -1
- package/types/factories/contracts/governance/Reputation__factory.ts +1 -1
- package/types/factories/contracts/governance/StakersDistribution__factory.ts +1 -1
- package/types/factories/contracts/identity/IdentityV2__factory.ts +1 -1
- package/types/factories/contracts/invite/InvitesFuseV2__factory.ts +1 -1
- package/types/factories/contracts/invite/InvitesV1__factory.ts +1 -1
- package/types/factories/contracts/invite/InvitesV2__factory.ts +1 -1
- package/types/factories/contracts/invite/OneTimeReward__factory.ts +1 -1
- package/types/factories/contracts/mocks/DistributionBridgeMock__factory.ts +1 -1
- package/types/factories/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTestHelper__factory.ts +20 -1
- package/types/factories/contracts/mocks/DistributionHelperTest.sol/DistributionHelperTest__factory.ts +20 -1
- package/types/factories/contracts/mocks/GoodCompoundStakingTest__factory.ts +1 -1
- package/types/factories/contracts/mocks/GoodDollarStakingMock__factory.ts +1 -1
- package/types/factories/contracts/mocks/GoodFundManagerTest__factory.ts +20 -1
- package/types/factories/contracts/mocks/IdentityMock__factory.ts +1 -1
- package/types/factories/contracts/mocks/MultichainRouterMock.sol/MultichainRouterMock__factory.ts +1 -1
- package/types/factories/contracts/mocks/OverMintTester.sol/OverMintTester__factory.ts +1 -1
- package/types/factories/contracts/mocks/OverMintTesterRegularStake__factory.ts +1 -1
- package/types/factories/contracts/mocks/SwapHelperTest__factory.ts +1 -1
- package/types/factories/contracts/mocks/UpgradableMocks.sol/UpgradableMock2__factory.ts +1 -1
- package/types/factories/contracts/mocks/UpgradableMocks.sol/UpgradableMock3__factory.ts +1 -1
- package/types/factories/contracts/mocks/UpgradableMocks.sol/UpgradableMock4__factory.ts +1 -1
- package/types/factories/contracts/mocks/UpgradableMocks.sol/UpgradableMock__factory.ts +1 -1
- package/types/factories/contracts/reserve/DistributionHelper__factory.ts +20 -1
- package/types/factories/contracts/reserve/ExchangeHelper__factory.ts +1 -1
- package/types/factories/contracts/reserve/GoodMarketMaker__factory.ts +5 -5
- package/types/factories/contracts/reserve/GoodReserveCDai.sol/GoodReserveCDai__factory.ts +2 -2
- package/types/factories/contracts/staking/BaseShareFieldV2__factory.ts +1 -1
- package/types/factories/contracts/staking/BaseShareField__factory.ts +1 -1
- package/types/factories/contracts/staking/DonationsStaking__factory.ts +1 -1
- package/types/factories/contracts/staking/FuseStakingV3.sol/FuseStakingV3__factory.ts +1 -1
- package/types/factories/contracts/staking/GoodFundManager__factory.ts +20 -1
- package/types/factories/contracts/staking/UniswapV2SwapHelper__factory.ts +1 -1
- package/types/factories/contracts/staking/aave/AaveStakingFactory__factory.ts +1 -1
- package/types/factories/contracts/staking/aave/GoodAaveStakingV2__factory.ts +1 -1
- package/types/factories/contracts/staking/aave/GoodAaveStaking__factory.ts +1 -1
- package/types/factories/contracts/staking/compound/CompoundStakingFactory__factory.ts +1 -1
- package/types/factories/contracts/staking/compound/GoodCompoundStakingV2__factory.ts +1 -1
- package/types/factories/contracts/staking/compound/GoodCompoundStaking__factory.ts +1 -1
- package/types/factories/contracts/token/GoodDollar__factory.ts +1 -1
- package/types/factories/contracts/token/superfluid/SuperGoodDollar__factory.ts +1 -1
- package/types/factories/contracts/ubi/UBISchemeV2__factory.ts +1 -1
- package/types/factories/contracts/ubi/UBIScheme__factory.ts +1 -1
- package/types/factories/contracts/utils/AdminWalletFuse__factory.ts +1 -1
- package/types/factories/contracts/utils/AdminWallet__factory.ts +1 -21
- package/types/factories/contracts/utils/BulkWhitelist__factory.ts +1 -1
- package/types/factories/contracts/utils/BuyAndBridgeHelper__factory.ts +1 -1
- package/types/factories/contracts/utils/BuyGDClone.sol/BuyGDCloneFactory__factory.ts +1 -1
- package/types/factories/contracts/utils/BuyGDClone.sol/BuyGDClone__factory.ts +1 -1
- package/types/factories/contracts/utils/BuyGDClone.sol/DonateGDClone__factory.ts +1 -1
- package/types/factories/contracts/utils/BuyGDClone.sol/index.ts +0 -2
- package/types/factories/contracts/utils/DAOContract__factory.ts +1 -1
- package/types/factories/contracts/utils/DAOUpgradeableContract__factory.ts +1 -1
- package/types/factories/contracts/utils/FuseOldBridgeKill.sol/FuseOldBridgeKill__factory.ts +82 -0
- package/types/factories/contracts/utils/FuseOldBridgeKill.sol/IUpgradeabilityOwnerStorage__factory.ts +43 -0
- package/types/factories/contracts/utils/FuseOldBridgeKill.sol/Initializable__factory.ts +75 -0
- package/types/factories/contracts/utils/FuseOldBridgeKill.sol/Ownable__factory.ts +105 -0
- package/types/factories/contracts/utils/FuseOldBridgeKill.sol/index.ts +7 -0
- package/types/factories/contracts/utils/GDFaucet__factory.ts +1 -1
- package/types/factories/contracts/utils/GoodDollarMintBurnWrapper.sol/GoodDollarMintBurnWrapper__factory.ts +1 -1
- package/types/factories/contracts/utils/IdentityFix__factory.ts +1 -1
- package/types/factories/contracts/utils/LastauthReduction__factory.ts +134 -0
- package/types/factories/contracts/utils/MultichainBridgeHelper__factory.ts +1 -1
- package/types/factories/contracts/utils/OneTimePaymentsV2__factory.ts +1 -1
- package/types/factories/contracts/utils/OneTimePayments__factory.ts +1 -1
- package/types/factories/contracts/utils/ProtocolUpgrade.sol/ProtocolUpgrade__factory.ts +1 -1
- package/types/factories/contracts/utils/ProtocolUpgradeFuseRecover__factory.ts +1 -1
- package/types/factories/contracts/utils/ProtocolUpgradeFuse__factory.ts +1 -1
- package/types/factories/contracts/utils/ProtocolUpgradeRecover__factory.ts +1 -1
- package/types/factories/contracts/utils/ReputationTestHelper__factory.ts +1 -1
- package/types/factories/contracts/utils/ReserveRestore__factory.ts +144 -0
- package/types/factories/contracts/utils/index.ts +3 -0
- package/types/hardhat.d.ts +79 -16
- package/types/index.ts +14 -4
- package/artifacts/contracts/utils/BuyGDClone.sol/IQuoterV2.dbg.json +0 -4
- package/artifacts/contracts/utils/BuyGDClone.sol/ISwapRouter.dbg.json +0 -4
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@gooddollar/goodprotocol",
|
|
3
|
-
"version": "2.0.25
|
|
3
|
+
"version": "2.0.25",
|
|
4
4
|
"description": "GoodDollar Protocol",
|
|
5
5
|
"engines": {
|
|
6
6
|
"node": ">=16.x"
|
|
@@ -61,22 +61,6 @@
|
|
|
61
61
|
"url": "https://github.com/GoodDollar/GoodProtocol/issues"
|
|
62
62
|
},
|
|
63
63
|
"homepage": "https://gooddollar.org",
|
|
64
|
-
"dependencies": {
|
|
65
|
-
"@gooddollar/goodcontracts": "^2.6.6",
|
|
66
|
-
"@jsier/retrier": "^1.2.4",
|
|
67
|
-
"@openzeppelin/contracts": "^4.8.0",
|
|
68
|
-
"@openzeppelin/contracts-upgradeable": "^4.8.0",
|
|
69
|
-
"@openzeppelin/hardhat-upgrades": "^1.22.1",
|
|
70
|
-
"@superfluid-finance/ethereum-contracts": "^1.8.1",
|
|
71
|
-
"@superfluid-finance/sdk-core": "^0.5.8",
|
|
72
|
-
"@typechain/hardhat": "^6.1.5",
|
|
73
|
-
"async-promise-pool": "^1.0.4",
|
|
74
|
-
"openzeppelin-solidity": "^4.3.2",
|
|
75
|
-
"patch-package": "latest",
|
|
76
|
-
"press-any-key": "^0.1.1",
|
|
77
|
-
"truffle-plugin-verify": "^0.6.1",
|
|
78
|
-
"truffle-source-verify": "^0.0.6"
|
|
79
|
-
},
|
|
80
64
|
"devDependencies": {
|
|
81
65
|
"@babel/core": "*",
|
|
82
66
|
"@babel/polyfill": "*",
|
|
@@ -88,19 +72,28 @@
|
|
|
88
72
|
"@gnosis.pm/safe-ethers-lib": "^1.7.0",
|
|
89
73
|
"@gnosis.pm/safe-service-client": "^1.4.0",
|
|
90
74
|
"@gooddollar/bridge-contracts": "1.0.14-beta.7",
|
|
75
|
+
"@gooddollar/goodcontracts": "^2.6.6",
|
|
76
|
+
"@jsier/retrier": "^1.2.4",
|
|
91
77
|
"@mean-finance/uniswap-v3-oracle": "^1.0.3",
|
|
92
78
|
"@nomicfoundation/hardhat-chai-matchers": "1",
|
|
93
79
|
"@nomicfoundation/hardhat-network-helpers": "^1.0.8",
|
|
94
80
|
"@nomicfoundation/hardhat-verify": "^2.0.1",
|
|
95
81
|
"@nomiclabs/hardhat-ethers": "^2.2.1",
|
|
96
82
|
"@nomiclabs/hardhat-waffle": "^2.0.6",
|
|
83
|
+
"@openzeppelin/contracts": "^4.8.0",
|
|
84
|
+
"@openzeppelin/contracts-upgradeable": "^4.8.0",
|
|
85
|
+
"@openzeppelin/hardhat-upgrades": "^1.22.1",
|
|
86
|
+
"@superfluid-finance/ethereum-contracts": "^1.8.1",
|
|
87
|
+
"@superfluid-finance/sdk-core": "^0.5.8",
|
|
97
88
|
"@swc/core": "1.3.96",
|
|
98
89
|
"@swc/helpers": "^0.3.16",
|
|
99
90
|
"@typechain/ethers-v5": "^11.1.1",
|
|
91
|
+
"@typechain/hardhat": "^6.1.5",
|
|
100
92
|
"@types/mocha": "*",
|
|
101
93
|
"@types/node": "*",
|
|
102
94
|
"@uniswap/v2-core": "*",
|
|
103
95
|
"@uniswap/v2-periphery": "^1.1.0-beta.0",
|
|
96
|
+
"async-promise-pool": "^1.0.4",
|
|
104
97
|
"bignumber.js": "*",
|
|
105
98
|
"bindings": "*",
|
|
106
99
|
"chai": "*",
|
|
@@ -114,7 +107,7 @@
|
|
|
114
107
|
"fs-extra": "9.0.0",
|
|
115
108
|
"graphql": "^15.5.0",
|
|
116
109
|
"graphql-request": "^3.4.0",
|
|
117
|
-
"hardhat": "^2
|
|
110
|
+
"hardhat": "^2.*",
|
|
118
111
|
"hardhat-contract-sizer": "^2.6.1",
|
|
119
112
|
"hardhat-gas-reporter": "^1.0.8",
|
|
120
113
|
"hardhat-storage-layout": "^0.1.7",
|
|
@@ -124,18 +117,23 @@
|
|
|
124
117
|
"mocha-lcov-reporter": "*",
|
|
125
118
|
"node-fetch": "*",
|
|
126
119
|
"node-jq": "*",
|
|
120
|
+
"openzeppelin-solidity": "^4.3.2",
|
|
121
|
+
"patch-package": "latest",
|
|
122
|
+
"press-any-key": "^0.1.1",
|
|
127
123
|
"prompt": "^1.3.0",
|
|
128
124
|
"regenerator-runtime": "^0.13.9",
|
|
129
125
|
"solhint": "*",
|
|
130
126
|
"solidity-coverage": "^0.8.4",
|
|
131
127
|
"truffle": "^5.11.5",
|
|
132
128
|
"truffle-hdwallet-provider": "*",
|
|
129
|
+
"truffle-plugin-verify": "^0.6.1",
|
|
130
|
+
"truffle-source-verify": "^0.0.6",
|
|
133
131
|
"ts-generator": "^0.1.1",
|
|
134
132
|
"ts-node": "^10.9.1",
|
|
135
133
|
"typechain": "^8.3.1",
|
|
136
134
|
"typescript": "^5.3.3"
|
|
137
135
|
},
|
|
138
|
-
"packageManager": "yarn@3.6.
|
|
136
|
+
"packageManager": "yarn@3.6.1",
|
|
139
137
|
"resolutions": {
|
|
140
138
|
"@swc/core": "1.3.96"
|
|
141
139
|
},
|
package/releases/deployment.json
CHANGED
|
@@ -434,11 +434,10 @@
|
|
|
434
434
|
"StaticOracle": "0x00851A91a3c4E9a4c1B48df827Bacc1f884bdE28",
|
|
435
435
|
"BuyGDFactory": "0x00e533B7d6255D05b7f15034B1c989c21F51b91C",
|
|
436
436
|
"BuyGDFactoryV2": "0x1F60C4C7037C6766924A43666B781ED1479587a2",
|
|
437
|
+
"CUSD": "0x765DE816845861e75A25fCA122bb6898B8B1282a",
|
|
437
438
|
"BulkWhitelist": "0x30Afd0534dAA29135308d048103b40dc1BA4518d"
|
|
438
439
|
},
|
|
439
|
-
"gnosis": {
|
|
440
|
-
"GuardiansSafe": "0x84c10b45fe51bfb4f86c19a47fdbc187d4572fb8"
|
|
441
|
-
},
|
|
440
|
+
"gnosis": { "GuardiansSafe": "0x84c10b45fe51bfb4f86c19a47fdbc187d4572fb8" },
|
|
442
441
|
"development-celo": {
|
|
443
442
|
"network": "development-celo",
|
|
444
443
|
"networkId": 42220,
|
|
@@ -464,7 +463,13 @@
|
|
|
464
463
|
"OneTimePaymentsV2": "0x2cb1c7d50371e277d7a36B171c0ACe9B157518EE",
|
|
465
464
|
"UniswapV3Router": "0x5615CDAb10dc425a742d643d949a7F474C01abc4",
|
|
466
465
|
"BuyGDFactory": "0x00e533B7d6255D05b7f15034B1c989c21F51b91C",
|
|
467
|
-
"BuyGDFactoryV2": "0x1F60C4C7037C6766924A43666B781ED1479587a2"
|
|
466
|
+
"BuyGDFactoryV2": "0x1F60C4C7037C6766924A43666B781ED1479587a2",
|
|
467
|
+
"MentoExchangeProvider": "0x02C5e6FfeC49Dca92af50A0718d2c4944DAaCb05",
|
|
468
|
+
"MentoExpansionController": "0xA354fE15A08318912D594E94DC7622C7D23Bb11A",
|
|
469
|
+
"CUSD": "0x2FFc031e855fE7C36669DC95CE00356D52195999",
|
|
470
|
+
"MentoReserve": "0x3f13b9FdB9ca8CDDa1c1E125296C8101B170C37C",
|
|
471
|
+
"MentoBroker": "0x43bC03995090E7B4E74cE70deF6bfA27D62049dC",
|
|
472
|
+
"CeloDistributionHelper": "0x4FE2400B80376a34e6a9011988d9D0D921EEf059"
|
|
468
473
|
},
|
|
469
474
|
"staging-celo": {
|
|
470
475
|
"network": "staging-celo",
|
|
@@ -491,7 +496,13 @@
|
|
|
491
496
|
"OneTimePaymentsV2": "0x963E7B4c970626Bb103c61fA16b002AFf6E6c2C7",
|
|
492
497
|
"UniswapV3Router": "0x5615CDAb10dc425a742d643d949a7F474C01abc4",
|
|
493
498
|
"BuyGDFactory": "0x00e533B7d6255D05b7f15034B1c989c21F51b91C",
|
|
494
|
-
"BuyGDFactoryV2": "0x1F60C4C7037C6766924A43666B781ED1479587a2"
|
|
499
|
+
"BuyGDFactoryV2": "0x1F60C4C7037C6766924A43666B781ED1479587a2",
|
|
500
|
+
"MentoExchangeProvider": "0x02C5e6FfeC49Dca92af50A0718d2c4944DAaCb05",
|
|
501
|
+
"MentoExpansionController": "0xA354fE15A08318912D594E94DC7622C7D23Bb11A",
|
|
502
|
+
"CUSD": "0x2FFc031e855fE7C36669DC95CE00356D52195999",
|
|
503
|
+
"MentoReserve": "0x3f13b9FdB9ca8CDDa1c1E125296C8101B170C37C",
|
|
504
|
+
"MentoBroker": "0x43bC03995090E7B4E74cE70deF6bfA27D62049dC",
|
|
505
|
+
"CeloDistributionHelper": "0x4FE2400B80376a34e6a9011988d9D0D921EEf059"
|
|
495
506
|
},
|
|
496
507
|
"development-goerli": {
|
|
497
508
|
"ProxyFactory": "0x65D8eACBCd9618b8780C4b444081915a5D54D611",
|
|
@@ -541,7 +552,67 @@
|
|
|
541
552
|
"GoodDollarMintBurnWrapper": "0x69d9c8d240E282a4ec0058CF0AC4E9D8ac7a11ac",
|
|
542
553
|
"GoodDollarStaking": "0xC9a3DdadC753e6a7675Aa125991096623d06c437"
|
|
543
554
|
},
|
|
544
|
-
"development-mainnet": {
|
|
545
|
-
|
|
555
|
+
"development-mainnet": { "networkId": 1 },
|
|
556
|
+
"test": {
|
|
557
|
+
"ProxyFactory": "0xCd7c00Ac6dc51e8dCc773971Ac9221cC582F3b1b",
|
|
558
|
+
"NameService": "0xB3d91a2650C8dB4456e96e06Bb147799338c5739",
|
|
559
|
+
"GReputation": "0xD759c30ADea571d35159302515b81473f7F0B5b3",
|
|
560
|
+
"CompoundVotingMachine": "0x07d17EcCcEE4568DE2b40cD1CB99b9984DF4519c",
|
|
561
|
+
"ClaimersDistribution": "0xA6D3dC26fC2f258d06B54EB6634077835C3C73Aa",
|
|
562
|
+
"GovernanceStaking": "0xA9e6Bfa2BF53dE88FEb19761D9b2eE2e821bF1Bf",
|
|
563
|
+
"UBIScheme": "0x16d5EF010758a483f94F3A001DeFf0ac9efF6352",
|
|
564
|
+
"ProtocolUpgradeFuse": "0x286B8DecD5ED79c962b2d8F4346CD97FF0E2C352",
|
|
565
|
+
"network": "test",
|
|
566
|
+
"networkId": 4447,
|
|
567
|
+
"HomeBridge": "0xcE0066b1008237625dDDBE4a751827de037E53D2",
|
|
568
|
+
"OneTimePayments": "0xcC4c41415fc68B2fBf70102742A83cDe435e0Ca7",
|
|
569
|
+
"AdminWallet": "0xAe120F0df055428E45b264E7794A18c54a2a3fAF",
|
|
570
|
+
"Identity": "0x87006e75a5B6bE9D1bbF61AC8Cd84f05D9140589",
|
|
571
|
+
"GoodDollar": "0x609a4341d11C29F8F5cDeF00931AdB96f76EF017",
|
|
572
|
+
"Controller": "0xd1f8C3b3C9C63a7a7f0dCFd20ae9053A04182db1",
|
|
573
|
+
"Avatar": "0xcafCfdF4517F504a473469F3723e674413EE9bce",
|
|
574
|
+
"FirstClaimPool": "0x0aec7c174554AF8aEc3680BB58431F6618311510",
|
|
575
|
+
"BancorFormula": "0x7B4f352Cd40114f12e82fC675b5BA8C7582FC513",
|
|
576
|
+
"DAI": "0xD6b040736e948621c5b6E0a494473c47a6113eA8",
|
|
577
|
+
"cDAI": "0xAdE429ba898c34722e722415D722A70a297cE3a2",
|
|
578
|
+
"COMP": "0x139e1D41943ee15dDe4DF876f9d0E7F85e26660A"
|
|
579
|
+
},
|
|
580
|
+
"test-mainnet": {
|
|
581
|
+
"ProxyFactory": "0x70E5370b8981Abc6e14C91F4AcE823954EFC8eA3",
|
|
582
|
+
"NameService": "0x50f2b544FD7af66D8a9dCF9a8d28F60c4955468D",
|
|
583
|
+
"GReputation": "0x08BC83e7cfe7DfEacAbCdC2432Cc6281ee678B46",
|
|
584
|
+
"CompoundVotingMachine": "0x6B2A2eA3b4965B2069f7112DFc5e766b10f52Bf4",
|
|
585
|
+
"GoodMarketMaker": "0x6E16fE6B78F307d78142A65CdFc3fB1c01Ed5416",
|
|
586
|
+
"GoodReserveCDai": "0xEF4c7EAD8C1aE06E76BD792785c9bed03811173B",
|
|
587
|
+
"ExchangeHelper": "0x39acC72200A9a847c2B6EFe514Db9eeE429e4B29",
|
|
588
|
+
"GoodFundManager": "0x68CC3Dc71a215bbbbc5fFeD38bc92F12d56eA835",
|
|
589
|
+
"StakersDistribution": "0x3957892fB94Ef52aB441e2BA77777F9dC8F7C501",
|
|
590
|
+
"ProtocolUpgrade": "0xa62835D1A6bf5f521C4e2746E1F51c923b8f3483",
|
|
591
|
+
"UniswapV2SwapHelper": "0x8E45C0936fa1a65bDaD3222bEFeC6a03C83372cE",
|
|
592
|
+
"CompoundStakingFactory": "0xBEe6FFc1E8627F51CcDF0b4399a1e1abc5165f15",
|
|
593
|
+
"AaveStakingFactory": "0xC32609C91d6B6b51D48f2611308FEf121B02041f",
|
|
594
|
+
"StakingContracts": [
|
|
595
|
+
["0x14aA87DEed1d13012F1C9C93ef660D88a594D289", 13888],
|
|
596
|
+
["0x47c7D4b2A310E651f846d7E8717F44414F59a7Da", "6944"]
|
|
597
|
+
],
|
|
598
|
+
"DonationsStaking": "0x0Af313Cb7928CC29Db382575b0d96969C00414EC",
|
|
599
|
+
"network": "test-mainnet",
|
|
600
|
+
"networkId": 4447,
|
|
601
|
+
"ForeignBridge": "0x02b0B4EFd909240FCB2Eb5FAe060dC60D112E3a4",
|
|
602
|
+
"Contribution": "0x40a42Baf86Fc821f972Ad2aC878729063CeEF403",
|
|
603
|
+
"Identity": "0x6C2d83262fF84cBaDb3e416D527403135D757892",
|
|
604
|
+
"GoodDollar": "0xDda88b7dF7C04D319c41B53305Cd443B1f975e29",
|
|
605
|
+
"Controller": "0xF2AdAad89d56D49C697B9907C7D66ef27d96f859",
|
|
606
|
+
"Avatar": "0xd1891dD9DFF0784baa1dEb361dDFCAa5aE49cc6F",
|
|
607
|
+
"FirstClaimPool": "0xA56F946D6398Dd7d9D4D9B337Cf9E0F68982ca5B",
|
|
608
|
+
"BancorFormula": "0x01c1DeF3b91672704716159C9041Aeca392DdFfb",
|
|
609
|
+
"DAI": "0xfcDB4564c18A9134002b9771816092C9693622e3",
|
|
610
|
+
"cDAI": "0x32EEce76C2C2e8758584A83Ee2F522D4788feA0f",
|
|
611
|
+
"COMP": "0x927b167526bAbB9be047421db732C663a0b77B11"
|
|
612
|
+
},
|
|
613
|
+
"development-base": {
|
|
614
|
+
"ProxyFactory": "0x5B22F5623ECB00E288539346F389E05f65e226ae",
|
|
615
|
+
"SuperfluidFaucet": "0x88d18B06E55b33B94578628fcB5a6e1D198b0e73",
|
|
616
|
+
"AdminWallet": "0x6672C998C49635aA6825Be355fF2e731f417B674"
|
|
546
617
|
}
|
|
547
618
|
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { uniq } from "lodash";
|
|
2
|
+
import fs from "fs";
|
|
3
|
+
import { network, ethers } from "hardhat";
|
|
4
|
+
import { Contract, Provider, setMulticallAddress } from "ethers-multicall";
|
|
5
|
+
import release from "../../releases/deployment.json"
|
|
6
|
+
import { SimpleStakingV2 } from "../../types";
|
|
7
|
+
|
|
8
|
+
setMulticallAddress(122, "0x3CE6158b7278Bf6792e014FA7B4f3c6c46fe9410");
|
|
9
|
+
|
|
10
|
+
setMulticallAddress(42220, "0x188C1bf697B66474dC3eaa119Ae691a8352537e3");
|
|
11
|
+
|
|
12
|
+
const main = async () => {
|
|
13
|
+
|
|
14
|
+
const c1 = await ethers.getContractAt("SimpleStakingV2", release["production-mainnet"].StakingContractsV3[0][0]) as SimpleStakingV2
|
|
15
|
+
const c2 = await ethers.getContractAt("SimpleStakingV2", release["production-mainnet"].StakingContractsV3[1][0]) as SimpleStakingV2
|
|
16
|
+
const f = c1.filters.Staked()
|
|
17
|
+
const events = await c1.queryFilter(f, 14338550)
|
|
18
|
+
const events2 = await c2.queryFilter(f, 14338550)
|
|
19
|
+
const stakers = uniq(events.concat(events2).map(_ => _.args[0]))
|
|
20
|
+
console.log(stakers)
|
|
21
|
+
const res = (await Promise.all(stakers.map(async s => [s, await c1.balanceOf(s), await c2.balanceOf(s)]))).filter(_ => _[1].gt(0) || _[2].gt(0))
|
|
22
|
+
console.log(events.length)
|
|
23
|
+
console.log(res)
|
|
24
|
+
}
|
|
25
|
+
main()
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
import { range, chunk, uniq } from "lodash";
|
|
2
|
-
import { ethers as Ethers } from "hardhat";
|
|
1
|
+
import { range, chunk, uniq, mapValues, groupBy } from "lodash";
|
|
2
|
+
import { ethers, ethers as Ethers } from "hardhat";
|
|
3
|
+
import fs from "fs";
|
|
4
|
+
import { bulkGetLastAuth } from "../utils";
|
|
3
5
|
|
|
4
6
|
const ONE_DAY = 24 * 60 * 60;
|
|
5
7
|
const ONE_HOUR = 60 * 60;
|
|
@@ -19,28 +21,27 @@ const main = async () => {
|
|
|
19
21
|
for (let day of daysAgo) {
|
|
20
22
|
const query = `
|
|
21
23
|
{
|
|
22
|
-
walletStats(first:1000, where: { lastClaimed_lte: ${curDay},lastClaimed_gt: ${
|
|
23
|
-
|
|
24
|
-
} isActiveUser: true }) {
|
|
24
|
+
walletStats(first:1000, where: { lastClaimed_lte: ${curDay},lastClaimed_gt: ${curDay - ONE_DAY
|
|
25
|
+
} isActiveUser: true }) {
|
|
25
26
|
id
|
|
26
27
|
}
|
|
27
28
|
}
|
|
28
29
|
`;
|
|
29
30
|
|
|
30
31
|
console.log("fetching inactive users since:", { curDay, day }, JSON.stringify({ query }));
|
|
31
|
-
const {
|
|
32
|
-
data: { walletStats }
|
|
33
|
-
} = await fetch("https://api.thegraph.com/subgraphs/name/gooddollar/gooddollarfuse", {
|
|
32
|
+
const result = await fetch("https://api.thegraph.com/subgraphs/name/gooddollar/gooddollarfuse", {
|
|
34
33
|
method: "post",
|
|
35
34
|
body: JSON.stringify({ query }),
|
|
36
35
|
headers: { "Content-Type": "application/json" }
|
|
37
36
|
}).then(_ => _.json());
|
|
38
37
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
38
|
+
|
|
39
|
+
console.log("got inactive wallets:", result);
|
|
40
|
+
// if (walletStats) {
|
|
41
|
+
// const accounts = walletStats.map(_ => _.id);
|
|
42
|
+
// allActive.push(...accounts);
|
|
43
|
+
// }
|
|
44
|
+
|
|
44
45
|
// for (let tofish of chunk(accounts, 50)) {
|
|
45
46
|
// const tx = await ubiScheme.fishMulti(tofish, { gasLimit: 2000000 });
|
|
46
47
|
// console.log("fishing tx:", tx, tofish);
|
|
@@ -54,32 +55,83 @@ const main = async () => {
|
|
|
54
55
|
console.log("active claimers:", unique.length);
|
|
55
56
|
};
|
|
56
57
|
|
|
58
|
+
const countClaimersUsingExplorer = async () => {
|
|
59
|
+
let claimers = [] //JSON.parse(fs.readFileSync("claimers.json").toString())
|
|
60
|
+
const curBlock = await ethers.provider.getBlockNumber()
|
|
61
|
+
const DAYS = 1
|
|
62
|
+
let fromBlock = curBlock - 60 * 60 * 24 * DAYS / 5 //roughly DAYS of blocks
|
|
63
|
+
const querySize = 90// 15 min of blocks
|
|
64
|
+
const blockRanges = range(fromBlock, curBlock, querySize)
|
|
65
|
+
const chunks = chunk(blockRanges, 10)
|
|
66
|
+
for (let idx in chunks) {
|
|
67
|
+
const toFetch = chunks[idx]
|
|
68
|
+
const ps = toFetch.map(async fromBlock => {
|
|
69
|
+
let toBlock = fromBlock + querySize
|
|
70
|
+
toBlock = toBlock > curBlock ? curBlock : toBlock
|
|
71
|
+
const result = await fetch(`https://explorer.celo.org/mainnet/api?module=logs&action=getLogs&fromBlock=${fromBlock}&toBlock=${toBlock}&address=0x43d72ff17701b2da814620735c39c620ce0ea4a1&topic0=0x89ed24731df6b066e4c5186901fffdba18cd9a10f07494aff900bdee260d1304`).then(_ => _.json())
|
|
72
|
+
fromBlock = toBlock
|
|
73
|
+
const addrs = result.result.map(_ => ethers.utils.defaultAbiCoder.decode(["address"], _.topics[1])[0])
|
|
74
|
+
claimers.push(...addrs);
|
|
75
|
+
console.log("claimers:", addrs.length, "block range:", { fromBlock, toBlock }, addrs[0])
|
|
76
|
+
})
|
|
77
|
+
await Promise.all(ps)
|
|
78
|
+
console.log(`${idx} out of ${chunks.length}`)
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
claimers = uniq(claimers)
|
|
82
|
+
fs.writeFileSync("claimers.json", JSON.stringify(claimers))
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
const countLastWhitelisted = async () => {
|
|
86
|
+
const claimers = JSON.parse(fs.readFileSync("claimers.json").toString())
|
|
87
|
+
const DAY = 60 * 60 * 24
|
|
88
|
+
let total = 0
|
|
89
|
+
let howOld = []
|
|
90
|
+
console.log("unique claimers:", claimers.length)
|
|
91
|
+
for (let bulk of chunk(claimers, 1000)) {
|
|
92
|
+
const results = await bulkGetLastAuth(bulk)
|
|
93
|
+
const older = results.filter(_ => _.toNumber() < Date.now() / 1000 - DAY * 180).length
|
|
94
|
+
bulk.forEach((_, i) => howOld.push([_, Math.ceil((Date.now() / 1000 - DAY * 180 - results[i].toNumber()) / (30 * DAY)).toFixed(0)]))
|
|
95
|
+
console.log(older, "out of", results.length)
|
|
96
|
+
total += older
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
howOld = howOld.filter(_ => Number(_[1]) > 0)
|
|
100
|
+
console.log({ total })
|
|
101
|
+
howOld = mapValues(groupBy(howOld, _ => _[1]), _ => _.length)
|
|
102
|
+
console.log(howOld)
|
|
103
|
+
}
|
|
104
|
+
|
|
57
105
|
const countActive = async () => {
|
|
58
|
-
const twoWeeksAgo = parseInt((Date.now() / 1000).toFixed(0)); //
|
|
59
106
|
|
|
60
|
-
const hoursAgo: number[] = range(0, 24 *
|
|
61
|
-
let curDay =
|
|
107
|
+
const hoursAgo: number[] = range(0, 24 * 30, 1);
|
|
108
|
+
let curDay = parseInt((Date.now() / 1000).toFixed(0));
|
|
62
109
|
const allActive = [];
|
|
63
110
|
for (let hour of hoursAgo) {
|
|
64
111
|
const query = `
|
|
65
112
|
{
|
|
66
|
-
walletStats(first:1000, where: { lastClaimed_lte: ${curDay},lastClaimed_gt: ${
|
|
67
|
-
|
|
68
|
-
} isActiveUser: true }) {
|
|
113
|
+
walletStats(first:1000, where: { lastClaimed_lte: ${curDay},lastClaimed_gt: ${curDay - ONE_HOUR
|
|
114
|
+
} isActiveUser: true }) {
|
|
69
115
|
id
|
|
70
116
|
}
|
|
71
117
|
}
|
|
72
118
|
`;
|
|
73
119
|
|
|
74
120
|
console.log("fetching active users since:", { curDay, hour }, JSON.stringify({ query }));
|
|
121
|
+
const result =
|
|
122
|
+
|
|
123
|
+
await fetch("https://gateway-arbitrum.network.thegraph.com/api/3c409250a317ce7b0c6a7a8b9a409ef8/subgraphs/id/F7314rxGdcpKPC1nN5KCoFW84EGRoUyzseY2sAT9PEkw", {
|
|
124
|
+
// await fetch("https://gateway.thegraph.com/api/3c409250a317ce7b0c6a7a8b9a409ef8/subgraphs/id/5cAhhzm7LSqGiFibV1odbbgZWiRmZsYjYrmaoj87UxFd", {
|
|
125
|
+
method: "post",
|
|
126
|
+
body: JSON.stringify({ query }),
|
|
127
|
+
headers: { "Content-Type": "application/json", "origin": "https://wallet.gooddollar.org" }
|
|
128
|
+
|
|
129
|
+
}).then(_ => _.json());
|
|
130
|
+
|
|
131
|
+
console.log(result)
|
|
75
132
|
const {
|
|
76
133
|
data: { walletStats }
|
|
77
|
-
} =
|
|
78
|
-
method: "post",
|
|
79
|
-
body: JSON.stringify({ query }),
|
|
80
|
-
headers: { "Content-Type": "application/json" }
|
|
81
|
-
}).then(_ => _.json());
|
|
82
|
-
|
|
134
|
+
} = result
|
|
83
135
|
console.log("got active wallets:", walletStats.length);
|
|
84
136
|
if (walletStats) {
|
|
85
137
|
const accounts = walletStats.map(_ => _.id);
|
|
@@ -99,4 +151,6 @@ const countActive = async () => {
|
|
|
99
151
|
};
|
|
100
152
|
|
|
101
153
|
//main();
|
|
102
|
-
countActive();
|
|
154
|
+
// countActive();
|
|
155
|
+
// countClaimersUsingExplorer()
|
|
156
|
+
countLastWhitelisted()
|
|
@@ -1,24 +1,88 @@
|
|
|
1
|
-
import { maxBy, range, sortBy } from "lodash";
|
|
1
|
+
import { maxBy, range, sortBy, flatten } from "lodash";
|
|
2
2
|
import PromisePool from "async-promise-pool";
|
|
3
3
|
import fs from "fs";
|
|
4
4
|
import { ethers } from "hardhat";
|
|
5
5
|
|
|
6
|
+
const today = new Date().toLocaleDateString().replace(/\//g, "");
|
|
7
|
+
console.log({ today });
|
|
6
8
|
/****
|
|
7
9
|
* Fetch token holders and their last activity date
|
|
8
10
|
* can be used to create stats about active users and how much G$ isnt active
|
|
9
11
|
*/
|
|
10
12
|
const main = async (chain = "fuse") => {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
+
let result = [];
|
|
14
|
+
let balances = {};
|
|
15
|
+
let curPage = 1;
|
|
16
|
+
let maxResult;
|
|
17
|
+
const fuseExplorer = "https://explorer.fuse.io/api";
|
|
18
|
+
const celoExplorer = "https://explorer.celo.org/mainnet/api";
|
|
19
|
+
const fuseSubgraph =
|
|
20
|
+
"https://gateway.thegraph.com/api/9048669a7632776aae01a191c4939445/subgraphs/id/5cAhhzm7LSqGiFibV1odbbgZWiRmZsYjYrmaoj87UxFd";
|
|
21
|
+
const celoSubgraph =
|
|
22
|
+
"https://gateway.thegraph.com/api/9048669a7632776aae01a191c4939445/subgraphs/id/F7314rxGdcpKPC1nN5KCoFW84EGRoUyzseY2sAT9PEkw";
|
|
23
|
+
do {
|
|
24
|
+
const pages = range(curPage, curPage + 5, 1);
|
|
25
|
+
curPage += 5;
|
|
26
|
+
const ps = pages.map(p =>
|
|
27
|
+
fetch(
|
|
28
|
+
`${fuseExplorer}?module=token&action=getTokenHolders&contractaddress=0x495d133B938596C9984d462F007B676bDc57eCEC&page=${p}&offset=10000`
|
|
29
|
+
)
|
|
30
|
+
.then(_ => _.json())
|
|
31
|
+
.then(_ => _.result)
|
|
32
|
+
);
|
|
33
|
+
const results = await Promise.all(ps);
|
|
34
|
+
result = result.concat(...results);
|
|
35
|
+
maxResult = maxBy(results, "length");
|
|
36
|
+
console.log(maxResult.length, result.length);
|
|
37
|
+
} while (maxResult.length === 10000);
|
|
38
|
+
result.forEach(
|
|
39
|
+
r =>
|
|
40
|
+
(balances[r.address.toLowerCase()] = {
|
|
41
|
+
balance: Number(r.value) / 100,
|
|
42
|
+
fuseBalance: Number(r.value) / 100,
|
|
43
|
+
lastSeen: 0
|
|
44
|
+
})
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
console.log("fetching celo balances....");
|
|
48
|
+
curPage = 1;
|
|
49
|
+
result = [];
|
|
50
|
+
do {
|
|
51
|
+
const pages = range(curPage, curPage + 3, 1);
|
|
52
|
+
curPage += 3;
|
|
53
|
+
const ps = pages.map(p =>
|
|
54
|
+
fetch(
|
|
55
|
+
`${celoExplorer}?module=token&action=getTokenHolders&contractaddress=0x62B8B11039FcfE5aB0C56E502b1C372A3d2a9c7A&page=${p}&offset=10000`
|
|
56
|
+
)
|
|
57
|
+
.then(_ => _.json())
|
|
58
|
+
.then(_ => _.result)
|
|
59
|
+
);
|
|
60
|
+
const results = await Promise.all(ps);
|
|
61
|
+
result = result.concat(...results);
|
|
62
|
+
maxResult = maxBy(results, "length");
|
|
63
|
+
console.log(maxResult.length, result.length);
|
|
64
|
+
} while (maxResult.length === 10000);
|
|
65
|
+
|
|
66
|
+
result.forEach(
|
|
67
|
+
r =>
|
|
68
|
+
(balances[r.address.toLowerCase()] = {
|
|
69
|
+
...balances[r.address.toLowerCase()],
|
|
70
|
+
celoBalance: Number(r.value) / 1e18,
|
|
71
|
+
balance: Number(balances[r.address.toLowerCase()]?.fuseBalance || 0) + Number(r.value) / 1e18,
|
|
72
|
+
lastSeen: 0
|
|
73
|
+
})
|
|
74
|
+
);
|
|
75
|
+
|
|
76
|
+
fs.writeFileSync(`activeWalletsBalances-${today}.json`, JSON.stringify(balances));
|
|
13
77
|
|
|
14
|
-
|
|
78
|
+
balances = JSON.parse(fs.readFileSync(`activeWalletsBalances-${today}.json`).toString());
|
|
15
79
|
|
|
16
80
|
const EPOCH = 60 * 60 * 6;
|
|
17
|
-
const pool = new PromisePool({ concurrency:
|
|
81
|
+
const pool = new PromisePool({ concurrency: 10 });
|
|
18
82
|
const lastUsed = {};
|
|
19
83
|
const epochs = range(1596045730, (Date.now() / 1000).toFixed(0), EPOCH);
|
|
20
84
|
|
|
21
|
-
const graphQuery = async (start, skip) => {
|
|
85
|
+
const graphQuery = async (start, skip, subgraph, retry = 3) => {
|
|
22
86
|
const query = `{
|
|
23
87
|
walletStats(first: 1000 skip:${skip} where: { dateAppeared_gte: ${start} dateAppeared_lt:${start + EPOCH} }) {
|
|
24
88
|
id
|
|
@@ -31,7 +95,7 @@ const main = async (chain = "fuse") => {
|
|
|
31
95
|
}`;
|
|
32
96
|
// console.log({ query });
|
|
33
97
|
try {
|
|
34
|
-
const { data = {}, errors } = await fetch(
|
|
98
|
+
const { data = {}, errors } = await fetch(subgraph, {
|
|
35
99
|
method: "POST",
|
|
36
100
|
headers: {
|
|
37
101
|
"Content-Type": "application/json"
|
|
@@ -39,27 +103,36 @@ const main = async (chain = "fuse") => {
|
|
|
39
103
|
body: JSON.stringify({ query })
|
|
40
104
|
}).then(_ => _.json());
|
|
41
105
|
errors && console.log({ errors });
|
|
106
|
+
if (errors) {
|
|
107
|
+
console.log("query failed:", { subgraph, start, skip, retrying: retry > 0 });
|
|
108
|
+
if (retry > 0) {
|
|
109
|
+
return graphQuery(start, skip, subgraph, retry - 1);
|
|
110
|
+
}
|
|
111
|
+
return [];
|
|
112
|
+
}
|
|
113
|
+
// console.log("query ok:", { subgraph, start, skip, records: data.walletStats.length })
|
|
42
114
|
if (data?.walletStats?.length === 1000) {
|
|
43
|
-
return data.walletStats.concat(await graphQuery(start, skip + 1000));
|
|
115
|
+
return data.walletStats.concat(await graphQuery(start, skip + 1000, subgraph));
|
|
44
116
|
}
|
|
45
117
|
return data.walletStats || [];
|
|
46
118
|
} catch (error) {
|
|
47
|
-
console.log({ query, error });
|
|
119
|
+
console.log({ query, error, subgraph });
|
|
48
120
|
return [];
|
|
49
121
|
}
|
|
50
122
|
};
|
|
51
123
|
epochs.forEach(e => {
|
|
52
124
|
pool.add(async () => {
|
|
53
|
-
const walletStats = await graphQuery(e, 0);
|
|
125
|
+
const walletStats = flatten(await Promise.all([graphQuery(e, 0, fuseSubgraph), graphQuery(e, 0, celoSubgraph)]));
|
|
54
126
|
walletStats.forEach(w => {
|
|
55
127
|
balances[w.id.toLowerCase()] = {
|
|
128
|
+
...balances[w.id.toLowerCase()],
|
|
56
129
|
lastSeen: Math.max(
|
|
130
|
+
balances[w.id.toLowerCase()]?.lastSeen,
|
|
57
131
|
Number(w.lastClaimed),
|
|
58
132
|
Number(w.lastTransactionFrom),
|
|
59
133
|
Number(w.lastTransactionTo),
|
|
60
134
|
Number(w.dateAppeared)
|
|
61
|
-
)
|
|
62
|
-
balance: balances[w.id.toLowerCase()]?.balance || w.balance
|
|
135
|
+
)
|
|
63
136
|
};
|
|
64
137
|
});
|
|
65
138
|
console.log({ curDate: e, records: walletStats.length });
|
|
@@ -67,7 +140,7 @@ const main = async (chain = "fuse") => {
|
|
|
67
140
|
});
|
|
68
141
|
|
|
69
142
|
await pool.all();
|
|
70
|
-
fs.writeFileSync(
|
|
143
|
+
fs.writeFileSync(`activeWalletsLastUsed-${today}.json`, JSON.stringify(balances));
|
|
71
144
|
// console.log({ lastUsed });
|
|
72
145
|
};
|
|
73
146
|
|
|
@@ -85,8 +158,46 @@ function arrayToCsv(data) {
|
|
|
85
158
|
)
|
|
86
159
|
.join("\r\n"); // rows starting on new lines
|
|
87
160
|
}
|
|
161
|
+
|
|
162
|
+
const fix = async () => {
|
|
163
|
+
const balances = JSON.parse(fs.readFileSync(`activeWalletsLastUsed-${today}.json`).toString());
|
|
164
|
+
|
|
165
|
+
let result = [];
|
|
166
|
+
|
|
167
|
+
let missing = 0;
|
|
168
|
+
for (let addr in balances) {
|
|
169
|
+
const r = balances[addr];
|
|
170
|
+
if (!r.fuseBalance && !r.celoBalance) {
|
|
171
|
+
console.log("missing:", addr);
|
|
172
|
+
missing += 1;
|
|
173
|
+
continue;
|
|
174
|
+
}
|
|
175
|
+
r.celoBalance = (r.celoBalance || 0) * 100;
|
|
176
|
+
r.balance = r.celoBalance + r.fuseBalance;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
console.log("missing balance", missing);
|
|
180
|
+
console.log(sortBy(Object.entries(balances), _ => -_.balance).slice(0, 10));
|
|
181
|
+
|
|
182
|
+
fs.writeFileSync(`activeWalletsLastUsed-${today}.json`, JSON.stringify(balances));
|
|
183
|
+
};
|
|
88
184
|
const etl = async () => {
|
|
89
|
-
|
|
185
|
+
/** Convert a 2D array into a CSV string
|
|
186
|
+
*/
|
|
187
|
+
function arrayToCsv(data) {
|
|
188
|
+
return data
|
|
189
|
+
.map(
|
|
190
|
+
row =>
|
|
191
|
+
row
|
|
192
|
+
.map(String) // convert every value to String
|
|
193
|
+
.map(v => v.replaceAll('"', '""')) // escape double colons
|
|
194
|
+
.map(v => `"${v}"`) // quote it
|
|
195
|
+
.join(",") // comma-separated
|
|
196
|
+
)
|
|
197
|
+
.join("\r\n"); // rows starting on new lines
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
const balances = JSON.parse(fs.readFileSync(`activeWalletsLastUsed-${today}.json`).toString());
|
|
90
201
|
|
|
91
202
|
let result = [];
|
|
92
203
|
|
|
@@ -95,22 +206,30 @@ const etl = async () => {
|
|
|
95
206
|
if (!r.balance) {
|
|
96
207
|
continue;
|
|
97
208
|
}
|
|
98
|
-
result.push([addr, r.balance
|
|
209
|
+
result.push([addr, r.balance, r.lastSeen, false, r.fuseBalance, r.celoBalance]);
|
|
99
210
|
}
|
|
211
|
+
result = sortBy(result, _ => -_[1]);
|
|
100
212
|
const top100 = result.slice(0, 100);
|
|
101
213
|
const pool = new PromisePool({ concurrency: 30 });
|
|
102
214
|
const provider = new ethers.providers.JsonRpcBatchProvider("https://rpc.fuse.io");
|
|
215
|
+
const celoprovider = new ethers.providers.JsonRpcBatchProvider("https://forno.celo.org");
|
|
103
216
|
|
|
104
217
|
for (let idx in top100) {
|
|
105
218
|
pool.add(async () => {
|
|
106
219
|
const record = top100[idx];
|
|
107
|
-
let isContract =
|
|
220
|
+
let isContract =
|
|
221
|
+
(
|
|
222
|
+
await Promise.all([
|
|
223
|
+
provider.getCode(record[0]).catch(e => "0x"),
|
|
224
|
+
celoprovider.getCode(record[0]).catch(e => "0x")
|
|
225
|
+
])
|
|
226
|
+
).find(_ => _ !== "0x") !== undefined;
|
|
108
227
|
record[3] = isContract;
|
|
109
228
|
});
|
|
110
229
|
}
|
|
111
230
|
await pool.all();
|
|
112
231
|
console.log({ top100 });
|
|
113
|
-
fs.writeFileSync(
|
|
232
|
+
fs.writeFileSync(`activeWalletsLastUsed-${today}.csv`, arrayToCsv(result));
|
|
114
233
|
};
|
|
115
234
|
|
|
116
235
|
const getFuseBalances = async (refetch = true) => {
|
|
@@ -177,5 +296,6 @@ const fundsByLastSeen = async () => {
|
|
|
177
296
|
};
|
|
178
297
|
getFuseBalances(false).catch(e => console.log(e));
|
|
179
298
|
// main().catch(e => console.log(e));
|
|
180
|
-
//
|
|
299
|
+
// fix();
|
|
300
|
+
etl();
|
|
181
301
|
// fundsByLastSeen();
|
package/scripts/fv.ts
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import fs from "fs";
|
|
2
2
|
import { chunk, uniqBy } from "lodash";
|
|
3
3
|
import delay from "delay";
|
|
4
|
+
import { bulkIsWhitelisted, bulkLastAuth } from "./utils";
|
|
4
5
|
|
|
5
|
-
|
|
6
|
+
//create tunnel to fv server ssh -L 9090:server:8080 -N user@server -i sshkey
|
|
6
7
|
|
|
7
|
-
const
|
|
8
|
+
const saveImages = async a => {
|
|
8
9
|
const i1 = await fetch("http://localhost:9090/enrollment-3d/" + a[1]).then(_ => _.json());
|
|
9
10
|
const i2 = await fetch("http://localhost:9090/enrollment-3d/" + a[2]).then(_ => _.json());
|
|
10
11
|
if (i1.auditTrailBase64 && i2.auditTrailBase64) {
|
|
@@ -16,7 +17,7 @@ const fetchImages = async a => {
|
|
|
16
17
|
});
|
|
17
18
|
} else console.log("not found", a, !!i1.auditTrailBase64, !!i2.auditTrailBase64);
|
|
18
19
|
};
|
|
19
|
-
|
|
20
|
+
|
|
20
21
|
const main = async () => {
|
|
21
22
|
const data = JSON.parse(fs.readFileSync("fvtriplets2.txt").toString());
|
|
22
23
|
const triplets = uniqBy(chunk(data, 3), _ => _.join("_"));
|
|
@@ -33,7 +34,7 @@ const main = async () => {
|
|
|
33
34
|
return fs.existsSync(key) === false;
|
|
34
35
|
});
|
|
35
36
|
console.log({ notfetched });
|
|
36
|
-
const ps = notfetched.map(
|
|
37
|
+
const ps = notfetched.map(saveImages);
|
|
37
38
|
|
|
38
39
|
await Promise.all(ps);
|
|
39
40
|
};
|
|
@@ -207,6 +208,7 @@ const deleteIdentifiers = async password => {
|
|
|
207
208
|
};
|
|
208
209
|
// checkIndexedOrDelete();
|
|
209
210
|
fixInvalidIndexed();
|
|
210
|
-
// main();
|
|
211
211
|
// console.log(process.env.ADMIN_PASSWORD);
|
|
212
212
|
// deleteIdentifiers(process.env.ADMIN_PASSWORD);
|
|
213
|
+
// main();
|
|
214
|
+
saveImages(["", "", ""]);
|