@etherisc/gif-next 0.0.2-c5049d4-401 → 0.0.2-c554b1e-622
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 +27 -6
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1007 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +744 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +791 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +505 -245
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.json +24 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +673 -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 +273 -16
- 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 +396 -185
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +139 -15
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +19 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +68 -5
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +194 -214
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +261 -27
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +132 -128
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +334 -159
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +115 -65
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +119 -110
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +205 -66
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +2 -2
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +197 -185
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +261 -27
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +415 -319
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +258 -28
- 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 +278 -166
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +644 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +175 -151
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +321 -183
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +644 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +787 -333
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +644 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +193 -45
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +218 -39
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +140 -95
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +260 -61
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +734 -321
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +205 -90
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +834 -221
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +166 -171
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +69 -49
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +498 -347
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +853 -0
- 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 +46 -5
- 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 +151 -171
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +243 -29
- 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 +113 -104
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +69 -11
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +127 -123
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +151 -81
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +95 -41
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +146 -142
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +261 -27
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +156 -262
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +79 -81
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +84 -111
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +133 -135
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +279 -247
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +146 -153
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +456 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +490 -390
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +133 -51
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +163 -50
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +77 -39
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +260 -195
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +261 -27
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +308 -158
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +106 -72
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +110 -9
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +199 -21
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +168 -54
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +105 -52
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +246 -176
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +65 -6
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +264 -170
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +293 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +102 -64
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +181 -116
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +89 -51
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +256 -191
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +138 -67
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +88 -38
- 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 +117 -17
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +144 -41
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +161 -53
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +600 -440
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +878 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +109 -185
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +68 -34
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +1954 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +47 -6
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +417 -249
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +66 -8
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +4 -4
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +105 -83
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +473 -514
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +94 -76
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +55 -2
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +509 -4
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
- 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 +92 -65
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +431 -284
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +113 -104
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +36 -0
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +36 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +16 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +148 -0
- 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 +55 -2
- 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 +126 -122
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +42 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -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 +18 -2
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +3 -3
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +152 -38
- 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 +55 -2
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +327 -73
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +88 -24
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +172 -98
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +148 -16
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +267 -178
- 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 +46 -5
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +96 -50
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +31 -63
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +199 -55
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +77 -39
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +185 -130
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +33 -23
- 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 +33 -9
- 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 +28 -4
- 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 +3 -3
- 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 +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -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 +33 -31
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
- 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 +69 -7
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +79 -15
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- 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/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- 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 +16 -3
- 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/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +44 -12
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/accounting/AccountingService.sol +262 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +45 -0
- package/contracts/authorization/AccessAdmin.sol +342 -230
- package/contracts/authorization/AccessAdminLib.sol +183 -0
- package/contracts/authorization/AccessManagerCloneable.sol +146 -4
- package/contracts/authorization/Authorization.sol +350 -202
- package/contracts/authorization/IAccess.sol +1 -0
- package/contracts/authorization/IAccessAdmin.sol +69 -34
- package/contracts/authorization/IAuthorization.sol +33 -7
- package/contracts/authorization/IServiceAuthorization.sol +3 -1
- package/contracts/authorization/ServiceAuthorization.sol +26 -10
- package/contracts/distribution/BasicDistribution.sol +15 -12
- package/contracts/distribution/BasicDistributionAuthorization.sol +22 -9
- package/contracts/distribution/Distribution.sol +41 -47
- package/contracts/distribution/DistributionService.sol +128 -79
- package/contracts/distribution/DistributionServiceManager.sol +1 -1
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +22 -20
- package/contracts/examples/fire/DamageLevel.sol +5 -2
- package/contracts/examples/fire/FirePool.sol +25 -10
- package/contracts/examples/fire/FirePoolAuthorization.sol +2 -1
- package/contracts/examples/fire/FireProduct.sol +106 -59
- package/contracts/examples/fire/FireProductAuthorization.sol +14 -8
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +39 -4
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +4 -4
- package/contracts/examples/unpermissioned/SimplePool.sol +37 -7
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +53 -27
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +42 -38
- package/contracts/instance/IInstance.sol +59 -17
- package/contracts/instance/IInstanceService.sol +22 -30
- package/contracts/instance/Instance.sol +108 -41
- package/contracts/instance/InstanceAdmin.sol +287 -122
- package/contracts/instance/InstanceAuthorizationV3.sol +90 -59
- package/contracts/instance/InstanceReader.sol +259 -39
- package/contracts/instance/InstanceService.sol +178 -182
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/InstanceStore.sol +13 -2
- package/contracts/instance/RiskSet.sol +118 -0
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +4 -2
- package/contracts/instance/base/ObjectSet.sol +31 -33
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IComponents.sol +13 -8
- package/contracts/instance/module/IDistribution.sol +5 -2
- package/contracts/instance/module/IPolicy.sol +4 -3
- package/contracts/instance/module/IRisk.sol +3 -0
- package/contracts/oracle/BasicOracle.sol +0 -1
- package/contracts/oracle/BasicOracleAuthorization.sol +3 -12
- package/contracts/oracle/IOracleService.sol +2 -1
- package/contracts/oracle/Oracle.sol +5 -16
- package/contracts/oracle/OracleService.sol +108 -79
- package/contracts/oracle/OracleServiceManager.sol +1 -1
- package/contracts/pool/BasicPool.sol +33 -24
- package/contracts/pool/BasicPoolAuthorization.sol +27 -9
- package/contracts/pool/BundleService.sol +88 -131
- package/contracts/pool/BundleServiceManager.sol +1 -1
- package/contracts/pool/IBundleService.sol +15 -34
- package/contracts/pool/IPoolComponent.sol +19 -15
- package/contracts/pool/IPoolService.sol +70 -65
- package/contracts/pool/Pool.sol +136 -117
- package/contracts/pool/PoolLib.sol +216 -0
- package/contracts/pool/PoolService.sol +483 -234
- package/contracts/pool/PoolServiceManager.sol +1 -1
- package/contracts/product/ApplicationService.sol +41 -19
- package/contracts/product/ApplicationServiceManager.sol +1 -1
- package/contracts/product/BasicProduct.sol +10 -12
- package/contracts/product/BasicProductAuthorization.sol +24 -11
- package/contracts/product/ClaimService.sol +246 -160
- package/contracts/product/ClaimServiceManager.sol +1 -1
- package/contracts/product/IApplicationService.sol +6 -2
- package/contracts/product/IClaimService.sol +17 -4
- package/contracts/product/IPolicyService.sol +27 -9
- package/contracts/product/IPricingService.sol +9 -9
- package/contracts/product/IProductComponent.sol +27 -4
- package/contracts/product/IRiskService.sol +5 -8
- package/contracts/product/PolicyService.sol +262 -249
- package/contracts/product/PolicyServiceLib.sol +65 -0
- package/contracts/product/PolicyServiceManager.sol +1 -1
- package/contracts/product/PricingService.sol +30 -26
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +119 -75
- package/contracts/product/RiskService.sol +79 -31
- package/contracts/product/RiskServiceManager.sol +1 -1
- package/contracts/registry/ChainNft.sol +10 -11
- package/contracts/registry/IRegistry.sol +16 -18
- package/contracts/registry/IRegistryService.sol +5 -12
- package/contracts/registry/IRelease.sol +26 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +36 -8
- package/contracts/registry/RegistryAdmin.sol +145 -351
- package/contracts/registry/RegistryAuthorization.sol +267 -0
- package/contracts/registry/RegistryService.sol +36 -47
- package/contracts/registry/RegistryServiceManager.sol +1 -1
- package/contracts/registry/ReleaseAdmin.sol +253 -0
- package/contracts/registry/ReleaseLifecycle.sol +8 -3
- package/contracts/registry/ReleaseRegistry.sol +271 -245
- package/contracts/registry/ServiceAuthorizationV3.sol +182 -50
- package/contracts/registry/TokenRegistry.sol +6 -8
- package/contracts/shared/Component.sol +69 -110
- package/contracts/shared/ComponentService.sol +421 -373
- package/contracts/shared/ComponentServiceManager.sol +1 -1
- package/contracts/shared/ComponentVerifyingService.sol +27 -16
- package/contracts/shared/ContractLib.sol +246 -3
- package/contracts/shared/IComponent.sol +8 -17
- package/contracts/shared/IComponentService.sol +40 -38
- package/contracts/shared/IInstanceLinkedComponent.sol +3 -22
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IRegisterable.sol +23 -1
- package/contracts/shared/IService.sol +3 -5
- package/contracts/shared/InitializableERC165.sol +9 -1
- package/contracts/shared/InstanceLinkedComponent.sol +69 -44
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +27 -7
- package/contracts/shared/PolicyHolder.sol +5 -1
- package/contracts/shared/Registerable.sol +50 -19
- package/contracts/shared/RegistryLinked.sol +7 -13
- package/contracts/shared/Service.sol +9 -31
- package/contracts/shared/TokenHandler.sol +275 -72
- package/contracts/shared/TokenHandlerDeployerLib.sol +10 -2
- package/contracts/staking/IStaking.sol +17 -10
- package/contracts/staking/IStakingService.sol +16 -4
- package/contracts/staking/Staking.sol +95 -47
- package/contracts/staking/{StakeManagerLib.sol → StakingLib.sol} +80 -23
- package/contracts/staking/StakingReader.sol +18 -21
- package/contracts/staking/StakingService.sol +81 -24
- package/contracts/staking/StakingServiceManager.sol +5 -4
- package/contracts/staking/StakingStore.sol +2 -1
- package/contracts/type/Amount.sol +15 -0
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +6 -0
- package/contracts/type/ObjectType.sol +54 -35
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/RiskId.sol +26 -8
- package/contracts/type/RoleId.sol +23 -15
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/StateId.sol +14 -1
- package/contracts/type/Timestamp.sol +0 -5
- package/contracts/type/UFixed.sol +13 -119
- package/contracts/type/Version.sol +54 -5
- package/contracts/upgradeability/ProxyManager.sol +2 -1
- package/package.json +5 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +0 -290
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +0 -390
- 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/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -440
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -16
- package/contracts/authorization/IModuleAuthorization.sol +0 -21
- package/contracts/authorization/ModuleAuthorization.sol +0 -78
- package/contracts/instance/module/IAccess.sol +0 -46
- package/contracts/shared/InitializableCustom.sol +0 -177
@@ -1,83 +1,67 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {Create2} from "@openzeppelin/contracts/utils/Create2.sol";
|
5
4
|
import {Clones} from "@openzeppelin/contracts/proxy/Clones.sol";
|
6
|
-
import {IAccessManager} from "@openzeppelin/contracts/access/manager/IAccessManager.sol";
|
7
|
-
import {Initializable} from "@openzeppelin/contracts/proxy/utils/Initializable.sol";
|
8
5
|
import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
|
9
|
-
import {Math} from "@openzeppelin/contracts/utils/math/Math.sol";
|
10
|
-
|
11
|
-
import {NftId} from "../type/NftId.sol";
|
12
|
-
import {RoleId, ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
|
13
|
-
import {ObjectType, ObjectTypeLib, POOL, RELEASE, REGISTRY, SERVICE, STAKING} from "../type/ObjectType.sol";
|
14
|
-
import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
|
15
|
-
import {Timestamp, TimestampLib, zeroTimestamp, ltTimestamp} from "../type/Timestamp.sol";
|
16
|
-
import {Seconds, SecondsLib} from "../type/Seconds.sol";
|
17
|
-
import {StateId, INITIAL, SCHEDULED, DEPLOYING, ACTIVE, PAUSED, CLOSED} from "../type/StateId.sol";
|
18
|
-
import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
|
19
|
-
|
20
|
-
import {IService} from "../shared/IService.sol";
|
21
|
-
import {ILifecycle} from "../shared/ILifecycle.sol";
|
22
|
-
import {INftOwnable} from "../shared/INftOwnable.sol";
|
23
|
-
import {IRegisterable} from "../shared/IRegisterable.sol";
|
24
6
|
|
7
|
+
import {IAccessAdmin} from "../authorization/IAccessAdmin.sol";
|
8
|
+
import {AccessManagerCloneable} from "../authorization/AccessManagerCloneable.sol";
|
25
9
|
import {IRegistry} from "./IRegistry.sol";
|
10
|
+
import {IRelease} from "./IRelease.sol";
|
26
11
|
import {IRegistryLinked} from "../shared/IRegistryLinked.sol";
|
27
|
-
import {
|
12
|
+
import {IService} from "../shared/IService.sol";
|
28
13
|
import {IServiceAuthorization} from "../authorization/IServiceAuthorization.sol";
|
29
|
-
|
14
|
+
|
15
|
+
import {ContractLib} from "../shared/ContractLib.sol";
|
16
|
+
import {NftId} from "../type/NftId.sol";
|
17
|
+
import {ObjectType, ObjectTypeLib, POOL, RELEASE, REGISTRY, SERVICE, STAKING} from "../type/ObjectType.sol";
|
30
18
|
import {RegistryAdmin} from "./RegistryAdmin.sol";
|
31
19
|
import {Registry} from "./Registry.sol";
|
32
|
-
import {
|
20
|
+
import {ReleaseAdmin} from "./ReleaseAdmin.sol";
|
33
21
|
import {ReleaseLifecycle} from "./ReleaseLifecycle.sol";
|
34
|
-
|
22
|
+
import {Seconds} from "../type/Seconds.sol";
|
23
|
+
import {StateId, SCHEDULED, DEPLOYING, DEPLOYED, SKIPPED, ACTIVE, PAUSED} from "../type/StateId.sol";
|
24
|
+
import {TimestampLib, zeroTimestamp} from "../type/Timestamp.sol";
|
25
|
+
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
26
|
+
|
27
|
+
/// @dev The ReleaseRegistry manages the lifecycle of major GIF releases and their services.
|
28
|
+
/// The creation of a new GIF release is a multi-step process:
|
29
|
+
/// 1. The creation of a new GIF release is initiated by the GIF admin.
|
30
|
+
/// 2. A GIF manager then prepares the release by setting up the service authorization contract.
|
31
|
+
/// 3. The GIF manager deploys and registers all related service contracts with the release registry.
|
32
|
+
/// 4. The GIF admin verifies and activates the release.
|
33
|
+
/// 3. The GIF admin may pause and resume a release.
|
35
34
|
contract ReleaseRegistry is
|
36
35
|
AccessManaged,
|
37
36
|
ReleaseLifecycle,
|
38
37
|
IRegistryLinked
|
39
38
|
{
|
40
|
-
|
41
|
-
|
42
|
-
uint256 public constant INITIAL_GIF_VERSION = 3;
|
39
|
+
uint256 public constant INITIAL_GIF_VERSION = 3;// first active release version
|
43
40
|
|
44
|
-
event LogReleaseCreation(VersionPart
|
45
|
-
event LogReleaseActivation(VersionPart
|
46
|
-
event LogReleaseDisabled(VersionPart
|
47
|
-
event LogReleaseEnabled(VersionPart
|
41
|
+
event LogReleaseCreation(IAccessAdmin admin, VersionPart release, bytes32 salt);
|
42
|
+
event LogReleaseActivation(VersionPart release);
|
43
|
+
event LogReleaseDisabled(VersionPart release);
|
44
|
+
event LogReleaseEnabled(VersionPart release);
|
48
45
|
|
49
46
|
// constructor
|
50
47
|
error ErrorReleaseRegistryNotRegistry(Registry registry);
|
51
48
|
|
52
|
-
//
|
53
|
-
error
|
54
|
-
|
55
|
-
|
56
|
-
error ErrorReleaseRegistryReleasePreparationDisallowed(VersionPart version, StateId currentStateId);
|
57
|
-
error ErrorReleaseRegistryReleaseAlreadyPrepared(VersionPart version, StateId currentStateId);
|
58
|
-
error ErrorReleaseRegistryVersionMismatch(VersionPart expected, VersionPart actual);
|
59
|
-
error ErrorReleaseRegistryNoDomains(VersionPart version);
|
49
|
+
// _verifyServiceAuthorization
|
50
|
+
error ErrorReleaseRegistryNotServiceAuth(address notAuth);
|
51
|
+
error ErrorReleaseRegistryServiceAuthVersionMismatch(IServiceAuthorization auth, VersionPart expected, VersionPart actual);
|
52
|
+
error ErrorReleaseRegistryServiceAuthDomainsZero(IServiceAuthorization auth, VersionPart release);
|
60
53
|
|
61
54
|
// registerService
|
62
|
-
error ErrorReleaseRegistryNoServiceRegistrationExpected();
|
63
|
-
error ErrorReleaseRegistryServiceRegistrationDisallowed(StateId currentStateId);
|
64
|
-
error ErrorReleaseRegistryServiceDomainMismatch(ObjectType expectedDomain, ObjectType actualDomain);
|
65
|
-
error ErrorReleaseRegistryNotService(address notService);
|
66
55
|
error ErrorReleaseRegistryServiceAddressMismatch(address expected, address actual);
|
67
56
|
|
68
57
|
// activateNextRelease
|
69
|
-
error
|
70
|
-
error ErrorReleaseRegistryReleaseNotCreated(VersionPart releaseVersion);
|
71
|
-
error ErrorReleaseRegistryReleaseRegistrationNotFinished(VersionPart releaseVersion, uint awaitingRegistration);
|
72
|
-
error ErrorReleaseRegistryReleaseAlreadyActivated(VersionPart releaseVersion);
|
73
|
-
|
74
|
-
// disableRelease
|
75
|
-
error ErrorReleaseRegistryReleaseNotActivated(VersionPart releaseVersion);
|
76
|
-
error ErrorReleaseRegistryReleaseAlreadyDisabled(VersionPart releaseVersion);
|
58
|
+
error ErrorReleaseRegistryRegistryServiceMissing(VersionPart releaseVersion);
|
77
59
|
|
78
60
|
// _verifyService
|
79
|
-
error
|
80
|
-
error
|
61
|
+
error ErrorReleaseRegistryNotService(address notService);
|
62
|
+
error ErrorReleaseRegistryServiceAuthorityMismatch(IService service, address serviceAuthority, address releaseAuthority);
|
63
|
+
error ErrorReleaseRegistryServiceVersionMismatch(IService service, VersionPart serviceVersion, VersionPart releaseVersion);
|
64
|
+
error ErrorReleaseRegistryServiceDomainMismatch(IService service, ObjectType expectedDomain, ObjectType actualDomain);
|
81
65
|
|
82
66
|
// _verifyServiceInfo
|
83
67
|
error ErrorReleaseRegistryServiceInfoAddressInvalid(IService service, address expected);
|
@@ -87,55 +71,60 @@ contract ReleaseRegistry is
|
|
87
71
|
error ErrorReleaseRegistryServiceSelfRegistration(IService service);
|
88
72
|
error ErrorReleaseRegistryServiceOwnerRegistered(IService service, address owner);
|
89
73
|
|
90
|
-
|
91
|
-
|
92
|
-
RegistryAdmin public immutable _admin;
|
74
|
+
RegistryAdmin public immutable _registryAdmin;
|
93
75
|
Registry public immutable _registry;
|
94
|
-
IRegisterable private _staking;
|
95
|
-
address private _stakingOwner;
|
96
76
|
|
97
|
-
mapping(VersionPart
|
98
|
-
|
77
|
+
mapping(VersionPart release => IRelease.ReleaseInfo info) internal _releaseInfo;
|
78
|
+
VersionPart [] internal _release; // array of all created releases
|
79
|
+
ReleaseAdmin internal _masterReleaseAdmin;
|
99
80
|
|
100
|
-
|
101
|
-
|
81
|
+
VersionPart internal _latest; // latest active release
|
82
|
+
VersionPart internal _next; // release version to create and activate
|
102
83
|
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
mapping(VersionPart verson => StateId releaseState) private _state;
|
107
|
-
|
108
|
-
uint256 internal _registeredServices;
|
109
|
-
uint256 internal _servicesToRegister;
|
84
|
+
// counters per release
|
85
|
+
uint256 internal _registeredServices = 0;
|
86
|
+
uint256 internal _servicesToRegister = 0;
|
110
87
|
|
88
|
+
// TODO move master relase admin outside constructor (same construction as for registry admin)
|
111
89
|
constructor(Registry registry)
|
112
90
|
AccessManaged(msg.sender)
|
113
91
|
{
|
114
|
-
|
115
|
-
if(!_isRegistry(address(registry))) {
|
92
|
+
if (!ContractLib.isRegistry(address(registry))) {
|
116
93
|
revert ErrorReleaseRegistryNotRegistry(registry);
|
117
94
|
}
|
118
95
|
|
119
96
|
setAuthority(registry.getAuthority());
|
120
97
|
|
121
98
|
_registry = registry;
|
122
|
-
|
99
|
+
_registryAdmin = RegistryAdmin(_registry.getRegistryAdminAddress());
|
100
|
+
_masterReleaseAdmin = new ReleaseAdmin(
|
101
|
+
_cloneNewAccessManager());
|
123
102
|
|
124
|
-
_initial = VersionPartLib.toVersionPart(INITIAL_GIF_VERSION);
|
125
103
|
_next = VersionPartLib.toVersionPart(INITIAL_GIF_VERSION - 1);
|
126
104
|
}
|
127
105
|
|
128
|
-
/// @dev
|
129
|
-
///
|
106
|
+
/// @dev Initiates the creation of a new GIF release by the GIF admin.
|
107
|
+
/// Sets previous release into SKIPPED state if it was created but not activated.
|
108
|
+
/// Sets the new release into state SCHEDULED.
|
130
109
|
function createNextRelease()
|
131
110
|
external
|
132
111
|
restricted() // GIF_ADMIN_ROLE
|
133
112
|
returns(VersionPart)
|
134
113
|
{
|
135
|
-
|
114
|
+
VersionPart release = _next;
|
115
|
+
|
116
|
+
if(isValidTransition(RELEASE(), _releaseInfo[release].state, SKIPPED())) {
|
117
|
+
_releaseInfo[release].state = SKIPPED();
|
118
|
+
}
|
119
|
+
|
120
|
+
release = VersionPartLib.toVersionPart(release.toInt() + 1);
|
121
|
+
_release.push(release);
|
122
|
+
|
123
|
+
_next = release;
|
124
|
+
_releaseInfo[release].version = release;
|
125
|
+
_releaseInfo[release].state = getInitialState(RELEASE());
|
136
126
|
_servicesToRegister = 0;
|
137
127
|
_registeredServices = 0;
|
138
|
-
_state[_next] = getInitialState(RELEASE());
|
139
128
|
|
140
129
|
return _next;
|
141
130
|
}
|
@@ -147,51 +136,39 @@ contract ReleaseRegistry is
|
|
147
136
|
external
|
148
137
|
restricted() // GIF_MANAGER_ROLE
|
149
138
|
returns(
|
150
|
-
|
151
|
-
VersionPart
|
139
|
+
ReleaseAdmin releaseAdmin,
|
140
|
+
VersionPart releaseVersion,
|
152
141
|
bytes32 releaseSalt
|
153
142
|
)
|
154
143
|
{
|
155
|
-
|
156
|
-
|
144
|
+
releaseVersion = _next;
|
145
|
+
|
146
|
+
// release can transition into DEPLOYING state
|
147
|
+
checkTransition(_releaseInfo[releaseVersion].state, RELEASE(), SCHEDULED(), DEPLOYING());
|
148
|
+
|
149
|
+
// verify authorizations
|
150
|
+
uint256 serviceDomainsCount = _verifyServiceAuthorization(serviceAuthorization, releaseVersion, salt);
|
151
|
+
|
152
|
+
// create and initialize release admin
|
153
|
+
releaseAdmin = _cloneNewReleaseAdmin(releaseVersion);
|
154
|
+
releaseSalt = salt;
|
157
155
|
|
158
156
|
// ensures unique salt
|
159
157
|
// TODO CreateX have clones capability also
|
160
158
|
// what would releaseSalt look like if used with CreateX in pemissioned mode?
|
161
|
-
releaseSalt = keccak256(
|
159
|
+
/*releaseSalt = keccak256(
|
162
160
|
bytes.concat(
|
163
|
-
bytes32(
|
164
|
-
salt))
|
165
|
-
|
166
|
-
// verify release in state SCHEDULED
|
167
|
-
if (!isValidTransition(RELEASE(), _state[version], DEPLOYING())) {
|
168
|
-
revert ErrorReleaseRegistryReleasePreparationDisallowed(version, _state[version]);
|
169
|
-
}
|
170
|
-
|
171
|
-
_state[version] = DEPLOYING();
|
172
|
-
|
173
|
-
// verify authorizaion contract release matches with expected version
|
174
|
-
VersionPart releaseVersion = serviceAuthorization.getRelease();
|
175
|
-
if (releaseVersion != version) {
|
176
|
-
revert ErrorReleaseRegistryVersionMismatch(version, releaseVersion);
|
177
|
-
}
|
178
|
-
|
179
|
-
|
180
|
-
// sanity check to ensure service domain list is not empty
|
181
|
-
uint256 serviceDomainsCount = serviceAuthorization.getServiceDomains().length;
|
182
|
-
if (serviceDomainsCount == 0) {
|
183
|
-
revert ErrorReleaseRegistryNoDomains(version);
|
184
|
-
}
|
185
|
-
|
186
|
-
// verify prepareNextRelease is only called once per release
|
187
|
-
if(_servicesToRegister > 0) {
|
188
|
-
revert ErrorReleaseRegistryReleaseAlreadyPrepared(version, _state[version]);
|
189
|
-
}
|
161
|
+
bytes32(releaseVersion.toInt()),
|
162
|
+
salt));*/
|
190
163
|
|
191
164
|
_servicesToRegister = serviceDomainsCount;
|
192
|
-
|
165
|
+
_releaseInfo[releaseVersion].state = DEPLOYING();
|
166
|
+
_releaseInfo[releaseVersion].salt = releaseSalt;
|
167
|
+
// TODO allow for the same serviceAuthorization address to be used for multiple releases?
|
168
|
+
_releaseInfo[releaseVersion].auth = serviceAuthorization;
|
169
|
+
_releaseInfo[releaseVersion].releaseAdmin = address(releaseAdmin);
|
193
170
|
|
194
|
-
emit LogReleaseCreation(
|
171
|
+
emit LogReleaseCreation(releaseAdmin, releaseVersion, releaseSalt);
|
195
172
|
}
|
196
173
|
|
197
174
|
function registerService(IService service)
|
@@ -200,136 +177,118 @@ contract ReleaseRegistry is
|
|
200
177
|
returns(NftId nftId)
|
201
178
|
{
|
202
179
|
VersionPart releaseVersion = _next;
|
203
|
-
StateId state = _state[releaseVersion];
|
204
180
|
|
205
|
-
//
|
206
|
-
|
207
|
-
// TOOD name must represent failed state transition
|
208
|
-
revert ErrorReleaseRegistryServiceRegistrationDisallowed(state);
|
209
|
-
}
|
181
|
+
// release can transition to DEPLOYED state
|
182
|
+
checkTransition(_releaseInfo[releaseVersion].state, RELEASE(), DEPLOYING(), DEPLOYED());
|
210
183
|
|
211
|
-
|
184
|
+
address releaseAuthority = ReleaseAdmin(_releaseInfo[releaseVersion].releaseAdmin).authority();
|
185
|
+
IServiceAuthorization releaseAuth = _releaseInfo[releaseVersion].auth;
|
186
|
+
ObjectType expectedDomain = releaseAuth.getServiceDomain(_registeredServices);
|
212
187
|
|
213
|
-
//
|
214
|
-
if (_servicesToRegister == _registeredServices) {
|
215
|
-
revert ErrorReleaseRegistryNoServiceRegistrationExpected();
|
216
|
-
}
|
217
|
-
|
218
|
-
// service can work with release manager
|
188
|
+
// service can work with release registry and release version
|
219
189
|
(
|
220
190
|
IRegistry.ObjectInfo memory info,
|
221
191
|
ObjectType serviceDomain,
|
222
192
|
VersionPart serviceVersion
|
223
|
-
|
193
|
+
//,string memory serviceName
|
194
|
+
) = _verifyService(
|
195
|
+
service,
|
196
|
+
releaseAuthority,
|
197
|
+
releaseVersion,
|
198
|
+
expectedDomain
|
199
|
+
);
|
200
|
+
|
201
|
+
//_releaseInfo[releaseVersion].addresses.push(address(service)); // TODO get this info from auth contract?
|
202
|
+
//_releaseInfo[releaseVersion].domains.push(serviceDomain);
|
203
|
+
//_releaseInfo[releaseVersion].names.push(serviceName); // TODO if needed read in _verifyService()
|
224
204
|
|
225
|
-
//
|
226
|
-
|
227
|
-
|
228
|
-
|
205
|
+
_registeredServices++; // TODO use releaseInfo.someArray.length instead of _registeredServices
|
206
|
+
|
207
|
+
// release fully deployed
|
208
|
+
if(_servicesToRegister == _registeredServices) {
|
209
|
+
_releaseInfo[releaseVersion].state = DEPLOYED();
|
229
210
|
}
|
230
211
|
|
231
|
-
//
|
232
|
-
//
|
233
|
-
nftId = _registry.registerService(info, serviceVersion, serviceDomain);
|
234
|
-
service.linkToRegisteredNftId();
|
235
|
-
_registeredServices++;
|
212
|
+
// TODO: service address matches defined in release auth (precalculated one)
|
213
|
+
// revert ErrorReleaseRegistryServiceAddressMismatch()
|
236
214
|
|
237
215
|
// setup service authorization
|
238
|
-
|
239
|
-
|
240
|
-
|
216
|
+
ReleaseAdmin releaseAdmin = ReleaseAdmin(_releaseInfo[releaseVersion].releaseAdmin);
|
217
|
+
releaseAdmin.setReleaseLocked(false);
|
218
|
+
releaseAdmin.authorizeService(
|
219
|
+
releaseAuth,
|
241
220
|
service,
|
242
221
|
serviceDomain,
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
//
|
247
|
-
|
248
|
-
|
249
|
-
serviceDomain == STAKING() ||
|
250
|
-
serviceDomain == POOL())
|
251
|
-
{
|
252
|
-
_admin.grantServiceRoleForAllVersions(service, serviceDomain);
|
253
|
-
}
|
222
|
+
releaseVersion);
|
223
|
+
releaseAdmin.setReleaseLocked(true);
|
224
|
+
|
225
|
+
// register service with registry
|
226
|
+
nftId = _registry.registerService(info, serviceVersion, serviceDomain);
|
227
|
+
service.linkToRegisteredNftId();
|
254
228
|
}
|
255
229
|
|
256
230
|
|
231
|
+
// TODO return activated version
|
257
232
|
function activateNextRelease()
|
258
233
|
external
|
259
234
|
restricted // GIF_ADMIN_ROLE
|
260
235
|
{
|
261
|
-
VersionPart
|
262
|
-
StateId state = _state[version];
|
263
|
-
StateId newState = ACTIVE();
|
236
|
+
VersionPart release = _next;
|
264
237
|
|
265
|
-
//
|
266
|
-
|
267
|
-
revert ErrorReleaseRegistryReleaseActivationDisallowed(version, state);
|
268
|
-
}
|
238
|
+
// release can transition to ACTIVE state
|
239
|
+
checkTransition(_releaseInfo[release].state, RELEASE(), DEPLOYED(), ACTIVE());
|
269
240
|
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
241
|
+
_latest = release;
|
242
|
+
_releaseInfo[release].state = ACTIVE();
|
243
|
+
_releaseInfo[release].activatedAt = TimestampLib.blockTimestamp();
|
244
|
+
_releaseInfo[release].disabledAt = TimestampLib.max();
|
274
245
|
|
275
|
-
//
|
276
|
-
|
246
|
+
// grant special roles for registry/staking/pool services
|
247
|
+
// this will enable access to core contracts functions
|
248
|
+
|
249
|
+
// registry service MUST be registered for each release
|
250
|
+
address service = _registry.getServiceAddress(REGISTRY(), release);
|
277
251
|
if(service == address(0)) {
|
278
|
-
revert
|
252
|
+
revert ErrorReleaseRegistryRegistryServiceMissing(release);
|
279
253
|
}
|
280
254
|
|
281
|
-
|
282
|
-
_state[version] = newState;
|
283
|
-
|
284
|
-
_releaseVersionByAddress[service] = version;
|
285
|
-
_releaseInfo[version].activatedAt = TimestampLib.blockTimestamp();
|
286
|
-
|
287
|
-
emit LogReleaseActivation(version);
|
288
|
-
}
|
289
|
-
|
290
|
-
/// @dev stop all operations with release services
|
291
|
-
function pauseRelease(VersionPart version)
|
292
|
-
external
|
293
|
-
restricted // GIF_ADMIN_ROLE
|
294
|
-
{
|
295
|
-
StateId state = _state[version];
|
296
|
-
StateId newState = PAUSED();
|
255
|
+
_registryAdmin.grantServiceRoleForAllVersions(IService(service), REGISTRY());
|
297
256
|
|
298
|
-
|
299
|
-
if
|
300
|
-
|
257
|
+
service = _registry.getServiceAddress(STAKING(), release);
|
258
|
+
if(service != address(0)) {
|
259
|
+
_registryAdmin.grantServiceRoleForAllVersions(IService(service), STAKING());
|
301
260
|
}
|
302
261
|
|
303
|
-
|
304
|
-
|
262
|
+
service = _registry.getServiceAddress(POOL(), release);
|
263
|
+
if(service != address(0)) {
|
264
|
+
_registryAdmin.grantServiceRoleForAllVersions(IService(service), POOL());
|
265
|
+
}
|
305
266
|
|
306
|
-
|
307
|
-
_releaseInfo[version].disabledAt = TimestampLib.blockTimestamp();
|
267
|
+
_setReleaseLocked(release, false);
|
308
268
|
|
309
|
-
emit
|
269
|
+
emit LogReleaseActivation(release);
|
310
270
|
}
|
311
271
|
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
restricted // GIF_ADMIN_ROLE
|
272
|
+
/// @dev stop/resume operations with restricted functions
|
273
|
+
function setActive(VersionPart release, bool active)
|
274
|
+
public
|
275
|
+
restricted
|
317
276
|
{
|
318
|
-
StateId state =
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
277
|
+
StateId state = _releaseInfo[release].state;
|
278
|
+
|
279
|
+
if(active) {
|
280
|
+
checkTransition(state, RELEASE(), PAUSED(), ACTIVE());
|
281
|
+
_releaseInfo[release].state = ACTIVE();
|
282
|
+
_releaseInfo[release].disabledAt = TimestampLib.max();
|
283
|
+
emit LogReleaseEnabled(release);
|
284
|
+
} else {
|
285
|
+
checkTransition(state, RELEASE(), ACTIVE(), PAUSED());
|
286
|
+
_releaseInfo[release].state = PAUSED();
|
287
|
+
_releaseInfo[release].disabledAt = TimestampLib.blockTimestamp();
|
288
|
+
emit LogReleaseDisabled(release);
|
324
289
|
}
|
325
290
|
|
326
|
-
|
327
|
-
// _releaseAccessManager[version].enable();
|
328
|
-
|
329
|
-
_state[version] = newState;
|
330
|
-
_releaseInfo[version].disabledAt = zeroTimestamp();
|
331
|
-
|
332
|
-
emit LogReleaseEnabled(version);
|
291
|
+
_setReleaseLocked(release, !active);
|
333
292
|
}
|
334
293
|
|
335
294
|
//--- view functions ----------------------------------------------------//
|
@@ -342,49 +301,55 @@ contract ReleaseRegistry is
|
|
342
301
|
return Clones.predictDeterministicAddress(implementation, salt, deployer);
|
343
302
|
}
|
344
303
|
|
345
|
-
function
|
346
|
-
|
347
|
-
return isActiveRelease(version);
|
304
|
+
function isActiveRelease(VersionPart release) public view returns(bool) {
|
305
|
+
return _releaseInfo[release].state == ACTIVE();
|
348
306
|
}
|
349
307
|
|
350
|
-
function
|
351
|
-
return
|
308
|
+
function getReleaseInfo(VersionPart release) external view returns(IRelease.ReleaseInfo memory) {
|
309
|
+
return _releaseInfo[release];
|
352
310
|
}
|
353
311
|
|
354
|
-
|
355
|
-
|
312
|
+
/// @dev Returns the number of created releases.
|
313
|
+
/// Releases might be in another state than ACTIVE.
|
314
|
+
function releases() external view returns (uint) {
|
315
|
+
return _release.length;
|
316
|
+
}
|
317
|
+
|
318
|
+
/// @dev Returns the n-th release version.
|
319
|
+
/// Valid values for idx [0 .. releases() - 1]
|
320
|
+
function getVersion(uint256 idx) external view returns (VersionPart release) {
|
321
|
+
// return _releases;
|
322
|
+
return _release[idx];
|
356
323
|
}
|
357
324
|
|
358
325
|
function getNextVersion() public view returns(VersionPart) {
|
359
326
|
return _next;
|
360
327
|
}
|
361
328
|
|
329
|
+
/// @dev Returns the latest activated relase version.
|
330
|
+
/// There is no guarantee that the release is not currently paused.
|
362
331
|
function getLatestVersion() external view returns(VersionPart) {
|
363
332
|
return _latest;
|
364
333
|
}
|
365
334
|
|
366
|
-
function
|
367
|
-
return
|
368
|
-
}
|
369
|
-
|
370
|
-
function getState(VersionPart version) external view returns (StateId stateId) {
|
371
|
-
return _state[version];
|
335
|
+
function getState(VersionPart release) external view returns (StateId stateId) {
|
336
|
+
return _releaseInfo[release].state;
|
372
337
|
}
|
373
338
|
|
374
339
|
function getRemainingServicesToRegister() external view returns (uint256 services) {
|
375
340
|
return _servicesToRegister - _registeredServices;
|
376
341
|
}
|
377
342
|
|
378
|
-
function getServiceAuthorization(VersionPart
|
343
|
+
function getServiceAuthorization(VersionPart release)
|
379
344
|
external
|
380
345
|
view
|
381
346
|
returns (IServiceAuthorization serviceAuthorization)
|
382
347
|
{
|
383
|
-
return
|
348
|
+
return _releaseInfo[release].auth;
|
384
349
|
}
|
385
350
|
|
386
351
|
function getRegistryAdmin() external view returns (address) {
|
387
|
-
return address(
|
352
|
+
return address(_registryAdmin);
|
388
353
|
}
|
389
354
|
|
390
355
|
//--- IRegistryLinked ------------------------------------------------------//
|
@@ -395,7 +360,82 @@ contract ReleaseRegistry is
|
|
395
360
|
|
396
361
|
//--- private functions ----------------------------------------------------//
|
397
362
|
|
398
|
-
function
|
363
|
+
function _setReleaseLocked(VersionPart release, bool locked)
|
364
|
+
private
|
365
|
+
{
|
366
|
+
ReleaseAdmin(
|
367
|
+
_releaseInfo[release].releaseAdmin).setReleaseLocked(locked);
|
368
|
+
}
|
369
|
+
|
370
|
+
function _cloneNewReleaseAdmin(VersionPart release)
|
371
|
+
private
|
372
|
+
returns (ReleaseAdmin clonedAdmin)
|
373
|
+
{
|
374
|
+
// clone and setup release specific release admin
|
375
|
+
clonedAdmin = ReleaseAdmin(
|
376
|
+
Clones.clone(address(_masterReleaseAdmin)));
|
377
|
+
|
378
|
+
string memory releaseAdminName = string(
|
379
|
+
abi.encodePacked(
|
380
|
+
"ReleaseAdmin_v",
|
381
|
+
release.toString()));
|
382
|
+
|
383
|
+
clonedAdmin.initialize(
|
384
|
+
address(_cloneNewAccessManager()),
|
385
|
+
releaseAdminName);
|
386
|
+
|
387
|
+
clonedAdmin.completeSetup(
|
388
|
+
address(_registry),
|
389
|
+
address(this), // release registry (this contract)
|
390
|
+
release);
|
391
|
+
|
392
|
+
// lock release (remains locked until activation)
|
393
|
+
clonedAdmin.setReleaseLocked(true);
|
394
|
+
}
|
395
|
+
|
396
|
+
|
397
|
+
function _cloneNewAccessManager()
|
398
|
+
private
|
399
|
+
returns (address accessManager)
|
400
|
+
{
|
401
|
+
return Clones.clone(address(_registryAdmin.authority()));
|
402
|
+
}
|
403
|
+
|
404
|
+
|
405
|
+
function _verifyServiceAuthorization(
|
406
|
+
IServiceAuthorization serviceAuthorization,
|
407
|
+
VersionPart releaseVersion,
|
408
|
+
bytes32 salt
|
409
|
+
)
|
410
|
+
private
|
411
|
+
view
|
412
|
+
returns (uint256 serviceDomainsCount)
|
413
|
+
{
|
414
|
+
// authorization contract supports IServiceAuthorization interface
|
415
|
+
if(!serviceAuthorization.supportsInterface(type(IServiceAuthorization).interfaceId)) {
|
416
|
+
revert ErrorReleaseRegistryNotServiceAuth(address(serviceAuthorization));
|
417
|
+
}
|
418
|
+
|
419
|
+
// authorizaions contract version matches with release version
|
420
|
+
VersionPart authVersion = serviceAuthorization.getRelease();
|
421
|
+
if (releaseVersion != authVersion) {
|
422
|
+
revert ErrorReleaseRegistryServiceAuthVersionMismatch(serviceAuthorization, releaseVersion, authVersion);
|
423
|
+
}
|
424
|
+
|
425
|
+
// sanity check to ensure service domain list is not empty
|
426
|
+
serviceDomainsCount = serviceAuthorization.getServiceDomains().length;
|
427
|
+
if (serviceDomainsCount == 0) {
|
428
|
+
revert ErrorReleaseRegistryServiceAuthDomainsZero(serviceAuthorization, releaseVersion);
|
429
|
+
}
|
430
|
+
}
|
431
|
+
|
432
|
+
// TODO get service names
|
433
|
+
function _verifyService(
|
434
|
+
IService service,
|
435
|
+
address expectedAuthority,
|
436
|
+
VersionPart expectedVersion,
|
437
|
+
ObjectType expectedDomain
|
438
|
+
)
|
399
439
|
internal
|
400
440
|
view
|
401
441
|
returns(
|
@@ -416,22 +456,25 @@ contract ReleaseRegistry is
|
|
416
456
|
|
417
457
|
_verifyServiceInfo(service, serviceInfo, owner);
|
418
458
|
|
419
|
-
VersionPart releaseVersion = _next; // never 0
|
420
|
-
address expectedAuthority = _admin.authority(); // can be zero if registering service when release is not created
|
421
|
-
|
422
|
-
// IMPORTANT: can not guarantee service access is actually controlled by authority
|
423
459
|
if(serviceAuthority != expectedAuthority) {
|
424
|
-
revert
|
460
|
+
revert ErrorReleaseRegistryServiceAuthorityMismatch(
|
425
461
|
service,
|
426
462
|
serviceAuthority,
|
427
463
|
expectedAuthority);
|
428
464
|
}
|
429
465
|
|
430
|
-
if(serviceVersion !=
|
431
|
-
revert
|
466
|
+
if(serviceVersion != expectedVersion) {
|
467
|
+
revert ErrorReleaseRegistryServiceVersionMismatch(
|
432
468
|
service,
|
433
469
|
serviceVersion,
|
434
|
-
|
470
|
+
expectedVersion);
|
471
|
+
}
|
472
|
+
|
473
|
+
if(serviceDomain != expectedDomain) {
|
474
|
+
revert ErrorReleaseRegistryServiceDomainMismatch(
|
475
|
+
service,
|
476
|
+
expectedDomain,
|
477
|
+
serviceDomain);
|
435
478
|
}
|
436
479
|
}
|
437
480
|
|
@@ -445,7 +488,7 @@ contract ReleaseRegistry is
|
|
445
488
|
view
|
446
489
|
{
|
447
490
|
if(info.objectAddress != address(service)) {
|
448
|
-
revert ErrorReleaseRegistryServiceInfoAddressInvalid(service,
|
491
|
+
revert ErrorReleaseRegistryServiceInfoAddressInvalid(service, info.objectAddress);
|
449
492
|
}
|
450
493
|
|
451
494
|
if(info.isInterceptor != false) { // service is never interceptor
|
@@ -470,22 +513,5 @@ contract ReleaseRegistry is
|
|
470
513
|
revert ErrorReleaseRegistryServiceOwnerRegistered(service, owner);
|
471
514
|
}
|
472
515
|
}
|
473
|
-
|
474
|
-
/// @dev returns true iff a the address passes some simple proxy tests.
|
475
|
-
function _isRegistry(address registryAddress) internal view returns (bool) {
|
476
|
-
|
477
|
-
// zero address is certainly not registry
|
478
|
-
if (registryAddress == address(0)) {
|
479
|
-
return false;
|
480
|
-
}
|
481
|
-
// TODO try catch and return false in case of revert
|
482
|
-
// or just panic
|
483
|
-
// check if contract returns a zero nft id for its own address
|
484
|
-
if (IRegistry(registryAddress).getNftIdForAddress(registryAddress).eqz()) {
|
485
|
-
return false;
|
486
|
-
}
|
487
|
-
|
488
|
-
return true;
|
489
|
-
}
|
490
516
|
}
|
491
517
|
|