@etherisc/gif-next 0.0.2-a733491-751 → 0.0.2-a755cba-731
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 +83 -93
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1000 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +746 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +767 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1293 -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/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +414 -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 +1060 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +295 -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/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +4 -0
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json +1196 -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 +1292 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +470 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +986 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1494 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +862 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → distribution}/IDistributionComponent.sol/IDistributionComponent.json +309 -367
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +984 -0
- 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 +1441 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +502 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1991 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +470 -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 +1429 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +470 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1145 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1605 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +502 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2329 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +470 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +808 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +343 -2120
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +278 -99
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +406 -2903
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1684 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +574 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1382 -482
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +351 -362
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +159 -114
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3668 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +810 -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 +4 -0
- package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +1 -49
- 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 +181 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +12 -115
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{ITreasury.sol/ITreasury.json → IComponents.sol/IComponents.json} +2 -2
- 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 +929 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +478 -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 +744 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IBundleService.sol/IBundleService.json → oracle/IOracleService.sol/IOracleService.json} +370 -283
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/{components/Component.sol/Component.json → oracle/Oracle.sol/Oracle.json} +305 -313
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +990 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +766 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
- package/artifacts/contracts/{components/Pool.sol/Pool.json → pool/BasicPool.sol/BasicPool.json} +450 -550
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +502 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1360 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +822 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +922 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +392 -402
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1285 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +997 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1619 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +794 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +806 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
- package/artifacts/contracts/{components/Product.sol/Product.json → product/BasicProduct.sol/BasicProduct.json} +387 -517
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +470 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1555 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +858 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPolicyService.sol/IPolicyService.json → product/IApplicationService.sol/IApplicationService.json} +203 -202
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +1058 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +944 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IApplicationService.sol/IApplicationService.json → product/IPricingService.sol/IPricingService.json} +253 -137
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → product}/IProductComponent.sol/IProductComponent.json +439 -272
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → product/IRiskService.sol/IRiskService.json} +120 -64
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1313 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +810 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +923 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/product/Product.sol/Product.json +1074 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +638 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +718 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +72 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +457 -27
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +263 -123
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +949 -128
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1899 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +349 -253
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +161 -94
- 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 +1067 -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 +316 -153
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/shared/Component.sol/Component.json +677 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1574 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +818 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +118 -185
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +488 -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/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +227 -138
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +1197 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +679 -0
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +95 -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 +19 -10
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +59 -13
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +28 -6
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +135 -18
- 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 +767 -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 +28 -70
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +35 -85
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +69 -99
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -28
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +136 -108
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +734 -8
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +395 -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 +4 -0
- package/artifacts/contracts/{components/Distribution.sol/Distribution.json → staking/IStaking.sol/IStaking.json} +707 -679
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1043 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +440 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +1816 -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 +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +780 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +587 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1265 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +734 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2283 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +607 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +10 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +398 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +203 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +104 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +317 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +125 -0
- 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 +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +228 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +239 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
- 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 +4 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +180 -0
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +369 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +246 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +105 -0
- 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 +4 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +312 -0
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +548 -0
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/type/Version.sol/VersionLib.json +177 -0
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +68 -0
- 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 +263 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +45 -0
- package/contracts/authorization/AccessAdmin.sol +615 -0
- package/contracts/authorization/AccessManagerCloneable.sol +16 -0
- package/contracts/authorization/Authorization.sol +289 -0
- package/contracts/authorization/IAccess.sol +49 -0
- package/contracts/authorization/IAccessAdmin.sol +137 -0
- package/contracts/authorization/IAuthorization.sol +60 -0
- package/contracts/authorization/IServiceAuthorization.sol +40 -0
- package/contracts/authorization/ReleaseAccessManager.sol +38 -0
- package/contracts/authorization/ServiceAuthorization.sol +106 -0
- package/contracts/distribution/BasicDistribution.sol +139 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
- package/contracts/distribution/Distribution.sol +287 -0
- package/contracts/distribution/DistributionService.sol +357 -0
- package/contracts/distribution/DistributionServiceManager.sol +39 -0
- package/contracts/distribution/IDistributionComponent.sol +52 -0
- package/contracts/distribution/IDistributionService.sol +100 -0
- 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 +436 -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 +107 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +366 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +130 -0
- package/contracts/instance/IInstance.sol +50 -73
- package/contracts/instance/IInstanceService.sol +38 -33
- package/contracts/instance/Instance.sol +171 -228
- package/contracts/instance/InstanceAdmin.sol +288 -0
- package/contracts/instance/InstanceAuthorizationV3.sol +223 -0
- package/contracts/instance/InstanceReader.sol +351 -63
- package/contracts/instance/InstanceService.sol +261 -336
- package/contracts/instance/InstanceServiceManager.sol +14 -29
- package/contracts/instance/InstanceStore.sol +287 -0
- package/contracts/instance/RiskSet.sol +119 -0
- package/contracts/instance/base/BalanceStore.sol +123 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +4 -22
- package/contracts/instance/base/ObjectCounter.sol +20 -0
- package/contracts/instance/base/ObjectLifecycle.sol +112 -0
- package/contracts/instance/base/ObjectSet.sol +78 -0
- package/contracts/instance/module/IAccess.sol +6 -14
- package/contracts/instance/module/IBundle.sol +8 -8
- package/contracts/instance/module/IComponents.sol +50 -0
- package/contracts/instance/module/IDistribution.sol +6 -4
- package/contracts/instance/module/IPolicy.sol +56 -18
- package/contracts/instance/module/IRisk.sol +2 -1
- package/contracts/{test/Usdc.sol → mock/Dip.sol} +6 -6
- package/contracts/oracle/BasicOracle.sol +47 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +46 -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 +156 -0
- package/contracts/oracle/OracleService.sol +309 -0
- package/contracts/oracle/OracleServiceManager.sol +39 -0
- package/contracts/pool/BasicPool.sol +175 -0
- package/contracts/pool/BasicPoolAuthorization.sol +68 -0
- package/contracts/pool/BundleService.sol +425 -0
- package/contracts/pool/BundleServiceManager.sol +39 -0
- package/contracts/pool/IBundleService.sol +121 -0
- package/contracts/pool/IPoolComponent.sol +62 -0
- package/contracts/pool/IPoolService.sol +153 -0
- package/contracts/pool/Pool.sol +345 -0
- package/contracts/pool/PoolService.sol +615 -0
- package/contracts/pool/PoolServiceManager.sol +39 -0
- package/contracts/product/ApplicationService.sol +259 -0
- package/contracts/{instance/service → product}/ApplicationServiceManager.sol +12 -9
- package/contracts/product/BasicProduct.sol +49 -0
- package/contracts/product/BasicProductAuthorization.sol +41 -0
- package/contracts/product/ClaimService.sol +683 -0
- package/contracts/{instance/service → product}/ClaimServiceManager.sol +12 -9
- package/contracts/{instance/service → product}/IApplicationService.sol +20 -36
- package/contracts/product/IClaimService.sol +136 -0
- package/contracts/product/IPolicyService.sol +90 -0
- package/contracts/product/IPricingService.sol +39 -0
- package/contracts/product/IProductComponent.sol +59 -0
- package/contracts/product/IRiskService.sol +33 -0
- package/contracts/product/PolicyService.sol +736 -0
- package/contracts/product/PolicyServiceManager.sol +39 -0
- package/contracts/product/PricingService.sol +300 -0
- package/contracts/product/PricingServiceManager.sol +39 -0
- package/contracts/product/Product.sol +451 -0
- package/contracts/product/RiskService.sol +107 -0
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +83 -36
- package/contracts/registry/IRegistry.sol +98 -26
- package/contracts/registry/IRegistryService.sol +36 -41
- package/contracts/registry/ITransferInterceptor.sol +1 -1
- package/contracts/registry/Registry.sol +454 -198
- package/contracts/registry/RegistryAdmin.sol +457 -0
- package/contracts/registry/RegistryService.sol +87 -129
- package/contracts/registry/RegistryServiceManager.sol +23 -32
- package/contracts/registry/ReleaseLifecycle.sol +30 -0
- package/contracts/registry/ReleaseRegistry.sol +486 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +207 -0
- package/contracts/registry/TokenRegistry.sol +261 -62
- package/contracts/shared/Component.sol +219 -0
- package/contracts/shared/ComponentService.sol +696 -0
- package/contracts/shared/ComponentServiceManager.sol +38 -0
- package/contracts/shared/ComponentVerifyingService.sol +128 -0
- package/contracts/shared/ContractLib.sol +224 -0
- package/contracts/shared/IComponent.sol +62 -0
- package/contracts/shared/IComponentService.sol +116 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +30 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +16 -11
- package/contracts/{instance/base → shared}/ILifecycle.sol +5 -4
- package/contracts/shared/INftOwnable.sol +4 -2
- package/contracts/shared/IPolicyHolder.sol +23 -14
- package/contracts/shared/IRegisterable.sol +11 -0
- package/contracts/shared/IRegistryLinked.sol +0 -1
- package/contracts/shared/IService.sol +15 -6
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +4 -4
- package/contracts/shared/InstanceLinkedComponent.sol +197 -0
- package/contracts/shared/KeyValueStore.sol +131 -0
- package/contracts/shared/Lifecycle.sol +88 -0
- package/contracts/shared/NftIdSet.sol +65 -0
- package/contracts/shared/NftOwnable.sol +32 -25
- package/contracts/shared/PolicyHolder.sol +22 -41
- package/contracts/shared/Registerable.sol +31 -22
- package/contracts/shared/RegistryLinked.sol +9 -19
- package/contracts/shared/Service.sol +55 -29
- package/contracts/shared/TokenHandler.sol +374 -12
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +173 -0
- package/contracts/staking/IStakingService.sol +157 -0
- package/contracts/staking/StakeManagerLib.sol +224 -0
- package/contracts/staking/Staking.sol +515 -0
- package/contracts/staking/StakingLifecycle.sol +23 -0
- package/contracts/staking/StakingManager.sol +52 -0
- package/contracts/staking/StakingReader.sol +190 -0
- package/contracts/staking/StakingService.sol +440 -0
- package/contracts/staking/StakingServiceManager.sol +44 -0
- package/contracts/staking/StakingStore.sol +605 -0
- package/contracts/staking/TargetManagerLib.sol +211 -0
- package/contracts/{types → type}/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +150 -0
- package/contracts/{types → type}/Blocknumber.sol +27 -3
- package/contracts/{types → type}/ClaimId.sol +31 -3
- package/contracts/{types → type}/Fee.sol +33 -23
- package/contracts/{types → type}/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/{types → type}/NftId.sol +28 -15
- package/contracts/{types → type}/NftIdSet.sol +2 -2
- package/contracts/type/ObjectType.sol +286 -0
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +6 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/{types → type}/RiskId.sol +31 -5
- package/contracts/type/RoleId.sol +162 -0
- package/contracts/type/Seconds.sol +101 -0
- package/contracts/type/Selector.sol +102 -0
- package/contracts/{types → type}/StateId.sol +48 -4
- package/contracts/type/String.sol +53 -0
- package/contracts/{types → type}/Timestamp.sol +34 -15
- package/contracts/{types → type}/UFixed.sol +41 -121
- package/contracts/{types → type}/Version.sol +5 -2
- package/contracts/{shared → upgradeability}/IVersionable.sol +1 -1
- package/contracts/{shared → upgradeability}/ProxyManager.sol +93 -30
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/contracts/{shared → upgradeability}/Versionable.sol +3 -3
- package/package.json +11 -7
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -764
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1221
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -261
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
- 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 -502
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
- 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/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -858
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -657
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1085
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -661
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -743
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -637
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -943
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -681
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +0 -398
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -480
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +0 -336
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1109
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -717
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -724
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -653
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -766
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -649
- 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 -547
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- 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 -582
- 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/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -510
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +0 -10
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +0 -100
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +0 -104
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +0 -125
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +0 -33
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +0 -100
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +0 -86
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +0 -92
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -249
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +0 -10
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +0 -479
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionLib.json +0 -177
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +0 -49
- package/contracts/components/Component.sol +0 -241
- package/contracts/components/Distribution.sol +0 -308
- package/contracts/components/IComponent.sol +0 -54
- package/contracts/components/IDistributionComponent.sol +0 -100
- package/contracts/components/IPoolComponent.sol +0 -87
- package/contracts/components/IProductComponent.sol +0 -39
- package/contracts/components/Pool.sol +0 -254
- package/contracts/components/Product.sol +0 -285
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -13
- package/contracts/instance/BundleManager.sol +0 -125
- package/contracts/instance/InstanceAccessManager.sol +0 -580
- package/contracts/instance/ObjectManager.sol +0 -84
- package/contracts/instance/base/ComponentService.sol +0 -134
- package/contracts/instance/base/KeyValueStore.sol +0 -172
- package/contracts/instance/base/Lifecycle.sol +0 -100
- package/contracts/instance/module/ISetup.sol +0 -47
- package/contracts/instance/module/ITreasury.sol +0 -23
- package/contracts/instance/service/ApplicationService.sol +0 -268
- package/contracts/instance/service/BundleService.sol +0 -298
- package/contracts/instance/service/BundleServiceManager.sol +0 -51
- package/contracts/instance/service/ClaimService.sol +0 -151
- package/contracts/instance/service/DistributionService.sol +0 -295
- package/contracts/instance/service/DistributionServiceManager.sol +0 -51
- package/contracts/instance/service/IBundleService.sol +0 -54
- package/contracts/instance/service/IClaimService.sol +0 -61
- package/contracts/instance/service/IDistributionService.sol +0 -65
- package/contracts/instance/service/IPolicyService.sol +0 -89
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/IProductService.sol +0 -40
- package/contracts/instance/service/PolicyService.sol +0 -474
- package/contracts/instance/service/PolicyServiceManager.sol +0 -54
- package/contracts/instance/service/PoolService.sol +0 -125
- package/contracts/instance/service/PoolServiceManager.sol +0 -51
- package/contracts/instance/service/ProductService.sol +0 -241
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- package/contracts/registry/RegistryAccessManager.sol +0 -216
- package/contracts/registry/ReleaseManager.sol +0 -322
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -25
- package/contracts/test/TestToken.sol +0 -26
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- package/contracts/types/ChainId.sol +0 -38
- package/contracts/types/NumberId.sol +0 -52
- package/contracts/types/ObjectType.sol +0 -156
- package/contracts/types/PayoutId.sol +0 -54
- package/contracts/types/RoleId.sol +0 -93
- /package/contracts/{types → type}/DistributorType.sol +0 -0
@@ -1,580 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.20;
|
3
|
-
|
4
|
-
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
|
-
import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
|
6
|
-
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
7
|
-
|
8
|
-
import {RoleId, RoleIdLib, ADMIN_ROLE, PUBLIC_ROLE, INSTANCE_SERVICE_ROLE, INSTANCE_OWNER_ROLE} from "../types/RoleId.sol";
|
9
|
-
import {TimestampLib} from "../types/Timestamp.sol";
|
10
|
-
import {NftId} from "../types/NftId.sol";
|
11
|
-
|
12
|
-
import {AccessManagerUpgradeableInitializeable} from "./AccessManagerUpgradeableInitializeable.sol";
|
13
|
-
|
14
|
-
import {IAccess} from "./module/IAccess.sol";
|
15
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
16
|
-
|
17
|
-
contract InstanceAccessManager is
|
18
|
-
AccessManagedUpgradeable
|
19
|
-
{
|
20
|
-
using RoleIdLib for RoleId;
|
21
|
-
|
22
|
-
string public constant ADMIN_ROLE_NAME = "AdminRole";
|
23
|
-
string public constant PUBLIC_ROLE_NAME = "PublicRole";
|
24
|
-
|
25
|
-
uint64 public constant CUSTOM_ROLE_ID_MIN = 10000; // MUST be even
|
26
|
-
uint32 public constant EXECUTION_DELAY = 0;
|
27
|
-
|
28
|
-
// role specific state
|
29
|
-
mapping(RoleId roleId => IAccess.RoleInfo info) internal _roleInfo;
|
30
|
-
mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
|
31
|
-
mapping(ShortString name => RoleId roleId) internal _roleIdForName;
|
32
|
-
RoleId [] internal _roleIds;
|
33
|
-
uint64 _idNext;
|
34
|
-
|
35
|
-
// target specific state
|
36
|
-
mapping(address target => IAccess.TargetInfo info) internal _targetInfo;
|
37
|
-
mapping(ShortString name => address target) internal _targetAddressForName;
|
38
|
-
address [] internal _targets;
|
39
|
-
|
40
|
-
AccessManagerUpgradeableInitializeable internal _accessManager;
|
41
|
-
IRegistry internal _registry;
|
42
|
-
|
43
|
-
modifier restrictedToRoleAdmin(RoleId roleId) {
|
44
|
-
RoleId admin = getRoleAdmin(roleId);
|
45
|
-
(bool inRole, uint32 executionDelay) = _accessManager.hasRole(admin.toInt(), _msgSender());
|
46
|
-
assert(executionDelay == 0); // to be sure no delayed execution functionality is used
|
47
|
-
if (!inRole) {
|
48
|
-
revert IAccess.ErrorIAccessCallerIsNotRoleAdmin(_msgSender(), roleId);
|
49
|
-
}
|
50
|
-
_;
|
51
|
-
}
|
52
|
-
|
53
|
-
function initialize(address ozAccessManager, address registry) external initializer
|
54
|
-
{
|
55
|
-
require(ozAccessManager != address(0));
|
56
|
-
require(registry != address(0));
|
57
|
-
|
58
|
-
__AccessManaged_init(ozAccessManager);
|
59
|
-
|
60
|
-
_accessManager = AccessManagerUpgradeableInitializeable(ozAccessManager);
|
61
|
-
_registry = IRegistry(registry);
|
62
|
-
_idNext = CUSTOM_ROLE_ID_MIN;
|
63
|
-
|
64
|
-
_createRole(ADMIN_ROLE(), ADMIN_ROLE_NAME, IAccess.Type.Core);
|
65
|
-
_createRole(PUBLIC_ROLE(), PUBLIC_ROLE_NAME, IAccess.Type.Core);
|
66
|
-
|
67
|
-
// assume `this` is already a member of ADMIN_ROLE
|
68
|
-
// assume msg.sender is instance service which is also member of ADMIN_ROLE
|
69
|
-
// assume instance service will renounce ADMIN_ROLE through ozAccessManager and should not be added to _roleMembers here
|
70
|
-
EnumerableSet.add(_roleMembers[ADMIN_ROLE()], address(this));
|
71
|
-
//EnumerableSet.add(_roleMembers[ADMIN_ROLE()], initialAdmin);
|
72
|
-
}
|
73
|
-
|
74
|
-
//--- Role ------------------------------------------------------//
|
75
|
-
// INSTANCE_SERVICE_ROLE
|
76
|
-
// assume core roles are never revoked or renounced -> core roles admin is never active after intialization
|
77
|
-
function createCoreRole(RoleId roleId, string memory name)
|
78
|
-
external
|
79
|
-
restricted()
|
80
|
-
{
|
81
|
-
_createRole(roleId, name, IAccess.Type.Core);
|
82
|
-
}
|
83
|
-
// INSTANCE_SERVICE_ROLE
|
84
|
-
// assume gif roles can be revoked or renounced
|
85
|
-
// TODO who can be admin of gif role?
|
86
|
-
function createGifRole(RoleId roleId, string memory name, RoleId admin)
|
87
|
-
external
|
88
|
-
restricted()
|
89
|
-
{
|
90
|
-
_createRole(roleId, name, IAccess.Type.Gif);
|
91
|
-
setRoleAdmin(roleId, admin);
|
92
|
-
}
|
93
|
-
|
94
|
-
// INSTANCE_OWNER_ROLE
|
95
|
-
function createCustomRole(string memory roleName, string memory adminName)
|
96
|
-
external
|
97
|
-
restricted()
|
98
|
-
returns(RoleId roleId, RoleId admin)
|
99
|
-
{
|
100
|
-
(roleId, admin) = _getNextCustomRoleId();
|
101
|
-
|
102
|
-
_createRole(roleId, roleName, IAccess.Type.Custom);
|
103
|
-
_createRole(admin, adminName, IAccess.Type.Custom);
|
104
|
-
|
105
|
-
// TODO works without this -> why?
|
106
|
-
setRoleAdmin(roleId, admin);
|
107
|
-
setRoleAdmin(admin, INSTANCE_OWNER_ROLE());
|
108
|
-
}
|
109
|
-
|
110
|
-
// ADMIN_ROLE
|
111
|
-
// TODO restricted to ADMIN_ROLE or have restrictedToRoleAdmin modifier ???
|
112
|
-
function setRoleAdmin(RoleId roleId, RoleId admin)
|
113
|
-
public
|
114
|
-
restricted()
|
115
|
-
{
|
116
|
-
if (!roleExists(roleId)) {
|
117
|
-
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
118
|
-
}
|
119
|
-
|
120
|
-
if(_roleInfo[roleId].rtype == IAccess.Type.Core) {
|
121
|
-
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
122
|
-
}
|
123
|
-
|
124
|
-
if (!roleExists(admin)) {
|
125
|
-
revert IAccess.ErrorIAccessRoleIdInvalid(admin);
|
126
|
-
}
|
127
|
-
|
128
|
-
_roleInfo[roleId].admin = admin;
|
129
|
-
}
|
130
|
-
|
131
|
-
// TODO notify member?
|
132
|
-
// TODO granting/revoking can be `attached` to nft transfer?
|
133
|
-
function grantRole(RoleId roleId, address member)
|
134
|
-
public
|
135
|
-
restrictedToRoleAdmin(roleId)
|
136
|
-
returns (bool granted)
|
137
|
-
{
|
138
|
-
if (!roleExists(roleId)) {
|
139
|
-
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
140
|
-
}
|
141
|
-
|
142
|
-
granted = EnumerableSet.add(_roleMembers[roleId], member);
|
143
|
-
if(granted) {
|
144
|
-
_accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
|
145
|
-
}
|
146
|
-
}
|
147
|
-
|
148
|
-
function revokeRole(RoleId roleId, address member)
|
149
|
-
external
|
150
|
-
restrictedToRoleAdmin(roleId)
|
151
|
-
returns (bool)
|
152
|
-
{
|
153
|
-
return _revokeRole(roleId, member);
|
154
|
-
}
|
155
|
-
|
156
|
-
/// @dev not restricted function by intention
|
157
|
-
/// the restriction to role members is already enforced by the call to the access manager
|
158
|
-
function renounceRole(RoleId roleId)
|
159
|
-
external
|
160
|
-
returns (bool)
|
161
|
-
{
|
162
|
-
address member = msg.sender;
|
163
|
-
// cannot use accessManger.renounce as it directly checks against msg.sender
|
164
|
-
return _revokeRole(roleId, member);
|
165
|
-
}
|
166
|
-
|
167
|
-
function roleExists(RoleId roleId) public view returns (bool exists) {
|
168
|
-
return _roleInfo[roleId].createdAt.gtz();
|
169
|
-
}
|
170
|
-
// TODO returns ADMIN_ROLE id for non existent roleId
|
171
|
-
function getRoleAdmin(RoleId roleId) public view returns(RoleId admin) {
|
172
|
-
return _roleInfo[roleId].admin;
|
173
|
-
}
|
174
|
-
|
175
|
-
function getRoleInfo(RoleId roleId) external view returns (IAccess.RoleInfo memory role) {
|
176
|
-
return _roleInfo[roleId];
|
177
|
-
}
|
178
|
-
|
179
|
-
function roleMembers(RoleId roleId) external view returns (uint256 numberOfMembers) {
|
180
|
-
return EnumerableSet.length(_roleMembers[roleId]);
|
181
|
-
}
|
182
|
-
|
183
|
-
function getRoleId(uint256 idx) external view returns (RoleId roleId) {
|
184
|
-
return _roleIds[idx];
|
185
|
-
}
|
186
|
-
|
187
|
-
// TODO now: for non existent name returns ADMIN_ROLE id
|
188
|
-
function getRoleIdForName(string memory name) external view returns (RoleId roleId) {
|
189
|
-
return _roleIdForName[ShortStrings.toShortString(name)];
|
190
|
-
}
|
191
|
-
|
192
|
-
function roleMember(RoleId roleId, uint256 idx) external view returns (address roleMember) {
|
193
|
-
return EnumerableSet.at(_roleMembers[roleId], idx);
|
194
|
-
}
|
195
|
-
|
196
|
-
function hasRole(RoleId roleId, address account) external view returns (bool accountHasRole) {
|
197
|
-
(accountHasRole, ) = _accessManager.hasRole(roleId.toInt(), account);
|
198
|
-
}
|
199
|
-
|
200
|
-
function roles() external view returns (uint256 numberOfRoles) {
|
201
|
-
return _roleIds.length;
|
202
|
-
}
|
203
|
-
|
204
|
-
function isCustomRoleAdmin(RoleId roleId) public pure returns (bool) {
|
205
|
-
uint roleIdInt = roleId.toInt();
|
206
|
-
return (
|
207
|
-
roleIdInt >= CUSTOM_ROLE_ID_MIN &&
|
208
|
-
roleIdInt % 2 == 1
|
209
|
-
);
|
210
|
-
}
|
211
|
-
|
212
|
-
//--- Target ------------------------------------------------------//
|
213
|
-
// INSTANCE_SERVICE_ROLE
|
214
|
-
// assume some core targets are registred (instance) while others are not (instance accesss manager, instance reader, bundle manager)
|
215
|
-
function createCoreTarget(address target, string memory name) external restricted() {
|
216
|
-
_createTarget(target, name, IAccess.Type.Core);
|
217
|
-
}
|
218
|
-
// INSTANCE_SERVICE_ROLE
|
219
|
-
// assume gif target is registered and belongs to the same instance as instance access manager
|
220
|
-
function createGifTarget(address target, string memory name) external restricted()
|
221
|
-
{
|
222
|
-
_createTarget(target, name, IAccess.Type.Gif);
|
223
|
-
}
|
224
|
-
// INSTANCE_OWNER_ROLE
|
225
|
-
// assume custom target.authority() is constant -> target can not be used with different instance access manager
|
226
|
-
// assume custom target can not be registered as component -> each service which is doing component registration MUST register a gif target
|
227
|
-
// assume custom target can not be registered as instance or service -> why?
|
228
|
-
// TODO check target associated with instance owner or instance or instance's components or components helpers
|
229
|
-
function createCustomTarget(address target, string memory name)
|
230
|
-
external
|
231
|
-
restricted()
|
232
|
-
{
|
233
|
-
if(_registry.isRegistered(target)) {
|
234
|
-
revert IAccess.ErrorIAccessTargetIsRegistered(target);
|
235
|
-
}
|
236
|
-
|
237
|
-
_createTarget(target, name, IAccess.Type.Custom);
|
238
|
-
}
|
239
|
-
// INSTANCE_SERVICE_ROLE
|
240
|
-
// IMPORTANT: instance access manager MUST be of Core type -> otherwise will be locked forever
|
241
|
-
function setTargetLocked(string memory targetName, bool locked)
|
242
|
-
external
|
243
|
-
restricted()
|
244
|
-
{
|
245
|
-
ShortString nameShort = ShortStrings.toShortString(targetName);
|
246
|
-
address target = _targetAddressForName[nameShort];
|
247
|
-
|
248
|
-
if (target == address(0)) {
|
249
|
-
revert IAccess.ErrorIAccessTargetDoesNotExist(nameShort);
|
250
|
-
}
|
251
|
-
|
252
|
-
if(_targetInfo[target].ttype == IAccess.Type.Core) {
|
253
|
-
revert IAccess.ErrorIAccessTargetTypeInvalid(nameShort, _targetInfo[target].ttype);
|
254
|
-
}
|
255
|
-
// TODO isLocked is redundant but makes getTargetInfo() faster
|
256
|
-
_targetInfo[target].isLocked = locked;
|
257
|
-
_accessManager.setTargetClosed(target, locked);
|
258
|
-
}
|
259
|
-
|
260
|
-
// allowed combinations of roles and targets:
|
261
|
-
//1) set core role for core target
|
262
|
-
//2) set gif role for gif target
|
263
|
-
//3) set custom role for gif target
|
264
|
-
//4) set custom role for custom target
|
265
|
-
|
266
|
-
// ADMIN_ROLE if used only during initialization, works with:
|
267
|
-
// any roles for any targets
|
268
|
-
// INSTANCE_SERVICE_ROLE if used not only during initilization, works with:
|
269
|
-
// core roles for core targets
|
270
|
-
// gif roles for gif targets
|
271
|
-
function setTargetFunctionRole(
|
272
|
-
string memory targetName,
|
273
|
-
bytes4[] calldata selectors,
|
274
|
-
RoleId roleId
|
275
|
-
)
|
276
|
-
public
|
277
|
-
virtual
|
278
|
-
restricted()
|
279
|
-
{
|
280
|
-
ShortString nameShort = ShortStrings.toShortString(targetName);
|
281
|
-
address target = _targetAddressForName[nameShort];
|
282
|
-
|
283
|
-
// not custom target
|
284
|
-
if(_targetInfo[target].ttype == IAccess.Type.Custom) {
|
285
|
-
revert IAccess.ErrorIAccessTargetTypeInvalid(nameShort, _targetInfo[target].ttype);
|
286
|
-
}
|
287
|
-
|
288
|
-
// not custom role
|
289
|
-
if(_roleInfo[roleId].rtype == IAccess.Type.Custom) {
|
290
|
-
revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, _roleInfo[roleId].rtype);
|
291
|
-
}
|
292
|
-
|
293
|
-
_setTargetFunctionRole(target, nameShort, selectors, roleId);
|
294
|
-
}
|
295
|
-
|
296
|
-
// INSTANCE_OWNER_ROLE
|
297
|
-
// custom role for gif target
|
298
|
-
// custom role for custom target
|
299
|
-
// TODO instance owner can mess with gif target (component) -> e.g. set custom role for function intendent to work with gif role
|
300
|
-
function setTargetFunctionCustomRole(
|
301
|
-
string memory targetName,
|
302
|
-
bytes4[] calldata selectors,
|
303
|
-
RoleId roleId
|
304
|
-
)
|
305
|
-
public
|
306
|
-
virtual
|
307
|
-
restricted()
|
308
|
-
{
|
309
|
-
ShortString nameShort = ShortStrings.toShortString(targetName);
|
310
|
-
address target = _targetAddressForName[nameShort];
|
311
|
-
|
312
|
-
// not core target
|
313
|
-
if(_targetInfo[target].ttype == IAccess.Type.Core) {
|
314
|
-
revert IAccess.ErrorIAccessTargetTypeInvalid(nameShort, _targetInfo[target].ttype);
|
315
|
-
}
|
316
|
-
|
317
|
-
// not core role
|
318
|
-
if(_roleInfo[roleId].rtype == IAccess.Type.Core) {
|
319
|
-
revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, _roleInfo[roleId].rtype);
|
320
|
-
}
|
321
|
-
|
322
|
-
_setTargetFunctionRole(target, nameShort, selectors, roleId);
|
323
|
-
}
|
324
|
-
|
325
|
-
function isTargetLocked(address target) public view returns (bool locked) {
|
326
|
-
return _accessManager.isTargetClosed(target);
|
327
|
-
}
|
328
|
-
|
329
|
-
function targetExists(address target) public view returns (bool exists) {
|
330
|
-
return _targetInfo[target].createdAt.gtz();
|
331
|
-
}
|
332
|
-
|
333
|
-
function getTargetInfo(address target) public view returns (IAccess.TargetInfo memory) {
|
334
|
-
return _targetInfo[target];
|
335
|
-
}
|
336
|
-
|
337
|
-
//--- internal view/pure functions --------------------------------------//
|
338
|
-
|
339
|
-
function _createRole(RoleId roleId, string memory nameLong, IAccess.Type rtype)
|
340
|
-
internal
|
341
|
-
{
|
342
|
-
ShortString name = ShortStrings.toShortString(nameLong);
|
343
|
-
_validateRole(roleId, name, rtype);
|
344
|
-
|
345
|
-
if(roleExists(roleId)) {
|
346
|
-
revert IAccess.ErrorIAccessRoleIdAlreadyExists(roleId);
|
347
|
-
}
|
348
|
-
|
349
|
-
if (_roleIdForName[name].gtz()) {
|
350
|
-
revert IAccess.ErrorIAccessRoleNameNotUnique(_roleIdForName[name], name);
|
351
|
-
}
|
352
|
-
|
353
|
-
IAccess.RoleInfo memory role = IAccess.RoleInfo(
|
354
|
-
name,
|
355
|
-
rtype,
|
356
|
-
ADMIN_ROLE(),
|
357
|
-
TimestampLib.blockTimestamp(),
|
358
|
-
TimestampLib.blockTimestamp());
|
359
|
-
|
360
|
-
_roleInfo[roleId] = role;
|
361
|
-
_roleIdForName[role.name] = roleId;
|
362
|
-
_roleIds.push(roleId);
|
363
|
-
}
|
364
|
-
|
365
|
-
function _validateRole(RoleId roleId, ShortString name, IAccess.Type rtype)
|
366
|
-
internal
|
367
|
-
view
|
368
|
-
{
|
369
|
-
|
370
|
-
uint roleIdInt = roleId.toInt();
|
371
|
-
if(rtype == IAccess.Type.Custom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
|
372
|
-
revert IAccess.ErrorIAccessRoleIdTooSmall(roleId);
|
373
|
-
}
|
374
|
-
|
375
|
-
if(
|
376
|
-
rtype != IAccess.Type.Custom &&
|
377
|
-
roleIdInt >= CUSTOM_ROLE_ID_MIN &&
|
378
|
-
roleIdInt != PUBLIC_ROLE().toInt())
|
379
|
-
{
|
380
|
-
revert IAccess.ErrorIAccessRoleIdTooBig(roleId);
|
381
|
-
}
|
382
|
-
|
383
|
-
// role name checks
|
384
|
-
if (ShortStrings.byteLength(name) == 0) {
|
385
|
-
revert IAccess.ErrorIAccessRoleNameEmpty(roleId);
|
386
|
-
}
|
387
|
-
}
|
388
|
-
// TODO if custom role admin have > 1 member -> limit to 1 member or revoke from all members?
|
389
|
-
function _revokeRole(RoleId roleId, address member)
|
390
|
-
internal
|
391
|
-
returns(bool revoked)
|
392
|
-
{
|
393
|
-
if (!roleExists(roleId)) {
|
394
|
-
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
395
|
-
}
|
396
|
-
|
397
|
-
revoked = EnumerableSet.remove(_roleMembers[roleId], member);
|
398
|
-
if(revoked) {
|
399
|
-
uint64 roleIdInt = roleId.toInt();
|
400
|
-
_accessManager.revokeRole(roleIdInt, member);
|
401
|
-
|
402
|
-
// revoke custom role if custom role admin is being revoked
|
403
|
-
if(isCustomRoleAdmin(roleId)) {
|
404
|
-
uint64 customRoleIdInt = roleIdInt - 1;
|
405
|
-
RoleId customRoleId = RoleIdLib.toRoleId(customRoleIdInt);
|
406
|
-
// loop through all custom role members
|
407
|
-
uint memberCount = EnumerableSet.length(_roleMembers[customRoleId]);
|
408
|
-
for(uint memberIdx = 0; memberIdx < memberCount; memberIdx++)
|
409
|
-
{
|
410
|
-
member = EnumerableSet.at(_roleMembers[customRoleId], memberIdx);
|
411
|
-
bool revokedCustom = EnumerableSet.remove(_roleMembers[customRoleId], member);
|
412
|
-
if(revokedCustom) {
|
413
|
-
_accessManager.revokeRole(customRoleIdInt, member);
|
414
|
-
}
|
415
|
-
}
|
416
|
-
}
|
417
|
-
}
|
418
|
-
}
|
419
|
-
|
420
|
-
function _getNextCustomRoleId()
|
421
|
-
internal
|
422
|
-
returns(RoleId roleId, RoleId admin)
|
423
|
-
{
|
424
|
-
uint64 roleIdInt = _idNext;
|
425
|
-
uint64 adminInt = roleIdInt + 1;
|
426
|
-
|
427
|
-
_idNext = roleIdInt + 2;
|
428
|
-
|
429
|
-
roleId = RoleIdLib.toRoleId(roleIdInt);
|
430
|
-
admin = RoleIdLib.toRoleId(adminInt);
|
431
|
-
}
|
432
|
-
|
433
|
-
function _createTarget(address target, string memory nameLong, IAccess.Type ttype)
|
434
|
-
internal
|
435
|
-
{
|
436
|
-
ShortString name = ShortStrings.toShortString(nameLong);
|
437
|
-
_validateTarget(target, name, ttype);
|
438
|
-
|
439
|
-
if (_targetInfo[target].createdAt.gtz()) {
|
440
|
-
revert IAccess.ErrorIAccessTargetAlreadyExists(target, _targetInfo[target].name);
|
441
|
-
}
|
442
|
-
|
443
|
-
if (_targetAddressForName[name] != address(0)) {
|
444
|
-
revert IAccess.ErrorIAccessTargetNameExists(
|
445
|
-
target,
|
446
|
-
_targetAddressForName[name],
|
447
|
-
name);
|
448
|
-
}
|
449
|
-
|
450
|
-
IAccess.TargetInfo memory info = IAccess.TargetInfo(
|
451
|
-
name,
|
452
|
-
ttype,
|
453
|
-
_accessManager.isTargetClosed(target), // sync with state in access manager
|
454
|
-
TimestampLib.blockTimestamp(),
|
455
|
-
TimestampLib.blockTimestamp());
|
456
|
-
|
457
|
-
_targetInfo[target] = info;
|
458
|
-
_targetAddressForName[info.name] = target;
|
459
|
-
_targets.push(target);
|
460
|
-
}
|
461
|
-
|
462
|
-
function _validateTarget(address target, ShortString name, IAccess.Type ttype)
|
463
|
-
internal
|
464
|
-
view
|
465
|
-
{
|
466
|
-
address targetAuthority = AccessManagedUpgradeable(target).authority();
|
467
|
-
// TODO check depends on target upgradabillity
|
468
|
-
if(targetAuthority != authority()) {
|
469
|
-
revert IAccess.ErrorIAccessTargetAuthorityInvalid(target, targetAuthority);
|
470
|
-
}
|
471
|
-
|
472
|
-
if (ShortStrings.byteLength(name) == 0) {
|
473
|
-
revert IAccess.ErrorIAccessTargetNameEmpty(target);
|
474
|
-
}
|
475
|
-
}
|
476
|
-
|
477
|
-
function _setTargetFunctionRole(
|
478
|
-
address target,
|
479
|
-
ShortString name,
|
480
|
-
bytes4[] calldata selectors,
|
481
|
-
RoleId roleId
|
482
|
-
)
|
483
|
-
internal
|
484
|
-
{
|
485
|
-
if (target == address(0)) {
|
486
|
-
revert IAccess.ErrorIAccessTargetDoesNotExist(name);
|
487
|
-
}
|
488
|
-
|
489
|
-
if (!roleExists(roleId)) {
|
490
|
-
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
491
|
-
}
|
492
|
-
|
493
|
-
uint64 roleIdInt = RoleId.unwrap(roleId);
|
494
|
-
_accessManager.setTargetFunctionRole(target, selectors, roleIdInt);
|
495
|
-
}
|
496
|
-
|
497
|
-
function canCall(
|
498
|
-
address caller,
|
499
|
-
address target,
|
500
|
-
bytes4 selector
|
501
|
-
) public view virtual returns (bool immediate, uint32 delay) {
|
502
|
-
return _accessManager.canCall(caller, target, selector);
|
503
|
-
}
|
504
|
-
}
|
505
|
-
|
506
|
-
|
507
|
-
/// TODO taget admin example:
|
508
|
-
// 1) ADMIN_ROLE (or `this`) is always admin for core targets
|
509
|
-
// 2) INSTANCE_OWNER_ROLE (or instance owner address) is always admin for gif(component) target
|
510
|
-
// 3) INSTANCE_OWNER_ROLE or custom role is initial admin for custom target, initialAdmin can be changed
|
511
|
-
/*function setTargetFunctionRole(
|
512
|
-
string memory targetName,
|
513
|
-
bytes4[] calldata selectors,
|
514
|
-
RoleId roleId
|
515
|
-
)
|
516
|
-
public
|
517
|
-
virtual
|
518
|
-
{
|
519
|
-
ShortString nameShort = ShortStrings.toShortString(targetName);
|
520
|
-
address target = _targetAddressForName[nameShort];
|
521
|
-
|
522
|
-
if(msg.sender != getTargetAdmin(target)) {
|
523
|
-
revert IAccess.ErrorIAccessNotTargetAdmin(target, msg.sender);
|
524
|
-
}
|
525
|
-
// checked at target creation time or always?
|
526
|
-
if(!_registry.isRegistered(target)) {
|
527
|
-
revert IAccess.ErrorIAccessTargetNotRegistered(target);
|
528
|
-
}
|
529
|
-
// guarantee apropriate target admin for core targets
|
530
|
-
// not core target
|
531
|
-
if(_targetInfo[target].ttype == IAccess.Type.Core) {
|
532
|
-
revert IAccess.ErrorIAccessTargetTypeInvalid(nameShort, _targetInfo[target].ttype);
|
533
|
-
}
|
534
|
-
|
535
|
-
// not core role
|
536
|
-
if(_roleInfo[roleId].rtype == IAccess.Type.Core) {
|
537
|
-
revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, _roleInfo[roleId].rtype);
|
538
|
-
}
|
539
|
-
|
540
|
-
_setTargetFunctionRole(target, nameShort, selectors, roleId);
|
541
|
-
}
|
542
|
-
|
543
|
-
function setTargetLocked(string memory targetName, bool locked)
|
544
|
-
external
|
545
|
-
{
|
546
|
-
ShortString nameShort = ShortStrings.toShortString(targetName);
|
547
|
-
address target = _targetAddressForName[nameShort];
|
548
|
-
|
549
|
-
if(msg.sender != getTargetAdmin(target)) {
|
550
|
-
revert IAccess.ErrorIAccessNotTargetAdmin(target, msg.sender);
|
551
|
-
}
|
552
|
-
|
553
|
-
_accessManager.setTargetClosed(target, locked);
|
554
|
-
}
|
555
|
-
|
556
|
-
function setTargetAdmin(address target, address admin)
|
557
|
-
public
|
558
|
-
restricted()
|
559
|
-
{
|
560
|
-
if (!targetExists(target)) {
|
561
|
-
revert IAccess.ErrorIAccessTargetInvalid(target);
|
562
|
-
}
|
563
|
-
|
564
|
-
if (!targetExists(admin)) {
|
565
|
-
revert IAccess.ErrorIAccessTargetInvalid(target);
|
566
|
-
}
|
567
|
-
|
568
|
-
if(_targetInfo[target].ttype == IAccess.Type.Core) {
|
569
|
-
revert IAccess.ErrorIAccessTargetInvalid(target);
|
570
|
-
}
|
571
|
-
|
572
|
-
// target admin is not target itself
|
573
|
-
//if (!targetExists(admin)) {
|
574
|
-
// revert IAccess.ErrorIAccessRoleIdInvalid(admin);
|
575
|
-
//}
|
576
|
-
|
577
|
-
_targetAdmin[target] = admin;
|
578
|
-
}*/
|
579
|
-
///
|
580
|
-
|
@@ -1,84 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.20;
|
3
|
-
|
4
|
-
import {Cloneable} from "./Cloneable.sol";
|
5
|
-
|
6
|
-
import {IInstance} from "./IInstance.sol";
|
7
|
-
import {INSTANCE} from "../types/ObjectType.sol";
|
8
|
-
import {InstanceReader} from "./InstanceReader.sol";
|
9
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
10
|
-
import {LibNftIdSet} from "../types/NftIdSet.sol";
|
11
|
-
import {NftId} from "../types/NftId.sol";
|
12
|
-
|
13
|
-
contract ObjectManager is
|
14
|
-
Cloneable
|
15
|
-
{
|
16
|
-
|
17
|
-
event LogObjectManagerInitialized(address instance);
|
18
|
-
|
19
|
-
error ErrorObjectManagerNftIdInvalid(NftId instanceNftId);
|
20
|
-
error ErrorObjectManagerAlreadyAdded(NftId componentNftId, NftId objectNftId);
|
21
|
-
|
22
|
-
mapping(NftId compnentNftId => LibNftIdSet.Set objects) internal _activeObjects;
|
23
|
-
mapping(NftId compnentNftId => LibNftIdSet.Set objects) internal _allObjects;
|
24
|
-
IInstance internal _instance; // store instance address -> more flexible, instance may not be registered during ObjectManager initialization
|
25
|
-
|
26
|
-
/// @dev call to initialize MUST be made in the same transaction as cloning of the contract
|
27
|
-
function initialize(
|
28
|
-
address authority,
|
29
|
-
address registry,
|
30
|
-
address instance
|
31
|
-
)
|
32
|
-
external
|
33
|
-
{
|
34
|
-
initialize(authority, registry);
|
35
|
-
|
36
|
-
_instance = IInstance(instance);
|
37
|
-
|
38
|
-
emit LogObjectManagerInitialized(instance);
|
39
|
-
}
|
40
|
-
|
41
|
-
function getInstance() external view returns (IInstance) {
|
42
|
-
return _instance;
|
43
|
-
}
|
44
|
-
|
45
|
-
function _add(NftId componentNftId, NftId objectNftId) internal {
|
46
|
-
LibNftIdSet.Set storage allSet = _allObjects[componentNftId];
|
47
|
-
LibNftIdSet.Set storage activeSet = _activeObjects[componentNftId];
|
48
|
-
|
49
|
-
LibNftIdSet.add(allSet, objectNftId);
|
50
|
-
LibNftIdSet.add(activeSet, objectNftId);
|
51
|
-
}
|
52
|
-
|
53
|
-
function _activate(NftId componentNftId, NftId objectNftId) internal {
|
54
|
-
LibNftIdSet.add(_activeObjects[componentNftId], objectNftId);
|
55
|
-
}
|
56
|
-
|
57
|
-
function _deactivate(NftId componentNftId, NftId objectNftId) internal {
|
58
|
-
LibNftIdSet.remove(_activeObjects[componentNftId], objectNftId);
|
59
|
-
}
|
60
|
-
|
61
|
-
function _objects(NftId componentNftId) internal view returns (uint256) {
|
62
|
-
return LibNftIdSet.size(_allObjects[componentNftId]);
|
63
|
-
}
|
64
|
-
|
65
|
-
function _contains(NftId componentNftId, NftId objectNftId) internal view returns (bool) {
|
66
|
-
return LibNftIdSet.contains(_allObjects[componentNftId], objectNftId);
|
67
|
-
}
|
68
|
-
|
69
|
-
function _getObject(NftId componentNftId, uint256 idx) internal view returns (NftId) {
|
70
|
-
return LibNftIdSet.getElementAt(_allObjects[componentNftId], idx);
|
71
|
-
}
|
72
|
-
|
73
|
-
function _activeObjs(NftId componentNftId) internal view returns (uint256) {
|
74
|
-
return LibNftIdSet.size(_activeObjects[componentNftId]);
|
75
|
-
}
|
76
|
-
|
77
|
-
function _isActive(NftId componentNftId, NftId objectNftId) internal view returns (bool) {
|
78
|
-
return LibNftIdSet.contains(_activeObjects[componentNftId], objectNftId);
|
79
|
-
}
|
80
|
-
|
81
|
-
function _getActiveObject(NftId componentNftId, uint256 idx) internal view returns (NftId) {
|
82
|
-
return LibNftIdSet.getElementAt(_activeObjects[componentNftId], idx);
|
83
|
-
}
|
84
|
-
}
|