@etherisc/gif-next 0.0.2-95b223b-528 → 0.0.2-95f0eec-843
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 +57 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +134 -59
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +93 -49
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +85 -9
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +640 -269
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +1289 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +202 -5
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +409 -33
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +525 -213
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +179 -19
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +246 -16
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +420 -27
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +105 -153
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +381 -46
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +58 -95
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +533 -218
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +149 -81
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +45 -82
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +379 -79
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +145 -114
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +355 -52
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +183 -144
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +380 -45
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +163 -169
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +380 -45
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +94 -68
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +175 -141
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +355 -52
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +259 -146
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +380 -45
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +88 -45
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +474 -48
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +377 -10
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +485 -83
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +999 -334
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +380 -52
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +724 -412
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +381 -77
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +82 -56
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +434 -358
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +1 -1
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +96 -53
- 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/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +16 -5
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
- 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/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +77 -49
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +379 -47
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +49 -21
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +56 -3
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +61 -33
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +120 -68
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +98 -54
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +102 -82
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +355 -52
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +304 -226
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +119 -75
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +200 -89
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +59 -31
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +333 -169
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +72 -44
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +522 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +574 -360
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +145 -73
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +292 -62
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +105 -45
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +87 -59
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +380 -45
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +171 -174
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +120 -84
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +234 -3
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +63 -17
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +160 -68
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +77 -3
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +70 -42
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +150 -7
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +278 -187
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +783 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +128 -84
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +135 -126
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +102 -74
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +81 -53
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +218 -76
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +102 -46
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +51 -16
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +56 -3
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/{authorization/AccessAdmin.sol/IAccessManagedChecker.json → registry/IRelease.sol/IRelease.json} +6 -6
- 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 +89 -54
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +728 -480
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +1053 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +75 -39
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +78 -42
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +2152 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +385 -63
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +437 -26
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +15 -15
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +60 -32
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +211 -250
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +104 -68
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +178 -34
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +49 -21
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +131 -153
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +49 -21
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- 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 +19 -0
- 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 +139 -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 +56 -3
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +2 -2
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +60 -32
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +21 -2
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +137 -62
- 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 +51 -11
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +63 -162
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +118 -29
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +32 -32
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +268 -39
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +163 -10
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +341 -103
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +469 -0
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +2 -2
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +112 -50
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +90 -61
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +218 -58
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +95 -47
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +162 -148
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +60 -50
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +10 -10
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- 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 +93 -37
- 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/Key32Set.sol/LibKey32Set.dbg.json +1 -1
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +2 -2
- 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 +33 -31
- 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 +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +30 -6
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +42 -157
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +50 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +60 -36
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +101 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.json +10 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +64 -26
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +15 -2
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.json +10 -0
- package/contracts/accounting/AccountingService.sol +18 -7
- package/contracts/accounting/AccountingServiceManager.sol +1 -1
- package/contracts/accounting/IAccountingService.sol +4 -2
- package/contracts/authorization/AccessAdmin.sol +419 -254
- package/contracts/authorization/AccessAdminLib.sol +396 -0
- package/contracts/authorization/AccessManagerCloneable.sol +146 -4
- package/contracts/authorization/Authorization.sol +142 -262
- package/contracts/authorization/IAccess.sol +25 -7
- package/contracts/authorization/IAccessAdmin.sol +87 -80
- package/contracts/authorization/IAuthorization.sol +9 -42
- package/contracts/authorization/IServiceAuthorization.sol +55 -17
- package/contracts/authorization/ServiceAuthorization.sol +247 -33
- package/contracts/distribution/BasicDistribution.sol +13 -11
- package/contracts/distribution/BasicDistributionAuthorization.sol +29 -9
- package/contracts/distribution/Distribution.sol +18 -58
- package/contracts/distribution/DistributionService.sol +168 -77
- package/contracts/distribution/DistributionServiceManager.sol +1 -1
- package/contracts/distribution/IDistributionComponent.sol +3 -10
- package/contracts/distribution/IDistributionService.sol +34 -19
- package/contracts/examples/fire/FirePool.sol +0 -4
- package/contracts/examples/fire/FirePoolAuthorization.sol +1 -1
- package/contracts/examples/fire/FireProduct.sol +2 -7
- package/contracts/examples/fire/FireProductAuthorization.sol +1 -1
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +32 -8
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +1 -1
- package/contracts/examples/unpermissioned/SimpleOracle.sol +4 -8
- package/contracts/examples/unpermissioned/SimplePool.sol +0 -5
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +1 -1
- package/contracts/examples/unpermissioned/SimpleProduct.sol +26 -11
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +1 -1
- package/contracts/instance/BundleSet.sol +4 -4
- package/contracts/instance/IInstance.sol +91 -17
- package/contracts/instance/IInstanceService.sol +50 -4
- package/contracts/instance/Instance.sol +159 -52
- package/contracts/instance/InstanceAdmin.sol +265 -170
- package/contracts/instance/InstanceAuthorizationV3.sol +75 -34
- package/contracts/instance/InstanceReader.sol +415 -379
- package/contracts/instance/InstanceService.sol +251 -144
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/RiskSet.sol +11 -12
- package/contracts/instance/base/BalanceStore.sol +3 -5
- package/contracts/instance/base/ObjectLifecycle.sol +0 -3
- package/contracts/instance/base/ObjectSet.sol +7 -8
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IBundle.sol +6 -5
- package/contracts/instance/module/IComponents.sol +16 -5
- package/contracts/instance/module/IDistribution.sol +21 -8
- package/contracts/instance/module/IPolicy.sol +28 -8
- package/contracts/instance/module/IRisk.sol +4 -0
- package/contracts/oracle/BasicOracle.sol +1 -3
- package/contracts/oracle/BasicOracleAuthorization.sol +15 -8
- package/contracts/oracle/IOracle.sol +9 -4
- package/contracts/oracle/Oracle.sol +1 -3
- package/contracts/oracle/OracleService.sol +20 -19
- package/contracts/oracle/OracleServiceManager.sol +1 -1
- package/contracts/pool/BasicPool.sol +2 -15
- package/contracts/pool/BasicPoolAuthorization.sol +29 -16
- package/contracts/pool/BundleService.sol +55 -94
- package/contracts/pool/BundleServiceManager.sol +1 -1
- package/contracts/pool/IBundleService.sol +27 -32
- package/contracts/pool/IPoolService.sol +57 -40
- package/contracts/pool/Pool.sol +11 -23
- package/contracts/pool/PoolLib.sol +341 -0
- package/contracts/pool/PoolService.sol +192 -193
- package/contracts/pool/PoolServiceManager.sol +1 -1
- package/contracts/product/ApplicationService.sol +85 -17
- package/contracts/product/ApplicationServiceManager.sol +1 -1
- package/contracts/product/BasicProduct.sol +0 -2
- package/contracts/product/BasicProductAuthorization.sol +31 -9
- package/contracts/product/ClaimService.sol +127 -169
- package/contracts/product/ClaimServiceManager.sol +1 -1
- package/contracts/product/IApplicationService.sol +23 -1
- package/contracts/product/IClaimService.sol +2 -3
- package/contracts/product/IPolicyService.sol +20 -8
- package/contracts/product/IPricingService.sol +1 -0
- package/contracts/product/IRiskService.sol +11 -7
- package/contracts/product/PolicyService.sol +104 -195
- package/contracts/product/PolicyServiceLib.sol +139 -0
- package/contracts/product/PolicyServiceManager.sol +1 -1
- package/contracts/product/PricingService.sol +38 -35
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +30 -21
- package/contracts/product/RiskService.sol +85 -29
- package/contracts/product/RiskServiceManager.sol +1 -1
- package/contracts/registry/IRegistry.sol +21 -19
- package/contracts/registry/IRelease.sol +29 -0
- package/contracts/registry/Registry.sol +19 -8
- package/contracts/registry/RegistryAdmin.sol +100 -369
- package/contracts/registry/RegistryAuthorization.sol +284 -0
- package/contracts/registry/RegistryService.sol +4 -4
- package/contracts/registry/RegistryServiceManager.sol +1 -1
- package/contracts/registry/ReleaseAdmin.sol +195 -0
- package/contracts/registry/ReleaseLifecycle.sol +2 -0
- package/contracts/registry/ReleaseRegistry.sol +150 -116
- package/contracts/registry/ServiceAuthorizationV3.sol +159 -22
- package/contracts/registry/TokenRegistry.sol +12 -13
- package/contracts/shared/Component.sol +17 -26
- package/contracts/shared/ComponentService.sol +263 -283
- package/contracts/shared/ComponentServiceManager.sol +1 -1
- package/contracts/shared/ContractLib.sol +163 -76
- package/contracts/shared/IComponent.sol +1 -5
- package/contracts/shared/IComponentService.sol +21 -26
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IRegisterable.sol +15 -5
- package/contracts/shared/IService.sol +3 -5
- package/contracts/shared/InitializableERC165.sol +9 -1
- package/contracts/shared/InstanceLinkedComponent.sol +4 -7
- package/contracts/shared/NftOwnable.sol +8 -6
- package/contracts/shared/PolicyHolder.sol +4 -3
- package/contracts/shared/Registerable.sol +42 -19
- package/contracts/shared/RegistryLinked.sol +1 -1
- package/contracts/shared/Service.sol +13 -30
- package/contracts/shared/TokenHandler.sol +45 -92
- package/contracts/staking/IStaking.sol +41 -19
- package/contracts/staking/IStakingService.sol +21 -8
- package/contracts/staking/Staking.sol +159 -69
- package/contracts/staking/{StakeManagerLib.sol → StakingLib.sol} +80 -23
- package/contracts/staking/StakingReader.sol +28 -19
- package/contracts/staking/StakingService.sol +74 -46
- package/contracts/staking/StakingServiceManager.sol +5 -4
- package/contracts/staking/StakingStore.sol +3 -2
- package/contracts/staking/TargetManagerLib.sol +1 -1
- package/contracts/type/Fee.sol +8 -8
- package/contracts/type/ObjectType.sol +69 -52
- package/contracts/type/RiskId.sol +9 -3
- package/contracts/type/RoleId.sol +63 -45
- package/contracts/type/Seconds.sol +4 -0
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/String.sol +12 -0
- package/contracts/type/Timestamp.sol +0 -5
- package/contracts/type/UFixed.sol +27 -10
- package/contracts/type/Version.sol +54 -5
- package/contracts/upgradeability/IVersionable.sol +3 -0
- package/contracts/upgradeability/ProxyManager.sol +26 -12
- package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +7 -1
- package/contracts/upgradeability/Versionable.sol +6 -3
- package/package.json +2 -2
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +0 -4
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +0 -4
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json +0 -1196
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +0 -4
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +0 -474
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -440
- package/contracts/authorization/ReleaseAccessManager.sol +0 -38
- package/contracts/instance/module/IAccess.sol +0 -46
- package/contracts/shared/ComponentVerifyingService.sol +0 -128
@@ -3,9 +3,10 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
|
-
import {Amount} from "../type/Amount.sol";
|
7
6
|
import {IService} from "../shared/IService.sol";
|
8
7
|
import {IStaking} from "./IStaking.sol";
|
8
|
+
|
9
|
+
import {Amount} from "../type/Amount.sol";
|
9
10
|
import {NftId} from "../type/NftId.sol";
|
10
11
|
import {Seconds} from "../type/Seconds.sol";
|
11
12
|
import {TokenHandler} from "../shared/TokenHandler.sol";
|
@@ -26,27 +27,31 @@ interface IStakingService is IService
|
|
26
27
|
event LogStakingServiceStakeCreated(NftId stakeNftId, NftId targetNftId, address owner, Amount stakedAmount);
|
27
28
|
event LogStakingServiceStakeIncreased(NftId stakeNftId, address owner, Amount stakedAmount, Amount stakeBalance);
|
28
29
|
event LogStakingServiceUnstaked(NftId stakeNftId, address stakeOwner, Amount totalAmount);
|
30
|
+
event LogStakingServiceStakeRestaked(address stakeOwner, NftId indexed stakeNftId, NftId newStakeNftId, NftId indexed newTargetNftId, Amount indexed newStakeBalance);
|
29
31
|
|
30
32
|
event LogStakingServiceRewardsUpdated(NftId stakeNftId);
|
31
33
|
event LogStakingServiceRewardsClaimed(NftId stakeNftId, address stakeOwner, Amount rewardsClaimedAmount);
|
32
34
|
|
33
35
|
// modifiers
|
36
|
+
error ErrorStakingServiceNotStakingOwner(address account);
|
34
37
|
error ErrorStakingServiceNotStaking(address stakingAddress);
|
35
38
|
error ErrorStakingServiceNotSupportingIStaking(address stakingAddress);
|
36
39
|
|
37
40
|
// create
|
41
|
+
error ErrorStakingServiceTargetUnknown(NftId targetNftId);
|
38
42
|
error ErrorStakingServiceZeroTargetNftId();
|
39
43
|
error ErrorStakingServiceNotTargetNftId(NftId targetNftId);
|
40
44
|
error ErrorStakingServiceNotActiveTargetNftId(NftId targetNftId);
|
41
45
|
error ErrorStakingServiceDipBalanceInsufficient(NftId targetNftId, uint256 amount, uint256 balance);
|
42
46
|
error ErrorStakingServiceDipAllowanceInsufficient(NftId targetNftId, address tokenHandler, uint256 amount, uint256 allowance);
|
43
47
|
|
44
|
-
|
45
|
-
///
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
48
|
+
|
49
|
+
/// @dev Approves the staking token handler.
|
50
|
+
/// Reverts if the staking token handler wallet is not the token handler itself.
|
51
|
+
function approveTokenHandler(
|
52
|
+
IERC20Metadata token,
|
53
|
+
Amount amount
|
54
|
+
) external;
|
50
55
|
|
51
56
|
/// @dev creates/registers an on-chain instance staking target.
|
52
57
|
/// function granted to instance service
|
@@ -64,6 +69,10 @@ interface IStakingService is IService
|
|
64
69
|
/// Permissioned: Only owner of the specified target.
|
65
70
|
function setInstanceRewardRate(NftId instanceNftId, UFixed rewardRate) external;
|
66
71
|
|
72
|
+
/// @dev Set the instance max staked amount to the specified value.
|
73
|
+
/// Permissioned: Only owner of the specified target.
|
74
|
+
function setInstanceMaxStakedAmount(NftId instanceNftId, Amount maxStakingAmount) external;
|
75
|
+
|
67
76
|
/// @dev (Re)fills the staking reward reserves for the specified target using the dips provided by the reward provider.
|
68
77
|
/// unpermissioned: anybody may fill up staking reward reserves
|
69
78
|
function refillInstanceRewardReserves(NftId instanceNftId, address rewardProvider, Amount dipAmount) external returns (Amount newBalance);
|
@@ -108,7 +117,8 @@ interface IStakingService is IService
|
|
108
117
|
)
|
109
118
|
external
|
110
119
|
returns (
|
111
|
-
NftId newStakeNftId
|
120
|
+
NftId newStakeNftId,
|
121
|
+
Amount newStakeBalance
|
112
122
|
);
|
113
123
|
|
114
124
|
|
@@ -145,13 +155,16 @@ interface IStakingService is IService
|
|
145
155
|
|
146
156
|
function getDipToken()
|
147
157
|
external
|
158
|
+
view
|
148
159
|
returns (IERC20Metadata dip);
|
149
160
|
|
150
161
|
function getTokenHandler()
|
151
162
|
external
|
163
|
+
view
|
152
164
|
returns (TokenHandler tokenHandler);
|
153
165
|
|
154
166
|
function getStaking()
|
155
167
|
external
|
168
|
+
view
|
156
169
|
returns (IStaking staking);
|
157
170
|
}
|
@@ -4,7 +4,7 @@ pragma solidity ^0.8.20;
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
6
|
import {IRegistry} from "../registry/IRegistry.sol";
|
7
|
-
import {
|
7
|
+
import {IRelease} from "../registry/IRelease.sol";
|
8
8
|
import {IStaking} from "./IStaking.sol";
|
9
9
|
import {IVersionable} from "../upgradeability/IVersionable.sol";
|
10
10
|
|
@@ -13,9 +13,10 @@ import {Component} from "../shared/Component.sol";
|
|
13
13
|
import {IComponent} from "../shared/IComponent.sol";
|
14
14
|
import {IComponentService} from "../shared/IComponentService.sol";
|
15
15
|
import {NftId} from "../type/NftId.sol";
|
16
|
-
import {ObjectType,
|
16
|
+
import {ObjectType, STAKE, STAKING} from "../type/ObjectType.sol";
|
17
17
|
import {Seconds} from "../type/Seconds.sol";
|
18
|
-
import {
|
18
|
+
import {Registerable} from "../shared/Registerable.sol";
|
19
|
+
import {StakingLib} from "./StakingLib.sol";
|
19
20
|
import {StakingReader} from "./StakingReader.sol";
|
20
21
|
import {StakingStore} from "./StakingStore.sol";
|
21
22
|
import {TargetManagerLib} from "./TargetManagerLib.sol";
|
@@ -24,7 +25,7 @@ import {TokenHandler} from "../shared/TokenHandler.sol";
|
|
24
25
|
import {TokenHandlerDeployerLib} from "../shared/TokenHandlerDeployerLib.sol";
|
25
26
|
import {TokenRegistry} from "../registry/TokenRegistry.sol";
|
26
27
|
import {UFixed} from "../type/UFixed.sol";
|
27
|
-
import {Version, VersionLib} from "../type/Version.sol";
|
28
|
+
import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
|
28
29
|
import {Versionable} from "../upgradeability/Versionable.sol";
|
29
30
|
|
30
31
|
contract Staking is
|
@@ -38,7 +39,6 @@ contract Staking is
|
|
38
39
|
bytes32 public constant STAKING_LOCATION_V1 = 0xafe8d4462b2ed26a47154f4b8f6d1497d2f772496965791d25bd456e342b7f00;
|
39
40
|
|
40
41
|
struct StakingStorage {
|
41
|
-
IRegistryService _registryService;
|
42
42
|
TokenRegistry _tokenRegistry;
|
43
43
|
TokenHandler _tokenHandler;
|
44
44
|
StakingStore _store;
|
@@ -62,49 +62,60 @@ contract Staking is
|
|
62
62
|
_;
|
63
63
|
}
|
64
64
|
|
65
|
+
//--- contract intitialization -------------------------------------------
|
66
|
+
|
65
67
|
function initializeTokenHandler()
|
66
68
|
external
|
69
|
+
virtual
|
67
70
|
{
|
68
71
|
if (msg.sender != address(getRegistry())) {
|
69
72
|
revert ErrorStakingNotRegistry(msg.sender);
|
70
73
|
}
|
71
74
|
|
72
75
|
StakingStorage storage $ = _getStakingStorage();
|
76
|
+
address dipToken = _getStakingStorage()._tokenRegistry.getDipTokenAddress();
|
73
77
|
$._tokenHandler = TokenHandlerDeployerLib.deployTokenHandler(
|
74
78
|
address(getRegistry()),
|
75
79
|
address(this),
|
76
|
-
|
80
|
+
dipToken,
|
77
81
|
getRegistry().getAuthority());
|
78
82
|
}
|
79
83
|
|
84
|
+
//--- staking owner functions -------------------------------------------//
|
80
85
|
|
81
|
-
|
82
|
-
|
86
|
+
// TODO also make sure that protocol rewards can be refilled and withdrawn
|
87
|
+
|
88
|
+
/// @inheritdoc IStaking
|
89
|
+
function setProtocolRewardRate(UFixed rewardRate)
|
90
|
+
external
|
91
|
+
virtual
|
83
92
|
restricted()
|
84
93
|
onlyOwner()
|
85
94
|
{
|
86
|
-
|
95
|
+
NftId protocolNftId = getRegistry().getProtocolNftId();
|
96
|
+
UFixed oldRewardRate = _updateRewardRate(protocolNftId, rewardRate);
|
97
|
+
emit LogStakingProtocolRewardRateSet(protocolNftId, oldRewardRate, rewardRate);
|
87
98
|
}
|
88
99
|
|
89
100
|
|
90
|
-
|
91
|
-
function
|
101
|
+
/// @inheritdoc IStaking
|
102
|
+
function setProtocolLockingPeriod(Seconds lockingPeriod)
|
92
103
|
external
|
93
104
|
virtual
|
105
|
+
restricted()
|
94
106
|
onlyOwner()
|
95
107
|
{
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
_getStakingStorage()._reader = stakingReader;
|
108
|
+
NftId protocolNftId = getRegistry().getProtocolNftId();
|
109
|
+
Seconds oldLockingPeriod = _updateLockingPeriod(protocolNftId, lockingPeriod);
|
110
|
+
emit LogStakingProtocolLockingPeriodSet(protocolNftId, oldLockingPeriod, lockingPeriod);
|
101
111
|
}
|
102
112
|
|
103
113
|
|
104
|
-
|
114
|
+
/// @inheritdoc IStaking
|
105
115
|
function setStakingRate(uint256 chainId, address token, UFixed stakingRate)
|
106
116
|
external
|
107
117
|
virtual
|
118
|
+
restricted()
|
108
119
|
onlyOwner()
|
109
120
|
{
|
110
121
|
StakingStorage storage $ = _getStakingStorage();
|
@@ -119,7 +130,31 @@ contract Staking is
|
|
119
130
|
emit LogStakingStakingRateSet(chainId, token, oldStakingRate, stakingRate);
|
120
131
|
}
|
121
132
|
|
122
|
-
|
133
|
+
|
134
|
+
/// @inheritdoc IStaking
|
135
|
+
function setStakingReader(StakingReader stakingReader)
|
136
|
+
external
|
137
|
+
virtual
|
138
|
+
onlyOwner()
|
139
|
+
{
|
140
|
+
if(stakingReader.getStaking() != IStaking(this)) {
|
141
|
+
revert ErrorStakingStakingReaderStakingMismatch(address(stakingReader.getStaking()));
|
142
|
+
}
|
143
|
+
|
144
|
+
_getStakingStorage()._reader = stakingReader;
|
145
|
+
}
|
146
|
+
|
147
|
+
|
148
|
+
/// @inheritdoc IStaking
|
149
|
+
function approveTokenHandler(IERC20Metadata token, Amount amount)
|
150
|
+
public
|
151
|
+
restricted()
|
152
|
+
onlyOwner()
|
153
|
+
{
|
154
|
+
_approveTokenHandler(token, amount);
|
155
|
+
}
|
156
|
+
|
157
|
+
//--- target management -------------------------------------------------//
|
123
158
|
|
124
159
|
function registerTarget(
|
125
160
|
NftId targetNftId,
|
@@ -146,7 +181,21 @@ contract Staking is
|
|
146
181
|
objectType: expectedObjectType,
|
147
182
|
chainId: chainId,
|
148
183
|
lockingPeriod: initialLockingPeriod,
|
149
|
-
rewardRate: initialRewardRate
|
184
|
+
rewardRate: initialRewardRate,
|
185
|
+
maxStakedAmount: AmountLib.max()}));
|
186
|
+
|
187
|
+
emit LogStakingTargetRegistered(targetNftId, expectedObjectType, initialLockingPeriod, initialRewardRate, AmountLib.max());
|
188
|
+
}
|
189
|
+
|
190
|
+
|
191
|
+
function setRewardRate(NftId targetNftId, UFixed rewardRate)
|
192
|
+
external
|
193
|
+
virtual
|
194
|
+
restricted()
|
195
|
+
onlyTarget(targetNftId)
|
196
|
+
{
|
197
|
+
UFixed oldRewardRate = _updateRewardRate(targetNftId, rewardRate);
|
198
|
+
emit LogStakingRewardRateSet(targetNftId, oldRewardRate, rewardRate);
|
150
199
|
}
|
151
200
|
|
152
201
|
|
@@ -159,39 +208,24 @@ contract Staking is
|
|
159
208
|
restricted()
|
160
209
|
onlyTarget(targetNftId)
|
161
210
|
{
|
162
|
-
(
|
163
|
-
Seconds oldLockingPeriod,
|
164
|
-
TargetInfo memory targetInfo
|
165
|
-
) = TargetManagerLib.updateLockingPeriod(
|
166
|
-
this,
|
167
|
-
targetNftId,
|
168
|
-
lockingPeriod);
|
169
|
-
|
170
|
-
_getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
|
171
|
-
|
211
|
+
Seconds oldLockingPeriod = _updateLockingPeriod(targetNftId, lockingPeriod);
|
172
212
|
emit LogStakingLockingPeriodSet(targetNftId, oldLockingPeriod, lockingPeriod);
|
173
213
|
}
|
174
214
|
|
175
|
-
// TODO add function to set protocol reward rate: onlyOwner
|
176
|
-
// get protocol nft id (from where)
|
177
215
|
|
178
|
-
function
|
216
|
+
function setMaxStakedAmount(NftId targetNftId, Amount maxStakedAmount)
|
179
217
|
external
|
180
218
|
virtual
|
181
219
|
restricted()
|
182
220
|
onlyTarget(targetNftId)
|
183
221
|
{
|
184
|
-
(
|
185
|
-
|
186
|
-
|
187
|
-
) = TargetManagerLib.updateRewardRate(
|
188
|
-
this,
|
189
|
-
targetNftId,
|
190
|
-
rewardRate);
|
222
|
+
IStaking.TargetInfo memory targetInfo = getStakingReader().getTargetInfo(targetNftId);
|
223
|
+
|
224
|
+
targetInfo.maxStakedAmount = maxStakedAmount;
|
191
225
|
|
192
226
|
_getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
|
193
227
|
|
194
|
-
emit
|
228
|
+
emit LogStakingMaxStakedAmountSet(targetNftId, maxStakedAmount);
|
195
229
|
}
|
196
230
|
|
197
231
|
|
@@ -226,7 +260,7 @@ contract Staking is
|
|
226
260
|
returns (Amount newBalance)
|
227
261
|
{
|
228
262
|
StakingStorage storage $ = _getStakingStorage();
|
229
|
-
|
263
|
+
uint256 chainId = $._reader.getTargetInfo(targetNftId).chainId;
|
230
264
|
UFixed stakingRate = $._reader.getStakingRate(chainId, token);
|
231
265
|
newBalance = $._store.increaseTotalValueLocked(targetNftId, stakingRate, token, amount);
|
232
266
|
}
|
@@ -239,7 +273,7 @@ contract Staking is
|
|
239
273
|
returns (Amount newBalance)
|
240
274
|
{
|
241
275
|
StakingStorage storage $ = _getStakingStorage();
|
242
|
-
|
276
|
+
uint256 chainId = $._reader.getTargetInfo(targetNftId).chainId;
|
243
277
|
UFixed stakingRate = $._reader.getStakingRate(chainId, token);
|
244
278
|
newBalance = $._store.decreaseTotalValueLocked(targetNftId, stakingRate, token, amount);
|
245
279
|
}
|
@@ -275,7 +309,7 @@ contract Staking is
|
|
275
309
|
restricted() // only staking service
|
276
310
|
{
|
277
311
|
StakingStorage storage $ = _getStakingStorage();
|
278
|
-
Timestamp lockedUntil =
|
312
|
+
Timestamp lockedUntil = StakingLib.checkCreateParameters(
|
279
313
|
$._reader,
|
280
314
|
targetNftId,
|
281
315
|
stakeAmount);
|
@@ -305,7 +339,7 @@ contract Staking is
|
|
305
339
|
returns (Amount stakeBalance)
|
306
340
|
{
|
307
341
|
StakingStorage storage $ = _getStakingStorage();
|
308
|
-
stakeBalance =
|
342
|
+
stakeBalance = StakingLib.stake(
|
309
343
|
getRegistry(),
|
310
344
|
$._reader,
|
311
345
|
$._store,
|
@@ -316,21 +350,26 @@ contract Staking is
|
|
316
350
|
|
317
351
|
function restake(
|
318
352
|
NftId stakeNftId,
|
319
|
-
NftId
|
353
|
+
NftId newStakeNftId
|
320
354
|
)
|
321
355
|
external
|
322
356
|
virtual
|
323
357
|
restricted() // only staking service
|
324
358
|
onlyStake(stakeNftId)
|
325
|
-
returns (
|
359
|
+
returns (Amount newStakeBalance)
|
326
360
|
{
|
361
|
+
_checkNftType(stakeNftId, STAKE());
|
362
|
+
_checkNftType(newStakeNftId, STAKE());
|
363
|
+
|
327
364
|
// TODO add check that allows additional staking amount
|
328
365
|
StakingStorage storage $ = _getStakingStorage();
|
329
|
-
|
330
|
-
|
366
|
+
newStakeBalance = StakingLib.restake(
|
367
|
+
$._reader,
|
368
|
+
$._store,
|
369
|
+
stakeNftId,
|
370
|
+
newStakeNftId);
|
331
371
|
}
|
332
372
|
|
333
|
-
|
334
373
|
function updateRewards(NftId stakeNftId)
|
335
374
|
external
|
336
375
|
virtual
|
@@ -379,7 +418,7 @@ contract Staking is
|
|
379
418
|
{
|
380
419
|
StakingStorage storage $ = _getStakingStorage();
|
381
420
|
|
382
|
-
|
421
|
+
StakingLib.checkUnstakeParameters($._reader, stakeNftId);
|
383
422
|
|
384
423
|
// update rewards since last update
|
385
424
|
NftId targetNftId = _updateRewards($._reader, $._store, stakeNftId);
|
@@ -401,15 +440,15 @@ contract Staking is
|
|
401
440
|
|
402
441
|
//--- view functions ----------------------------------------------------//
|
403
442
|
|
404
|
-
function getStakingReader() public view returns (StakingReader reader) {
|
443
|
+
function getStakingReader() public virtual view returns (StakingReader reader) {
|
405
444
|
return _getStakingStorage()._reader;
|
406
445
|
}
|
407
446
|
|
408
|
-
function getStakingStore() external view returns (StakingStore stakingStore) {
|
447
|
+
function getStakingStore() external virtual view returns (StakingStore stakingStore) {
|
409
448
|
return _getStakingStorage()._store;
|
410
449
|
}
|
411
450
|
|
412
|
-
function getTokenRegistryAddress() external view returns (address tokenRegistry) {
|
451
|
+
function getTokenRegistryAddress() external virtual view returns (address tokenRegistry) {
|
413
452
|
return address(_getStakingStorage()._tokenRegistry);
|
414
453
|
}
|
415
454
|
|
@@ -417,18 +456,65 @@ contract Staking is
|
|
417
456
|
return _getStakingStorage()._tokenHandler;
|
418
457
|
}
|
419
458
|
|
420
|
-
// from
|
459
|
+
// from IRegisterable
|
460
|
+
function getRelease()
|
461
|
+
public
|
462
|
+
pure
|
463
|
+
virtual override (IRelease, Registerable)
|
464
|
+
returns(VersionPart)
|
465
|
+
{
|
466
|
+
return VersionPartLib.toVersionPart(3);
|
467
|
+
}
|
468
|
+
|
469
|
+
// from IVersionable
|
421
470
|
function getVersion()
|
422
471
|
public
|
423
472
|
pure
|
424
|
-
virtual override (IVersionable, Versionable)
|
473
|
+
virtual override (Component, IVersionable, Versionable)
|
425
474
|
returns(Version)
|
426
475
|
{
|
427
|
-
return VersionLib.toVersion(
|
476
|
+
return VersionLib.toVersion(3,0,0);
|
428
477
|
}
|
429
478
|
|
430
479
|
//--- internal functions ------------------------------------------------//
|
431
480
|
|
481
|
+
function _updateRewardRate(
|
482
|
+
NftId targetNftId,
|
483
|
+
UFixed rewardRate
|
484
|
+
)
|
485
|
+
internal
|
486
|
+
virtual
|
487
|
+
returns (UFixed oldRewardRate)
|
488
|
+
{
|
489
|
+
|
490
|
+
TargetInfo memory targetInfo;
|
491
|
+
(oldRewardRate, targetInfo) = TargetManagerLib.updateRewardRate(
|
492
|
+
this,
|
493
|
+
targetNftId,
|
494
|
+
rewardRate);
|
495
|
+
|
496
|
+
_getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
|
497
|
+
}
|
498
|
+
|
499
|
+
|
500
|
+
function _updateLockingPeriod(
|
501
|
+
NftId targetNftId,
|
502
|
+
Seconds lockingPeriod
|
503
|
+
)
|
504
|
+
internal
|
505
|
+
virtual
|
506
|
+
returns (Seconds oldLockingPeriod)
|
507
|
+
{
|
508
|
+
TargetInfo memory targetInfo;
|
509
|
+
(oldLockingPeriod, targetInfo) = TargetManagerLib.updateLockingPeriod(
|
510
|
+
this,
|
511
|
+
targetNftId,
|
512
|
+
lockingPeriod);
|
513
|
+
|
514
|
+
_getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
|
515
|
+
}
|
516
|
+
|
517
|
+
|
432
518
|
function _updateRewards(
|
433
519
|
StakingReader reader,
|
434
520
|
StakingStore store,
|
@@ -441,7 +527,7 @@ contract Staking is
|
|
441
527
|
UFixed rewardRate;
|
442
528
|
|
443
529
|
(targetNftId, rewardRate) = reader.getTargetRewardRate(stakeNftId);
|
444
|
-
(Amount rewardIncrement, ) =
|
530
|
+
(Amount rewardIncrement, ) = StakingLib.calculateRewardIncrease(
|
445
531
|
reader,
|
446
532
|
stakeNftId,
|
447
533
|
rewardRate);
|
@@ -453,18 +539,21 @@ contract Staking is
|
|
453
539
|
}
|
454
540
|
|
455
541
|
|
456
|
-
function _approveTokenHandler(
|
542
|
+
function _approveTokenHandler(
|
543
|
+
IERC20Metadata token,
|
544
|
+
Amount amount)
|
457
545
|
internal
|
458
546
|
virtual override
|
459
547
|
{
|
460
|
-
IComponentService(_getServiceAddress(
|
548
|
+
IComponentService(_getServiceAddress(STAKING())).approveTokenHandler(
|
461
549
|
token,
|
462
550
|
amount);
|
463
551
|
}
|
464
552
|
|
465
553
|
|
554
|
+
/// @dev top level initializer (upgradable contract)
|
466
555
|
function _initialize(
|
467
|
-
address
|
556
|
+
address,
|
468
557
|
bytes memory data
|
469
558
|
)
|
470
559
|
internal
|
@@ -481,27 +570,28 @@ contract Staking is
|
|
481
570
|
// only admin(authority) and dip token address are set in registry at this point
|
482
571
|
IRegistry registry = IRegistry(registryAddress);
|
483
572
|
address authority = registry.getAuthority();
|
484
|
-
|
485
|
-
|
573
|
+
|
574
|
+
// wiring to external contracts
|
575
|
+
StakingStorage storage $ = _getStakingStorage();
|
576
|
+
$._protocolNftId = registry.getProtocolNftId();
|
577
|
+
$._store = StakingStore(stakingStoreAddress);
|
578
|
+
$._reader = StakingStore(stakingStoreAddress).getStakingReader();
|
579
|
+
$._tokenRegistry = TokenRegistry(tokenRegistryAddress);
|
486
580
|
|
487
581
|
_initializeComponent(
|
488
582
|
authority,
|
489
583
|
registryAddress,
|
490
584
|
registry.getNftId(), // parent nft id
|
491
585
|
CONTRACT_NAME,
|
492
|
-
dipTokenAddress,
|
493
586
|
STAKING(),
|
494
587
|
false, // is interceptor
|
495
588
|
stakingOwner,
|
496
589
|
"", // registry data
|
497
590
|
""); // component data
|
498
591
|
|
499
|
-
//
|
500
|
-
|
501
|
-
|
502
|
-
$._store = StakingStore(stakingStoreAddress);
|
503
|
-
$._reader = StakingStore(stakingStoreAddress).getStakingReader();
|
504
|
-
$._tokenRegistry = TokenRegistry(tokenRegistryAddress);
|
592
|
+
// HINT: protocol target is created in the StakingStore constructor.
|
593
|
+
// This allows setting up the protocol target before the full
|
594
|
+
// staking authorization setup is in place.
|
505
595
|
|
506
596
|
_registerInterface(type(IStaking).interfaceId);
|
507
597
|
}
|