@etherisc/gif-next 0.0.2-82c6d88-499 → 0.0.2-8311e70-020
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 +67 -8
- 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 +1341 -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 +1434 -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/authorization/IAccess.sol/IAccess.json +10 -0
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/{shared → authorization}/IAccessAdmin.sol/IAccessAdmin.json +181 -278
- 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/{registry → authorization}/IServiceAuthorization.sol/IServiceAuthorization.json +48 -10
- 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 +1322 -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 +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +144 -544
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +368 -245
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +143 -109
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +201 -261
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +230 -49
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1475 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +502 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2040 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +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 +1479 -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 +1195 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1655 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +502 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2408 -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 +851 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +134 -78
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +116 -126
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +162 -215
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1354 -262
- 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 +966 -328
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +135 -330
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +97 -111
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +651 -531
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +853 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +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/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +959 -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 +1 -1
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +43 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +141 -126
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +69 -11
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +127 -398
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +153 -190
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +122 -88
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1252 -0
- 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 +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +435 -202
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +163 -97
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +270 -27
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +132 -379
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +448 -217
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +124 -662
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +569 -396
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +141 -91
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +134 -184
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +91 -93
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1161 -0
- 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 +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +435 -212
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +145 -107
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +94 -9
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +318 -8
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +361 -113
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +136 -83
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +260 -237
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +57 -4
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +455 -318
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +141 -99
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +230 -312
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +120 -122
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +258 -536
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +637 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +724 -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 +340 -55
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +72 -152
- 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 +566 -112
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +396 -436
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +109 -292
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +94 -80
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +1795 -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 +1325 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +101 -16
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +5 -5
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +76 -265
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +578 -492
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +141 -113
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +57 -111
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +541 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +89 -88
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +550 -209
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +127 -123
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +45 -3
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +34 -3
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +16 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +148 -0
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +55 -2
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +112 -351
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +55 -88
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -62
- 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 +22 -57
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +122 -97
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +57 -111
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +697 -25
- 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 +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +134 -125
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +55 -23
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +85 -105
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +210 -366
- 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 +122 -95
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +7 -12
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +100 -171
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +98 -84
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +186 -164
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +59 -23
- 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 +61 -8
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +2 -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 +17 -12
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +55 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +4 -4
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +118 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +117 -14
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +50 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +2 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +2 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +23 -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 +66 -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/{shared → authorization}/AccessAdmin.sol +271 -371
- package/contracts/authorization/AccessManagerCloneable.sol +149 -0
- package/contracts/authorization/Authorization.sol +289 -0
- package/contracts/authorization/IAccess.sol +49 -0
- package/contracts/{shared → authorization}/IAccessAdmin.sol +31 -59
- package/contracts/authorization/IAuthorization.sol +60 -0
- package/contracts/{registry → authorization}/IServiceAuthorization.sol +11 -6
- package/contracts/{registry → authorization}/ServiceAuthorization.sol +45 -25
- package/contracts/distribution/BasicDistribution.sol +139 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
- package/contracts/distribution/Distribution.sol +147 -121
- package/contracts/distribution/DistributionService.sol +160 -100
- package/contracts/distribution/DistributionServiceManager.sol +8 -11
- package/contracts/distribution/IDistributionComponent.sol +26 -40
- package/contracts/distribution/IDistributionService.sol +28 -9
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +90 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
- package/contracts/examples/fire/FireProduct.sol +438 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +57 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +107 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +370 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +130 -0
- package/contracts/instance/IInstance.sol +23 -44
- package/contracts/instance/IInstanceService.sol +16 -41
- package/contracts/instance/Instance.sol +92 -120
- package/contracts/instance/InstanceAdmin.sol +250 -255
- package/contracts/instance/InstanceAuthorizationV3.sol +225 -0
- package/contracts/instance/InstanceReader.sol +238 -34
- package/contracts/instance/InstanceService.sol +145 -180
- package/contracts/instance/InstanceServiceManager.sol +8 -13
- package/contracts/instance/InstanceStore.sol +35 -6
- package/contracts/instance/RiskSet.sol +118 -0
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- 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 -1
- package/contracts/instance/module/IComponents.sol +14 -15
- package/contracts/instance/module/IDistribution.sol +0 -1
- package/contracts/instance/module/IPolicy.sol +26 -25
- package/contracts/instance/module/IRisk.sol +3 -0
- package/contracts/mock/Dip.sol +1 -1
- package/contracts/oracle/BasicOracle.sol +47 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
- package/contracts/oracle/IOracle.sol +16 -0
- package/contracts/oracle/IOracleComponent.sol +2 -1
- package/contracts/oracle/IOracleService.sol +2 -1
- package/contracts/oracle/Oracle.sol +64 -53
- package/contracts/oracle/OracleService.sol +113 -81
- package/contracts/oracle/OracleServiceManager.sol +8 -11
- package/contracts/pool/BasicPool.sol +175 -0
- package/contracts/pool/BasicPoolAuthorization.sol +68 -0
- package/contracts/pool/BundleService.sol +231 -102
- package/contracts/pool/BundleServiceManager.sol +8 -11
- package/contracts/pool/IBundleService.sol +33 -18
- package/contracts/pool/IPoolComponent.sol +20 -70
- package/contracts/pool/IPoolService.sol +53 -50
- package/contracts/pool/Pool.sol +208 -162
- package/contracts/pool/PoolService.sol +343 -180
- package/contracts/pool/PoolServiceManager.sol +6 -9
- package/contracts/product/ApplicationService.sol +83 -78
- package/contracts/product/ApplicationServiceManager.sol +6 -6
- package/contracts/product/BasicProduct.sol +51 -0
- package/contracts/product/BasicProductAuthorization.sol +41 -0
- package/contracts/product/ClaimService.sol +425 -159
- package/contracts/product/ClaimServiceManager.sol +6 -6
- package/contracts/product/IApplicationService.sol +6 -2
- package/contracts/product/IClaimService.sol +44 -7
- package/contracts/product/IPolicyService.sol +46 -34
- package/contracts/product/IPricingService.sol +10 -10
- package/contracts/product/IProductComponent.sol +29 -9
- package/contracts/product/{IProductService.sol → IRiskService.sol} +1 -1
- package/contracts/product/PolicyService.sol +520 -259
- package/contracts/product/PolicyServiceManager.sol +6 -9
- package/contracts/product/PricingService.sol +66 -62
- package/contracts/product/PricingServiceManager.sol +6 -9
- package/contracts/product/Product.sol +220 -134
- package/contracts/product/RiskService.sol +151 -0
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +72 -40
- package/contracts/registry/IRegistry.sol +72 -32
- package/contracts/registry/IRegistryService.sol +3 -10
- package/contracts/registry/IRelease.sol +26 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +364 -220
- package/contracts/registry/RegistryAdmin.sol +228 -217
- package/contracts/registry/RegistryService.sol +41 -66
- package/contracts/registry/RegistryServiceManager.sol +5 -5
- package/contracts/registry/ReleaseAdmin.sol +245 -0
- package/contracts/registry/ReleaseLifecycle.sol +32 -0
- package/contracts/registry/ReleaseRegistry.sol +511 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +102 -60
- package/contracts/registry/TokenRegistry.sol +8 -10
- package/contracts/shared/Component.sol +71 -126
- package/contracts/shared/ComponentService.sol +463 -380
- package/contracts/shared/ComponentServiceManager.sol +10 -7
- package/contracts/shared/ComponentVerifyingService.sol +29 -18
- package/contracts/shared/ContractLib.sol +252 -0
- package/contracts/shared/IComponent.sol +8 -17
- package/contracts/shared/IComponentService.sol +53 -39
- package/contracts/shared/IInstanceLinkedComponent.sol +10 -26
- package/contracts/shared/IKeyValueStore.sol +1 -0
- package/contracts/shared/ILifecycle.sol +3 -2
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/IRegisterable.sol +23 -1
- package/contracts/shared/IService.sol +4 -6
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +3 -3
- package/contracts/shared/InstanceLinkedComponent.sol +95 -42
- package/contracts/shared/KeyValueStore.sol +7 -3
- package/contracts/shared/Lifecycle.sol +30 -72
- package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +1 -1
- package/contracts/shared/NftOwnable.sol +31 -11
- package/contracts/shared/PolicyHolder.sol +17 -57
- package/contracts/shared/Registerable.sol +55 -21
- package/contracts/shared/RegistryLinked.sol +9 -14
- package/contracts/shared/Service.sol +18 -36
- package/contracts/shared/TokenHandler.sol +357 -26
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +12 -7
- package/contracts/staking/IStakingService.sol +12 -8
- package/contracts/staking/StakeManagerLib.sol +18 -25
- package/contracts/staking/Staking.sol +86 -73
- package/contracts/staking/StakingLifecycle.sol +23 -0
- package/contracts/staking/StakingManager.sol +10 -12
- package/contracts/staking/StakingReader.sol +23 -20
- package/contracts/staking/StakingService.sol +64 -36
- package/contracts/staking/StakingServiceManager.sol +4 -4
- package/contracts/staking/StakingStore.sol +15 -23
- package/contracts/staking/TargetManagerLib.sol +7 -3
- package/contracts/type/Amount.sol +27 -5
- package/contracts/type/Blocknumber.sol +7 -1
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +7 -0
- package/contracts/type/ObjectType.sol +73 -24
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/Referral.sol +1 -0
- package/contracts/type/RiskId.sol +35 -4
- package/contracts/type/RoleId.sol +57 -93
- package/contracts/type/Seconds.sol +21 -1
- package/contracts/type/StateId.sol +15 -1
- package/contracts/type/Timestamp.sol +10 -5
- package/contracts/type/UFixed.sol +40 -121
- package/contracts/type/Version.sol +18 -6
- package/contracts/{shared → upgradeability}/ProxyManager.sol +71 -38
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/contracts/{shared → upgradeability}/Versionable.sol +2 -2
- package/package.json +8 -5
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -709
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -228
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +0 -187
- 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 -708
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -702
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1218
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +0 -4
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +0 -171
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +0 -1559
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +0 -1193
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +0 -1747
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +0 -1760
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +0 -1838
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +0 -1856
- 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/IAccessAdmin.sol/IAccessAdmin.dbg.json +0 -4
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +0 -4
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +0 -1562
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +0 -4
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +0 -1600
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +0 -306
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -617
- 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/InstanceAuthorizationsLib.sol +0 -377
- package/contracts/instance/base/ObjectManager.sol +0 -80
- package/contracts/product/ProductService.sol +0 -124
- package/contracts/product/ProductServiceManager.sol +0 -42
- package/contracts/registry/ReleaseManager.sol +0 -527
- package/contracts/shared/AccessManagerCustom.sol +0 -741
- package/contracts/shared/AccessManagerExtended.sol +0 -481
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +0 -13
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +0 -137
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +0 -14
- package/contracts/shared/IAccessManagerExtended.sol +0 -74
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +0 -18
- package/contracts/shared/InitializableCustom.sol +0 -177
- /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
@@ -0,0 +1,130 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {LibNftIdSet} from "../type/NftIdSet.sol";
|
5
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
6
|
+
import {Key32} from "../type/Key32.sol";
|
7
|
+
import {BUNDLE} from "../type/ObjectType.sol";
|
8
|
+
|
9
|
+
import {ObjectSet} from "./base/ObjectSet.sol";
|
10
|
+
import {ObjectSetHelperLib} from "./base/ObjectSetHelperLib.sol";
|
11
|
+
|
12
|
+
contract BundleSet is
|
13
|
+
ObjectSet
|
14
|
+
{
|
15
|
+
using LibNftIdSet for LibNftIdSet.Set;
|
16
|
+
|
17
|
+
event LogBundleSetPolicyLinked(NftId bundleNftId, NftId policyNftId);
|
18
|
+
event LogBundleSetPolicyUnlinked(NftId bundleNftId, NftId policyNftId);
|
19
|
+
|
20
|
+
event LogBundleSetBundleAdded(NftId poolNftId, NftId bundleNftId);
|
21
|
+
event LogBundleSetBundleUnlocked(NftId poolNftId, NftId bundleNftId);
|
22
|
+
event LogBundleSetBundleLocked(NftId poolNftId, NftId bundleNftId);
|
23
|
+
event LogBundleSetBundleClosed(NftId poolNftId, NftId bundleNftId);
|
24
|
+
|
25
|
+
error ErrorBundleSetPolicyAlreadyActivated(NftId policyNftId);
|
26
|
+
error ErrorBundleSetBundleLocked(NftId bundleNftId, NftId policyNftId);
|
27
|
+
error ErrorBundleSetPolicyWithOpenClaims(NftId policyNftId, uint256 openClaimsCount);
|
28
|
+
error ErrorBundleSetPolicyNotCloseable(NftId policyNftId);
|
29
|
+
error ErrorBundleSetBundleUnknown(NftId bundleNftId);
|
30
|
+
error ErrorBundleSetBundleNotRegistered(NftId bundleNftId);
|
31
|
+
|
32
|
+
mapping(NftId bundleNftId => LibNftIdSet.Set policies) internal _activePolicies;
|
33
|
+
|
34
|
+
/// @dev links a policy to its bundle
|
35
|
+
function linkPolicy(NftId poolNftId, NftId bundleNftId, NftId policyNftId) external restricted() {
|
36
|
+
|
37
|
+
// ensure bundle is unlocked (in active set) and registered with this instance
|
38
|
+
if (!_isActive(poolNftId, _toBundleKey32(bundleNftId))) {
|
39
|
+
revert ErrorBundleSetBundleLocked(bundleNftId, policyNftId);
|
40
|
+
}
|
41
|
+
|
42
|
+
_activePolicies[bundleNftId].add(policyNftId);
|
43
|
+
emit LogBundleSetPolicyLinked(bundleNftId, policyNftId);
|
44
|
+
}
|
45
|
+
|
46
|
+
|
47
|
+
/// @dev unlinks a policy from its bundle
|
48
|
+
function unlinkPolicy(NftId poolNftId, NftId bundleNftId, NftId policyNftId) external restricted() {
|
49
|
+
|
50
|
+
// ensure bundle is registered with this instance
|
51
|
+
if (!_contains(poolNftId, _toBundleKey32(bundleNftId))) {
|
52
|
+
revert ErrorBundleSetBundleUnknown(bundleNftId);
|
53
|
+
}
|
54
|
+
|
55
|
+
_activePolicies[bundleNftId].remove(policyNftId);
|
56
|
+
emit LogBundleSetPolicyUnlinked(bundleNftId, policyNftId);
|
57
|
+
}
|
58
|
+
|
59
|
+
|
60
|
+
/// @dev add a new bundle to a pool registerd with this instance
|
61
|
+
// the corresponding pool is fetched via instance reader
|
62
|
+
function add(NftId bundleNftId) external restricted() {
|
63
|
+
NftId poolNftId = ObjectSetHelperLib.getPoolNftId(_instanceAddress, bundleNftId);
|
64
|
+
|
65
|
+
// ensure pool is registered with instance
|
66
|
+
if(poolNftId.eqz()) {
|
67
|
+
revert ErrorBundleSetBundleNotRegistered(bundleNftId);
|
68
|
+
}
|
69
|
+
|
70
|
+
_add(poolNftId, _toBundleKey32(bundleNftId));
|
71
|
+
emit LogBundleSetBundleAdded(poolNftId, bundleNftId);
|
72
|
+
}
|
73
|
+
|
74
|
+
|
75
|
+
/// @dev unlocked (active) bundles are available to collateralize new policies
|
76
|
+
function unlock(NftId bundleNftId) external restricted() {
|
77
|
+
NftId poolNftId = ObjectSetHelperLib.getPoolNftId(_instanceAddress, bundleNftId);
|
78
|
+
_activate(poolNftId, _toBundleKey32(bundleNftId));
|
79
|
+
emit LogBundleSetBundleUnlocked(poolNftId, bundleNftId);
|
80
|
+
}
|
81
|
+
|
82
|
+
/// @dev locked (deactivated) bundles may not collateralize any new policies
|
83
|
+
function lock(NftId bundleNftId) external restricted() {
|
84
|
+
NftId poolNftId = ObjectSetHelperLib.getPoolNftId(_instanceAddress, bundleNftId);
|
85
|
+
_deactivate(poolNftId, _toBundleKey32(bundleNftId));
|
86
|
+
emit LogBundleSetBundleLocked(poolNftId, bundleNftId);
|
87
|
+
}
|
88
|
+
|
89
|
+
|
90
|
+
function checkBundle(NftId productNftId, NftId bundleId)
|
91
|
+
public
|
92
|
+
view
|
93
|
+
returns (bool exists, bool active)
|
94
|
+
{
|
95
|
+
Key32 bundleKey32 = bundleId.toKey32(BUNDLE());
|
96
|
+
exists = _contains(productNftId, bundleKey32);
|
97
|
+
|
98
|
+
if (exists) {
|
99
|
+
active = _isActive(productNftId, bundleKey32);
|
100
|
+
}
|
101
|
+
}
|
102
|
+
|
103
|
+
function bundles(NftId poolNftId) external view returns(uint256) {
|
104
|
+
return _objects(poolNftId);
|
105
|
+
}
|
106
|
+
|
107
|
+
function getBundleNftId(NftId poolNftId, uint256 idx) external view returns(NftId) {
|
108
|
+
return NftIdLib.toNftId(_getObject(poolNftId, idx).toKeyId());
|
109
|
+
}
|
110
|
+
|
111
|
+
function activeBundles(NftId poolNftId) external view returns(uint256) {
|
112
|
+
return _activeObjs(poolNftId);
|
113
|
+
}
|
114
|
+
|
115
|
+
function getActiveBundleNftId(NftId poolNftId, uint256 idx) external view returns(NftId) {
|
116
|
+
return NftIdLib.toNftId(_getActiveObject(poolNftId, idx).toKeyId());
|
117
|
+
}
|
118
|
+
|
119
|
+
function activePolicies(NftId bundleNftId) external view returns(uint256) {
|
120
|
+
return _activePolicies[bundleNftId].size();
|
121
|
+
}
|
122
|
+
|
123
|
+
function getActivePolicy(NftId bundleNftId, uint256 idx) external view returns(NftId policyNftId) {
|
124
|
+
return _activePolicies[bundleNftId].getElementAt(idx);
|
125
|
+
}
|
126
|
+
|
127
|
+
function _toBundleKey32(NftId nftId) private pure returns (Key32) {
|
128
|
+
return nftId.toKey32(BUNDLE());
|
129
|
+
}
|
130
|
+
}
|
@@ -1,57 +1,33 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
5
|
-
|
6
4
|
import {Amount} from "../type/Amount.sol";
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
5
|
+
import {BundleSet} from "./BundleSet.sol";
|
6
|
+
import {RiskSet} from "./RiskSet.sol";
|
7
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
8
|
+
import {InstanceReader} from "./InstanceReader.sol";
|
9
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
10
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
10
11
|
import {NftId} from "../type/NftId.sol";
|
11
|
-
import {StateId} from "../type/StateId.sol";
|
12
|
-
import {ReferralId} from "../type/Referral.sol";
|
13
|
-
import {RiskId} from "../type/RiskId.sol";
|
14
|
-
import {VersionPart} from "../type/Version.sol";
|
15
|
-
import {Key32} from "../type/Key32.sol";
|
16
12
|
import {RoleId} from "../type/RoleId.sol";
|
17
13
|
import {Seconds} from "../type/Seconds.sol";
|
18
14
|
import {UFixed} from "../type/UFixed.sol";
|
19
15
|
|
20
|
-
import {AccessManagerExtendedInitializeable} from "../shared/AccessManagerExtendedInitializeable.sol";
|
21
|
-
import {IRegisterable} from "../shared/IRegisterable.sol";
|
22
|
-
|
23
|
-
import {ITransferInterceptor} from "../registry/ITransferInterceptor.sol";
|
24
|
-
|
25
|
-
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
26
|
-
import {BundleManager} from "./BundleManager.sol";
|
27
|
-
import {InstanceReader} from "./InstanceReader.sol";
|
28
|
-
import {InstanceStore} from "./InstanceStore.sol";
|
29
|
-
|
30
|
-
import {IKeyValueStore} from "../shared/IKeyValueStore.sol";
|
31
|
-
|
32
|
-
import {IAccess} from "./module/IAccess.sol";
|
33
|
-
|
34
|
-
import {IBundleService} from "../pool/IBundleService.sol";
|
35
|
-
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
36
|
-
import {IPolicyService} from "../product/IPolicyService.sol";
|
37
|
-
import {IPoolService} from "../pool/IPoolService.sol";
|
38
|
-
import {IProductService} from "../product/IProductService.sol";
|
39
|
-
import {IPolicyService} from "../product/IPolicyService.sol";
|
40
|
-
import {IBundleService} from "../pool/IBundleService.sol";
|
41
|
-
|
42
16
|
|
43
17
|
interface IInstance is
|
44
|
-
IRegisterable
|
45
|
-
ITransferInterceptor,
|
46
|
-
IAccessManaged
|
18
|
+
IRegisterable
|
47
19
|
{
|
48
20
|
error ErrorInstanceInstanceAdminZero();
|
49
21
|
error ErrorInstanceInstanceAdminAlreadySet(address InstanceAdmin);
|
50
22
|
error ErrorInstanceInstanceAdminAuthorityMismatch(address instanceAuthority);
|
51
23
|
|
52
|
-
error
|
53
|
-
error
|
54
|
-
error
|
24
|
+
error ErrorInstanceBundleSetAlreadySet(address instanceBundleSet);
|
25
|
+
error ErrorInstanceBundleSetInstanceMismatch(address instance);
|
26
|
+
error ErrorInstanceBundleSetAuthorityMismatch(address instanceAuthority);
|
27
|
+
|
28
|
+
error ErrorInstanceRiskSetAlreadySet(address instanceRiskSet);
|
29
|
+
error ErrorInstanceRiskSetInstanceMismatch(address instance);
|
30
|
+
error ErrorInstanceRiskSetAuthorityMismatch(address instanceAuthority);
|
55
31
|
|
56
32
|
error ErrorInstanceInstanceReaderInstanceMismatch(address instanceAuthority);
|
57
33
|
|
@@ -62,26 +38,29 @@ interface IInstance is
|
|
62
38
|
uint64 requestsCount;
|
63
39
|
}
|
64
40
|
|
41
|
+
/// @dev Register a product with the instance.
|
42
|
+
function registerProduct(address product) external returns (NftId productNftId);
|
43
|
+
|
65
44
|
function createRole(string memory roleName, string memory adminName) external returns (RoleId roleId, RoleId admin);
|
66
45
|
function grantRole(RoleId roleId, address account) external;
|
67
46
|
function revokeRole(RoleId roleId, address account) external;
|
68
47
|
|
69
48
|
function createTarget(address target, string memory name) external;
|
70
49
|
function setTargetFunctionRole(string memory targetName, bytes4[] calldata selectors, RoleId roleId) external;
|
71
|
-
function
|
50
|
+
function setLocked(address target, bool locked) external;
|
72
51
|
|
73
52
|
function setStakingLockingPeriod(Seconds stakeLockingPeriod) external;
|
74
53
|
function setStakingRewardRate(UFixed rewardRate) external;
|
75
54
|
function refillStakingRewardReserves(Amount dipAmount) external;
|
76
55
|
|
77
|
-
/// @dev
|
78
|
-
///
|
56
|
+
/// @dev Defunds the staking reward reserves for the specified target.
|
57
|
+
/// Permissioned: only the target owner may call this function.
|
79
58
|
function withdrawStakingRewardReserves(Amount dipAmount) external returns (Amount newBalance);
|
80
59
|
|
81
|
-
|
60
|
+
// get instance release and supporting contracts
|
82
61
|
function getInstanceReader() external view returns (InstanceReader);
|
83
|
-
function
|
62
|
+
function getBundleSet() external view returns (BundleSet);
|
63
|
+
function getRiskSet() external view returns (RiskSet);
|
84
64
|
function getInstanceAdmin() external view returns (InstanceAdmin);
|
85
65
|
function getInstanceStore() external view returns (InstanceStore);
|
86
|
-
function getInstanceAccessManager() external view returns (AccessManagerExtendedInitializeable);
|
87
66
|
}
|
@@ -2,12 +2,10 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {Amount} from "../type/Amount.sol";
|
5
|
-
import {
|
6
|
-
import {Instance} from "./Instance.sol";
|
5
|
+
import {IInstance} from "./IInstance.sol";
|
7
6
|
import {IService} from "../shared/IService.sol";
|
8
7
|
import {NftId} from "../type/NftId.sol";
|
9
8
|
import {ObjectType} from "../type/ObjectType.sol";
|
10
|
-
import {RoleId} from "../type/RoleId.sol";
|
11
9
|
import {Seconds} from "../type/Seconds.sol";
|
12
10
|
import {UFixed} from "../type/UFixed.sol";
|
13
11
|
import {VersionPart} from "../type/Version.sol";
|
@@ -22,9 +20,9 @@ interface IInstanceService is IService {
|
|
22
20
|
error ErrorInstanceServiceComponentNotInstanceLinked(address component);
|
23
21
|
|
24
22
|
error ErrorInstanceServiceMasterInstanceAlreadySet();
|
25
|
-
error ErrorInstanceServiceMasterInstanceAccessManagerAlreadySet();
|
26
23
|
error ErrorInstanceServiceMasterInstanceAdminAlreadySet();
|
27
|
-
error
|
24
|
+
error ErrorInstanceServiceMasterBundleSetAlreadySet();
|
25
|
+
error ErrorInstanceServiceMasterRiskSetAlreadySet();
|
28
26
|
error ErrorInstanceServiceInstanceAddressZero();
|
29
27
|
|
30
28
|
error ErrorInstanceServiceMasterInstanceReaderNotSet();
|
@@ -32,15 +30,19 @@ interface IInstanceService is IService {
|
|
32
30
|
error ErrorInstanceServiceInstanceReaderSameAsMasterInstanceReader();
|
33
31
|
error ErrorInstanceServiceInstanceReaderInstanceMismatch();
|
34
32
|
|
33
|
+
error ErrorInstanceServiceAccessManagerZero();
|
35
34
|
error ErrorInstanceServiceInstanceAdminZero();
|
36
35
|
error ErrorInstanceServiceInstanceReaderZero();
|
37
|
-
error
|
36
|
+
error ErrorInstanceServiceBundleSetZero();
|
37
|
+
error ErrorInstanceServiceRiskSetZero();
|
38
38
|
error ErrorInstanceServiceInstanceStoreZero();
|
39
39
|
|
40
40
|
error ErrorInstanceServiceInstanceAuthorityMismatch();
|
41
|
-
error
|
41
|
+
error ErrorInstanceServiceBundleSetAuthorityMismatch();
|
42
|
+
error ErrorInstanceServiceRiskSetAuthorityMismatch();
|
42
43
|
error ErrorInstanceServiceInstanceReaderInstanceMismatch2();
|
43
|
-
error
|
44
|
+
error ErrorInstanceServiceBundleSetInstanceMismatch();
|
45
|
+
error ErrorInstanceServiceRiskSetInstanceMismatch();
|
44
46
|
error ErrorInstanceServiceInstanceStoreAuthorityMismatch();
|
45
47
|
|
46
48
|
error ErrorInstanceServiceRequestUnauhorized(address caller);
|
@@ -49,49 +51,22 @@ interface IInstanceService is IService {
|
|
49
51
|
error ErrorInstanceServiceInstanceComponentMismatch(NftId instanceNftId, NftId componentNftId);
|
50
52
|
error ErrorInstanceServiceInvalidComponentType(address componentAddress, ObjectType expectedType, ObjectType componentType);
|
51
53
|
|
52
|
-
event LogInstanceCloned(
|
53
|
-
address clonedOzAccessManager,
|
54
|
-
address clonedInstanceAccessManager,
|
55
|
-
address clonedInstance,
|
56
|
-
address clonedInstanceStore,
|
57
|
-
address clonedBundleManager,
|
58
|
-
address clonedInstanceReader,
|
59
|
-
NftId clonedInstanceNftId
|
60
|
-
);
|
54
|
+
event LogInstanceCloned(NftId instanceNftId, address instance);
|
61
55
|
|
62
|
-
function
|
56
|
+
function createInstance()
|
63
57
|
external
|
64
58
|
returns (
|
65
|
-
|
66
|
-
Instance clonedInstance,
|
59
|
+
IInstance instance,
|
67
60
|
NftId instanceNftId
|
68
61
|
);
|
69
62
|
|
63
|
+
function upgradeInstanceReader(NftId instanceNftId) external;
|
64
|
+
function upgradeMasterInstanceReader(address instanceReaderAddress) external;
|
70
65
|
|
71
66
|
function setStakingLockingPeriod(Seconds stakeLockingPeriod) external;
|
72
67
|
function setStakingRewardRate(UFixed rewardRate) external;
|
73
68
|
function refillStakingRewardReserves(address rewardProvider, Amount dipAmount) external;
|
74
69
|
|
75
|
-
/// @dev
|
76
|
-
/// permissioned: only the target owner may call this function
|
70
|
+
/// @dev Defunds the staking reward reserves for the specified target.
|
77
71
|
function withdrawStakingRewardReserves(Amount dipAmount) external returns (Amount newBalance);
|
78
|
-
|
79
|
-
|
80
|
-
function createComponentTarget(
|
81
|
-
NftId instanceNftId,
|
82
|
-
address targetAddress,
|
83
|
-
string memory targetName,
|
84
|
-
bytes4[][] memory selectors,
|
85
|
-
RoleId[] memory roles
|
86
|
-
) external;
|
87
|
-
|
88
|
-
function createGifTarget(
|
89
|
-
NftId instanceNftId,
|
90
|
-
address targetAddress,
|
91
|
-
string memory targetName,
|
92
|
-
bytes4[][] memory selectors,
|
93
|
-
RoleId[] memory roles
|
94
|
-
) external;
|
95
|
-
|
96
|
-
function setComponentLocked(bool locked) external;
|
97
72
|
}
|
@@ -1,62 +1,35 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
|
-
|
6
4
|
import {Amount} from "../type/Amount.sol";
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET, COMPONENT, DISTRIBUTOR, DISTRIBUTOR_TYPE} from "../type/ObjectType.sol";
|
11
|
-
import {RoleId, RoleIdLib, eqRoleId, ADMIN_ROLE, INSTANCE_ROLE, INSTANCE_OWNER_ROLE} from "../type/RoleId.sol";
|
12
|
-
import {ClaimId} from "../type/ClaimId.sol";
|
13
|
-
import {ReferralId} from "../type/Referral.sol";
|
14
|
-
import {PayoutId} from "../type/PayoutId.sol";
|
15
|
-
import {DistributorType} from "../type/DistributorType.sol";
|
16
|
-
import {Seconds} from "../type/Seconds.sol";
|
17
|
-
import {UFixed} from "../type/UFixed.sol";
|
18
|
-
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
19
|
-
|
20
|
-
import {Registerable} from "../shared/Registerable.sol";
|
21
|
-
import {TokenHandler} from "../shared/TokenHandler.sol";
|
22
|
-
import {AccessManagerExtendedInitializeable} from "../shared/AccessManagerExtendedInitializeable.sol";
|
23
|
-
|
24
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
25
|
-
|
5
|
+
import {BundleSet} from "./BundleSet.sol";
|
6
|
+
import {RiskSet} from "./RiskSet.sol";
|
7
|
+
import {COMPONENT, INSTANCE} from "../type/ObjectType.sol";
|
26
8
|
import {IInstance} from "./IInstance.sol";
|
9
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
27
10
|
import {IInstanceService} from "./IInstanceService.sol";
|
28
11
|
import {InstanceReader} from "./InstanceReader.sol";
|
29
12
|
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
30
|
-
import {BundleManager} from "./BundleManager.sol";
|
31
13
|
import {InstanceStore} from "./InstanceStore.sol";
|
32
|
-
|
33
|
-
import {
|
34
|
-
|
35
|
-
import {
|
36
|
-
import {
|
37
|
-
import {
|
38
|
-
import {IPolicy} from "./module/IPolicy.sol";
|
39
|
-
import {IRisk} from "./module/IRisk.sol";
|
40
|
-
|
41
|
-
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
42
|
-
import {IPoolService} from "../pool/IPoolService.sol";
|
43
|
-
import {IProductService} from "../product/IProductService.sol";
|
44
|
-
import {IPolicyService} from "../product/IPolicyService.sol";
|
45
|
-
import {IBundleService} from "../pool/IBundleService.sol";
|
14
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
15
|
+
import {NftId} from "../type/NftId.sol";
|
16
|
+
import {Registerable} from "../shared/Registerable.sol";
|
17
|
+
import {RoleId} from "../type/RoleId.sol";
|
18
|
+
import {Seconds} from "../type/Seconds.sol";
|
19
|
+
import {UFixed} from "../type/UFixed.sol";
|
46
20
|
|
47
21
|
contract Instance is
|
48
22
|
IInstance,
|
49
|
-
AccessManagedUpgradeable,
|
50
23
|
Registerable
|
51
24
|
{
|
52
|
-
uint256 public constant GIF_MAJOR_VERSION = 3;
|
53
|
-
|
54
25
|
bool private _initialized;
|
55
26
|
|
27
|
+
IComponentService internal _componentService;
|
56
28
|
IInstanceService internal _instanceService;
|
57
29
|
InstanceAdmin internal _instanceAdmin;
|
58
30
|
InstanceReader internal _instanceReader;
|
59
|
-
|
31
|
+
BundleSet internal _bundleSet;
|
32
|
+
RiskSet internal _riskSet;
|
60
33
|
InstanceStore internal _instanceStore;
|
61
34
|
|
62
35
|
modifier onlyChainNft() {
|
@@ -66,32 +39,72 @@ contract Instance is
|
|
66
39
|
_;
|
67
40
|
}
|
68
41
|
|
69
|
-
function initialize(
|
42
|
+
function initialize(
|
43
|
+
InstanceAdmin instanceAdmin,
|
44
|
+
InstanceStore instanceStore,
|
45
|
+
BundleSet bundleSet,
|
46
|
+
RiskSet riskSet,
|
47
|
+
InstanceReader instanceReader,
|
48
|
+
IRegistry registry,
|
49
|
+
address initialOwner
|
50
|
+
)
|
70
51
|
external
|
71
52
|
initializer()
|
72
53
|
{
|
73
|
-
if(
|
54
|
+
if(address(instanceAdmin) == address(0)) {
|
74
55
|
revert ErrorInstanceInstanceAdminZero();
|
75
56
|
}
|
76
57
|
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
58
|
+
_instanceAdmin = instanceAdmin;
|
59
|
+
|
60
|
+
// setup instance object info
|
61
|
+
__Registerable_init(
|
62
|
+
instanceAdmin.authority(),
|
63
|
+
address(registry),
|
64
|
+
registry.getNftId(),
|
65
|
+
INSTANCE(),
|
66
|
+
true,
|
67
|
+
initialOwner,
|
68
|
+
"");
|
69
|
+
|
70
|
+
// store instance supporting contracts
|
71
|
+
_instanceStore = instanceStore;
|
72
|
+
_bundleSet = bundleSet;
|
73
|
+
_riskSet = riskSet;
|
74
|
+
_instanceReader = instanceReader;
|
75
|
+
|
76
|
+
// initialize instance supporting contracts
|
77
|
+
_instanceStore.initialize();
|
78
|
+
_bundleSet.initialize(instanceAdmin.authority(), address(registry));
|
79
|
+
_riskSet.initialize(instanceAdmin.authority(), address(registry));
|
80
|
+
_instanceReader.initialize();
|
81
|
+
|
82
|
+
_componentService = IComponentService(
|
83
|
+
getRegistry().getServiceAddress(
|
84
|
+
COMPONENT(),
|
85
|
+
getRelease()));
|
81
86
|
|
82
87
|
_instanceService = IInstanceService(
|
83
88
|
getRegistry().getServiceAddress(
|
84
89
|
INSTANCE(),
|
85
|
-
|
90
|
+
getRelease()));
|
86
91
|
|
87
|
-
|
92
|
+
_registerInterface(type(IInstance).interfaceId);
|
93
|
+
}
|
94
|
+
|
95
|
+
//--- ProductRegistration ----------------------------------------------//
|
96
|
+
function registerProduct(address product)
|
97
|
+
external
|
98
|
+
onlyOwner()
|
99
|
+
returns (NftId productNftId)
|
100
|
+
{
|
101
|
+
return _componentService.registerProduct(product);
|
88
102
|
}
|
89
103
|
|
90
104
|
//--- Staking ----------------------------------------------------------//
|
91
105
|
|
92
106
|
function setStakingLockingPeriod(Seconds stakeLockingPeriod)
|
93
107
|
external
|
94
|
-
// TODO decide if onlyOwner or restricted to instance owner role is better
|
95
108
|
onlyOwner()
|
96
109
|
{
|
97
110
|
_instanceService.setStakingLockingPeriod(stakeLockingPeriod);
|
@@ -124,37 +137,36 @@ contract Instance is
|
|
124
137
|
|
125
138
|
function createRole(string memory roleName, string memory adminName)
|
126
139
|
external
|
127
|
-
|
128
|
-
restricted // INSTANCE_OWNER_ROLE
|
140
|
+
onlyOwner()
|
129
141
|
returns (RoleId roleId, RoleId admin)
|
130
142
|
{
|
131
|
-
|
143
|
+
// TODO refactor
|
144
|
+
// (roleId, admin) = _instanceAdmin.createRole(roleName, adminName);
|
132
145
|
}
|
133
146
|
|
134
147
|
function grantRole(RoleId roleId, address account)
|
135
148
|
external
|
136
|
-
|
137
|
-
restricted // INSTANCE_OWNER_ROLE
|
149
|
+
onlyOwner()
|
138
150
|
{
|
139
|
-
|
151
|
+
_instanceAdmin.grantRole(roleId, account);
|
140
152
|
}
|
141
153
|
|
142
154
|
function revokeRole(RoleId roleId, address account)
|
143
155
|
external
|
144
|
-
|
145
|
-
restricted // INSTANCE_OWNER_ROLE
|
156
|
+
onlyOwner()
|
146
157
|
{
|
147
|
-
|
158
|
+
// TODO refactor
|
159
|
+
// AccessManagerExtendedInitializeable(authority()).revokeRole(roleId.toInt(), account);
|
148
160
|
}
|
149
161
|
|
150
162
|
//--- Targets ------------------------------------------------------------//
|
151
163
|
|
152
164
|
function createTarget(address target, string memory name)
|
153
165
|
external
|
154
|
-
|
155
|
-
restricted // INSTANCE_OWNER_ROLE
|
166
|
+
onlyOwner()
|
156
167
|
{
|
157
|
-
|
168
|
+
// TODO refactor
|
169
|
+
// _instanceAdmin.createTarget(target, name);
|
158
170
|
}
|
159
171
|
|
160
172
|
function setTargetFunctionRole(
|
@@ -163,59 +175,33 @@ contract Instance is
|
|
163
175
|
RoleId roleId
|
164
176
|
)
|
165
177
|
external
|
166
|
-
|
178
|
+
onlyOwner()
|
167
179
|
{
|
168
|
-
|
180
|
+
// TODO refactor
|
181
|
+
// _instanceAdmin.setTargetFunctionRoleByInstance(targetName, selectors, roleId);
|
169
182
|
}
|
170
183
|
|
171
|
-
function
|
184
|
+
function setLocked(address target, bool locked)
|
172
185
|
external
|
173
|
-
|
186
|
+
onlyOwner()
|
174
187
|
{
|
175
|
-
|
188
|
+
_componentService.setLockedFromInstance(target, locked);
|
176
189
|
}
|
177
190
|
|
178
191
|
//--- ITransferInterceptor ----------------------------------------------//
|
179
192
|
|
180
|
-
|
181
|
-
|
182
|
-
_instanceAdmin.transferInstanceOwnerRole(
|
193
|
+
function nftTransferFrom(address from, address to, uint256 tokenId, address operator) external onlyChainNft {
|
194
|
+
// TODO refactor
|
195
|
+
// _instanceAdmin.transferInstanceOwnerRole(from, to);
|
183
196
|
}
|
184
197
|
|
185
|
-
function nftTransferFrom(address from, address to, uint256 tokenId) external onlyChainNft {
|
186
|
-
_instanceAdmin.transferInstanceOwnerRole(from, to);
|
187
|
-
}
|
188
|
-
|
189
|
-
//function nftBurn(address from, uint256 tokenId) external onlyChainNft {
|
190
|
-
//_instanceAdmin.transferInstanceOwnerRole(from, address(0));
|
191
|
-
//}
|
192
|
-
|
193
198
|
//--- initial setup functions -------------------------------------------//
|
194
199
|
|
195
|
-
function setInstanceAdmin(InstanceAdmin accessManager) external restricted {
|
196
|
-
if(address(_instanceAdmin) != address(0)) {
|
197
|
-
revert ErrorInstanceInstanceAdminAlreadySet(address(_instanceAdmin));
|
198
|
-
}
|
199
|
-
if(accessManager.authority() != authority()) {
|
200
|
-
revert ErrorInstanceInstanceAdminAuthorityMismatch(authority());
|
201
|
-
}
|
202
|
-
_instanceAdmin = accessManager;
|
203
|
-
}
|
204
|
-
|
205
|
-
function setBundleManager(BundleManager bundleManager) external restricted() {
|
206
|
-
if(address(_bundleManager) != address(0)) {
|
207
|
-
revert ErrorInstanceBundleManagerAlreadySet(address(_bundleManager));
|
208
|
-
}
|
209
|
-
if(bundleManager.getInstance() != Instance(this)) {
|
210
|
-
revert ErrorInstanceBundleManagerInstanceMismatch(address(this));
|
211
|
-
}
|
212
|
-
if(bundleManager.authority() != authority()) {
|
213
|
-
revert ErrorInstanceBundleManagerAuthorityMismatch(authority());
|
214
|
-
}
|
215
|
-
_bundleManager = bundleManager;
|
216
|
-
}
|
217
200
|
|
218
|
-
function setInstanceReader(InstanceReader instanceReader)
|
201
|
+
function setInstanceReader(InstanceReader instanceReader)
|
202
|
+
external
|
203
|
+
restricted()
|
204
|
+
{
|
219
205
|
if(instanceReader.getInstance() != Instance(this)) {
|
220
206
|
revert ErrorInstanceInstanceReaderInstanceMismatch(address(this));
|
221
207
|
}
|
@@ -223,41 +209,27 @@ contract Instance is
|
|
223
209
|
_instanceReader = instanceReader;
|
224
210
|
}
|
225
211
|
|
226
|
-
function setInstanceStore(InstanceStore instanceStore) external restricted {
|
227
|
-
if(address(_instanceStore) != address(0)) {
|
228
|
-
revert ErrorInstanceInstanceStoreAlreadySet(address(_instanceStore));
|
229
|
-
}
|
230
|
-
if(instanceStore.authority() != authority()) {
|
231
|
-
revert ErrorInstanceInstanceStoreAuthorityMismatch(authority());
|
232
|
-
}
|
233
|
-
_instanceStore = instanceStore;
|
234
|
-
}
|
235
|
-
|
236
212
|
//--- external view functions -------------------------------------------//
|
237
213
|
|
238
214
|
function getInstanceReader() external view returns (InstanceReader) {
|
239
215
|
return _instanceReader;
|
240
216
|
}
|
241
217
|
|
242
|
-
function
|
243
|
-
return
|
218
|
+
function getBundleSet() external view returns (BundleSet) {
|
219
|
+
return _bundleSet;
|
244
220
|
}
|
245
221
|
|
246
|
-
function
|
247
|
-
return
|
222
|
+
function getRiskSet() external view returns (RiskSet) {
|
223
|
+
return _riskSet;
|
248
224
|
}
|
249
225
|
|
250
|
-
function
|
251
|
-
return
|
226
|
+
function getInstanceAdmin() external view returns (InstanceAdmin) {
|
227
|
+
return _instanceAdmin;
|
252
228
|
}
|
253
229
|
|
254
230
|
function getInstanceStore() external view returns (InstanceStore) {
|
255
231
|
return _instanceStore;
|
256
232
|
}
|
257
233
|
|
258
|
-
function getMajorVersion() public pure returns (VersionPart majorVersion) {
|
259
|
-
return VersionPartLib.toVersionPart(GIF_MAJOR_VERSION);
|
260
|
-
}
|
261
|
-
|
262
234
|
//--- internal view/pure functions --------------------------------------//
|
263
235
|
}
|