@etherisc/gif-next 0.0.2-fd4931b-974 → 0.0.2-fd9539f-062
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +20 -3
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +19 -13
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +115 -80
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +86 -59
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +11 -5
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +20 -1
- 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 +83 -71
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +121 -12
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +105 -85
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +125 -29
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +195 -64
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +206 -49
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +79 -36
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +248 -118
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- 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/IAccess.sol/IAccess.json +8 -116
- 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 +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +10 -0
- 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 -48
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +74 -43
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +20 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +11 -5
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +35 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +18 -12
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +84 -42
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +63 -40
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +79 -36
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +68 -37
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +119 -68
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +88 -53
- 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 +20 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +20 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +11 -5
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +20 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +97 -46
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +77 -42
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +105 -62
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +81 -50
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +18 -12
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +61 -26
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +59 -32
- 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 +82 -45
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +31 -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 +254 -97
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1901 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +69 -15
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +51 -35
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +288 -182
- 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 +46 -177
- 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 +4 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1747 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1760 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1838 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1856 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +18 -12
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +119 -69
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +85 -54
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +20 -1
- 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 +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +11 -5
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +27 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +11 -5
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +0 -10
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.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/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 +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +18 -12
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +10 -20
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +6 -6
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +27 -35
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +13 -7
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +6 -6
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +35 -16
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +15 -9
- 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 +20 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +6 -6
- 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 +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +247 -579
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +471 -62
- 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 +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +303 -798
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +81 -164
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +368 -39
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +503 -120
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +67 -43
- 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 +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +281 -18
- 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 +40 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +4 -4
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +12 -12
- 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 +28 -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 +4 -4
- 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 +4 -4
- 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 +52 -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/MathLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +2 -2
- 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 +2 -4
- package/contracts/distribution/DistributionService.sol +5 -6
- package/contracts/distribution/DistributionServiceManager.sol +1 -13
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +1 -1
- package/contracts/instance/BundleManager.sol +1 -1
- package/contracts/instance/IInstance.sol +22 -12
- package/contracts/instance/IInstanceService.sol +27 -13
- package/contracts/instance/Instance.sol +85 -50
- package/contracts/instance/InstanceAdmin.sol +331 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +193 -152
- package/contracts/instance/InstanceReader.sol +33 -7
- package/contracts/instance/InstanceService.sol +120 -48
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/InstanceStore.sol +30 -21
- package/contracts/instance/base/BalanceStore.sol +12 -7
- package/contracts/instance/base/Cloneable.sol +3 -26
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/base/ObjectManager.sol +2 -4
- package/contracts/instance/module/IAccess.sol +3 -11
- package/contracts/instance/module/IBundle.sol +1 -1
- package/contracts/instance/module/IComponents.sol +1 -1
- package/contracts/instance/module/IDistribution.sol +1 -1
- package/contracts/instance/module/IPolicy.sol +1 -1
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/mock/Dip.sol +1 -1
- 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 +20 -20
- package/contracts/pool/BundleServiceManager.sol +1 -1
- package/contracts/pool/IBundleService.sol +1 -1
- package/contracts/pool/IPoolComponent.sol +1 -1
- package/contracts/pool/IPoolService.sol +4 -1
- package/contracts/pool/Pool.sol +1 -1
- package/contracts/pool/PoolService.sol +38 -10
- package/contracts/pool/PoolServiceManager.sol +1 -1
- package/contracts/product/ApplicationService.sol +6 -6
- package/contracts/product/ApplicationServiceManager.sol +1 -1
- package/contracts/product/ClaimService.sol +12 -7
- package/contracts/product/ClaimServiceManager.sol +1 -1
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +1 -1
- package/contracts/product/IPricingService.sol +1 -1
- package/contracts/product/IProductComponent.sol +1 -1
- package/contracts/product/IProductService.sol +1 -1
- package/contracts/product/PolicyService.sol +9 -7
- package/contracts/product/PolicyServiceManager.sol +1 -1
- package/contracts/product/PricingService.sol +8 -9
- package/contracts/product/PricingServiceManager.sol +1 -1
- package/contracts/product/Product.sol +1 -1
- package/contracts/product/ProductService.sol +6 -6
- package/contracts/product/ProductServiceManager.sol +1 -1
- package/contracts/registry/ChainNft.sol +2 -1
- package/contracts/registry/IRegistry.sol +21 -15
- package/contracts/registry/IRegistryService.sol +2 -1
- package/contracts/registry/IServiceAuthorization.sol +35 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -1
- package/contracts/registry/Registry.sol +86 -67
- package/contracts/registry/RegistryAdmin.sol +333 -0
- package/contracts/registry/RegistryService.sol +9 -71
- package/contracts/registry/RegistryServiceManager.sol +2 -21
- package/contracts/registry/ReleaseManager.sol +219 -222
- package/contracts/registry/ServiceAuthorization.sol +86 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
- package/contracts/registry/TokenRegistry.sol +57 -61
- package/contracts/shared/AccessAdmin.sol +759 -0
- package/contracts/shared/AccessManagerCustom.sol +741 -0
- package/contracts/shared/AccessManagerExtended.sol +481 -0
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
- package/contracts/shared/Component.sol +9 -14
- package/contracts/shared/ComponentService.sol +40 -18
- package/contracts/shared/ComponentServiceManager.sol +1 -1
- package/contracts/shared/ComponentVerifyingService.sol +14 -8
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessAdmin.sol +168 -0
- package/contracts/shared/IAccessManagerExtended.sol +74 -0
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
- package/contracts/shared/IComponent.sol +4 -8
- package/contracts/shared/IComponentService.sol +12 -1
- package/contracts/shared/IInstanceLinkedComponent.sol +1 -1
- package/contracts/shared/IKeyValueStore.sol +2 -2
- package/contracts/shared/ILifecycle.sol +1 -1
- package/contracts/shared/INftOwnable.sol +2 -2
- package/contracts/shared/IPolicyHolder.sol +1 -1
- package/contracts/shared/IRegisterable.sol +1 -1
- package/contracts/shared/IRegistryLinked.sol +1 -1
- package/contracts/shared/IService.sol +8 -1
- package/contracts/shared/IVersionable.sol +1 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +2 -3
- package/contracts/shared/KeyValueStore.sol +2 -5
- package/contracts/shared/Lifecycle.sol +12 -3
- package/contracts/shared/NftIdSetManager.sol +3 -7
- package/contracts/shared/NftOwnable.sol +3 -14
- package/contracts/shared/PolicyHolder.sol +3 -2
- package/contracts/shared/ProxyManager.sol +7 -3
- package/contracts/shared/Registerable.sol +1 -1
- package/contracts/shared/RegistryLinked.sol +1 -1
- package/contracts/shared/Service.sol +28 -22
- package/contracts/shared/TokenHandler.sol +1 -1
- package/contracts/shared/UpgradableProxyWithAdmin.sol +1 -1
- package/contracts/shared/Versionable.sol +1 -1
- package/contracts/staking/IStaking.sol +94 -39
- package/contracts/staking/IStakingService.sol +71 -40
- package/contracts/staking/StakeManagerLib.sol +231 -0
- package/contracts/staking/Staking.sol +303 -138
- package/contracts/staking/StakingManager.sol +23 -21
- package/contracts/staking/StakingReader.sol +120 -25
- package/contracts/staking/StakingService.sol +194 -77
- package/contracts/staking/StakingServiceManager.sol +3 -3
- package/contracts/staking/StakingStore.sol +613 -0
- package/contracts/staking/TargetManagerLib.sol +77 -11
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +16 -2
- package/contracts/type/Blocknumber.sol +14 -2
- package/contracts/type/ClaimId.sol +1 -1
- package/contracts/type/DistributorType.sol +1 -1
- package/contracts/type/Fee.sol +1 -1
- package/contracts/type/Key32.sol +1 -1
- package/contracts/type/NftId.sol +9 -9
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +140 -68
- package/contracts/type/PayoutId.sol +1 -1
- 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 +79 -21
- package/contracts/type/Seconds.sol +19 -1
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +13 -1
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +7 -3
- package/contracts/type/UFixed.sol +1 -1
- package/contracts/type/Version.sol +1 -1
- package/package.json +6 -3
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1348
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -298
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +0 -4
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +0 -137
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/contracts/instance/InstanceAccessManager.sol +0 -543
- package/contracts/registry/RegistryAccessManager.sol +0 -167
- package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
@@ -1,5 +1,5 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.24;
|
3
3
|
|
4
4
|
import {Amount, AmountLib} from "../type/Amount.sol";
|
5
5
|
import {ChainNft} from "../registry/ChainNft.sol";
|
@@ -9,29 +9,23 @@ import {IRegistryService} from "../registry/IRegistryService.sol";
|
|
9
9
|
import {IStaking} from "./IStaking.sol";
|
10
10
|
import {IVersionable} from "../shared/IVersionable.sol";
|
11
11
|
import {Key32} from "../type/Key32.sol";
|
12
|
-
import {KeyValueStore} from "../shared/KeyValueStore.sol";
|
13
|
-
import {KEEP_STATE} from "../type/StateId.sol";
|
14
12
|
import {LibNftIdSet} from "../type/NftIdSet.sol";
|
15
13
|
import {NftId, NftIdLib} from "../type/NftId.sol";
|
16
14
|
import {NftIdSetManager} from "../shared/NftIdSetManager.sol";
|
17
15
|
import {ObjectType, INSTANCE, PROTOCOL, STAKE, STAKING, TARGET} from "../type/ObjectType.sol";
|
18
16
|
import {Seconds, SecondsLib} from "../type/Seconds.sol";
|
17
|
+
import {StakeManagerLib} from "./StakeManagerLib.sol";
|
19
18
|
import {StakingReader} from "./StakingReader.sol";
|
19
|
+
import {StakingStore} from "./StakingStore.sol";
|
20
20
|
import {TargetManagerLib} from "./TargetManagerLib.sol";
|
21
21
|
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
22
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
22
23
|
import {TokenRegistry} from "../registry/TokenRegistry.sol";
|
23
24
|
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
24
25
|
import {Version, VersionLib} from "../type/Version.sol";
|
25
26
|
import {Versionable} from "../shared/Versionable.sol";
|
26
27
|
|
27
|
-
// TODO split staking
|
28
|
-
// candidate clusters
|
29
|
-
// - strake management
|
30
|
-
// - target management
|
31
|
-
// - reward calculation
|
32
|
-
// - read access
|
33
28
|
contract Staking is
|
34
|
-
KeyValueStore,
|
35
29
|
Component,
|
36
30
|
Versionable,
|
37
31
|
IStaking
|
@@ -45,42 +39,32 @@ contract Staking is
|
|
45
39
|
struct StakingStorage {
|
46
40
|
IRegistryService _registryService;
|
47
41
|
TokenRegistry _tokenRegistry;
|
42
|
+
StakingStore _store;
|
48
43
|
StakingReader _reader;
|
49
|
-
|
50
|
-
NftIdSetManager _targetManager;
|
51
|
-
|
52
|
-
mapping(uint256 chainId => mapping(address token => UFixed stakingRate)) _stakingRate;
|
53
|
-
|
54
|
-
mapping(NftId targetNftId => Amount stakedAmount) _stakedAmount;
|
55
|
-
mapping(NftId targetNftId => mapping(address token => Amount tvlAmount)) _tvlAmount;
|
44
|
+
NftId _protocolNftId;
|
56
45
|
}
|
57
46
|
|
58
47
|
|
59
|
-
modifier
|
60
|
-
|
61
|
-
|
62
|
-
revert ErrorStakingNotNftOwner(nftId);
|
48
|
+
modifier onlyStake(NftId stakeNftId) {
|
49
|
+
if (!_getStakingStorage()._store.exists(stakeNftId)) {
|
50
|
+
revert ErrorStakingNotStake(stakeNftId);
|
63
51
|
}
|
64
52
|
_;
|
65
53
|
}
|
66
54
|
|
67
55
|
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
returns(Version)
|
74
|
-
{
|
75
|
-
return VersionLib.toVersion(GIF_MAJOR_VERSION,0,0);
|
56
|
+
modifier onlyTarget(NftId targetNftId) {
|
57
|
+
if (!_getStakingStorage()._store.getTargetManager().exists(targetNftId)) {
|
58
|
+
revert ErrorStakingNotTarget(targetNftId);
|
59
|
+
}
|
60
|
+
_;
|
76
61
|
}
|
77
62
|
|
78
|
-
|
79
63
|
// set/update staking reader
|
80
64
|
function setStakingReader(StakingReader stakingReader)
|
81
65
|
external
|
82
66
|
virtual
|
83
|
-
onlyOwner
|
67
|
+
onlyOwner()
|
84
68
|
{
|
85
69
|
if(stakingReader.getStaking() != IStaking(this)) {
|
86
70
|
revert ErrorStakingStakingReaderStakingMismatch(address(stakingReader.getStaking()));
|
@@ -94,33 +78,18 @@ contract Staking is
|
|
94
78
|
function setStakingRate(uint256 chainId, address token, UFixed stakingRate)
|
95
79
|
external
|
96
80
|
virtual
|
97
|
-
onlyOwner
|
98
|
-
{
|
99
|
-
|
100
|
-
}
|
101
|
-
|
102
|
-
// reward management
|
103
|
-
function setRewardRate(NftId targetNftId, UFixed rewardRate)
|
104
|
-
external
|
105
|
-
virtual
|
106
|
-
// onlyNftOwner(targetNftId)
|
81
|
+
onlyOwner()
|
107
82
|
{
|
83
|
+
StakingStorage storage $ = _getStakingStorage();
|
108
84
|
|
109
|
-
|
85
|
+
if (!$._tokenRegistry.isRegistered(chainId, token)) {
|
86
|
+
revert ErrorStakingTokenNotRegistered(chainId, token);
|
87
|
+
}
|
110
88
|
|
111
|
-
|
112
|
-
|
113
|
-
virtual
|
114
|
-
{
|
89
|
+
UFixed oldStakingRate = $._store.getStakingRate(chainId, token);
|
90
|
+
$._store.setStakingRate(chainId, token, stakingRate);
|
115
91
|
|
116
|
-
|
117
|
-
|
118
|
-
function withdrawRewardReserves(NftId targetNftId, Amount dipAmount)
|
119
|
-
external
|
120
|
-
virtual
|
121
|
-
// onlyNftOwner(targetNftId)
|
122
|
-
{
|
123
|
-
|
92
|
+
emit LogStakingStakingRateSet(chainId, token, oldStakingRate, stakingRate);
|
124
93
|
}
|
125
94
|
|
126
95
|
// target management
|
@@ -134,32 +103,23 @@ contract Staking is
|
|
134
103
|
)
|
135
104
|
external
|
136
105
|
virtual
|
137
|
-
|
106
|
+
restricted()
|
138
107
|
{
|
139
108
|
TargetManagerLib.checkTargetParameters(
|
140
109
|
getRegistry(),
|
141
|
-
|
110
|
+
_getStakingStorage()._reader,
|
142
111
|
targetNftId,
|
143
112
|
expectedObjectType,
|
144
113
|
initialLockingPeriod,
|
145
114
|
initialRewardRate);
|
146
115
|
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
lockingPeriod: initialLockingPeriod,
|
155
|
-
rewardRate: initialRewardRate,
|
156
|
-
rewardReserveAmount: AmountLib.zero()
|
157
|
-
})));
|
158
|
-
|
159
|
-
// add target nft id to all/active sets
|
160
|
-
_getStakingStorage()._targetManager.add(targetNftId);
|
161
|
-
|
162
|
-
emit LogStakingTargetAdded(targetNftId, expectedObjectType, chainId);
|
116
|
+
_getStakingStorage()._store.createTarget(
|
117
|
+
targetNftId,
|
118
|
+
TargetInfo({
|
119
|
+
objectType: expectedObjectType,
|
120
|
+
chainId: chainId,
|
121
|
+
lockingPeriod: initialLockingPeriod,
|
122
|
+
rewardRate: initialRewardRate}));
|
163
123
|
}
|
164
124
|
|
165
125
|
|
@@ -169,42 +129,99 @@ contract Staking is
|
|
169
129
|
)
|
170
130
|
external
|
171
131
|
virtual
|
172
|
-
|
132
|
+
restricted()
|
133
|
+
onlyTarget(targetNftId)
|
173
134
|
{
|
174
135
|
(
|
175
|
-
|
176
|
-
|
136
|
+
Seconds oldLockingPeriod,
|
137
|
+
TargetInfo memory targetInfo
|
177
138
|
) = TargetManagerLib.updateLockingPeriod(
|
178
139
|
this,
|
179
140
|
targetNftId,
|
180
141
|
lockingPeriod);
|
142
|
+
|
143
|
+
_getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
|
181
144
|
|
182
|
-
|
145
|
+
emit LogStakingLockingPeriodSet(targetNftId, oldLockingPeriod, lockingPeriod);
|
146
|
+
}
|
183
147
|
|
184
|
-
|
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);
|
185
168
|
}
|
186
169
|
|
187
170
|
|
188
|
-
function
|
171
|
+
function refillRewardReserves(NftId targetNftId, Amount dipAmount)
|
189
172
|
external
|
190
173
|
virtual
|
191
|
-
|
174
|
+
restricted()
|
175
|
+
returns (Amount newBalance)
|
192
176
|
{
|
177
|
+
// update book keeping of reward reserves
|
178
|
+
StakingStorage storage $ = _getStakingStorage();
|
179
|
+
newBalance = $._store.increaseReserves(targetNftId, dipAmount);
|
180
|
+
}
|
193
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);
|
194
192
|
}
|
195
193
|
|
196
|
-
|
194
|
+
|
195
|
+
function increaseTotalValueLocked(NftId targetNftId, address token, Amount amount)
|
197
196
|
external
|
198
197
|
virtual
|
199
|
-
|
198
|
+
restricted() // only pool service
|
199
|
+
returns (Amount newBalance)
|
200
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
|
+
}
|
201
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);
|
202
218
|
}
|
203
219
|
|
204
220
|
|
205
221
|
function registerRemoteTarget(NftId targetNftId, TargetInfo memory targetInfo)
|
206
222
|
external
|
207
223
|
virtual
|
224
|
+
restricted()
|
208
225
|
onlyOwner // or CCIP
|
209
226
|
{
|
210
227
|
|
@@ -213,80 +230,232 @@ contract Staking is
|
|
213
230
|
function updateRemoteTvl(NftId targetNftId, address token, Amount amount)
|
214
231
|
external
|
215
232
|
virtual
|
233
|
+
restricted()
|
216
234
|
onlyOwner // or CCIP
|
217
235
|
{
|
218
236
|
|
219
237
|
}
|
220
238
|
|
221
|
-
|
222
|
-
|
239
|
+
//--- staking functions -------------------------------------------------//
|
240
|
+
|
241
|
+
function createStake(
|
223
242
|
NftId stakeNftId,
|
224
243
|
NftId targetNftId,
|
225
|
-
Amount
|
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
|
226
273
|
)
|
227
274
|
external
|
228
275
|
virtual
|
276
|
+
restricted() // only staking service
|
277
|
+
onlyStake(stakeNftId)
|
278
|
+
returns (Amount stakeBalance)
|
229
279
|
{
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
stakeNftId
|
236
|
-
|
237
|
-
StakeInfo({
|
238
|
-
stakeAmount: dipAmount,
|
239
|
-
rewardAmount: AmountLib.zero(),
|
240
|
-
lockedUntil: lockedUntil,
|
241
|
-
rewardsUpdatedAt: currentTime
|
242
|
-
})));
|
280
|
+
StakingStorage storage $ = _getStakingStorage();
|
281
|
+
stakeBalance = StakeManagerLib.stake(
|
282
|
+
getRegistry(),
|
283
|
+
$._reader,
|
284
|
+
$._store,
|
285
|
+
stakeNftId,
|
286
|
+
stakeAmount);
|
243
287
|
}
|
244
288
|
|
245
289
|
|
246
|
-
function
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
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();
|
252
302
|
|
303
|
+
// TODO implement
|
304
|
+
}
|
253
305
|
|
254
|
-
// view functions
|
255
306
|
|
256
|
-
function
|
257
|
-
|
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);
|
258
315
|
}
|
259
316
|
|
260
|
-
|
261
|
-
|
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);
|
262
340
|
}
|
263
341
|
|
264
|
-
|
265
|
-
|
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);
|
266
371
|
}
|
267
372
|
|
268
|
-
|
269
|
-
|
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);
|
270
391
|
}
|
271
392
|
|
272
|
-
|
273
|
-
|
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;
|
274
419
|
}
|
275
420
|
|
276
421
|
function getTokenRegistryAddress() external view returns (address tokenRegistry) {
|
277
422
|
return address(_getStakingStorage()._tokenRegistry);
|
278
423
|
}
|
279
424
|
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
)
|
425
|
+
|
426
|
+
// from Versionable
|
427
|
+
function getVersion()
|
284
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
|
285
444
|
virtual
|
286
|
-
|
287
|
-
returns (Amount rewardIncrementAmount)
|
445
|
+
returns (NftId targetNftId)
|
288
446
|
{
|
447
|
+
UFixed rewardRate;
|
289
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);
|
290
459
|
}
|
291
460
|
|
292
461
|
|
@@ -299,26 +468,27 @@ contract Staking is
|
|
299
468
|
initializer
|
300
469
|
{
|
301
470
|
(
|
302
|
-
address initialAuthority,
|
303
471
|
address registryAddress,
|
304
|
-
address
|
305
|
-
address
|
306
|
-
address
|
307
|
-
) = abi.decode(data, (address, address, address, address
|
472
|
+
address tokenRegistryAddress,
|
473
|
+
address stakingStoreAddress,
|
474
|
+
address stakingOwner
|
475
|
+
) = abi.decode(data, (address, address, address, address));
|
308
476
|
|
477
|
+
// only admin(authority) and dip token address are set in registry at this point
|
309
478
|
IRegistry registry = IRegistry(registryAddress);
|
310
|
-
|
311
|
-
|
479
|
+
address authority = registry.getAuthority();
|
480
|
+
TokenRegistry tokenRegistry = TokenRegistry(tokenRegistryAddress);
|
481
|
+
address dipTokenAddress = tokenRegistry.getDipTokenAddress();
|
312
482
|
|
313
483
|
initializeComponent(
|
314
|
-
|
484
|
+
authority,
|
315
485
|
registryAddress,
|
316
486
|
registry.getNftId(),
|
317
487
|
CONTRACT_NAME,
|
318
488
|
dipTokenAddress,
|
319
489
|
STAKING(),
|
320
490
|
false, // is interceptor
|
321
|
-
|
491
|
+
stakingOwner,
|
322
492
|
"", // registry data
|
323
493
|
""); // component data
|
324
494
|
|
@@ -326,14 +496,10 @@ contract Staking is
|
|
326
496
|
|
327
497
|
// wiring to external contracts
|
328
498
|
StakingStorage storage $ = _getStakingStorage();
|
329
|
-
$.
|
330
|
-
$.
|
331
|
-
$.
|
332
|
-
|
333
|
-
|
334
|
-
// wiring to staking
|
335
|
-
$._targetManager.setOwner(address(this));
|
336
|
-
$._reader.setStaking(address(this));
|
499
|
+
$._protocolNftId = getRegistry().getProtocolNftId();
|
500
|
+
$._store = StakingStore(stakingStoreAddress);
|
501
|
+
$._reader = StakingStore(stakingStoreAddress).getStakingReader();
|
502
|
+
$._tokenRegistry = TokenRegistry(tokenRegistryAddress);
|
337
503
|
|
338
504
|
registerInterface(type(IStaking).interfaceId);
|
339
505
|
}
|
@@ -344,5 +510,4 @@ contract Staking is
|
|
344
510
|
$.slot := STAKING_LOCATION_V1
|
345
511
|
}
|
346
512
|
}
|
347
|
-
|
348
513
|
}
|
@@ -1,47 +1,49 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.24;
|
3
3
|
|
4
4
|
import {IVersionable} from "../shared/IVersionable.sol";
|
5
|
-
import {NftIdSetManager} from "../shared/NftIdSetManager.sol";
|
6
5
|
import {ProxyManager} from "../shared/ProxyManager.sol";
|
6
|
+
import {ReleaseManager} from "../registry/ReleaseManager.sol";
|
7
7
|
import {Staking} from "./Staking.sol";
|
8
8
|
import {StakingReader} from "./StakingReader.sol";
|
9
|
+
import {StakingStore} from "./StakingStore.sol";
|
10
|
+
|
11
|
+
import {RegistryAdmin} from "../registry/RegistryAdmin.sol";
|
9
12
|
|
10
13
|
contract StakingManager is
|
11
14
|
ProxyManager
|
12
15
|
{
|
13
|
-
|
14
16
|
Staking private _staking;
|
17
|
+
address private _initialImplementation;
|
18
|
+
bytes private _initializationData;
|
15
19
|
|
16
20
|
/// @dev initializes proxy manager with service implementation
|
17
21
|
constructor(
|
18
|
-
address
|
19
|
-
address
|
22
|
+
address registry,
|
23
|
+
address tokenRegistry,
|
24
|
+
address stakingStore,
|
25
|
+
address initialOwner
|
20
26
|
)
|
21
|
-
ProxyManager(
|
27
|
+
ProxyManager(registry)
|
22
28
|
{
|
23
|
-
Staking
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
bytes memory data = abi.encode(
|
31
|
-
initialAuthority,
|
32
|
-
registryAddress,
|
33
|
-
address(targetManager),
|
34
|
-
address(stakingReader),
|
29
|
+
Staking stakingImplementation = new Staking();
|
30
|
+
|
31
|
+
_initialImplementation = address(stakingImplementation);
|
32
|
+
_initializationData = abi.encode(
|
33
|
+
registry,
|
34
|
+
tokenRegistry,
|
35
|
+
stakingStore,
|
35
36
|
initialOwner);
|
36
37
|
|
37
38
|
IVersionable versionable = deploy(
|
38
|
-
|
39
|
-
|
39
|
+
_initialImplementation,
|
40
|
+
_initializationData);
|
40
41
|
|
41
42
|
_staking = Staking(address(versionable));
|
42
43
|
}
|
43
44
|
|
44
45
|
//--- view functions ----------------------------------------------------//
|
46
|
+
|
45
47
|
function getStaking()
|
46
48
|
external
|
47
49
|
view
|
@@ -49,4 +51,4 @@ contract StakingManager is
|
|
49
51
|
{
|
50
52
|
return _staking;
|
51
53
|
}
|
52
|
-
}
|
54
|
+
}
|