@etherisc/gif-next 0.0.2-bcecc4c-647 → 0.0.2-bd1522a-487
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 +46 -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 +495 -254
- 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 +273 -16
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +391 -199
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +139 -15
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +19 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +68 -5
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +140 -479
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +261 -27
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +81 -385
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +378 -355
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +133 -119
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +83 -197
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +248 -122
- 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 +222 -38
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +140 -95
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +241 -126
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +733 -323
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +205 -90
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1030 -302
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +168 -280
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +96 -96
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +665 -518
- 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/mock/Dip.sol/Dip.json +2 -2
- 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 +243 -29
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +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 +122 -88
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +113 -402
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +261 -27
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +193 -415
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +113 -135
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +105 -141
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +113 -229
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +348 -323
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +103 -409
- 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 +518 -564
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +148 -102
- 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 +100 -90
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +234 -412
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +261 -27
- 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 +140 -114
- 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 +365 -104
- 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 +224 -212
- 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 +459 -309
- 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 +141 -99
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +247 -313
- 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 +232 -410
- 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 +334 -34
- 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 +540 -95
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +639 -367
- 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 +94 -80
- 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 +423 -245
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +66 -8
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +4 -4
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +67 -277
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +500 -640
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +132 -128
- 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 +445 -282
- 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 +187 -134
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +148 -16
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +264 -381
- 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 +126 -95
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +31 -63
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +201 -164
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +103 -85
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +185 -130
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +65 -24
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +33 -9
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/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 +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +3 -3
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +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 +26 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +23 -4
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +16 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +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 +71 -70
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/accounting/AccountingService.sol +262 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +45 -0
- package/contracts/authorization/AccessAdmin.sol +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 +1 -0
- 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 +152 -104
- 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 +63 -44
- package/contracts/instance/IInstanceService.sol +22 -30
- package/contracts/instance/Instance.sol +113 -71
- 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 +208 -189
- 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/IComponents.sol +14 -15
- package/contracts/instance/module/IDistribution.sol +5 -2
- 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 +1 -4
- package/contracts/oracle/BasicOracleAuthorization.sol +3 -12
- 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 +131 -160
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +22 -35
- package/contracts/pool/IPoolComponent.sol +19 -15
- package/contracts/pool/IPoolService.sol +90 -80
- package/contracts/pool/Pool.sol +140 -129
- package/contracts/pool/PoolLib.sol +216 -0
- package/contracts/pool/PoolService.sol +514 -301
- 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 +12 -45
- 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 -36
- 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 +458 -270
- package/contracts/product/PolicyServiceLib.sol +65 -0
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +71 -62
- package/contracts/product/PricingServiceManager.sol +4 -4
- package/contracts/product/Product.sol +168 -93
- 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 +60 -28
- package/contracts/registry/IRegistryService.sol +5 -12
- package/contracts/registry/IRelease.sol +26 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +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 +6 -8
- package/contracts/shared/Component.sol +65 -135
- package/contracts/shared/ComponentService.sol +436 -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 +42 -38
- 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 +19 -11
- 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/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 +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 +8 -0
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/StateId.sol +15 -1
- package/contracts/type/Timestamp.sol +10 -5
- package/contracts/type/UFixed.sol +13 -119
- package/contracts/type/Version.sol +54 -5
- package/contracts/upgradeability/ProxyManager.sol +68 -34
- 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
@@ -1,43 +1,44 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {IAccountingService} from "../accounting/IAccountingService.sol";
|
4
5
|
import {IBundle} from "../instance/module/IBundle.sol";
|
5
6
|
import {IBundleService} from "./IBundleService.sol";
|
6
7
|
import {IComponents} from "../instance/module/IComponents.sol";
|
7
8
|
import {IComponentService} from "../shared/IComponentService.sol";
|
8
9
|
import {IInstance} from "../instance/IInstance.sol";
|
9
|
-
import {IInstanceService} from "../instance/IInstanceService.sol";
|
10
10
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
11
|
+
import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
|
12
|
+
import {IPoolComponent} from "../pool/IPoolComponent.sol";
|
11
13
|
import {IPoolService} from "./IPoolService.sol";
|
14
|
+
import {IProductComponent} from "../product/IProductComponent.sol";
|
12
15
|
import {IRegistry} from "../registry/IRegistry.sol";
|
13
|
-
import {IRegistryService} from "../registry/IRegistryService.sol";
|
14
16
|
import {IStaking} from "../staking/IStaking.sol";
|
15
17
|
|
16
18
|
import {Amount, AmountLib} from "../type/Amount.sol";
|
17
|
-
import {
|
18
|
-
import {
|
19
|
-
import {
|
20
|
-
import {
|
21
|
-
import {Fee, FeeLib} from "../type/Fee.sol";
|
19
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
20
|
+
import {ContractLib} from "../shared/ContractLib.sol";
|
21
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
22
|
+
import {InstanceStore} from "../instance/InstanceStore.sol";
|
22
23
|
import {KEEP_STATE} from "../type/StateId.sol";
|
23
|
-
import {
|
24
|
+
import {NftId} from "../type/NftId.sol";
|
25
|
+
import {ObjectType, ACCOUNTING, POOL, BUNDLE, PRODUCT, POLICY, COMPONENT} from "../type/ObjectType.sol";
|
26
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
27
|
+
import {PoolLib} from "./PoolLib.sol";
|
28
|
+
import {Service} from "../shared/Service.sol";
|
24
29
|
import {TokenHandler} from "../shared/TokenHandler.sol";
|
25
30
|
import {UFixed} from "../type/UFixed.sol";
|
26
|
-
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
27
|
-
import {InstanceReader} from "../instance/InstanceReader.sol";
|
28
|
-
import {InstanceStore} from "../instance/InstanceStore.sol";
|
29
31
|
|
30
32
|
string constant POOL_SERVICE_NAME = "PoolService";
|
31
33
|
|
34
|
+
|
32
35
|
contract PoolService is
|
33
|
-
|
36
|
+
Service,
|
34
37
|
IPoolService
|
35
38
|
{
|
39
|
+
IAccountingService private _accountingService;
|
36
40
|
IBundleService internal _bundleService;
|
37
41
|
IComponentService internal _componentService;
|
38
|
-
IInstanceService private _instanceService;
|
39
|
-
IRegistryService private _registryService;
|
40
|
-
|
41
42
|
IStaking private _staking;
|
42
43
|
|
43
44
|
function _initialize(
|
@@ -45,298 +46,321 @@ contract PoolService is
|
|
45
46
|
bytes memory data
|
46
47
|
)
|
47
48
|
internal
|
48
|
-
initializer
|
49
49
|
virtual override
|
50
|
+
initializer()
|
50
51
|
{
|
51
52
|
(
|
52
|
-
address
|
53
|
-
|
54
|
-
|
55
|
-
) = abi.decode(data, (address, address, address));
|
53
|
+
address authority,
|
54
|
+
address registry
|
55
|
+
) = abi.decode(data, (address, address));
|
56
56
|
|
57
|
-
|
57
|
+
__Service_init(authority, registry, owner);
|
58
58
|
|
59
|
-
|
59
|
+
_accountingService = IAccountingService(_getServiceAddress(ACCOUNTING()));
|
60
60
|
_bundleService = IBundleService(_getServiceAddress(BUNDLE()));
|
61
|
-
_instanceService = IInstanceService(_getServiceAddress(INSTANCE()));
|
62
61
|
_componentService = IComponentService(_getServiceAddress(COMPONENT()));
|
63
|
-
|
64
62
|
_staking = IStaking(getRegistry().getStakingAddress());
|
65
63
|
|
66
|
-
|
64
|
+
_registerInterface(type(IPoolService).interfaceId);
|
67
65
|
}
|
68
66
|
|
69
67
|
|
70
|
-
|
68
|
+
/// @inheritdoc IPoolService
|
69
|
+
function setMaxBalanceAmount(Amount maxBalanceAmount)
|
71
70
|
external
|
72
71
|
virtual
|
73
72
|
{
|
74
|
-
|
75
|
-
(NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
|
73
|
+
(NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
|
76
74
|
InstanceReader instanceReader = instance.getInstanceReader();
|
75
|
+
IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
|
77
76
|
|
78
|
-
|
79
|
-
|
80
|
-
Amount previousMaxCapitalAmount = poolInfo.maxCapitalAmount;
|
81
|
-
|
82
|
-
poolInfo.maxCapitalAmount = maxCapitalAmount;
|
77
|
+
Amount previousMaxBalanceAmount = poolInfo.maxBalanceAmount;
|
78
|
+
poolInfo.maxBalanceAmount = maxBalanceAmount;
|
83
79
|
instance.getInstanceStore().updatePool(poolNftId, poolInfo, KEEP_STATE());
|
84
80
|
|
85
|
-
emit
|
86
|
-
*/
|
81
|
+
emit LogPoolServiceMaxBalanceAmountUpdated(poolNftId, previousMaxBalanceAmount, maxBalanceAmount);
|
87
82
|
}
|
88
83
|
|
89
|
-
|
84
|
+
|
85
|
+
function closeBundle(NftId bundleNftId)
|
90
86
|
external
|
91
87
|
virtual
|
92
88
|
{
|
93
|
-
(
|
94
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
89
|
+
_checkNftType(bundleNftId, BUNDLE());
|
95
90
|
|
96
|
-
|
97
|
-
IComponents.PoolInfo memory poolInfo = abi.decode(componentInfo.data, (IComponents.PoolInfo));
|
91
|
+
(NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
|
98
92
|
|
99
|
-
//
|
100
|
-
if(poolInfo.bundleOwnerRole != PUBLIC_ROLE()) {
|
101
|
-
revert ErrorPoolServiceBundleOwnerRoleAlreadySet(poolNftId);
|
102
|
-
}
|
93
|
+
// TODO get performance fee for pool (#477)
|
103
94
|
|
104
|
-
|
105
|
-
|
95
|
+
// releasing collateral in bundle
|
96
|
+
(Amount unstakedAmount, Amount feeAmount) = _bundleService.close(instance, bundleNftId);
|
106
97
|
|
107
|
-
|
98
|
+
_accountingService.decreasePoolBalance(
|
99
|
+
instance.getInstanceStore(),
|
100
|
+
poolNftId,
|
101
|
+
unstakedAmount + feeAmount,
|
102
|
+
AmountLib.zero());
|
103
|
+
|
104
|
+
emit LogPoolServiceBundleClosed(instance.getNftId(), poolNftId, bundleNftId);
|
105
|
+
|
106
|
+
if ((unstakedAmount + feeAmount).gtz()){
|
107
|
+
IComponents.ComponentInfo memory poolComponentInfo = instance.getInstanceReader().getComponentInfo(poolNftId);
|
108
|
+
poolComponentInfo.tokenHandler.pushToken(
|
109
|
+
getRegistry().ownerOf(bundleNftId),
|
110
|
+
unstakedAmount + feeAmount);
|
111
|
+
}
|
108
112
|
}
|
109
113
|
|
110
114
|
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
115
|
+
/// @inheritdoc IPoolService
|
116
|
+
function processFundedClaim(
|
117
|
+
NftId policyNftId,
|
118
|
+
ClaimId claimId,
|
119
|
+
Amount availableAmount
|
120
|
+
)
|
116
121
|
external
|
117
122
|
virtual
|
118
123
|
{
|
119
|
-
(
|
120
|
-
|
121
|
-
IComponents.PoolInfo memory poolInfo = instance.getInstanceReader().getPoolInfo(poolNftId);
|
122
|
-
poolInfo.poolFee = poolFee;
|
123
|
-
poolInfo.stakingFee = stakingFee;
|
124
|
-
poolInfo.performanceFee = performanceFee;
|
125
|
-
|
126
|
-
instance.getInstanceStore().updatePool(poolNftId, poolInfo, KEEP_STATE());
|
124
|
+
_checkNftType(policyNftId, POLICY());
|
127
125
|
|
128
|
-
|
129
|
-
}
|
130
|
-
|
131
|
-
/// @inheritdoc IPoolService
|
132
|
-
function createBundle(
|
133
|
-
address bundleOwner, // initial bundle owner
|
134
|
-
Fee memory fee, // fees deducted from premium that go to bundle owner
|
135
|
-
Amount stakingAmount, // staking amount - staking fees result in initial bundle capital
|
136
|
-
Seconds lifetime, // initial duration for which new policies are covered
|
137
|
-
bytes calldata filter // optional use case specific criteria that define if a policy may be covered by this bundle
|
138
|
-
)
|
139
|
-
external
|
140
|
-
virtual
|
141
|
-
returns(NftId bundleNftId)
|
142
|
-
{
|
143
|
-
(NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
|
126
|
+
(NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
|
144
127
|
InstanceReader instanceReader = instance.getInstanceReader();
|
128
|
+
NftId productNftId = getRegistry().getParentNftId(poolNftId);
|
129
|
+
|
130
|
+
// check policy matches with calling pool
|
131
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
132
|
+
if(policyInfo.productNftId != productNftId) {
|
133
|
+
revert ErrorPoolServicePolicyPoolMismatch(
|
134
|
+
policyNftId,
|
135
|
+
policyInfo.productNftId,
|
136
|
+
productNftId);
|
137
|
+
}
|
145
138
|
|
146
|
-
(
|
147
|
-
Amount stakingFeeAmount,
|
148
|
-
Amount stakingNetAmount
|
149
|
-
) = FeeLib.calculateFee(
|
150
|
-
_getStakingFee(instanceReader, poolNftId),
|
151
|
-
stakingAmount);
|
152
|
-
|
153
|
-
// TODO: staking amount must be be > maxCapitalAmount
|
154
|
-
|
155
|
-
bundleNftId = _bundleService.create(
|
156
|
-
instance,
|
157
|
-
poolNftId,
|
158
|
-
bundleOwner,
|
159
|
-
fee,
|
160
|
-
stakingNetAmount,
|
161
|
-
lifetime,
|
162
|
-
filter);
|
163
|
-
|
164
|
-
// pool book keeping
|
165
|
-
_componentService.increasePoolBalance(
|
166
|
-
instance.getInstanceStore(),
|
167
|
-
poolNftId,
|
168
|
-
stakingNetAmount,
|
169
|
-
stakingFeeAmount);
|
170
|
-
|
171
|
-
// pool bookkeeping and collect tokens from bundle owner
|
172
|
-
_collectStakingAmount(
|
173
|
-
instanceReader,
|
174
|
-
poolNftId,
|
175
|
-
bundleOwner,
|
176
|
-
stakingAmount);
|
139
|
+
emit LogPoolServiceProcessFundedClaim(policyNftId, claimId, availableAmount);
|
177
140
|
|
178
|
-
|
141
|
+
// callback to product component if applicable
|
142
|
+
if (instanceReader.getProductInfo(productNftId).isProcessingFundedClaims) {
|
143
|
+
address productAddress = getRegistry().getObjectAddress(productNftId);
|
144
|
+
IProductComponent(productAddress).processFundedClaim(policyNftId, claimId, availableAmount);
|
145
|
+
}
|
179
146
|
}
|
180
147
|
|
181
|
-
function _getStakingFee(InstanceReader instanceReader, NftId poolNftId)
|
182
|
-
internal
|
183
|
-
virtual
|
184
|
-
view
|
185
|
-
returns (Fee memory stakingFee)
|
186
|
-
{
|
187
|
-
NftId productNftId = instanceReader.getPoolInfo(poolNftId).productNftId;
|
188
|
-
return instanceReader.getPoolInfo(productNftId).stakingFee;
|
189
|
-
}
|
190
148
|
|
191
|
-
function
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
149
|
+
// function _checkAndGetPoolInfo(NftId bundleNftId)
|
150
|
+
// internal
|
151
|
+
// view
|
152
|
+
// returns (
|
153
|
+
// InstanceReader instanceReader,
|
154
|
+
// InstanceStore instanceStore,
|
155
|
+
// NftId instanceNftId,
|
156
|
+
// NftId poolNftId,
|
157
|
+
// IComponents.PoolInfo memory poolInfo
|
158
|
+
// )
|
159
|
+
// {
|
160
|
+
// _checkNftType(bundleNftId, BUNDLE());
|
196
161
|
|
197
|
-
|
162
|
+
// (NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
|
163
|
+
// instanceReader = instance.getInstanceReader();
|
164
|
+
// instanceStore = instance.getInstanceStore();
|
165
|
+
// instanceNftId = instance.getNftId();
|
166
|
+
// poolInfo = instanceReader.getPoolInfo(poolNftId);
|
198
167
|
|
199
|
-
|
200
|
-
|
168
|
+
// if (getRegistry().getParentNftId(bundleNftId) != poolNftId) {
|
169
|
+
// revert ErrorPoolServiceBundlePoolMismatch(bundleNftId, poolNftId);
|
170
|
+
// }
|
171
|
+
// }
|
201
172
|
|
202
|
-
// TODO get performance fee for pool, transfer of remaining funds + bundle fees to bundle owner
|
203
|
-
|
204
|
-
emit LogPoolServiceBundleClosed(instance.getNftId(), poolNftId, bundleNftId);
|
205
|
-
}
|
206
173
|
|
207
174
|
/// @inheritdoc IPoolService
|
208
175
|
function stake(NftId bundleNftId, Amount amount)
|
209
176
|
external
|
210
177
|
virtual
|
211
|
-
restricted()
|
212
|
-
returns(
|
178
|
+
// TODO: restricted() (once #462 is done)
|
179
|
+
returns(
|
180
|
+
Amount netAmount
|
181
|
+
)
|
213
182
|
{
|
214
|
-
(
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
183
|
+
(
|
184
|
+
InstanceReader instanceReader,
|
185
|
+
InstanceStore instanceStore,
|
186
|
+
NftId instanceNftId,
|
187
|
+
NftId poolNftId,
|
188
|
+
IComponents.PoolInfo memory poolInfo
|
189
|
+
) = PoolLib.checkAndGetPoolInfo(getRegistry(), msg.sender, bundleNftId);
|
190
|
+
|
191
|
+
{
|
192
|
+
Amount currentPoolBalance = instanceReader.getBalanceAmount(poolNftId);
|
193
|
+
if (currentPoolBalance + amount > poolInfo.maxBalanceAmount) {
|
194
|
+
revert ErrorPoolServiceMaxBalanceAmountExceeded(poolNftId, poolInfo.maxBalanceAmount, currentPoolBalance, amount);
|
195
|
+
}
|
226
196
|
}
|
227
197
|
|
228
198
|
// calculate fees
|
199
|
+
Amount feeAmount;
|
229
200
|
(
|
230
|
-
|
231
|
-
|
232
|
-
) =
|
233
|
-
|
201
|
+
feeAmount,
|
202
|
+
netAmount
|
203
|
+
) = PoolLib.calculateStakingAmounts(
|
204
|
+
getRegistry(),
|
205
|
+
instanceReader,
|
206
|
+
poolNftId,
|
234
207
|
amount);
|
235
208
|
|
236
|
-
// do all the
|
237
|
-
|
238
|
-
|
209
|
+
// do all the book keeping
|
210
|
+
_accountingService.increasePoolBalance(
|
211
|
+
instanceStore,
|
239
212
|
poolNftId,
|
240
213
|
netAmount,
|
241
214
|
feeAmount);
|
242
215
|
|
243
|
-
_bundleService.stake(
|
216
|
+
_bundleService.stake(instanceReader, instanceStore, bundleNftId, netAmount);
|
244
217
|
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
poolNftId,
|
250
|
-
bundleOwner,
|
251
|
-
amount);
|
218
|
+
emit LogPoolServiceBundleStaked(instanceNftId, poolNftId, bundleNftId, amount, netAmount);
|
219
|
+
|
220
|
+
// only collect staking amount when pool is not externally managed
|
221
|
+
if (!poolInfo.isExternallyManaged) {
|
252
222
|
|
253
|
-
|
223
|
+
// collect tokens from bundle owner
|
224
|
+
address bundleOwner = getRegistry().ownerOf(bundleNftId);
|
225
|
+
_pullStakingAmount(
|
226
|
+
instanceReader,
|
227
|
+
poolNftId,
|
228
|
+
bundleOwner,
|
229
|
+
amount);
|
230
|
+
}
|
254
231
|
}
|
255
232
|
|
233
|
+
|
256
234
|
/// @inheritdoc IPoolService
|
257
235
|
function unstake(NftId bundleNftId, Amount amount)
|
258
236
|
external
|
259
237
|
virtual
|
260
|
-
restricted()
|
238
|
+
// TODO: restricted() (once #462 is done)
|
261
239
|
returns(Amount netAmount)
|
262
240
|
{
|
263
|
-
(
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
revert ErrorPoolServiceBundlePoolMismatch(bundleNftId, poolNftId);
|
270
|
-
}
|
241
|
+
(
|
242
|
+
InstanceReader instanceReader,
|
243
|
+
InstanceStore instanceStore,
|
244
|
+
NftId instanceNftId,
|
245
|
+
NftId poolNftId,
|
246
|
+
) = PoolLib.checkAndGetPoolInfo(getRegistry(), msg.sender, bundleNftId);
|
271
247
|
|
272
248
|
// call bundle service for bookkeeping and additional checks
|
273
|
-
_bundleService.unstake(
|
249
|
+
Amount unstakedAmount = _bundleService.unstake(instanceStore, bundleNftId, amount);
|
274
250
|
|
275
|
-
//
|
276
|
-
//
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
) = FeeLib.calculateFee(
|
281
|
-
_getPerformanceFee(instanceReader, poolNftId),
|
282
|
-
amount);
|
251
|
+
// Important: from now on work only with unstakedAmount as it is the only reliable amount.
|
252
|
+
// if amount was max, this was set to the available amount
|
253
|
+
|
254
|
+
// TODO: handle performance fees (issue #477)
|
255
|
+
netAmount = unstakedAmount;
|
283
256
|
|
284
257
|
// update pool bookkeeping - performance fees stay in the pool, but as fees
|
285
|
-
|
258
|
+
_accountingService.decreasePoolBalance(
|
286
259
|
instanceStore,
|
287
260
|
poolNftId,
|
288
|
-
|
261
|
+
unstakedAmount,
|
289
262
|
AmountLib.zero());
|
290
263
|
|
291
|
-
_componentService.increasePoolBalance(
|
292
|
-
instanceStore,
|
293
|
-
poolNftId,
|
294
|
-
AmountLib.zero(),
|
295
|
-
performanceFeeAmount);
|
296
264
|
|
297
|
-
|
265
|
+
emit LogPoolServiceBundleUnstaked(instanceNftId, poolNftId, bundleNftId, unstakedAmount, netAmount);
|
266
|
+
|
267
|
+
// only distribute staking amount when pool is not externally managed
|
268
|
+
if (!instanceReader.getPoolInfo(poolNftId).isExternallyManaged) {
|
298
269
|
|
299
|
-
|
270
|
+
// transfer amount to bundle owner
|
271
|
+
address bundleOwner = getRegistry().ownerOf(bundleNftId);
|
272
|
+
_pushUnstakingAmount(
|
273
|
+
instanceReader,
|
274
|
+
poolNftId,
|
275
|
+
bundleOwner,
|
276
|
+
netAmount);
|
277
|
+
}
|
300
278
|
}
|
301
279
|
|
302
|
-
|
303
|
-
|
280
|
+
|
281
|
+
function fundPoolWallet(Amount amount)
|
282
|
+
external
|
304
283
|
virtual
|
305
|
-
|
306
|
-
returns (Fee memory performanceFee)
|
284
|
+
// restricted()
|
307
285
|
{
|
308
|
-
|
309
|
-
|
286
|
+
(
|
287
|
+
NftId poolNftId,
|
288
|
+
IInstance instance
|
289
|
+
) = _getAndVerifyActivePool();
|
290
|
+
|
291
|
+
// check that pool is externally managed
|
292
|
+
InstanceReader reader = instance.getInstanceReader();
|
293
|
+
if (!reader.getPoolInfo(poolNftId).isExternallyManaged) {
|
294
|
+
revert ErrorPoolServicePoolNotExternallyManaged(poolNftId);
|
295
|
+
}
|
296
|
+
|
297
|
+
address poolOwner = getRegistry().ownerOf(poolNftId);
|
298
|
+
emit LogPoolServiceWalletFunded(poolNftId, poolOwner, amount);
|
299
|
+
|
300
|
+
_pullStakingAmount(
|
301
|
+
reader,
|
302
|
+
poolNftId,
|
303
|
+
poolOwner,
|
304
|
+
amount);
|
310
305
|
}
|
311
306
|
|
307
|
+
|
308
|
+
function defundPoolWallet(Amount amount)
|
309
|
+
external
|
310
|
+
virtual
|
311
|
+
// restricted()
|
312
|
+
{
|
313
|
+
(
|
314
|
+
NftId poolNftId,
|
315
|
+
IInstance instance
|
316
|
+
) = _getAndVerifyActivePool();
|
317
|
+
|
318
|
+
// check that pool is externally managed
|
319
|
+
InstanceReader reader = instance.getInstanceReader();
|
320
|
+
if (!reader.getPoolInfo(poolNftId).isExternallyManaged) {
|
321
|
+
revert ErrorPoolServicePoolNotExternallyManaged(poolNftId);
|
322
|
+
}
|
323
|
+
|
324
|
+
address poolOwner = getRegistry().ownerOf(poolNftId);
|
325
|
+
emit LogPoolServiceWalletDefunded(poolNftId, poolOwner, amount);
|
326
|
+
|
327
|
+
_pushUnstakingAmount(
|
328
|
+
reader,
|
329
|
+
poolNftId,
|
330
|
+
poolOwner,
|
331
|
+
amount);
|
332
|
+
}
|
333
|
+
|
334
|
+
|
312
335
|
function processSale(
|
313
336
|
NftId bundleNftId,
|
314
|
-
IPolicy.
|
337
|
+
IPolicy.PremiumInfo memory premium
|
315
338
|
)
|
316
339
|
external
|
317
340
|
virtual
|
318
341
|
restricted()
|
319
342
|
{
|
343
|
+
_checkNftType(bundleNftId, BUNDLE());
|
344
|
+
|
320
345
|
IRegistry registry = getRegistry();
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
IInstance instance = IInstance(instanceObjectInfo.objectAddress);
|
346
|
+
NftId poolNftId = registry.getParentNftId(bundleNftId);
|
347
|
+
(, address instanceAddress) = ContractLib.getInfoAndInstance(registry, poolNftId, true);
|
348
|
+
IInstance instance = IInstance(instanceAddress);
|
325
349
|
|
326
|
-
Amount poolFeeAmount =
|
327
|
-
Amount bundleFeeAmount =
|
328
|
-
Amount bundleNetAmount =
|
350
|
+
Amount poolFeeAmount = premium.poolFeeFixAmount + premium.poolFeeVarAmount;
|
351
|
+
Amount bundleFeeAmount = premium.bundleFeeFixAmount + premium.bundleFeeVarAmount;
|
352
|
+
Amount bundleNetAmount = premium.netPremiumAmount;
|
329
353
|
|
330
354
|
InstanceStore instanceStore = instance.getInstanceStore();
|
331
|
-
|
355
|
+
_accountingService.increasePoolBalance(
|
332
356
|
instanceStore,
|
333
|
-
|
357
|
+
poolNftId,
|
334
358
|
bundleNetAmount + bundleFeeAmount,
|
335
359
|
poolFeeAmount);
|
336
360
|
|
337
|
-
|
361
|
+
_accountingService.increaseBundleBalanceForPool(
|
338
362
|
instanceStore,
|
339
|
-
|
363
|
+
bundleNftId,
|
340
364
|
bundleNetAmount,
|
341
365
|
bundleFeeAmount);
|
342
366
|
}
|
@@ -354,14 +378,22 @@ contract PoolService is
|
|
354
378
|
virtual
|
355
379
|
restricted()
|
356
380
|
returns (
|
357
|
-
Amount
|
358
|
-
Amount
|
381
|
+
Amount totalCollateralAmount,
|
382
|
+
Amount localCollateralAmount
|
359
383
|
)
|
360
384
|
{
|
385
|
+
_checkNftType(productNftId, PRODUCT());
|
386
|
+
_checkNftType(applicationNftId, POLICY());
|
387
|
+
_checkNftType(bundleNftId, BUNDLE());
|
388
|
+
|
389
|
+
NftId poolNftId;
|
390
|
+
bool poolIsVerifyingApplications;
|
361
391
|
(
|
392
|
+
poolNftId,
|
393
|
+
totalCollateralAmount,
|
362
394
|
localCollateralAmount,
|
363
|
-
|
364
|
-
) = calculateRequiredCollateral(
|
395
|
+
poolIsVerifyingApplications
|
396
|
+
) = PoolLib.calculateRequiredCollateral(
|
365
397
|
instance.getInstanceReader(),
|
366
398
|
productNftId,
|
367
399
|
sumInsuredAmount);
|
@@ -379,36 +411,170 @@ contract PoolService is
|
|
379
411
|
token,
|
380
412
|
totalCollateralAmount);
|
381
413
|
|
382
|
-
//
|
383
|
-
|
384
|
-
|
414
|
+
// pool callback when required
|
415
|
+
if (poolIsVerifyingApplications) {
|
416
|
+
IPoolComponent pool = IPoolComponent(
|
417
|
+
getRegistry().getObjectAddress(poolNftId));
|
418
|
+
|
419
|
+
pool.verifyApplication(
|
420
|
+
applicationNftId,
|
421
|
+
bundleNftId,
|
422
|
+
totalCollateralAmount);
|
385
423
|
|
424
|
+
// TODO add logging
|
386
425
|
}
|
387
|
-
}
|
388
426
|
|
427
|
+
// TODO add logging
|
428
|
+
}
|
389
429
|
|
390
|
-
function
|
391
|
-
|
392
|
-
|
430
|
+
function processPayout(
|
431
|
+
InstanceReader instanceReader,
|
432
|
+
InstanceStore instanceStore,
|
433
|
+
NftId productNftId,
|
393
434
|
NftId policyNftId,
|
394
|
-
|
395
|
-
|
435
|
+
NftId bundleNftId,
|
436
|
+
PayoutId payoutId,
|
437
|
+
Amount payoutAmount,
|
438
|
+
address payoutBeneficiary
|
396
439
|
)
|
397
440
|
external
|
398
441
|
virtual
|
399
442
|
restricted()
|
400
443
|
{
|
444
|
+
// checks
|
445
|
+
_checkNftType(policyNftId, POLICY());
|
446
|
+
|
447
|
+
// effects
|
448
|
+
NftId poolNftId = getRegistry().getParentNftId(bundleNftId);
|
449
|
+
|
450
|
+
_accountingService.decreasePoolBalance(
|
451
|
+
instanceStore,
|
452
|
+
poolNftId,
|
453
|
+
payoutAmount,
|
454
|
+
AmountLib.zero());
|
455
|
+
|
456
|
+
_accountingService.decreaseBundleBalanceForPool(
|
457
|
+
instanceStore,
|
458
|
+
bundleNftId,
|
459
|
+
payoutAmount,
|
460
|
+
AmountLib.zero());
|
461
|
+
|
401
462
|
_bundleService.releaseCollateral(
|
402
|
-
|
463
|
+
instanceStore,
|
403
464
|
policyNftId,
|
404
|
-
|
465
|
+
bundleNftId,
|
405
466
|
payoutAmount);
|
406
467
|
|
407
468
|
// update value locked with staking service
|
469
|
+
TokenHandler poolTokenHandler = instanceReader.getTokenHandler(poolNftId);
|
470
|
+
|
408
471
|
_staking.decreaseTotalValueLocked(
|
409
|
-
|
410
|
-
|
472
|
+
instanceReader.getInstanceNftId(),
|
473
|
+
address(poolTokenHandler.TOKEN()),
|
411
474
|
payoutAmount);
|
475
|
+
|
476
|
+
// interactions
|
477
|
+
_transferTokenAndNotifyPolicyHolder(
|
478
|
+
instanceReader,
|
479
|
+
poolTokenHandler,
|
480
|
+
productNftId,
|
481
|
+
policyNftId,
|
482
|
+
payoutId,
|
483
|
+
payoutAmount,
|
484
|
+
payoutBeneficiary);
|
485
|
+
}
|
486
|
+
|
487
|
+
function _transferTokenAndNotifyPolicyHolder(
|
488
|
+
InstanceReader instanceReader,
|
489
|
+
TokenHandler poolTokenHandler,
|
490
|
+
NftId productNftId,
|
491
|
+
NftId policyNftId,
|
492
|
+
PayoutId payoutId,
|
493
|
+
Amount payoutAmount,
|
494
|
+
address payoutBeneficiary
|
495
|
+
)
|
496
|
+
internal
|
497
|
+
{
|
498
|
+
(
|
499
|
+
Amount netPayoutAmount,
|
500
|
+
Amount processingFeeAmount,
|
501
|
+
address beneficiary
|
502
|
+
) = PoolLib.calculatePayoutAmounts(
|
503
|
+
getRegistry(),
|
504
|
+
instanceReader,
|
505
|
+
productNftId,
|
506
|
+
policyNftId,
|
507
|
+
payoutAmount,
|
508
|
+
payoutBeneficiary);
|
509
|
+
|
510
|
+
// 1st token tx to payout to beneficiary
|
511
|
+
poolTokenHandler.pushToken(
|
512
|
+
beneficiary,
|
513
|
+
netPayoutAmount);
|
514
|
+
|
515
|
+
// 2nd token tx to transfer processing fees to product wallet
|
516
|
+
// if processingFeeAmount > 0
|
517
|
+
if (processingFeeAmount.gtz()) {
|
518
|
+
poolTokenHandler.pushToken(
|
519
|
+
instanceReader.getWallet(productNftId),
|
520
|
+
processingFeeAmount);
|
521
|
+
}
|
522
|
+
|
523
|
+
// callback to policy holder if applicable
|
524
|
+
_policyHolderPayoutExecuted(
|
525
|
+
policyNftId,
|
526
|
+
payoutId,
|
527
|
+
beneficiary,
|
528
|
+
netPayoutAmount);
|
529
|
+
}
|
530
|
+
|
531
|
+
|
532
|
+
/// @inheritdoc IPoolService
|
533
|
+
function withdrawBundleFees(
|
534
|
+
NftId bundleNftId,
|
535
|
+
Amount amount
|
536
|
+
)
|
537
|
+
public
|
538
|
+
virtual
|
539
|
+
restricted()
|
540
|
+
returns (Amount withdrawnAmount)
|
541
|
+
{
|
542
|
+
// checks
|
543
|
+
_checkNftType(bundleNftId, BUNDLE());
|
544
|
+
|
545
|
+
(NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
|
546
|
+
InstanceReader reader = instance.getInstanceReader();
|
547
|
+
|
548
|
+
// determine withdrawn amount
|
549
|
+
withdrawnAmount = amount;
|
550
|
+
if (withdrawnAmount.gte(AmountLib.max())) {
|
551
|
+
withdrawnAmount = reader.getFeeAmount(bundleNftId);
|
552
|
+
} else {
|
553
|
+
if (withdrawnAmount > reader.getFeeAmount(bundleNftId)) {
|
554
|
+
revert ErrorPoolServiceFeesWithdrawAmountExceedsLimit(withdrawnAmount, reader.getFeeAmount(bundleNftId));
|
555
|
+
}
|
556
|
+
}
|
557
|
+
|
558
|
+
// effects
|
559
|
+
// decrease fee counters by withdrawnAmount
|
560
|
+
{
|
561
|
+
InstanceStore store = instance.getInstanceStore();
|
562
|
+
// decrease fee amount of the bundle
|
563
|
+
_accountingService.decreaseBundleBalanceForPool(store, bundleNftId, AmountLib.zero(), withdrawnAmount);
|
564
|
+
// decrease pool balance
|
565
|
+
_accountingService.decreasePoolBalance(store, poolNftId, withdrawnAmount, AmountLib.zero());
|
566
|
+
}
|
567
|
+
|
568
|
+
// interactions
|
569
|
+
// transfer amount to bundle owner
|
570
|
+
{
|
571
|
+
address bundleOwner = getRegistry().ownerOf(bundleNftId);
|
572
|
+
TokenHandler tokenHandler = reader.getTokenHandler(poolNftId);
|
573
|
+
address token = address(tokenHandler.TOKEN());
|
574
|
+
emit LogPoolServiceFeesWithdrawn(bundleNftId, bundleOwner, token, withdrawnAmount);
|
575
|
+
|
576
|
+
tokenHandler.pushToken(bundleOwner, withdrawnAmount);
|
577
|
+
}
|
412
578
|
}
|
413
579
|
|
414
580
|
|
@@ -416,7 +582,6 @@ contract PoolService is
|
|
416
582
|
/// may only be called by the policy service for unlocked pool components
|
417
583
|
function releaseCollateral(
|
418
584
|
IInstance instance,
|
419
|
-
address token,
|
420
585
|
NftId policyNftId,
|
421
586
|
IPolicy.PolicyInfo memory policyInfo
|
422
587
|
)
|
@@ -424,117 +589,165 @@ contract PoolService is
|
|
424
589
|
virtual
|
425
590
|
restricted()
|
426
591
|
{
|
592
|
+
_checkNftType(policyNftId, POLICY());
|
593
|
+
|
427
594
|
Amount remainingCollateralAmount = policyInfo.sumInsuredAmount - policyInfo.claimAmount;
|
428
595
|
|
429
596
|
_bundleService.releaseCollateral(
|
430
|
-
instance,
|
597
|
+
instance.getInstanceStore(),
|
431
598
|
policyNftId,
|
432
599
|
policyInfo.bundleNftId,
|
433
600
|
remainingCollateralAmount);
|
434
601
|
|
435
|
-
_bundleService.unlinkPolicy(
|
436
|
-
instance,
|
437
|
-
policyNftId);
|
438
|
-
|
439
602
|
// update value locked with staking service
|
603
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
440
604
|
_staking.decreaseTotalValueLocked(
|
441
|
-
|
442
|
-
|
605
|
+
instanceReader.getInstanceNftId(),
|
606
|
+
address(instanceReader.getToken(policyInfo.productNftId)),
|
443
607
|
remainingCollateralAmount);
|
444
608
|
}
|
445
609
|
|
446
610
|
|
447
|
-
function calculateRequiredCollateral(
|
448
|
-
|
449
|
-
|
450
|
-
|
611
|
+
// function calculateRequiredCollateral(
|
612
|
+
// InstanceReader instanceReader,
|
613
|
+
// NftId productNftId,
|
614
|
+
// Amount sumInsuredAmount
|
615
|
+
// )
|
616
|
+
// public
|
617
|
+
// view
|
618
|
+
// returns(
|
619
|
+
// NftId poolNftId,
|
620
|
+
// Amount totalCollateralAmount,
|
621
|
+
// Amount localCollateralAmount,
|
622
|
+
// bool poolIsVerifyingApplications
|
623
|
+
// )
|
624
|
+
// {
|
625
|
+
// return CollateralLib.calculateRequiredCollateral(
|
626
|
+
// instanceReader,
|
627
|
+
// productNftId,
|
628
|
+
// sumInsuredAmount);
|
629
|
+
// }
|
630
|
+
|
631
|
+
// _checkNftType(productNftId, PRODUCT());
|
632
|
+
|
633
|
+
// poolNftId = instanceReader.getProductInfo(productNftId).poolNftId;
|
634
|
+
// IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
|
635
|
+
// poolIsVerifyingApplications = poolInfo.isVerifyingApplications;
|
636
|
+
|
637
|
+
// (
|
638
|
+
// totalCollateralAmount,
|
639
|
+
// localCollateralAmount
|
640
|
+
// ) = calculateRequiredCollateral(
|
641
|
+
// poolInfo.collateralizationLevel,
|
642
|
+
// poolInfo.retentionLevel,
|
643
|
+
// sumInsuredAmount);
|
644
|
+
// }
|
645
|
+
|
646
|
+
|
647
|
+
// function calculateRequiredCollateral(
|
648
|
+
// UFixed collateralizationLevel,
|
649
|
+
// UFixed retentionLevel,
|
650
|
+
// Amount sumInsuredAmount
|
651
|
+
// )
|
652
|
+
// public
|
653
|
+
// pure
|
654
|
+
// returns(
|
655
|
+
// Amount totalCollateralAmount,
|
656
|
+
// Amount localCollateralAmount
|
657
|
+
// )
|
658
|
+
// {
|
659
|
+
// // collateralization is applied to sum insured
|
660
|
+
// UFixed totalUFixed = collateralizationLevel * sumInsuredAmount.toUFixed();
|
661
|
+
// totalCollateralAmount = AmountLib.toAmount(totalUFixed.toInt());
|
662
|
+
|
663
|
+
// // retention level defines how much capital is required locally
|
664
|
+
// localCollateralAmount = AmountLib.toAmount(
|
665
|
+
// (retentionLevel * totalUFixed).toInt());
|
666
|
+
// }
|
667
|
+
|
668
|
+
|
669
|
+
|
670
|
+
|
671
|
+
function _policyHolderPayoutExecuted(
|
672
|
+
NftId policyNftId,
|
673
|
+
PayoutId payoutId,
|
674
|
+
address beneficiary,
|
675
|
+
Amount payoutAmount
|
451
676
|
)
|
452
|
-
|
453
|
-
view
|
454
|
-
returns(
|
455
|
-
Amount localCollateralAmount,
|
456
|
-
Amount totalCollateralAmount
|
457
|
-
)
|
677
|
+
internal
|
458
678
|
{
|
459
|
-
|
460
|
-
|
461
|
-
|
462
|
-
|
463
|
-
localCollateralAmount,
|
464
|
-
totalCollateralAmount
|
465
|
-
) = calculateRequiredCollateral(
|
466
|
-
poolInfo.collateralizationLevel,
|
467
|
-
poolInfo.retentionLevel,
|
468
|
-
sumInsuredAmount);
|
679
|
+
IPolicyHolder policyHolder = PoolLib.getPolicyHolder(getRegistry(), policyNftId);
|
680
|
+
if(address(policyHolder) != address(0)) {
|
681
|
+
policyHolder.payoutExecuted(policyNftId, payoutId, payoutAmount, beneficiary);
|
682
|
+
}
|
469
683
|
}
|
470
684
|
|
471
685
|
|
472
|
-
|
473
|
-
|
474
|
-
|
475
|
-
|
686
|
+
/// @dev Transfers the specified amount from the "from account" to the pool's wallet
|
687
|
+
function _pullStakingAmount(
|
688
|
+
InstanceReader reader,
|
689
|
+
NftId poolNftId,
|
690
|
+
address from,
|
691
|
+
Amount amount
|
476
692
|
)
|
477
|
-
|
478
|
-
pure
|
479
|
-
returns(
|
480
|
-
Amount localCollateralAmount,
|
481
|
-
Amount totalCollateralAmount
|
482
|
-
)
|
693
|
+
internal
|
483
694
|
{
|
484
|
-
|
485
|
-
|
486
|
-
|
487
|
-
|
488
|
-
// - collateralizationLevel == 1.0
|
489
|
-
// - retentionLevel == 1.0
|
490
|
-
localCollateralAmount = sumInsuredAmount;
|
491
|
-
totalCollateralAmount = localCollateralAmount;
|
695
|
+
IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
|
696
|
+
info.tokenHandler.pullToken(
|
697
|
+
from,
|
698
|
+
amount);
|
492
699
|
}
|
493
700
|
|
494
|
-
|
495
|
-
function
|
496
|
-
|
497
|
-
|
701
|
+
/// @dev Transfers the specified amount from the pool's wallet to the "to account"
|
702
|
+
function _pushUnstakingAmount(
|
703
|
+
InstanceReader reader,
|
704
|
+
NftId poolNftId,
|
705
|
+
address to,
|
706
|
+
Amount amount
|
498
707
|
)
|
499
708
|
internal
|
500
|
-
returns (Amount stakingNetAmount)
|
501
709
|
{
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
(Amount feeAmount, Amount netAmount) = FeeLib.calculateFee(stakingFee, stakingAmount);
|
507
|
-
stakingNetAmount = netAmount;
|
508
|
-
|
509
|
-
// TODO update fee balance for pool
|
510
|
-
}
|
710
|
+
IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
|
711
|
+
info.tokenHandler.pushToken(
|
712
|
+
to,
|
713
|
+
amount);
|
511
714
|
}
|
512
715
|
|
513
716
|
|
514
|
-
|
515
|
-
/// @dev transfers the specified amount from the bundle owner to the pool's wallet
|
516
|
-
function _collectStakingAmount(
|
517
|
-
InstanceReader instanceReader,
|
518
|
-
NftId poolNftId,
|
519
|
-
address bundleOwner,
|
520
|
-
Amount amount
|
521
|
-
)
|
717
|
+
function _getAndVerifyActivePool()
|
522
718
|
internal
|
719
|
+
virtual
|
720
|
+
view
|
721
|
+
returns (
|
722
|
+
NftId poolNftId,
|
723
|
+
IInstance instance
|
724
|
+
)
|
523
725
|
{
|
726
|
+
return PoolLib.getAndVerifyActivePool(getRegistry(), msg.sender);
|
727
|
+
}
|
524
728
|
|
525
|
-
|
526
|
-
|
527
|
-
|
528
|
-
|
729
|
+
// function _getAndVerifyActivePool()
|
730
|
+
// internal
|
731
|
+
// virtual
|
732
|
+
// view
|
733
|
+
// returns (
|
734
|
+
// NftId poolNftId,
|
735
|
+
// IInstance instance
|
736
|
+
// )
|
737
|
+
// {
|
738
|
+
// (
|
739
|
+
// IRegistry.ObjectInfo memory info,
|
740
|
+
// address instanceAddress
|
741
|
+
// ) = ContractLib.getAndVerifyComponent(
|
742
|
+
// getRegistry(),
|
743
|
+
// msg.sender,
|
744
|
+
// POOL(),
|
745
|
+
// true); // only active pools
|
746
|
+
|
747
|
+
// poolNftId = info.nftId;
|
748
|
+
// instance = IInstance(instanceAddress);
|
749
|
+
// }
|
529
750
|
|
530
|
-
if(amount.gtz()) {
|
531
|
-
// TODO: centralize token handling (issue #471)
|
532
|
-
tokenHandler.transfer(
|
533
|
-
bundleOwner,
|
534
|
-
poolWallet,
|
535
|
-
amount);
|
536
|
-
}
|
537
|
-
}
|
538
751
|
|
539
752
|
function _getDomain() internal pure override returns(ObjectType) {
|
540
753
|
return POOL();
|