@etherisc/gif-next 0.0.2-ff282a4-523 → 0.0.2-ffa91a6-022
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 +77 -10
- 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 +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1494 -0
- 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 +4 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1403 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +615 -0
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → authorization/IAccess.sol/IAccess.json} +2 -2
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1224 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +382 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +167 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +253 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1209 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +644 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +152 -598
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +470 -446
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +200 -112
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +164 -335
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +340 -109
- 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 +1445 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +644 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2002 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +644 -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 +1388 -0
- 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 +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1152 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1612 -0
- 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 +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2389 -0
- 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 +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +851 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +262 -79
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +274 -88
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +278 -196
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +2036 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +716 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1386 -502
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +308 -239
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +161 -83
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1417 -536
- 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 +4 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +192 -0
- 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 +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +938 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +632 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +753 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +733 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +854 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +997 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +764 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1231 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +644 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +333 -360
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +196 -92
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +215 -70
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +214 -423
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +509 -356
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +223 -624
- 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 +641 -689
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +202 -102
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +205 -244
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +170 -78
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1140 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +644 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +442 -332
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +204 -104
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +155 -9
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +327 -16
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +399 -69
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +195 -82
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +367 -231
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +100 -62
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +446 -394
- 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 +183 -115
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +265 -318
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +193 -97
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +403 -503
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +688 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +736 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +462 -56
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +251 -127
- 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 +905 -121
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +2018 -0
- 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 +303 -245
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +159 -81
- 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 +4 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1337 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +272 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +315 -139
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +109 -296
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1172 -247
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +816 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +485 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +597 -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 +116 -141
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +1196 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +688 -0
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +46 -14
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +35 -4
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +23 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +16 -30
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +154 -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 +74 -2
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +776 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +538 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +174 -0
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +26 -55
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +20 -124
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +129 -90
- 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 +67 -102
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +615 -6
- 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 +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1301 -119
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +684 -62
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +1567 -176
- 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 +4 -0
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +205 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +232 -63
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +560 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +762 -179
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +177 -73
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2297 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +617 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +121 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +53 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +39 -34
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/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 +66 -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 +153 -4
- 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 +4 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +125 -7
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +283 -6
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +124 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +148 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
- package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +36 -4
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +71 -2
- 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 +120 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +618 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.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 +704 -0
- package/contracts/authorization/AccessAdminLib.sol +183 -0
- package/contracts/authorization/AccessManagerCloneable.sol +158 -0
- package/contracts/authorization/Authorization.sol +365 -0
- package/contracts/authorization/IAccess.sol +49 -0
- package/contracts/authorization/IAccessAdmin.sol +170 -0
- package/contracts/authorization/IAuthorization.sol +80 -0
- package/contracts/authorization/IServiceAuthorization.sol +40 -0
- package/contracts/authorization/ServiceAuthorization.sol +106 -0
- package/contracts/distribution/BasicDistribution.sol +141 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +60 -0
- package/contracts/distribution/Distribution.sol +134 -175
- package/contracts/distribution/DistributionService.sol +233 -197
- package/contracts/distribution/DistributionServiceManager.sol +13 -25
- package/contracts/distribution/IDistributionComponent.sol +22 -50
- package/contracts/distribution/IDistributionService.sol +45 -29
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +86 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
- package/contracts/examples/fire/FireProduct.sol +433 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +373 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +130 -0
- package/contracts/instance/IInstance.sol +76 -48
- package/contracts/instance/IInstanceService.sol +48 -37
- package/contracts/instance/Instance.sol +195 -128
- package/contracts/instance/InstanceAdmin.sol +450 -0
- package/contracts/instance/InstanceAuthorizationV3.sol +235 -0
- package/contracts/instance/InstanceReader.sol +358 -76
- package/contracts/instance/InstanceService.sol +327 -173
- package/contracts/instance/InstanceServiceManager.sol +14 -29
- package/contracts/instance/InstanceStore.sol +151 -64
- package/contracts/instance/RiskSet.sol +118 -0
- package/contracts/instance/base/BalanceStore.sol +123 -0
- package/contracts/instance/base/Cloneable.sol +2 -25
- package/contracts/instance/base/ObjectCounter.sol +20 -0
- package/contracts/instance/base/ObjectLifecycle.sol +113 -0
- package/contracts/instance/base/ObjectSet.sol +77 -0
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IBundle.sol +1 -4
- package/contracts/instance/module/IComponents.sol +24 -15
- package/contracts/instance/module/IDistribution.sol +5 -3
- package/contracts/instance/module/IPolicy.sol +33 -26
- package/contracts/instance/module/IRisk.sol +3 -0
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/BasicOracle.sol +45 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +37 -0
- package/contracts/oracle/IOracle.sol +36 -0
- package/contracts/oracle/IOracleComponent.sol +33 -0
- package/contracts/oracle/IOracleService.sol +66 -0
- package/contracts/oracle/Oracle.sol +154 -0
- package/contracts/oracle/OracleService.sol +310 -0
- package/contracts/oracle/OracleServiceManager.sol +39 -0
- package/contracts/pool/BasicPool.sol +173 -0
- package/contracts/pool/BasicPoolAuthorization.sol +76 -0
- package/contracts/pool/BundleService.sol +237 -224
- package/contracts/pool/BundleServiceManager.sol +13 -25
- package/contracts/pool/IBundleService.sol +35 -38
- package/contracts/pool/IPoolComponent.sol +23 -75
- package/contracts/pool/IPoolService.sol +107 -56
- package/contracts/pool/Pool.sol +209 -168
- package/contracts/pool/PoolLib.sol +216 -0
- package/contracts/pool/PoolService.sol +608 -256
- package/contracts/pool/PoolServiceManager.sol +12 -24
- package/contracts/product/ApplicationService.sol +173 -85
- package/contracts/product/ApplicationServiceManager.sol +12 -9
- package/contracts/product/BasicProduct.sol +49 -0
- package/contracts/product/BasicProductAuthorization.sol +56 -0
- package/contracts/product/ClaimService.sol +373 -183
- package/contracts/product/ClaimServiceManager.sol +12 -9
- package/contracts/product/IApplicationService.sol +10 -3
- package/contracts/product/IClaimService.sol +48 -6
- package/contracts/product/IPolicyService.sol +54 -39
- package/contracts/product/IPricingService.sol +14 -11
- package/contracts/product/IProductComponent.sol +31 -10
- package/contracts/product/IRiskService.sol +33 -0
- package/contracts/product/PolicyService.sol +522 -234
- package/contracts/product/PolicyServiceLib.sol +65 -0
- package/contracts/product/PolicyServiceManager.sol +12 -27
- package/contracts/product/PricingService.sol +117 -83
- package/contracts/product/PricingServiceManager.sol +12 -24
- package/contracts/product/Product.sol +236 -148
- package/contracts/product/RiskService.sol +154 -0
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +72 -39
- package/contracts/registry/IRegistry.sol +90 -34
- package/contracts/registry/IRegistryService.sol +28 -35
- package/contracts/registry/IRelease.sol +26 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +444 -219
- package/contracts/registry/RegistryAdmin.sol +258 -0
- package/contracts/registry/RegistryAuthorization.sol +267 -0
- package/contracts/registry/RegistryService.sol +74 -137
- package/contracts/registry/RegistryServiceManager.sol +23 -30
- package/contracts/registry/ReleaseAdmin.sol +253 -0
- package/contracts/registry/ReleaseLifecycle.sol +32 -0
- package/contracts/registry/ReleaseRegistry.sol +517 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +331 -0
- package/contracts/registry/TokenRegistry.sol +261 -64
- package/contracts/shared/Component.sol +122 -183
- package/contracts/shared/ComponentService.sol +655 -97
- package/contracts/shared/ComponentServiceManager.sol +38 -0
- package/contracts/shared/ComponentVerifyingService.sol +128 -0
- package/contracts/shared/ContractLib.sol +281 -0
- package/contracts/shared/IComponent.sol +17 -49
- package/contracts/shared/IComponentService.sol +112 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +30 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +7 -6
- package/contracts/{instance/base → shared}/ILifecycle.sol +5 -4
- package/contracts/shared/INftOwnable.sol +3 -1
- package/contracts/shared/IPolicyHolder.sol +12 -17
- package/contracts/shared/IRegisterable.sol +23 -1
- package/contracts/shared/IService.sol +11 -6
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +12 -4
- package/contracts/shared/InstanceLinkedComponent.sol +195 -0
- package/contracts/{instance/base → shared}/KeyValueStore.sol +36 -74
- package/contracts/shared/Lifecycle.sol +88 -0
- package/contracts/shared/NftIdSet.sol +65 -0
- package/contracts/shared/NftOwnable.sol +33 -24
- package/contracts/shared/PolicyHolder.sol +18 -50
- package/contracts/shared/Registerable.sol +54 -23
- package/contracts/shared/RegistryLinked.sol +9 -14
- package/contracts/shared/Service.sol +33 -40
- package/contracts/shared/TokenHandler.sol +320 -13
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +166 -6
- package/contracts/staking/IStakingService.sol +107 -40
- package/contracts/staking/Staking.sol +509 -27
- package/contracts/staking/StakingLib.sol +281 -0
- package/contracts/staking/StakingLifecycle.sol +23 -0
- package/contracts/staking/StakingManager.sol +24 -16
- package/contracts/staking/StakingReader.sol +180 -0
- package/contracts/staking/StakingService.sol +308 -48
- package/contracts/staking/StakingServiceManager.sol +12 -8
- package/contracts/staking/StakingStore.sol +606 -0
- package/contracts/staking/TargetManagerLib.sol +211 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +44 -3
- package/contracts/type/Blocknumber.sol +26 -3
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Fee.sol +17 -16
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +21 -16
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +191 -63
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/Referral.sol +2 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +39 -7
- package/contracts/type/RoleId.sol +118 -68
- package/contracts/type/Seconds.sol +48 -1
- package/contracts/type/Selector.sol +107 -0
- package/contracts/type/StateId.sol +41 -2
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +16 -7
- package/contracts/type/UFixed.sol +40 -121
- package/contracts/type/Version.sol +58 -7
- package/contracts/{shared → upgradeability}/ProxyManager.sol +90 -27
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/contracts/{shared → upgradeability}/Versionable.sol +2 -2
- package/package.json +12 -8
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1348
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -124
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -581
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +0 -256
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -237
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -864
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -640
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -620
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -569
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -10
- package/contracts/instance/BundleManager.sol +0 -126
- package/contracts/instance/InstanceAccessManager.sol +0 -543
- package/contracts/instance/InstanceAuthorizationsLib.sol +0 -308
- package/contracts/instance/base/Lifecycle.sol +0 -121
- package/contracts/instance/base/ObjectManager.sol +0 -82
- package/contracts/instance/module/IAccess.sol +0 -54
- package/contracts/instance/module/ISetup.sol +0 -33
- package/contracts/instance/module/ITreasury.sol +0 -23
- package/contracts/product/IProductService.sol +0 -40
- package/contracts/product/ProductService.sol +0 -210
- package/contracts/product/ProductServiceManager.sol +0 -54
- package/contracts/registry/RegistryAccessManager.sol +0 -207
- package/contracts/registry/ReleaseManager.sol +0 -360
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
- /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
@@ -2,36 +2,77 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
6
|
+
import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
|
7
|
+
import {Initializable} from "@openzeppelin/contracts/proxy/utils/Initializable.sol";
|
5
8
|
|
6
|
-
import {NftId,
|
7
|
-
import {VersionPart} from "../type/Version.sol";
|
8
|
-
import {ObjectType, PROTOCOL, REGISTRY,
|
9
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
10
|
+
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
11
|
+
import {ObjectType, ObjectTypeLib, PROTOCOL, REGISTRY, SERVICE, INSTANCE, STAKE, STAKING, PRODUCT, DISTRIBUTION, DISTRIBUTOR, ORACLE, POOL, POLICY, BUNDLE} from "../type/ObjectType.sol";
|
9
12
|
|
10
13
|
import {ChainNft} from "./ChainNft.sol";
|
11
14
|
import {IRegistry} from "./IRegistry.sol";
|
12
|
-
import {
|
13
|
-
|
14
|
-
|
15
|
+
import {IRelease} from "./IRelease.sol";
|
16
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
17
|
+
import {IStaking} from "../staking/IStaking.sol";
|
18
|
+
import {ReleaseRegistry} from "./ReleaseRegistry.sol";
|
19
|
+
import {TokenRegistry} from "./TokenRegistry.sol";
|
20
|
+
import {RegistryAdmin} from "./RegistryAdmin.sol";
|
21
|
+
|
22
|
+
/// @dev IMPORTANT
|
15
23
|
// Each NFT minted by registry is accosiated with:
|
16
24
|
// 1) NFT owner
|
17
25
|
// 2) registred contract OR object stored in registered (parent) contract
|
18
|
-
//
|
19
|
-
// 1) IService address by
|
20
|
-
// 2)
|
21
|
-
// 3)
|
22
|
-
// 4)
|
23
|
-
|
26
|
+
// Five registration flows:
|
27
|
+
// 1) registerService() -> registers IService address by ReleaseRegistry (ReleaseRegistry is set at deployment time)
|
28
|
+
// 2) register() -> registers IRegisterable address by IService (INSTANCE, PRODUCT, POOL, DISTRIBUTION, ORACLE)
|
29
|
+
// 3) -> registers object by IService (POLICY, BUNDLE, STAKE)
|
30
|
+
// 4) registerWithCustomType() -> registers IRegisterable address with custom type by IService
|
31
|
+
// 5) registerRegistry() -> registers IRegistry address (from different chain) by GifAdmin. Works ONLY on mainnet.
|
32
|
+
// Note: getters by address MUST not be used with this address (will return 0 or data related to different object or even revert)
|
33
|
+
|
34
|
+
/// @dev Chain Registry contract implementing IRegistry.
|
35
|
+
/// IRegistry for method details.
|
24
36
|
contract Registry is
|
37
|
+
Initializable,
|
38
|
+
AccessManaged,
|
25
39
|
IRegistry
|
26
40
|
{
|
41
|
+
/// @dev Protocol NFT ID
|
42
|
+
NftId public immutable PROTOCOL_NFT_ID;
|
43
|
+
|
44
|
+
/// @dev Gobal registry NFT ID
|
45
|
+
NftId public immutable GLOBAL_REGISTRY_NFT_ID;
|
46
|
+
|
47
|
+
/// @dev Gobal registry address on mainnet.
|
48
|
+
address public immutable GLOBAL_REGISTRY_ADDRESS;
|
49
|
+
|
50
|
+
/// @dev Registry NFT ID
|
51
|
+
NftId public immutable REGISTRY_NFT_ID;
|
52
|
+
|
53
|
+
/// @dev Deployer address that authorizes the initializer of this contract.
|
54
|
+
address public immutable DEPLOYER;
|
55
|
+
|
56
|
+
/// @dev Registry admin contract for this registry.
|
57
|
+
RegistryAdmin public immutable ADMIN;
|
58
|
+
|
59
|
+
/// @dev Chain NFT contract that keeps track of the ownership of all registered objects.
|
60
|
+
ChainNft public immutable CHAIN_NFT;
|
61
|
+
|
27
62
|
address public constant NFT_LOCK_ADDRESS = address(0x1);
|
28
63
|
uint256 public constant REGISTRY_TOKEN_SEQUENCE_ID = 2;
|
29
64
|
uint256 public constant STAKING_TOKEN_SEQUENCE_ID = 3;
|
30
65
|
string public constant EMPTY_URI = "";
|
31
66
|
|
67
|
+
/// @dev keep track of different registries on different chains
|
68
|
+
mapping(uint256 chainId => NftId registryNftId) private _registryNftIdByChainId;
|
69
|
+
uint256[] private _chainId;
|
70
|
+
|
71
|
+
/// @dev keep track of object info and address reverse lookup
|
32
72
|
mapping(NftId nftId => ObjectInfo info) private _info;
|
33
73
|
mapping(address object => NftId nftId) private _nftIdByAddress;
|
34
74
|
|
75
|
+
/// @dev keep track of service addresses by version and domain
|
35
76
|
mapping(VersionPart version => mapping(ObjectType serviceDomain => address)) private _service;
|
36
77
|
|
37
78
|
mapping(ObjectType objectType => bool) private _coreTypes;
|
@@ -42,210 +83,296 @@ contract Registry is
|
|
42
83
|
mapping(ObjectType objectType => mapping(
|
43
84
|
ObjectType parentType => bool)) private _coreObjectCombinations;
|
44
85
|
|
45
|
-
NftId private
|
46
|
-
ChainNft private _chainNft;
|
86
|
+
NftId private _stakingNftId;
|
47
87
|
|
48
|
-
|
88
|
+
ReleaseRegistry private _releaseRegistry;
|
89
|
+
address private _tokenRegistryAddress;
|
49
90
|
address private _stakingAddress;
|
50
91
|
|
51
|
-
modifier
|
52
|
-
if(
|
53
|
-
revert
|
54
|
-
}
|
55
|
-
_;
|
56
|
-
}
|
57
|
-
|
58
|
-
modifier onlyReleaseManager() {
|
59
|
-
if(msg.sender != address(_releaseManager)) {
|
60
|
-
revert CallerNotReleaseManager();
|
92
|
+
modifier onlyDeployer() {
|
93
|
+
if (msg.sender != DEPLOYER) {
|
94
|
+
revert ErrorRegistryCallerNotDeployer();
|
61
95
|
}
|
62
96
|
_;
|
63
97
|
}
|
64
98
|
|
65
|
-
|
66
|
-
|
99
|
+
// TODO when create2 strategy is added to ignition:
|
100
|
+
// 1. move globalRegistry arg out from constructor into initialize()
|
101
|
+
// 2. add testRegistry_deployChainRegistryAtGlobalRegistryAddress
|
102
|
+
/// @dev Creates the registry contract and populates it with the protocol and registry objects.
|
103
|
+
/// Internally deploys the ChainNft contract.
|
104
|
+
constructor(RegistryAdmin admin, address globalRegistry)
|
105
|
+
AccessManaged(admin.authority())
|
106
|
+
{
|
107
|
+
DEPLOYER = msg.sender;
|
108
|
+
ADMIN = admin;
|
109
|
+
GLOBAL_REGISTRY_ADDRESS = _getGlobalRegistryAddress(globalRegistry);
|
67
110
|
|
68
111
|
// deploy NFT
|
69
|
-
|
112
|
+
CHAIN_NFT = new ChainNft(address(this));
|
113
|
+
GLOBAL_REGISTRY_NFT_ID = NftIdLib.toNftId(
|
114
|
+
CHAIN_NFT.GLOBAL_REGISTRY_ID());
|
70
115
|
|
71
116
|
// initial registry setup
|
72
|
-
_registerProtocol();
|
73
|
-
_registerRegistry();
|
117
|
+
PROTOCOL_NFT_ID = _registerProtocol();
|
118
|
+
REGISTRY_NFT_ID = _registerRegistry();
|
74
119
|
|
75
120
|
// set object types and object parent relations
|
76
121
|
_setupValidCoreTypesAndCombinations();
|
77
122
|
}
|
78
123
|
|
79
124
|
|
80
|
-
|
81
|
-
|
82
|
-
|
125
|
+
/// @dev Wires release registry, token registry and staking contract to this registry.
|
126
|
+
/// MUST be called by release registry.
|
127
|
+
function initialize(
|
128
|
+
address releaseRegistry,
|
129
|
+
address tokenRegistry,
|
130
|
+
address staking
|
131
|
+
)
|
132
|
+
external
|
133
|
+
initializer()
|
134
|
+
onlyDeployer()
|
135
|
+
{
|
136
|
+
// store links to supporting contracts
|
137
|
+
_releaseRegistry = ReleaseRegistry(releaseRegistry);
|
138
|
+
_tokenRegistryAddress = tokenRegistry;
|
139
|
+
_stakingAddress = staking;
|
140
|
+
|
141
|
+
// register staking contract
|
142
|
+
_stakingNftId = _registerStaking();
|
143
|
+
}
|
144
|
+
|
145
|
+
/// @inheritdoc IRegistry
|
146
|
+
function registerRegistry(
|
147
|
+
NftId nftId,
|
148
|
+
uint256 chainId,
|
149
|
+
address registryAddress
|
83
150
|
)
|
84
151
|
external
|
85
|
-
|
86
|
-
returns(NftId stakingNftId)
|
152
|
+
restricted()
|
87
153
|
{
|
88
|
-
//
|
89
|
-
if (
|
90
|
-
revert
|
154
|
+
// registration of chain registries only allowed on mainnet
|
155
|
+
if (block.chainid != 1) {
|
156
|
+
revert ErrorRegistryNotOnMainnet(block.chainid);
|
91
157
|
}
|
92
158
|
|
93
|
-
|
94
|
-
|
95
|
-
|
159
|
+
// registry chain id is not zero
|
160
|
+
if(chainId == 0) {
|
161
|
+
revert ErrorRegistryChainRegistryChainIdZero(nftId);
|
162
|
+
}
|
163
|
+
|
164
|
+
// registry address is not zero
|
165
|
+
if (registryAddress == address(0)) {
|
166
|
+
revert ErrorRegistryChainRegistryAddressZero(nftId, chainId);
|
167
|
+
}
|
96
168
|
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
isInterceptor: false,
|
103
|
-
objectAddress: _stakingAddress,
|
104
|
-
initialOwner: stakingOwner,
|
105
|
-
data: ""
|
106
|
-
});
|
169
|
+
// registry nft id matches registry chain id
|
170
|
+
uint256 expectedRegistryId = CHAIN_NFT.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID, chainId);
|
171
|
+
if (nftId != NftIdLib.toNftId(expectedRegistryId)) {
|
172
|
+
revert ErrorRegistryChainRegistryNftIdInvalid(nftId, chainId);
|
173
|
+
}
|
107
174
|
|
108
|
-
|
175
|
+
emit LogChainRegistryRegistration(nftId, chainId, registryAddress);
|
176
|
+
|
177
|
+
_registerRegistryForNft(
|
178
|
+
chainId,
|
179
|
+
ObjectInfo({
|
180
|
+
nftId: nftId,
|
181
|
+
parentNftId: REGISTRY_NFT_ID,
|
182
|
+
objectType: REGISTRY(),
|
183
|
+
isInterceptor: false,
|
184
|
+
objectAddress: registryAddress,
|
185
|
+
initialOwner: NFT_LOCK_ADDRESS,
|
186
|
+
data: ""
|
187
|
+
}),
|
188
|
+
false); // do not update address lookup for objects on a different chain
|
109
189
|
}
|
110
190
|
|
191
|
+
// TODO limit service owner to registry admin?
|
192
|
+
/// @inheritdoc IRegistry
|
111
193
|
function registerService(
|
112
194
|
ObjectInfo memory info,
|
113
195
|
VersionPart version,
|
114
196
|
ObjectType domain
|
115
197
|
)
|
116
198
|
external
|
117
|
-
|
199
|
+
restricted()
|
118
200
|
returns(NftId nftId)
|
119
201
|
{
|
120
|
-
|
202
|
+
// service address is defined
|
203
|
+
address service = info.objectAddress;
|
204
|
+
if(service == address(0)) {
|
205
|
+
revert ErrorRegistryServiceAddressZero();
|
206
|
+
}
|
207
|
+
|
208
|
+
// version is defined
|
209
|
+
if(version.eqz()) {
|
210
|
+
revert ErrorRegistryServiceVersionZero(service);
|
211
|
+
}
|
212
|
+
// service domain is defined
|
213
|
+
if(domain.eqz()) {
|
214
|
+
revert ErrorRegistryServiceDomainZero(service, version);
|
215
|
+
}
|
216
|
+
|
217
|
+
// service has proper type
|
121
218
|
if(info.objectType != SERVICE()) {
|
122
|
-
revert();
|
219
|
+
revert ErrorRegistryNotService(service, info.objectType);
|
123
220
|
}
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
*/
|
129
|
-
|
130
|
-
if(_service[version][domain] > address(0)) {
|
131
|
-
revert ServiceAlreadyRegistered(info.objectAddress);
|
221
|
+
|
222
|
+
// service parent has registry type
|
223
|
+
if(info.parentNftId != REGISTRY_NFT_ID) {
|
224
|
+
revert ErrorRegistryServiceParentNotRegistry(service, version, info.parentNftId);
|
132
225
|
}
|
133
226
|
|
134
|
-
|
227
|
+
// service has not already been registered
|
228
|
+
if(_service[version][domain] != address(0)) {
|
229
|
+
revert ErrorRegistryServiceDomainAlreadyRegistered(service, version, domain);
|
230
|
+
}
|
135
231
|
|
136
|
-
|
232
|
+
_service[version][domain] = service;
|
137
233
|
|
138
234
|
emit LogServiceRegistration(version, domain);
|
235
|
+
|
236
|
+
nftId = _register(info);
|
139
237
|
}
|
140
238
|
|
239
|
+
|
240
|
+
/// @inheritdoc IRegistry
|
141
241
|
function register(ObjectInfo memory info)
|
142
242
|
external
|
143
|
-
|
243
|
+
restricted()
|
144
244
|
returns(NftId nftId)
|
145
245
|
{
|
246
|
+
address objectAddress = info.objectAddress;
|
146
247
|
ObjectType objectType = info.objectType;
|
147
|
-
ObjectType parentType = _info[info.parentNftId].objectType;
|
148
248
|
|
149
|
-
//
|
150
|
-
//
|
151
|
-
|
152
|
-
revert ServiceRegistration();
|
153
|
-
}
|
249
|
+
// this indidirectly enforces that the parent is registered
|
250
|
+
// parentType would be zero for a non-registered parent which is never a valid type combination
|
251
|
+
ObjectType parentType = _info[info.parentNftId].objectType;
|
154
252
|
|
155
|
-
//
|
156
|
-
if(
|
157
|
-
{
|
253
|
+
// check type combinations for core objects
|
254
|
+
if(objectAddress == address(0)) {
|
158
255
|
if(_coreObjectCombinations[objectType][parentType] == false) {
|
159
|
-
revert
|
256
|
+
revert ErrorRegistryTypesCombinationInvalid(objectAddress, objectType, parentType);
|
160
257
|
}
|
161
258
|
}
|
162
|
-
|
163
|
-
{
|
259
|
+
// check type combinations for contract objects
|
260
|
+
else {
|
164
261
|
if(_coreContractCombinations[objectType][parentType] == false) {
|
165
|
-
revert
|
262
|
+
revert ErrorRegistryTypesCombinationInvalid(objectAddress, objectType, parentType);
|
166
263
|
}
|
167
264
|
}
|
168
265
|
|
169
266
|
nftId = _register(info);
|
170
267
|
}
|
171
268
|
|
269
|
+
|
270
|
+
/// @inheritdoc IRegistry
|
172
271
|
function registerWithCustomType(ObjectInfo memory info)
|
173
272
|
external
|
174
|
-
|
273
|
+
restricted()
|
175
274
|
returns(NftId nftId)
|
176
275
|
{
|
177
276
|
ObjectType objectType = info.objectType;
|
178
277
|
ObjectType parentType = _info[info.parentNftId].objectType;
|
179
278
|
|
180
279
|
if(_coreTypes[objectType]) {
|
181
|
-
revert
|
280
|
+
revert ErrorRegistryCoreTypeRegistration();
|
182
281
|
}
|
183
282
|
|
184
283
|
if(
|
284
|
+
objectType == ObjectTypeLib.zero() ||
|
285
|
+
parentType == ObjectTypeLib.zero() ||
|
185
286
|
parentType == PROTOCOL() ||
|
186
|
-
parentType == REGISTRY() ||
|
187
287
|
parentType == SERVICE()
|
188
288
|
) {
|
189
|
-
revert
|
289
|
+
revert ErrorRegistryTypesCombinationInvalid(info.objectAddress, objectType, parentType);
|
190
290
|
}
|
191
291
|
|
192
|
-
_register(info);
|
292
|
+
nftId = _register(info);
|
193
293
|
}
|
194
294
|
|
195
295
|
|
196
296
|
/// @dev earliest GIF major version
|
197
297
|
function getInitialVersion() external view returns (VersionPart) {
|
198
|
-
return
|
298
|
+
return VersionPartLib.toVersionPart(_releaseRegistry.INITIAL_GIF_VERSION());
|
199
299
|
}
|
200
300
|
|
201
|
-
|
202
|
-
// need to be thought trough, not yet clear if necessary
|
203
|
-
// need to answer question: what is the latest version during the upgrade process?
|
204
|
-
// likely setting up a new gif version does not fit into a single tx
|
205
|
-
// in this case we might want to have a period where the latest version is
|
206
|
-
// in the process of being set up while the latest active version is 1 major release smaller
|
207
|
-
/// @dev latest GIF major version (might not yet be active)
|
301
|
+
/// @dev next GIF release version to be released
|
208
302
|
function getNextVersion() external view returns (VersionPart) {
|
209
|
-
return
|
303
|
+
return _releaseRegistry.getNextVersion();
|
210
304
|
}
|
211
305
|
|
212
306
|
/// @dev latest active GIF release version
|
213
307
|
function getLatestVersion() external view returns (VersionPart) {
|
214
|
-
return
|
308
|
+
return _releaseRegistry.getLatestVersion();
|
215
309
|
}
|
216
310
|
|
217
|
-
function getReleaseInfo(VersionPart
|
218
|
-
return
|
311
|
+
function getReleaseInfo(VersionPart release) external view returns (IRelease.ReleaseInfo memory) {
|
312
|
+
return _releaseRegistry.getReleaseInfo(release);
|
219
313
|
}
|
220
314
|
|
221
|
-
function
|
222
|
-
return
|
315
|
+
function chainIds() public view returns (uint256) {
|
316
|
+
return _chainId.length;
|
317
|
+
}
|
318
|
+
|
319
|
+
function getChainId(uint256 idx) public view returns (uint256) {
|
320
|
+
return _chainId[idx];
|
223
321
|
}
|
224
322
|
|
225
|
-
function
|
226
|
-
return
|
323
|
+
function getRegistryNftId(uint256 chainId) public view returns (NftId nftId) {
|
324
|
+
return _registryNftIdByChainId[chainId];
|
325
|
+
}
|
326
|
+
|
327
|
+
function getObjectCount() external view returns (uint256) {
|
328
|
+
return CHAIN_NFT.totalSupply();
|
227
329
|
}
|
228
330
|
|
229
331
|
function getNftId() external view returns (NftId nftId) {
|
230
|
-
return
|
332
|
+
return REGISTRY_NFT_ID;
|
231
333
|
}
|
232
334
|
|
233
|
-
function
|
335
|
+
function getProtocolNftId() external view returns (NftId nftId) {
|
336
|
+
return PROTOCOL_NFT_ID;
|
337
|
+
}
|
338
|
+
|
339
|
+
function getNftIdForAddress(address object) external view returns (NftId id) {
|
234
340
|
return _nftIdByAddress[object];
|
235
341
|
}
|
236
342
|
|
237
343
|
function ownerOf(NftId nftId) public view returns (address) {
|
238
|
-
return
|
344
|
+
return CHAIN_NFT.ownerOf(nftId.toInt());
|
345
|
+
}
|
346
|
+
|
347
|
+
function isOwnerOf(NftId nftId, address expectedOwner) public view returns (bool) {
|
348
|
+
return CHAIN_NFT.ownerOf(nftId.toInt()) == expectedOwner;
|
239
349
|
}
|
240
350
|
|
241
351
|
function ownerOf(address contractAddress) public view returns (address) {
|
242
|
-
return
|
352
|
+
return CHAIN_NFT.ownerOf(_nftIdByAddress[contractAddress].toInt());
|
243
353
|
}
|
244
354
|
|
245
355
|
function getObjectInfo(NftId nftId) external view returns (ObjectInfo memory) {
|
246
356
|
return _info[nftId];
|
247
357
|
}
|
248
358
|
|
359
|
+
function getParentNftId(NftId nftId) external view returns (NftId parentNftId) {
|
360
|
+
return _info[nftId].parentNftId;
|
361
|
+
}
|
362
|
+
|
363
|
+
function isObjectType(address contractAddress, ObjectType expectedObjectType) external view returns (bool) {
|
364
|
+
NftId nftId = _nftIdByAddress[contractAddress];
|
365
|
+
return isObjectType(nftId, expectedObjectType);
|
366
|
+
}
|
367
|
+
|
368
|
+
function isObjectType(NftId nftId, ObjectType expectedObjectType) public view returns (bool) {
|
369
|
+
return _info[nftId].objectType == expectedObjectType;
|
370
|
+
}
|
371
|
+
|
372
|
+
function getObjectAddress(NftId nftId) external view returns (address) {
|
373
|
+
return _info[nftId].objectAddress;
|
374
|
+
}
|
375
|
+
|
249
376
|
function getObjectInfo(address object) external view returns (ObjectInfo memory) {
|
250
377
|
return _info[_nftIdByAddress[object]];
|
251
378
|
}
|
@@ -267,28 +394,41 @@ contract Registry is
|
|
267
394
|
return _info[objectParentNftId].objectType == INSTANCE();
|
268
395
|
}
|
269
396
|
|
270
|
-
function
|
397
|
+
function isActiveRelease(VersionPart version) external view returns (bool)
|
271
398
|
{
|
272
|
-
return
|
399
|
+
return _releaseRegistry.isActiveRelease(version);
|
273
400
|
}
|
274
401
|
|
275
402
|
function getStakingAddress() external view returns (address staking) {
|
276
403
|
return _stakingAddress;
|
277
404
|
}
|
278
405
|
|
406
|
+
function getTokenRegistryAddress() external view returns (address tokenRegistry) {
|
407
|
+
return _tokenRegistryAddress;
|
408
|
+
}
|
409
|
+
|
279
410
|
function getServiceAddress(
|
280
411
|
ObjectType serviceDomain,
|
281
412
|
VersionPart releaseVersion
|
282
413
|
) external view returns (address service)
|
283
414
|
{
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
415
|
+
service = _service[releaseVersion][serviceDomain];
|
416
|
+
}
|
417
|
+
|
418
|
+
function getReleaseRegistryAddress() external view returns (address) {
|
419
|
+
return address(_releaseRegistry);
|
288
420
|
}
|
289
421
|
|
290
422
|
function getChainNftAddress() external view override returns (address) {
|
291
|
-
return address(
|
423
|
+
return address(CHAIN_NFT);
|
424
|
+
}
|
425
|
+
|
426
|
+
function getRegistryAdminAddress() external view returns (address) {
|
427
|
+
return address(ADMIN);
|
428
|
+
}
|
429
|
+
|
430
|
+
function getAuthority() external view returns (address) {
|
431
|
+
return ADMIN.authority();
|
292
432
|
}
|
293
433
|
|
294
434
|
function getOwner() public view returns (address owner) {
|
@@ -308,65 +448,83 @@ contract Registry is
|
|
308
448
|
// Internals
|
309
449
|
|
310
450
|
/// @dev registry protects only against tampering existing records, registering with invalid types pairs and 0 parent address
|
311
|
-
// TODO registration of precompile addresses
|
312
451
|
function _register(ObjectInfo memory info)
|
313
452
|
internal
|
314
453
|
returns(NftId nftId)
|
315
454
|
{
|
316
|
-
ObjectType objectType = info.objectType;
|
317
|
-
|
455
|
+
ObjectType objectType = info.objectType; // do not care here, never PROTOCOL(), REGISTRY()
|
456
|
+
bool isInterceptor = info.isInterceptor;
|
457
|
+
address objectAddress = info.objectAddress; // do not care here, can be 0
|
458
|
+
address owner = info.initialOwner; // do not care here, can be 0, can be equal info.objectAddress
|
459
|
+
|
460
|
+
NftId parentNftId = info.parentNftId; // do not care here, can not be 0
|
318
461
|
ObjectInfo memory parentInfo = _info[parentNftId];
|
319
|
-
|
320
|
-
address parentAddress = parentInfo.objectAddress;
|
462
|
+
address parentAddress = parentInfo.objectAddress; // can be 0
|
321
463
|
|
322
464
|
// parent is contract -> need to check? -> check before minting
|
323
|
-
// special case:
|
324
|
-
// special case: when
|
325
|
-
// special case: when parentNftId ==
|
326
|
-
|
327
|
-
|
465
|
+
// special case: staking: to protocol possible as well
|
466
|
+
// NO LONGER TRUE: special case: global registry nft as parent when not on mainnet -> global registry address is 0
|
467
|
+
// special case: when parentNftId == CHAIN_NFT.mint(), check for zero parent address before mint
|
468
|
+
// special case: when parentNftId == CHAIN_NFT.mint() && objectAddress == initialOwner
|
469
|
+
// Parent can have 0 address in case of STAKE for PROTOCOL / CUSTOM_TYPE for POLICY
|
470
|
+
// But it MUST be registered -> parentType != 0 && parentNftId != 0
|
471
|
+
/*if(objectType != STAKE()) {
|
472
|
+
if(parentAddress == address(0)) {
|
473
|
+
revert ErrorRegistryParentAddressZero();
|
474
|
+
}
|
475
|
+
}*/
|
476
|
+
|
477
|
+
// global registry is never parent when not on mainnet
|
478
|
+
if(block.chainid != 1) {
|
479
|
+
if(parentNftId == GLOBAL_REGISTRY_NFT_ID) {
|
480
|
+
revert ErrorRegistryGlobalRegistryAsParent(objectAddress, objectType);
|
481
|
+
}
|
328
482
|
}
|
329
483
|
|
330
|
-
address
|
331
|
-
|
332
|
-
|
484
|
+
address interceptorAddress = _getInterceptor(
|
485
|
+
isInterceptor,
|
486
|
+
objectType,
|
487
|
+
objectAddress,
|
488
|
+
parentInfo.isInterceptor,
|
489
|
+
parentAddress);
|
333
490
|
|
491
|
+
uint256 tokenId = CHAIN_NFT.getNextTokenId();
|
492
|
+
nftId = NftIdLib.toNftId(tokenId);
|
334
493
|
info.nftId = nftId;
|
335
|
-
_info[nftId] = info;
|
336
|
-
|
337
|
-
if(info.objectAddress > address(0))
|
338
|
-
{
|
339
|
-
address contractAddress = info.objectAddress;
|
340
|
-
|
341
|
-
if(_nftIdByAddress[contractAddress].gtz()) {
|
342
|
-
revert ContractAlreadyRegistered(contractAddress);
|
343
|
-
}
|
344
494
|
|
345
|
-
|
346
|
-
|
495
|
+
_info[nftId] = info;
|
496
|
+
_setAddressForNftId(nftId, objectAddress);
|
347
497
|
|
348
|
-
emit LogRegistration(nftId, parentNftId, objectType,
|
498
|
+
emit LogRegistration(nftId, parentNftId, objectType, isInterceptor, objectAddress, owner);
|
349
499
|
|
350
500
|
// calls nft receiver(1) and interceptor(2)
|
351
|
-
uint256 mintedTokenId =
|
352
|
-
|
353
|
-
|
501
|
+
uint256 mintedTokenId = CHAIN_NFT.mint(
|
502
|
+
owner,
|
503
|
+
interceptorAddress,
|
354
504
|
EMPTY_URI);
|
355
|
-
|
356
|
-
|
505
|
+
|
506
|
+
assert(mintedTokenId == tokenId);
|
357
507
|
}
|
358
508
|
|
359
509
|
/// @dev obtain interceptor address for this nft if applicable, address(0) otherwise
|
510
|
+
/// special case: STAKES (parent may be any type) -> no intercept call
|
511
|
+
/// default case:
|
360
512
|
function _getInterceptor(
|
361
513
|
bool isInterceptor,
|
514
|
+
ObjectType objectType,
|
362
515
|
address objectAddress,
|
363
516
|
bool parentIsInterceptor,
|
364
517
|
address parentObjectAddress
|
365
518
|
)
|
366
519
|
internal
|
367
|
-
|
520
|
+
pure
|
368
521
|
returns (address interceptor)
|
369
522
|
{
|
523
|
+
// no intercepting calls for stakes
|
524
|
+
if (objectType == STAKE()) {
|
525
|
+
return address(0);
|
526
|
+
}
|
527
|
+
|
370
528
|
if (objectAddress == address(0)) {
|
371
529
|
if (parentIsInterceptor) {
|
372
530
|
return parentObjectAddress;
|
@@ -387,119 +545,186 @@ contract Registry is
|
|
387
545
|
/// @dev protocol registration used to anchor the dip ecosystem relations
|
388
546
|
function _registerProtocol()
|
389
547
|
private
|
548
|
+
returns (NftId protocolNftId)
|
390
549
|
{
|
391
|
-
uint256 protocolId =
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
550
|
+
uint256 protocolId = CHAIN_NFT.PROTOCOL_NFT_ID();
|
551
|
+
protocolNftId = NftIdLib.toNftId(protocolId);
|
552
|
+
|
553
|
+
_registerForNft(
|
554
|
+
ObjectInfo({
|
555
|
+
nftId: protocolNftId,
|
556
|
+
parentNftId: NftIdLib.zero(),
|
557
|
+
objectType: PROTOCOL(),
|
558
|
+
isInterceptor: false,
|
559
|
+
objectAddress: address(0),
|
560
|
+
initialOwner: NFT_LOCK_ADDRESS,
|
561
|
+
data: ""}),
|
562
|
+
true);
|
563
|
+
}
|
564
|
+
|
565
|
+
/// @dev register this registry
|
566
|
+
function _registerRegistry()
|
567
|
+
internal
|
568
|
+
virtual
|
569
|
+
returns (NftId registryNftId)
|
570
|
+
{
|
571
|
+
// initial assignment
|
572
|
+
registryNftId = GLOBAL_REGISTRY_NFT_ID;
|
573
|
+
|
574
|
+
// register global registry
|
575
|
+
_registerRegistryForNft(
|
576
|
+
1, // mainnet chain id
|
577
|
+
ObjectInfo({
|
578
|
+
nftId: GLOBAL_REGISTRY_NFT_ID,
|
579
|
+
parentNftId: PROTOCOL_NFT_ID,
|
580
|
+
objectType: REGISTRY(),
|
581
|
+
isInterceptor: false,
|
582
|
+
objectAddress: GLOBAL_REGISTRY_ADDRESS,
|
583
|
+
initialOwner: NFT_LOCK_ADDRESS,
|
584
|
+
data: ""}),
|
585
|
+
block.chainid == 1);// update address lookup for global registry only on mainnet
|
586
|
+
|
587
|
+
// if not on mainnet: register this registry with global registry as parent
|
588
|
+
if (block.chainid != 1) {
|
589
|
+
|
590
|
+
// modify registry nft id to local registry when not on mainnet
|
591
|
+
registryNftId = NftIdLib.toNftId(
|
592
|
+
CHAIN_NFT.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID));
|
593
|
+
|
594
|
+
_registerRegistryForNft(
|
595
|
+
block.chainid,
|
596
|
+
ObjectInfo({
|
597
|
+
nftId: registryNftId,
|
598
|
+
parentNftId: GLOBAL_REGISTRY_NFT_ID,
|
599
|
+
objectType: REGISTRY(),
|
600
|
+
isInterceptor: false,
|
601
|
+
objectAddress: address(this),
|
602
|
+
initialOwner: NFT_LOCK_ADDRESS,
|
603
|
+
data: ""}),
|
604
|
+
true);
|
605
|
+
}
|
405
606
|
}
|
406
607
|
|
407
|
-
/// @dev
|
408
|
-
|
409
|
-
|
608
|
+
/// @dev staking registration
|
609
|
+
function _registerRegistryForNft(
|
610
|
+
uint256 chainId,
|
611
|
+
ObjectInfo memory info,
|
612
|
+
bool updateAddressLookup
|
613
|
+
)
|
410
614
|
private
|
411
615
|
{
|
412
|
-
|
413
|
-
|
414
|
-
NftId parentNftId;
|
415
|
-
|
416
|
-
if(registryId != _chainNft.GLOBAL_REGISTRY_ID())
|
417
|
-
{// we're not the global registry
|
418
|
-
_registerGlobalRegistry();
|
419
|
-
parentNftId = toNftId(_chainNft.GLOBAL_REGISTRY_ID());
|
420
|
-
}
|
421
|
-
else
|
422
|
-
{// we are global registry
|
423
|
-
parentNftId = toNftId(_chainNft.PROTOCOL_NFT_ID());
|
616
|
+
if (!_registryNftIdByChainId[chainId].eqz()) {
|
617
|
+
revert ErrorRegistryChainRegistryAlreadyRegistered(info.nftId, chainId);
|
424
618
|
}
|
425
619
|
|
426
|
-
|
427
|
-
|
428
|
-
|
429
|
-
objectType: REGISTRY(),
|
430
|
-
isInterceptor: false,
|
431
|
-
objectAddress: address(this),
|
432
|
-
initialOwner: NFT_LOCK_ADDRESS,
|
433
|
-
data: ""
|
434
|
-
});
|
435
|
-
_nftIdByAddress[address(this)] = registryNftId;
|
436
|
-
_registryNftId = registryNftId;
|
620
|
+
// update registry lookup variables
|
621
|
+
_registryNftIdByChainId[chainId] = info.nftId;
|
622
|
+
_chainId.push(chainId);
|
437
623
|
|
438
|
-
|
624
|
+
// register the registry info
|
625
|
+
_registerForNft(
|
626
|
+
info,
|
627
|
+
updateAddressLookup);
|
439
628
|
}
|
440
629
|
|
441
|
-
/// @dev
|
442
|
-
function
|
630
|
+
/// @dev staking registration
|
631
|
+
function _registerStaking()
|
443
632
|
private
|
633
|
+
returns (NftId stakingNftId)
|
444
634
|
{
|
445
|
-
|
446
|
-
|
635
|
+
address stakingOwner = IRegisterable(_stakingAddress).getOwner();
|
636
|
+
uint256 stakingId = CHAIN_NFT.calculateTokenId(STAKING_TOKEN_SEQUENCE_ID);
|
637
|
+
stakingNftId = NftIdLib.toNftId(stakingId);
|
638
|
+
|
639
|
+
_registerForNft(
|
640
|
+
ObjectInfo({
|
641
|
+
nftId: stakingNftId,
|
642
|
+
parentNftId: REGISTRY_NFT_ID,
|
643
|
+
objectType: STAKING(),
|
644
|
+
isInterceptor: false,
|
645
|
+
objectAddress: _stakingAddress,
|
646
|
+
initialOwner: stakingOwner,
|
647
|
+
data: ""}),
|
648
|
+
true);
|
649
|
+
|
650
|
+
IStaking(_stakingAddress).initializeTokenHandler();
|
651
|
+
}
|
652
|
+
|
653
|
+
/// @dev Register the provided object info for the specified NFT ID.
|
654
|
+
function _registerForNft(
|
655
|
+
ObjectInfo memory info,
|
656
|
+
bool updateAddressLookup
|
657
|
+
)
|
658
|
+
internal
|
659
|
+
{
|
660
|
+
_info[info.nftId] = info;
|
447
661
|
|
448
|
-
|
449
|
-
nftId
|
450
|
-
|
451
|
-
objectType: REGISTRY(),
|
452
|
-
isInterceptor: false,
|
453
|
-
objectAddress: address(0),
|
454
|
-
initialOwner: NFT_LOCK_ADDRESS,
|
455
|
-
data: ""
|
456
|
-
});
|
662
|
+
if (updateAddressLookup) {
|
663
|
+
_setAddressForNftId(info.nftId, info.objectAddress);
|
664
|
+
}
|
457
665
|
|
458
|
-
|
666
|
+
// calls nft receiver
|
667
|
+
CHAIN_NFT.mint(info.initialOwner, info.nftId.toInt());
|
668
|
+
}
|
669
|
+
|
670
|
+
function _setAddressForNftId(NftId nftId, address objectAddress)
|
671
|
+
internal
|
672
|
+
{
|
673
|
+
if (objectAddress != address(0)) {
|
674
|
+
if (_nftIdByAddress[objectAddress].gtz()) {
|
675
|
+
revert ErrorRegistryContractAlreadyRegistered(objectAddress);
|
676
|
+
}
|
677
|
+
|
678
|
+
_nftIdByAddress[objectAddress] = nftId;
|
679
|
+
}
|
680
|
+
}
|
681
|
+
|
682
|
+
function _getGlobalRegistryAddress(address globalRegistry) internal view returns (address) {
|
683
|
+
if (block.chainid == 1) {
|
684
|
+
return address(this);
|
685
|
+
} else {
|
686
|
+
return globalRegistry;
|
687
|
+
}
|
459
688
|
}
|
460
689
|
|
461
690
|
/// @dev defines which object - parent types relations are allowed to register
|
462
|
-
|
463
|
-
//
|
464
|
-
// 2) DO NOT use object type (e.g. POLCY, BUNDLE, STAKE) as parent type
|
465
|
-
// 3) DO NOT use REGISTRY as object type
|
466
|
-
// 2) DO NOT use PROTOCOL and "zeroObjectType"
|
691
|
+
/// EACH object type MUST have only one parent type across ALL mappings
|
692
|
+
// the only EXCEPTION is STAKE, can have any number of parent types
|
467
693
|
function _setupValidCoreTypesAndCombinations()
|
468
|
-
private
|
694
|
+
private
|
469
695
|
{
|
696
|
+
_coreTypes[PROTOCOL()] = true;
|
470
697
|
_coreTypes[REGISTRY()] = true;
|
471
698
|
_coreTypes[SERVICE()] = true;
|
472
|
-
_coreTypes[TOKEN()] = true;
|
473
699
|
_coreTypes[INSTANCE()] = true;
|
474
700
|
_coreTypes[PRODUCT()] = true;
|
475
701
|
_coreTypes[POOL()] = true;
|
476
702
|
_coreTypes[DISTRIBUTION()] = true;
|
703
|
+
_coreTypes[DISTRIBUTOR()] = true;
|
704
|
+
_coreTypes[ORACLE()] = true;
|
477
705
|
_coreTypes[POLICY()] = true;
|
478
706
|
_coreTypes[BUNDLE()] = true;
|
479
707
|
_coreTypes[STAKING()] = true;
|
480
708
|
_coreTypes[STAKE()] = true;
|
481
|
-
|
482
|
-
_coreContractCombinations[REGISTRY()][REGISTRY()] = true; // only for global regstry
|
483
|
-
_coreContractCombinations[STAKING()][REGISTRY()] = true; // only for chain staking contract
|
484
|
-
_coreContractCombinations[TOKEN()][REGISTRY()] = true;
|
485
|
-
//_coreContractCombinations[SERVICE()][REGISTRY()] = true;// do not need it here -> registerService() registers exactly this combination
|
486
709
|
|
487
|
-
//
|
710
|
+
// types combinations allowed to use with register() function ONLY
|
488
711
|
_coreContractCombinations[INSTANCE()][REGISTRY()] = true;
|
489
712
|
|
490
|
-
// instance
|
713
|
+
// components with instance parent
|
491
714
|
_coreContractCombinations[PRODUCT()][INSTANCE()] = true;
|
492
|
-
_coreContractCombinations[DISTRIBUTION()][INSTANCE()] = true;
|
493
|
-
_coreContractCombinations[ORACLE()][INSTANCE()] = true;
|
494
|
-
_coreContractCombinations[POOL()][INSTANCE()] = true;
|
495
715
|
|
496
|
-
|
716
|
+
// components with product parent
|
717
|
+
_coreContractCombinations[DISTRIBUTION()][PRODUCT()] = true;
|
718
|
+
_coreContractCombinations[ORACLE()][PRODUCT()] = true;
|
719
|
+
_coreContractCombinations[POOL()][PRODUCT()] = true;
|
497
720
|
|
498
|
-
//
|
721
|
+
// objects with component parents
|
499
722
|
_coreObjectCombinations[POLICY()][PRODUCT()] = true;
|
500
|
-
|
501
|
-
// pool as parent, ONLY approved
|
723
|
+
_coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
|
502
724
|
_coreObjectCombinations[BUNDLE()][POOL()] = true;
|
503
|
-
|
725
|
+
|
726
|
+
// staking
|
727
|
+
_coreObjectCombinations[STAKE()][PROTOCOL()] = true;
|
728
|
+
_coreObjectCombinations[STAKE()][INSTANCE()] = true;
|
504
729
|
}
|
505
730
|
}
|