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