@etherisc/gif-next 0.0.2-9d962ff-943 → 0.0.2-9daf7a4-699
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 +87 -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 +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +496 -255
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.json +24 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +673 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +202 -5
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +277 -20
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +395 -203
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +143 -19
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +19 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +68 -5
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +151 -490
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +265 -31
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +82 -386
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +382 -359
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +143 -129
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +84 -198
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +252 -126
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1445 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +644 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2002 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +644 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1388 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +644 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1152 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1612 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +644 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2389 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +644 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +193 -45
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +236 -39
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +144 -93
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +256 -123
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +737 -327
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +209 -94
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1080 -352
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +172 -278
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +106 -106
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +859 -712
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +853 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +46 -5
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +16 -5
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +108 -355
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +247 -33
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +91 -140
- 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 +84 -323
- 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 +132 -98
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +132 -421
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +265 -31
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +281 -320
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +132 -118
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +178 -103
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +120 -236
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +460 -308
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +110 -416
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +456 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +673 -552
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +173 -107
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +194 -178
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +110 -100
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +261 -439
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +265 -31
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +415 -234
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +150 -124
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +136 -9
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +308 -16
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +354 -106
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +157 -83
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +245 -233
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +88 -8
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +445 -308
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +293 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +151 -109
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +230 -336
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +119 -141
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +253 -431
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +688 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +736 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +342 -42
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +144 -41
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +548 -103
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +640 -368
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +878 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +109 -292
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +104 -90
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +1954 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +47 -6
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +431 -253
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +66 -8
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +15 -15
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +67 -277
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +511 -651
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +142 -138
- 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 +597 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +80 -100
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +463 -300
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +91 -140
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +36 -0
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +36 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +16 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +148 -0
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +55 -2
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +2 -22
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +83 -322
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +42 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +22 -57
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +122 -97
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +57 -111
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +585 -12
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +196 -143
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +152 -20
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +280 -397
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +469 -0
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +46 -5
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +136 -105
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +41 -73
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +205 -168
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +113 -95
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +205 -150
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +90 -49
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +35 -11
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +94 -38
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +33 -31
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +125 -7
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +79 -15
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/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 +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +23 -4
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +73 -36
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +101 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +81 -80
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +15 -2
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/accounting/AccountingService.sol +262 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +45 -0
- package/contracts/authorization/AccessAdmin.sol +338 -225
- package/contracts/authorization/AccessAdminLib.sol +183 -0
- package/contracts/authorization/AccessManagerCloneable.sol +146 -4
- package/contracts/authorization/Authorization.sol +350 -203
- package/contracts/authorization/IAccess.sol +13 -4
- package/contracts/authorization/IAccessAdmin.sol +69 -35
- package/contracts/authorization/IAuthorization.sol +33 -7
- package/contracts/authorization/IServiceAuthorization.sol +3 -1
- package/contracts/authorization/ServiceAuthorization.sol +26 -10
- package/contracts/distribution/BasicDistribution.sol +20 -17
- package/contracts/distribution/BasicDistributionAuthorization.sol +22 -9
- package/contracts/distribution/Distribution.sol +37 -88
- package/contracts/distribution/DistributionService.sol +167 -119
- package/contracts/distribution/DistributionServiceManager.sol +6 -6
- package/contracts/distribution/IDistributionComponent.sol +1 -10
- package/contracts/distribution/IDistributionService.sol +31 -25
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +86 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
- package/contracts/examples/fire/FireProduct.sol +433 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +373 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +42 -38
- package/contracts/instance/IInstance.sol +64 -44
- package/contracts/instance/IInstanceService.sol +27 -31
- package/contracts/instance/Instance.sol +120 -70
- package/contracts/instance/InstanceAdmin.sol +287 -103
- package/contracts/instance/InstanceAuthorizationV3.sol +92 -61
- package/contracts/instance/InstanceReader.sol +288 -43
- package/contracts/instance/InstanceService.sol +207 -191
- package/contracts/instance/InstanceServiceManager.sol +6 -7
- package/contracts/instance/InstanceStore.sol +23 -2
- package/contracts/instance/RiskSet.sol +118 -0
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +11 -4
- package/contracts/instance/base/ObjectSet.sol +31 -33
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IBundle.sol +6 -5
- package/contracts/instance/module/IComponents.sol +30 -19
- package/contracts/instance/module/IDistribution.sol +21 -8
- package/contracts/instance/module/IPolicy.sol +50 -29
- package/contracts/instance/module/IRisk.sol +5 -0
- package/contracts/oracle/BasicOracle.sol +1 -4
- package/contracts/oracle/BasicOracleAuthorization.sol +3 -12
- package/contracts/oracle/IOracle.sol +9 -4
- package/contracts/oracle/IOracleService.sol +2 -1
- package/contracts/oracle/Oracle.sol +7 -19
- package/contracts/oracle/OracleService.sol +113 -81
- package/contracts/oracle/OracleServiceManager.sol +6 -6
- package/contracts/pool/BasicPool.sol +37 -28
- package/contracts/pool/BasicPoolAuthorization.sol +32 -11
- package/contracts/pool/BundleService.sol +179 -125
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +29 -34
- package/contracts/pool/IPoolComponent.sol +19 -15
- package/contracts/pool/IPoolService.sol +90 -75
- package/contracts/pool/Pool.sol +145 -130
- package/contracts/pool/PoolLib.sol +216 -0
- package/contracts/pool/PoolService.sol +538 -217
- package/contracts/pool/PoolServiceManager.sol +4 -4
- package/contracts/product/ApplicationService.sol +87 -43
- package/contracts/product/ApplicationServiceManager.sol +4 -4
- package/contracts/product/BasicProduct.sol +10 -13
- package/contracts/product/BasicProductAuthorization.sol +24 -11
- package/contracts/product/ClaimService.sol +368 -153
- package/contracts/product/ClaimServiceManager.sol +4 -4
- package/contracts/product/IApplicationService.sol +9 -2
- package/contracts/product/IClaimService.sol +44 -8
- package/contracts/product/IPolicyService.sol +53 -38
- package/contracts/product/IPricingService.sol +11 -10
- package/contracts/product/IProductComponent.sol +27 -5
- package/contracts/product/{IProductService.sol → IRiskService.sol} +8 -8
- package/contracts/product/PolicyService.sol +446 -281
- package/contracts/product/PolicyServiceLib.sol +65 -0
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +69 -60
- package/contracts/product/PricingServiceManager.sol +4 -4
- package/contracts/product/Product.sol +161 -95
- package/contracts/product/RiskService.sol +154 -0
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +72 -40
- package/contracts/registry/IRegistry.sol +64 -28
- package/contracts/registry/IRegistryService.sol +5 -12
- package/contracts/registry/IRelease.sol +29 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +357 -203
- package/contracts/registry/RegistryAdmin.sol +162 -269
- package/contracts/registry/RegistryAuthorization.sol +267 -0
- package/contracts/registry/RegistryService.sol +37 -48
- package/contracts/registry/RegistryServiceManager.sol +3 -3
- package/contracts/registry/ReleaseAdmin.sol +253 -0
- package/contracts/registry/ReleaseLifecycle.sol +8 -3
- package/contracts/registry/ReleaseRegistry.sol +272 -240
- package/contracts/registry/ServiceAuthorizationV3.sol +183 -52
- package/contracts/registry/TokenRegistry.sol +10 -9
- package/contracts/shared/Component.sol +65 -135
- package/contracts/shared/ComponentService.sol +435 -378
- package/contracts/shared/ComponentServiceManager.sol +8 -5
- package/contracts/shared/ComponentVerifyingService.sol +28 -17
- package/contracts/shared/ContractLib.sol +281 -0
- package/contracts/shared/IComponent.sol +5 -17
- package/contracts/shared/IComponentService.sol +44 -40
- package/contracts/shared/IInstanceLinkedComponent.sol +6 -32
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/IRegisterable.sol +23 -1
- package/contracts/shared/IService.sol +3 -5
- package/contracts/shared/InitializableERC165.sol +10 -2
- package/contracts/shared/InstanceLinkedComponent.sol +73 -50
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +29 -9
- package/contracts/shared/PolicyHolder.sol +15 -52
- package/contracts/shared/Registerable.sol +52 -21
- package/contracts/shared/RegistryLinked.sol +9 -14
- package/contracts/shared/Service.sol +15 -32
- package/contracts/shared/TokenHandler.sol +310 -26
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +25 -13
- package/contracts/staking/IStakingService.sol +16 -4
- package/contracts/staking/Staking.sol +103 -73
- package/contracts/staking/{StakeManagerLib.sol → StakingLib.sol} +95 -45
- package/contracts/staking/StakingManager.sol +8 -6
- package/contracts/staking/StakingReader.sol +18 -21
- package/contracts/staking/StakingService.sol +90 -37
- package/contracts/staking/StakingServiceManager.sol +6 -5
- package/contracts/staking/StakingStore.sol +2 -1
- package/contracts/staking/TargetManagerLib.sol +7 -3
- package/contracts/type/Amount.sol +15 -0
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Fee.sol +8 -8
- 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 +57 -34
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/RiskId.sol +38 -6
- package/contracts/type/RoleId.sol +23 -15
- package/contracts/type/Seconds.sol +21 -1
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/StateId.sol +15 -1
- package/contracts/type/Timestamp.sol +4 -5
- package/contracts/type/UFixed.sol +37 -126
- package/contracts/type/Version.sol +54 -5
- package/contracts/upgradeability/ProxyManager.sol +79 -43
- package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +7 -1
- package/contracts/upgradeability/Versionable.sol +2 -2
- package/package.json +5 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +0 -290
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +0 -390
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
- package/artifacts/contracts/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/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -470
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -16
- package/contracts/authorization/IModuleAuthorization.sol +0 -21
- package/contracts/authorization/ModuleAuthorization.sol +0 -78
- package/contracts/instance/module/IAccess.sol +0 -46
- package/contracts/product/ProductService.sol +0 -99
- package/contracts/product/ProductServiceManager.sol +0 -39
- package/contracts/shared/InitializableCustom.sol +0 -177
package/contracts/pool/Pool.sol
CHANGED
@@ -2,7 +2,8 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {Amount, AmountLib} from "../type/Amount.sol";
|
5
|
-
import {BUNDLE, COMPONENT, POOL} from "../type/ObjectType.sol";
|
5
|
+
import {BUNDLE, COMPONENT, POLICY, POOL} from "../type/ObjectType.sol";
|
6
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
6
7
|
import {IBundleService} from "./IBundleService.sol";
|
7
8
|
import {IAuthorization} from "../authorization/IAuthorization.sol";
|
8
9
|
import {IPoolComponent} from "./IPoolComponent.sol";
|
@@ -10,12 +11,13 @@ import {IPoolService} from "./IPoolService.sol";
|
|
10
11
|
import {IComponents} from "../instance/module/IComponents.sol";
|
11
12
|
import {IComponentService} from "../shared/IComponentService.sol";
|
12
13
|
import {InstanceLinkedComponent} from "../shared/InstanceLinkedComponent.sol";
|
13
|
-
import {
|
14
|
-
import {
|
14
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
15
|
+
import {Fee} from "../type/Fee.sol";
|
16
|
+
import {NftId} from "../type/NftId.sol";
|
15
17
|
import {RoleId, PUBLIC_ROLE} from "../type/RoleId.sol";
|
16
18
|
import {Seconds} from "../type/Seconds.sol";
|
17
|
-
import {
|
18
|
-
import {UFixed
|
19
|
+
import {Timestamp} from "../type/Timestamp.sol";
|
20
|
+
import {UFixed} from "../type/UFixed.sol";
|
19
21
|
|
20
22
|
abstract contract Pool is
|
21
23
|
InstanceLinkedComponent,
|
@@ -25,6 +27,7 @@ abstract contract Pool is
|
|
25
27
|
bytes32 public constant POOL_STORAGE_LOCATION_V1 = 0x25e3e51823fbfffb988e0a2744bb93722d9f3e906c07cc0a9e77884c46c58300;
|
26
28
|
|
27
29
|
struct PoolStorage {
|
30
|
+
IComponents.PoolInfo _poolInfo;
|
28
31
|
IComponentService _componentService;
|
29
32
|
IPoolService _poolService;
|
30
33
|
IBundleService _bundleService;
|
@@ -39,23 +42,29 @@ abstract contract Pool is
|
|
39
42
|
}
|
40
43
|
|
41
44
|
|
45
|
+
// TODO remove function once this is no longer used to produce contract locations on the fly ...
|
46
|
+
function getContractLocation(bytes memory name) external pure returns (bytes32 hash) {
|
47
|
+
return keccak256(abi.encode(uint256(keccak256(name)) - 1)) & ~bytes32(uint256(0xff));
|
48
|
+
}
|
49
|
+
|
50
|
+
|
42
51
|
/// @dev see {IPoolComponent.verifyApplication}
|
43
52
|
function verifyApplication(
|
44
53
|
NftId applicationNftId,
|
45
|
-
bytes memory applicationData,
|
46
54
|
NftId bundleNftId,
|
47
|
-
bytes memory bundleFilter,
|
48
55
|
Amount collateralizationAmount
|
49
56
|
)
|
50
57
|
public
|
51
58
|
virtual
|
52
59
|
restricted()
|
60
|
+
onlyNftOfType(applicationNftId, POLICY())
|
53
61
|
{
|
62
|
+
InstanceReader reader = _getInstanceReader();
|
54
63
|
if(!applicationMatchesBundle(
|
55
64
|
applicationNftId,
|
56
|
-
applicationData,
|
65
|
+
reader.getPolicyInfo(applicationNftId).applicationData,
|
57
66
|
bundleNftId,
|
58
|
-
|
67
|
+
reader.getBundleInfo(bundleNftId).filter,
|
59
68
|
collateralizationAmount)
|
60
69
|
)
|
61
70
|
{
|
@@ -66,9 +75,25 @@ abstract contract Pool is
|
|
66
75
|
}
|
67
76
|
|
68
77
|
|
78
|
+
/// @dev see {IPoolComponent.processConfirmedClaim}
|
79
|
+
function processConfirmedClaim(
|
80
|
+
NftId policyNftId,
|
81
|
+
ClaimId claimId,
|
82
|
+
Amount amount
|
83
|
+
)
|
84
|
+
public
|
85
|
+
virtual
|
86
|
+
restricted()
|
87
|
+
onlyNftOfType(policyNftId, POLICY())
|
88
|
+
{
|
89
|
+
// default implementation is empty
|
90
|
+
}
|
91
|
+
|
92
|
+
|
69
93
|
/// @dev see {IPoolComponent.applicationMatchesBundle}
|
70
|
-
///
|
71
|
-
///
|
94
|
+
/// Default implementation always returns true.
|
95
|
+
/// Override this function to implement any custom application verification.
|
96
|
+
/// Calling super.applicationMatchesBundle will ensure validation of application and bundle nft ids.
|
72
97
|
function applicationMatchesBundle(
|
73
98
|
NftId applicationNftId,
|
74
99
|
bytes memory applicationData,
|
@@ -79,65 +104,32 @@ abstract contract Pool is
|
|
79
104
|
public
|
80
105
|
virtual
|
81
106
|
view
|
107
|
+
onlyNftOfType(applicationNftId, POLICY())
|
108
|
+
onlyNftOfType(bundleNftId, BUNDLE())
|
82
109
|
returns (bool isMatching)
|
83
110
|
{
|
84
111
|
return true;
|
85
112
|
}
|
86
113
|
|
87
114
|
|
88
|
-
function register()
|
89
|
-
external
|
90
|
-
virtual
|
91
|
-
onlyOwner()
|
92
|
-
{
|
93
|
-
_getPoolStorage()._componentService.registerPool();
|
94
|
-
_approveTokenHandler(type(uint256).max);
|
95
|
-
}
|
96
|
-
|
97
|
-
/// @inheritdoc IPoolComponent
|
98
|
-
function withdrawBundleFees(NftId bundleNftId, Amount amount)
|
99
|
-
external
|
100
|
-
virtual
|
101
|
-
restricted()
|
102
|
-
onlyBundleOwner(bundleNftId)
|
103
|
-
returns (Amount withdrawnAmount)
|
104
|
-
{
|
105
|
-
return _withdrawBundleFees(bundleNftId, amount);
|
106
|
-
}
|
107
|
-
|
108
|
-
|
109
115
|
function getInitialPoolInfo()
|
110
116
|
public
|
111
117
|
virtual
|
112
118
|
view
|
113
119
|
returns (IComponents.PoolInfo memory poolInfo)
|
114
120
|
{
|
115
|
-
return
|
116
|
-
NftIdLib.zero(), // will be set when GIF registers the related product
|
117
|
-
PUBLIC_ROLE(), // bundleOwnerRole
|
118
|
-
AmountLib.max(), // maxCapitalAmount,
|
119
|
-
isNftInterceptor(), // isInterceptingBundleTransfers
|
120
|
-
false, // isExternallyManaged,
|
121
|
-
false, // isVerifyingApplications,
|
122
|
-
UFixedLib.toUFixed(1), // collateralizationLevel,
|
123
|
-
UFixedLib.toUFixed(1), // retentionLevel,
|
124
|
-
FeeLib.zero(), // initialPoolFee,
|
125
|
-
FeeLib.zero(), // initialStakingFee,
|
126
|
-
FeeLib.zero() // initialPerformanceFee,
|
127
|
-
);
|
121
|
+
return _getPoolStorage()._poolInfo;
|
128
122
|
}
|
129
123
|
|
130
124
|
// Internals
|
131
125
|
|
132
126
|
function _initializePool(
|
133
127
|
address registry,
|
134
|
-
NftId
|
128
|
+
NftId productNftId,
|
135
129
|
string memory name,
|
136
|
-
|
130
|
+
IComponents.PoolInfo memory poolInfo,
|
137
131
|
IAuthorization authorization,
|
138
|
-
bool isInterceptingNftTransfers,
|
139
132
|
address initialOwner,
|
140
|
-
bytes memory registryData, // writeonly data that will saved in the object info record of the registry
|
141
133
|
bytes memory componentData // component specifidc data
|
142
134
|
)
|
143
135
|
internal
|
@@ -146,24 +138,106 @@ abstract contract Pool is
|
|
146
138
|
{
|
147
139
|
_initializeInstanceLinkedComponent(
|
148
140
|
registry,
|
149
|
-
|
141
|
+
productNftId,
|
150
142
|
name,
|
151
|
-
token,
|
152
143
|
POOL(),
|
153
144
|
authorization,
|
154
|
-
|
145
|
+
poolInfo.isInterceptingBundleTransfers,
|
155
146
|
initialOwner,
|
156
|
-
registryData,
|
157
147
|
componentData);
|
158
148
|
|
159
149
|
PoolStorage storage $ = _getPoolStorage();
|
150
|
+
|
151
|
+
$._poolInfo = poolInfo;
|
160
152
|
$._poolService = IPoolService(_getServiceAddress(POOL()));
|
161
153
|
$._bundleService = IBundleService(_getServiceAddress(BUNDLE()));
|
162
154
|
$._componentService = IComponentService(_getServiceAddress(COMPONENT()));
|
163
155
|
|
164
|
-
|
156
|
+
_registerInterface(type(IPoolComponent).interfaceId);
|
157
|
+
}
|
158
|
+
|
159
|
+
|
160
|
+
/// @dev Update pool fees to the specified values.
|
161
|
+
/// Pool fee: are deducted from the premium amount and goes to the pool owner.
|
162
|
+
/// Staking fee: are deducted from the staked tokens by a bundle owner and goes to the pool owner.
|
163
|
+
/// Performance fee: when a bundle is closed a bundle specific profit is calculated.
|
164
|
+
/// The performance fee is deducted from this profit and goes to the pool owner.
|
165
|
+
function _setPoolFees(
|
166
|
+
Fee memory poolFee,
|
167
|
+
Fee memory stakingFee,
|
168
|
+
Fee memory performanceFee
|
169
|
+
)
|
170
|
+
internal
|
171
|
+
virtual
|
172
|
+
{
|
173
|
+
_getPoolStorage()._componentService.setPoolFees(poolFee, stakingFee, performanceFee);
|
174
|
+
}
|
175
|
+
|
176
|
+
|
177
|
+
/// @dev Sets the maximum balance amound held by this pool.
|
178
|
+
/// Function may only be called by pool owner.
|
179
|
+
function _setMaxBalanceAmount(Amount maxBalanceAmount)
|
180
|
+
internal
|
181
|
+
virtual
|
182
|
+
{
|
183
|
+
_getPoolStorage()._poolService.setMaxBalanceAmount(maxBalanceAmount);
|
184
|
+
}
|
185
|
+
|
186
|
+
|
187
|
+
/// @dev Fund the pool wallet with the specified amount.
|
188
|
+
/// Function is only available for externally managed pools.
|
189
|
+
function _fundPoolWallet(Amount amount)
|
190
|
+
internal
|
191
|
+
virtual
|
192
|
+
{
|
193
|
+
_getPoolStorage()._poolService.fundPoolWallet(amount);
|
194
|
+
}
|
195
|
+
|
196
|
+
|
197
|
+
/// @dev Withdraw the specified amount from the pool wallet.
|
198
|
+
/// Function is only available for externally managed pools.
|
199
|
+
function _defundPoolWallet(Amount amount)
|
200
|
+
internal
|
201
|
+
virtual
|
202
|
+
{
|
203
|
+
_getPoolStorage()._poolService.defundPoolWallet(amount);
|
165
204
|
}
|
166
205
|
|
206
|
+
|
207
|
+
/// @dev Creates a new empty bundle using the provided parameter values.
|
208
|
+
function _createBundle(
|
209
|
+
address bundleOwner,
|
210
|
+
Fee memory fee,
|
211
|
+
Seconds lifetime,
|
212
|
+
bytes memory filter
|
213
|
+
)
|
214
|
+
internal
|
215
|
+
returns(NftId bundleNftId)
|
216
|
+
{
|
217
|
+
bundleNftId = _getPoolStorage()._bundleService.create(
|
218
|
+
bundleOwner,
|
219
|
+
fee,
|
220
|
+
lifetime,
|
221
|
+
filter);
|
222
|
+
|
223
|
+
// TODO add logging
|
224
|
+
}
|
225
|
+
|
226
|
+
|
227
|
+
/// @dev Sets the fee for the specified bundle.
|
228
|
+
/// The fee is added on top of the poolFee and deducted from the premium amounts
|
229
|
+
/// Via these fees individual bundler owner may earn income per policy in the context of peer to peer pools.
|
230
|
+
function _setBundleFee(
|
231
|
+
NftId bundleNftId,
|
232
|
+
Fee memory fee
|
233
|
+
)
|
234
|
+
internal
|
235
|
+
virtual
|
236
|
+
{
|
237
|
+
_getPoolStorage()._bundleService.setFee(bundleNftId, fee);
|
238
|
+
}
|
239
|
+
|
240
|
+
|
167
241
|
/// @dev increases the staked tokens by the specified amount
|
168
242
|
/// bundle MUST be in active or locked state
|
169
243
|
function _stake(
|
@@ -172,8 +246,9 @@ abstract contract Pool is
|
|
172
246
|
)
|
173
247
|
internal
|
174
248
|
virtual
|
249
|
+
returns(Amount)
|
175
250
|
{
|
176
|
-
|
251
|
+
return _getPoolStorage()._poolService.stake(bundleNftId, amount);
|
177
252
|
}
|
178
253
|
|
179
254
|
|
@@ -185,8 +260,9 @@ abstract contract Pool is
|
|
185
260
|
)
|
186
261
|
internal
|
187
262
|
virtual
|
263
|
+
returns(Amount netAmount)
|
188
264
|
{
|
189
|
-
|
265
|
+
return _getPoolStorage()._poolService.unstake(bundleNftId, amount);
|
190
266
|
}
|
191
267
|
|
192
268
|
|
@@ -198,8 +274,9 @@ abstract contract Pool is
|
|
198
274
|
)
|
199
275
|
internal
|
200
276
|
virtual
|
277
|
+
returns (Timestamp extendedExpiredAt)
|
201
278
|
{
|
202
|
-
|
279
|
+
return _getPoolStorage()._bundleService.extend(bundleNftId, lifetimeExtension);
|
203
280
|
}
|
204
281
|
|
205
282
|
|
@@ -229,7 +306,7 @@ abstract contract Pool is
|
|
229
306
|
/// To close a bundle all all linked policies MUST be in closed state as well.
|
230
307
|
/// Closing a bundle finalizes the bundle bookkeeping including overall profit calculation.
|
231
308
|
/// Once a bundle is closed this action cannot be reversed.
|
232
|
-
function
|
309
|
+
function _closeBundle(NftId bundleNftId)
|
233
310
|
internal
|
234
311
|
virtual
|
235
312
|
{
|
@@ -237,88 +314,26 @@ abstract contract Pool is
|
|
237
314
|
}
|
238
315
|
|
239
316
|
|
240
|
-
/// @dev
|
241
|
-
|
242
|
-
/// Via these fees individual bundler owner may earn income per policy in the context of peer to peer pools.
|
243
|
-
function _setBundleFee(
|
244
|
-
NftId bundleNftId,
|
245
|
-
Fee memory fee
|
246
|
-
)
|
247
|
-
internal
|
248
|
-
virtual
|
249
|
-
{
|
250
|
-
_getPoolStorage()._bundleService.setFee(bundleNftId, fee);
|
251
|
-
}
|
252
|
-
|
253
|
-
|
254
|
-
/// @dev Sets the maximum overall capital amound held by this pool.
|
255
|
-
/// Function may only be called by pool owner.
|
256
|
-
function _setMaxCapitalAmount(Amount maxCapitalAmount)
|
257
|
-
internal
|
258
|
-
virtual
|
259
|
-
{
|
260
|
-
_getPoolStorage()._poolService.setMaxCapitalAmount(maxCapitalAmount);
|
261
|
-
}
|
262
|
-
|
263
|
-
/// @dev Sets the required role to create/own bundles.
|
264
|
-
/// May only be called once after setting up a pool.
|
265
|
-
/// May only be called by pool owner.
|
266
|
-
function _setBundleOwnerRole(RoleId bundleOwnerRole)
|
317
|
+
/// @dev Withdraws the specified amount of fees from the bundle.
|
318
|
+
function _withdrawBundleFees(NftId bundleNftId, Amount amount)
|
267
319
|
internal
|
268
|
-
|
320
|
+
returns (Amount withdrawnAmount)
|
269
321
|
{
|
270
|
-
_getPoolStorage()._poolService.
|
322
|
+
return _getPoolStorage()._poolService.withdrawBundleFees(bundleNftId, amount);
|
271
323
|
}
|
272
324
|
|
273
325
|
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
/// The performance fee is deducted from this profit and goes to the pool owner.
|
279
|
-
function _setPoolFees(
|
280
|
-
Fee memory poolFee,
|
281
|
-
Fee memory stakingFee,
|
282
|
-
Fee memory performanceFee
|
326
|
+
function _processFundedClaim(
|
327
|
+
NftId policyNftId,
|
328
|
+
ClaimId claimId,
|
329
|
+
Amount availableAmount
|
283
330
|
)
|
284
331
|
internal
|
285
|
-
virtual
|
286
332
|
{
|
287
|
-
_getPoolStorage().
|
333
|
+
_getPoolStorage()._poolService.processFundedClaim(
|
334
|
+
policyNftId, claimId, availableAmount);
|
288
335
|
}
|
289
336
|
|
290
|
-
/// @dev Creates a new bundle using the provided parameter values.
|
291
|
-
function _createBundle(
|
292
|
-
address bundleOwner,
|
293
|
-
Fee memory fee,
|
294
|
-
Amount amount,
|
295
|
-
Seconds lifetime,
|
296
|
-
bytes memory filter
|
297
|
-
)
|
298
|
-
internal
|
299
|
-
returns(NftId bundleNftId)
|
300
|
-
{
|
301
|
-
bundleNftId = _getPoolStorage()._poolService.createBundle(
|
302
|
-
bundleOwner,
|
303
|
-
fee,
|
304
|
-
amount,
|
305
|
-
lifetime,
|
306
|
-
filter);
|
307
|
-
|
308
|
-
// TODO add logging
|
309
|
-
}
|
310
|
-
|
311
|
-
// TODO remove function once this is no longer used to produce contract locations on the fly ...
|
312
|
-
function getContractLocation(bytes memory name) external pure returns (bytes32 hash) {
|
313
|
-
return keccak256(abi.encode(uint256(keccak256(name)) - 1)) & ~bytes32(uint256(0xff));
|
314
|
-
}
|
315
|
-
|
316
|
-
function _withdrawBundleFees(NftId bundleNftId, Amount amount)
|
317
|
-
internal
|
318
|
-
returns (Amount withdrawnAmount)
|
319
|
-
{
|
320
|
-
return _getPoolStorage()._bundleService.withdrawBundleFees(bundleNftId, amount);
|
321
|
-
}
|
322
337
|
|
323
338
|
function _getPoolStorage() private pure returns (PoolStorage storage $) {
|
324
339
|
assembly {
|
@@ -0,0 +1,216 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
5
|
+
import {IInstance} from "../instance/IInstance.sol";
|
6
|
+
import {INftOwnable} from "../shared/INftOwnable.sol";
|
7
|
+
import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
|
8
|
+
import {IPoolService} from "./IPoolService.sol";
|
9
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
10
|
+
|
11
|
+
import {Amount, AmountLib} from "../type/Amount.sol";
|
12
|
+
import {ContractLib} from "../shared/ContractLib.sol";
|
13
|
+
import {Fee, FeeLib} from "../type/Fee.sol";
|
14
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
15
|
+
import {InstanceStore} from "../instance/InstanceStore.sol";
|
16
|
+
import {NftId} from "../type/NftId.sol";
|
17
|
+
import {ObjectType, BUNDLE, POOL} from "../type/ObjectType.sol";
|
18
|
+
import {UFixed} from "../type/UFixed.sol";
|
19
|
+
|
20
|
+
library PoolLib {
|
21
|
+
|
22
|
+
/// @dev Calulate required collateral for the provided parameters.
|
23
|
+
function calculateRequiredCollateral(
|
24
|
+
InstanceReader instanceReader,
|
25
|
+
NftId productNftId,
|
26
|
+
Amount sumInsuredAmount
|
27
|
+
)
|
28
|
+
public
|
29
|
+
view
|
30
|
+
returns(
|
31
|
+
NftId poolNftId,
|
32
|
+
Amount totalCollateralAmount,
|
33
|
+
Amount localCollateralAmount,
|
34
|
+
bool poolIsVerifyingApplications
|
35
|
+
)
|
36
|
+
{
|
37
|
+
poolNftId = instanceReader.getProductInfo(productNftId).poolNftId;
|
38
|
+
IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
|
39
|
+
poolIsVerifyingApplications = poolInfo.isVerifyingApplications;
|
40
|
+
|
41
|
+
(
|
42
|
+
totalCollateralAmount,
|
43
|
+
localCollateralAmount
|
44
|
+
) = calculateRequiredCollateral(
|
45
|
+
poolInfo.collateralizationLevel,
|
46
|
+
poolInfo.retentionLevel,
|
47
|
+
sumInsuredAmount);
|
48
|
+
}
|
49
|
+
|
50
|
+
|
51
|
+
/// @dev calulate required collateral for the provided parameters.
|
52
|
+
/// Collateralization is applied to sum insured.
|
53
|
+
/// Retention level defines the fraction of the collateral that is required locally.
|
54
|
+
function calculateRequiredCollateral(
|
55
|
+
UFixed collateralizationLevel,
|
56
|
+
UFixed retentionLevel,
|
57
|
+
Amount sumInsuredAmount
|
58
|
+
)
|
59
|
+
public
|
60
|
+
pure
|
61
|
+
returns(
|
62
|
+
Amount totalCollateralAmount,
|
63
|
+
Amount localCollateralAmount
|
64
|
+
)
|
65
|
+
{
|
66
|
+
// collateralization is applied to sum insured
|
67
|
+
UFixed totalUFixed = collateralizationLevel * sumInsuredAmount.toUFixed();
|
68
|
+
totalCollateralAmount = AmountLib.toAmount(totalUFixed.toInt());
|
69
|
+
|
70
|
+
// retention level defines how much capital is required locally
|
71
|
+
localCollateralAmount = AmountLib.toAmount(
|
72
|
+
(retentionLevel * totalUFixed).toInt());
|
73
|
+
}
|
74
|
+
|
75
|
+
|
76
|
+
function calculateStakingAmounts(
|
77
|
+
IRegistry registry,
|
78
|
+
InstanceReader instanceReader,
|
79
|
+
NftId poolNftId,
|
80
|
+
Amount stakingAmount
|
81
|
+
)
|
82
|
+
public
|
83
|
+
view
|
84
|
+
returns (
|
85
|
+
Amount feeAmount,
|
86
|
+
Amount netStakingAmount
|
87
|
+
)
|
88
|
+
{
|
89
|
+
NftId productNftId = registry.getParentNftId(poolNftId);
|
90
|
+
Fee memory stakingFee = instanceReader.getFeeInfo(productNftId).stakingFee;
|
91
|
+
(
|
92
|
+
feeAmount,
|
93
|
+
netStakingAmount
|
94
|
+
) = FeeLib.calculateFee(
|
95
|
+
stakingFee,
|
96
|
+
stakingAmount);
|
97
|
+
}
|
98
|
+
|
99
|
+
|
100
|
+
function calculatePayoutAmounts(
|
101
|
+
IRegistry registry,
|
102
|
+
InstanceReader instanceReader,
|
103
|
+
NftId productNftId,
|
104
|
+
NftId policyNftId,
|
105
|
+
Amount payoutAmount,
|
106
|
+
address payoutBeneficiary
|
107
|
+
)
|
108
|
+
external
|
109
|
+
view
|
110
|
+
returns (
|
111
|
+
Amount netPayoutAmount,
|
112
|
+
Amount processingFeeAmount,
|
113
|
+
address beneficiary
|
114
|
+
)
|
115
|
+
{
|
116
|
+
// Amount payoutAmount = payoutInfo.amount;
|
117
|
+
|
118
|
+
if(payoutAmount.gtz()) {
|
119
|
+
netPayoutAmount = payoutAmount;
|
120
|
+
|
121
|
+
if (payoutBeneficiary == address(0)) {
|
122
|
+
beneficiary = registry.ownerOf(policyNftId);
|
123
|
+
} else {
|
124
|
+
beneficiary = payoutBeneficiary;
|
125
|
+
}
|
126
|
+
|
127
|
+
// calculate processing fees if applicable
|
128
|
+
IComponents.FeeInfo memory feeInfo = instanceReader.getFeeInfo(productNftId);
|
129
|
+
if(FeeLib.gtz(feeInfo.processingFee)) {
|
130
|
+
// TODO calculate and set net payout and processing fees
|
131
|
+
}
|
132
|
+
}
|
133
|
+
}
|
134
|
+
|
135
|
+
|
136
|
+
function getPolicyHolder(
|
137
|
+
IRegistry registry,
|
138
|
+
NftId policyNftId
|
139
|
+
)
|
140
|
+
internal
|
141
|
+
view
|
142
|
+
returns (IPolicyHolder policyHolder)
|
143
|
+
{
|
144
|
+
address policyHolderAddress = registry.ownerOf(policyNftId);
|
145
|
+
policyHolder = IPolicyHolder(policyHolderAddress);
|
146
|
+
|
147
|
+
if (!ContractLib.isPolicyHolder(policyHolderAddress)) {
|
148
|
+
policyHolder = IPolicyHolder(address(0));
|
149
|
+
}
|
150
|
+
}
|
151
|
+
|
152
|
+
|
153
|
+
function checkAndGetPoolInfo(
|
154
|
+
IRegistry registry,
|
155
|
+
address sender,
|
156
|
+
NftId bundleNftId
|
157
|
+
)
|
158
|
+
public
|
159
|
+
view
|
160
|
+
returns (
|
161
|
+
InstanceReader instanceReader,
|
162
|
+
InstanceStore instanceStore,
|
163
|
+
NftId instanceNftId,
|
164
|
+
NftId poolNftId,
|
165
|
+
IComponents.PoolInfo memory poolInfo
|
166
|
+
)
|
167
|
+
{
|
168
|
+
checkNftType(registry, bundleNftId, BUNDLE());
|
169
|
+
|
170
|
+
IInstance instance;
|
171
|
+
(poolNftId, instance) = getAndVerifyActivePool(registry, sender);
|
172
|
+
instanceReader = instance.getInstanceReader();
|
173
|
+
instanceStore = instance.getInstanceStore();
|
174
|
+
instanceNftId = instance.getNftId();
|
175
|
+
poolInfo = instanceReader.getPoolInfo(poolNftId);
|
176
|
+
|
177
|
+
if (registry.getParentNftId(bundleNftId) != poolNftId) {
|
178
|
+
revert IPoolService.ErrorPoolServiceBundlePoolMismatch(bundleNftId, poolNftId);
|
179
|
+
}
|
180
|
+
}
|
181
|
+
|
182
|
+
|
183
|
+
function getAndVerifyActivePool(
|
184
|
+
IRegistry registry,
|
185
|
+
address sender
|
186
|
+
)
|
187
|
+
public
|
188
|
+
view
|
189
|
+
returns (
|
190
|
+
NftId poolNftId,
|
191
|
+
IInstance instance
|
192
|
+
)
|
193
|
+
{
|
194
|
+
(
|
195
|
+
IRegistry.ObjectInfo memory info,
|
196
|
+
address instanceAddress
|
197
|
+
) = ContractLib.getAndVerifyComponent(
|
198
|
+
registry,
|
199
|
+
sender,
|
200
|
+
POOL(),
|
201
|
+
true); // only active pools
|
202
|
+
|
203
|
+
poolNftId = info.nftId;
|
204
|
+
instance = IInstance(instanceAddress);
|
205
|
+
}
|
206
|
+
|
207
|
+
function checkNftType(
|
208
|
+
IRegistry registry,
|
209
|
+
NftId nftId,
|
210
|
+
ObjectType expectedObjectType
|
211
|
+
) internal view {
|
212
|
+
if(!registry.isObjectType(nftId, expectedObjectType)) {
|
213
|
+
revert INftOwnable.ErrorNftOwnableInvalidType(nftId, expectedObjectType);
|
214
|
+
}
|
215
|
+
}
|
216
|
+
}
|