@etherisc/gif-next 0.0.2-c00cf5d-513 → 0.0.2-c0457ac-280
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/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +198 -177
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +130 -335
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +67 -96
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +83 -108
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +35 -48
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +32 -101
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +65 -66
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +163 -10
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +81 -93
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +56 -40
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +84 -44
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +458 -331
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +268 -46
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +74 -43
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1095 -344
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +2 -71
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +91 -264
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +56 -69
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +19 -51
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +145 -86
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +134 -133
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +242 -103
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +180 -376
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +42 -83
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +93 -167
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +56 -45
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +121 -211
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +64 -61
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +20 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +20 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +94 -25
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +40 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +241 -107
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +13 -55
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +180 -297
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +54 -99
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +163 -174
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +81 -54
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +337 -157
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +47 -230
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +34 -47
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +65 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +153 -1
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +129 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +294 -15
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1712 -103
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +198 -28
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +45 -42
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +321 -161
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +171 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +187 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +314 -136
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1559 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +52 -20
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +52 -20
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +100 -96
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +916 -55
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +539 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1189 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +76 -81
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +1 -11
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +7 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +21 -3
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +7 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +20 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +33 -20
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +31 -13
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +19 -32
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +17 -22
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +16 -16
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +40 -4
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +566 -54
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +657 -100
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +65 -46
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2261 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +68 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +53 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +34 -34
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +47 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +96 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +114 -4
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +76 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
- package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +2 -2
- package/contracts/distribution/Distribution.sol +29 -53
- package/contracts/distribution/DistributionService.sol +61 -115
- package/contracts/distribution/IDistributionComponent.sol +5 -10
- package/contracts/distribution/IDistributionService.sol +2 -8
- package/contracts/instance/IInstance.sol +15 -7
- package/contracts/instance/IInstanceService.sol +35 -10
- package/contracts/instance/Instance.sol +63 -34
- package/contracts/instance/InstanceAdmin.sol +3 -2
- package/contracts/instance/InstanceAuthorizationsLib.sol +84 -27
- package/contracts/instance/InstanceReader.sol +64 -40
- package/contracts/instance/InstanceService.sol +185 -45
- package/contracts/instance/InstanceStore.sol +122 -64
- package/contracts/instance/base/BalanceStore.sol +123 -0
- package/contracts/instance/base/Cloneable.sol +2 -25
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/base/ObjectManager.sol +1 -3
- package/contracts/instance/module/IBundle.sol +1 -4
- package/contracts/instance/module/IComponents.sol +15 -4
- package/contracts/instance/module/IPolicy.sol +8 -2
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/IOracle.sol +20 -0
- package/contracts/oracle/IOracleComponent.sol +32 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +145 -0
- package/contracts/oracle/OracleService.sol +278 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +79 -167
- package/contracts/pool/IBundleService.sol +4 -16
- package/contracts/pool/IPoolComponent.sol +4 -6
- package/contracts/pool/IPoolService.sol +45 -9
- package/contracts/pool/Pool.sol +39 -42
- package/contracts/pool/PoolService.sol +190 -142
- package/contracts/product/ApplicationService.sol +109 -42
- package/contracts/product/ClaimService.sol +18 -19
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +6 -8
- package/contracts/product/IPricingService.sol +3 -1
- package/contracts/product/IProductComponent.sol +7 -6
- package/contracts/product/IProductService.sol +1 -8
- package/contracts/product/PolicyService.sol +225 -128
- package/contracts/product/PricingService.sol +72 -48
- package/contracts/product/Product.sol +47 -49
- package/contracts/product/ProductService.sol +26 -114
- package/contracts/registry/ChainNft.sol +8 -1
- package/contracts/registry/IRegistry.sol +15 -4
- package/contracts/registry/IRegistryService.sol +10 -0
- package/contracts/registry/IServiceAuthorization.sol +35 -0
- package/contracts/registry/Registry.sol +164 -47
- package/contracts/registry/RegistryAdmin.sol +264 -72
- package/contracts/registry/RegistryService.sol +48 -14
- package/contracts/registry/RegistryServiceManager.sol +2 -9
- package/contracts/registry/ReleaseManager.sol +242 -177
- package/contracts/registry/ServiceAuthorization.sol +86 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
- package/contracts/registry/TokenRegistry.sol +261 -64
- package/contracts/shared/AccessAdmin.sol +759 -0
- package/contracts/shared/AccessManagerCustom.sol +6 -1
- package/contracts/shared/AccessManagerExtended.sol +19 -7
- package/contracts/shared/Component.sol +139 -129
- package/contracts/shared/ComponentService.sol +563 -88
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +117 -0
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessAdmin.sol +168 -0
- package/contracts/shared/IComponent.sol +17 -37
- package/contracts/shared/IComponentService.sol +102 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +6 -6
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +6 -1
- package/contracts/shared/IService.sol +8 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +144 -0
- package/contracts/{instance/base → shared}/KeyValueStore.sol +30 -72
- package/contracts/{instance/base → shared}/Lifecycle.sol +12 -3
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +3 -13
- package/contracts/shared/PolicyHolder.sol +21 -13
- package/contracts/shared/ProxyManager.sol +2 -3
- package/contracts/shared/Registerable.sol +2 -2
- package/contracts/shared/Service.sol +32 -21
- package/contracts/shared/TokenHandler.sol +24 -1
- package/contracts/staking/IStaking.sol +168 -0
- package/contracts/staking/IStakingService.sol +98 -47
- package/contracts/staking/StakeManagerLib.sol +231 -0
- package/contracts/staking/Staking.sol +513 -0
- package/contracts/staking/StakingManager.sol +54 -0
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +286 -44
- package/contracts/staking/StakingServiceManager.sol +7 -3
- package/contracts/staking/StakingStore.sol +613 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +20 -1
- package/contracts/type/Blocknumber.sol +20 -3
- package/contracts/type/Fee.sol +17 -16
- package/contracts/type/NftId.sol +14 -16
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +142 -63
- package/contracts/type/Referral.sol +1 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +82 -20
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +27 -2
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/Version.sol +1 -1
- package/package.json +3 -3
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -581
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
- package/contracts/instance/module/ISetup.sol +0 -33
- package/contracts/instance/module/ITreasury.sol +0 -23
@@ -0,0 +1,513 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Amount, AmountLib} from "../type/Amount.sol";
|
5
|
+
import {ChainNft} from "../registry/ChainNft.sol";
|
6
|
+
import {Component} from "../shared/Component.sol";
|
7
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
8
|
+
import {IRegistryService} from "../registry/IRegistryService.sol";
|
9
|
+
import {IStaking} from "./IStaking.sol";
|
10
|
+
import {IVersionable} from "../shared/IVersionable.sol";
|
11
|
+
import {Key32} from "../type/Key32.sol";
|
12
|
+
import {LibNftIdSet} from "../type/NftIdSet.sol";
|
13
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
14
|
+
import {NftIdSetManager} from "../shared/NftIdSetManager.sol";
|
15
|
+
import {ObjectType, INSTANCE, PROTOCOL, STAKE, STAKING, TARGET} from "../type/ObjectType.sol";
|
16
|
+
import {Seconds, SecondsLib} from "../type/Seconds.sol";
|
17
|
+
import {StakeManagerLib} from "./StakeManagerLib.sol";
|
18
|
+
import {StakingReader} from "./StakingReader.sol";
|
19
|
+
import {StakingStore} from "./StakingStore.sol";
|
20
|
+
import {TargetManagerLib} from "./TargetManagerLib.sol";
|
21
|
+
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
22
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
23
|
+
import {TokenRegistry} from "../registry/TokenRegistry.sol";
|
24
|
+
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
25
|
+
import {Version, VersionLib} from "../type/Version.sol";
|
26
|
+
import {Versionable} from "../shared/Versionable.sol";
|
27
|
+
|
28
|
+
contract Staking is
|
29
|
+
Component,
|
30
|
+
Versionable,
|
31
|
+
IStaking
|
32
|
+
{
|
33
|
+
string public constant CONTRACT_NAME = "Staking";
|
34
|
+
uint8 private constant GIF_MAJOR_VERSION = 3;
|
35
|
+
|
36
|
+
// keccak256(abi.encode(uint256(keccak256("gif-next.contracts.component.Staking.sol")) - 1)) & ~bytes32(uint256(0xff));
|
37
|
+
bytes32 public constant STAKING_LOCATION_V1 = 0xafe8d4462b2ed26a47154f4b8f6d1497d2f772496965791d25bd456e342b7f00;
|
38
|
+
|
39
|
+
struct StakingStorage {
|
40
|
+
IRegistryService _registryService;
|
41
|
+
TokenRegistry _tokenRegistry;
|
42
|
+
StakingStore _store;
|
43
|
+
StakingReader _reader;
|
44
|
+
NftId _protocolNftId;
|
45
|
+
}
|
46
|
+
|
47
|
+
|
48
|
+
modifier onlyStake(NftId stakeNftId) {
|
49
|
+
if (!_getStakingStorage()._store.exists(stakeNftId)) {
|
50
|
+
revert ErrorStakingNotStake(stakeNftId);
|
51
|
+
}
|
52
|
+
_;
|
53
|
+
}
|
54
|
+
|
55
|
+
|
56
|
+
modifier onlyTarget(NftId targetNftId) {
|
57
|
+
if (!_getStakingStorage()._store.getTargetManager().exists(targetNftId)) {
|
58
|
+
revert ErrorStakingNotTarget(targetNftId);
|
59
|
+
}
|
60
|
+
_;
|
61
|
+
}
|
62
|
+
|
63
|
+
// set/update staking reader
|
64
|
+
function setStakingReader(StakingReader stakingReader)
|
65
|
+
external
|
66
|
+
virtual
|
67
|
+
onlyOwner()
|
68
|
+
{
|
69
|
+
if(stakingReader.getStaking() != IStaking(this)) {
|
70
|
+
revert ErrorStakingStakingReaderStakingMismatch(address(stakingReader.getStaking()));
|
71
|
+
}
|
72
|
+
|
73
|
+
_getStakingStorage()._reader = stakingReader;
|
74
|
+
}
|
75
|
+
|
76
|
+
|
77
|
+
// rate management
|
78
|
+
function setStakingRate(uint256 chainId, address token, UFixed stakingRate)
|
79
|
+
external
|
80
|
+
virtual
|
81
|
+
onlyOwner()
|
82
|
+
{
|
83
|
+
StakingStorage storage $ = _getStakingStorage();
|
84
|
+
|
85
|
+
if (!$._tokenRegistry.isRegistered(chainId, token)) {
|
86
|
+
revert ErrorStakingTokenNotRegistered(chainId, token);
|
87
|
+
}
|
88
|
+
|
89
|
+
UFixed oldStakingRate = $._store.getStakingRate(chainId, token);
|
90
|
+
$._store.setStakingRate(chainId, token, stakingRate);
|
91
|
+
|
92
|
+
emit LogStakingStakingRateSet(chainId, token, oldStakingRate, stakingRate);
|
93
|
+
}
|
94
|
+
|
95
|
+
// target management
|
96
|
+
|
97
|
+
function registerTarget(
|
98
|
+
NftId targetNftId,
|
99
|
+
ObjectType expectedObjectType,
|
100
|
+
uint256 chainId,
|
101
|
+
Seconds initialLockingPeriod,
|
102
|
+
UFixed initialRewardRate
|
103
|
+
)
|
104
|
+
external
|
105
|
+
virtual
|
106
|
+
restricted()
|
107
|
+
{
|
108
|
+
TargetManagerLib.checkTargetParameters(
|
109
|
+
getRegistry(),
|
110
|
+
_getStakingStorage()._reader,
|
111
|
+
targetNftId,
|
112
|
+
expectedObjectType,
|
113
|
+
initialLockingPeriod,
|
114
|
+
initialRewardRate);
|
115
|
+
|
116
|
+
_getStakingStorage()._store.createTarget(
|
117
|
+
targetNftId,
|
118
|
+
TargetInfo({
|
119
|
+
objectType: expectedObjectType,
|
120
|
+
chainId: chainId,
|
121
|
+
lockingPeriod: initialLockingPeriod,
|
122
|
+
rewardRate: initialRewardRate}));
|
123
|
+
}
|
124
|
+
|
125
|
+
|
126
|
+
function setLockingPeriod(
|
127
|
+
NftId targetNftId,
|
128
|
+
Seconds lockingPeriod
|
129
|
+
)
|
130
|
+
external
|
131
|
+
virtual
|
132
|
+
restricted()
|
133
|
+
onlyTarget(targetNftId)
|
134
|
+
{
|
135
|
+
(
|
136
|
+
Seconds oldLockingPeriod,
|
137
|
+
TargetInfo memory targetInfo
|
138
|
+
) = TargetManagerLib.updateLockingPeriod(
|
139
|
+
this,
|
140
|
+
targetNftId,
|
141
|
+
lockingPeriod);
|
142
|
+
|
143
|
+
_getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
|
144
|
+
|
145
|
+
emit LogStakingLockingPeriodSet(targetNftId, oldLockingPeriod, lockingPeriod);
|
146
|
+
}
|
147
|
+
|
148
|
+
// TODO add function to set protocol reward rate: onlyOwner
|
149
|
+
// get protocol nft id (from where)
|
150
|
+
|
151
|
+
function setRewardRate(NftId targetNftId, UFixed rewardRate)
|
152
|
+
external
|
153
|
+
virtual
|
154
|
+
restricted()
|
155
|
+
onlyTarget(targetNftId)
|
156
|
+
{
|
157
|
+
(
|
158
|
+
UFixed oldRewardRate,
|
159
|
+
TargetInfo memory targetInfo
|
160
|
+
) = TargetManagerLib.updateRewardRate(
|
161
|
+
this,
|
162
|
+
targetNftId,
|
163
|
+
rewardRate);
|
164
|
+
|
165
|
+
_getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
|
166
|
+
|
167
|
+
emit LogStakingRewardRateSet(targetNftId, oldRewardRate, rewardRate);
|
168
|
+
}
|
169
|
+
|
170
|
+
|
171
|
+
function refillRewardReserves(NftId targetNftId, Amount dipAmount)
|
172
|
+
external
|
173
|
+
virtual
|
174
|
+
restricted()
|
175
|
+
returns (Amount newBalance)
|
176
|
+
{
|
177
|
+
// update book keeping of reward reserves
|
178
|
+
StakingStorage storage $ = _getStakingStorage();
|
179
|
+
newBalance = $._store.increaseReserves(targetNftId, dipAmount);
|
180
|
+
}
|
181
|
+
|
182
|
+
|
183
|
+
function withdrawRewardReserves(NftId targetNftId, Amount dipAmount)
|
184
|
+
external
|
185
|
+
virtual
|
186
|
+
restricted()
|
187
|
+
returns (Amount newBalance)
|
188
|
+
{
|
189
|
+
// update book keeping of reward reserves
|
190
|
+
StakingStorage storage $ = _getStakingStorage();
|
191
|
+
newBalance = $._store.decreaseReserves(targetNftId, dipAmount);
|
192
|
+
}
|
193
|
+
|
194
|
+
|
195
|
+
function increaseTotalValueLocked(NftId targetNftId, address token, Amount amount)
|
196
|
+
external
|
197
|
+
virtual
|
198
|
+
restricted() // only pool service
|
199
|
+
returns (Amount newBalance)
|
200
|
+
{
|
201
|
+
StakingStorage storage $ = _getStakingStorage();
|
202
|
+
uint chainId = $._reader.getTargetInfo(targetNftId).chainId;
|
203
|
+
UFixed stakingRate = $._reader.getStakingRate(chainId, token);
|
204
|
+
newBalance = $._store.increaseTotalValueLocked(targetNftId, stakingRate, token, amount);
|
205
|
+
}
|
206
|
+
|
207
|
+
|
208
|
+
function decreaseTotalValueLocked(NftId targetNftId, address token, Amount amount)
|
209
|
+
external
|
210
|
+
virtual
|
211
|
+
restricted() // only pool service
|
212
|
+
returns (Amount newBalance)
|
213
|
+
{
|
214
|
+
StakingStorage storage $ = _getStakingStorage();
|
215
|
+
uint chainId = $._reader.getTargetInfo(targetNftId).chainId;
|
216
|
+
UFixed stakingRate = $._reader.getStakingRate(chainId, token);
|
217
|
+
newBalance = $._store.decreaseTotalValueLocked(targetNftId, stakingRate, token, amount);
|
218
|
+
}
|
219
|
+
|
220
|
+
|
221
|
+
function registerRemoteTarget(NftId targetNftId, TargetInfo memory targetInfo)
|
222
|
+
external
|
223
|
+
virtual
|
224
|
+
restricted()
|
225
|
+
onlyOwner // or CCIP
|
226
|
+
{
|
227
|
+
|
228
|
+
}
|
229
|
+
|
230
|
+
function updateRemoteTvl(NftId targetNftId, address token, Amount amount)
|
231
|
+
external
|
232
|
+
virtual
|
233
|
+
restricted()
|
234
|
+
onlyOwner // or CCIP
|
235
|
+
{
|
236
|
+
|
237
|
+
}
|
238
|
+
|
239
|
+
//--- staking functions -------------------------------------------------//
|
240
|
+
|
241
|
+
function createStake(
|
242
|
+
NftId stakeNftId,
|
243
|
+
NftId targetNftId,
|
244
|
+
Amount stakeAmount
|
245
|
+
)
|
246
|
+
external
|
247
|
+
virtual
|
248
|
+
restricted() // only staking service
|
249
|
+
{
|
250
|
+
StakingStorage storage $ = _getStakingStorage();
|
251
|
+
Timestamp lockedUntil = StakeManagerLib.checkCreateParameters(
|
252
|
+
$._reader,
|
253
|
+
targetNftId,
|
254
|
+
stakeAmount);
|
255
|
+
|
256
|
+
// create new stake
|
257
|
+
$._store.create(
|
258
|
+
stakeNftId,
|
259
|
+
StakeInfo({
|
260
|
+
lockedUntil: lockedUntil}));
|
261
|
+
|
262
|
+
// update target stake balance
|
263
|
+
$._store.increaseStake(
|
264
|
+
stakeNftId,
|
265
|
+
targetNftId,
|
266
|
+
stakeAmount);
|
267
|
+
}
|
268
|
+
|
269
|
+
|
270
|
+
function stake(
|
271
|
+
NftId stakeNftId,
|
272
|
+
Amount stakeAmount
|
273
|
+
)
|
274
|
+
external
|
275
|
+
virtual
|
276
|
+
restricted() // only staking service
|
277
|
+
onlyStake(stakeNftId)
|
278
|
+
returns (Amount stakeBalance)
|
279
|
+
{
|
280
|
+
StakingStorage storage $ = _getStakingStorage();
|
281
|
+
stakeBalance = StakeManagerLib.stake(
|
282
|
+
getRegistry(),
|
283
|
+
$._reader,
|
284
|
+
$._store,
|
285
|
+
stakeNftId,
|
286
|
+
stakeAmount);
|
287
|
+
}
|
288
|
+
|
289
|
+
|
290
|
+
function restake(
|
291
|
+
NftId stakeNftId,
|
292
|
+
NftId newTargetNftId
|
293
|
+
)
|
294
|
+
external
|
295
|
+
virtual
|
296
|
+
restricted() // only staking service
|
297
|
+
onlyStake(stakeNftId)
|
298
|
+
returns (NftId newStakeNftId)
|
299
|
+
{
|
300
|
+
// TODO add check that allows additional staking amount
|
301
|
+
StakingStorage storage $ = _getStakingStorage();
|
302
|
+
|
303
|
+
// TODO implement
|
304
|
+
}
|
305
|
+
|
306
|
+
|
307
|
+
function updateRewards(NftId stakeNftId)
|
308
|
+
external
|
309
|
+
virtual
|
310
|
+
restricted() // only staking service
|
311
|
+
onlyStake(stakeNftId)
|
312
|
+
{
|
313
|
+
StakingStorage storage $ = _getStakingStorage();
|
314
|
+
_updateRewards($._reader, $._store, stakeNftId);
|
315
|
+
}
|
316
|
+
|
317
|
+
|
318
|
+
function claimRewards(NftId stakeNftId)
|
319
|
+
external
|
320
|
+
virtual
|
321
|
+
restricted() // only staking service
|
322
|
+
onlyStake(stakeNftId)
|
323
|
+
returns (
|
324
|
+
Amount rewardsClaimedAmount
|
325
|
+
)
|
326
|
+
{
|
327
|
+
StakingStorage storage $ = _getStakingStorage();
|
328
|
+
|
329
|
+
// update rewards since last update
|
330
|
+
NftId targetNftId = _updateRewards($._reader, $._store, stakeNftId);
|
331
|
+
|
332
|
+
// unstake all available rewards
|
333
|
+
rewardsClaimedAmount = $._store.claimUpTo(
|
334
|
+
stakeNftId,
|
335
|
+
targetNftId,
|
336
|
+
AmountLib.max());
|
337
|
+
|
338
|
+
// update reward reserves
|
339
|
+
$._store.decreaseReserves(targetNftId, rewardsClaimedAmount);
|
340
|
+
}
|
341
|
+
|
342
|
+
|
343
|
+
function unstake(NftId stakeNftId)
|
344
|
+
external
|
345
|
+
virtual
|
346
|
+
restricted() // only staking service
|
347
|
+
onlyStake(stakeNftId)
|
348
|
+
returns (
|
349
|
+
Amount unstakedAmount,
|
350
|
+
Amount rewardsClaimedAmount
|
351
|
+
)
|
352
|
+
{
|
353
|
+
// TODO add check that stake locking is in the past
|
354
|
+
StakingStorage storage $ = _getStakingStorage();
|
355
|
+
|
356
|
+
// update rewards since last update
|
357
|
+
NftId targetNftId = _updateRewards($._reader, $._store, stakeNftId);
|
358
|
+
|
359
|
+
// unstake all available dips
|
360
|
+
(
|
361
|
+
unstakedAmount,
|
362
|
+
rewardsClaimedAmount
|
363
|
+
) = $._store.unstakeUpTo(
|
364
|
+
stakeNftId,
|
365
|
+
targetNftId,
|
366
|
+
AmountLib.max(), // unstake all stakes
|
367
|
+
AmountLib.max()); // claim all rewards
|
368
|
+
|
369
|
+
// update reward reserves
|
370
|
+
$._store.decreaseReserves(targetNftId, rewardsClaimedAmount);
|
371
|
+
}
|
372
|
+
|
373
|
+
|
374
|
+
|
375
|
+
//--- other functions ---------------------------------------------------//
|
376
|
+
|
377
|
+
function collectDipAmount(address from, Amount dipAmount)
|
378
|
+
external
|
379
|
+
restricted() // only staking service
|
380
|
+
{
|
381
|
+
TokenHandler tokenHandler = getTokenHandler();
|
382
|
+
address stakingWallet = getWallet();
|
383
|
+
|
384
|
+
StakeManagerLib.checkDipBalanceAndAllowance(
|
385
|
+
getToken(),
|
386
|
+
from,
|
387
|
+
address(tokenHandler),
|
388
|
+
dipAmount);
|
389
|
+
|
390
|
+
tokenHandler.transfer(from, stakingWallet, dipAmount);
|
391
|
+
}
|
392
|
+
|
393
|
+
|
394
|
+
function transferDipAmount(address to, Amount dipAmount)
|
395
|
+
external
|
396
|
+
restricted() // only staking service
|
397
|
+
{
|
398
|
+
TokenHandler tokenHandler = getTokenHandler();
|
399
|
+
address stakingWallet = getWallet();
|
400
|
+
|
401
|
+
StakeManagerLib.checkDipBalanceAndAllowance(
|
402
|
+
getToken(),
|
403
|
+
stakingWallet,
|
404
|
+
address(tokenHandler),
|
405
|
+
dipAmount);
|
406
|
+
|
407
|
+
tokenHandler.transfer(stakingWallet, to, dipAmount);
|
408
|
+
}
|
409
|
+
|
410
|
+
|
411
|
+
//--- view functions ----------------------------------------------------//
|
412
|
+
|
413
|
+
function getStakingReader() public view returns (StakingReader reader) {
|
414
|
+
return _getStakingStorage()._reader;
|
415
|
+
}
|
416
|
+
|
417
|
+
function getStakingStore() external view returns (StakingStore stakingStore) {
|
418
|
+
return _getStakingStorage()._store;
|
419
|
+
}
|
420
|
+
|
421
|
+
function getTokenRegistryAddress() external view returns (address tokenRegistry) {
|
422
|
+
return address(_getStakingStorage()._tokenRegistry);
|
423
|
+
}
|
424
|
+
|
425
|
+
|
426
|
+
// from Versionable
|
427
|
+
function getVersion()
|
428
|
+
public
|
429
|
+
pure
|
430
|
+
virtual override (IVersionable, Versionable)
|
431
|
+
returns(Version)
|
432
|
+
{
|
433
|
+
return VersionLib.toVersion(GIF_MAJOR_VERSION,0,0);
|
434
|
+
}
|
435
|
+
|
436
|
+
//--- internal functions ------------------------------------------------//
|
437
|
+
|
438
|
+
function _updateRewards(
|
439
|
+
StakingReader reader,
|
440
|
+
StakingStore store,
|
441
|
+
NftId stakeNftId
|
442
|
+
)
|
443
|
+
internal
|
444
|
+
virtual
|
445
|
+
returns (NftId targetNftId)
|
446
|
+
{
|
447
|
+
UFixed rewardRate;
|
448
|
+
|
449
|
+
(targetNftId, rewardRate) = reader.getTargetRewardRate(stakeNftId);
|
450
|
+
(Amount rewardIncrement, ) = StakeManagerLib.calculateRewardIncrease(
|
451
|
+
reader,
|
452
|
+
stakeNftId,
|
453
|
+
rewardRate);
|
454
|
+
|
455
|
+
store.updateRewards(
|
456
|
+
stakeNftId,
|
457
|
+
targetNftId,
|
458
|
+
rewardIncrement);
|
459
|
+
}
|
460
|
+
|
461
|
+
|
462
|
+
function _initialize(
|
463
|
+
address owner,
|
464
|
+
bytes memory data
|
465
|
+
)
|
466
|
+
internal
|
467
|
+
virtual override
|
468
|
+
initializer
|
469
|
+
{
|
470
|
+
(
|
471
|
+
address registryAddress,
|
472
|
+
address tokenRegistryAddress,
|
473
|
+
address stakingStoreAddress,
|
474
|
+
address stakingOwner
|
475
|
+
) = abi.decode(data, (address, address, address, address));
|
476
|
+
|
477
|
+
// only admin(authority) and dip token address are set in registry at this point
|
478
|
+
IRegistry registry = IRegistry(registryAddress);
|
479
|
+
address authority = registry.getAuthority();
|
480
|
+
TokenRegistry tokenRegistry = TokenRegistry(tokenRegistryAddress);
|
481
|
+
address dipTokenAddress = tokenRegistry.getDipTokenAddress();
|
482
|
+
|
483
|
+
initializeComponent(
|
484
|
+
authority,
|
485
|
+
registryAddress,
|
486
|
+
registry.getNftId(),
|
487
|
+
CONTRACT_NAME,
|
488
|
+
dipTokenAddress,
|
489
|
+
STAKING(),
|
490
|
+
false, // is interceptor
|
491
|
+
stakingOwner,
|
492
|
+
"", // registry data
|
493
|
+
""); // component data
|
494
|
+
|
495
|
+
_createAndSetTokenHandler();
|
496
|
+
|
497
|
+
// wiring to external contracts
|
498
|
+
StakingStorage storage $ = _getStakingStorage();
|
499
|
+
$._protocolNftId = getRegistry().getProtocolNftId();
|
500
|
+
$._store = StakingStore(stakingStoreAddress);
|
501
|
+
$._reader = StakingStore(stakingStoreAddress).getStakingReader();
|
502
|
+
$._tokenRegistry = TokenRegistry(tokenRegistryAddress);
|
503
|
+
|
504
|
+
registerInterface(type(IStaking).interfaceId);
|
505
|
+
}
|
506
|
+
|
507
|
+
|
508
|
+
function _getStakingStorage() private pure returns (StakingStorage storage $) {
|
509
|
+
assembly {
|
510
|
+
$.slot := STAKING_LOCATION_V1
|
511
|
+
}
|
512
|
+
}
|
513
|
+
}
|
@@ -0,0 +1,54 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IVersionable} from "../shared/IVersionable.sol";
|
5
|
+
import {ProxyManager} from "../shared/ProxyManager.sol";
|
6
|
+
import {ReleaseManager} from "../registry/ReleaseManager.sol";
|
7
|
+
import {Staking} from "./Staking.sol";
|
8
|
+
import {StakingReader} from "./StakingReader.sol";
|
9
|
+
import {StakingStore} from "./StakingStore.sol";
|
10
|
+
|
11
|
+
import {RegistryAdmin} from "../registry/RegistryAdmin.sol";
|
12
|
+
|
13
|
+
contract StakingManager is
|
14
|
+
ProxyManager
|
15
|
+
{
|
16
|
+
Staking private _staking;
|
17
|
+
address private _initialImplementation;
|
18
|
+
bytes private _initializationData;
|
19
|
+
|
20
|
+
/// @dev initializes proxy manager with service implementation
|
21
|
+
constructor(
|
22
|
+
address registry,
|
23
|
+
address tokenRegistry,
|
24
|
+
address stakingStore,
|
25
|
+
address initialOwner
|
26
|
+
)
|
27
|
+
ProxyManager(registry)
|
28
|
+
{
|
29
|
+
Staking stakingImplementation = new Staking();
|
30
|
+
|
31
|
+
_initialImplementation = address(stakingImplementation);
|
32
|
+
_initializationData = abi.encode(
|
33
|
+
registry,
|
34
|
+
tokenRegistry,
|
35
|
+
stakingStore,
|
36
|
+
initialOwner);
|
37
|
+
|
38
|
+
IVersionable versionable = deploy(
|
39
|
+
_initialImplementation,
|
40
|
+
_initializationData);
|
41
|
+
|
42
|
+
_staking = Staking(address(versionable));
|
43
|
+
}
|
44
|
+
|
45
|
+
//--- view functions ----------------------------------------------------//
|
46
|
+
|
47
|
+
function getStaking()
|
48
|
+
external
|
49
|
+
view
|
50
|
+
returns (Staking)
|
51
|
+
{
|
52
|
+
return _staking;
|
53
|
+
}
|
54
|
+
}
|